前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux系统驱动之链式中断控制器驱动程序编写

Linux系统驱动之链式中断控制器驱动程序编写

作者头像
韦东山
发布2021-12-08 10:25:47
1.6K0
发布2021-12-08 10:25:47
举报
文章被收录于专栏:韦东山嵌入式

资料下载

coding无法使用浏览器打开,必须用git工具下载:

代码语言:javascript
复制
git clone https://e.coding.net/weidongshan/linux/doc_and_source_for_drivers.git

视频观看

百问网驱动大全

链式中断控制器驱动程序编写

参考资料:

1. 链式中断控制器的重要函数和结构体

1.1 回顾处理流程

为方便描述,假设下级的链式中断控制器就是GPIO控制器。

在这里插入图片描述
在这里插入图片描述

沿着中断的处理流程,GIC之下的中断控制器涉及这4个重要部分:handleB、GPIO Domain、handleC、irq_chip

  • handleB:处理GIC 33号中断,handleB由GPIO驱动提供
    • 屏蔽GIC 33号中断:调用irq_dataA的irq_chip的函数,irq_dataA由GIC驱动提供
    • 细分并处理某个GPIO中断:
      • 读取GPIO寄存器得到hwirq,通过GPIO Domain转换为virq,假设是102
      • 调用irq_desc[102].handle_irq,即handleC
    • 清除GIC 33号中断:调用irq_dataA的irq_chip的函数,由GIC驱动提供
  • handleC:处理GPIO 2号中断,handleC由GPIO驱动提供
    • 屏蔽GPIO 2号中断:调用irq_dataB的irq_chip的函数,由GPIO驱动提供
    • 处理:调用actions链表中用户注册的函数
    • 清除GPIO 2号中断:调用irq_dataB的irq_chip的函数,由GPIO驱动提供
1.2 irq_domain的核心作用

怎么把handleB、GPIO Domain、handleC、irq_chip这4个结构体组织起来,irq_domain是核心。

我们从使用中断的流程来讲解。

2. 硬件模型

下图中列出了链式中断控制器、层级中断控制器,本节课程只涉及左边的链式中断控制器。

内核中有各类中断控制器的驱动程序,它们涉及的硬件过于复杂,从这些杂乱的代码中去讲清楚中断体系,比较难。

我们实现一些虚拟的中断控制器,如下图所示。

实际板子中,我们可以通过按键触发中断。

对于这些虚拟的中断控制器,我们没有真实按键,通过devmem指令写GIC的PENDING寄存器触发中断。

在这里插入图片描述
在这里插入图片描述

3. 编程

会涉及2个驱动程序:虚拟的中断控制器驱动程序,按键驱动程序,以及对应的设备树。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/08/23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 视频观看
    • 链式中断控制器驱动程序编写
      • 1. 链式中断控制器的重要函数和结构体
        • 1.1 回顾处理流程
        • 1.2 irq_domain的核心作用
      • 2. 硬件模型
        • 3. 编程
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档