gd32f330-正交编码器配置

背景:
  • 使用编码器获取电机的转动情况,gd32部分timer带有编码器模式,因此可以直接使用简化处理。
环境:
  • 硬件平台:gd32f330r8t6
  • gd库版本:GD32F3x0_Firmware_Library_V2.2.1
配置源码
  • 使用timer0的ch0和ch1通道,ch2和ch3不能再使用
  • io使用PA8 PA9
void timer_encode_config(void)
{
	timer_ic_parameter_struct timer_icintpara;
	timer_oc_parameter_struct timer_ocintpara;
    timer_parameter_struct timer_initpara;

    rcu_periph_clock_enable(RCU_TIMER0);

    rcu_periph_clock_enable(RCU_GPIOA);

    /*Configure PA8 PA9 PA10(TIMER0 CH0 CH1 CH2) as alternate function*/
    gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_NONE, GPIO_PIN_8);
    gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_8);

    gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_NONE, GPIO_PIN_9);
    gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_9);
        
    gpio_af_set(GPIOA, GPIO_AF_2, GPIO_PIN_8);
    gpio_af_set(GPIOA, GPIO_AF_2, GPIO_PIN_9);

    timer_deinit(TIMER0);

    timer_initpara.prescaler         = 0;
    timer_initpara.alignedmode       = TIMER_COUNTER_EDGE;
    timer_initpara.counterdirection  = TIMER_COUNTER_UP;
    timer_initpara.period            = 0xffff;                          //计数的最大值 ,可以设置中值
    timer_initpara.clockdivision     = TIMER_CKDIV_DIV1;
    timer_initpara.repetitioncounter = 0;
    timer_init(TIMER0,&timer_initpara);
    
	nvic_irq_enable(TIMER0_Channel_IRQn, 0, 0);

	timer_update_source_config(TIMER0, TIMER_UPDATE_SRC_REGULAR);
	timer_quadrature_decoder_mode_config(TIMER0,TIMER_ENCODER_MODE2,TIMER_IC_POLARITY_RISING,TIMER_IC_POLARITY_RISING);//配置译码器的模式,模式2,ch0和ch1都计数,上升沿
    timer_interrupt_enable(TIMER0, TIMER_INT_UP);                                       //使能上溢中断
    timer_auto_reload_shadow_enable(TIMER0);                                            //自动重载
    timer_enable(TIMER0);
}
  • 在一个循环任务中调用接口获取编码器的值
 uint32_t value= timer_counter_read(TIMER0);
 printf("value:%d\r\n",value);
实验结果:
2023/01/14: 15:42:12(737): 
value:22541
value:22514
value:22487
value:22460
va
2023/01/14: 15:42:12(785):
value:22407
  • 两个反向分别对应编码器的值一个递增,一个递减,需要自己处理溢出的情况。
  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
以下是gd32f330RBT6 SPI主从配置的示例代码: ```c #include "gd32f3x0_spi.h" #include "gd32f3x0_gpio.h" #define SPI0_SLAVE_PIN_CS GPIO_PIN_4 #define SPI0_SLAVE_PIN_SCK GPIO_PIN_5 #define SPI0_SLAVE_PIN_MISO GPIO_PIN_6 #define SPI0_SLAVE_PIN_MOSI GPIO_PIN_7 #define SPI0_SLAVE_GPIO GPIOB void spi0_slave_gpio_init(void) { rcu_periph_clock_enable(RCU_GPIOB); gpio_mode_set(SPI0_SLAVE_GPIO, GPIO_MODE_INPUT, GPIO_PUPD_PULLUP, SPI0_SLAVE_PIN_CS); gpio_mode_set(SPI0_SLAVE_GPIO, GPIO_MODE_AF, GPIO_PUPD_NONE, SPI0_SLAVE_PIN_SCK | SPI0_SLAVE_PIN_MISO | SPI0_SLAVE_PIN_MOSI); gpio_output_options_set(SPI0_SLAVE_GPIO, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, SPI0_SLAVE_PIN_SCK | SPI0_SLAVE_PIN_MOSI); gpio_af_set(SPI0_SLAVE_GPIO, GPIO_AF_0, SPI0_SLAVE_PIN_SCK | SPI0_SLAVE_PIN_MISO | SPI0_SLAVE_PIN_MOSI); } void spi0_slave_init(void) { spi_parameter_struct spi_init_struct; rcu_periph_clock_enable(RCU_SPI0); spi_i2s_deinit(SPI0); spi_struct_para_init(&spi_init_struct); spi_init_struct.device_mode = SPI_SLAVE; spi_init_struct.trans_mode = SPI_TRANSMODE_RECEIVEONLY; spi_init_struct.frame_size = SPI_FRAMESIZE_8BIT; spi_init_struct.nss = SPI_NSS_SOFT; spi_init_struct.clock_polarity_phase = SPI_CK_PL_LOW_PH_1EDGE; spi_init_struct.prescale = SPI_PSC_256; spi_init(SPI0, &spi_init_struct); spi_enable(SPI0); } int main(void) { uint8_t data; spi0_slave_gpio_init(); spi0_slave_init(); while (1) { while (RESET == spi_i2s_flag_get(SPI0, SPI_FLAG_RBNE)); data = spi_i2s_data_receive(SPI0); // 处理接收到的数据 } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

路人 假

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

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

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

打赏作者

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

抵扣说明:

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

余额充值