百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Linux内核中断之获取中断号_linux对中断处理的流程

haoteby 2025-02-16 20:56 27 浏览

Linux内核中可使用platform_get_irq()函数获取dts文件中设置的中断号。

函数原型:int platform_get_irq(struct platform_device *dev, unsigned int num)

定义文件:drivers\base\platform.c

一、调用流程

中断号获取函数platform_get_irq()调用流程如下:

platform_get_irq()->
    of_irq_get()->
        of_irq_parse_one()                  ## 解析dts中中断相关属性,填充结构体of_phandle_args中的args[]参数
        irq_create_of_mapping()->           
            of_phandle_args_to_fwspec()     ## 将of_phandle_args->args[]赋值给fwspec->param[],给translate使用
            irq_create_fwspec_mapping()->   
                irq_domain_translate()->    ## 获取中断号和中断触发类型
                    translate()->           ## 对应某个版本的gic处理函数

rk3399使用的是GICv3,对应irq_domain->name

文件:
drivers/irqchip/irq-gic-v3.c

translate()函数实现如下:

static const struct irq_domain_ops gic_irq_domain_ops = {
    .translate = gic_irq_domain_translate,  ## .translate的实现函数
    ...
};

static int gic_irq_domain_translate(struct irq_domain *d,
                    struct irq_fwspec *fwspec,
                    unsigned long *hwirq,
                    unsigned int *type)
{
        ...
        switch (fwspec->param[0]) {
        case 0:         /* SPI */
            *hwirq = fwspec->param[1] + 32;  ## 中断号
            break;
        case 1:         /* PPI */
            *hwirq = fwspec->param[1] + 16; ## 中断号
            break;
        case GIC_IRQ_TYPE_LPI:  /* LPI */
            *hwirq = fwspec->param[1];     ## 中断号
            break;
        default:
            return -EINVAL;
        }
        *type = fwspec->param[2] & IRQ_TYPE_SENSE_MASK; ## 中断触发类型
        ...
}

二、应用举例

RockPI 4A单板Debian系统Linux 4.4内核中的获取HDMI中断号为例。

1、查找中断号

从手册“Rockchip RK3399 TRM V1.3 Part1.pdf”中,可以查到HDMI_IRQ中断号,即55。

2、dts配置

文件:
arch/arm64/boot/dts/rockchip/rk3399.dtsi

    hdmi: hdmi@ff940000 {
        compatible = "rockchip,rk3399-dw-hdmi";
        ...
        interrupts = ;
        ...
    }

hdmi使用的是GIC_SPI中断,按照gic_irq_domain_translate()函数中处理,需要将中断号55减去32,得到dts中的中断号23。

注:interrupts = <中断类型 中断号 中断触发类型 中断分区(对应哪个CPU cluster,PPI类型中断特有)>

3、驱动函数

文件:drivers\gpu\drm\rockchip\dw_hdmi-rockchip.c

static int dw_hdmi_rockchip_bind(struct device *dev, struct device *master,
                 void *data)
{
    ...
    irq = platform_get_irq(pdev, 0);
    ...
}

此时,irq返回值为55。

后续会介绍GIC和中断注册等实现函数。

相关推荐

法网公开赛再遭雨水突袭“三无赛事”困局一年后破解

大雨突降,比赛被迫取消。广州日报全媒体记者孙嘉晖摄今天,法网公开赛进入正赛第11个比赛日,突如其来的大雨让本该在当地时间14时开球的女单1/4决赛被迫延迟,最终组委会官方确认,当天比赛因恶劣天气全...

AC米兰队史今天:2005年3比1尤文,马尔蒂尼PK伊布+众将围殴穆图

AC米兰队史今天:2005年3比1尤文,马尔蒂尼PK伊布+众将围攻穆图2005年10月29日,2005-2006赛季意甲第10轮的一场焦点对决在圣西罗上演,AC米兰坐镇主场迎战老妇人尤文图斯。强强死磕...

如果2005年西部全明星阵容VS2021年全明星阵容

#NBA全明星#如果2004-05赛季的西部全明星阵容,分别对阵今年的詹姆斯和杜兰特队,会孰强孰弱呢?首先我们来看看2004-05赛季西部全明星的阵容,首发球员是:科比、麦迪、加内特、邓肯、姚明;替补...

EtherCAT从站EEPROM更新操作指南_ethercat stm32从站

@ZHangZMo升级EtherCAT从站EEPROM...

LAN8820I-ABZJ/MICROCHIP/微芯/代理现货库存/以太网/太航半导体

描述微芯片lan820/lan820i是低功率100BASE/100BASE/1000BASE-TX/1000BASE-TX/100000base是由IEEE802.3和802.3ab...

汽车的发明者到底是谁?哪一年?百年历史的汽车品牌有哪些

今天是解读大学本科汽车专业教材《汽车构造》解读的第一期“总论”部分。后面将以教材内容为基础,并结合汽车发展现状做有一些更丰富的延展,同时补充进一些相关的常见故障及维修内容。华歌通俗易懂讲原理的讲解方...

嵌入式Linux自学不走弯路!670+讲课程!应用层+底层系统学习路线

在智能设备爆发式进化的今天,智能设备正从单点控制迈向系统级智能。从工业机械臂的精准控制到智能座舱的多屏交互,从边缘AI推理到云端协同,...

从cpu角度理解PCIe_cpuz pcie

举报Herok...

什么是big.LITTLE,你真的了解吗_big 是什么

2015年最佳智能手机阵容处理器均基于ARM的big.LITTLE架构,采用该架构处理器的手机工作速度更快更高效。三星GalaxyS6、HTCM9、LGG4等手机均采用基于big...

网上疯传的乌克兰战争片段,其实是一段游戏视频

希望人没事。...

《爱奇艺视频》UWP已悄悄更新ARM版,支持Win10 Mobile部署安装

此前IT之家报道过,爱奇艺视频(Beta版)已经推出Win10UWP版,适配Windows10PC系统,Win10Mobile还不能下载,不过现在有IT之家网友发现,爱奇艺视频(Beta版)商店里已...

Arm版Chrome/Edge浏览器新改进:加速视频渲染、延长续航时间

IT之家6月29日消息,科技媒体WindowsReport昨日(6月28日)发布博文,挖掘ChromiumCommit发现了“EnableMediaFoundationA...

ARM全新视频处理器Mali Egil曝光:支持VP9编解码

5月30日,ARM正式发布了其最新的图形处理器Mail-G71,基于ARM全新的GPU架构“Bifrost”,并且结合了线程级并行(TLP)设计。实际上,完整的MaliGPU基于ARM图形产品堆栈设...

2020年手机最全资源app网站合集,你要的基本上都有

手机最全资源app合集,你要的基本上都有聚BT:(最强资源聚合网站)https://jubt.net安卓老子追剧+安卓南瓜影视破解版+安卓香蕉影视+韩剧TV安卓:https://www.lanzous...

闰秒宣布取消,网友:让Linus本人与谷歌微软达成一致,只有它了

詹士发自凹非寺量子位|公众号QbitAI决定了!这一秒,程序员们不用再续了!...