stm32下485使用記錄
剛開(kāi)始編寫(xiě)代碼時(shí),由于對485使用不熟悉,不知道該注意哪些,就直接編寫(xiě)程序:
1.配置管腳,這里管腳配置232與485是一樣的,但485要用一個(gè)管腳的高低電平控制輸入輸出方向,這里使用使用4個(gè)管腳對串口2--串口4控制
2.中斷配置,每個(gè)串口給與打開(kāi)對應的中斷線(xiàn),并給與一定的優(yōu)先級
3.串口配置,這里包含時(shí)鐘、波特率、8N1等,并選擇使用的中斷事件,這里所有串口都選用接收中斷
232配置和485配置是一樣的,無(wú)非485是半雙工的,需要控制方向,還有一個(gè)特別注意的地方,也是我記錄這個(gè)文檔的原因:
由于硬件是我手工制作,不確定所用串口都能使用,所以使用循環(huán)輸出測試是否到pc的串口助手,測試結果發(fā)現程序一直會(huì )進(jìn)入
輸入中斷,沒(méi)錯是輸入中斷,發(fā)送數據進(jìn)入輸入中斷,后經(jīng)仔細研究發(fā)現問(wèn)題,代碼如下:
主函數
int main(void)
{
u8 cmd = 0xaa;
//配置過(guò)程不寫(xiě)了
while(1)
{
serial3_putchar(cmd);
}
}
串口接收中斷我已打開(kāi),這里不寫(xiě)了
串口3發(fā)送字節函數
void Serial3PutChar(u8 c)
{
int i;
MAX485EN3(); //485輸出控制 GPIO_SetBits(GPIOE, GPIO_Pin_15)
USART_SendData(USART3, c);
while (USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);
MAX485RE3(); //485輸入控制 GPIO_ResetBits(GPIOE, GPIO_Pin_15)
}
串口中斷服務(wù)子程序
void USART3_IRQHandler(void)
{
if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET)
{
Serial1PutChar(Serial3GetChar()); //串口1發(fā)送串口2接收到的數據
USART_ClearITPendingBit(USART2, USART_IT_RXNE);
}
}
后來(lái)經(jīng)過(guò)本人查找資料及反復思量,發(fā)現問(wèn)題是485發(fā)送數據的時(shí)間不夠,后經(jīng)修改波特率為9600,輸入中斷不再產(chǎn)生,
但發(fā)送數據與接收到的數據不相同,后在發(fā)送函數內加了一定時(shí)間延時(shí),方可!
void Serial3PutChar(u8 c)
{
int i;
MAX485EN3(); //485輸出控制 GPIO_SetBits(GPIOE, GPIO_Pin_15)
delay_mS(1);
USART_SendData(USART3, c);
while (USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);
delay_mS(10);
MAX485RE3(); //485輸入控制 GPIO_ResetBits(GPIOE, GPIO_Pin_15)
}
評論