在后续的开发中需要用到两个串口,从手册中可以看出此芯片是有2个UART模块的,demo中给出的例子是用了UART1(虽然有几句注释写的是UART2,不要被误导)。
1.demo代码分析
- void EvbUart1Config(void)
- {
- rcu_periph_clock_enable(RCU_GPIOA);
- rcu_periph_clock_enable(RCU_USART1);
- /* connect port to USART1_Tx */
- gpio_af_set(GPIOA, GPIO_AF_1, GPIO_PIN_2);
- /* connect port to USARTx_R1 */
- gpio_af_set(GPIOA, GPIO_AF_1, GPIO_PIN_3);
- /* configure USART1 Tx as alternate function push-pull */
- gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_PULLUP,GPIO_PIN_2);
- gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ,GPIO_PIN_2);
- /* configure USART2 Rx as alternate function push-pull */
- gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_PULLUP,GPIO_PIN_3);
- gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ,GPIO_PIN_3);
- /* USART2 configure */
- usart_deinit(USART1);
- usart_baudrate_set(USART1,115200);
- usart_receive_config(USART1, USART_RECEIVE_ENABLE);
- usart_transmit_config(USART1, USART_TRANSMIT_ENABLE);
- usart_enable(USART1);
- }
复制代码
这一段是demo中对串口的初始化,可以看出deinit后只是配置了波特率,那么其余的校验(无)、数据长度(8位)、停止位(1位)都是默认。并没有配置和使能中断。我所需要的是接收由中断触发,那么在此基础上去整理和修改。
2、加入接收中断
- void uart_init()
- {
-
- usart_deinit(USART1);
- usart_baudrate_set(USART1,115200);
- usart_parity_config(USART1, USART_PM_NONE);
- usart_word_length_set(USART1, USART_WL_8BIT);
- usart_stop_bit_set(USART1, USART_STB_1BIT);
- usart_receive_config(USART1, USART_RECEIVE_ENABLE);
- usart_transmit_config(USART1, USART_TRANSMIT_ENABLE);
-
- usart_interrupt_enable(USART1, USART_INT_RBNEIE);
- nvic_irq_enable(USART1_IRQn, 0, 2);
- usart_enable(USART1);
- }
复制代码
为了配置看起来更加合理,将校验等项目都配置一次。使能的是接收中断(接收不为空触发中断)。至此依然没有结束,需要添加nvic_irq_enable(USART1_IRQn, 0, 2); 配置优先级同时使能这个中断通道。
在main函数开始处设置了nvic_priority_group_set(NVIC_PRIGROUP_PRE0_SUB4);
- void USART1_IRQHandler()
- {
- uint8_t tmp = 0;
- tmp = usart_data_receive(USART1);
- uart1_write_ch(tmp);
- }
复制代码
中断处理函数将收到的发出去,以此验证是否成功。
hex格式发送0x34就是字符'4'了。
本文来自论坛,点击查看完整帖子内容。