5-设备树_中断

设备树是描述硬件信息的ASCII文本文件,自Linux 3.0版本起引入,用于解决硬件代码管理问题。中断是CPU处理突发事件的方式,分为外部中断、内部中断、可屏蔽和不可屏蔽中断等类型。ARM平台采用GIC中断控制器,支持PPI、SPI和SWI中断。中断编程包括申请和释放中断号。
摘要由CSDN通过智能技术生成
设备树:
  • 是描述硬件信息的asiII文本文件,其书写符合人类思维习惯。
历史:
  • 在linux更新维护过程中,linux创始人linus发现在收到arm平台负责人的维护邮件后,提出了linux内核中由来已久存在的问题。
    即硬件代码在linux内核中,管理无序混乱,冗余,效率低。提出借鉴powerPC架构的FDT机制,来描述硬件。由此在linux3.0以后的版本
    引入了设备树的概念。其中比较显著的特点,设备树是以外部参数的形式将硬件信息导入内核。
关键词:
  • 1.DTC 是编译设备树的小工具
  • 2.DTS 是描述硬件信息的asiII文本文件
  • 3.DTB 是编译后的二进制文件,可被bootloader识别并解析
  • 4.DTSI 类似头文件,描述平台共性
设备树的内容:
  • 1.节点:是描述某个具体设备或参数

    • 1.1根节点 每个平台设备树,有且只有一个根节点,根节点包含所有子节点,根节点以“/”命名
    • 1.2子节点:子节点可互相包含,命名方式是[name]@,其中name为必写项,adress为可写项,一般adress
      写的话,如果该设备有地址,就写该设备地址,没有写序号。
    • 1.3子节点描述的设备类型:
      • 1.3.1 CPU
      • 1.3.2 内存
      • 1.3.3 总线和桥
      • 1.3.4 gpio控制器
      • 1.3.5 中断控制器
      • 1.3.6 clk时钟
      • 1.3.7 外设
  • 2.属性 是描述节点的特性。属性的表现形式为name=value,其中name的含义和value的含义由具体相关平台给出。

  • 2.1属性的值的类型:
    • 1.u32
    • 2.u64
    • 3.字符串
    • 4.字符串数组
    • 5.结构体
    • 6.结构体数组
    • 7.phandle值
  • 2.1重要属性:
    • 1.compatible: 其值为字符串,兼容性。是设备树和驱动匹配的标识
    • 2.reg: 描述节点的地址资源属性。其值为结构体数组,一般以adress size成组出现。
    • 3.#adress-cells: 规定子节点的reg的value值的adress的个数,其值为u32
    • 4.#size-cells:规定子节点的reg的value值的size的个数,其值为u32
    • 5.interrupts: 描述节点的中断源,其值的含义需查看相关文档,其值为结构体数组,
    • 6.intrerupt-parent: 描述节点的父中断节点。其为phandle值,表现<&标号>,实际是一个u32
    • 7.interrupt-controller: 描述节点为中断控制器,其值为空值。
    • 8.interrupt-cells:描述子中断节点的interrupts属性的value的cell个数。其值为u32,它只能在拥有interrupt-controller属性的节点出现。
中断: 当cpu遇到突发事件,转而去处理突发事件,处理完成后,返回到正常状态
中断按来源分类:
  • 外部中断
  • 内部中断
按可屏蔽:
  • 可屏蔽中断
  • 不可屏蔽中断
按入口地址:
  • 向量中断(硬件提供入口地址)和非向量中断(软件提供入口地址)

ARM平台支持GIC中断控制器:
  • GIC所支持的中断类型:
    • 1.PPI:私有中断,中断必须绑定一个固定CPU
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值