?? binload.c
字號(hào):
}
/////////////////////////////////////////////////////////////////////////////
/*/ PopRingBuffer : 從RingBuffer取出Data時(shí)。 /*/
BOOL PopRingBuffer(PRINGBUFF buffer, BYTE* data)
{
if (buffer->cbData == 0) { /*/ Data數(shù)為0時(shí) /*/
return FALSE;
}
asm("fclr I"); /*/ 中斷禁止。 /*/
* data = buffer->abData[buffer->bReadIndex]; /*/ 從Buffer的讀入位置取出Data。 /*/
buffer->cbData --; /*/ 。 /*/
asm("fset I"); /*/ 中斷許可。 /*/
buffer->bReadIndex ++; /*/ 讀入位置的增加。 /*/
if (buffer->bReadIndex >= buffer->bSize) { /*/ 讀入位置在BufferSize以上時(shí) /*/
buffer->bReadIndex = 0; /*/ 讀入位置設(shè)為先頭。 /*/
}
return TRUE; /*/ 。 /*/
}
/////////////////////////////////////////////////////////////////////////////
/*/ UARTTxOn : Data送信的開(kāi)始。 /*/
void UARTTxOn(void)
{
BYTE data; /*/ 送信的Data。 /*/
if (((struct _PORT *) &U0C1)->bit1) { /*/ 送信BufferRegister中,Data沒(méi)有時(shí) /*/
if (PopRingBuffer(&UARTTx, &data)) { /*/ 送信Buffer中,Data有的時(shí)候 /*/
U0TB = (WORD)data; /*/ 送信BufferRegister中,Data的寫(xiě)入。 /*/
} else {
return; /*/。 /*/
}
}
}
/////////////////////////////////////////////////////////////////////////////
/*/ OnUARTTxEnd : UART送信Buffer為空時(shí)的處理。 /*/
void OnUARTTxEnd(void)
{
BYTE data; /*/ 送信Data。 /*/
if (UARTTx.cbData != 0) { /*/ Data數(shù)為0以外時(shí) /*/
data = UARTTx.abData[UARTTx.bReadIndex]; /*/ Buffer的讀入位置上,取出Data。 /*/
UARTTx.cbData --;
UARTTx.bReadIndex ++; /*/ 讀入位置的增加。 /*/
if (UARTTx.bReadIndex >= UARTTx.bSize) { /*/ 讀入位置為BufferSize以上時(shí) /*/
UARTTx.bReadIndex = 0; /*/ 讀入位置設(shè)為先頭。 /*/
}
U0TB = (WORD)data; /*/ 送信BufferRegister中,寫(xiě)入Data。 /*/
}
}
/////////////////////////////////////////////////////////////////////////////
/*/ OnUARTRxEnd : UART受信終了時(shí)的處理。 /*/
void OnUARTRxEnd(void)
{
WORD data; /*/ 受信Data。 /*/
data = U0RB; /*/ 受信Data的讀出。 /*/
if (HIBYTE(data) & 0xF0) { /*/ 受信Error有的時(shí)候 /*/
U0MR &= 0xF8; /*/ 串行I/O模式選擇Bit設(shè)為000。 /*/
U0C1 &= 0xFB; /*/ 受信許可Bit設(shè)為0。 /*/
U0MR |= 0x05; /*/ 串行I/O模式選擇Bit設(shè)為101。 /*/
U0C1 |= 0x04; /*/ 受信許可Bit設(shè)為1。 /*/
}
if (UARTRx.cbData < UARTRx.bSize) { /*/ Data數(shù)比BufferSize小的時(shí)候 /*/
UARTRx.abData[UARTRx.bWriteIndex] = LOBYTE(data); /*/ Buffer的寫(xiě)入位置中,Data的裝入。 /*/
UARTRx.cbData ++; /*/ Data數(shù)的增加。 /*/
UARTRx.bWriteIndex ++; /*/ 寫(xiě)入位置的增加。 /*/
if (UARTRx.bWriteIndex >= UARTRx.bSize) { /*/ 寫(xiě)入位置在BufferSize以上時(shí) /*/
UARTRx.bWriteIndex = 0; /*/ 寫(xiě)入位置設(shè)為先頭。 /*/
}
}
}
/////////////////////////////////////////////////////////////////////////////
/*/ Hextoc : Hex to char 1為的16進(jìn)數(shù)的ASCII文字變換為char。 /*/
char Hextoc(BYTE hex)
{
if ('0' <= hex && hex <= '9') { /*/ 數(shù)字時(shí) /*/
return hex - '0'; /*/ 返回0-9。 /*/
} else if (('a' <= hex && hex <= 'f') || ('A' <= hex && hex <= 'F')) { /*/ A-F時(shí) /*/
return (hex | 0x20) - 'a' + 10; /*/ 返回10-15。 /*/
} else {
return 0; /*/ 不能變換的話,返回0。 /*/
}
}
char ctoHex(UCHAR hex)
{
if (0 <= hex && hex <= 9) { // 數(shù)字時(shí)
return hex + '0'; // 返回0-9。
} else if (10 <= hex && hex <= 15) { // A-F時(shí)
return (hex -10 + 'A'); // 返回10-15。
} else {
return 0; // 不能變換的話,返回0。
}
}
/*===================================================================/*/
/*/ * 函數(shù)名 : CS0AddressTransform/*/
/*/ * 功能 : 將FLASH的物理地址轉(zhuǎn)換成CS0擴(kuò)展模式下的地址,同時(shí)可能更改BANKREG寄存器/*/
/*/為了效率,定義了全局變量WriteAddress, 地址變換都對(duì)它操作/*/
/*/ * 參數(shù)說(shuō)明 : FLASH的物理地址/*/
/*/ * 返回值說(shuō)明 : 擴(kuò)展模式下要訪問(wèn)的地址/*/
/*/ ==================================================================*/
void CS0AddressTransform(DWORD dwPhysicalAddress)
{
if(dwPhysicalAddress < 0x130000)
{
BANKREG |= 0x3f;
BANKREG &= (BYTE)(dwPhysicalAddress >> 15);
WriteAddress = (dwPhysicalAddress & 0x00007fff) + 0x28000;
}
else
{
WriteAddress = dwPhysicalAddress & 0xfffff;
}
}
/*/判斷FLASH類型.如果為不能支持或不能識(shí)別的類型,則返回FALSE.否由返回TRUE;/*/
BOOL DetectFlashType(void)
{
BYTE c;
BYTE ReturnString[16]; /*/返回給計(jì)算機(jī)的字符串。包含Device ID等字節(jié)。/*/
ReturnString[0] = 'I';
ReturnString[1] = 'D';
ReturnString[2] = ':';
ReturnString[3] = ' ';
// Enter autoselect mode, read manufacturercode and device code
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0xAA;
CS0AddressTransform(0x5555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0x90;
CS0AddressTransform(0x0);
ManufacturerCode = *((BYTE far*)(WriteAddress));
CS0AddressTransform(0x2);
DeviceCode = *((BYTE far*)(WriteAddress));
//RESET/READ
// FlashReset(); //reset until know the writemode
c = ctoHex(ManufacturerCode>>4);
ReturnString[4] = c;
c = ctoHex(ManufacturerCode&0x0f);
ReturnString[5] = c;
c = ctoHex(DeviceCode>>4);
ReturnString[6] = c;
c = ctoHex(DeviceCode&0x0f);
ReturnString[7] = c;
c = ctoHex((~ManufacturerCode)>>4);
ReturnString[8] = c;
c = ctoHex((~ManufacturerCode)&0x0f);
ReturnString[9] = c;
c = ctoHex((~DeviceCode)>>4);
ReturnString[10] = c;
c = ctoHex((~DeviceCode)&0x0f);
ReturnString[11] = c;
c = ctoHex((ManufacturerCode+DeviceCode)>>4);
ReturnString[12] = c;
c = ctoHex((ManufacturerCode+DeviceCode)&0x0f);
ReturnString[13] = c;
ReturnString[14] = 0x0d;
ReturnString[15] = 0x0a;
WriteUART(szVersion,13);
WriteUART(ReturnString,16);
return TRUE;
}
/*===================================================================/*/
/*/ * 函數(shù)名 : FlashEraseSector/*/
/*/ * 功能 : 擦除FLASH的塊/*/
/*/ * 參數(shù)說(shuō)明 : Sector地址/*/
/*/ * 返回值說(shuō)明 : 成功返回TRUE,失敗返回FALSE/*/
/*/ ==================================================================*/
BOOL FlashEraseSector(DWORD sectoraddr)
{
BYTE polling;
switch(BinFileHeader.Struct.WriteMode)
{
case 0:
CS0AddressTransform(0xAAA);
*((BYTE far*)(WriteAddress)) = 0xAA;
CS0AddressTransform(0x555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaa);
*((BYTE far*)(WriteAddress)) = 0x80;
CS0AddressTransform(0xaaa);
*((BYTE far*)(WriteAddress)) = 0xAA;
CS0AddressTransform(0x555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(sectoraddr);
*((BYTE far*)(WriteAddress)) = 0x30;
do{
polling = *((BYTE far*)(WriteAddress));
}while ( (polling & 0x80) == 0 );
break;
case 1:
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0xaa;
CS0AddressTransform(0x5555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0x80;
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0xAA;
CS0AddressTransform(0x5555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(sectoraddr);
*((BYTE far*)(WriteAddress)) = 0x50;
do{
polling = *((BYTE far*)(WriteAddress));
}while ( (polling & 0x80) == 0 );
break;
case 2:
CS0AddressTransform(sectoraddr);
*((BYTE far*)(WriteAddress)) = 0x70; //0x70:read status, addr : don't care
do{
polling = *((BYTE far*)(WriteAddress));
}while ( (polling & 0x80) == 0 ); // read status, while busy , waiting
*((BYTE far*)(WriteAddress)) = 0x20; //0x20:erase setup
*((BYTE far*)(WriteAddress)) = 0xd0; //0x20:erase confirm
do{
polling = *((BYTE far*)(WriteAddress));
}while ( (polling & 0x80) == 0 ); // read status, while busy , waiting
*((BYTE far*)(WriteAddress)) = 0xff; //0xff:reset
break;
}
//polling check, and time out check
return TRUE;
}
/*===================================================================/*/
/*/ * 函數(shù)名 : FlashReset/*/
/*/ * 功能 : Reset FLASH/*/
/*/ * 參數(shù)說(shuō)明 : /*/
/*/ * 返回值說(shuō)明 : 無(wú)/*/
/*/ ==================================================================*/
void FlashReset(void)
{
switch(BinFileHeader.Struct.WriteMode)
{
case 0:
CS0AddressTransform(0);
*((BYTE far*)(WriteAddress)) = 0xf0;
break;
case 1:
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0xaa;
CS0AddressTransform(0x5555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0xf0;
break;
case 2:
*((BYTE far*)(WriteAddress)) = 0xff; //intel reset
}
}
#if 0 /*/不用ChipErase。因?yàn)槿绻型镜綦妼⒑芪kU(xiǎn)。/*/
/*===================================================================/*/
/*/ * 函數(shù)名 : FlashChipErase/*/
/*/ * 功能 : 擦除整個(gè)FLASH/*/
/*/ * 參數(shù)說(shuō)明 : /*/
/*/ * 返回值說(shuō)明 : 無(wú)/*/
/*/ ==================================================================*/
void FlashChipErase(void)
{
BYTE polling;
/****************** CHIP ERASE *********************/
switch(BinFileHeader.Struct.WriteMode)
{
case 0:
CS0AddressTransform(0xAAA);
*((BYTE far*)(WriteAddress)) = 0xAA;
CS0AddressTransform(0x555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaa);
*((BYTE far*)(WriteAddress)) = 0x80;
CS0AddressTransform(0xaaa);
*((BYTE far*)(WriteAddress)) = 0xAA;
CS0AddressTransform(0x555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaa);
*((BYTE far*)(WriteAddress)) = 0x10;
break;
case 1:
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0xaa;
CS0AddressTransform(0x5555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0x80;
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0xAA;
CS0AddressTransform(0x5555);
*((BYTE far*)(WriteAddress)) = 0x55;
CS0AddressTransform(0xaaaa);
*((BYTE far*)(WriteAddress)) = 0x10;
break;
}
//polling check
CS0AddressTransform(0x00);
do{
polling = *((BYTE far*)(WriteAddress));
}while ( (polling & 0x80) == 0 );
}
#endif
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -