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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? flash.c

?? gumstiz u-boot loader in linux
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
		flash_write_cmd (info, sector, 0, FLASH_CMD_PROTECT_CLEAR);	if ((retcode =	     flash_full_status_check (info, sector, info->erase_blk_tout,				      prot ? "protect" : "unprotect")) == 0) {		info->protect[sector] = prot;		/* Intel's unprotect unprotects all locking */		if (prot == 0) {			int i;			for (i = 0; i < info->sector_count; i++) {				if (info->protect[i])					flash_real_protect (info, i, 1);			}		}	}	return retcode;}/*----------------------------------------------------------------------- *  wait for XSR.7 to be set. Time out with an error if it does not. *  This routine does not set the flash to read-array mode. */static int flash_status_check (flash_info_t * info, ulong sector, ulong tout,			       char *prompt){	ulong start;	/* Wait for command completion */	start = get_timer (0);	while (!flash_isset (info, sector, 0, FLASH_STATUS_DONE)) {		if (get_timer (start) > info->erase_blk_tout) {			printf ("Flash %s timeout at address %lx\n", prompt,				info->start[sector]);			flash_write_cmd (info, sector, 0, FLASH_CMD_RESET);			return ERR_TIMOUT;		}	}	return ERR_OK;}/*----------------------------------------------------------------------- * Wait for XSR.7 to be set, if it times out print an error, otherwise do a full status check. * This routine sets the flash to read-array mode. */static int flash_full_status_check (flash_info_t * info, ulong sector,				    ulong tout, char *prompt){	int retcode;	retcode = flash_status_check (info, sector, tout, prompt);	if ((retcode == ERR_OK)	    && !flash_isequal (info, sector, 0, FLASH_STATUS_DONE)) {		retcode = ERR_INVAL;		printf ("Flash %s error at address %lx\n", prompt,			info->start[sector]);		if (flash_isset		    (info, sector, 0,		     FLASH_STATUS_ECLBS | FLASH_STATUS_PSLBS)) {			printf ("Command Sequence Error.\n");		} else if (flash_isset (info, sector, 0, FLASH_STATUS_ECLBS)) {			printf ("Block Erase Error.\n");			retcode = ERR_NOT_ERASED;		} else if (flash_isset (info, sector, 0, FLASH_STATUS_PSLBS)) {			printf ("Locking Error\n");		}		if (flash_isset (info, sector, 0, FLASH_STATUS_DPS)) {			printf ("Block locked.\n");			retcode = ERR_PROTECTED;		}		if (flash_isset (info, sector, 0, FLASH_STATUS_VPENS))			printf ("Vpp Low Error.\n");	}	flash_write_cmd (info, sector, 0, FLASH_CMD_RESET);	return retcode;}/*----------------------------------------------------------------------- */static void flash_add_byte (flash_info_t * info, cfiword_t * cword, uchar c){	switch (info->portwidth) {	case FLASH_CFI_8BIT:		cword->c = c;		break;	case FLASH_CFI_16BIT:		cword->w = (cword->w << 8) | c;		break;	case FLASH_CFI_32BIT:		cword->l = (cword->l << 8) | c;	}}/*----------------------------------------------------------------------- * make a proper sized command based on the port and chip widths */static void flash_make_cmd (flash_info_t * info, uchar cmd, void *cmdbuf){	/*int i; */	uchar *cp = (uchar *) cmdbuf;	/* for(i=0; i< info->portwidth; i++) */	/*  *cp++ = ((i+1) % info->chipwidth) ? '\0':cmd; */	if (info->portwidth == FLASH_CFI_8BIT	    && info->chipwidth == FLASH_CFI_16BIT) {		cp[0] = cmd;	} else if (info->portwidth == FLASH_CFI_16BIT		   && info->chipwidth == FLASH_CFI_16BIT) {		cp[0] = '\0';		cp[1] = cmd;	};}/* * Write a proper sized command to the correct address */static void flash_write_cmd (flash_info_t * info, int sect, uchar offset,			     uchar cmd){	volatile cfiptr_t addr;	cfiword_t cword;	addr.cp = flash_make_addr (info, sect, offset);	flash_make_cmd (info, cmd, &cword);	switch (info->portwidth) {	case FLASH_CFI_8BIT:		*addr.cp = cword.c;		break;	case FLASH_CFI_16BIT:		*addr.wp = cword.w;		break;	case FLASH_CFI_32BIT:		*addr.lp = cword.l;		break;	}}/*----------------------------------------------------------------------- */static int flash_isequal (flash_info_t * info, int sect, uchar offset,			  uchar cmd){	cfiptr_t cptr;	cfiword_t cword;	int retval;	cptr.cp = flash_make_addr (info, sect, offset);	flash_make_cmd (info, cmd, &cword);	switch (info->portwidth) {	case FLASH_CFI_8BIT:		retval = (cptr.cp[0] == cword.c);		break;	case FLASH_CFI_16BIT:		retval = (cptr.wp[0] == cword.w);		break;	case FLASH_CFI_32BIT:		retval = (cptr.lp[0] == cword.l);		break;	default:		retval = 0;		break;	}	return retval;}/*----------------------------------------------------------------------- */static int flash_isset (flash_info_t * info, int sect, uchar offset,			uchar cmd){	cfiptr_t cptr;	cfiword_t cword;	int retval;	cptr.cp = flash_make_addr (info, sect, offset);	flash_make_cmd (info, cmd, &cword);	switch (info->portwidth) {	case FLASH_CFI_8BIT:		retval = ((cptr.cp[0] & cword.c) == cword.c);		break;	case FLASH_CFI_16BIT:		retval = ((cptr.wp[0] & cword.w) == cword.w);		break;	case FLASH_CFI_32BIT:		retval = ((cptr.lp[0] & cword.l) == cword.l);		break;	default:		retval = 0;		break;	}	return retval;}/*----------------------------------------------------------------------- * detect if flash is compatible with the Common Flash Interface (CFI) * http://www.jedec.org/download/search/jesd68.pdf **/static int flash_detect_cfi (flash_info_t * info){#if 0	for (info->portwidth = FLASH_CFI_8BIT;	     info->portwidth <= FLASH_CFI_32BIT; info->portwidth <<= 1) {		for (info->chipwidth = FLASH_CFI_BY8;		     info->chipwidth <= info->portwidth;		     info->chipwidth <<= 1) {			flash_write_cmd (info, 0, 0, FLASH_CMD_RESET);			flash_write_cmd (info, 0, FLASH_OFFSET_CFI,					 FLASH_CMD_CFI);			if (flash_isequal			    (info, 0, FLASH_OFFSET_CFI_RESP, 'Q')			    && flash_isequal (info, 0,					      FLASH_OFFSET_CFI_RESP + 1, 'R')			    && flash_isequal (info, 0,					      FLASH_OFFSET_CFI_RESP + 2, 'Y'))				return 1;		}	}#endif	flash_write_cmd (info, 0, 0, FLASH_CMD_RESET);	flash_write_cmd (info, 0, FLASH_OFFSET_CFI, FLASH_CMD_CFI);	if (flash_isequal (info, 0, FLASH_OFFSET_CFI_RESP, 'Q') &&	    flash_isequal (info, 0, FLASH_OFFSET_CFI_RESP + 1, 'R') &&	    flash_isequal (info, 0, FLASH_OFFSET_CFI_RESP + 2, 'Y')) {		return 1;	} else {		return 0;	};}/* * The following code cannot be run from FLASH! * */static ulong flash_get_size (ulong base, int banknum){	flash_info_t *info = &flash_info[banknum];	int i, j;	int sect_cnt;	unsigned long sector;	unsigned long tmp;	int size_ratio;	uchar num_erase_regions;	int erase_region_size;	int erase_region_count;	info->start[0] = base;	if (flash_detect_cfi (info)) {#ifdef DEBUG_FLASH		printf ("portwidth=%d chipwidth=%d\n", info->portwidth, info->chipwidth);	/* test-only */#endif		size_ratio = 1;	/* info->portwidth / info->chipwidth; */		num_erase_regions =			flash_read_uchar (info,					  FLASH_OFFSET_NUM_ERASE_REGIONS);#ifdef DEBUG_FLASH		printf ("found %d erase regions\n", num_erase_regions);#endif		sect_cnt = 0;		sector = base;		for (i = 0; i < num_erase_regions; i++) {			if (i > NUM_ERASE_REGIONS) {				printf ("%d erase regions found, only %d used\n", num_erase_regions, NUM_ERASE_REGIONS);				break;			}			tmp = flash_read_long (info, 0,					       FLASH_OFFSET_ERASE_REGIONS);			erase_region_count = (tmp & 0xffff) + 1;			tmp >>= 16;			erase_region_size =				(tmp & 0xffff) ? ((tmp & 0xffff) * 256) : 128;			for (j = 0; j < erase_region_count; j++) {				info->start[sect_cnt] = sector;				sector += (erase_region_size * size_ratio);				info->protect[sect_cnt] =					flash_isset (info, sect_cnt,						     FLASH_OFFSET_PROTECT,						     FLASH_STATUS_PROTECT);				sect_cnt++;			}		}		info->sector_count = sect_cnt;		/* multiply the size by the number of chips */		info->size =			(1 << flash_read_uchar (info, FLASH_OFFSET_SIZE)) *			size_ratio;		info->buffer_size =			(1 <<			 flash_read_ushort (info, 0,					    FLASH_OFFSET_BUFFER_SIZE));		tmp = 1 << flash_read_uchar (info, FLASH_OFFSET_ETOUT);		info->erase_blk_tout =			(tmp *			 (1 <<			  flash_read_uchar (info, FLASH_OFFSET_EMAX_TOUT)));		tmp = 1 << flash_read_uchar (info, FLASH_OFFSET_WBTOUT);		info->buffer_write_tout =			(tmp *			 (1 <<			  flash_read_uchar (info, FLASH_OFFSET_WBMAX_TOUT)));		tmp = 1 << flash_read_uchar (info, FLASH_OFFSET_WTOUT);		info->write_tout =			(tmp *			 (1 <<			  flash_read_uchar (info,					    FLASH_OFFSET_WMAX_TOUT))) / 1000;		info->flash_id = FLASH_MAN_CFI;	}	flash_write_cmd (info, 0, 0, FLASH_CMD_RESET);	return (info->size);}/*----------------------------------------------------------------------- */static int flash_write_cfiword (flash_info_t * info, ulong dest,				cfiword_t cword){	cfiptr_t ctladdr;	cfiptr_t cptr;	int flag;	ctladdr.cp = flash_make_addr (info, 0, 0);	cptr.cp = (uchar *) dest;	/* Check if Flash is (sufficiently) erased */	switch (info->portwidth) {	case FLASH_CFI_8BIT:		flag = ((cptr.cp[0] & cword.c) == cword.c);		break;	case FLASH_CFI_16BIT:		flag = ((cptr.wp[0] & cword.w) == cword.w);		break;	case FLASH_CFI_32BIT:		flag = ((cptr.lp[0] & cword.l) == cword.l);		break;	default:		return 2;	}	if (!flag)		return 2;	/* Disable interrupts which might cause a timeout here */	flag = disable_interrupts ();	flash_write_cmd (info, 0, 0, FLASH_CMD_CLEAR_STATUS);	flash_write_cmd (info, 0, 0, FLASH_CMD_WRITE);	switch (info->portwidth) {	case FLASH_CFI_8BIT:		cptr.cp[0] = cword.c;		break;	case FLASH_CFI_16BIT:		cptr.wp[0] = cword.w;		break;	case FLASH_CFI_32BIT:		cptr.lp[0] = cword.l;		break;	}	/* re-enable interrupts if necessary */	if (flag)		enable_interrupts ();	return flash_full_status_check (info, 0, info->write_tout, "write");}#ifdef CFG_FLASH_USE_BUFFER_WRITE/* loop through the sectors from the highest address * when the passed address is greater or equal to the sector address * we have a match */static int find_sector (flash_info_t * info, ulong addr){	int sector;	for (sector = info->sector_count - 1; sector >= 0; sector--) {		if (addr >= info->start[sector])			break;	}	return sector;}static int flash_write_cfibuffer (flash_info_t * info, ulong dest, uchar * cp,				  int len){	int sector;	int cnt;	int retcode;	volatile cfiptr_t src;	volatile cfiptr_t dst;	src.cp = cp;	dst.cp = (uchar *) dest;	sector = find_sector (info, dest);	flash_write_cmd (info, sector, 0, FLASH_CMD_CLEAR_STATUS);	flash_write_cmd (info, sector, 0, FLASH_CMD_WRITE_TO_BUFFER);	if ((retcode =	     flash_status_check (info, sector, info->buffer_write_tout,				 "write to buffer")) == ERR_OK) {		switch (info->portwidth) {		case FLASH_CFI_8BIT:			cnt = len;			break;		case FLASH_CFI_16BIT:			cnt = len >> 1;			break;		case FLASH_CFI_32BIT:			cnt = len >> 2;			break;		default:			return ERR_INVAL;			break;		}		flash_write_cmd (info, sector, 0, (uchar) cnt - 1);		while (cnt-- > 0) {			switch (info->portwidth) {			case FLASH_CFI_8BIT:				*dst.cp++ = *src.cp++;				break;			case FLASH_CFI_16BIT:				*dst.wp++ = *src.wp++;				break;			case FLASH_CFI_32BIT:				*dst.lp++ = *src.lp++;				break;			default:				return ERR_INVAL;				break;			}		}		flash_write_cmd (info, sector, 0,				 FLASH_CMD_WRITE_BUFFER_CONFIRM);		retcode =			flash_full_status_check (info, sector,						 info->buffer_write_tout,						 "buffer write");	}	flash_write_cmd (info, sector, 0, FLASH_CMD_CLEAR_STATUS);	return retcode;}#endif /* CFG_USE_FLASH_BUFFER_WRITE */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品日韩av一区二区| 中文字幕第一区第二区| aaa欧美色吧激情视频| 日韩精品1区2区3区| 国产欧美精品日韩区二区麻豆天美| 欧美性色黄大片手机版| 国产成人av一区二区三区在线观看| 日本韩国精品一区二区在线观看| 裸体在线国模精品偷拍| 一区二区成人在线| 日本一区二区在线不卡| 日韩久久免费av| 成人免费看的视频| 日本韩国欧美在线| 成人精品国产福利| 久久精品国产99久久6| 亚洲国产成人av好男人在线观看| 国产精品久久久久影视| 精品国精品国产| 欧美电影在哪看比较好| 92国产精品观看| 国产999精品久久| 国内偷窥港台综合视频在线播放| 婷婷中文字幕一区三区| 亚洲日本在线视频观看| 国产欧美一区二区精品久导航| 8v天堂国产在线一区二区| 日本精品视频一区二区| 97精品久久久久中文字幕 | 国产综合久久久久久久久久久久| 亚洲伊人色欲综合网| 亚洲视频一区二区免费在线观看 | 欧美电影免费观看高清完整版在 | 99久久伊人精品| 国产精品123区| 国产一区二三区| 国产在线日韩欧美| 黄页视频在线91| 国产在线精品免费| 久久精品国产秦先生| 久久精品久久精品| 精品一区中文字幕| 激情六月婷婷综合| 国产精品99久久久久久久女警| 久久99国内精品| 国产综合一区二区| 国产精品456| 成人美女视频在线观看18| 成人污视频在线观看| 成人午夜电影久久影院| 99久久精品久久久久久清纯| 97se亚洲国产综合自在线不卡 | 精品国内二区三区| 精品国产免费视频| 亚洲国产精品黑人久久久| 最新日韩av在线| 一区二区激情小说| 亚洲午夜久久久久久久久电影网| 亚洲国产精品久久人人爱| 日日欢夜夜爽一区| 精品一区二区三区在线视频| 狠狠色狠狠色合久久伊人| 国产精品亚洲专一区二区三区| 不卡视频免费播放| 欧美天堂亚洲电影院在线播放| 777色狠狠一区二区三区| 欧美成人性战久久| 国产精品原创巨作av| 成人激情动漫在线观看| 欧美在线影院一区二区| 欧美一区二区播放| 欧美激情一区二区三区全黄| 亚洲综合精品久久| 久久精品国内一区二区三区| 国产69精品久久777的优势| 93久久精品日日躁夜夜躁欧美| 精品婷婷伊人一区三区三| 精品国产制服丝袜高跟| 亚洲人成网站在线| 久久精品理论片| 一本大道久久a久久综合婷婷| 日韩三级伦理片妻子的秘密按摩| 欧美国产激情一区二区三区蜜月| 亚洲一区二区影院| 国产乱对白刺激视频不卡| 色婷婷国产精品| 2021国产精品久久精品| 一区二区三区中文字幕精品精品| 久久精品国产亚洲5555| 色综合天天狠狠| 久久婷婷一区二区三区| 亚洲国产视频网站| 大尺度一区二区| 欧美一区二区三区性视频| 亚洲欧美另类小说| 精品一区二区三区视频在线观看 | 国产精品18久久久久久久久久久久| 中文字幕av资源一区| 午夜激情久久久| 99久久伊人网影院| 精品国产乱码久久久久久1区2区 | 九九九精品视频| 在线看一区二区| 国产欧美精品国产国产专区| 五月天一区二区| a在线播放不卡| 久久久久久夜精品精品免费| 丝袜美腿高跟呻吟高潮一区| 91在线视频观看| 国产女人水真多18毛片18精品视频 | 久久麻豆一区二区| 婷婷开心激情综合| 成人的网站免费观看| 精品国产乱码久久久久久老虎| 亚洲成人av福利| 在线观看亚洲专区| 亚洲图片另类小说| 国产 欧美在线| 久久色成人在线| 久久99久久精品欧美| 91精品国产综合久久久蜜臀粉嫩 | 精品一区二区在线播放| 777a∨成人精品桃花网| 性做久久久久久免费观看 | 2023国产精品| 精品一区二区影视| 精品日韩av一区二区| 久久不见久久见免费视频1| 538在线一区二区精品国产| 亚洲精品第1页| 国产精品久久久久久久久快鸭| 极品销魂美女一区二区三区| 91精品国产综合久久香蕉的特点 | 成人av动漫网站| 国产免费成人在线视频| 丁香天五香天堂综合| 欧美国产1区2区| 91亚洲永久精品| 国产精品国产馆在线真实露脸 | 国产69精品一区二区亚洲孕妇 | 婷婷丁香激情综合| 在线电影欧美成精品| 免费在线观看一区二区三区| 欧美大白屁股肥臀xxxxxx| 久久国产婷婷国产香蕉| 欧美精品一区二区久久婷婷| 老司机精品视频线观看86| 精品国产一区二区三区不卡 | 不卡一区二区在线| 亚洲欧洲另类国产综合| 日本电影欧美片| 天天影视涩香欲综合网| 欧美一区二区日韩| 国内国产精品久久| 国产精品色婷婷久久58| 91论坛在线播放| 日韩中文欧美在线| 精品国内二区三区| 99久久99久久免费精品蜜臀| 亚洲综合色噜噜狠狠| 欧美一区二区三区日韩视频| 国内一区二区在线| |精品福利一区二区三区| 欧美视频精品在线观看| 蜜臀99久久精品久久久久久软件| 国产亚洲欧美日韩俺去了| 99久久精品国产一区| 天天操天天综合网| 国产亚洲视频系列| 欧美中文字幕一区| 精品写真视频在线观看| 亚洲欧洲三级电影| 91精品国产综合久久精品app | 不卡的av电影| 午夜欧美大尺度福利影院在线看| 日韩美女一区二区三区四区| 成人午夜视频在线观看| 午夜激情久久久| 国产嫩草影院久久久久| 欧美日韩精品一区视频| 国产伦理精品不卡| 亚洲444eee在线观看| 国产欧美一区二区精品秋霞影院| 欧美午夜免费电影| 成人午夜免费视频| 男女性色大片免费观看一区二区 | 亚洲超丰满肉感bbw| 久久日韩粉嫩一区二区三区| 日本黄色一区二区| 国产激情视频一区二区在线观看| 夜夜嗨av一区二区三区四季av | 91免费视频大全| 久久精品国产网站| 亚洲一二三四区不卡| 国产欧美一区二区三区网站| 欧美一级在线免费| 日本精品一区二区三区高清| 国产成人在线网站| 蜜桃av一区二区三区电影| 亚洲精品第1页|