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

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

?? intel28f128_16x2.c

?? umon bootloader source code, support mips cpu.
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/* intel28f128_16x2.c:
 * Support for INTEL 28f128.
 * A 16-bit device in a 2-device-wide bank.
 */
#include "config.h"
#if INCLUDE_FLASH
#include "stddefs.h"
#include "genlib.h"
#include "cpu.h"
#include "flash.h"
#include "intel28f128_16x2.h"

#define SR_WAIT	100000
#define WR_WAIT	50

#define DEV_WIDTH	4

#define WSMS	0x00800080
#define WSMS_L	0x00000080
#define WSMS_H	0x00800000
#define ESS		0x00400040
#define ES		0x00200020
#define PSS		0x00040004
#define PS		0x00100010

extern struct flashinfo	Fdev;
extern int FlashProtectWindow;

/* Manufacturer and device ids... */
#define INTEL28F128J	0x00890018

#define	ftype			    volatile unsigned long

#define FWrite(to,frm)		(*(ftype *)(to) = *(ftype *)(frm))
#define Write_to(add, val)	(*(ftype *)(add) = (val))
#define Write_01_to(add)	(*(ftype *)(add) = 0x00010001)
#define Write_20_to(add)	(*(ftype *)(add) = 0x00200020)
#define Write_40_to(add)	(*(ftype *)(add) = 0x00400040)
#define Write_60_to(add)	(*(ftype *)(add) = 0x00600060)
#define Write_70_to(add)	(*(ftype *)(add) = 0x00700070)
#define Write_d0_to(add)	(*(ftype *)(add) = 0x00d000d0)

#define Write_50_to_base()	(*(ftype *)(fdev->base) = 0x00500050)
#define Write_60_to_base()	(*(ftype *)(fdev->base) = 0x00600060)
#define Write_70_to_base()	(*(ftype *)(fdev->base) = 0x00700070)
#define Write_90_to_base()	(*(ftype *)(fdev->base) = 0x00900090)
#define Write_d0_to_base()	(*(ftype *)(fdev->base) = 0x00d000d0)
#define Write_ff_to_base()	(*(ftype *)(fdev->base) = 0x00FF00FF)

#define Read_from(add)		(*(ftype *)(add))
#define Read_0000_from_base()	(*(ftype *)(fdev->base+(0x00000000<<2)))
#define Read_0001_from_base()	(*(ftype *)(fdev->base+(0x00000001<<2)))
#define Read_5555_from_base()	(*(ftype *)(fdev->base+(0x5555<<1)))

#define Is_ff(add)		(*(ftype *)(add) == 0xFFFFFFFF)
#define Is_not_ff(add)		(*(ftype *)(add) != 0xFFFFFFFF)
#define Is_Equal(p1,p2)		(*(ftype *)(p1) == *(ftype *)(p2))
#define Is_Not_Equal(p1,p2)	(*(ftype *)(p1) != *(ftype *)(p2))
#define Not32BitAligned(ptr)	((long)ptr & 3)

/* Intel28f128_16x2_erase():
 * Based on the 'snum' value, erase the appropriate sector(s).
 * Return 0 if success, else -1.
 */
int
Intel28f128_16x2_erase(struct flashinfo *fdev,int snum)
{
	int	ret, sector;
	volatile int i;

	ret = 0;

	/* Erase the request sector(s): */
	for (sector=0; sector < fdev->sectorcnt; sector++) {
		if ((!FlashProtectWindow) && (fdev->sectors[sector].protected)) {
			continue;
		}
		if ((snum == ALL_SECTORS) || (snum == sector)) {
			register ulong *lp, *lp1;
			int	noterased;

			/* See if the sector is already erased: */
			noterased = 0;
			lp = (ulong *)fdev->sectors[sector].begin; 
			lp1 = (ulong *)((char *)lp + fdev->sectors[sector].size - 1); 
			while(lp <= lp1) {
				if (*lp++ != 0xffffffff) {
					noterased = 1;
					break;
				}
			}
			if (noterased) {
				/* Issue the setup/confirm sequence: */
				Write_20_to(fdev->sectors[sector].begin);/* setup */
				Write_d0_to(fdev->sectors[sector].begin);/* confirm */

				/* Wait for sector erase to complete by polling RSR... */
				while(1) {
					ulong rsr;

					Write_70_to_base();
					rsr = Read_0000_from_base();
					if (!(rsr & WSMS_H && rsr & WSMS_L)) { /* Wait till ready */
						for (i=0; i<SR_WAIT; i++);
						continue;
					}
					if (rsr & ESS) { /* Should not be suspended */
						ret = -1;
					}
					if (rsr & ES) { /* Should not have error */
						ret = -1;
					}
					break;
				}
				Write_50_to_base();	/* Clear status register */
				Write_ff_to_base();	/* Go to read-array mode */
			}
			if (ret == -1)
				break;
		}
	}
	for (i=0; i<SR_WAIT; i++);
	return(ret);
}

/* EndIntel28f128_16x2_erase():
 * Function place holder to determine the end of the above function.
 */
void
EndIntel28f128_16x2_erase(void)
{}


/* Intel28f128_16x2_write():
 * Copy specified number of bytes from source to destination.  The destination
 * address is assumed to be flash space.
 */
int
Intel28f128_16x2_write(struct flashinfo *fdev,uchar *dest,uchar *src,
	long bytecnt)
{
	ftype			stat;
	volatile long	cnt, buf4[1];
	volatile int	i, tot, ret, delta;
	volatile uchar	*bp4;

#ifdef FLASH_TRACE
	printf("fwrite(dest=0x%lx,src=0x%lx,size=%d)\n",
		(ulong)dest,(ulong)src,bytecnt);
#endif

	/* If the destination address is not properly aligned, then build a
	 * fake source buffer using bytes below dest.  Then call this function
	 * recursively to do that operation.
	 */
	if (Not32BitAligned(dest)) {
		uchar	*tmpdest;

		delta = (long)dest & 3;
		tmpdest = dest - delta;

		bp4 = (uchar *)buf4;
		for(i=0;delta>0;i++,delta--) {
			*bp4++ = *(dest-delta);
		}
		for(;i<4;i++) {
			if (bytecnt > 0) {
				*bp4++ = *src++;
				bytecnt--;
			}
			else {
				*bp4++ = *dest;
			}
			dest++;
		}
#ifdef FLASH_TRACE
		printf("pre-align:  0x%lx = %08lx\n",(ulong)tmpdest,buf4[0]);
#endif

		if (Intel28f128_16x2_write(fdev,tmpdest,(uchar *)buf4,4) == -1)
			return(-1);
	}

#ifdef FLASH_TRACE
	printf("bc=%d\n",bytecnt);
#endif
	ret = 0;
	cnt = bytecnt & ~3;

	for (tot=0;tot<cnt;tot+=4) {
		bp4 = (uchar *)buf4;
		*bp4++ = *src++;				/* Just in case src is not aligned... */
		*bp4++ = *src++;				
		*bp4++ = *src++;				
		*bp4++ = *src++;				

#ifdef FLASH_TRACE
		printf("fwrite1:    0x%lx = %08lx\n",(ulong)dest,buf4[0]);
#endif

		Write_40_to(dest);	/* flash program setup */
		FWrite(dest, buf4); /* write value */
		do {
			Write_70_to_base();
			stat = Read_0000_from_base();
		} while ( ! (stat & WSMS_H && stat & WSMS_L) );
		Write_50_to_base(); /* Clear status register */
		Write_ff_to_base(); /* Go to read-array mode */
		if ( Is_Not_Equal(dest, buf4)) {
			ret = -1;
			break;
		}
		dest += 4; 
	}

onemore:
	for (;tot<cnt;tot+=4) {
		bp4 = (uchar *)buf4;
		*bp4++ = *src++;				/* Just in case src is not aligned... */
		*bp4++ = *src++;
		*bp4++ = *src++;
		*bp4++ = *src++;

#ifdef FLASH_TRACE
		printf("fwrite2:    0x%lx = %08lx\n",(ulong)dest,buf4[0]);
#endif
		Write_40_to(dest);	/* flash program setup */
		FWrite(dest, buf4); /* write value */
		do {
			Write_70_to_base();
			stat = Read_0000_from_base();
		} while ( ! (stat & WSMS_H && stat & WSMS_L) );
		Write_50_to_base(); /* Clear status register */
		Write_ff_to_base(); /* Go to read-array mode */
		if (Is_Not_Equal(dest,buf4)) {
			ret = -1;
			break;
		}

		dest += 4; 
	}

	/* If cnt != bytecnt then bytecnt is not mod4, so one more write must be
	 * be done.  To do this, we must combine the source data with data that
	 * is already in the flash above the intended final address...
	 */
	if (cnt != bytecnt) {
		bp4 = (uchar *)buf4;
		for(delta=0;cnt != bytecnt;delta++,cnt++)
			*bp4++ = *src++;
		for(;delta != 4;delta++)
			*bp4++ = *(dest+delta);
		src = (uchar *)buf4;

		tot = cnt-1;
		goto onemore;
	}
	return(ret);
}

/* EndIntel28f128_16x2_write():
 * Function place holder to determine the end of the above function.
 */
void
EndIntel28f128_16x2_write(void)
{}

/* Intel28f128_16x2_ewrite():
 * Erase all sectors that are part of the address space to be written,
 * then write the data to that address space.  This is basically a
 * concatenation of the above erase & write done in one step.  This is
 * necessary primarily for re-writing the bootcode; because after the boot
 * code is erased, there is nowhere to return so the re-write must be done
 * while executing out of ram also.  It is only needed in systems that are
 * executing the monitor out of the same device that is being updated.
 */
int
Intel28f128_16x2_ewrite(struct flashinfo *fdev,uchar *destA,uchar *srcA,
	long bytecnt)
{
	int	    sector, efail, i;
	void	(*reset)();
	uchar	*src1;
	ftype	val;
	uchar   *src, *dest;
	ulong   rsr;

ewrite_again:
	efail = 0;
	src = srcA;
	dest = destA;
	Write_50_to_base(); /* clear status register */
	Write_ff_to_base(); /* set device in read-array mode */

	/* For each sector, if it overlaps any of the destination space */
	/* then erase that sector. */
	for (sector = 0; sector < fdev->sectorcnt; sector++) {
		if ((((uchar *)dest) > (fdev->sectors[sector].end)) ||
		    (((uchar *)dest+bytecnt-1) < (fdev->sectors[sector].begin))) {
			continue;
		}

		/* Issue the ERASE setup/confirm sequence: */
		Write_20_to(fdev->sectors[sector].begin);/* setup */
		Write_d0_to(fdev->sectors[sector].begin);/* confirm */

		/* Wait for sector erase to complete by polling RSR... */
		while(1) {
			ulong rsr;

			Write_70_to_base();
			rsr = Read_0000_from_base();
			if (!(rsr & WSMS_H && rsr & WSMS_L)) { /* Wait till ready */
				for (i=0; i<SR_WAIT; i++);
				continue;
			}

			if (rsr & (ESS|ES))	/* Failure if suspension or error. */
				efail = 1;

			break;
		}
		Write_50_to_base();		/* Clear status register */
		Write_ff_to_base();		/* Go to read-array mode */

		if (efail)				/* If erase failed, return -1 */
			return(-1);
	}


	src1 = (uchar *)&val;

	for(i = 0; i < bytecnt; i += DEV_WIDTH) {

		/* Just in case src is not aligned... */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线制服丝袜| 欧美丝袜丝nylons| 亚洲成人免费视| 国产片一区二区| 欧美日本视频在线| 99re免费视频精品全部| 激情综合亚洲精品| 日韩精品成人一区二区在线| 亚洲视频你懂的| 久久男人中文字幕资源站| 欧美精选午夜久久久乱码6080| aaa亚洲精品一二三区| 狠狠网亚洲精品| 日韩精品一二区| 亚洲h精品动漫在线观看| 亚洲裸体在线观看| 国产精品萝li| 中文天堂在线一区| 久久久夜色精品亚洲| 日韩一区二区三区四区五区六区| 91福利在线观看| 色综合中文综合网| 国产老女人精品毛片久久| 偷窥国产亚洲免费视频| 一区二区三区国产精品| 国产精品天美传媒| 久久久亚洲高清| 久久久久99精品国产片| xnxx国产精品| 精品国产第一区二区三区观看体验| 4438x亚洲最大成人网| 欧美体内she精视频| 在线免费观看日韩欧美| 欧美私模裸体表演在线观看| 91麻豆国产香蕉久久精品| www.av亚洲| 91日韩一区二区三区| 91在线观看免费视频| 97久久精品人人做人人爽 | 91在线国产观看| 成人黄色小视频| 97久久精品人人澡人人爽| 91亚洲国产成人精品一区二区三| 99国产精品久久久久久久久久| www.日韩av| 欧美最新大片在线看| 欧美午夜精品一区二区三区| 欧美色老头old∨ideo| 欧美另类videos死尸| 日韩欧美一级精品久久| 精品国产91久久久久久久妲己| 精品国产乱码久久久久久闺蜜| 精品国产精品一区二区夜夜嗨| 久久人人97超碰com| 欧美激情在线免费观看| 亚洲三级电影全部在线观看高清| 亚洲欧美一区二区不卡| 五月天婷婷综合| 久久电影网站中文字幕| 丁香婷婷综合网| 91精品91久久久中77777| 678五月天丁香亚洲综合网| 精品1区2区在线观看| 国产精品夫妻自拍| 污片在线观看一区二区| 国产在线精品不卡| 99r国产精品| 日韩一区和二区| 欧美国产日韩亚洲一区| 亚洲第一av色| 国产福利一区二区| 91成人在线免费观看| 日韩一区二区精品在线观看| 国产欧美一区在线| 亚洲国产欧美一区二区三区丁香婷 | 国产欧美一区二区精品性色超碰| 日韩毛片一二三区| 免费日本视频一区| www.亚洲精品| 欧美α欧美αv大片| 亚洲精品视频在线观看免费| 日韩va欧美va亚洲va久久| 成人永久免费视频| 91精品国产麻豆| 1000精品久久久久久久久| 国产成人aaa| 欧美中文字幕一区| 国产日韩欧美激情| 免费在线观看精品| 欧美中文字幕久久| 欧美激情在线一区二区三区| 亚洲精品少妇30p| 91精品福利在线| 亚洲精品中文字幕乱码三区| 久久er精品视频| 91麻豆视频网站| 国产欧美精品日韩区二区麻豆天美| 亚洲一区日韩精品中文字幕| 国产精品中文有码| 欧美精品aⅴ在线视频| 亚洲视频在线观看三级| 狠狠色狠狠色合久久伊人| 欧美日韩成人综合天天影院 | 中文字幕成人网| 免费在线观看视频一区| 99视频在线精品| 久久久蜜桃精品| 久久精品99国产国产精| 欧美日韩国产天堂| 亚洲人成人一区二区在线观看| 国产一区二区免费看| 在线播放视频一区| 亚洲一区在线观看网站| av影院午夜一区| 中日韩av电影| 久久国产尿小便嘘嘘| 欧美日韩一级二级三级| 亚洲精选在线视频| 99久久国产综合精品麻豆| 欧美videofree性高清杂交| 亚洲国产成人va在线观看天堂| av电影天堂一区二区在线| 国产喷白浆一区二区三区| 国内精品久久久久影院色| 欧美sm美女调教| 麻豆精品国产91久久久久久| 91精品国产麻豆| 老司机精品视频线观看86| 69p69国产精品| 青青草国产精品97视觉盛宴| 69堂亚洲精品首页| 日韩中文字幕区一区有砖一区| 在线视频一区二区三| 亚洲综合在线免费观看| 色妹子一区二区| 亚洲一区二区三区影院| 欧美视频第二页| 日日摸夜夜添夜夜添国产精品 | 天天综合色天天综合| 777久久久精品| 毛片av一区二区三区| 欧美va亚洲va香蕉在线| 国产麻豆精品在线| 久久久国产精品午夜一区ai换脸| 国产乱码精品一区二区三| 亚洲国产精品ⅴa在线观看| 久久99久久精品| av在线不卡电影| 成人app软件下载大全免费| 国产精品色婷婷久久58| 91网站最新地址| 亚洲午夜国产一区99re久久| 6080亚洲精品一区二区| 精品在线观看免费| 国产精品国产自产拍在线| 91国偷自产一区二区开放时间| 天堂资源在线中文精品| 最新国产成人在线观看| 色网站国产精品| 亚洲va欧美va人人爽午夜| 欧美r级在线观看| 波多野结衣一区二区三区 | 国产精品每日更新在线播放网址 | 91久久久免费一区二区| 日日摸夜夜添夜夜添国产精品 | 椎名由奈av一区二区三区| 欧美伊人久久大香线蕉综合69| 日韩精品一级二级| 国产午夜亚洲精品不卡| 91福利小视频| 久久精品国产99久久6| 中文字幕一区二区三区精华液| 欧美日韩性生活| 国产成人精品1024| 亚洲小说欧美激情另类| 久久久久久日产精品| 91国偷自产一区二区三区成为亚洲经典 | 欧美日韩国产高清一区| 国产一区二区按摩在线观看| 一区二区三区中文字幕| 精品蜜桃在线看| 欧美亚洲一区三区| 国产精一品亚洲二区在线视频| 亚洲美女免费视频| 精品久久久三级丝袜| 日本高清视频一区二区| 国产一区二区伦理| 五月天网站亚洲| 亚洲视频1区2区| 久久久99精品久久| 欧美日韩www| 91在线porny国产在线看| 国内精品第一页| 亚洲成人午夜电影| 成人免费视频在线观看| 久久综合九色综合97婷婷女人 | 亚洲色图欧美在线| 欧美精品一区二区三区四区| 91九色02白丝porn| www..com久久爱|