cortex-A7核中断实验

引脚线路分析

在这里插入图片描述
在这里插入图片描述

分析框图

总结框图:
1.通过框图分析可知:RCC章节/GPIOF章节/EXTI章节/GIC章节
2.需要分析GPIOF章节:设置引脚为输入模式
3.需要分析EXTI章节:检测中断的触发方式
3.需要分析GIC章节:设置GPIOF引脚对应的中断号

在这里插入图片描述

控制器设置分析

分析RCC章节

1、寄存器总线

在这里插入图片描述
在这里插入图片描述

分析RCC_MP_AHB4ENSETR寄存器

1.确定RCC基地址
通过2.5.2章节
2.RCC_MP_AHB4ENSETR地址
RCC_MP_AHB4ENSETR地址=基地址+偏移地址 = 0x50000000 + 0xA28 =0x50000A28    
3.设置GPIOF控制器使能
0x50000A28地址的第5位置1,设置GPIOF控制器使能
RCC_MP_AHB4ENSETR[5] = 1 -------->设置GPIOF控制器使能工作

在这里插入图片描述

分析GPIO章节

分析GPIOx_MODER寄存器

在这里插入图片描述

	KEY1------>PF9引脚
	KEY2------>PF7引脚
	KEY3------>PF8引脚
	1.确定GPIOF_MODER寄存器的地址
  	地址=基地址+偏移地址=0x50007000+0x00=0x50007000    
	2.通过GPIOF_MODER设置PF9/PF7/PF8引脚设置为输入模式
  	 GPIOF_MODER[19:18]=00------>KEY1输入模式
 	 GPIOF_MODER[15:14]=00------>KEY2输入模式
  	 GPIOF_MODER[17:16]=00------>KEY3输入模式

分析EXTI章节

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

EXTI_EXTICR3:EXTI external interrupt selection registe
EXTI:外部中断选择寄存器 功能:GPIO控制器和EXTI控制器进行连	接

思考:1.EXTI_EXTICRn(n:1~4),为什么有4个EXTI_EXTICRn这样控制器?
1)通过EXTI框图分析可知,一共有16个EXTI(EXTI0~EXIT15)
2)EXTI_EXTICRn寄存器每8位管理一个EXTI,一个寄存器32位,最多管理4个EXTI
3)要想管理16个EXTI,需要4个这样EXTI_EXTICRn控制器

key1------>PF9------>EXTI9-------->EXTI_EXTICR3[15:8] = 0x05
key2------>PF7------>EXTI7-------->EXTI_EXTICR2[31:24] = 0x05
key3------>PF8------>EXTI8-------->EXTI_EXTICR3[7:0] = 0x05

思考2:有没有什么公式可以直接推出哪一个寄存器的哪几位
EXTI编号 / 4 = 商 ...... 余数
商+1 :对应的哪一个寄存器
余数*8:对应寄存器8位中的最低位
key1------>PF9------>EXTI9--->9 / 4 = 2.....1--->EXTI_EXTICR3[15:8] = 	0x05
key2------>PF7------>EXTI7--->7 / 4 = 1.....3--->EXTI_EXTICR2[31:24] 	= 0x05
key3------>PF8------>EXTI8--->8 / 4 = 2.....0--->EXTI_EXTICR3[7:0] = 0x05

分析EXTI_FTSR1寄存器

在这里插入图片描述
在这里插入图片描述

1.需要知道EXTI7/EXTI8/EXTI9对应输入事件编号是多少
通过芯片手册21.3章节进行查看
2.EXTI7/EXTI8/EXTI9对应设置EXTI_FTSR1位数:
key1------>PF9------>EXTI9--->对应事件9--->EXTI_FTSR1[9] = 0x1
key2------>PF7------>EXTI7--->对应事件7--->EXTI_FTSR1[7] = 0x1
key3------>PF8------>EXTI8--->对应事件8--->EXTI_FTSR1[8] = 0x1
3.地址
地址 = 基地址 + 偏移地址 = 0x5000D000 + 0x004  =  0x5000D004

分析EXTI_IMR1寄存器

在这里插入图片描述

分析EXTI_FPR1寄存器在这里插入图片描述

分析EXTI_FTSR1寄存器

在这里插入图片描述
在这里插入图片描述

分析EXTI_IMR1寄存器

在这里插入图片描述

分析EXTI_FPR1寄存器

在这里插入图片描述
在这里插入图片描述

分析GICD章节

在这里插入图片描述

分析GICD_CTLR寄存器

在这里插入图片描述
在这里插入图片描述

分析GICD_IPRIORITYRx寄存器

在这里插入图片描述

分析GICD_ITARGETSRx寄存器

在这里插入图片描述

分析GICD_ICPENDRx寄存器

在这里插入图片描述

分析GICC章节

分析GICC_CTLR寄存器

在这里插入图片描述

分析GICC_PMR寄存器

在这里插入图片描述

分析GICC_IAR寄存器

在这里插入图片描述

分析GICC_EOIR寄存器

在这里插入图片描述

实验现象

在这里插入图片描述

实验代码

key.c

#include "key.h"

/*****KEY1---->PF9**********/
//初始化EXTI层
void pf9_exti_init()
{
/*****RCC章节初始化******/
//1.设置GPIOF组时钟使能 MP_AHB4ENSETR[5] = 1
    RCC->MP_AHB4ENSETR |= 0x1<<5;

/*****GPIO章节初始化******/
//1.设置PF9引脚为输入模式 MODER[19:18] = 00
GPIOF->MODER &=(~(0x3<<18));

/*****EXTI章节初始化******/
//1.设置PF9引脚和EXIT9控制器进行连接 EXTICR3[15:8] = 0x05
EXTI->EXTICR3 &=(~(0xff<<8));
EXTI->EXTICR3 |= (0x05<<8);
//2.设置PF9引脚检测方式下降沿 FTSR1[9] = 1
EXTI->FTSR1 |= 0x1<<9;
//3.设置PF9引脚中断不屏蔽 C1IMR1[9] = 1
    EXTI->C1IMR1 |= 0x1<<9;
}

//初始化GICD层
void pf9_gicd_init()
{
//1.设置GICD层全局中断使能寄存器 CTRL[0] = 1
GICD->CTRL |=0x1<<0;
//2.设置GICD层中断使能寄存器 ISENABLER[3] 第三位 1
GICD->ISENABLER[3] |= 0x1<<3;
//3.设置GICD层中断优先级寄存器IPRIORITYR[24] [31:27]
GICD->IPRIORITYR[24] &=(~(0x1f<<27));
//4.设置GICD层中断目标分配寄存器 ITARGETSR[24] [25:24] = 01
GICD->ITARGETSR[24] &=(~(0x3<<24));
GICD->ITARGETSR[24] |=0x1<<24;
}

//初始化GICC层
void pf9_gicc_init()
{
//1.设置GICC层全局中断使能寄存器 CTRL[0] = 1
     GICC->CTRL |=0x1<<0;
//2.设置GICC层中断优先级寄存器 PMR[7:3]
GICC->PMR &=(~(0x1f<<3));
GICC->PMR |=0x1f<<3;
}

key.h

#ifndef __KEY_H__
#define __KEY_H__
#include "stm32mp1xx_rcc.h"
#include "stm32mp1xx_gpio.h"
#include "stm32mp1xx_exti.h"
#include "stm32mp1xx_gic.h"
/*****KEY1---->PF9**********/
//初始化EXTI层
void pf9_exti_init();
//初始化GICD层
void pf9_gicd_init();
//初始化GICC层
void pf9_gicc_init();




#endif
AST2600 SoC 包含两个主要的处理器心:一个 Cortex-A7和一个 Cortex-M3 内。这两个内之间可以通过 AMBA AXI4 接口进行通信。在 Cortex-M3 内中,可以通过 NVIC(Nested Vector Interrupt Controller)设置和管理中断。以下是在 AST2600 中设置 Cortex-M3 内间通信中断的基本步骤: 1. 配置 AMBA AXI4 接口:在 Cortex-A7中,需要配置 AMBA AXI4 接口,以便与 Cortex-M3 内进行通信。这包括设置 AXI4 接口的基址、大小和属性等参数。 2. 配置 Cortex-M3 中断:在 Cortex-M3 内中,需要使用 NVIC 设置和管理中断。可以使用 CMSIS(Cortex Microcontroller Software Interface Standard)库中提供的 NVIC API 来设置中断优先级、使能中断等。 3. 设置中断处理程序:在 Cortex-M3 内中,需要编写中断处理程序来处理接收到的中断。可以使用标准的 C 或汇编语言编写中断处理程序,并将其链接到正确的中断向量表中。 4. 触发中断:在 Cortex-A7中,可以通过向 AXI4 接口发送中断请求来触发中断。当 Cortex-M3 内接收到中断请求后,将跳转到相应的中断处理程序中执行。 需要注意的是,上述步骤仅提供了一般的框架,具体的实现方式可能会因系统架构和应用场景而异。在实际应用中,可能需要进一步优化中断处理程序的性能和可靠性,并考虑调试和故障排除等方面的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值