2、GD32F470ZK USART发送和接收中断

一、串口初始化

void Serial_Init(void)
{	
	rcu_periph_clock_enable(RCU_GPIOA);
	rcu_periph_clock_enable(RCU_USART1);
	
	gpio_af_set(GPIOA, GPIO_AF_7, GPIO_PIN_2);
	gpio_af_set(GPIOA, GPIO_AF_7, GPIO_PIN_3);
	gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_NONE, GPIO_PIN_2);
	gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_2);
	gpio_mode_set(GPIOA, GPIO_MODE_INPUT, GPIO_PUPD_NONE, GPIO_PIN_3);
	
	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_data_first_config(USART1, USART_MSBF_LSB);
	
	nvic_priority_group_set(NVIC_PRIGROUP_PRE2_SUB2);
	nvic_irq_enable(USART1_IRQn, 0, 0);
	usart_interrupt_enable(USART1, USART_INT_RBNE);
	
	usart_transmit_config(USART1, USART_TRANSMIT_ENABLE);
	usart_receive_config(USART1, USART_RECEIVE_ENABLE);
	usart_enable(USART1);
}

二、串口发送一个字节数据

void Serial_SendByte(uint16_t txData)
{
	usart_data_transmit(USART1, txData);
	while(usart_flag_get(USART1, USART_FLAG_TBE) == RESET);
}

三、串口接收一个字节数据

uint16_t Serial_ReceiveByte(void)
{
	uint16_t rxData;
	while(usart_flag_get(USART1, USART_FLAG_RBNE) == RESET);
	rxData = usart_data_receive(USART1);
	return rxData;
}

四、串口中断处理函数

void USART1_IRQHandler(void)
{
	if(usart_flag_get(USART1, USART_FLAG_RBNE) == SET)
	{
		receive_Byte = Serial_ReceiveByte();
    }
	usart_interrupt_flag_clear(USART1, USART_INT_FLAG_RBNE);
}

其他功能函数可以参考我的stm32的内容

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是使用GD32F470zit6进行SPI中断接收数据的基本流程: 1. 初始化SPI控制器。设置SPI的通信参数,如时钟极性、相位、数据位、帧格式等。 2. 配置SPI接收缓冲区。开辟一个缓冲区用于存储接收到的数据。 3. 配置SPI中断。使能SPI中断,并设置中断优先级。 4. 在中断服务程序中接收数据。当SPI接收数据时,会触发中断。在中断服务程序中,读取SPI数据寄存器中的数据,并存储到接收缓冲区中。 下面是一个简单的示例代码,展示如何使用GD32F470zit6进行SPI中断接收数据: ``` #include "gd32f4xx.h" #define SPI_SLAVE_SELECT_PIN GPIO_PIN_4 #define SPI_SLAVE_SELECT_PORT GPIOC uint8_t rx_buffer[256]; volatile uint8_t rx_index = 0; void spi_init(void) { spi_parameter_struct spi_init_struct; rcu_periph_clock_enable(RCU_GPIOC); rcu_periph_clock_enable(RCU_SPI1); gpio_init(SPI_SLAVE_SELECT_PORT, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, SPI_SLAVE_SELECT_PIN); spi_i2s_deinit(SPI1); spi_init_struct.trans_mode = SPI_TRANSMODE_RECEIVEONLY; spi_init_struct.device_mode = SPI_DEVICE_SLAVE; spi_init_struct.frame_size = SPI_FRAMESIZE_8BIT; spi_init_struct.clock_polarity_phase = SPI_CK_PL_LOW_PH_2EDGE; spi_init_struct.nss = SPI_NSS_HARD; spi_init_struct.prescale = SPI_PSC_256; spi_init_struct.endian = SPI_ENDIAN_LSB; spi_init(SPI1, &spi_init_struct); nvic_irq_enable(SPI1_IRQn, 0, 0); spi_i2s_interrupt_enable(SPI1, SPI_I2S_INT_RBNE); } void SPI1_IRQHandler(void) { if (RESET != spi_i2s_interrupt_flag_get(SPI1, SPI_I2S_INT_RBNE)) { rx_buffer[rx_index++] = spi_i2s_data_receive(SPI1); spi_i2s_interrupt_flag_clear(SPI1, SPI_I2S_INT_RBNE); } } int main(void) { spi_init(); while(1) { // Wait for data to be received if (rx_index > 0) { // Process received data // ... // Reset receive buffer index rx_index = 0; } } } ``` 在这个示例中,我们使用SPI1作为从设备(SPI_DEVICE_SLAVE),并开启接收中断。当SPI接收数据时,会触发中断中断服务程序中会将接收到的数据存储到rx_buffer中,并将rx_index加1。在主程序中,我们可以通过检查rx_index是否大于0来判断是否有数据接收,然后进行相应的处理。注意,在处理完数据后,需要将rx_index重置为0。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值