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

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

?? nand.c

?? arm9處理器
?? C
?? 第 1 頁 / 共 2 頁
字號:
		mcr	p15, 0, r1, c7, c5, 0	/* invalidate I cache */
		mcr	p15, 0, r1, c7, c10, 4	/* drain WB */
	}
}
void cache_clean_invalidate(void)
{
	cpu_arm920_cache_clean_invalidate_all();
}

static __inline void cpu_arm920_tlb_invalidate_all(void)
{
	__asm{
		mov	r0, #0
		mcr	p15, 0, r0, c7, c10, 4	/* drain WB */
		mcr	p15, 0, r0, c8, c7, 0	/* invalidate I & D TLBs */
	}
}

void tlb_invalidate(void)
{
	cpu_arm920_tlb_invalidate_all();
}

void disable_irq(void);

void call_linux(U32 a0, U32 a1, U32 a2)
{
	void (*goto_start)(U32, U32);
	
	rINTMSK=BIT_ALLMSK;
	
	cache_clean_invalidate();
	tlb_invalidate();	

	__asm{
//		mov	r0, a0//%0
//		mov	r1, a1//%1
//		mov	r2, a2//%2
		mov	ip, #0
		mcr	p15, 0, ip, c13, c0, 0	/* zero PID */
		mcr	p15, 0, ip, c7, c7, 0	/* invalidate I,D caches */
		mcr	p15, 0, ip, c7, c10, 4	/* drain write buffer */
		mcr	p15, 0, ip, c8, c7, 0	/* invalidate I,D TLBs */
		mrc	p15, 0, ip, c1, c0, 0	/* get control register */
		bic	ip, ip, #0x0001			/* disable MMU */
		mcr	p15, 0, ip, c1, c0, 0	/* write control register */
		//mov	pc, r2
		//nop
		//nop
		/* no outpus */
		//: "r" (a0), "r" (a1), "r" (a2)
	}
//	SetClockDivider(1, 1);
//	SetSysFclk(FCLK_200M);		//start kernel, use 200M
	//SET_IF();
	goto_start = (void (*)(U32, U32))a2;
	(*goto_start)(a0, a1);	
}

extern int sprintf(char * /*s*/, const char * /*format*/, ...);

static void LoadRun(void)//引導Linux,feipeng
{
	U32 i, ram_addr, buf = boot_params.run_addr.val;
	struct param_struct *params = (struct param_struct *)0x30000100;
	int size;
	
	memset(params, 0, sizeof(struct param_struct));
	/*{
		U32 *pD = (U32 *)0x30000100;
		
		for(i=0; i<0x1000; i++)
			pD[i] = 0;
	}*/
	if(boot_params.start.val) {
		char parameters[512];
		char *rootfs;
		char initrd[32];
		char *tty_sel;
		char *devfs_sel;
		
		switch (boot_params.root_sel.val) {
		case 0:
			rootfs = "/dev/ram";
			break;
		case 1:
			rootfs = "nfs";
			break;
		case 2:
			rootfs = "/dev/mtdblock2";
			break;
		case 3:
			rootfs = "/dev/mtdblock3";
			break;
		case 4:
			rootfs = "/dev/hda1";
		default:
			rootfs="";	//user define
			break;
		}
	
		if(boot_params.root_sel.val)
			sprintf(initrd, "load_ramdisk=0");
		else
			sprintf(initrd, "initrd=0x%08x,0x%08x",
						boot_params.initrd_addr.val,
						boot_params.initrd_len.val);
	
		switch (boot_params.tty_sel.val) {
		case 0:
			tty_sel="ttyS0";
			break;
		case 1:
			tty_sel="ttyS1";
			break;
		case 2:
			tty_sel="tty1";
			break;
		default:
			tty_sel="";	//user define
			break;
		}
	
		if(boot_params.devfs_sel.val)
			devfs_sel = "devfs=mount";
		else
			devfs_sel = "";
		
		memset(parameters, 0, sizeof(parameters));
		sprintf(parameters,
					"root=%s init=/linuxrc %s console=%s,%d mem=%dK %s %s",
					rootfs,
					initrd,
					tty_sel,
					boot_params.serial_baud.val,
					boot_params.mem_cfg.val>>10,
					devfs_sel,
					boot_params.string);
		
		params->u1.s.page_size = LINUX_PAGE_SIZE;
		params->u1.s.nr_pages = (boot_params.mem_cfg.val >> LINUX_PAGE_SHIFT);
		memcpy(params->commandline, parameters, strlen(parameters));
	
		printf("Set boot params = %s\n", params->commandline);
	}

	printf("Load Kernel...\n");	

	if(boot_params.osstor.val)	//load program from NOR or NAND FLASH
		memcpy((void *)buf, (void *)(0x04000000+0x00020000), 0x001e0000);
	else {
		StartPage = NandPart[1].offset>>9;
		size = NandPart[1].size;
		ram_addr = buf;	
	
		for(i=0; size>0; ) {
			if(!(i&0x1f)) {
				if(CheckBadBlk(i+StartPage)) {
					printf("Skipped bad block at 0x%x\n", i+StartPage);
					i += 32;
					size -= 32<<9;
					continue;
				}
			}
			ReadPage((i+StartPage), (U8 *)ram_addr);
			i++;
			size -= 512;
			ram_addr += 512;
		}
	}
	
	if(!boot_params.root_sel.val) {
		int ramdisk_sz;
		
		printf("Load Ramdisk...\n");
		
		StartPage = NandPart[2].offset>>9;
		size = NandPart[1].size;
		
		ram_addr = boot_params.initrd_addr.val;
		ramdisk_sz = boot_params.initrd_len.val;
		
		for(i=0; size>0&&ramdisk_sz>0; ) {
			if(!(i&0x1f)) {
				if(CheckBadBlk(i+StartPage)) {
					printf("Skipped bad block at 0x%x\n", i+StartPage);
					i += 32;
					size -= 32<<9;
					continue;
				}
			}
			ReadPage((i+StartPage), (U8 *)ram_addr);
			i++;
			size -= 512;
			ram_addr += 512;
			ramdisk_sz -= 512;
		}
	}
	
	DsNandFlash();

		//ChangeClockDivider(13,12);
		//ChangeMPllValue(67,1,1);	//300MHz,2440A!
		//rCLKCON = 0x7fff0;
	call_linux(0, boot_params.machine.val, buf);
}

/************************************************************/
static int have_nandflash;
static void InitNandFlash(int info)//初始化NandFlash,包括配置寄存器和讀芯片ID
{	
	U32 i;
	
	InitNandCfg();//配置NandFlash寄存器,NFCONF和NFCONT
	i = ReadChipId();//讀芯片ID
	if(info)
		printf("Read chip id = %x\n", i);	
	if((i==0x9873)||(i==0xec75))	
		NandAddr = 0;//?
	else if(i==0xec76)
		NandAddr = 1;//?
	else {
		if(info)	
			puts("Chip id error!!!\n");
		have_nandflash = 0;
		return;
	}
	have_nandflash = 1;
	if(info)
		printf("Nand flash status = %x\n", ReadStatus());
}

void NandErase(void)
{
	int i, err = 0;
	
	InitNandFlash(1);
	if(!have_nandflash)
		return;
	
	i = NandSelPart("erase");
	if(i<0)
		return;	
	
	printf("Are you sure to erase nand flash from page 0x%x, block count 0x%x ? [y/n]\n", StartPage, BlockCnt);
	while(1) {
		char c;
		
		c = getch();
		if((c=='y')||(c=='Y'))
			break;
		if((c=='n')||(c=='N'))
			return;
	}	
	
	for(i=0; BlockCnt; BlockCnt--, i+=32) {
		if(EraseBlock(i+StartPage)) {
			err ++;
			puts("Press any key to continue...\n");
			getch();
		}
	}	

	DsNandFlash();		//disable nand flash interface
	puts("Erase Nand partition completed ");
	if(err)
		printf("with %d bad block(s)\n", err);
	else
		puts("success\n");
}

void NandWrite(void)
{
	InitNandFlash(1);
	if(!have_nandflash)
		return;
	WrFileToNF();
	DsNandFlash();		//disable nand flash interface
}

extern MemoryTest(void);
int RelocateNKBIN(U32 img_src, U32 *pStart, U32 *pLength, U32 *pLaunch);

static void LoadRunWince(void)
{
	U32 i, ram_addr, buf = boot_params.initrd_addr.val;
	int size;
	MemoryTest();
	printf("Load Kernel...\n");	

	if(boot_params.osstor.val)	//load program from NOR or NAND FLASH
		memcpy((void *)buf, (void *)(0x04000000+0x00020000), 0x00fe0000);
	else {
		StartPage = NandPart[boot_params.start.val].offset>>9;	//part 2,3...
		size = boot_params.initrd_len.val;//NandPart[boot_params.root_sel.val].size;
		ram_addr = buf;
	
		for(i=0; size>0; ) {
			if(!(i&0x1f)) {
				if(CheckBadBlk(i+StartPage)) {
					printf("Skipped bad block at 0x%x\n", i+StartPage);
					i += 32;
					//size -= 32<<9;
					continue;
				}
			}
			ReadPage((i+StartPage), (U8 *)ram_addr);
			i++;
			size -= 512;
			ram_addr += 512;
		}
	}
	
	printf("run 0x%08x...\n", boot_params.run_addr.val);
	//RelocateNKBIN(buf, &buf, &i, &boot_params.run_addr.val);
	call_linux(0, 0, boot_params.run_addr.val);
}

void NandLoadRun(void)
{
	InitNandFlash(1);
	//if(!have_nandflash)
	//	return;
	if(boot_params.start.val<2)	//linux
		LoadRun();//引導Linux,feipeng
	LoadRunWince();//引導WinCE,feipeng
}

/*
void TestNandFlash(void)
{		
	InitNandFlash();	
	
	while(1)
	{
		U8 key = '2';
		
		puts("\nNand flash operations, press ESC to exit\n");
		puts("1.Write nand flash with download file\n");
		puts("2.Load progam from nand flash and run\n");
		puts("3.Erase nand flash partition\n");
		puts("4.Test nand flash erase, write, read\n");
	
		key = getch();		
		
		if(key==0x1b)
			goto TestNandExit;
		else if(key=='1')
			WrFileToNF();
		else if(key=='2')
			LoadRun();
		else if(key=='3')
			NandErase();
		else if(key=='4')	
			TestFunc();
	}			
TestNandExit:	
	DsNandFlash();		//disable nand flash interface
}*/

#include "norflash.h"
#define	NOR_PARAMS_OFFSET	0x1c000

int search_params(void)
{
	U32 page, page_cnt;
	U8 dat[528];
	BootParams *pBP = (BootParams *)dat;//定義一個pBP指針,指向dat數組,并作強制類型轉換,feipeng
	int ret=-1;
	
	InitNandFlash(0);	//don't show info in InitNandFlash!給info傳參數0表示不打印調試信息,打印也看不到,feipeng
	if(have_nandflash) {
		page     = NandPart[0].offset>>9;//對0分區,bootloader區操作,feipeng
		page_cnt = NandPart[0].size>>9;//2的9次方是512Bytes,除512得出有幾個page,feipeng
	
		//search from the last page
		while(page_cnt--) {
			ReadPage(page+page_cnt, dat);//每個循環讀一頁,feipeng
			if(!strncmp(boot_params.start.flags, pBP->start.flags, 10)) {//比較字符串的前10個字符,相等則跳出,feipeng
				ret = 0;//相等,則ret=0;
				break;
			}
		}
	} else {	
		memcpy(dat, (void *)(NOR_PARAMS_OFFSET), 512);	//now mmu is not set, so use original address
		if(!strncmp(boot_params.start.flags, pBP->start.flags, 10))
			ret = 0;
	}
	
	DsNandFlash();//禁用NandFlash控制器,feipeng
	
	if(!ret) {
		ParamItem *pPIS = &pBP->start, *pPID = &boot_params.start;
		
		for(; pPID<=&boot_params.user_params; pPIS++, pPID++)
			if(!strncmp(pPID->flags, pPIS->flags, sizeof(pPID->flags)))
				pPID->val = pPIS->val;//把Flash中實際存的para賦值給程序中的boot_params,即使程序改了,只要Flash存para部分不重寫,也不變,feipeng
		strncpy(boot_params.string, pPIS->flags, boot_params.user_params.val+1);
		if(boot_params.user_params.val!=strlen(pPID->flags)) {
			memset(boot_params.string, 0, sizeof(boot_params.string));
			boot_params.user_params.val = 0;
		}
	} else {
		//printf("Fail to find boot params! Use Default parameters.\n");
		//don't printf anything before serial initialized!
	}
	
	return ret;
}

//保存在最后兩個page(不是block),應確保程序(包括出現壞塊時)不會覆蓋到最后兩page,(不是block)feipeng
int save_params(void)
{
	U32 page, page_cnt;
	U8 dat[0x20000];
	int ret = 0;
	
	InitNandFlash(1);//info=1,表示打印信息,feipeng
	have_nandflash=1;//多余?feipeng
	if(have_nandflash) {
		memset(dat, 0, sizeof(boot_params));//初始化內存,feipeng
		memcpy(dat, &boot_params, sizeof(boot_params));//拷貝內存,feipeng

		page = (NandPart[1].offset>>9)-64;//計算分區0占了"NandPart[1].offset>>9"個頁(page),再減去64頁,使page指向NandPart[0]的最后64頁的開始,feipeng
	
		for(page_cnt=0; page_cnt<64; page_cnt++) {//先擦一塊,寫32頁,再擦一塊,寫32頁,對最后64頁操作,feipeng
			if(!(page_cnt%32))//64頁共兩塊,按塊擦除,feipeng
				EraseBlock(page);//擦除,傳入頁的參數,實際操作時除32,轉換為塊參數,feipeng
			if(!WritePage(page+page_cnt, dat))//寫一頁,返回0表示出錯?好像和stat定義有矛盾,feipeng
				break;
		}
		if(page_cnt>=64)
			ret = -1;
		printf("Save boot params %s.\n", ret?"fail":"success");
	} else {//對NorFlash的操作,此處不涉及,feipeng
		memcpy(dat, (void *)0x04000000, NOR_PARAMS_OFFSET);
		memcpy(dat+NOR_PARAMS_OFFSET, &boot_params, sizeof(boot_params));
		ProgNorFlash(0, (U32)dat, sizeof(dat));	//28F128
	}
	
	DsNandFlash();
	
	return ret;
}

int set_params(void)
{
	int i, key, chg=0;
	ParamItem *pPID;
	
	printf("\nConfig parameters\n");
	
	do {
		pPID = &boot_params.start;
		for(i=0; pPID<=&boot_params.user_params; pPID++, i++)
			printf("[%d] : %s%-8s is 0x%08x (%d)\n",
						i, (i>9)?"":" ", pPID->flags, pPID->val, pPID->val);
		printf("[%d] : Exit\n", i);
		if(boot_params.user_params.val)
			printf("User parameters is : \"%s\"\n", boot_params.string);
		
		printf("\nplease select item:");
		key = Uart_GetIntNum();
		if(key>=0&&key<i) {
			chg = 1;
			printf("please enter value:");
			i = key;
			if((&boot_params.start + i)==&boot_params.user_params) {
				//確保輸入的字節數不超過127!
				char cmd[128];
				memset(cmd, 0, sizeof(cmd));
				Uart_GetString(cmd);
				strncpy(boot_params.string, cmd, strlen(cmd)+1);
				boot_params.user_params.val = strlen(cmd);
			} else {
				key = Uart_GetIntNum();
				(&boot_params.start + i)->val = key;
			}
		} else
			break;
	} while(1);
	
	if(chg) {
		printf("Do you want to save parameters? press y or Y for save.\n");
		key = getch();
		if(key=='y'||key=='Y')
			save_params();
	}
	
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成国产人片在线观看| 欧美丰满嫩嫩电影| 欧美日韩国产bt| 日韩欧美aaaaaa| 国产精品久久久久天堂| 亚洲成人精品一区二区| 精品中文av资源站在线观看| 成人国产精品免费网站| 欧美日韩亚洲高清一区二区| 亚洲精品一区在线观看| 亚洲久本草在线中文字幕| 日韩电影在线一区| jiyouzz国产精品久久| 4438x成人网最大色成网站| 国产日产精品一区| 午夜精品福利久久久| 成人午夜av影视| 3d成人h动漫网站入口| 国产精品三级在线观看| 丝瓜av网站精品一区二区| 国产成人亚洲精品青草天美| 在线观看日韩高清av| 久久综合九色综合97婷婷女人| 亚洲视频一二区| 免费成人在线影院| 在线精品视频一区二区三四| 26uuu精品一区二区| 亚洲香蕉伊在人在线观| 成人美女视频在线看| 日韩一区二区不卡| 一区二区三区在线视频观看58| 国产真实乱子伦精品视频| 欧美自拍偷拍午夜视频| 国产精品久久夜| 激情成人午夜视频| 欧美另类z0zxhd电影| 综合电影一区二区三区| 国产乱理伦片在线观看夜一区 | 国产欧美精品一区aⅴ影院| 亚洲制服丝袜av| jlzzjlzz亚洲女人18| 久久久国产精品麻豆| 免费人成精品欧美精品| 在线观看中文字幕不卡| 亚洲欧洲成人精品av97| 国产在线不卡一卡二卡三卡四卡| 欧美日韩亚洲综合在线| 亚洲品质自拍视频| 成人av影视在线观看| 久久久国产一区二区三区四区小说| 日韩av一级电影| 一区二区三区在线播| av在线一区二区三区| 国产亚洲精品aa午夜观看| 日本aⅴ精品一区二区三区| 欧美亚洲日本一区| 亚洲欧美日韩成人高清在线一区| 成人精品视频.| 欧美激情中文不卡| 国产成人综合亚洲网站| 国产三级欧美三级日产三级99| 蜜桃久久av一区| 欧美一二三在线| 日本不卡1234视频| 91.成人天堂一区| 三级精品在线观看| 欧美一二三在线| 蜜桃久久av一区| 精品成人在线观看| 精品影院一区二区久久久| 精品日韩在线观看| 国产制服丝袜一区| 久久久噜噜噜久噜久久综合| 国产揄拍国内精品对白| 久久午夜羞羞影院免费观看| 国产精品99久久久久久宅男| 久久久久99精品国产片| 粉嫩欧美一区二区三区高清影视| 国产欧美日韩综合| www.在线成人| 一级日本不卡的影视| 欧美三级电影一区| 日韩和欧美一区二区| 日韩一二三区不卡| 经典三级在线一区| 日本一区二区三级电影在线观看| 成人丝袜视频网| 亚洲精品乱码久久久久久日本蜜臀| 色屁屁一区二区| 图片区日韩欧美亚洲| 日韩精品中午字幕| 国产成人av资源| 亚洲女同一区二区| 欧美丰满美乳xxx高潮www| 精品一区二区三区欧美| 国产女主播视频一区二区| 91蜜桃视频在线| 午夜精品一区二区三区电影天堂| 欧美一级国产精品| 国产成人激情av| 一区二区三区久久久| 91麻豆精品国产91久久久久久久久| 青青草伊人久久| 国产拍欧美日韩视频二区| 91影院在线免费观看| 肉色丝袜一区二区| 国产欧美一区二区在线观看| 在线视频欧美精品| 老司机精品视频导航| 国产精品丝袜91| 在线影院国内精品| 免费的成人av| 专区另类欧美日韩| 日韩一级黄色片| 成人av小说网| 青青青伊人色综合久久| 中文字幕成人在线观看| 欧美视频中文一区二区三区在线观看| 免费成人在线网站| 亚洲欧洲av色图| 免费在线视频一区| 综合自拍亚洲综合图不卡区| 7777精品伊人久久久大香线蕉完整版| 国产米奇在线777精品观看| 亚洲激情图片小说视频| 日韩精品一区二区三区蜜臀| 91小视频免费观看| 麻豆国产欧美日韩综合精品二区| 亚洲丝袜自拍清纯另类| 精品久久久久久久久久久久久久久久久| 成人av在线看| 精品写真视频在线观看| 亚洲激情自拍视频| 久久久久久久久久久久久女国产乱 | 97se亚洲国产综合自在线不卡 | 2023国产一二三区日本精品2022| 97精品视频在线观看自产线路二| 久久精品国产精品青草| 亚洲日本一区二区| 久久久久久久久久久久久久久99 | 久久久久久久网| 成人免费高清在线| 蜜桃一区二区三区四区| 一区二区在线观看免费视频播放| 久久青草欧美一区二区三区| 91丝袜高跟美女视频| 亚洲免费看黄网站| 蜜臀av一级做a爰片久久| 一区二区三区免费网站| 亚洲视频香蕉人妖| 亚洲人午夜精品天堂一二香蕉| 国产精品第四页| 国产精品青草久久| 中文字幕av一区二区三区 | 在线观看91精品国产入口| 色欧美日韩亚洲| 在线观看三级视频欧美| 欧美做爰猛烈大尺度电影无法无天| 91最新地址在线播放| 色国产综合视频| 91成人网在线| 欧美日韩五月天| 欧美人xxxx| 欧美一卡2卡三卡4卡5免费| 欧美一级在线免费| www国产精品av| 中文字幕乱码亚洲精品一区| 亚洲欧洲国产日韩| 亚洲国产美女搞黄色| 午夜精品一区二区三区免费视频| 日韩av午夜在线观看| 国内精品自线一区二区三区视频| 国产精品一区二区果冻传媒| 成人精品视频一区二区三区尤物| 91丝袜美腿高跟国产极品老师| 91国在线观看| 91 com成人网| 久久久久亚洲综合| 国产精品你懂的在线| 亚洲人成小说网站色在线 | 亚洲欧洲精品一区二区三区 | 亚洲综合一二三区| 日韩精品高清不卡| 精品亚洲成a人| 成人高清视频免费观看| 色一情一伦一子一伦一区| 欧美人牲a欧美精品| 精品剧情v国产在线观看在线| 国产亚洲一区二区三区| 亚洲欧美日韩一区二区| 天天色天天操综合| 国产一区二区在线影院| 99在线精品免费| 91精品国产综合久久香蕉麻豆| 26uuu色噜噜精品一区二区| 亚洲人成影院在线观看| 秋霞国产午夜精品免费视频| 成人免费观看男女羞羞视频| 欧美日韩成人一区二区| 久久伊人蜜桃av一区二区|