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

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

?? x

?? umon bootloader source code, support mips cpu.
??
字號:
/* flashpic.c:
   This file contains the flash-support code that is relocated to
   RAM prior to execution.  This file currently only supports the
   device when configured in 16-bit mode.
*/
#include "config.h"
#if INCLUDE_FLASH
typedef unsigned char uchar;
typedef unsigned short ushort;
typedef unsigned long ulong;
typedef volatile unsigned char vuchar;
typedef volatile unsigned short vushort;
typedef volatile unsigned long vulong;
typedef volatile unsigned int vuint;
typedef volatile int vint;

#include "cpu.h"
#include "flashdev.h"
#include "flash.h"

#define WSMS	0x0080
#define ESS		0x0040
#define ES		0x0020
#define PSS		0x0004
#define PS		0x0010

extern struct flashinfo	Fdev;
extern int FlashProtectWindow;

int
Flashlock16(struct flashinfo *fdev,int snum,int operation)
{
	ulong	add;
	int	sector;

	add = (ulong)(fdev->base);

	/* Lock the requested sector(s): */
	for (sector=0;sector<fdev->sectorcnt;sector++) {
		if ((snum == ALL_SECTORS) || (snum == sector)) {
			/* Issue the appropriate command sequence: */
			Write_60_to_base();	
			switch(operation) {
			case FLASH_UNLOCK:
				Write_d0_to_(add);
				break;
			case FLASH_LOCK:
				Write_01_to_(add);
				break;
			case FLASH_LOCKDWN:
				Write_2f_to_(add);
				break;
			}
		}
		add += fdev->sectors[sector].size;
	}
	Write_FF_to_base();		/* Go to read-array mode */
	return(0);
}

void
EndFlashlock16()
{}

/* Flasherase():
   Based on the 'snum' value, erase the appropriate sector(s).
   Write the "Erase Setup" and "Erase Confirm" commands...
   Return 0 if success, else -1.
*/
int
Flasherase16(struct flashinfo *fdev,int snum)
{
	ulong	add;
	int	ret, sector;

	ret = 0;
	add = (ulong)(fdev->base);

	/* Erase the request sector(s): */
	for (sector=0;sector<fdev->sectorcnt;sector++) {
		if ((!FlashProtectWindow) &&
		    (fdev->sectors[sector].protected)) {
			add += fdev->sectors[sector].size;
			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); 
			while(lp < lp1) {
				if (*lp++ != 0xffffffff) {
					noterased = 1;
					break;
				}
			}
			if (noterased) {
				/* Issue the setup/confirm sequence: */
				Write_20_to_base();		/* setup */
				Write_d0_to_(add);		/* confirm */

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

					rsr = Read_0000();
					if (!(rsr & WSMS))	/* Wait till ready */
						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;
		}
		add += fdev->sectors[sector].size;
	}
	return(ret);
}

/* EndFlasherase():
   Function place holder to determine the "end" of the
   sectorerase() function.
*/
void
EndFlasherase16()
{
}


/* Flashwrite():
   Return 0 if successful, else -1.
*/
int
Flashwrite16(struct flashinfo *fdev,uchar *dest,uchar *src,long bytecnt)
{
	int		i, ret;
	long	cnt;
	uchar 	*src1;
	ftype	val;

	/* If destination address is not properly aligned, then build a fake   */
	/* source buffer based on the current value in dest[-1] and src[0].    */
	/* Then call this function to do that 2-byte operation.  Once that     */
	/* completes, simply increment dest and src by 1 and continue in this  */
	/* context. */
	if (NotAligned(dest)) {
		uchar buf[2];
		buf[0] = *(dest-1);
		buf[1] = *src;
		Flashwrite16(fdev,dest-1,buf,2);
		dest++; src++; bytecnt--;
	}

	/* Each pass through this loop writes 'fdev->width' bytes... */
	ret = 0;
	cnt = bytecnt & ~1;
	src1 = (uchar *)&val;

onemore:
	for (i=0;i<cnt;i+=fdev->width) {

	   /* Just in case src is not aligned... */
		src1[0] = src[0];
		src1[1] = src[1];

		/* Flash program setup command */
		Write_40_to_base();
		  
		/* Write the value */
		Fwrite(dest,src1);

		/* Wait for write to complete or timeout. */
		Write_70_to_base();
		while(1) {
			ushort rsr;

			rsr = Read_0000();
			if (!(rsr & WSMS))	/* Wait till ready */
				continue;
			if (rsr & PSS) 		/* Should not be suspended */
				ret = -1;
			if (rsr & PS) 		/* Should not have error */
				ret = -1;
			break;
		}
		Write_50_to_base();		/* Clear status register */
		Write_FF_to_base();		/* Go to read-array mode */
		dest += fdev->width; 
		src += fdev->width;
	}

	/* If bytecount was odd... */
	/* If cnt != bytecnt then bytecnt is odd, so one more byte must be */
	/* written to flash.  To do this, the one byte must be combined with */
	/* the next byte that is already stored in flash; then re-written... */
	if (cnt != bytecnt) {
		val = (ftype)*dest | ((ftype)(*src) << 8);
		src = (uchar *)&val;
		bytecnt = cnt = 1;
		goto onemore;
	}

	return(ret);
}

/* EndFlashwrite():
	Function place holder to determine the "end" of the
	Flashwrite() function.
*/
void
EndFlashwrite16()
{
}

/* 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 flasherase and flashwrite 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.
*/

int
Flashewrite16(struct flashinfo *fdev,ftype *dest,ftype *src,int bytecnt)
{
	int	i, err;
	ulong	add;
	void	(*reset)();
	ftype	*src1;

	err = 0;
	add = (ulong)(fdev->base);
	src1 = src;

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

		/* Issue the ERASE setup/confirm sequence: */
		Write_20_to_base();		/* setup */
		Write_d0_to_(add);		/* confirm */

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

			rsr = Read_0000();
			if (!(rsr & WSMS))	/* Wait till ready */
				continue;
			if (rsr & ESS) 		/* Should not be suspended */
				err = 1;
			if (rsr & ES) 		/* Should not have error */
				err = 1;
			break;
		}
		Write_50_to_base();		/* Clear status register */
		Write_FF_to_base();		/* Go to read-array mode */
		if (err)
			return(-1);
		add += fdev->sectors[i].size;
	}

	for(i=0;i<bytecnt;i+=fdev->width) {
		/* Flash program setup command */
		Write_40_to_base();
		
		/* Just in case src is not aligned... */
		src1[0] = src[0];
		src1[1] = src[1];

		/* Write the value */
		Fwrite(dest,src1);

		/* Wait for write to complete by polling RSR... */
		Write_70_to_base();
		while(1) {
			ushort rsr;

			rsr = Read_0000();
			if (!(rsr & WSMS))	/* Wait till ready */
				continue;
			if (rsr & PSS) 		/* Should not be suspended */
				err = 1;
			if (rsr & PS) 		/* Should not have error */
				err = 1;
			break;
		}
		Write_50_to_base();		/* Clear status register */
		Write_FF_to_base();		/* Go to read-array mode */
		if (err)
			return(-1);
		dest++; 
		src++;
	}
	
	/* Wait till flash is readable, then reset: */
	while(1) {
		if (Is_Equal((dest-1),src1))
			break;
	}

	/* Now that the re-programming of flash is complete, reset: */
	reset = RESETFUNC();
	reset();

	return(0);	/* won't get here */
}

/* EndFlashewrite():
	Function place holder to determine the "end" of the
	FlashEraseAndWrite() function.
*/
void
EndFlashewrite16()
{
}

/* Flashtype():
   Use the ReadCOnfiguration command (90H) to read manufacturer code (0000)
   and device id code (0001).
*/

int
Flashtype16(struct flashinfo *fdev)
{
	ftype	val;
	ushort	man, dev;
	ulong	id;

	val = Read_0000();

	/* Issue the read configuration command: */
	Write_90_to_base();

	man = (ushort)Read_0000();	/* manufacturer ID */
	dev = (ushort)Read_0001();	/* device ID */
	id = man;
	id <<= 16;
	id |= dev;

	fdev->id = id;

	/* Issue the read array command: */
	Write_FF_to_base();
	return((int)(fdev->id));
}

/* EndFlashtype():
	Function place holder to determine the "end" of the
	Flashtype() function.
*/
void
EndFlashtype16()
{
}
#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成年人影院| 亚洲国产精品精华液ab| 亚洲一区二区三区自拍| 91老师国产黑色丝袜在线| 亚洲三级免费观看| 91国产丝袜在线播放| 亚洲成国产人片在线观看| 欧美日韩成人一区| 久久66热偷产精品| 国产精品午夜电影| 欧美日韩久久不卡| 国产一区亚洲一区| 亚洲乱码精品一二三四区日韩在线 | 欧美激情综合五月色丁香| 国产成人精品免费视频网站| 国产精品午夜久久| 欧美日韩久久不卡| 国产尤物一区二区| 亚洲免费观看高清在线观看| 欧美最新大片在线看 | 蜜芽一区二区三区| 国产午夜精品久久久久久免费视| 成人av网站在线观看| 亚洲自拍偷拍网站| 日韩一区二区免费电影| 国产一区二区伦理片| 亚洲视频免费观看| 欧美一区二区三区视频免费 | 国产精品久久久久久妇女6080| 色综合色狠狠综合色| 日本怡春院一区二区| 国产精品免费网站在线观看| 在线观看视频一区二区| 精品一二线国产| 一区二区三区鲁丝不卡| 精品国产凹凸成av人导航| 91视频你懂的| 久久精品国产亚洲a| 亚洲欧美激情小说另类| www国产成人| 欧美精品一二三四| 91亚洲精品久久久蜜桃网站| 国内精品久久久久影院色| 亚洲综合激情另类小说区| 久久久精品欧美丰满| 欧美色视频在线观看| 国产99久久久国产精品| 日韩av高清在线观看| 一区精品在线播放| 久久伊99综合婷婷久久伊| 欧美日韩国产经典色站一区二区三区| 国产成人免费视频精品含羞草妖精| 偷拍一区二区三区| 亚洲视频你懂的| 亚洲国产精品99久久久久久久久 | 日韩欧美三级在线| 91黄视频在线| 成人av网站大全| 国产成a人亚洲| 美女网站色91| 日韩不卡一区二区三区| 樱花草国产18久久久久| 国产精品看片你懂得| 国产三区在线成人av| 日韩你懂的在线播放| 欧美精品在线观看播放| 欧美性受xxxx黑人xyx性爽| 99久久99久久久精品齐齐| 国产成人在线视频网站| 国产揄拍国内精品对白| 久久91精品久久久久久秒播| 蜜臀av在线播放一区二区三区| 亚洲国产精品久久久久婷婷884| 中文字幕欧美一区| 最新国产の精品合集bt伙计| 国产欧美一区二区三区在线老狼| 欧美va天堂va视频va在线| 制服丝袜激情欧洲亚洲| 69p69国产精品| 91麻豆精品国产自产在线| 欧美精品乱码久久久久久按摩| 欧美日韩在线免费视频| 在线成人av网站| 欧美一二三四区在线| 日韩欧美国产一区二区在线播放| 日韩欧美国产三级电影视频| 日韩精品一区二区三区在线观看| 欧美一区三区二区| 欧美变态凌虐bdsm| 欧美激情在线观看视频免费| 亚洲国产高清不卡| 综合激情网...| 亚洲六月丁香色婷婷综合久久 | 国产麻豆精品视频| 国产一区二区三区久久悠悠色av| 国产精品12区| 不卡一区二区在线| 欧美三级韩国三级日本三斤| 欧美精品一二三| 欧美草草影院在线视频| 欧美激情在线一区二区| 亚洲美女视频一区| 日韩精彩视频在线观看| 精品一区二区在线看| 成人激情电影免费在线观看| 欧美亚洲国产一区二区三区va | 亚洲午夜一区二区| 久久精品噜噜噜成人88aⅴ| 国产乱子伦视频一区二区三区| 成人av在线资源网| 欧美三级中文字| 精品福利一区二区三区| 国产精品美女久久久久久久久| 亚洲综合一区二区三区| 精品一区二区免费看| 91极品视觉盛宴| 久久久久久久精| 亚洲一区在线视频观看| 国产一区二区影院| 91成人国产精品| 精品免费99久久| 一区二区三区 在线观看视频| 久99久精品视频免费观看| 99久久久国产精品免费蜜臀| 91精品国产综合久久久久久久| 国产情人综合久久777777| 亚洲综合小说图片| 国产不卡视频在线播放| 正在播放亚洲一区| 国产精品传媒视频| 极品美女销魂一区二区三区| 91一区二区三区在线播放| 精品久久久久久综合日本欧美| 一区二区三区中文字幕| 国产成人日日夜夜| 欧美电视剧在线观看完整版| 亚洲另类中文字| 成人激情免费网站| 久久精品视频网| 免费人成黄页网站在线一区二区 | 国产在线精品一区二区不卡了| 在线观看欧美精品| 亚洲欧洲精品天堂一级| 黄网站免费久久| 欧美一级黄色录像| 亚洲午夜一二三区视频| 91免费看片在线观看| 中文字幕av一区二区三区免费看| 美女mm1313爽爽久久久蜜臀| 日本道在线观看一区二区| 国产女人aaa级久久久级 | 成人丝袜视频网| 久久综合狠狠综合久久综合88 | 久久久不卡影院| 麻豆传媒一区二区三区| 欧美日韩1区2区| 亚洲一区二区三区激情| 日本高清免费不卡视频| 亚洲天天做日日做天天谢日日欢| 成人精品高清在线| 欧美激情在线一区二区三区| 国产黄人亚洲片| 欧美极品美女视频| 国产精品1024| 国产亚洲精品久| 成人午夜电影久久影院| 亚洲国产精品ⅴa在线观看| 国产凹凸在线观看一区二区| 久久综合网色—综合色88| 狠狠色综合播放一区二区| 亚洲精品一区二区三区影院| 捆绑调教美女网站视频一区| 欧美一级黄色大片| 国产在线日韩欧美| 国产欧美一区在线| 99re这里只有精品视频首页| 日韩美女精品在线| 欧美在线观看视频一区二区 | 亚洲视频免费在线| 欧美最猛性xxxxx直播| 天天综合网天天综合色| 日韩一区二区不卡| 国产在线视频精品一区| 国产精品天美传媒| 色婷婷av一区二区| 亚洲福利国产精品| 日韩欧美在线不卡| 成熟亚洲日本毛茸茸凸凹| 日韩美女视频一区二区| 精品视频免费在线| 久久97超碰色| 18欧美亚洲精品| 欧美美女黄视频| 国产剧情在线观看一区二区| 国产精品素人一区二区| 欧美午夜精品久久久久久超碰 | 国产福利一区二区三区视频| 中文字幕中文在线不卡住| 欧美午夜影院一区| 国产在线麻豆精品观看|