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

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

?? flash.c

?? uboot for K9 AT91RM9200 學習板
?? C
字號:
/* * (C) Copyright 2002 * Sysgo Real-Time Solutions, GmbH <www.elinos.com> * Alex Zuepke <azu@sysgo.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 */#include <common.h>ulong myflush(void);#define FLASH_BANK_SIZE	PHYS_FLASH_SIZE#define MAIN_SECT_SIZE  0x10000		/* 64 KB */flash_info_t    flash_info[CFG_MAX_FLASH_BANKS];#define CMD_READ_ARRAY		0x000000F0#define CMD_UNLOCK1		0x000000AA#define CMD_UNLOCK2		0x00000055#define CMD_ERASE_SETUP		0x00000080#define CMD_ERASE_CONFIRM	0x00000030#define CMD_PROGRAM		0x000000A0#define CMD_UNLOCK_BYPASS	0x00000020#define MEM_FLASH_ADDR1		(*(volatile u16 *)(CFG_FLASH_BASE + (0x00000555 << 1)))#define MEM_FLASH_ADDR2		(*(volatile u16 *)(CFG_FLASH_BASE + (0x000002AA << 1)))#define BIT_ERASE_DONE		0x00000080#define BIT_RDY_MASK		0x00000080#define BIT_PROGRAM_ERROR	0x00000020#define BIT_TIMEOUT		0x80000000 /* our flag */#define READY 1#define ERR   2#define TMO   4/*----------------------------------------------------------------------- */ulong flash_init(void){    int i, j;    ulong size = 0;    for (i = 0; i < CFG_MAX_FLASH_BANKS; i++)    {	ulong flashbase = 0;	flash_info[i].flash_id =#if defined(CONFIG_AMD_LV400)	  (AMD_MANUFACT & FLASH_VENDMASK) |	  (AMD_ID_LV400B & FLASH_TYPEMASK);#elif defined(CONFIG_AMD_LV800)	  (AMD_MANUFACT & FLASH_VENDMASK) |	  (AMD_ID_LV800B & FLASH_TYPEMASK);#else#error "Unknown flash configured"#endif	flash_info[i].size = FLASH_BANK_SIZE;	flash_info[i].sector_count = CFG_MAX_FLASH_SECT;	memset(flash_info[i].protect, 0, CFG_MAX_FLASH_SECT);	if (i == 0)	  flashbase = PHYS_FLASH_1;	else	  panic("configured too many flash banks!\n");	for (j = 0; j < flash_info[i].sector_count; j++)	{	    if (j <= 3)	    {		/* 1st one is 16 KB */		if (j == 0)		{			flash_info[i].start[j] = flashbase + 0;		}		/* 2nd and 3rd are both 8 KB */		if ((j == 1) || (j == 2))		{			flash_info[i].start[j] = flashbase + 0x4000 + (j-1)*0x2000;		}		/* 4th 32 KB */		if (j == 3)		{			flash_info[i].start[j] = flashbase + 0x8000;		}	    }	    else	    {		flash_info[i].start[j] = flashbase + (j - 3)*MAIN_SECT_SIZE;	    }	}	size += flash_info[i].size;    }    flash_protect(FLAG_PROTECT_SET,		  CFG_FLASH_BASE,		  CFG_FLASH_BASE + monitor_flash_len - 1,		  &flash_info[0]);    flash_protect(FLAG_PROTECT_SET,		  CFG_ENV_ADDR,		  CFG_ENV_ADDR + CFG_ENV_SIZE - 1,		  &flash_info[0]);    return size;}/*----------------------------------------------------------------------- */void flash_print_info  (flash_info_t *info){    int i;    switch (info->flash_id & FLASH_VENDMASK)    {    case (AMD_MANUFACT & FLASH_VENDMASK):	printf("AMD: ");	break;    default:	printf("Unknown Vendor ");	break;    }    switch (info->flash_id & FLASH_TYPEMASK)    {    case (AMD_ID_LV400B & FLASH_TYPEMASK):	printf("1x Amd29LV400BB (4Mbit)\n");	break;    case (AMD_ID_LV800B & FLASH_TYPEMASK):	printf("1x Amd29LV800BB (8Mbit)\n");	break;    default:	printf("Unknown Chip Type\n");	goto Done;	break;    }    printf("  Size: %ld MB in %d Sectors\n",	   info->size >> 20, info->sector_count);    printf("  Sector Start Addresses:");    for (i = 0; i < info->sector_count; i++)    {	if ((i % 5) == 0)	{	    printf ("\n   ");	}	printf (" %08lX%s", info->start[i],		info->protect[i] ? " (RO)" : "     ");    }    printf ("\n");Done:}/*----------------------------------------------------------------------- */int	flash_erase (flash_info_t *info, int s_first, int s_last){    ushort result;    int iflag, cflag, prot, sect;    int rc = ERR_OK;    int chip;    /* first look for protection bits */    if (info->flash_id == FLASH_UNKNOWN)	return ERR_UNKNOWN_FLASH_TYPE;    if ((s_first < 0) || (s_first > s_last)) {	return ERR_INVAL;    }    if ((info->flash_id & FLASH_VENDMASK) !=	(AMD_MANUFACT & FLASH_VENDMASK)) {	return ERR_UNKNOWN_FLASH_VENDOR;    }    prot = 0;    for (sect=s_first; sect<=s_last; ++sect) {	if (info->protect[sect]) {	    prot++;	}    }    if (prot)	return ERR_PROTECTED;    /*     * Disable interrupts which might cause a timeout     * here. Remember that our exception vectors are     * at address 0 in the flash, and we don't want a     * (ticker) exception to happen while the flash     * chip is in programming mode.     */    cflag = icache_status();    icache_disable();    iflag = disable_interrupts();    /* Start erase on unprotected sectors */    for (sect = s_first; sect<=s_last && !ctrlc(); sect++)    {	printf("Erasing sector %2d ... ", sect);	/* arm simple, non interrupt dependent timer */	reset_timer_masked();	if (info->protect[sect] == 0)	{	/* not protected */	    vu_short *addr = (vu_short *)(info->start[sect]);	    MEM_FLASH_ADDR1 = CMD_UNLOCK1;	    MEM_FLASH_ADDR2 = CMD_UNLOCK2;	    MEM_FLASH_ADDR1 = CMD_ERASE_SETUP;	    MEM_FLASH_ADDR1 = CMD_UNLOCK1;	    MEM_FLASH_ADDR2 = CMD_UNLOCK2;	    *addr = CMD_ERASE_CONFIRM;	    /* wait until flash is ready */	    chip = 0;	    do	    {		result = *addr;		/* check timeout */		if (get_timer_masked() > CFG_FLASH_ERASE_TOUT)		{		    MEM_FLASH_ADDR1 = CMD_READ_ARRAY;		    chip = TMO;		    break;		}		if (!chip && (result & 0xFFFF) & BIT_ERASE_DONE)			chip = READY;		if (!chip && (result & 0xFFFF) & BIT_PROGRAM_ERROR)			chip = ERR;	    }  while (!chip);	    MEM_FLASH_ADDR1 = CMD_READ_ARRAY;	    if (chip == ERR)	    {		rc = ERR_PROG_ERROR;		goto outahere;	    }	    if (chip == TMO)	    {		rc = ERR_TIMOUT;		goto outahere;	    }	    printf("ok.\n");	}	else /* it was protected */	{	    printf("protected!\n");	}    }    if (ctrlc())      printf("User Interrupt!\n");outahere:    /* allow flash to settle - wait 10 ms */    udelay_masked(10000);    if (iflag)      enable_interrupts();    if (cflag)      icache_enable();    return rc;}/*----------------------------------------------------------------------- * Copy memory to flash */volatile static int write_hword (flash_info_t *info, ulong dest, ushort data){    vu_short *addr = (vu_short *)dest;    ushort result;    int rc = ERR_OK;    int cflag, iflag;    int chip;    /*     * Check if Flash is (sufficiently) erased     */    result = *addr;    if ((result & data) != data)	return ERR_NOT_ERASED;    /*     * Disable interrupts which might cause a timeout     * here. Remember that our exception vectors are     * at address 0 in the flash, and we don't want a     * (ticker) exception to happen while the flash     * chip is in programming mode.     */    cflag = icache_status();    icache_disable();    iflag = disable_interrupts();    MEM_FLASH_ADDR1 = CMD_UNLOCK1;    MEM_FLASH_ADDR2 = CMD_UNLOCK2;    MEM_FLASH_ADDR1 = CMD_PROGRAM;    *addr = data;    /* arm simple, non interrupt dependent timer */    reset_timer_masked();    /* wait until flash is ready */    chip = 0;    do    {	result = *addr;	/* check timeout */	if (get_timer_masked() > CFG_FLASH_ERASE_TOUT)	{	    chip = ERR | TMO;	    break;	}	if (!chip && ((result & 0x80) == (data & 0x80)))		chip = READY;	if (!chip && ((result & 0xFFFF) & BIT_PROGRAM_ERROR))	{		result = *addr;		if ((result & 0x80) == (data & 0x80))			chip = READY;		else			chip = ERR;	}    }  while (!chip);    *addr = CMD_READ_ARRAY;    if (chip == ERR || *addr != data)	rc = ERR_PROG_ERROR;    if (iflag)      enable_interrupts();    if (cflag)      icache_enable();    return rc;}/*----------------------------------------------------------------------- * Copy memory to flash. */int write_buff (flash_info_t *info, uchar *src, ulong addr, ulong cnt){    ulong cp, wp;    int l;    int i, rc;    ushort data;    wp = (addr & ~1);	/* 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 << 8);	}	for (; i<2 && cnt>0; ++i) {	    data = (data >> 8) | (*src++ << 8);	    --cnt;	    ++cp;	}	for (; cnt==0 && i<2; ++i, ++cp) {	    data = (data >> 8) | (*(uchar *)cp << 8);	}	if ((rc = write_hword(info, wp, data)) != 0) {	    return (rc);	}	wp += 2;    }    /*     * handle word aligned part     */    while (cnt >= 2) {	data = *((vu_short*)src);	if ((rc = write_hword(info, wp, data)) != 0) {	    return (rc);	}	src += 2;	wp  += 2;	cnt -= 2;    }    if (cnt == 0) {	return ERR_OK;    }    /*     * handle unaligned tail bytes     */    data = 0;    for (i=0, cp=wp; i<2 && cnt>0; ++i, ++cp) {	data = (data >> 8) | (*src++ << 8);	--cnt;    }    for (; i<2; ++i, ++cp) {	data = (data >> 8) | (*(uchar *)cp << 8);    }    return write_hword(info, wp, data);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲在线视频网站| 国产精品高潮呻吟| 在线观看一区二区视频| 成人丝袜高跟foot| 国产大陆精品国产| 成人一区二区三区在线观看 | 成人毛片在线观看| 国产成人精品综合在线观看| 国产一区视频导航| 国产成人aaa| 不卡区在线中文字幕| 99久久夜色精品国产网站| 成人午夜在线免费| 色综合久久综合网| 欧美日韩国产电影| 精品久久国产97色综合| 久久久久久麻豆| 中文字幕在线不卡国产视频| 亚洲激情自拍偷拍| 五月天网站亚洲| 捆绑紧缚一区二区三区视频| 国产一区二区看久久| 成人听书哪个软件好| 色噜噜久久综合| 在线不卡a资源高清| 2020国产精品| 亚洲免费看黄网站| 午夜久久久久久久久久一区二区| 久久精品免费看| 国产99久久久国产精品潘金 | www.日韩av| 欧美亚洲综合久久| 精品少妇一区二区三区日产乱码| 日本一区二区在线不卡| 亚洲综合色自拍一区| 激情五月播播久久久精品| 成人a免费在线看| 欧美午夜视频网站| 国产亚洲综合色| 亚洲综合免费观看高清完整版在线| 秋霞电影一区二区| av亚洲精华国产精华精华 | 欧美网站大全在线观看| 91麻豆精品国产91久久久 | 亚洲第一狼人社区| 国产精品一区二区果冻传媒| 在线免费观看日本欧美| 久久亚洲精品国产精品紫薇| 亚洲综合成人网| 成人亚洲精品久久久久软件| 91麻豆精品国产综合久久久久久 | 亚洲精品ww久久久久久p站| 久久精品国产秦先生| 日本道精品一区二区三区| 久久蜜桃一区二区| 午夜私人影院久久久久| 波多野结衣中文字幕一区| 精品少妇一区二区三区日产乱码| 一区二区三区四区亚洲| 国产成人一区二区精品非洲| 欧美精选一区二区| 一区二区三区在线视频观看| 国产精品18久久久久久久久久久久 | 日韩电影在线一区二区| 91久久人澡人人添人人爽欧美| 久久久久国产免费免费| 免费精品99久久国产综合精品| 色女孩综合影院| 综合网在线视频| 99久久777色| 国产精品剧情在线亚洲| 丰满白嫩尤物一区二区| 久久九九全国免费| 国产精品一区二区在线观看不卡 | 久久久久国产精品免费免费搜索| 六月丁香婷婷久久| 日韩欧美www| 国内精品自线一区二区三区视频| 欧美一级久久久久久久大片| 亚洲国产成人91porn| 欧美亚男人的天堂| 婷婷亚洲久悠悠色悠在线播放| 欧美性受xxxx| 午夜影视日本亚洲欧洲精品| 欧美日韩国产小视频在线观看| 亚洲综合免费观看高清完整版在线| 色噜噜狠狠色综合中国| 亚洲国产精品欧美一二99| 欧美日韩国产首页在线观看| 青青草原综合久久大伊人精品优势| 5月丁香婷婷综合| 精品影视av免费| 国产欧美精品一区aⅴ影院| 成人免费va视频| 亚洲乱码中文字幕综合| 在线这里只有精品| 麻豆免费精品视频| 国产午夜精品美女毛片视频| 成人爱爱电影网址| 亚洲va中文字幕| 日韩免费一区二区| 国产高清不卡一区二区| 亚洲视频你懂的| 欧美狂野另类xxxxoooo| 精品一区二区在线观看| 国产精品私房写真福利视频| 色综合久久综合| 久久国产精品一区二区| 亚洲色图一区二区| 欧美一区二区三区四区视频| 国产成人99久久亚洲综合精品| 夜夜亚洲天天久久| 久久综合成人精品亚洲另类欧美 | 91久久精品网| 久久成人久久爱| 亚洲欧美日韩国产中文在线| 精品视频在线免费| 国产精品99久| 亚洲午夜精品网| 欧美国产亚洲另类动漫| 欧美高清激情brazzers| 成人av免费在线观看| 日本91福利区| 一级日本不卡的影视| 久久久久久久久久久99999| 欧洲精品视频在线观看| 国产精品影视天天线| 天天做天天摸天天爽国产一区| 中文字幕精品一区二区三区精品| 欧美日高清视频| 91在线免费播放| 福利一区在线观看| 麻豆精品一区二区av白丝在线| 亚洲一级二级三级| 国产精品美女久久久久av爽李琼| 日韩欧美一区二区久久婷婷| 色综合久久66| 99re这里都是精品| 国产成人三级在线观看| 激情国产一区二区| 免费成人你懂的| 奇米四色…亚洲| 丝瓜av网站精品一区二区| 一区二区成人在线视频| 最近中文字幕一区二区三区| 国产欧美综合在线| 久久久噜噜噜久久人人看 | 国产成人av电影在线播放| 琪琪久久久久日韩精品| 香蕉成人伊视频在线观看| 一区二区三区加勒比av| 亚洲激情五月婷婷| 亚洲精品成人精品456| 亚洲欧美日韩国产手机在线| 综合久久久久久| 国产精品私人影院| 中文字幕精品一区二区精品绿巨人 | 中文字幕日韩欧美一区二区三区| 久久久久久久久蜜桃| 欧美精品一区二区高清在线观看| 日韩一区二区三区在线观看| 欧美日韩国产综合一区二区三区| 欧美日韩另类国产亚洲欧美一级| 欧美亚洲综合一区| 7777精品伊人久久久大香线蕉完整版 | 国产精品一线二线三线精华| 国产高清精品在线| 91片黄在线观看| 欧美主播一区二区三区美女| 欧美日韩一区不卡| 欧美一区二区黄色| 精品福利在线导航| 国产精品女主播av| 亚洲黄色免费网站| 日本aⅴ亚洲精品中文乱码| 九一九一国产精品| 成人夜色视频网站在线观看| 91亚洲精品久久久蜜桃| 精品视频在线免费| 精品电影一区二区| 亚洲欧洲国产日韩| 日韩中文字幕亚洲一区二区va在线 | 亚洲一区二区三区不卡国产欧美| 丝袜亚洲精品中文字幕一区| 久久99国内精品| 色综合久久99| 日韩欧美一区二区免费| 国产精品久久久久久久久免费丝袜 | 国产性色一区二区| 亚洲天堂免费看| 麻豆专区一区二区三区四区五区| 国产精品亚洲视频| 91成人国产精品| 久久久久久久久久久电影| 亚洲人成网站在线| 美国欧美日韩国产在线播放| 成人av在线资源网| 日韩区在线观看| 樱花影视一区二区| 国产成人精品午夜视频免费|