详解linux pwm驱动编写

吾爱主题 阅读:258 2024-04-05 13:53:31 评论:0

pwm方波可以用来控制很多的设备,比如它可以被用来控制电机。简单来说,就是单位时间内的方波越多,那么电机的转速就会越快;反之就越慢。通过这个特性,soc就可以轻松地利用pwm对外设进行自动控制。所以,今天的主题就是pwm驱动。

1、驱动目录

?
1 drivers/pwm

2、查看对应目录下的Kconfig

?
1 2 3 4 5 6 7 8 config PWM_SAMSUNG   tristate "Samsung PWM support"   depends on PLAT_SAMSUNG || ARCH_EXYNOS   help    Generic PWM framework driver for Samsung.      To compile this driver as a module, choose M here: the module    will be called pwm-samsung.

3、确认PWM_SAMSUNG只依赖于自己之外,继续看Makefile

?
1 2 3 obj-$(CONFIG_PWM) += core.o   obj-$(CONFIG_PWM_SAMSUNG) += pwm-samsung.o

4、根据Makefile查阅pwm-samsung.c文件,结构比较清楚

?
1 2 3 4 5 6 7 8 9 10 static struct platform_driver pwm_samsung_driver = {   .driver = {   .name = "samsung-pwm" ,   .pm = &pwm_samsung_pm_ops,   .of_match_table = of_match_ptr(samsung_pwm_matches),   },   .probe = pwm_samsung_probe,   . remove = pwm_samsung_remove, }; module_platform_driver(pwm_samsung_driver);

5、soc设备大多数是platform设备,继续寻找probe函数中的有用信息

?
1 2 3 4 5 6 ret = pwmchip_add(&chip->chip);   if (ret < 0) {   dev_err(dev, "failed to register PWM chip\n" );   clk_disable_unprepare(chip->base_clk);   return ret;   }

6、找到注册函数后,接续看看函数接口点在什么地方

?
1 2 3 4 5 6 7 8 9 static const struct pwm_ops pwm_samsung_ops = {   .request = pwm_samsung_request,   . free = pwm_samsung_free,   .enable = pwm_samsung_enable,   .disable = pwm_samsung_disable,   .config = pwm_samsung_config,   .set_polarity = pwm_samsung_set_polarity,   .owner = THIS_MODULE, };

7、pwm设备没有中断函数,一般是立马生效,除此之外,代码中还是有设备树的内容,可以看看

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 static const struct of_device_id samsung_pwm_matches[] = {   { .compatible = "samsung,s3c2410-pwm" , .data = &s3c24xx_variant },   { .compatible = "samsung,s3c6400-pwm" , .data = &s3c64xx_variant },   { .compatible = "samsung,s5p6440-pwm" , .data = &s5p64x0_variant },   { .compatible = "samsung,s5pc100-pwm" , .data = &s5pc100_variant },   { .compatible = "samsung,exynos4210-pwm" , .data = &s5p64x0_variant },   {}, }; MODULE_DEVICE_TABLE(of, samsung_pwm_matches);   static int pwm_samsung_parse_dt( struct samsung_pwm_chip *chip) {   struct device_node *np = chip->chip.dev->of_node;   const struct of_device_id *match;   struct property *prop;   const __be32 *cur;   u32 val;     match = of_match_node(samsung_pwm_matches, np);   if (!match)   return -ENODEV;     memcpy (&chip->variant, match->data, sizeof (chip->variant));     of_property_for_each_u32(np, "samsung,pwm-outputs" , prop, cur, val) {   if (val >= SAMSUNG_PWM_NUM) {    dev_err(chip->chip.dev,    "%s: invalid channel index in samsung,pwm-outputs property\n" ,      __func__);    continue ;   }   chip->variant.output_mask |= BIT(val);   }     return 0; }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/feixiaoxing/article/details/79889240

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容