GD32f303之rs485配置

本文详细介绍了如何使用RS485进行硬件通信接口的初始化,包括USART配置、RS485使能和中断初始化。通过示例代码展示了发送和接收数据的流程,采用两线制半双工通讯方式,适用于工业控制和远程通信场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介

        rs485是一种硬件通信接口,USART引脚的TTL电平通过SP485芯片转换为差分信号,+2V~+6V表示"0",- 6V~- 2V表示"1"。RS485有两线制和四线制两种接线,四线制是全双工通讯方式,本文采用两线制半双工通讯方式。

1 rs485初始化

    //1、USART配置
    /* enable GPIO clock */
    rcu_periph_clock_enable(RCU_GPIOB);

    /* enable USART clock */
    rcu_periph_clock_enable(RCU_USART2);

    /* connect port to USARTx_Tx */
    gpio_init(GPIOB, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_10 );

    /* connect port to USARTx_Rx */
    gpio_init(GPIOB, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, GPIO_PIN_11);

    /* USART configure */
    usart_deinit(USART2);
    usart_baudrate_set(USART2, 9600U);
    usart_receive_config(USART2, USART_RECEIVE_ENABLE);        //默认接收使能
    usart_transmit_config(USART2, USART_TRANSMIT_ENABLE);
    usart_enable(com);

    //2、 rs485使能
    /* enable the RS485_OE clock */
    rcu_periph_clock_enable(RCU_GPIOC);
    /* configure led GPIO port */
    gpio_init(GPIOC, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ,GPIO_PIN_3);
    GPIO_BC(GPIOC) = GPIO_PIN_3; 	//默认接收使能

    //3、rs485中断初始化
    nvic_irq_enable(USART2_IRQn,0, 1U);
	usart_interrupt_enable(USART2, USART_INT_RBNE);         /* 使能USART2读区非空中断 */  
	usart_interrupt_enable(USART2, USART_INT_IDLE);         /* 使能USART2空闲中断 */

    

2 rs485发送数据

//发送数据
int rs485_send_data(uint8_t *buf, uint32_t len)
{   
    gpio_bit_set(GPIOC,  GPIO_PIN_3);; // 设置为发送模式
		
    while(len--)
	{
		while(RESET == usart_flag_get(USART2, USART_FLAG_TBE));	// 等待发送区为空
		usart_data_transmit(USART2, *(buf++));  		// 发送数据
    }
	while(RESET == usart_flag_get(USART2, USART_FLAG_TC));	// 发送完成中断
		
	rxcount = 0;		
	gpio_bit_reset(GPIOC,  GPIO_PIN_3);		// 设置为接收模式
		
	return 0;
}

3 中断接收数据

void USART2_IRQHandler(void)
{   
    if((RESET != usart_interrupt_flag_get(USART2, USART_INT_FLAG_RBNE)) && 
		(RESET != usart_flag_get(USART2, USART_FLAG_RBNE)))// 接收到数据
	{	
		rxbuffer[rxcount++] = usart_data_receive(USART2);
		usart_interrupt_flag_clear(USART2, USART_INT_FLAG_RBNE); //清中断标志
	} else if (RESET != usart_interrupt_flag_get(USART2, USART_INT_FLAG_IDLE)) {
	    usart_interrupt_flag_clear(USART2, USART_INT_FLAG_IDLE);
		usart_data_receive(USART2); /* 清除接收完成标志位 */
		g_rs485_receive_end = 1;     //事件通知接收完成
	}
}

当然可以!下面是一个简单的GD32f303RS485串口驱动示例代码: ```c #include "gd32f30x.h" #define USART USART1 void rs485_init(void) { rcu_periph_clock_enable(RCU_USART1); rcu_periph_clock_enable(RCU_AF); gpio_init(GPIOA, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_9); gpio_init(GPIOA, GPIO_MODE_AF_OD, GPIO_OSPEED_50MHZ, GPIO_PIN_10); usart_deinit(USART); usart_baudrate_set(USART, 9600); usart_parity_config(USART, USART_PM_NONE); usart_word_length_set(USART, USART_WL_8BIT); usart_stop_bit_set(USART, USART_STB_1BIT); usart_hardware_flow_rts_config(USART, USART_RTS_DISABLE); usart_hardware_flow_cts_config(USART, USART_CTS_DISABLE); usart_transmit_config(USART, USART_TRANSMIT_ENABLE); usart_receive_config(USART, USART_RECEIVE_ENABLE); usart_enable(USART); } void rs485_send(uint8_t *buffer, uint16_t len) { gpio_bit_reset(GPIOA, GPIO_PIN_10); // 设置为发送模式 for (uint16_t i = 0; i < len; i++) { usart_data_transmit(USART, buffer[i]); while (usart_flag_get(USART, USART_FLAG_TC) == RESET) ; } while (usart_flag_get(USART, USART_FLAG_TC) == RESET) ; gpio_bit_set(GPIOA, GPIO_PIN_10); // 设置为接收模式 } uint16_t rs485_receive(uint8_t *buffer, uint16_t maxlen) { uint16_t cnt = 0; gpio_bit_set(GPIOA, GPIO_PIN_10); // 设置为接收模式 while (usart_flag_get(USART, USART_FLAG_RBNE)) { buffer[cnt++] = usart_data_receive(USART); if (cnt >= maxlen) break; } return cnt; } ``` 这是一个简单的RS485串口驱动的初始化、发送和接收函数示例。你可以根据自己的需求进行修改和扩展。希望对你有所帮助!如果有任何问题,请随时提问。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小可嵌入式

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值