- [cpp] view plain copy
- //串口初始化:
-
- #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. 记得使能中断和串口。
具体还是看代码吧。
|