cortex-A7核中断实验

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

//RCC/GPIO/EXTI章节初始化
void hal_exti_pf9_init();
//GIC章节初始化
void hal_gic_pf9_init();


#endif

key.c:

#include "key.h"


//RCC/GPIO/EXTI章节初始化
void hal_exti_pf9_init()
{
	//RCC章节初始化
	//1.使能GPIOF组控制器 MP_AHB4ENSETR[5] = 1
	RCC->MP_AHB4ENSETR |= (0x1 << 5);
	//GPIO章节初始化
	//1.设置KEY1按键为输入模式 MODER[19:18] = 00
	GPIOF->MODER &= (~(0x3 << 18));
	//EXTI章节初始化
	//1.设置PF9引脚与EXTI9进行连接EXTICR3[15:8] = 0x05
	EXTI->EXTICR3 &= (~(0xff << 8));
	EXTI->EXTICR3 |= (0x05 << 8);
	//2.设置KEY1按键为下降沿触发方式 FTSR1[9] = 1
	EXTI->FTSR1 |= (0x1 << 9);
	//3.设置EXTI9中断不屏蔽 C1IMR1[9] = 1
	EXTI->C1IMR1 |= (0x1 << 9);
}

//GIC章节初始化
void hal_gic_pf9_init()
{
	//GICD章节初始化
	//1.设置GICD层中断设置使能寄存器 
	//CTRL[0] = 1 ISENABLER[3]第3位写1
	GICD->CTRL |= (0x1 << 0);
	GICD->ISENABLER[3] |= (0x1 << 3);
	//2.设置GICD层中断优先级寄存器 IPRIORITYR[24]第[31:27] = 0b00000
	GICD->IPRIORITYR[24] &= (~(0x1f << 27));
	//3.设置中断目标分配寄存器 ITARGETSR[24]第[25:24] = 0b01
	GICD->ITARGETSR[24] &= (~(0x3 << 24));
	GICD->ITARGETSR[24] |= (0x1 << 24);

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

main.c:

#include "key.h"
extern void printf(const char *fmt, ...);
void delay_ms(int ms)
{
	int i,j;
	for(i = 0; i < ms;i++)
		for (j = 0; j < 1800; j++);
}


int main()
{
	hal_exti_pf9_init();
	hal_gic_pf9_init();
	while(1)
	{

	}
	return 0;
}

do_irq:

#include "stm32mp1xx_gic.h"
#include "stm32mp1xx_exti.h"

extern void printf(const char *fmt, ...);
//中断处理函数
void do_irq(void) 
{
	unsigned int num;
	//1.获取中断号 IAR[9:0]
	num = GICC->IAR & (0x3ff);
	//2.判断中断号,并且打印一句话
	switch(num)
	{
		case 97:
			break;
		case 98:
			break;
		case 99:
			printf("key1 down!!!!\n");
		//3.清除EXTI层中断挂起标志位 FPR1[9] = 1
		EXTI->FPR1 |= (0x1 << 9);
		//4.清除GICD层中断挂起标志位 ICPENDR[3]第三位
		GICD->ICPENDR[3] |= (0x1 << 3);
			break;
	}
	//5.清除获取到中断号 EOIR
	GICC->EOIR = num;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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、付费专栏及课程。

余额充值