//串口初始化:
#define EN_USART2_RX 1
void RS485_Init(u32 bound)
{
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;
NVIC_InitTypeDef NVIC_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOG, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; // RE
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOG, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; //PA2 TX
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_Init(GPIOA, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;//PA3 RX
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);
RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART2,ENABLE);
RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART2,DISABLE);//í£?1?′??
#ifdef EN_USART2_RX //
USART_InitStructure.USART_BaudRate = 9600;//波特率9600;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;//8位数据位
USART_InitStructure.USART_StopBits = USART_StopBits_1;//停止位1位
USART_InitStructure.USART_Parity = USART_Parity_No;//奇偶校验无
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//串口配置为收发模式
USART_Init(USART2, &USART_InitStructure); ;
NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn; //指定中断
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; //中断抢占优先级
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //′中断响应优先级
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; // 中断函数使能
NVIC_Init(&NVIC_InitStructure);
USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//接收终端使能
USART_Cmd(USART2, ENABLE); //串口使能
#endif
RS485_TX_EN=0; //默认配置为接收模式 这里可以用GPIO_ResetBits(GPIOG,GPIO_Pin_9),同样置1可用GPIO_SetBits(),
}
//串口的中断函数:
void USART2_IRQHandler(void)
{
u8 res;
if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)
{
res =USART_ReceiveData(USART2);
RS485_TX_EN = 1;
// 此处发送数据主要是为了检验中断是否进行触发
while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
USART_SendData(USART2,0xff);
while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
RS485_TX_EN = 0;
if(RS485_RX_CNT<64)
{
RS485_RX_BUF[RS485_RX_CNT]=res;、
RS485_RX_CNT++;
}
}
}
好吧,今天又被串口虐的死去活来,最开始一直怀疑是自己的程序写的有问题,纠结串口配置是不是出问题了,最后找个demo自己找问题,发现收发数据是需要控制复位引脚,进行收发控制,我这里是复位引脚置为1,则可以进行发,为0,则表示收数据,当然如果你觉得设置好复位引脚的值就可以进行发送送数据了,呵呵,你看到的还是一片白,我的数据呢??在发送数据之前你需要写这样一条代码
while(USART_GetFlagStatus(USARTx,USART_FLAG_TC)==RESET),这样我们就用USART_Send(USARTx,data); 发送数据了,之后我们同样还需要用
while(USART_GetFlagStatus(USARTx,USART_FLAG_TC)==RESET)来处理自己发送的内容,看上去复杂吧,呵呵。
下面给出具体步骤:
1. 像配置232串口一样配置rs485的引脚,使能相应的时钟。
RX: GPIO_Mode_IN_FLOATING/GPIO_Mode_IPD
TX: GPIO_Mode_Out_PP
RE: GPIO_Mode_Out_PP
2. 进行中断配置
3. 记得使能中断和串口。
具体还是看代码吧。