使用 rust 开发 stm32:stm32f3discovery-pwm-rtic

此篇博客介绍了如何使用STM32F3xx HAL库实现TIM2定时器的PWM功能,基于官方例程扩展,适合移植和学习。通过设置GPIO和调整Duty Cycle,演示了如何控制PB10引脚的脉冲宽度调制输出。
摘要由CSDN通过智能技术生成

更多分享内容可访问我的个人博客

https://www.niuiic.top/

本系列教程全部置于stm32专栏

本例程参考stm32fxxx-hal crate(如stm32f1xx-hal)官方例程,并在官方例程的基础上增加了一些注释,修正了一些错误。可以借鉴不同型号的 stm32 例程,毕竟固件库的核是一样的。

#![no_main]
#![no_std]

use panic_semihosting as _;
use rtic::app;
use stm32f3xx_hal::{pac, prelude::*, pwm::tim2, rcc::RccExt};

#[app(device = stm32f3xx_hal::pac, peripherals = true)]
const APP: () = {
    struct Resources {}

    #[init]
    fn init(cx: init::Context) {
        let dp: pac::Peripherals = cx.device;
        let mut rcc = dp.RCC.constrain();

        let mut flash = dp.FLASH.constrain();
        let clocks = rcc.cfgr.sysclk(16_u32.MHz()).freeze(&mut flash.acr);

        let mut gpiob = dp.GPIOB.split(&mut rcc.ahb);
        let pb10 =
            gpiob
                .pb10
                .into_af1_push_pull(&mut gpiob.moder, &mut gpiob.otyper, &mut gpiob.afrh);

        let tim2_channels = tim2(dp.TIM2, 160_000, 50_u32.Hz(), &clocks);

        let mut tim2_ch3 = tim2_channels.2.output_to_pb10(pb10);
        tim2_ch3.set_duty(tim2_ch3.get_max_duty() / 4); // 25% duty cycle
        tim2_ch3.enable();
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值