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");

看现象

相关推荐
kcuwu.27 分钟前
Python进阶:生成器与协程,高效并发编程的核心实践
windows·python·php
牛马鸡niumasi1 小时前
C/C++ 程序编译过程、静态/动态链接、静态/动态库
linux
2401_835792542 小时前
FastAPI 速通
windows·python·fastapi
捧月华如2 小时前
Linux 系统性能压测工具全景指南(含工程实战)
linux·运维·服务器
YMWM_2 小时前
export MPLBACKEND=Agg命令使用
linux·python
想唱rap2 小时前
线程的同步与互斥
linux·运维·服务器·数据库·mysql
格林威3 小时前
SSD 写入速度测试命令(Linux)(基于工业相机高速存储)
linux·运维·开发语言·人工智能·数码相机·计算机视觉·工业相机
easyboot3 小时前
Visual Studio 2026安装Avalonia
ide·windows·visual studio
勇闯逆流河3 小时前
【LInux】linux控制(进程替换,自主shell的实现详解)
linux·运维·服务器
IMPYLH4 小时前
Linux 的 ls 命令
linux·运维·服务器·bash