在mm32f3270上为micropython创建PWM模块(1)

在mm32f3270上为micropython创建PWM模块(1)


PS: 对于以英文作为主要编码工具的软件工程师, 即使在中文编辑环境写文档, 使用英文标点符号还是比较方便的.

Requirements

micropython的开发手册中提供了关于PWM模块的API参考设计规范, 见:

https://docs.micropython.org/en/latest/library/machine.PWM.html

我又在micropython的代码仓库里看了一下, 只有rp2/esp32/esp8266三个平台上有machine_pwm.c的实现, 官方开发手册中的实现同rp2保持一致, esp系列另一套相近的实现.

在设计PWM模块的时候, 要考虑多个PWM公用同一个定时器的问题, 并且定时器的引脚有时不会很多, 不能支持很多PWM, 那么如果要支持更多的PWM输出通道, 还有可能考虑到多个定时器分组的问题.

rp2的实现有点炫富的味道, 从代码上看, 可能rp2的1定时器有8个通道(强大的定时器IP), 也可能是有8个定时器(强大的SOC), 每个定时器仅引出一路通道(A和B算一个).

STATIC machine_pwm_obj_t machine_pwm_obj[] = {
    {{&machine_pwm_type}, 0, PWM_CHAN_A},
    {{&machine_pwm_type}, 0, PWM_CHAN_B},
    {{&machine_pwm_type}, 1, PWM_CHAN_A},
    {{&machine_pwm_type}, 1, PWM_CHAN_B},
    {{&machine_pwm_type}, 2, PWM_CHAN_A},
    {{&machine_pwm_type}, 2, PWM_CHAN_B},
    {{&machine_pwm_type}, 3, PWM_CHAN_A},
    {{&machine_pwm_type}, 3, PWM_CHAN_B},
    {{&machine_pwm_type}, 4, PWM_CHAN_A},
    {{&machine_pwm_type}, 4, PWM_CHAN_B},
    {{&machine_pwm_type}, 5, PWM_CHAN_A},
    {{&machine_pwm_type}, 5, PWM_CHAN_B},
    {{&machine_pwm_type}, 6, PWM_CHAN_A},
    {{&machine_pwm_type}, 6, PWM_CHAN_B},
    {{&machine_pwm_type}, 7, PWM_CHAN_A},
    {{&machine_pwm_type}, 7, PWM_CHAN_B},
};

如此, 它当然很好解决PWM多路复用的问题, 要么全复用, 要么全独立.

顺便翻了一下raspberry pico的介绍, 好家伙, 这个芯片几乎就是为这块专属的板子定义的, 而这个板子的定义就是为了服务micropython.

https://pico.org.cn/

rp2的machine_pwm实现专门把duty的可调范围扩展到65536. 甚至不惜耗费算力在CM0+的内核上做乘除法进行换算ns等.

        // Set the frequency, making "top" as large as possible for maximum resolution.
        // Maximum "top" is set at 65534 to be able to achieve 100% duty with 65535.
        #define TOP_MAX 65534
        mp_int_t freq = mp_obj_get_int(args[1]);
        uint32_t div16_top = 16 * source_hz / freq;

整体代码实现得也不是很好看. 但无所谓, 只要板子最终的功能出来就行, 软件可能也不是为了给用户做二次开发的. 大气! 但做通用MCU不能这么搞. 所以最终我还是考虑参考esp系列的实现模型.

esp32和esp8266使用的是同一套接口:

STATIC const mp_rom_map_elem_t pyb_pwm_locals_dict_table[] =
{
    { MP_ROM_QSTR(MP_QSTR_init), MP_ROM_PTR(&pyb_pwm_init_obj) },
    { MP_ROM_QSTR(MP_QSTR_deinit), MP_ROM_PTR(&pyb_pwm_deinit_obj) },
    { MP_ROM_QSTR(MP_QSTR_freq), MP_ROM_PTR(&pyb_pwm_freq_obj) },
    { MP_ROM_QSTR(MP_QSTR_duty), MP_ROM_PTR(&pyb_pwm_duty_obj) },
};

从命名风格上看, PWM模块还归属在pyb模块下, 而不是后来明文约定的machine, 说明这个还是早期的实现. 问题不大, 我用它的实现模型, 再挂在machine模块下.

在实现基本API的同时, 我会提前约定:

  • duty的有效输入范围为0-1000, 表示千分比. 这样可以固定定时器的计数周期就是1000, 但是频率可调
  • 通过TIM3和TIM3和TIM4, 总共引出6个通道, 尝试设计一种多定时器组合的架构, 同时要考虑好共用一个定时器的多个PWM通道之间的耦合问题.
    // start the PWM subsystem if it's not already running
    if (!pwm_inited) {
        pwm_init();
        pwm_inited = true;
    }

呵呵, 我也是这么想的,避免重复初始化共享时基.

  • 关于实例化传参, 还是遵循micropython中流行的做法, 可以接受: 引脚名/全局通道号/同类对象

未完待续 …

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2022 / 01/ 30: 新版esptool 刷micropython固件指令不是 esptool.py cmd... 而是 esptool cmd... 即可;另外rshell 在 >= python 3.10 的时候出错解决方法可以查看:  已于2022年发布的: 第二章:修复rshell在python3.10出错 免费内容: https://edu.csdn.net/course/detail/29666 micropython语法和python3一样,编写起来非常方便。如果你快速入门单片机玩物联网而且像轻松实现各种功能,那绝力推荐使用micropython。方便易懂易学。 同时如果你懂C语音,也可以用C写好函数并编译进micropython固件里然后进入micropython调用(非必须)。 能通过WIFI联网(2.1章),也能通过sim卡使用2G/3G/4G/5G联网(4.5章)。 为实现语音控制,本教程会教大家使用tensorflow利用神经网络训练自己的语音模型并应用。为实现通过网页控制,本教程会教大家linux(debian10 nginx->uwsgi->python3->postgresql)网站前后台入门。为记录单片机传输过来的数据, 本教程会教大家入门数据库。  本教程会通过通俗易懂的比喻来讲解各种原理与思路,并手把手编写程序来实现各项功能。 本教程micropython版本是 2019年6月发布的1.11; 更多内容请看视频列表。  学习这门课程之前你需要至少掌握: 1: python3基础(变量, 循环, 函数, 常用库, 常用方法)。 本视频使用到的零件与淘宝上大致价格:     1: 超声波传感器(3)     2: MAX9814麦克风放大模块(8)     3: DHT22(15)     4: LED(0.1)     5: 8路5V低电平触发继电器(12)     6: HX1838红外接收模块(2)     7:红外发射管(0.1),HX1838红外接收板(1)     other: 电表, 排线, 面包板(2)*2,ESP32(28)  

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值