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

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

?? flash.c

?? gumstiz u-boot loader in linux
?? C
字號(hào):
/* * (C) Copyright 2000 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * 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 *//* * Modified 4/5/2001 * Wait for completion of each sector erase command issued * 4/5/2001 * Chris Hallinan - DS4.COM, Inc. - clh@net1plus.com *//* * Modified July 20, 2001 * Strip down to support ONLY the AMD29F032B. * Dave Updegraff - Cray, Inc. dave@cray.com */#include <common.h>#include <ppc4xx.h>#include <asm/processor.h>/* The flash chip we use... */#define AMD_ID_F032B	0x41	/* 29F032B ID  32 Mbit,64 64Kx8 sectors */#define FLASH_AM320B    0x0009flash_info_t	flash_info[CFG_MAX_FLASH_BANKS]; /* info for FLASH chips	*//*----------------------------------------------------------------------- * Functions */static ulong flash_get_size (vu_long *addr, flash_info_t *info);static int write_word (flash_info_t *info, ulong dest, ulong data);static void flash_get_offsets (ulong base, flash_info_t *info);#define ADDR0           0x5555#define ADDR1           0x2aaa#define FLASH_WORD_SIZE unsigned char/*----------------------------------------------------------------------- */unsigned long flash_init (void){	unsigned long size_b0, size_b1;	int i;	/* Init: no FLASHes known */	for (i=0; i<CFG_MAX_FLASH_BANKS; ++i) {		flash_info[i].flash_id = FLASH_UNKNOWN;	}	/* Static FLASH Bank configuration here - FIXME XXX */	size_b0 = flash_get_size((vu_long *)FLASH_BASE0_PRELIM, &flash_info[0]);	if (flash_info[0].flash_id == FLASH_UNKNOWN) {		printf ("## Unknown FLASH on Bank 0 - Size = 0x%08lx = %ld MB\n",			size_b0, size_b0<<20);	}	/* Only one bank */	if (CFG_MAX_FLASH_BANKS == 1)	  {	    /* Setup offsets */	    flash_get_offsets (FLASH_BASE0_PRELIM, &flash_info[0]);#if 0	    /* Monitor protection ON by default */	    (void)flash_protect(FLAG_PROTECT_SET,				FLASH_BASE0_PRELIM,				FLASH_BASE0_PRELIM+monitor_flash_len-1,				&flash_info[0]);#endif	    size_b1 = 0 ;	    flash_info[0].size = size_b0;	  }	return (size_b0 + size_b1);}/*----------------------------------------------------------------------- */static void flash_get_offsets (ulong base, flash_info_t *info){	int i;	/* set up sector start address table */	for (i = 0; i < info->sector_count; i++)		info->start[i] = base + (i * 0x00010000);}/*----------------------------------------------------------------------- */void flash_print_info  (flash_info_t *info){	int i;	int k;	int size;	int erased;	volatile unsigned long *flash;	if (info->flash_id == FLASH_UNKNOWN) {		printf ("missing or unknown FLASH type\n");		return;	}	switch (info->flash_id & FLASH_VENDMASK) {	case FLASH_MAN_AMD:	printf ("AMD ");		break;	default:		printf ("Unknown Vendor ");	break;	}	switch (info->flash_id & FLASH_TYPEMASK) {	case FLASH_AM320B:printf ("AM29F032B (32 Mbit 64x64KB uniform sectors)\n");				break;	default:		printf ("Unknown Chip Type\n");				break;	}	printf ("  Size: %ld KB in %d Sectors\n",		info->size >> 10, info->sector_count);	printf ("  Sector Start Addresses:");	for (i=0; i<info->sector_count; ++i) {		/*		 * Check if whole sector is erased		 */		if (i != (info->sector_count-1))		  size = info->start[i+1] - info->start[i];		else		  size = info->start[0] + info->size - info->start[i];		erased = 1;		flash = (volatile unsigned long *)info->start[i];		size = size >> 2;        /* divide by 4 for longword access */		for (k=0; k<size; k++)		  {		    if (*flash++ != 0xffffffff)		      {			erased = 0;			break;		      }		  }		if ((i % 5) == 0)			printf ("\n   ");		printf (" %08lX%s%s",			info->start[i],			erased ? " E" : "  ",			info->protect[i] ? "RO " : "   "		);	}	printf ("\n");}/*----------------------------------------------------------------------- *//*----------------------------------------------------------------------- *//* * The following code cannot be run from FLASH! */static ulong flash_get_size (vu_long *addr, flash_info_t *info){	short i;	FLASH_WORD_SIZE value;	ulong base = (ulong)addr;	volatile FLASH_WORD_SIZE *addr2 = (FLASH_WORD_SIZE *)addr;	/* Write auto select command: read Manufacturer ID */	addr2[ADDR0] = (FLASH_WORD_SIZE)0x00AA00AA;	addr2[ADDR1] = (FLASH_WORD_SIZE)0x00550055;	addr2[ADDR0] = (FLASH_WORD_SIZE)0x00900090;	value = addr2[0];	switch (value) {	case (FLASH_WORD_SIZE)AMD_MANUFACT:		info->flash_id = FLASH_MAN_AMD;		break;	default:		info->flash_id = FLASH_UNKNOWN;		info->sector_count = 0;		info->size = 0;		return (0);			/* no or unknown flash	*/	}	value = addr2[1];			/* device ID		*/	switch (value) {	case (FLASH_WORD_SIZE)AMD_ID_F032B:		info->flash_id += FLASH_AM320B;		info->sector_count = 64;		info->size = 0x0400000; /* => 4 MB */		break;	default:		info->flash_id = FLASH_UNKNOWN;		return (0);			/* => no or unknown flash */	}	/* set up sector start address table */	for (i = 0; i < info->sector_count; i++)		info->start[i] = base + (i * 0x00010000);	/* check for protected sectors */	for (i = 0; i < info->sector_count; i++) {		/* read sector protection at sector address, (A7 .. A0) = 0x02 */		/* D0 = 1 if protected */		addr2 = (volatile FLASH_WORD_SIZE *)(info->start[i]);	info->protect[i] = addr2[2] & 1;	}	/*	 * Prevent writes to uninitialized FLASH.	 */	if (info->flash_id != FLASH_UNKNOWN) {		addr2 = (FLASH_WORD_SIZE *)info->start[0];		*addr2 = (FLASH_WORD_SIZE)0x00F000F0;	/* reset bank */	}	return (info->size);}int wait_for_DQ7(flash_info_t *info, int sect){	ulong start, now, last;	volatile FLASH_WORD_SIZE *addr = (FLASH_WORD_SIZE *)(info->start[sect]);	start = get_timer (0);    last  = start;    while ((addr[0] & (FLASH_WORD_SIZE)0x00800080) != (FLASH_WORD_SIZE)0x00800080) {	if ((now = get_timer(start)) > CFG_FLASH_ERASE_TOUT) {	    printf ("Timeout\n");	    return -1;	}	/* show that we're waiting */	if ((now - last) > 1000) {  /* every second */	    putc ('.');	    last = now;	}    }	return 0;}/*----------------------------------------------------------------------- */int	flash_erase (flash_info_t *info, int s_first, int s_last){	volatile FLASH_WORD_SIZE *addr = (FLASH_WORD_SIZE *)(info->start[0]);	volatile FLASH_WORD_SIZE *addr2;	int flag, prot, sect, l_sect;	if ((s_first < 0) || (s_first > s_last)) {		if (info->flash_id == FLASH_UNKNOWN) {			printf ("- missing\n");		} else {			printf ("- no sectors to erase\n");		}		return 1;	}	if (info->flash_id == FLASH_UNKNOWN) {		printf ("Can't erase unknown flash type - aborted\n");		return 1;	}	prot = 0;	for (sect=s_first; sect<=s_last; ++sect) {		if (info->protect[sect]) {			prot++;		}	}	if (prot) {		printf ("- Warning: %d protected sectors will not be erased!\n",			prot);	} else {		printf ("\n");	}	l_sect = -1;	/* Disable interrupts which might cause a timeout here */	flag = disable_interrupts();	/* Start erase on unprotected sectors */	for (sect = s_first; sect<=s_last; sect++) {		if (info->protect[sect] == 0) {	/* not protected */		    addr2 = (FLASH_WORD_SIZE *)(info->start[sect]);		    printf("Erasing sector %p\n", addr2);			addr[ADDR0] = (FLASH_WORD_SIZE)0x00AA00AA;			addr[ADDR1] = (FLASH_WORD_SIZE)0x00550055;			addr[ADDR0] = (FLASH_WORD_SIZE)0x00800080;			addr[ADDR0] = (FLASH_WORD_SIZE)0x00AA00AA;			addr[ADDR1] = (FLASH_WORD_SIZE)0x00550055;			addr2[0] = (FLASH_WORD_SIZE)0x00300030;  /* sector erase */		    l_sect = sect;		    /*		     * Wait for each sector to complete, it's more		     * reliable.  According to AMD Spec, you must		     * issue all erase commands within a specified		     * timeout.  This has been seen to fail, especially		     * if printf()s are included (for debug)!!		     */		    wait_for_DQ7(info, sect);		}	}	/* re-enable interrupts if necessary */	if (flag)		enable_interrupts();	/* wait at least 80us - let's wait 1 ms */	udelay (1000);	/* reset to read mode */	addr = (FLASH_WORD_SIZE *)info->start[0];	addr[0] = (FLASH_WORD_SIZE)0x00F000F0;	/* reset bank */	printf (" done\n");	return 0;}/*----------------------------------------------------------------------- * Copy memory to flash, returns: * 0 - OK * 1 - write timeout * 2 - Flash not erased */int write_buff (flash_info_t *info, uchar *src, ulong addr, ulong cnt){	ulong cp, wp, data;	int i, l, rc;	wp = (addr & ~3);	/* get lower word aligned address */	/*	 * handle unaligned start bytes	 */	if ((l = addr - wp) != 0) {		data = 0;		for (i=0, cp=wp; i<l; ++i, ++cp) {			data = (data << 8) | (*(uchar *)cp);		}		for (; i<4 && cnt>0; ++i) {			data = (data << 8) | *src++;			--cnt;			++cp;		}		for (; cnt==0 && i<4; ++i, ++cp) {			data = (data << 8) | (*(uchar *)cp);		}		if ((rc = write_word(info, wp, data)) != 0) {			return (rc);		}		wp += 4;	}	/*	 * handle word aligned part	 */	while (cnt >= 4) {		data = 0;		for (i=0; i<4; ++i) {			data = (data << 8) | *src++;		}		if ((rc = write_word(info, wp, data)) != 0) {			return (rc);		}		wp  += 4;		cnt -= 4;	}	if (cnt == 0) {		return (0);	}	/*	 * handle unaligned tail bytes	 */	data = 0;	for (i=0, cp=wp; i<4 && cnt>0; ++i, ++cp) {		data = (data << 8) | *src++;		--cnt;	}	for (; i<4; ++i, ++cp) {		data = (data << 8) | (*(uchar *)cp);	}	return (write_word(info, wp, data));}/*----------------------------------------------------------------------- * Write a word to Flash, returns: * 0 - OK * 1 - write timeout * 2 - Flash not erased */static int write_word (flash_info_t *info, ulong dest, ulong data){	volatile FLASH_WORD_SIZE *addr2 = (FLASH_WORD_SIZE *)(info->start[0]);	volatile FLASH_WORD_SIZE *dest2 = (FLASH_WORD_SIZE *)dest;	volatile FLASH_WORD_SIZE *data2 = (FLASH_WORD_SIZE *)&data;	ulong start;	int flag;	int i;	/* Check if Flash is (sufficiently) erased */	if ((*((volatile FLASH_WORD_SIZE *)dest) &	     (FLASH_WORD_SIZE)data) != (FLASH_WORD_SIZE)data) {		return (2);	}	/* Disable interrupts which might cause a timeout here */	flag = disable_interrupts();	for (i=0; i<4/sizeof(FLASH_WORD_SIZE); i++)	  {	    addr2[ADDR0] = (FLASH_WORD_SIZE)0x00AA00AA;	    addr2[ADDR1] = (FLASH_WORD_SIZE)0x00550055;	    addr2[ADDR0] = (FLASH_WORD_SIZE)0x00A000A0;	    dest2[i] = data2[i];	    /* re-enable interrupts if necessary */	    if (flag)	      enable_interrupts();	    /* data polling for D7 */	    start = get_timer (0);	    while ((dest2[i] & (FLASH_WORD_SIZE)0x00800080) !=		   (data2[i] & (FLASH_WORD_SIZE)0x00800080)) {	      if (get_timer(start) > CFG_FLASH_WRITE_TOUT) {		return (1);	      }	    }	  }	return (0);}/*----------------------------------------------------------------------- */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区二区三区视频| 8x8x8国产精品| 五月婷婷综合网| 中文字幕的久久| 这里只有精品视频在线观看| 99精品欧美一区| 麻豆成人91精品二区三区| 中文字幕一区av| 久久久久久麻豆| 在线免费观看一区| 成人免费av资源| 国内精品免费**视频| 亚洲国产精品久久久久婷婷884 | 亚洲欧美在线观看| 精品国产免费久久| 欧美日韩成人高清| 色婷婷av一区二区三区软件 | 国产一区欧美一区| 日一区二区三区| 亚洲在线视频一区| ●精品国产综合乱码久久久久| xf在线a精品一区二区视频网站| 欧美三级日韩三级| 欧洲国内综合视频| 91九色最新地址| 91浏览器在线视频| 99久久精品国产精品久久| 国产成人av一区二区三区在线| 蜜桃视频在线观看一区| 偷拍与自拍一区| 亚洲成人av资源| 亚洲大尺度视频在线观看| 一区二区三区中文字幕电影| 亚洲欧美一区二区在线观看| 国产精品久久777777| 欧美国产禁国产网站cc| 国产欧美一区二区三区在线看蜜臀| 日韩欧美国产一区二区三区| 欧美一区二区三区四区在线观看 | 国产精品88888| 国产资源精品在线观看| 激情综合五月天| 久久99精品久久久久婷婷| 麻豆一区二区三区| 久久精品国产免费看久久精品| 偷拍一区二区三区四区| 日本成人中文字幕| 久久国产尿小便嘘嘘尿| 狠狠色丁香久久婷婷综| 激情综合网最新| 国产不卡高清在线观看视频| 6080亚洲精品一区二区| 在线观看免费视频综合| 欧美日韩国产另类一区| 日韩一级大片在线| 2020国产精品| 国产精品美日韩| 亚洲精品国产成人久久av盗摄| 亚洲另类一区二区| 日韩精品久久久久久| 另类小说视频一区二区| 国产高清久久久| 一本色道久久综合狠狠躁的推荐| 欧美性三三影院| 欧美一区二区三区男人的天堂| 精品乱码亚洲一区二区不卡| 国产校园另类小说区| 国产精品国产三级国产有无不卡| 亚洲免费观看高清在线观看| 日本午夜精品一区二区三区电影 | 国产亚洲欧美一级| 亚洲色图在线播放| 三级欧美韩日大片在线看| 激情偷乱视频一区二区三区| 成人91在线观看| 777精品伊人久久久久大香线蕉| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 久久超级碰视频| 99综合影院在线| 欧美日韩一区二区三区四区五区 | 亚洲亚洲精品在线观看| 麻豆精品精品国产自在97香蕉| 国产大陆精品国产| 欧美日韩一区二区三区在线| 国产亚洲精品资源在线26u| 亚洲蜜臀av乱码久久精品| 捆绑调教一区二区三区| 99久久er热在这里只有精品15| 欧美肥妇毛茸茸| 欧美激情在线看| 日本强好片久久久久久aaa| 成人网页在线观看| 6080午夜不卡| 亚洲人成网站在线| 国内成+人亚洲+欧美+综合在线| 91麻豆免费看| 国产亚洲欧洲一区高清在线观看| 亚洲成a人在线观看| 成人av网站免费观看| 日韩视频永久免费| 亚洲午夜一区二区三区| 成人a免费在线看| 日韩精品一区二区在线| 亚洲一区日韩精品中文字幕| 国产精品综合网| 欧美一区二区三区成人| 亚洲女与黑人做爰| 丁香六月综合激情| 久久综合九色综合97婷婷女人| 亚洲二区视频在线| 久久先锋资源网| 日韩成人dvd| 欧美三级三级三级爽爽爽| 综合av第一页| 成人av网站在线观看| 久久综合99re88久久爱| 日韩av中文字幕一区二区| 欧美色视频在线观看| 亚洲男人电影天堂| 97se狠狠狠综合亚洲狠狠| 久久精品人人做| 极品少妇一区二区| 精品国产乱子伦一区| 奇米影视在线99精品| 51久久夜色精品国产麻豆| 亚洲一区二区三区激情| 欧美亚洲精品一区| 亚洲精品免费在线播放| 色综合久久综合网欧美综合网| 国产精品久久久久一区二区三区共| 国产精品正在播放| 久久亚洲私人国产精品va媚药| 久久爱另类一区二区小说| 日韩欧美国产三级电影视频| 美女网站在线免费欧美精品| 欧美一级电影网站| 蜜桃一区二区三区在线观看| 欧美一区二区三区免费在线看| 亚洲福利视频一区二区| 欧美日韩一区 二区 三区 久久精品| 亚洲一区免费在线观看| 欧美系列在线观看| 调教+趴+乳夹+国产+精品| 4438x亚洲最大成人网| 蜜桃免费网站一区二区三区| 3d动漫精品啪啪一区二区竹菊| 婷婷综合另类小说色区| 911精品国产一区二区在线| 日韩电影在线一区| 2023国产精品自拍| 粉嫩一区二区三区在线看| 日韩伦理av电影| 欧美午夜不卡在线观看免费| 亚洲一区在线播放| 日韩视频一区二区在线观看| 国内成人精品2018免费看| 欧美国产日韩亚洲一区| 色综合久久中文字幕| 亚洲国产裸拍裸体视频在线观看乱了 | 自拍av一区二区三区| 91免费精品国自产拍在线不卡| 亚洲夂夂婷婷色拍ww47| 日韩一区二区在线看| 国产高清精品久久久久| 亚洲品质自拍视频| 欧美精品第1页| 国内精品写真在线观看| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 91国产丝袜在线播放| 日本伊人午夜精品| 国产精品萝li| 欧美午夜不卡在线观看免费| 免费久久精品视频| 欧美激情在线免费观看| 欧美在线短视频| 精品亚洲porn| 亚洲欧美另类久久久精品 | 日韩欧美国产精品一区| 国产成人免费高清| 亚洲第四色夜色| 久久久久久免费毛片精品| 欧美亚洲综合在线| 国产一区二区不卡| 亚洲国产精品久久久久秋霞影院| 久久综合色一综合色88| 色狠狠色狠狠综合| 日本美女视频一区二区| 亚洲欧洲成人av每日更新| 日韩一卡二卡三卡| 色综合久久久久| 国产乱国产乱300精品| 亚洲成人av在线电影| 欧美国产综合色视频| 欧美一级理论片| 91浏览器在线视频| 国产激情视频一区二区三区欧美| 亚洲成av人片一区二区梦乃| 国产精品久久久久aaaa樱花 | 色综合久久久久综合体| 国产中文字幕精品|