【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_IntLowLevelkey_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.mzph.cn/bicheng/7710.shtml

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

相关文章

Git同步代码

Git中5个区,和具体操作? 代码提交和同步代码 代码撤销和撤销同步 平时是怎么提交代码的? 第零步: 工作区与仓库保持一致第一步: 文件增删改,变为已修改状态第二步: git add ,变为已暂存状态 $ git status $ git a…

1天搞定SpringBoot+Vue全栈开发 (8)前端路由VueRouter(进行组件切换)

1.VueRouter安装与使用 2.参数传递 创建路由组件 在项目中定义Discover.vue、Friends.vue、My.vue三个组件&#xff0c;将来要使用vue-router来控制它们的展示与切换&#xff1a; Discover.vue <template><div><h1>发现音乐</h1></div> <…

智能实训-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…

面试题:String类型长度有限制吗?最大多少?

简介 Java中String是有长度限制的。String还有长度限制?是的有,而且在JVM编译中还有规范,String长度限制的场景(将某固定文件转码成Base64的形式用字符串存储,在运行时需要的时候在转回来,当时文件比较大),那这个规范限制到底是怎么样的,我们分析下。 …

crossover怎么打开软件 mac怎么下载steam crossover下载的软件怎么运行

CrossOver是一款Mac和Linux平台上的类虚拟机软件&#xff0c;通过CrossOver可以运行Windows的可执行文件。如果你是Mac用户且需要使用CrossOver&#xff0c;但是不知道CrossOver怎么打开软件&#xff0c;如果你想在Mac电脑上玩Windows游戏&#xff0c;但不知道怎么下载Steam&am…

2-5 任务:打印九九表

本次实战的目标是通过编写程序实现打印九九乘法表、字符矩形、字符平行四边形和字符菱形等图形&#xff0c;以及解决百钱买百鸡问题和输出素数等实际问题。在实战过程中&#xff0c;我们将学习并掌握以下知识点。 双重循环的使用&#xff1a;通过双重循环实现九九乘法表的打印&…

代码版本管理:提升团队协作效率的利器

在软件开发过程中&#xff0c;代码版本管理是一个至关重要的环节。它不仅能够有效管理代码的变更历史&#xff0c;还能提高团队协作效率、保证代码质量、降低风险。本文将介绍两种常用的代码版本管理工具&#xff1a;Git 和 Subversion&#xff08;SVN&#xff09;&#xff0c;…

怎么把图片尺寸在线修改?5种方法调整方式介绍

在日常生活和工作中&#xff0c;我们经常遇到需要调整图片尺寸的情况&#xff0c;无论是为了适应自媒体文章内容中的图片、还是上传社交媒体平台要求&#xff0c;调整图片尺寸是一项非常有用的技能。在本教程中&#xff0c;我们将介绍几个方便快捷的图片处理工具&#xff0c;帮…

如何让CANoe或Wireshark自动解析应用层协议

当我们使用CANoe软件或Wireshark工具抓取以太网总线上的报文时,网卡首先会把以太网总线上的模拟信号解析成以太网帧数据。数据链路层根据二层头部中的Type字段值确定上层的协议。 如果以太网使用的是TCP/IP协议栈,那么Type值要么是0x0800(IPv4),要么是0x0806(ARP),要么是0x…

【牛客】【模板】前缀和

原题链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 目录 1. 题目描述 2. 思路分析 3. 代码实现 1. 题目描述 2. 思路分析 前缀和模板题。 前缀和中数组下标为1~n。 前缀和&#xff1a;pre[i]pre[i-1]a[i]; 某段区间 [l,r]的和&#xff1a;pre[r]-pre[l-1] 3.…

数据结构---动态数组

一、数据结构基本理论 数据结构是相互之间存在一种或多种特定关系的数据元素的集合。强调数据元素之间的关系 算法五个特性&#xff1a; 输入、输出、有穷、确定、可行 数据结构分类&#xff1a; 逻辑结构&#xff1a;集合、线性结构、树形结构、图形结构 物理…

安装nginx-1.25.5与ngx_http_headers_more_filter_module模块

#下载nginx的代码 curl -O http://nginx.org/download/nginx-1.25.5.tar.gz #下载headers-more-nginx-module代码 git clone https://github.com/openresty/headers-more-nginx-module#解压 tar -xzf nginx-1.25.5.tar.gzcd nginx-1.25.5#--add-dynamic-module 下载下来的目录 …

接入大量设备后,视频汇聚系统EasyCVR安防监控视频融合平台是如何实现负载均衡的?

一、负载均衡 随着技术的不断进步和监控需求的日益增长&#xff0c;企业视频监控系统的规模也在不断扩大&#xff0c;接入大量监控设备已成为一项常态化的挑战。为确保企业能够有效应对这一挑战&#xff0c;视频汇聚系统EasyCVR视频融合平台凭借其卓越的高并发处理能力&#x…

“Postman 中文版使用教程:如何切换到中文界面?”

Postman 的很好用的接口测试软件。但是&#xff0c;Postman 默认是英文版的&#xff0c;也不支持在软件内切换为中文版。很多同学的英语并不是很好&#xff0c;看到一堆的英文很是头痛。 今天我们来介绍下&#xff1a;切换到 Postman 中文版的方法。想要学习更多的关于 Postma…

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

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

皮秒激光切割机可以切割材料及主要应用行业

皮秒激光切割机可以切割多种材料&#xff0c;主要应用行业包括但不限于&#xff1a; 1. PCB板行业&#xff1a;主要用于PCB激光分板&#xff0c;如FR4、补强钢片、FPC、软硬结合板、玻纤板等材料的紫外激光切割。 2. 薄膜材料切割&#xff1a;皮秒紫外激光切割机可以直接切割薄…

启英泰伦“离线自然说”技术,让智能语音芯片更善解人意

“以科技创新推动产业创新&#xff0c;特别是以颠覆性技术和前沿技术催生新产业、新模式、新动能&#xff0c;发展新质生产力”。2023年12月&#xff0c;中央经济工作会议强调了发展新质生产力的路径。“科技创新是发展新质生产力的核心要素&#xff0c;这也是我们一直潜心在做…

解决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…

07_Flutter使用NestedScrollView+TabBarView滚动位置共享问题修复

07_Flutter使用NestedScrollViewTabBarView滚动位置共享问题修复 一.案发现场 可以看到&#xff0c;上图中三个列表的滑动位置共享了&#xff0c;滑动其中一个列表&#xff0c;会影响到另外两个&#xff0c;这显然不符合要求&#xff0c;先来看下布局&#xff0c;再说明产生这个…

【MM32F3270 Micropython】pwm输出

文章目录 前言一、PWM脉宽调制技术介绍二、machine.PWM 类2.1 machine.PWM 类的构造对象2.2 PWM 对象初始化2.3 关闭PWM设备2.4 设置pwm的周期2.5 设置占空比 三、pwm示例代码总结 前言 MicroPython是一种精简的Python 3编程语言实现&#xff0c;旨在在微控制器和嵌入式系统上…