基于高通MSM8953平台android9.0的GPIO驱动开发

2023-12-09 16:45

本文主要是介绍基于高通MSM8953平台android9.0的GPIO驱动开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2.1、注册设备:

2.1.1、添加编译选项:

1)、修改kernel/msm-4.9/drivers/leds下Makefile文件:

        obj-$(CONFIG_LED_GPIO) += led_gpio.o

2)、修改kernel/msm-4.9/drivers/leds下Kconfig文件:

        config LED_GPIO

                tristate "led_gpio"

2.1.2、修改驱动配置文件,驱动编译进系统:

        修改kernel/msm-4.9/arch/arm64/configs下的msm8953_defconfig文件:

                CONFIG_LED_GPIO=y

2.2、注册驱动:

2.2.1、修改dts设备树文件:

1)、文件名:msm8953-mtp-dtsi。

2)、文件路径:kernel/msm-4.9/arch/arm64/boot/dts/qcom/msm8953-mtp-dtsi

3)、在&soc下添加:

&soc {

led_gpio {

compatible = "led_gpio";

         led_gpio,gpio97 = <&tlmm 97 0x1>;

};

};

2.2.2、添加驱动:

在kernel/msm-4.9/drivers/leds下添加led_gpio.c文件:

#include <linux/types.h>

#include <linux/pm.h>

#include <linux/gpio.h>

#include <linux/slab.h>

#include <linux/init.h>

#include <linux/platform_device.h>

#include <linux/fsl_devices.h>

#include <asm/setup.h>

#include <linux/of.h>

#include <linux/of_gpio.h>

#include <linux/stat.h>

#include <linux/module.h>

#include <linux/err.h>

#include <linux/spinlock.h>

#include <linux/err.h>

#include <linux/regulator/consumer.h>

int led_gpio97 = -1;

static struct class * led_gpios_class = NULL;

static struct device * led_gpio97_dev = NULL;

#define CTL_LED_ON "1"

#define CTL_LED_OFF "0"

//使用 cat命令时候调用此函数

static ssize_t led_gpio97_show(struct device *dev,struct device_attribute *attr, char *buf)

{

int gpio_state = gpio_get_value(led_gpio97);

sprintf(buf, "%d\n", gpio_state);

return strlen(buf);

}

//使用 echo 命令时候调用此函数

static ssize_t led_gpio97_store(struct device *dev, struct device_attribute *attr, const char *buf, size_t count)

{

if(!strncmp(buf, CTL_LED_ON, strlen(CTL_LED_ON))) {

gpio_set_value(led_gpio97, 1);

} else if(!strncmp(buf, CTL_LED_OFF, strlen(CTL_LED_OFF))) {

gpio_set_value(led_gpio97, 0);

}

return count;

}

static struct device_attribute led_gpio97_dev_attr = {

.attr = {

.name = "state",

.mode = S_IRWXU|S_IRWXG|S_IRWXO,

},

.show = led_gpio97_show,

.store = led_gpio97_store,

};

static int led_gpio_probe(struct platform_device *pdev)

{

int ret = 0;

printk("enter led_gpio_probe \n");

//寻找设备树dts下的 "led_gpio,gpio97" 名称对应的GPIO口

led_gpio97 = of_get_named_gpio(pdev->dev.of_node, "led_gpio,gpio97", 0);

if (led_gpio97 < 0)

printk("led_gpio97 is not available \n");

//对应修改的dts的 label

ret = gpio_request(led_gpio97, "led_gpio");

if(0 != ret) {

printk("gpio request %d failed.", led_gpio97);

goto fail1;

}

gpio_direction_output(led_gpio97, 0); //设置gpio为输出

//创建led_gpios节点

led_gpios_class = class_create(THIS_MODULE, "led_gpios");

if(IS_ERR(led_gpios_class))

{

ret = PTR_ERR(led_gpios_class);

printk("Failed to create class.\n");

return ret;

}

//创建led_gpio97 的驱动设备

led_gpio0_dev=device_create(led_gpios_class, NULL, 0, NULL, "led_gpio7");

if (IS_ERR(led_gpio97_dev))

{

ret = PTR_ERR(test_gpios_class);

printk("Failed to create device(led_gpio97_dev)!\n");

return ret;

}

//根据 led_gpio0_dev_attr 配置,生成相应的文件

ret = device_create_file(led_gpio97_dev, & led_gpio97_dev_attr);

if(ret)

{

pr_err("%s: led_gpio97 creat sysfs failed\n",__func__);

return ret;

}

printk("enter led_gpio_probe, ok \n");

fail1:

return ret;

}

static int led_gpio_remove(struct platform_device *pdev)

{

device_destroy(led_gpios_class, 0);

class_destroy(led_gpios_class);

device_remove_file(led_gpio97_dev, & led_gpio97_dev_attr);

return 0;

}

static int led_gpio_suspend(struct platform_device *pdev,pm_message_t state)

{

return 0;

}

static int led_gpio_resume(struct platform_device *pdev)

{

return 0;

}

static struct of_device_id led_gpio_dt_match[] = {

{ .compatible = "led_gpio",},

{ },

};

  

MODULE_DEVICE_TABLE(of, led_gpio_dt_match);

//驱动的方法与函数对应

static struct platform_driver gpio_led_driver = {

.driver = {

.name = "led_gpio",

.owner = THIS_MODULE,

.of_match_table = of_match_ptr(led_gpio_dt_match),

},

.probe = led_gpio_probe,

.remove = led_gpio_remove,

.suspend = led_gpio_suspend,

.resume = led_gpio_resume,

};

  

static __init int gpio_led_init(void)

{

return platform_driver_register(&gpio_led_driver);

}

static void __exit gpio_led_exit(void)

{

platform_driver_unregister(&gpio_led_driver);

}

  

module_init(gpio_led_init);

module_exit(gpio_led_exit);

MODULE_LICENSE("GPL");

2.3、编译系统:

source build/envsetup.sh

lunch msm8953_64-userdebug

make -j8

这篇关于基于高通MSM8953平台android9.0的GPIO驱动开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/474404

相关文章

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

如何基于Python开发一个微信自动化工具

《如何基于Python开发一个微信自动化工具》在当今数字化办公场景中,自动化工具已成为提升工作效率的利器,本文将深入剖析一个基于Python的微信自动化工具开发全过程,有需要的小伙伴可以了解下... 目录概述功能全景1. 核心功能模块2. 特色功能效果展示1. 主界面概览2. 定时任务配置3. 操作日志演示

JavaScript实战:智能密码生成器开发指南

本文通过JavaScript实战开发智能密码生成器,详解如何运用crypto.getRandomValues实现加密级随机密码生成,包含多字符组合、安全强度可视化、易混淆字符排除等企业级功能。学习密码强度检测算法与信息熵计算原理,获取可直接嵌入项目的完整代码,提升Web应用的安全开发能力 目录

如何在Ubuntu上安装NVIDIA显卡驱动? Ubuntu安装英伟达显卡驱动教程

《如何在Ubuntu上安装NVIDIA显卡驱动?Ubuntu安装英伟达显卡驱动教程》Windows系统不同,Linux系统通常不会自动安装专有显卡驱动,今天我们就来看看Ubuntu系统安装英伟达显卡... 对于使用NVIDIA显卡的Ubuntu用户来说,正确安装显卡驱动是获得最佳图形性能的关键。与Windo

一文教你如何解决Python开发总是import出错的问题

《一文教你如何解决Python开发总是import出错的问题》经常朋友碰到Python开发的过程中import包报错的问题,所以本文将和大家介绍一下可编辑安装(EditableInstall)模式,可... 目录摘要1. 可编辑安装(Editable Install)模式到底在解决什么问题?2. 原理3.

Python+PyQt5开发一个Windows电脑启动项管理神器

《Python+PyQt5开发一个Windows电脑启动项管理神器》:本文主要介绍如何使用PyQt5开发一款颜值与功能并存的Windows启动项管理工具,不仅能查看/删除现有启动项,还能智能添加新... 目录开篇:为什么我们需要启动项管理工具功能全景图核心技术解析1. Windows注册表操作2. 启动文件

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构