【linux-IMX6ULL中断配置流程】

目录

  • 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);

}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

页面嵌套,界面套娃,除了用iframe,还有其他方式吗?

UIOTOS可以了解下,uiotos.net,通过连线来代替脚本逻辑开发,复杂的交互界面,通过页面嵌套轻松解决,是个很新颖的思路,前端零代码! 蓝图连线尤其是独创的页面嵌套和属性继承技术,好家…

独有病眼花,春风吹不落。 (二维坐标压缩成一个点,并查集)

本题链接:登录—专业IT笔试面试备考平台_牛客网 题目: 样例: 输入 3 8 1 1 D 1 1 R 1 2 D 2 1 D 2 2 R 3 1 R 3 2 R 2 3 D 输出 8 思路: 根据题意,要求连接线段后,操作多少次,连接的线段闭合&…

javaweb学习笔记1

1、基本概念 1.1、前言 web开发: web,网页的意思,www.baidu.com 静态web html,css 提供给所有人看的数据始终不会发生变化! 动态web 淘宝,几乎是所有的网站; 提供给所有人看的数据始终会发生变化&…

00后设计师如何通过咸鱼接单实现副业月入过万?

大家好,我是一个00后,拥有6年设计经验的平面/包装/品牌设计师。在裸辞探索自由职业的过程中,误打误撞地通过咸鱼接单做副业,首月收入竟然超过了万元!在这里,我将分享具体的实操经验、心得体会以及一些额外的…

c++游戏小技巧16:实例1(地牢生成算法)

1.前言 (头图) (其实最开始是想写恶魔轮盘的,但没想到它竟然更新了) (等我有时间在更,最近很忙,玩第五玩的) 想法来源:房间和迷宫:一个地牢生成算法https://indienova…

【牛客】值周

原题链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 目录 1. 题目描述 2. 思路分析 3. 代码实现 1. 题目描述 2. 思路分析 差分。 因为l<100000000,所以数组开1e8。 唯一需要注意的点就是前面给b[0]单独赋值为1&#xff08;因为如果在循环中给b[0]赋值&…

MIT加州理工等革命性KAN破记录,发现数学定理碾压DeepMind!KAN论文解读

KAN的数学原理 如果f是有界域上的多元连续函数&#xff0c;那么f可以被写成关于单个变量和加法二元操作的连续函数的有限组合。更具体地说&#xff0c;对于光滑函数f&#xff1a;[0, 1]ⁿ → R&#xff0c;有 f ( x ) f ( x 1 , … , x n ) ∑ q 1 2 n 1 Φ q ∑ p 1 n …

解决Pyppeteer下载chromium慢或者失败的问题[INFO] Starting Chromium download.

文章目录 1.进入网址2.选择上面对应自己系统的文件夹进去3. 然后找到自己的python环境中的site-packages中pyppeteer中的chromium_downloader.py文件并打开 在首次使用Pyppeteer时需要下载chromium 1.进入网址 https://registry.npmmirror.com/binary.html?pathchromium-bro…

贪心算法应用例题

最优装载问题 #include <stdio.h> #include <algorithm>//排序int main() {int data[] { 8,20,5,80,3,420,14,330,70 };//物体重量int max 500;//船容最大总重量int count sizeof(data) / sizeof(data[0]);//物体数量std::sort(data, data count);//排序,排完数…

品高虚拟化后端存储的发展演进

在品高虚拟化技术不断发展的过程中&#xff0c;虚拟化的后端存储一直是关注的焦点之一。 本文将从最初的文件存储和NFS开始&#xff0c;追溯到集中式存储SAN&#xff0c;然后选择了Ceph的RBD方式&#xff0c;并最终抵达选择支持vhost协议的后端存储的现状&#xff0c;我们将探…

使用wxPython和pandas模块生成Excel文件

介绍&#xff1a; 在Python编程中&#xff0c;有时我们需要根据特定的数据生成Excel文件。本文将介绍如何使用wxPython和pandas模块来实现这个目标。我们将创建一个简单的GUI应用程序&#xff0c;允许用户选择输出文件夹和输入的Excel文件&#xff0c;并根据Excel文件中每个单…

图像处理技术与应用(四)

图像处理技术与应用入门 颜色空间及其转换 颜色空间是一种用于在数字图像中表达和指定颜色的方法。不同的颜色空间使用不同的方式来定义颜色&#xff0c;每种方式都有其特定的用途和优势。以下是一些常见的颜色空间及其特点&#xff1a; RGB&#xff08;红绿蓝&#xff09;&a…

每日一题(PTAL2):列车调度--贪心+二分

选择去维护一个最小区间 代码1&#xff1a; #include<bits/stdc.h> using namespace std; int main() {int n;cin>>n;int num;vector <int> v;int res0;for(int i0;i<n;i){cin>>num;int locv.size();int left0;int rightv.size()-1;while(left<…

AIGC技术带给我们什么?基于AIGC原理及其技术更迭的思考

AIGC技术带给我们什么&#xff1f;基于AIGC原理以及技术更迭的思考 前言 AI&#xff0c;这个词在如今人们的视野中出现频率几乎超过了所有一切其他的事物&#xff0c;更有意思的是&#xff0c;出现频率仅次于这个词的&#xff0c;几乎都会加上一个修饰亦或是前缀——AI&#…

快速排序找出第K大的元素

有序数组里第 K 大的元素就是index 为 array.length - k 的元素。 快速排序的思路主要就是选一个基准值p&#xff0c;然后将小于p的值放在p的左右&#xff0c;大于p的值放在p的右边&#xff0c;然后对左右数组进行递归。 利用这个思路&#xff0c;当我们找到这个基准值对应的 i…

【教学类-50-14】20240505“数一数”图片样式12:数一数(12个“人物”图案)

作品展示 背景需求&#xff1a; 前文做了“”材料”图片的数一数学具&#xff0c;效果不错&#xff0c; https://blog.csdn.net/reasonsummer/article/details/138466325https://blog.csdn.net/reasonsummer/article/details/138466325 为了让图案内容更丰富&#xff0c;我又…

Python Dash库:一个Web应用只需几行代码

大家好&#xff0c;在数据科学领域&#xff0c;数据可视化是将数据以图形化形式展示出来&#xff0c;帮助我们更直观地理解数据。Python中有一个非常流行的数据可视化库叫做Dash&#xff0c;Dash以其简洁、高效和强大的功能而闻名&#xff0c;它允许开发者快速构建交互式Web应用…

【智能算法】人类进化优化算法(HEOA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献5.代码获取 1.背景 2024年&#xff0c;J Lian受到人类进化启发&#xff0c;提出了人类进化优化算法&#xff08;Human Evolutionary Optimization Algorithm, HEOA&#xff09;。 2.算法原理 2.1算法思想 …

JavaWEB 框架安全:Spring 漏洞序列.(CVE-2022-22965)

什么叫 Spring 框架. Spring 框架是一个用于构建企业级应用程序的开源框架。它提供了一种全面的编程和配置模型&#xff0c;可以简化应用程序的开发过程。Spring 框架的核心特性包括依赖注入&#xff08;Dependency Injection&#xff09;、面向切面编程&#xff08;Aspect-Or…

Springboot项目学习之各组件的用法和逻辑结构

1.Controller层&#xff08;Controller&#xff09;&#xff1a; 也称为前端控制器或请求处理器&#xff0c;它是项目与用户交互的入口。Controller接收HTTP请求&#xff0c;解析请求参数&#xff0c;调用Service层处理业务逻辑&#xff0c;并返回响应给客户端。 Controller通…