【linux-IMX6ULL中断配置流程】

news2024/7/6 17:38:23

目录

  • 1. Cortex-A7和GIC中断概述
    • 1. 1 Cortex-A7中断系统:
    • 1. 2 GIC中断控制器简介:
  • 2. 中断配置概述
  • 3. 底层中断文件配置
    • 3.1 对启动文件.s的配置思路
    • 3.2 对中断函数配置思路
  • 4. 上层中断配置流程

1. Cortex-A7和GIC中断概述

  学习IMX6UL的中断处理系统,可以参考STM32的中断系统,并把知识点迁移过来:如下图,IMX6ULL与STM32最大的不同的就是IMX6ULL的中断控制器GIC( general interrupt controller),其他总体思路都是类似的:

  但是对于裸机编程而言,没有标准库可以直接调用,因此对于裸机而言,配置中断可分为底层配置,把相关的函数封装完毕,另外一个就是对这些封装好的函数进行调用,这里就和STM32使用标准库类似了

1. 1 Cortex-A7中断系统:

  对于Cortex-A7而言,有8个中断系统,但是我们常用的就是复位中断IRQ中断,因此主要了解就是IRQ中断;属于IRQ的中断有很多,我们怎么确定是哪一个类型的的呢?这个判断就是交给下面的GIC中断控制器。

1. 2 GIC中断控制器简介:

  GIC控制器负责确定发生了那个中断并报给arm内核,由于目前只关注IRQ中断类型,因此GIC上报给ARM内核的只有IRQ中断类型:GIC中比较重要的点就是中断ID号和SPI中断类型。

  重点关注的点1:就是我们使用的中断ID号是32-1019,但是在IM6ULL中我们使用的只有160个中断,其中前32个我们用不到,因此我实际用到的中断ID号就是32-159
  重点关注的点2:SPI(Shared Peripheral Interrupt)中断类型,所有核共享的中断,比如按键中断、串口中断等等,这些中断所有的 Core 都可以处理,不限定特定 Core。

2. 中断配置概述

  配置中断,拿IRQ中断类型来说,分两种情况,第一种情况是底层中断配置,因为是裸机编程,所以底层中断配置有两大类,一类就是启动文件的编写,和系统中断函数的编写;启动文件的编写主要有包含现场保护、CP15协处理器的中断功能编写、GIC中断控制器的编写、系统中断服务函数的调用、恢复现场这几大块;这个系统中断函数不是中断服务函数,中断服务函数属于上层编写,编写完毕并进行注册一就可以的。而对于系统中断函数则牵扯的就更多,其中就有中断初始化(包括GIC、中断偏移量、中断向量表的初始化)、中断向量表的编写、中断注册函数的编写;

  第二种情况就是上层的中断初始化编写,类似于STM32的标准库的中断的处理流程,拿外部输入触发的中断来举例,主要编写的内容就是中断初始化函数和中断服务函数的编写两大块,其中中断初始化函数包括:引脚的模式要配置成中断触发(例如上升沿触发中断)、其次就是使能GIC中断控制器,(底层已经初始化了GIC控制器,但是初始化不等于使能),然后就是调用中断注册函数,对中断服务函数进行注册(实际就是把中断服务函数的地址传到中断向量表中);另外中断服务函数编写我们要处理的程序。
在这里插入图片描述

3. 底层中断文件配置

  由于这些内容比较复杂,因此这里对整体的思路做一个抽象的概括,相当于掌握大纲,即首先对整个配置流程有一个理解,具体细节的配置要根据代码详细揣摩

3.1 对启动文件.s的配置思路

  由于是裸机编程,因此首先就是在启动文件中对各个中断模式进行设置,而对于IMX6ULL而言有7种中断模式,但是我们最关注的是reset_Handler和IRQ_Handler,这里拿IRQ的中断模式进行说明,其他都是类似的,首先就是触发中断,进入到IRQ_Handler函数中:如下伪代码

.global _start
_start:
    1. 第一步:配置IRQ中断处理函数:
    ldr pc,=IRQ_Handler      /*IRQ中断 */
    .......
IRQ_Handler:
    .......
    /*处理过程*/
 	2. 第二步:保护现场
 	3. 第三步:处理CP15协处理器
	4. 第四步:处理GIC中断控制器
	5. 第五步:进入到中断服务函数
	6. 第六步:恢复现场
  1. 第一步:配置IRQ中断处理函数:
  2. 第二步:保护现场
  3. 第三步:处理CP15协处理器
  4. 第四步:处理GIC中断控制器
  5. 第五步:进入到中断服务函数
  6. 第六步:恢复现场

对于启动文件中的编写就是大体如此,其次就是对中断函数的编写:

3.2 对中断函数配置思路

  注意,这里的中断函数不是中断服务函数,中断服务函数是最终的处理函数,我们要先配置好中断函数,这样才能正确进入到中断服务函数;
  我们在中断函数中要做的工作主要是包括以下部分:中断初始化(包含初始化GIC中断控制器金设置中断偏移量),中断偏移量的设置,然后就是中断向量表的建立及初始化,其次就是对注册中断服务函数的编写,以便于对中断服务函数进注册;总体思路如下:

  1. 中断初始化:包括:GIC中的初始化,系统中断向量表的初始化,以及中断向量偏移的设置:
  2. 建立系统中断向量表:对于IMX6ULL是包含160个中断,可以用一个结构体数组来表示:这个结构体数组包含两部分,第一部分是用来存储中断服务函数的地址,另外一个就是用户参数
  3. 注册中断服务函数:编写中断服务注册函数,方便对中断服务函数进行注册,也就是负责给中断向量表写入中断服务函数的地址;
  4. 中断处理函数: 系统中断函数是放入启动文件中的函数,这个函数通过中断号直接读取结构体数组中对应的元素,这个元素的第一个参数就是中断服务函数的地址,所以要对中断服务函数进行编写完成后要进行注册,注意的是中断是可以嵌套的:

在这里插入图片描述

4. 上层中断配置流程

  对于上层而言,中断触发的方式很多,包括GPIO中断出触发、IIC中断触发、UART中断触发等等,这里拿GPIO的外部输入中断配置而言就是分为两步:中断初始化函数的编写和中断分服务函数的编写,其中中断初始化包括:GPIO初始化、GIC使能、对中断服务函数进行注册、GPIO中断使能;对于中断服务函数的编写就是处理中断程序,具体代码如下,比较简单:

/*初始化外部中断————GPIO_18*/

void exit_init(void)
{
    gpio_pin_config_t key_config;
    IOMUXC_SetPinMux(IOMUXC_UART1_CTS_B_GPIO1_IO18,0);
    IOMUXC_SetPinConfig(IOMUXC_UART1_CTS_B_GPIO1_IO18,0xF080);
    key_config.direction=kGPIO_DigitalInput;
    key_config.interruptMode=kGPIO_IntFallingEdge;  //注意这里错误
    //错误设置成低电平触发:导致按键按下去频繁进入中断
    //key_config.interruptMode=kGPIO_IntLowLevel
    
    key_config.outputLogic = 1;
    gpio_init(GPIO1,18,&key_config);
    
    GIC_EnableIRQ(GPIO1_Combined_16_31_IRQn);

    system_register_irqhandler(GPIO1_Combined_16_31_IRQn,gpio1_io18_irqhandler,NULL);

    gpio_enable_int(GPIO1,18);

}
/*中断处理函数*/
void gpio1_io18_irqhandler(unsigned int gicciar,void *param)
{
    static int status = 0 ;
    delay(20);
    if(gpio_pinread(GPIO1,18)==0)
    {
        status=!status;
        led_switch(LED0,status);
       // beep_switch(status);
    }
    /* 清除中断标志位*/
    gpio_clearintflags(GPIO1,18);

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1649732.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

毕业就业信息|基于Springboot+vue的毕业就业信息管理系统的设计与实现(源码+数据库+文档)

毕业就业信息管理系统 目录 基于Springboot+vue的毕业就业信息管理系统设计与实现 一、前言 二、系统设计 三、系统功能设计 1学生信息管理 2 公司信息管理 3公告类型管理 4公告信息管理 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设…

自动化运维管理工具 Ansible-----【inventory 主机清单和playbook剧本】

目录 一、inventory 主机清单 1.1inventory 中的变量 1.1.1主机变量 1.1.2组变量 1.1.3组嵌套 二、Ansible 的脚本 ------ playbook(剧本) 2.1 playbook介绍 2.2playbook格式 2.3playbooks 的组成 2.4playbook编写 2.5运行playbook 2.5.1ans…

如何翻译外文文献【攻略】

如何翻译外文文献【攻略】 前言版权推荐如何翻译外文文献简单描述第一步 准备一篇外文文献第二步 翻译网站第三步 解锁文档第四步 编辑dpf第五步 pdf转为word第六步 编辑word方便操作快捷键设置章节设置页眉页脚设置页码三线表的绘制 第七步 word转为pdf 最后 前言 2024-5-7 1…

电脑提示“无法定位程序输入点kernel32.dll”怎么解决?分享kernel32.dll丢失的五个修复方法

打开游戏或者软件的时候,电脑提示由于找不到kernel32.dll,无法继续执行此代码怎么办,其实修复起来不难。首先需要先知道怎么是dll文件,dll文件可以简单的把库文件看成一种代码仓库,它提供给使用者一些可以直接拿来用的…

【SSM进阶学习系列丨分页篇】PageHelper 分页插件集成实践

文章目录 一、说明什么是分页PageHelper介绍 二、导入依赖三、集成Spring框架中四、编写Service五、编写Controller六、编写queryAllByPage页面展示数据 一、说明 什么是分页 ​ 针对分页,使用的是PageHelper分页插件,版本使用的是5.1.8 。 ​ 参考文档…

openEuler 22.03 GPT分区表模式下磁盘分区管理

目录 GPT分区表模式下磁盘分区管理parted交互式创建分区步骤 1 执行如下步骤对/dev/sdc磁盘分区 非交互式创建分区步骤 1 输入如下命令直接创建分区。 删除分区步骤 1 执行如下命令删除/dev/sdc1分区。 GPT分区表模式下磁盘分区管理 parted交互式创建分区 步骤 1 执行如下步骤…

Day 24 数据库管理及数据类型

数据库管理及数据类型 一:数据类型 1.数值类型 整数类型 ​ 整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT ​ 作用:用于存储用户的年龄、游戏的Level、经验值等 浮点数类型 ​ 浮点数类型:FLOAT DOUBLE ​ 作用&#xf…

2024 cleanmymac有没有必要买呢,全反面分析

在使用mac时,小编遇到了运行内存不足、硬盘空间不足的情况。遇到这种情况,我们可以借助经典的电脑深度清理软件——CleanMyMac X,清理不常用的软件和系统垃圾,非常好用!不过,有许多网友发现CleanMyMac X有免…

基于Springboot的校园新闻管理系统(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的校园新闻管理系统(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构…

NFTScan 与 Scattering 达成合作伙伴,双方将共同解决混合 NFT 数据需求

在区块链领域,NFT 的创新与发展从未停止。近日,NFT 数据基础设施 NFTScan 与一站式混合 NFT 交易市场 Scattering 达成合作伙伴关系,双方将在 NFT 数据层面展开合作,共同解决混合 NFT 的独特数据需求,Scattering 在协议…

非平衡数据处理-Tomek link算法介绍,代码和实战测评

作者Toby,来源公众号:Python风控模型,非平衡数据处理-Tomek link算法 概述 非平衡数据在金融风控领域、反欺诈客户识别、广告智能推荐和生物医疗中普遍存在。一般而言,不平衡数据正负样本的比例差异极大,如在Kaggle竞…

Quora 首席执行官亚当·德安杰洛 (Adam D’Angelo) 谈论了 AI、聊天机器人平台 Poe,以及 OpenAI 为什么不是竞争对手

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

无线通信基础

这里写目录标题 通信概述什么是无线通信无线通信电磁波 通信概述 什么是无线通信 无线通信 : 是指利用电磁波信号可以在自由空间中传播的特性进行信息交换的一种通信方式 无线通信的关键技术包括调制技术、解调技术、信道编码技术、信号处理技术、天线技术等。这些技术的不断…

【探索Java编程:从入门到入狱】Day4

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~ ✨主攻领域:【渗透领域】【应急响应】 【Java、PHP】 【VulnHub靶场复现】【面试分析】 🎉点赞➕评论➕收…

CANdela/Diva系列2--CANdela Studio的工作树介绍1

本系列的第一篇文章(CANdela/Diva系列1--CANdela Studio的基本介绍)主要介绍了CANdela这个工具,本篇文章将对CANdela Studio的工作树的每个模块进行详细介绍,不啰嗦,直接开始! 目录 1. ECU Information的…

数据库被Elbie勒索病毒加密可以恢复吗?

一、Elbie勒索病毒简介 Elbie勒索病毒是一种严重的网络安全威胁,它通过加密用户文件并索要高额赎金来获取解密密钥。该病毒通常通过电子邮件附件、恶意网站、社交媒体平台以及利用用户网站服务器上的漏洞进行传播。一旦感染,用户的文件将被加密&#xff…

【vulhub靶场】Tomcat中间件漏洞复现

【vulhub靶场】Tomcat中间件漏洞复现 一、Tomcat AJP 任意文件读取/包含漏洞 (CVE-2020-1938)1. 漏洞描述2. 影响版本3. 漏洞原理4. 漏洞复现 二、任意文件写入漏洞 (CVE-2017-12615)1. 漏洞原理2. 影响版本3. 漏洞复现 三、Tomca…

.[[MyFile@waifu.club]].svh勒索病毒数据库恢复方案

.[[MyFilewaifu.club]].svh勒索病毒有什么特点? .[[MyFilewaifu.club]].svh是一种最近多发的勒索病毒,它通过加密受害者的文件并要求支付赎金来解锁,从而达到勒索钱财的目的。恢复重要数据请添加技术服务号(safe130)。以下是关于这种病毒的详…

智能实训-wheeltec小车-抓取(源代码)

语言 :C 源代码&#xff1a; #include <ros/ros.h> #include <image_transport/image_transport.h> #include <cv_bridge/cv_bridge.h> #include <sensor_msgs/image_encodings.h> #include <sensor_msgs/JointState.h> #include <geometry…