ARM 中断初始设置

一、首先要设置异常向量表地址为0(因为为0才可重映射)

再汇编中进行(由下图,在13位置零)

MRC p15, 0, <Rt>, c1, c0, 0 ; Read System Control Register
MCR p15, 0, <Rt>, c1, c0, 0 ; Write System Control Register

在_reset_handler当中加上

cpp 复制代码
mrc p15, 0, r1, c1, c0, 0
    orr r1, r1, #(1 << 12)
    bic r1, r1, #(1 << 13) 
mcr p15, 0, r1, c1, c0, 0  

二、中断初始化

重映射异常向量地址

初始化GIC

cpp 复制代码
void system_irq_init(void)
{
  __set_VBAR(0x87800000);
  GIC_Init();
}

三、配置中断源

1、引脚相关

配置引脚功能及其方向 GPIO_DIR

设置中断触发方式 ICR/IMR

ICR:中断配置寄存器,

|-------|----|
| 低电平触发 | 00 |
| 高电平触发 | 01 |
| 上升沿触发 | 10 |
| 下降沿触发 | 11 |

IMR:中断屏蔽寄存器

|---|------|
| 0 | 禁止中断 |
| 1 | 允许中断 |

2、GIC相关

GIC中断使能:GIC_EnableIRQ(IRQn_Type IRQn);

GIC中断优先级设置:GIC_SetPriority("中断号","优先级");

cpp 复制代码
void key_irq_init(void)
{
    IOMUXC_SetPinMux(IOMUXC_UART1_CTS_B_GPIO1_IO18, 0);
    IOMUXC_SetPinConfig(IOMUXC_UART1_CTS_B_GPIO1_IO18, 0x10b0);
    GPIO1->GDIR &= ~(1 << 18);
    //设置中断触发方式
    GPIO1->ICR2 |= (0x3 << 4);
    //使能 GPIO 中断
    GPIO1->IMR |= (1 << 18);
    GIC_EnableIRQ(GPIO1_Combined_16_31_IRQn);
    GIC_SetPriority(GPIO1_Combined_16_31_IRQn, 0);
}

3、异常处理

在汇编中结合c函数进行

前提须知

因此在iqr中要先给lr减4再入栈

cpp 复制代码
_irq_handler:
    sub lr,lr,#4
    stmfd sp!,{r0-r12,lr}

    //读取GIC中断号
    mrc p15,4,r1,c15,c0,0
    add r1,r1,#0x2000
    ldr r0,[r1,#0x0c]
    stmfd sp!, {r0,r1}
    cps #0x1f
    stmfd sp!, {r0-r12,lr}
    bl system_irq_handler
    stmfd sp!, {r0-r12,pc}
    cps #0x12
    ldmfd sp!, {r0,r1}
    str r0, [r1,#0x10]

    ldmfd sp!,{r0-r12,pc}^
cpp 复制代码
void system_irq_handler(IRQn_Type irq_num)
{
    if (irq_num == GPIO1_Combined_16_31_IRQn)
    {
        if (GPIO1->ISR & (1 << 18))
        {
            led_on();
            tamper1_on();
            GPIO1->ISR |= (1 << 18);
        }
    }
}
相关推荐
web守墓人30 分钟前
【linux】Mubuntu发布,将完整的ubuntu arm装进手机应用中
linux·arm开发·ubuntu
EnglishJun1 天前
ARM嵌入式学习(十九)--- 字符设备驱动的注册与调用流程
arm开发·学习
ai产品老杨1 天前
异构计算时代的安防底座:基于 Docker 的 X86/ARM 双模部署与 NPU 资源池化实战
arm开发·docker·容器
somi71 天前
ARM-驱动-06-中断底半部 + ioctl + 原子操作与锁
arm开发·单片机·嵌入式硬件
好家伙VCC1 天前
**TEE在嵌入式安全中的应用实践:基于ARM TrustZone的加密存储方案设计与实现*
java·arm开发·python·struts·安全
进击的小头1 天前
第9篇:嵌入式芯片指令集架构(ISA)详解:ARM_RISC-V等主流ISA全对比
arm开发·单片机·架构·risc-v
Yeats_Liao1 天前
混合部署架构:CPU+GPU协同推理的任务调度策略
服务器·arm开发·人工智能·架构·边缘计算
somi71 天前
ARM-驱动-06-DHT11
linux·arm开发·自用
xingyuzhisuan2 天前
从x86到Arm:GPU服务器CPU架构多元化趋势深度解读
服务器·arm开发·架构·gpu算力
惶了个恐2 天前
嵌入式硬件第十弹——ARM(6)
arm开发·stm32·嵌入式硬件·硬件工程