亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cmd_pci405.c

?? 改寫的U-boot for s3c4510 (注意此源碼是在windows下壓縮了)。 1、支持串口下載
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * (C) Copyright 2002-2004 * Stefan Roese, esd gmbh germany, stefan.roese@esd-electronics.com * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */#include <common.h>#include <command.h>#include <malloc.h>#include <net.h>#include <asm/io.h>#include <pci.h>#include <405gp_pci.h>#include <asm/processor.h>#include "pci405.h"#if (CONFIG_COMMANDS & CFG_CMD_BSP)extern int do_bootm (cmd_tbl_t *, int, int, char *[]);extern int do_bootvx (cmd_tbl_t *, int, int, char *[]);unsigned long get_dcr(unsigned short);/* * Command loadpci: wait for signal from host and boot image. */int do_loadpci(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	unsigned int *ptr = 0;	int count = 0;	int count2 = 0;	int status;	int i;	char addr[16];	char str[] = "\\|/-";	char *local_args[2];	/*	 * Mark sync address	 */	ptr = 0;	*ptr = 0xffffffff;	puts("\nWaiting for image from pci host -");	/*	 * Wait for host to write the start address	 */	while (*ptr == 0xffffffff) {		count++;		if (!(count % 100)) {			count2++;			putc(0x08); /* backspace */			putc(str[count2 % 4]);		}		/* Abort if ctrl-c was pressed */		if (ctrlc()) {			puts("\nAbort\n");			return 0;		}		udelay(1000);	}	if (*ptr == PCI_RECONFIG_MAGIC) {		/*		 * Save own pci configuration in PRAM		 */		memset((char *)PCI_REGS_ADDR, 0, PCI_REGS_LEN);		ptr = (unsigned int *)PCI_REGS_ADDR + 1;		for (i=0; i<0x40; i+=4) {			pci_read_config_dword(PCIDEVID_405GP, i, ptr++);		}		ptr = (unsigned int *)PCI_REGS_ADDR;		*ptr = crc32(0, (uchar *)PCI_REGS_ADDR+4, PCI_REGS_LEN-4);		printf("\nStoring PCI Configuration Regs...\n");	} else {		sprintf(addr, "%08x", *ptr);#if 0		/*		 * Boot image		 */		if (*ptr & 0x00000001) {			/*			 * Boot VxWorks image via bootvx			 */			addr[strlen(addr)-1] = '0';			printf("\nBooting VxWorks-Image at addr 0x%s ...\n", addr);			setenv("loadaddr", addr);			local_args[0] = argv[0];			local_args[1] = NULL;			status = do_bootvx (cmdtp, 0, 1, local_args);		} else {			/*			 * Boot image via bootm (normally Linux)			 */			printf("\nBooting Image at addr 0x%s ...\n", addr);			setenv("loadaddr", addr);			local_args[0] = argv[0];			local_args[1] = NULL;			status = do_bootm (cmdtp, 0, 1, local_args);		}#else		/*		 * Boot image via bootm		 */		printf("\nBooting Image at addr 0x%s ...\n", addr);		setenv("loadaddr", addr);		local_args[0] = argv[0];		local_args[1] = NULL;		status = do_bootm (cmdtp, 0, 1, local_args);#endif	}	return 0;}U_BOOT_CMD(	loadpci,	1,	1,	do_loadpci,	"loadpci - Wait for pci-image and boot it\n",	NULL);#endif#if 1 /* test-only */int do_getpci(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	unsigned int val;	int i;	printf("\nPCI Configuration Regs for PPC405GP:");	for (i=0; i<0x64; i+=4) {		pci_read_config_dword(PCIDEVID_405GP, i, &val);		if (!(i % 0x10)) {			printf("\n%02x: ", i);		}		printf("%08x ", val);	}	printf("\n");	return 0;}U_BOOT_CMD(	getpci,	1,	1,	do_getpci,	"getpci  - Print own pci configuration registers\n",	NULL);int do_setpci(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	unsigned int addr;	unsigned int val;	addr = simple_strtol (argv[1], NULL, 16);	val = simple_strtol (argv[2], NULL, 16);	printf("\nWriting %08x to PCI reg %08x.\n", val, addr);	pci_write_config_dword(PCIDEVID_405GP, addr, val);	return 0;}U_BOOT_CMD(	setpci,	3,	1,	do_setpci,	"setpci  - Set one pci configuration lword\n",	"<addr> <val>\n"	"        - Write pci configuration lword <val> to <addr>.\n");int do_dumpdcr(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	int i;	printf("\nDevice Configuration Registers (DCR's) for PPC405GP:");	for (i=0; i<=0x1e0; i++) {		if (!(i % 0x8)) {			printf("\n%04x ", i);		}		printf("%08lx ", get_dcr(i));	}	printf("\n");	return 0;}U_BOOT_CMD(	dumpdcr,	1,	1,	do_dumpdcr,	"dumpdcr - Dump all DCR registers\n",	NULL);int do_dumpspr(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	printf("\nSpecial Purpose Registers (SPR's) for PPC405GP:");	printf("\n%04x %08x ", 947, mfspr(947));	printf("\n%04x %08x ", 9, mfspr(9));	printf("\n%04x %08x ", 1014, mfspr(1014));	printf("\n%04x %08x ", 1015, mfspr(1015));	printf("\n%04x %08x ", 1010, mfspr(1010));	printf("\n%04x %08x ", 957, mfspr(957));	printf("\n%04x %08x ", 1008, mfspr(1008));	printf("\n%04x %08x ", 1018, mfspr(1018));	printf("\n%04x %08x ", 954, mfspr(954));	printf("\n%04x %08x ", 950, mfspr(950));	printf("\n%04x %08x ", 951, mfspr(951));	printf("\n%04x %08x ", 981, mfspr(981));	printf("\n%04x %08x ", 980, mfspr(980));	printf("\n%04x %08x ", 982, mfspr(982));	printf("\n%04x %08x ", 1012, mfspr(1012));	printf("\n%04x %08x ", 1013, mfspr(1013));	printf("\n%04x %08x ", 948, mfspr(948));	printf("\n%04x %08x ", 949, mfspr(949));	printf("\n%04x %08x ", 1019, mfspr(1019));	printf("\n%04x %08x ", 979, mfspr(979));	printf("\n%04x %08x ", 8, mfspr(8));	printf("\n%04x %08x ", 945, mfspr(945));	printf("\n%04x %08x ", 987, mfspr(987));	printf("\n%04x %08x ", 287, mfspr(287));	printf("\n%04x %08x ", 953, mfspr(953));	printf("\n%04x %08x ", 955, mfspr(955));	printf("\n%04x %08x ", 272, mfspr(272));	printf("\n%04x %08x ", 273, mfspr(273));	printf("\n%04x %08x ", 274, mfspr(274));	printf("\n%04x %08x ", 275, mfspr(275));	printf("\n%04x %08x ", 260, mfspr(260));	printf("\n%04x %08x ", 276, mfspr(276));	printf("\n%04x %08x ", 261, mfspr(261));	printf("\n%04x %08x ", 277, mfspr(277));	printf("\n%04x %08x ", 262, mfspr(262));	printf("\n%04x %08x ", 278, mfspr(278));	printf("\n%04x %08x ", 263, mfspr(263));	printf("\n%04x %08x ", 279, mfspr(279));	printf("\n%04x %08x ", 26, mfspr(26));	printf("\n%04x %08x ", 27, mfspr(27));	printf("\n%04x %08x ", 990, mfspr(990));	printf("\n%04x %08x ", 991, mfspr(991));	printf("\n%04x %08x ", 956, mfspr(956));	printf("\n%04x %08x ", 284, mfspr(284));	printf("\n%04x %08x ", 285, mfspr(285));	printf("\n%04x %08x ", 986, mfspr(986));	printf("\n%04x %08x ", 984, mfspr(984));	printf("\n%04x %08x ", 256, mfspr(256));	printf("\n%04x %08x ", 1, mfspr(1));	printf("\n%04x %08x ", 944, mfspr(944));	printf("\n");	return 0;}U_BOOT_CMD(	dumpspr,	1,	1,	do_dumpspr,	"dumpspr - Dump all SPR registers\n",	NULL);#define PCI0_BRDGOPT1 0x4a#define plb0_acr      0x87int do_getplb(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	unsigned short val;	printf("PLB0_ACR=%08lx\n", get_dcr(0x87));	pci_read_config_word(PCIDEVID_405GP, PCI0_BRDGOPT1, &val);	printf("PCI0_BRDGOPT1=%04x\n", val);	printf("CCR0=%08x\n", mfspr(ccr0));	return 0;}U_BOOT_CMD(	getplb,	1,	1,	do_getplb,	"getplb  - Dump all plb arbiter registers\n",	NULL);int do_setplb(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	unsigned int my_acr;	unsigned int my_brdgopt1;	unsigned int my_ccr0;	my_acr = simple_strtol (argv[1], NULL, 16);	my_brdgopt1 = simple_strtol (argv[2], NULL, 16);	my_ccr0 = simple_strtol (argv[3], NULL, 16);	mtdcr(plb0_acr, my_acr);	pci_write_config_word(PCIDEVID_405GP, PCI0_BRDGOPT1, my_brdgopt1);	mtspr(ccr0, my_ccr0);	return 0;}U_BOOT_CMD(	setplb,	4,	1,	do_setplb,	"setplb  - Set all plb arbiter registers\n",	"PLB0_ACR PCI0_BRDGOPT1 CCR0\n"	"        - Set all plb arbiter registers\n");/*********************************************************************** * * The following code is only for test purposes!!!! * Please ignore this ugly stuff!!!!!!!!!!!!!!!!!!! * ***********************************************************************/#define PCI_ADDR 0xc0000000int do_writepci(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	unsigned int addr;	unsigned int size;	unsigned int countmax;	int i;	int max;	volatile unsigned long *ptr;	volatile unsigned long val;	int loopcount = 0;	int test_pci_read = 0;	int test_pci_cfg_write = 0;	int test_sync = 0;	int test_pci_pre_read = 0;	addr = simple_strtol (argv[1], NULL, 16);	size = simple_strtol (argv[2], NULL, 16);	countmax = simple_strtol (argv[3], NULL, 16);	if (countmax == 0)		countmax = 1000;	do_getplb(NULL, 0, 0, NULL);#if 0	out32r(PMM0LA, 0);	out32r(PMM0PCILA, 0);	out32r(PMM0PCIHA, 0);	out32r(PMM0MA, 0);	out32r(PMM1LA, PCI_ADDR);	out32r(PMM1PCILA, addr & 0xff000000);	out32r(PMM1PCIHA, 0x00000000);	out32r(PMM1MA, 0xff000001);#endif	printf("PMM1LA    =%08lx\n", in32r(PMM1LA));	printf("PMM1MA    =%08lx\n", in32r(PMM1MA));	printf("PMM1PCILA =%08lx\n", in32r(PMM1PCILA));	printf("PMM1PCIHA =%08lx\n", in32r(PMM1PCIHA));	addr = PCI_ADDR | (addr & 0x00ffffff);	printf("\nWriting at addr %08x, size %08x (countmax=%x)\n", addr, size, countmax);	max = size >> 2;	pci_write_config_word(PCIDEVID_405GP, 0x04, 0x0106); /* write command reg */	val = *(ulong *)0x00000000;	if (val & 0x00000008) {		test_pci_pre_read = 1;		printf("Running test with pre pci-memory-read access!\n");	}	if (val & 0x00000004) {		test_sync = 1;		printf("Running test with sync instruction!\n");	}	if (val & 0x00000001) {		test_pci_read = 1;		printf("Running test with pci-memory-read access!\n");	}	if (val & 0x00000002) {		test_pci_cfg_write = 1;		printf("Running test with pci-config-write access!\n");	}	while (1) {		if (test_pci_pre_read) {			/*			 * Read one value back			 */			ptr = (volatile unsigned long *)addr;			val = *ptr;		}		/*		 * Write some values to host via pci busmastering		 */		ptr = (volatile unsigned long *)addr;		for (i=0; i<max; i++) {			*ptr++ = i;		}		if (test_sync) {			/*			 * Sync previous writes			 */			ppcSync();		}		if (test_pci_read) {			/*			 * Read one value back			 */			ptr = (volatile unsigned long *)addr;			val = *ptr;		}		if (test_pci_cfg_write) {			/*			 * Generate IRQ to host via config regs			 */			pci_write_config_byte(PCIDEVID_405GP, 0x44, 0x00);		}		if (loopcount++ > countmax) {			/* Abort if ctrl-c was pressed */			if (ctrlc()) {				puts("\nAbort\n");				return 0;			}			putc('.');			loopcount = 0;		}	}	return 0;}U_BOOT_CMD(	writepci,	4,	1,	do_writepci,	"writepci - Write some data to pcibus\n",	"<addr> <size>\n"	"        - Write some data to pcibus.\n");#define PCI_CFGADDR        0xeec00000#define PCI_CFGDATA        0xeec00004int ibmPciConfigWrite(	int offset,     /* offset into the configuration space */	int width,      /* data width                          */	unsigned int data       /* data to be written                  */	){	/*	 * Write config register address to the PCI config address register	 * bit 31 must be 1 and bits 1:0 must be 0 (note LE bit notation)	 */	out32r(PCI_CFGADDR, 0x80000000 | (offset & 0xFFFFFFFC));#if 0 /* test-only */	ppcSync();#endif	/*	 * Write value to be written to the PCI config data register	 */	switch ( width ) {	case 1: out32r(PCI_CFGDATA | (offset & 0x3), (unsigned char)(data & 0xFF));		break;	case 2: out32r(PCI_CFGDATA | (offset & 0x3), (unsigned short)(data & 0xFFFF));		break;	case 4:	out32r(PCI_CFGDATA | (offset & 0x3), data);		break;	}	return (0);}int do_writepci2(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www国产成人| av电影在线不卡| 国产福利一区二区三区视频在线 | 色综合久久久久综合| 91美女蜜桃在线| 欧美成人女星排行榜| 国产精品免费免费| 青青青爽久久午夜综合久久午夜| www.66久久| 亚洲精品一区二区三区精华液| 夜夜爽夜夜爽精品视频| 国产成人免费在线观看| 正在播放亚洲一区| 亚洲综合一二区| av动漫一区二区| 国产女同互慰高潮91漫画| 秋霞影院一区二区| 欧美日韩一区二区三区高清| 国产精品嫩草久久久久| 国产精品一二三区| 亚洲在线观看免费视频| 91精品国产麻豆| 亚洲三级久久久| 高清不卡在线观看| 久久欧美一区二区| 蜜臀va亚洲va欧美va天堂| 欧美视频一区二区三区在线观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 日韩一区二区视频在线观看| 亚洲国产精品麻豆| 欧美午夜精品久久久久久超碰| 中文字幕一区免费在线观看| 成人夜色视频网站在线观看| 久久久91精品国产一区二区精品| 久久国产精品72免费观看| 91精品在线麻豆| 日本特黄久久久高潮| 6080国产精品一区二区| 日本成人中文字幕| 国产激情一区二区三区四区| 久久先锋资源网| 蜜臂av日日欢夜夜爽一区| 欧美高清一级片在线| 婷婷综合在线观看| 欧美伦理影视网| 日韩激情视频网站| 欧美mv日韩mv国产网站app| 久久99国产精品尤物| 久久亚洲精品国产精品紫薇| 国产精品一区免费在线观看| 欧美激情一二三区| 色拍拍在线精品视频8848| 亚洲综合男人的天堂| 制服丝袜亚洲色图| 精品一区二区三区久久久| 久久久一区二区| 91原创在线视频| 五月天激情综合网| 国产精品剧情在线亚洲| 国产69精品久久99不卡| 国产精品夫妻自拍| 欧美亚洲综合在线| 麻豆成人av在线| 国产欧美一区二区三区在线老狼| 成av人片一区二区| 亚洲综合999| 精品久久人人做人人爱| 成人av小说网| 午夜激情综合网| 国产视频一区不卡| 欧美在线免费播放| 精品一区二区三区视频| 亚洲天堂福利av| 日韩手机在线导航| 99九九99九九九视频精品| 天天操天天干天天综合网| 久久精品亚洲精品国产欧美| 色婷婷国产精品综合在线观看| 日韩av一区二| 一区在线观看免费| 日韩一卡二卡三卡四卡| 99精品欧美一区二区三区小说 | 精品一区精品二区高清| 国产精品人妖ts系列视频| 欧美日韩黄色一区二区| 成人午夜激情视频| 久久精品国产一区二区三 | 一区二区三区精品久久久| 日韩一级片网站| 色婷婷综合五月| 国产成人综合在线观看| 天堂久久一区二区三区| 中文字幕一区二区5566日韩| 日韩欧美亚洲一区二区| 日本久久电影网| 成人丝袜18视频在线观看| 日本在线观看不卡视频| 亚洲综合在线免费观看| 中文字幕av一区 二区| 日韩一级片在线播放| 欧美日韩不卡在线| 91捆绑美女网站| 国产成人99久久亚洲综合精品| 日韩精品一区第一页| 亚洲电影在线播放| 亚洲精品日韩一| 亚洲丝袜自拍清纯另类| 国产精品国产三级国产aⅴ入口| 久久久一区二区三区捆绑**| 欧美大片在线观看一区二区| 欧美一区二区三区免费在线看| 91国偷自产一区二区三区观看| 99国产精品久久久| 波波电影院一区二区三区| 成人黄色av电影| 成人午夜伦理影院| 99久久婷婷国产综合精品| 成人97人人超碰人人99| 不卡的电视剧免费网站有什么| 国产98色在线|日韩| 国产精品一区二区在线观看网站 | 丰满放荡岳乱妇91ww| 国产精品99久久不卡二区| 国产伦精一区二区三区| 国产乱人伦偷精品视频不卡| 国产激情一区二区三区桃花岛亚洲| 99久久综合国产精品| 国产成人自拍在线| 不卡的看片网站| 一本大道av伊人久久综合| 在线观看欧美日本| 6080日韩午夜伦伦午夜伦| 欧美v亚洲v综合ⅴ国产v| 久久久国产精品午夜一区ai换脸| 日本一区二区三区在线不卡| 亚洲国产精品v| 一区二区三区精品视频在线| 亚洲第一成人在线| 精品一区二区在线看| 国产精品亚洲а∨天堂免在线| 成人黄色一级视频| 欧美四级电影在线观看| 欧美电影免费观看高清完整版| 久久久久综合网| 亚洲美女偷拍久久| 三级成人在线视频| 国产精品18久久久久久久久久久久 | 国产精品1024久久| 91久久精品国产91性色tv| 欧美日韩亚洲不卡| 26uuu国产一区二区三区| 国产精品久久久久久久久久久免费看| 亚洲视频一区二区免费在线观看| 国产日韩v精品一区二区| 日韩理论片中文av| 亚洲精品视频一区| 蜜桃视频在线观看一区| 成人污视频在线观看| 欧美三级在线视频| 久久综合成人精品亚洲另类欧美| 国产精品麻豆一区二区| 五月天久久比比资源色| 丁香激情综合五月| 6080国产精品一区二区| 欧美激情综合网| 三级一区在线视频先锋| www.亚洲色图| www国产亚洲精品久久麻豆| 亚洲最大成人网4388xx| 国产盗摄一区二区| 欧美精品久久99久久在免费线 | 精品一区二区三区影院在线午夜| av动漫一区二区| 久久蜜桃av一区精品变态类天堂| 欧美日韩一区久久| 国产精品原创巨作av| 欧美中文字幕一区| 国产偷v国产偷v亚洲高清| 亚洲国产综合在线| 97久久超碰国产精品电影| 精品免费一区二区三区| 亚洲福中文字幕伊人影院| 不卡一二三区首页| 久久久国产午夜精品| 美女国产一区二区三区| 欧美综合色免费| 亚洲人成在线播放网站岛国| 国产精品18久久久久久久网站| 欧美一级久久久| 亚洲永久精品国产| 色香色香欲天天天影视综合网| 国产精品萝li| 国产成人免费视频网站高清观看视频| 欧美一区二区在线看| 一区二区久久久久| 日本高清不卡视频| 亚洲精品乱码久久久久久久久| 99国产精品一区| 中文字幕一区二区三区不卡在线| 成人精品小蝌蚪|