linux驱动—在自己的总线目录下创建属性文件

在总线目录下创建属性文件以扩展其功能。 通过创建属性文件, 我们可以为总线添加额外的信息和控制选项, 以便与设备和驱动进行交互。 简单就是,属性文件,可以完成用户空间和内核空间的数据交互, 比如在应用层快速修改gpio引脚的电平。

介绍一下API

bus_create_file() 函数用于在总线的 sysfs 目录下创建一个属性文件。

参数说明:​

bus: 指向总线类型结构体 struct bus_type 的指针, 表示要在这个目录下创建属性文件的 总线。​

attr:指向属性 struct bus_attribute的指针, 表示要创建的属性文件的属性。

函数原型:

int bus_create_file(struct bus_type *bus,struct bus_attribute *attr);

在调用 bus_create_file()函数之前, 需要先定义好属性结构体 struct bus_attribute *attr, 并将其相关字段填充好。 通常, 属性结构体会包含以下字段:

第一个字段,attr

复制代码
static ssize_t my_show (struct bus_type *bus, char *buf)
{
    // 在 sysfs 中显示总线的值​
    return sprintf(buf, "%s\n", "mybus_show");
}

static ssize_t my_store(struct bus_type *bus, const char *buf, size_t count)
{
    // 在 sysfs 中显示总线的值​
    return sprintf(buf, "%s\n", "mybus_show");
}

struct bus_attribute mybus_attr = {
    /*属性文件的名字和操作权限*/
    .attr = {
        .name = "value",
        .mode = 0664,
    },
    .show = my_show,
    .store= my_store,

};

代码编写

复制代码
#include <linux/module.h>
#include <linux/init.h>
#include <linux/slab.h>
#include <linux/configfs.h>
#include <linux/kernel.h>
#include <linux/kobject.h>
#include <linux/device.h>
#include <linux/sysfs.h>


int mybus_match(struct device *dev, struct device_driver *drv)
{
    // 检查设备名称和驱动程序名称是否匹配
    return (strcmp(dev_name(dev), drv->name) == 0);
}

int mybus_probe(struct device *dev)
{
    struct device_driver *drv = dev->driver;
    if(drv->probe)
    {
        drv->probe(dev);
    }
    return 0;
}

static ssize_t my_show (struct bus_type *bus, char *buf)
{
    // 在 sysfs 中显示总线的值​
    return sprintf(buf, "%s\n", "mybus_show");
}

static ssize_t my_store(struct bus_type *bus, const char *buf, size_t count)
{
    // 在 sysfs 中显示总线的值​
    return sprintf(buf, "%s\n", "mybus_show");
}

struct bus_attribute mybus_attr = {
    /*属性文件的名字和操作权限*/
    .attr = {
        .name = "value",
        .mode = 0664,
    },
    .show = my_show,
    .store= my_store,

};

struct bus_type mybus ={
    .name  = "mabus",        // 总线的名称
    .match =  mybus_match,   // 设备和驱动程序匹配的回调函数
    .probe =  mybus_probe,   //设备探测的回调函数
}

EXPORT_SYMBOL_GPL(mybus);             // 导出总线符号

static int bus_attr_init (void)
{
    int ret;
    ret = bus_register(&mybus);      // 注册总线
    buf_create_file(&mybus, &mybus_attr);
    return 0;
}

static void bus_attr_exit (void)
{
    bus_remove_file(&mybus, &mybus_attr);  // 从 sysfs 中移除属性文件​
    bus_unregister(&mybus);                // 取消注册总线
}


/* 加载和卸载*/
module_init(bus_attr_init);
module_eixt(bus_attr_exit );
MODULE_LICENSE("GPL");
MODULE_AUTHOR("xiaoyang");

看现象

相关推荐
摇滚侠1 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
bush41 天前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行5201 天前
Linux 11 动态监控指令top
linux
qq_369224331 天前
Windows全系通用!ntdll.dll文件丢失、报错、闪退问题的完整排查与修复教程
windows·dll·dll修复·dll丢失·dll错误
不会C语言的男孩1 天前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
古城小栈1 天前
Unix 与 Linux 异同小叙
linux·服务器·unix
凡人叶枫1 天前
Effective C++ 条款42:了解 typename 的双重意义
java·linux·服务器·c++
Data-Miner1 天前
大语言模型+智能体AI,122页PPT详解落地应用培训!
人工智能·microsoft·语言模型
2601_961875241 天前
决战申论100题2026|最新|范文
linux·容器·centos·debian·ssh·fabric·vagrant
java_cj1 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes