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

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

?? bf533ezflash.c

?? SST39VF160 NOR Flash驅動 VDSP環境
?? C
?? 第 1 頁 / 共 2 頁
字號:
///////////////////////////////////////////////////////////////
//
// BF533EzFlash.c
//
// Analog Devices, Inc. - 2001
//
//
// Change Log
//
//		1.00.1
//			- made changes so that the driver will work with
//			  the revised GUI
//
//		1.00.0
//			- initial release
//
// VisualDSP++ "Flash Programmer" flash driver for use with the
// ADSP-BF533 EZ-KIT Lite containing the STMicroelectronics PSD4256G
// flash device.
//
///////////////////////////////////////////////////////////////

// error enum
#include <stdlib.h>
#include "Errors.h"
#include <cdefBF533.h>
#include <ccblkfn.h>

// #defines
#define TRUE			0x1
#define FALSE			0x0
#define BUFFER_SIZE		0x600
//#define	NUM_SECTORS 	40				// number of sectors in the flash device
#define	NUM_SECTORS 	32//     SST39VF160 blocks

#define SECTOR_SIZE             2048    /* Must be 2048 words for 39VF160 */
#define BLOCK_SIZE              32768   /* Must be 32K words for 39VF160  */

#define DELAY 			0x5
char state = 0;
// structure for flash sector information
typedef struct _SECTORLOCATION{
	long lStartOff;
	long lEndOff;
}SECTORLOCATION;


// Flash Programmer commands
typedef enum
{
	NO_COMMAND,		// 0
	GET_CODES,		// 1
	RESET,			// 2
	WRITE,			// 3
	FILL,			// 4
	ERASE_ALL,		// 5
	ERASE_SECT,		// 6
	READ,			// 7
	GET_SECTNUM,	// 8
	GET_SECSTARTEND	// 9
}enProgCmds;

// #defines for the assembler
asm ("#define FLASH_START_L 0x0000");
asm ("#define FLASH_START_H 0x2000");

// function prototypes
ERROR_CODE SetupForFlash();
ERROR_CODE GetCodes();
ERROR_CODE PollToggleBit(unsigned long ulOffset);
ERROR_CODE ResetFlash();
ERROR_CODE EraseFlash();
ERROR_CODE EraseBlock( int nBlock );
ERROR_CODE UnlockFlash(unsigned long ulOffset);
ERROR_CODE WriteData( unsigned long ulStart, long lCount, long lStride, int *pnData );
ERROR_CODE FillData( unsigned long ulStart, long lCount, long lStride, int *pnData );
ERROR_CODE ReadData( unsigned long ulStart, long lCount, long lStride, int *pnData );
ERROR_CODE ReadFlash( unsigned long ulOffset, int *pnValue );
ERROR_CODE WriteFlash( unsigned long ulOffset, int nValue );
ERROR_CODE GetSectorNumber( unsigned long ulOffset, int *pnSector );
ERROR_CODE GetSectorStartEnd( long *lStartOff, long *lEndOff, int nSector );

// global data for use with the VisualDSP++ plug-in
char 			*AFP_Title = "ADSP-BF533 Board";
char 			*AFP_Description = "SS39TVF160";
enProgCmds 		AFP_Command = NO_COMMAND;
int 			AFP_ManCode = -1;				// 0x20 = STMicroelectronics
int 			AFP_DevCode = -1;				// 0xE9 = PSD4256G
unsigned long 	AFP_Offset = 0x0;
int 			*AFP_Buffer;
long 			AFP_Size = BUFFER_SIZE;
long 			AFP_Count = -1;
long 			AFP_Stride = -1;
int 			AFP_NumSectors = NUM_SECTORS;
long 			AFP_SectorSize	= 0x10000;//byte
long 			AFP_SectorSize1 = 0x10000;
int 			AFP_SectorSize2 = 0x2000;
int 			AFP_Sector = -1;
int 			AFP_Error 			= 0;			// contains last error encountered
//bool 			AFP_Verify 			= FALSE;		// verify writes or not
bool 			AFP_Verify 			= TRUE;
long 			AFP_StartOff 		= 0x0;			// sector start offset
long 			AFP_EndOff 			= 0x0;			// sector end offset
int				AFP_FlashWidth		= 0x10;			// width of the flash device
int 			*AFP_SectorInfo;
SECTORLOCATION SectorInfo[NUM_SECTORS];



// flag telling us that the flash had to be reset
char reset = 0x0;

// exit flag
bool bExit = FALSE;



#define DELAY_WRITE 9
ERROR_CODE Delay(int time)
{
	int i =0;
	int j =0;
	for(j=0;j<300;j++)
	for(i=0;i<time;i++)
	{
		asm("nop;");
	}
	
	return NO_ERR;
}

void main_test()
{
//  unsigned long ulStart - offset in flash to start the writes at
//	long lCount - number of elements to write, in this case bytes
//	long lStride - number of locations to skip between writes
//	int *pnData - pointer to data buffer
//
	int start  = 0;
	int lcount = 0x100;
	int lstride= 0x1;
	int data[10]={0};
	int data1[10]={0};
	int i=0;
	char j;
	int m_j;
	for(i=0;i<10;i++)
	{
		data[i] = 8;
		data1[i] = i;	
		
	}
	
//	SetupForFlash();
	*pEBIU_AMBCTL0 = 0x78B078B0;
	*pEBIU_AMBCTL1 = 0x78B078B0;
	*pEBIU_AMGCTL |= 0xF;
	ssync();
	
	GetCodes();
	unsigned short test = 0;
	
	EraseFlash();
	for(i=0;i<SECTOR_SIZE/4;i++)
	{
	WriteFlash( 0x5555*2, 0xaaaa );
	WriteFlash( 0x2aaa*2, 0x5555 );
	WriteFlash( 0x5555*2, 0xa0a0 );
	WriteFlash( (0x0+i)*2, test );

	PollToggleBit( (0x0+i)*2);
	test++;
//	Delay( DELAY_WRITE *1000);
	}
//	ReadFlash( 0x10000*2, test );
//	Delay( DELAY_WRITE *10000);
		
	GetCodes();
	

	
	start  = 0;
	lcount = 0x100;
	ReadData(start,lcount,lstride,data1);
	
}

main()
{
	int i = 0;
	// by making AFP_Buffer as big as possible the plug-in can send and
	// receive more data at a time making the data transfer quicker
	//
	// by allocating it on the heap the compiler does not create an
	// initialized array therefore making the driver image smaller
	// and faster to load
	//
	// we have modified the linker description file (LDF) so that the heap
	// is large enough to store BUFFER_SIZE elements at this point
	AFP_Buffer = (int *)malloc(BUFFER_SIZE);

	// AFP_Buffer will be NULL if we could not allocate storage for the
	// buffer
	if ( AFP_Buffer == NULL )
	{
		// tell GUI that our buffer was not initialized
		AFP_Error = BUFFER_IS_NULL;
	}

	//initiate sector information structures
	for(i=0;i<AFP_NumSectors; i++)
	{
		GetSectorStartEnd(&SectorInfo[i].lStartOff, &SectorInfo[i].lEndOff, i);
	}

	AFP_SectorInfo = (int*)&SectorInfo[0];

	// setup the flash so the DSP can access it
	SetupForFlash();

	EraseFlash();
	//setup code so that flash programmer can just read memory instead of call GetCodes().
	GetCodes();
	
//	int test[10]={0,1,2,3,4,5,6,7,8,9};
	

	
//	WriteData( 2, 10, 1, test );
	
//	EraseBlock(0);
	// command processing loop
	while ( !bExit )
	{
		// the plug-in will set a breakpoint at "AFP_BreakReady" so it knows
		// when we are ready for a new command because the DSP will halt
		//
		// the jump is used so that the label will be part of the debug
		// information in the driver image otherwise it may be left out
		// since the label is not referenced anywhere
		asm("AFP_BreakReady:");
		if ( FALSE )
			asm("jump AFP_BreakReady;");

		// switch on the command
		switch ( AFP_Command )
		{
			// get manufacturer and device codes
			case GET_CODES:
				AFP_Error = GetCodes();
				break;

			// reset
			case RESET:
				AFP_Error = ResetFlash();
				break;

			// write
			case WRITE:
				AFP_Error = WriteData( AFP_Offset, AFP_Count, AFP_Stride, AFP_Buffer );
				break;

			// fill
			case FILL:
				AFP_Error = FillData( AFP_Offset, AFP_Count, AFP_Stride, AFP_Buffer );
				break;

			// erase all
			case ERASE_ALL:
				AFP_Error = EraseFlash();
				break;

			// erase sector
			case ERASE_SECT:
				AFP_Error = EraseBlock( AFP_Sector );
				break;

			// read
			case READ:
				AFP_Error = ReadData( AFP_Offset, AFP_Count, AFP_Stride, AFP_Buffer );
				break;

			// get sector number based on address
			case GET_SECTNUM:
				AFP_Error = GetSectorNumber( AFP_Offset, &AFP_Sector );
				break;

			// get sector number start and end offset
			case GET_SECSTARTEND:
				AFP_Error = GetSectorStartEnd( &AFP_StartOff, &AFP_EndOff, AFP_Sector );
				break;

			// no command or unknown command do nothing
			case NO_COMMAND:
			default:
				// set our error
				AFP_Error = UNKNOWN_COMMAND;
				break;
		}

		// clear the command
		AFP_Command = NO_COMMAND;
	}

	// free the buffer if we were able to allocate one
	if ( AFP_Buffer )
		free( AFP_Buffer );


	// all done
	return 0;
}


//////////////////////////////////////////////////////////////
// ERROR_CODE SetupForFlash()
//
// Perform necessary setup for the processor to talk to the
// flash such as external memory interface registers, etc.
//
//////////////////////////////////////////////////////////////

ERROR_CODE SetupForFlash()
{
	asm("#define EBIU_AMGCTL 0xFFC00A00");

	// setup EBIU_AMGCTL reg (enable all banks)
	asm("p0.l = EBIU_AMGCTL & 0xFFFF;");
	asm("p0.h = (EBIU_AMGCTL >> 16) & 0xFFFF;");
	asm("r0 = 0x0f;");
	//asm("r0 = 0xff;");
	asm("w[p0] = r0;");

	return NO_ERR;
}


//////////////////////////////////////////////////////////////
// ERROR_CODE WriteData()
//
// Write a buffer to flash.
//
// Inputs:	unsigned long ulStart - offset in flash to start the writes at
//			long lCount - number of elements to write, in this case bytes
//			long lStride - number of locations to skip between writes
//			int *pnData - pointer to data buffer
//
//////////////////////////////////////////////////////////////

ERROR_CODE WriteData( unsigned long ulStart, long lCount, long lStride, int *pnData )
{
	long i = 0;						// loop counter
	int j = 0;						// inner loop counter
	unsigned long ulOffset = ulStart;// current offset to write
	int iShift = 0;					// shift value by iShift bits
	int iNumWords = 2;				// number of words in a long
	int nLeftover = lCount % 4;		// how much if any do we have leftover to write
	ERROR_CODE ErrorCode = NO_ERR;	// tells whether there was an error trying to write
	int nCompare = 0;				// value that we use to verify flash
	bool bVerifyError = FALSE;		// lets us know if there was a verify error
	int nSector = 0;

	// if the user wants to verify then do it
	if( AFP_Verify == TRUE )
	{
		// write the buffer up to BUFFER_SIZE items
		for (i = 0; (i < lCount/4) && (i < BUFFER_SIZE); i++)
		{
			for (iShift = 0, j = 0; ( ( j < iNumWords ) && ( ErrorCode == NO_ERR ) ); j++, ulOffset += (lStride * 2))
			{
				
				// check to see that the address is within a valid sector
				ErrorCode = GetSectorNumber( ulOffset, &nSector );
				if( NO_ERR == ErrorCode )
				{
					// unlock the flash, do the write, increase shift, and wait for completion
					UnlockFlash(ulOffset);
					WriteFlash( ulOffset, (pnData[i] >> iShift) );
					//ErrorCode = PollToggleBit(ulOffset);
					ErrorCode = Delay( DELAY_WRITE );
					ReadFlash( ulOffset, &nCompare );
					if( nCompare != ( (pnData[i]  >> iShift) & 0x0000FFFF ) )
					{
						bVerifyError = TRUE;
						break;
					}
					iShift += 16;
				}
				else
				{	// handle error
					bVerifyError = TRUE;
					return ErrorCode;
				}
			}
		}

		// because of the way our ldr file is built, we will always have
		// 2 bytes leftover if there is leftover, because the flash is 16 bit
		// that will mean only one write to do.
		if( ( nLeftover > 0 ) && ( ErrorCode == NO_ERR ) && bVerifyError == FALSE )
		{

			// check to see that the address is within a valid sector
			ErrorCode = GetSectorNumber( ulOffset, &nSector );
			if( NO_ERR == ErrorCode )
			{
				// unlock the flash, do the write, increase shift, and wait for completion
				UnlockFlash(ulOffset);
				WriteFlash( ulOffset, pnData[i] );
				ErrorCode = PollToggleBit(ulOffset);
				ReadFlash( ulOffset, &nCompare );
				if( nCompare != ( pnData[i] & 0x0000FFFF ) )
				{
					bVerifyError = TRUE;
				}
			}
			else
			{
				return ErrorCode;
			}
		}

		
		// return appropriate error code if there was a verification error
		if( bVerifyError == TRUE )
			return VERIFY_WRITE;
	}
	// the user does not want to verify
	else
	{
		// write the buffer up to BUFFER_SIZE items
		for (i = 0; (i < lCount/4) && (i < BUFFER_SIZE); i++)
		{
			for (iShift = 0, j = 0; ( ( j < iNumWords ) && ( ErrorCode == NO_ERR ) ); j++, ulOffset += (lStride * 2))
			{

				// check to see that the address is within a valid sector
				ErrorCode = GetSectorNumber( ulOffset, &nSector );
				if( NO_ERR == ErrorCode )
				{
					// unlock the flash, do the write, increase shift, and wait for completion
					UnlockFlash(ulOffset);
					WriteFlash( ulOffset, (pnData[i] >> iShift) );
					//ErrorCode = PollToggleBit(ulOffset);
					ErrorCode = Delay( DELAY_WRITE );
					iShift += 16;
				}
				else
				{
					return ErrorCode;
				}
			}
		}

		// because of the way our ldr file is built, we will always have
		// 2 bytes leftover if there is leftover, because the flash is 16 bit
		// that will mean only one write to do.
		if( ( nLeftover > 0 ) && ( ErrorCode == NO_ERR ) )
		{
			// you cannot write to this region in flash
			if( ( ulOffset >= 0x20270000 ) && ( ulOffset < 0x20280000 ) )
				return INVALID_SECTOR;

			// check to see that the address is within a valid sector
			ErrorCode = GetSectorNumber( ulOffset, &nSector );
			if( NO_ERR == ErrorCode )
			{
				// unlock the flash, do the write, increase shift, and wait for completion
				UnlockFlash(ulOffset);
				WriteFlash( ulOffset, pnData[i] );
				ErrorCode = PollToggleBit(ulOffset);
			}
			else
			{
				return ErrorCode;
			}
		}

	}

	// return the appropriate error code
	return ErrorCode;
}


//////////////////////////////////////////////////////////////
// ERROR_CODE FillData()
//
// Fill flash with a value.
//
// Inputs:	unsigned long ulStart - offset in flash to start the writes at
//			long lCount - number of elements to write, in this case bytes
//			long lStride - number of locations to skip between writes
//			int *pnData - pointer to data buffer
//
//////////////////////////////////////////////////////////////

ERROR_CODE FillData( unsigned long ulStart, long lCount, long lStride, int *pnData )
{
	long i = 0;							// loop counter
	unsigned long ulOffset = ulStart;	// current offset to write
	ERROR_CODE ErrorCode = NO_ERR;		// tells whether we had an error while filling
	int nCompare = 0;					// value that we use to verify flash
	bool bVerifyError = FALSE;			// lets us know if there was a verify error
	unsigned long ulNewOffset = 0;		// used if we have an odd address
	int nSector = 0;

	// if we have an odd offset we need to write a byte
	// to the first location and the last
	if(ulOffset%2 != 0)
	{
		// read the offset - 1 and OR in our value
		ulNewOffset = ulOffset - 1;
		ReadFlash( ulNewOffset, &nCompare );
		nCompare &= 0xFF00;
		nCompare |= (pnData[0] & 0x00FF);

		// unlock the flash, do the write, and wait for completion
		UnlockFlash(ulNewOffset);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费黄色在线| 欧美精品一区视频| 日韩视频不卡中文| 亚洲国产高清在线| 无吗不卡中文字幕| 成人精品鲁一区一区二区| 在线视频你懂得一区二区三区| 欧美一级日韩免费不卡| 亚洲欧洲在线观看av| 蜜臀久久99精品久久久久久9| 国产91丝袜在线播放0| 69久久夜色精品国产69蝌蚪网| 国产亚洲欧美色| 日本aⅴ精品一区二区三区| 99re热视频精品| 久久九九影视网| 精品一区二区国语对白| 欧美日韩卡一卡二| 亚洲精品一二三| 成人网在线播放| 亚洲自拍都市欧美小说| 国产真实乱子伦精品视频| 欧美亚洲动漫制服丝袜| 国产精品久久久久影院老司| 久久er精品视频| 91.com在线观看| 亚洲va中文字幕| 欧美日韩国产123区| 亚洲色图视频网| 99久久综合99久久综合网站| 国产婷婷精品av在线| 另类小说视频一区二区| 欧美精品成人一区二区三区四区| 亚洲色图欧美激情| 91一区二区三区在线播放| 中文久久乱码一区二区| 成人在线一区二区三区| 国产精品色一区二区三区| 国产老妇另类xxxxx| 久久嫩草精品久久久精品一| 国内精品第一页| 久久夜色精品国产噜噜av| 国产在线日韩欧美| 国产亚洲人成网站| 国产91精品欧美| 国产精品国产三级国产三级人妇 | 精品国产百合女同互慰| 日韩电影免费在线观看网站| 91精品在线麻豆| 久久99热狠狠色一区二区| 日韩欧美精品在线视频| 久久成人久久鬼色| 久久精品网站免费观看| 国产成人av在线影院| 中文字幕一区二区三区视频| 91丨九色丨尤物| 亚洲香蕉伊在人在线观| 欧美一区二区三区日韩视频| 激情五月播播久久久精品| 国产日产欧产精品推荐色| 99久久久国产精品免费蜜臀| 亚洲综合精品久久| 欧美成人精品1314www| 成人在线视频首页| 亚洲亚洲精品在线观看| 日韩三级视频在线看| 国产传媒一区在线| 亚洲综合999| 欧美变态凌虐bdsm| 99久久久精品| 奇米一区二区三区| 国产精品美女一区二区| 欧美日韩国产免费一区二区| 久久激五月天综合精品| 成人免费在线播放视频| 91精品国产高清一区二区三区| 国产激情一区二区三区| 亚洲一区免费在线观看| 精品欧美一区二区在线观看| 成人激情校园春色| 日韩av高清在线观看| 国产精品夫妻自拍| 91精品国产91久久久久久最新毛片| 国产黄色精品视频| 香蕉久久一区二区不卡无毒影院| 亚洲午夜久久久久久久久久久| 欧美一区二区三区精品| 成人激情午夜影院| 久久精品二区亚洲w码| 亚洲精品欧美专区| 国产区在线观看成人精品| 欧美精品少妇一区二区三区 | 一卡二卡欧美日韩| 久久久亚洲综合| 欧美日韩一二区| 99视频在线观看一区三区| 久久99久国产精品黄毛片色诱| 亚洲精品视频一区二区| 欧美韩日一区二区三区| 日韩一区二区影院| 欧美日韩国产在线播放网站| 成人av网站免费观看| 国产在线播精品第三| 亚洲国产精品一区二区www在线| 国产精品三级av| 久久久高清一区二区三区| 91精品国产乱码久久蜜臀| 在线观看av一区二区| 99精品1区2区| 9l国产精品久久久久麻豆| 国产精品自拍网站| 国产综合色产在线精品| 美女网站在线免费欧美精品| 亚洲成人av中文| 亚洲一区二区三区四区中文字幕| 中文字幕日本不卡| 国产精品日韩精品欧美在线| ww久久中文字幕| 欧美mv和日韩mv的网站| 337p粉嫩大胆色噜噜噜噜亚洲| 日韩一区二区三区视频在线| 欧美日韩视频在线一区二区| 日本精品一区二区三区四区的功能| 不卡影院免费观看| 91在线观看视频| 91蜜桃在线免费视频| 91亚洲精品一区二区乱码| 色婷婷久久综合| 欧美丝袜自拍制服另类| 欧美日韩高清在线| 日韩欧美激情一区| 久久久亚洲国产美女国产盗摄| 精品国产sm最大网站| 国产无遮挡一区二区三区毛片日本| 国产欧美视频一区二区三区| 国产精品人成在线观看免费| 国产精品毛片高清在线完整版| 中文字幕在线一区二区三区| 亚洲嫩草精品久久| 亚洲二区在线视频| 看国产成人h片视频| 国产精品99久| 91麻豆文化传媒在线观看| 欧洲一区二区三区在线| 91麻豆精品国产91久久久使用方法 | 精品亚洲aⅴ乱码一区二区三区| 久久精工是国产品牌吗| 粉嫩av一区二区三区在线播放| 99久久精品国产麻豆演员表| 欧美亚洲综合另类| 精品盗摄一区二区三区| 国产精品久久久久久久久免费桃花 | 欧美日韩一区视频| 欧美一区二区三区系列电影| 久久久99免费| 亚洲已满18点击进入久久| 日本美女视频一区二区| 国产99一区视频免费| 91久久久免费一区二区| 欧美变态tickle挠乳网站| 亚洲欧洲日本在线| 久久精品国产99| 91久久精品一区二区三| 欧美精品一区二区三区一线天视频| 亚洲欧洲成人精品av97| 日韩电影在线观看电影| 97精品国产97久久久久久久久久久久| 欧美亚洲综合网| 国产精品久久久久久久久搜平片 | 欧美性色aⅴ视频一区日韩精品| 日韩一区二区免费电影| 中文字幕亚洲一区二区av在线| 日韩av高清在线观看| 91视频在线观看| 国产亚洲精品资源在线26u| 亚洲成人av资源| 99在线精品观看| 久久欧美一区二区| 日韩和欧美一区二区三区| av在线不卡网| 精品日韩99亚洲| 婷婷久久综合九色综合绿巨人 | 日韩欧美中文字幕精品| 亚洲欧美日韩一区二区三区在线观看| 久久成人av少妇免费| 欧美午夜电影网| 亚洲黄色在线视频| www..com久久爱| 国产无遮挡一区二区三区毛片日本| 日韩高清中文字幕一区| 在线观看亚洲a| 亚洲色图一区二区三区| 成人性生交大片免费看在线播放| 日韩欧美一区电影| 日韩精品成人一区二区在线| 欧洲精品视频在线观看| ...av二区三区久久精品| 国产a区久久久| 国产亲近乱来精品视频| 国产麻豆精品95视频|