📄 uart.c
字号:
#include <string.h>
#include <stdlib.h>
#include "..\inc\44b.h"
#include "..\inc\44blib.h"
#include "..\inc\def.h"
#define KEY_BUFLEN 100
#define AFC_BUFLEN 0x100
char Uart_IntGetkey(void);
void Uart_Port(void);
void Return_Port(void);
void __irq Uart0_TxFifoInt(void);
void __irq Uart0_RxFifoInt(void);
void __irq Uart0_RxFifoErrorInt(void);
void __irq Uart0_RxInt(void);
void __irq Uart0_TxInt(void);
void __irq Uart1_TxFifoInt(void);
void __irq Uart1_RxFifoInt(void);
void __irq Uart1_RxFifoErrorInt(void);
void __irq Uart1_RxInt(void);
void __irq Uart1_TxInt(void);
void __irq U1AFC_TxInt(void);
void __irq U0AFC_RxInt(void);
void __irq U0AFC_RxErrorInt(void);
void __irq Exint2(void);
void __irq Test_Done(void);
void __irq Error(void);
static unsigned char keyBuf[KEY_BUFLEN];
volatile static int keyBufRdPt=0;
volatile static int keyBufWrPt=0;
volatile char out=1;
volatile static char *uart0TxStr;
volatile static char *uart1TxStr;
volatile U32 save_UC,save_UE,save_UF,save_UPC,save_UPE,save_UPF;
void Uart_Port(void)
{
save_UC=rPCONC;//for nRTS0,nCTS0
save_UE=rPCONE;//for TxD0,RxD0
save_UF=rPCONF;//for nRTS1,TxD1,RxD1,nCTS1
save_UPC=rPUPC;
save_UPE=rPUPE;
save_UPF=rPUPF;
rPCONC |=0xf0000000; //enable nCTS0,nRTS0,TXD1,RXD1
rPUPC |=0xc000;//Uart port pull-up disable
rPCONE=(rPCONE &0x3ffeb)|0x28; //enable TXD0,RXD0
rPUPE |=0x6;
rPCONF=(rPCONF &0x3ff)+0x124800;//ENABLE nCTS1,TXD1,RXD1,nCRS1
rPUPF |=0x1e0;
}
void Return_Port(void)
{
rPCONC=save_UC;
rPCONE=save_UE;
rPCONF=save_UF;
rPUPC=save_UPC;
rPUPE=save_UPE;
rPUPF=save_UPF;
}
char Uart_IntGetkey(void)
{
if(keyBufRdPt==KEY_BUFLEN)
keyBufRdPt=0;
while(keyBufWrPt==keyBufRdPt); //until FIFO is triggered
return keyBuf[keyBufRdPt++];
}
////////UART 0 TEST////////////////
void Test_Uart0(void)
{
int key;
Uart_Port();
keyBufRdPt=keyBufWrPt=0;
pISR_UTXD0=(unsigned)Uart0_TxInt;
pISR_URXD0=(unsigned)Uart0_RxInt;
/*********** UART0 Tx test with interrupt ***********/
Uart_Printf("[Uart channel 0 tx Interrupt Test]\n");
Uart_TxEmpty(0); //wait until tx shifter is empty.
uart0TxStr="UART0 Tx interrupt test is good!!!!\r\n";
rUCON0 = 0x244; //tx:level,rx:edge,error int,normal*2,interrupt(Start)
rINTMSK=~(BIT_GLOBAL|BIT_UTXD0);
Delay(3000);
/*********** UART0 Tx test with BDMA0 ***********/
rUCON0 = 0x245;//for BDMA0
Uart_Printf("\n[Uart0 Tx Test by BDMA0]\n");
uart0TxStr="UART0 Tx Test by BDMA0 is good!!!!\r\n";
Uart_TxEmpty(0);
rUCON0=0x48; //tx:BDMA0 rx:disable
rBDICNT0=0x0;
rBDCON0 =0x0;
rBDISRC0=(unsigned int)uart0TxStr|(0<<30)|(1<<28); // byte,inc
rBDIDES0=UTXH0 |(1<<30)|(3<<28); //L/B endian,M2IO,fix
rBDICNT0=strlen((char *)uart0TxStr)|(2<<30)|(1<<26)|(0<<20); //UART0,
rBDICNT0 |= (1<<20); //enable
while(!((rBDCON0&0x30)==0x20));
Uart_TxEmpty(0);
/*********** UART0 Rx test with interrupt ***********/
rUCON0=0x45; //tx:int rx:int
Uart_Printf("\n[Uart channel 0 Rx Interrupt Test]:Type any key!!!\n");
Uart_Printf("You will see the typed character. To quit, press Enter key.\n");
Uart_TxEmpty(0);
rINTMSK=~(BIT_GLOBAL|BIT_URXD0);
keyBufRdPt=keyBufWrPt=0;
while((key=Uart_IntGetkey())!='\r')
Uart_SendByte(key);
rINTMSK=~BIT_GLOBAL;
Uart_Printf("\n");
Return_Port();
}
void __irq Uart0_RxInt(void)
{
rI_ISPC=BIT_URXD0;
keyBuf[keyBufWrPt++]=RdURXH0();
if(keyBufWrPt==KEY_BUFLEN)
keyBufWrPt=0;
}
//unsigned int txcount=0;
void __irq Uart0_TxInt(void)
{
// rI_ISPC=BIT_UTXD0; //This cann't make the pending bit be cleared in the level trigger mode.
if(*uart0TxStr != '\0')
{
WrUTXH0(*uart0TxStr++);
rI_ISPC=BIT_UTXD0; //Because UART operates using level trigger mode.
}
else
// {
// rUCON0 &= 0x3f3; //workaround
// rI_ISPC=BIT_UTXD0; //This cann't make the pending bit be cleared in the level trigger mode.
// rINTMSK|=BIT_UTXD0;
// }
// WrUTXH0('@');
{ //ES3
rINTMSK |= BIT_UTXD0; //ES3
rI_ISPC=BIT_UTXD0; //ES3
} //ES3
}
////////Auto Flow Control TEST(Tx)////////////////
volatile unsigned char * volatile tx0,* tx1,*tx2,tx_end=0;
volatile int i;
volatile int tx_cnt=0;
void Test_UartAFC_Tx(void)
{
Uart_Port();
tx_cnt=0;
tx0=(unsigned char *)malloc(AFC_BUFLEN);
tx1=tx0;
tx2=tx0;
Uart_Printf("!!!tx0=0x%x\n",tx0);
for(i=0;i<AFC_BUFLEN;i++)
*tx1++=i;
pISR_UTXD1=(unsigned)U1AFC_TxInt;
// Led_Display(0xf); //LED off
Uart_Printf("[UART AFC Tx Test]\n");
Uart_Printf("This test should be configured two boards.\n");
Uart_Printf("Connect twitsted(rx/tx, nCTS/nRTS) cable com2 to other board's com1 port.\n");
Uart_Printf("Start Rx first and press any key and,.\n");
Uart_TxEmpty(0);
Uart_Getch();
rUCON1=(1<<9)|(0<<8)|(0<<7)|(0<<6)|(0<<5)|(0<<4)|(1<<2)|(1);
rUFCON1=0x0; //FIFO disable
rUMCON1=0x10; //Uart1 AFC enable
Uart_Printf("Now... Tx with AFC\n");
Uart_TxEmpty(0);
rINTMSK=~(BIT_GLOBAL|BIT_UTXD1);
while(!tx_end);
Led_Display(0x0); //LED on
Uart_Printf("\nEnd Tx, transfer data count=%d\n",tx_cnt);
Return_Port();
free((void *)tx0);
tx_end=0;
tx_cnt=0;
}
void __irq U1AFC_TxInt(void)
{
if(tx_cnt < (AFC_BUFLEN))
{
Uart_Printf("%d,",*tx2);
WrUTXH1(*tx2++);
rI_ISPC=BIT_UTXD1;
tx_cnt++;
}
else
{
Uart_TxEmpty(1);
/* rUCON1 &= 0x3f3;//workaround for ES1,2
rI_ISPC=BIT_UTXD1;
rINTMSK|=BIT_UTXD1;*/
rINTMSK |= BIT_UTXD0; //ES3
rI_ISPC=BIT_UTXD0; //ES3
tx_end=1;
}
}
////////Auto Flow Control TEST(Rx with FIFO)////////////////
volatile unsigned char *rx0,*rx1,*rx2,rx_end=0;
volatile int rx_cnt=0;
void Test_UartAFC_Rx(void)
{
unsigned int i;
unsigned int err_cnt=0;
Uart_Port();
Uart_Printf("[UART AFC Rx Test]\n");
Uart_Printf("This test should be configured two boards.\n");
Uart_Printf("Connect twisted(rx/tx, nCTS/nRTS) cable com1 to other board's com2 port.\n");
Uart_Printf("Then, change connected cable between host and com1, host to com2.\n");
Uart_Printf("Press any key to com2 and start Rx first.\n");
Uart_TxEmpty(0);
Uart_Select(1);
Uart_Getch();
rx0=(unsigned char *)malloc(AFC_BUFLEN);
rx1=rx0;
rx2=rx0;
pISR_URXD0=(unsigned)U0AFC_RxInt;
pISR_UERR01=(unsigned)U0AFC_RxErrorInt;
Led_Display(0xf); //LED off
rUMCON0=0x10; //Uart0 AFC enable
rUCON0=(1<<9)|(0<<8)|(1<<7)|(1<<6)|(0<<5)|(0<<4)|(1<<2)|(1);
rUFCON0=(2<<6)|(1<<4)|(1<<2)|(1<<1)|(1);
Uart_Printf("Now... Rx with AFC\n");
Uart_TxEmpty(1);
rINTMSK=~(BIT_GLOBAL|BIT_URXD0|BIT_UERR01);
while(!rx_end);
Delay(1000);
rINTMSK=BIT_GLOBAL;
Uart_Printf("\nEnd Rx, receive data count=%d\n",rx_cnt);
Led_Display(0x0); //LED on
Uart_Printf("Now, change connected cable between host and com2, host to com1.\n");
Uart_Printf("Then, press any key.\n");
Uart_Init(0,115200);
Uart_Select(0);
Uart_Getch();
for(i=0;i<AFC_BUFLEN;i++)
{
if(i-(*rx1++))
{
Uart_Printf("i=%d\n",i);
err_cnt++;
}
}
if(err_cnt)
Uart_Printf("AFC test fail!! Error count=%d\n",err_cnt);
else
Uart_Printf("AFC test is good!!\n");
Return_Port();
free((void *)rx0);
rx_end=0;
rx_cnt=0;
}
void __irq U0AFC_RxInt(void)
{
rI_ISPC=BIT_URXD0;
while( (rUFSTAT0 & 0x100) || ((rUFSTAT0 & 0xf) >0) )
{
Delay(1000);
*rx2++=rURXH0;
Uart_Printf("%d,",*(rx2-1));
rx_cnt++;
}
if(rx_cnt == (AFC_BUFLEN))
rx_end=1;
}
void __irq U0AFC_RxErrorInt(void)
{
rI_ISPC=BIT_UERR01;
switch(rUERSTAT0)//to clear and check the status of register bits
{
case 1:
WrUTXH1('!');
break;
case 2:
WrUTXH1('#');
break;
case 4:
WrUTXH1('$');
break;
case 8:
WrUTXH1('@');
break;
default :
WrUTXH1('*');
break;
}
}
char _done=0, error=0;
void Test_BDMA(void)
{
char *_buf,i;
char *_temp2;
int *_temp;
_buf=(char *)malloc(100);
_temp=(int *)malloc(1);
_temp2=_buf;
rINTMSK=~(BIT_GLOBAL|BIT_BDMA0|BIT_UERR01);
pISR_BDMA0=(unsigned)Test_Done;
pISR_UERR01=(unsigned)Error;
Uart_Init(0,115200);
Uart_Printf("[Read BDCON0 register in Rxing...]\n");
Uart_TxEmpty(0);
rBDISRC0=(0<<30)+(3<<28)+(int)URXH0; //byte,inc,Rx-buf
rBDIDES0=(2<<30)+(1<<28)+(int)_buf; //M2IO,fix,IISFIF
rBDICNT0=(2<<30)+(1<<26)+(3<<22)+(1<<21)+(0<<20)+700;
//Uart0,reserve,done_int,auto-reload/start,DMA disable,COUNT
rBDICNT0 |= (1<<20);//enable
rBDCON0 = 0x0<<2;
rUCON0=0x2c6; //tx:polling rx:BDMA0
while(!_done)
{
*_temp=rBDCON0;
if((rBDCON0 & 0xf))
{
Uart_Printf("!!Error0x%x!!,",rBDCON0);
break;
}
}
Uart_Printf("!END!\n");
if(error)
Uart_Printf("[rUERSTAT=0x%x]\n",rUERSTAT0);
rINTMSK=BIT_GLOBAL;
// rUCON0 &= 0x3fd;//Rx disable
rBDICNT0=0x0; //BDMA stop
for(i=0;i<10;i++)
Uart_Printf("%d=0x%x,",i,*_temp2++);
Uart_Printf("\n0x%x,",*_temp);
free(_buf);
_done=0;
}
void __irq Test_Done(void)
{
rI_ISPC=BIT_BDMA0; //clear pending bit
_done=1;
}
void __irq Error(void)
{
rI_ISPC=BIT_UERR01;
error=1;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -