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