|
串口接收到的數(shù)據(jù):01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02 03 04 01 02
相關(guān)代碼:
unsigned char Send[5]= {0x01,0x02,0x03,0x04,0x05};
//串口2發(fā)送數(shù)據(jù)
void USART2_SendData(char Data)
{
while (USART2_BUSY);
USART2_BUSY = 1;
S2BUF = Data;
}
void USART2_SendDataUint8(uint8 Data)
{
while (USART2_BUSY);
USART2_BUSY = 1;
S2BUF = Data;
}
//串口2發(fā)送字符串
void USART2_SendStr(char *USARTData,int Lenght)
{
int j=0;
for(j=0; j<Lenght; j++)
{
USART2_SendData(USARTData[j]);
}
}
void USART2_Init()
{
S2CON = 0x50; //模式0,8位可變波特率,允許串口接受數(shù)據(jù)
T2L = (65536-(11059200/4/9600)); //設(shè)置定時(shí)器2初值,用于波特率發(fā)生器,該值決定波特率
T2H = (65536-(11059200/4/9600))>>8;
AUXR = 0x14; //開定時(shí)器2,時(shí)鐘為1T模式,作為波特率發(fā)生器
IE2 = 0x01; //開啟串口2的中斷
EA=1;
P1M1 &= ~0x02;
P1M0 |= 0x02; //串口2的發(fā)送口設(shè)置為雙向口
T3L = 0x00; //設(shè)置定時(shí)初值,20ms
T3H = 0xB8; //設(shè)置定時(shí)初值
//定時(shí)器3和定時(shí)器4只能工作于自動(dòng)重裝載模式
T4T3M &= ~0x04; //工作于定時(shí)器模式,定時(shí)器3用作一幀數(shù)據(jù)結(jié)束的間隔時(shí)間的判斷
T4T3M &= ~0x02; //工作于定時(shí)器模式
IE2 |= ET3; //使能定時(shí)器中斷
USART2_BUSY=0; //串口1忙標(biāo)志初始狀態(tài)為0
}
//低于16MHz的時(shí)鐘頻率在自行調(diào)節(jié)時(shí)有一定的誤差
//需要將其調(diào)制目標(biāo)頻率的2至3倍,然后再進(jìn)行分頻
//這里十分重要,否則在串口而通訊的時(shí)候會導(dǎo)致波特率不準(zhǔn)卻,然后出現(xiàn)亂碼
P_SW2 = 0x80;
CKSEL = 0x00; //選擇內(nèi)部 IRC ( 默認(rèn) )
CLKDIV = 0x02; //2分頻
P_SW2 = 0x00;
USART2_Init();
while(1)
{
USART2_SendStr(Send,5);
Delay10ms();
}
}
//串口2中斷服務(wù)程序
void USART2_Handle(void) interrupt 8
{
if (S2CON & S2TI)
{
USART2_BUSY = 0; //清忙標(biāo)志
S2CON &= ~S2TI; //清除S3TI位
}
if(S2CON & S2RI)
{
T4T3M |= 0x08; //啟動(dòng)定時(shí)器
USART2_RecBuff[USART2_ReceCount++]=S2BUF;
TL3 = 0x00; //設(shè)置定時(shí)初值 ,20ms
TH3 = 0xB8; //設(shè)置定時(shí)初值
S2CON &= ~0x01; //清楚接收中斷
}
}
void TIME3_Handle(void) interrupt 19
{
USART2_RecOverFlag=1; //定時(shí)器溢出,說明一幀數(shù)據(jù)接收完成置位標(biāo)志位
USART2_ReceCount=0;
TL3 = 0x00; //設(shè)置定時(shí)初值 ,20ms
TH3 = 0xB8; //設(shè)置定時(shí)初值
T4T3M &= ~0x08; //關(guān)定時(shí)器
AUXINTIF &= ~T3IF; //清中定時(shí)器中斷標(biāo)志
}
哪位大神能幫忙看看這個(gè)問題,為什么我的最后一個(gè)0x05在串口中沒有接收到。
void USART2_SendStr(char *USARTData,int Lenght)
{
int j=0;
for(j=0; j<Lenght; j++)
{
USART2_SendData(USARTData[j]);
}
} //這個(gè)邏輯我再其他單片機(jī)上驗(yàn)證過的,為什么在這里就不行了呢,哪位高手能解釋一下這個(gè)問題嗎
|
|