詳解linux pwm驅(qū)動編寫
pwm方波可以用來控制很多的設(shè)備,比如它可以被用來控制電機(jī)。簡單來說,就是單位時間內(nèi)的方波越多,那么電機(jī)的轉(zhuǎn)速就會越快;反之就越慢。通過這個特性,soc就可以輕松地利用pwm對外設(shè)進(jìn)行自動控制。所以,今天的主題就是pwm驅(qū)動。
1、驅(qū)動目錄
drivers/pwm
2、查看對應(yīng)目錄下的Kconfig
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、確認(rèn)PWM_SAMSUNG只依賴于自己之外,繼續(xù)看Makefile
obj-$(CONFIG_PWM) += core.o obj-$(CONFIG_PWM_SAMSUNG) += pwm-samsung.o
4、根據(jù)Makefile查閱pwm-samsung.c文件,結(jié)構(gòu)比較清楚
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設(shè)備大多數(shù)是platform設(shè)備,繼續(xù)尋找probe函數(shù)中的有用信息
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、找到注冊函數(shù)后,接續(xù)看看函數(shù)接口點在什么地方
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設(shè)備沒有中斷函數(shù),一般是立馬生效,除此之外,代碼中還是有設(shè)備樹的內(nèi)容,可以看看
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;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Centos8搭建本地Web服務(wù)器的實現(xiàn)步驟
這篇文章主要介紹了Centos8搭建本地Web服務(wù)器的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
centos 5.1下的安全設(shè)置(適合所有的linux版本)
因為root用戶對系統(tǒng)具有全權(quán)的操作權(quán)限,為了避免一些失誤的操作,建議在一般情況下,以一般用戶登錄系統(tǒng),必要的時候需要root操作權(quán)限時,再通過“su -”命令來登錄為root用戶進(jìn)行操作。2010-03-03
使用vscode遠(yuǎn)程linux開發(fā)的實現(xiàn)
這篇文章主要介紹了使用vscode遠(yuǎn)程linux開發(fā)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
在linux中設(shè)置tomcat開機(jī)自啟動的方法
由于各種各樣的原因,服務(wù)器有重啟的可能,這樣tomcat就需要配置成開機(jī)自動啟動,否則每次重啟后就需要連遠(yuǎn)程手動啟動tomcat,如果服務(wù)器被迫重啟,而技術(shù)人員又不能及時運行tomcat,那么后果很嚴(yán)重,所以本文給大家介紹了在linux中設(shè)置tomcat開機(jī)自啟動的方法2024-02-02

