基于platform驱动模型完成LED驱动的编写

添加设备树文件信息

复制代码
myplatform{
    compatible="hqyj,myplatform";//厂商信息,用于驱动端进行匹配
    interrupt-parent=<&gpiof>;
//关联中断父节点
    interrupts=<9 0>;
//和中断父节点的关系描述符
    led1-gpio=<&gpioe 10 0>;
led2-gpio=<&gpiof 10 0>;
led3-gpio=<&gpioe 8 0>;
//gpio管脚描述符信息
    reg=<0X12345678 0x50>;
//地址信息
    };

pdrv.c

复制代码
#include <linux/init.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/mod_devicetable.h>
#include <linux/of.h>
#include <linux/of_gpio.h>
#include <linux/gpio.h>
struct resource *res;
unsigned int irqno;
struct gpio_desc *gpiono[3];
int pdrv_probe(struct platform_device *pdev) // 当驱动和设备匹配成功后执行
{
    // 获取MEM类型的资源
    res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
    if (res == NULL)
    {
        printk("获取MEM类型的资源失败\n");
        return -ENXIO;
    }
    // 获取中断类型资源
    irqno = platform_get_irq(pdev, 0);
    if (irqno < 0)
    {
        printk("获取中断类型资源失败\n");
        return -ENXIO;
    }
    printk("MEM类型资源为%x\n", res->start);
    printk("中断类型资源为%d\n", irqno);
    // 获取gpio信息
    gpiono[0] = gpiod_get_from_of_node(pdev->dev.of_node, "led1-gpio", 0, GPIOD_OUT_HIGH, NULL);
    if (IS_ERR(gpiono[0]))
    {
        printk("解析GPIO 0信息失败\n");
        return -PTR_ERR(gpiono[0]);
    }

    gpiono[1] = gpiod_get_from_of_node(pdev->dev.of_node, "led2-gpio", 0, GPIOD_OUT_HIGH, NULL);
    if (IS_ERR(gpiono[1]))
    {
        printk("解析GPIO 1信息失败\n");
        return -PTR_ERR(gpiono[1]);
    }

    gpiono[2] = gpiod_get_from_of_node(pdev->dev.of_node, "led3-gpio", 0, GPIOD_OUT_HIGH, NULL);
    if (IS_ERR(gpiono[2]))
    {
        printk("解析GPIO 2信息失败\n");
        return -PTR_ERR(gpiono[2]);
    }

    printk("解析GPIO信息成功,LED亮\n");
    return 0;
}

int pdrv_remove(struct platform_device *pdev) // 当设备和驱动分离时执行
{
    // 释放GPIO信息]

    gpiod_set_value(gpiono[0], 0);
    gpiod_put(gpiono[0]);

    gpiod_set_value(gpiono[1], 0);
    gpiod_put(gpiono[1]);

    gpiod_set_value(gpiono[2], 0);
    gpiod_put(gpiono[2]);
    printk("%s:%s:%d\n", __FILE__, __func__, __LINE__);
    return 0;
}
// 构建设备树匹配表
struct of_device_id oftable[] = {
    {
        .compatible = "hqyj,myplatform",
    },
    {
        .compatible = "hqyj,myplatform1",
    },
    {}, // 防止数组越界
};
// 1.分配驱动信息对象
struct platform_driver pdrv = {
    .probe = pdrv_probe,
    .remove = pdrv_remove,
    .driver = {
        .name = "bbbbb", // 驱动名
        .of_match_table = oftable,
    },

};
// 一键注册宏
module_platform_driver(pdrv);
MODULE_LICENSE("GPL");
相关推荐
xiangw@GZ12 小时前
ARM TCM 紧耦合内存与 Cache 架构区别
arm开发·架构
XINVRY-FPGA13 小时前
XCKU035-2FBVA676I AMD Xilinx Kintex UltraScale FPGA
arm开发·嵌入式硬件·网络安全·fpga开发·硬件工程·信号处理·fpga
少年、潜行15 小时前
IAR FOR ARM 历史版本安装包、安装、注册流程【百度网盘资源】
arm开发·iar·iar历史版本·iar安装
Aaron15881 天前
无人机反制中AOA+TDOA联合定位技术与雷达探测定位技术的应用对比分析
arm开发·嵌入式硬件·fpga开发·硬件工程·无人机·信息与通信·信号处理
m0_747124531 天前
ARM架构基础知识扫盲
arm开发·架构
海绵宝宝de派小星1 天前
MCP与A2A协议深度解析:Agent时代的“TCP/IP“如何诞生
arm开发·网络协议·tcp/ip·ai
Zephyrus_20232 天前
LSM6DSV16X驱动移植+调试
c语言·arm开发
瑞禧生物tech2 天前
四臂聚乙二醇-磷脂 4-Arm PEG-DSPE 反应原理解析
arm开发
振南的单片机世界2 天前
地址总线定“找谁”,数据总线定“搬多少”
arm开发·stm32·单片机
有想法的py工程师3 天前
手工处理 Oracle Cloud ARM 实例在线 DD Rocky Linux 10报错
linux·arm开发·oracle