当前位置: 首页 > news >正文

6. 平台总线

一、平台总线概念

1.1. 什么是平台总线

  • 什么是平台总线
    平台总线是Linux内核虚拟出来的一种总线,并不是实际存在的物理总线(I2C,SPI)。与物理总线的区别在于平台总线是虚拟的,抽象出来的。而物理总线(USB,PCI)是实际存在的硬件。
    在这里插入图片描述

  • 引入平台总线的目的
    将驱动(driver)与硬件(device)资源进行分离,方便管理和统一与平台紧密相关的设备,并提供统一的接口进行访问。

  • Linux中总线的分类
    虚拟总线platform和实际存在的物理总线I2C、SPI、USB

  • 平台总线的实现
    平台总线的工作体系主要定义在driver/base/platform.c中,主要涉及两个结构体struct platform_device 描述设备信息 struct platform_driver描述驱动程序,两者通过设备名字进行关联。

  • 优点
    减少重复代码,提高程序可移植性及效率;
    统一管理和控制各种硬件设备;
    扩展性强,方便添加新的硬件设备;

  • 常见的平台总线

1.2. 平台总线的模型

​ 概述:平台总线模型将设备驱动分为两部分:device.cdriver.c,分别用于描述硬件信息和控制硬件。通过字符串比较,具有相同name的设备(device.c)和驱动(driver.c)被匹配起来以控制硬件。

二、设备(device)&&驱动(driver)

2.1. 设备相关接口&&变量

2.1.1. 通用变量

struct platform_device该结构体位于linux/platform_device.h

struct platform_device {const char *name; /* 设备名称,用于与驱动进行关联 */int id; /* 设备ID,-1:表示不设置 0~x:给设备标注序号 */bool id_auto; /* 是否自动分配ID,1-自动分配;0-不分配 */struct device dev; /* 描述设备的属性和状态,例如内存地址、中断号等 +重要+ */u32 num_resources; /* 设备资源数量 */struct resource *resource; /* 设备资源详细信息 +重要+ */const struct platform_device_id *id_entry; /* 指向平台设备ID表的指针,用于匹配设备驱动程序[暂无需关注] */char *driver_override; /* 强制匹配的驱动程序名称。如果该成员不为NULL,则表示强制匹配该名称的驱动程序[暂无需关注] */struct mfd_cell *mfd_cell; /* 平台设备所属的MFD(多功能设备)单元[暂无需关注] */struct pdev_archdata archdata; /* 平台设备的体系结构相关数据,用于存储与体系结构相关的信息[暂无需关注] */
};

struct device该结构体位于linux/platform_device.h中,当前只需要关注void (*release)(struct device *dev);参数,且注册设备时,必须给该参数赋值,不然驱动无法正常编译。

struct device {struct device *parent;struct device_private *p;struct kobject kobj;const char *init_name; /* initial name of the device */const struct device_type *type;struct mutex mutex; /* mutex to synchronize calls to its driver. */struct bus_type *bus; /* type of bus device is on */struct device_driver *driver; /* which driver has allocated this device */void *platform_data; /* Platform specific data, device core doesn't touch it */void *driver_data; /* Driver data, set and get with dev_set/get_drvdata */struct dev_pm_info power;struct dev_pm_domain *pm_domain;#ifdef CONFIG_PINCTRLstruct dev_pin_info *pins;#endif#ifdef CONFIG_NUMAint numa_node; /* NUMA node this device is close to */#endifu64 *dma_mask; /* dma mask (if dma'able device) */u64 coherent_dma_mask;/* Like dm
http://www.dtcms.com/a/312774.html

相关文章:

  • 机器学习第四课之决策树
  • Shell 脚本流程控制语句详解(四):while 循环详解
  • lua table常用函数汇总
  • Django 序列化详解:从 Model 到 JSON,全面掌握数据转换机制
  • 使用AndroidStudio调试Framework源码
  • 腾讯人脸识别
  • 数据治理:DQC(Data Quality Center,数据质量中心)概述
  • [嵌入式embed]C51单片机STC-ISP提示:正在检测目标单片机
  • 《前端无障碍设计的深层逻辑与实践路径》
  • MyBatis动态SQL精要:从<if>到<foreach>的灵活拼接之道
  • 高质量数据集|建设三大难点
  • [硬件电路-140]:模拟电路 - 信号处理电路 - 锁定放大器概述、工作原理、常见芯片、管脚定义
  • [硬件电路-133]:模拟电路 - 信号处理电路 - 电荷放大器概述、工作原理、常见芯片、管脚定义
  • 深度学习(鱼书)day10--与学习相关的技巧(后两节)
  • 仿TCmalloc内存分配器
  • 后端研发转型爬虫实战:Scrapy 二开爬虫框架的避坑指南
  • C++入门自学Day5-- C/C++内存管理(续)
  • jvm之jconsole的使用
  • Maven 常用命令详解
  • react native中markdown添加数学公式的支持
  • 文明存续的时间博弈:论地球资源枯竭临界期的技术突围与行动紧迫性
  • STM32-驱动OLED显示屏使用SPI(软件模拟时序)实现
  • 【stm32】按键控制LED以及光敏传感器控制蜂鸣器
  • PYTHON从入门到实践-18Django模版渲染
  • 我的世界进阶模组开发教程——伤害(2)
  • 20250803让飞凌OK3576-C开发板在Rockchip的原厂Android14下适配声卡NAU88C22YG【Android部分】
  • C++:STL中的栈和队列的适配器deque
  • 多模态大模型的原理
  • 机器人产业需要技术与资本双驱动,在泡沫期中探索商业化路径
  • Python中的sys.path与PYTHONPATH全解析:模块导入路径的底层机制与最佳实践