2022.12.29---KEY

本文介绍了STM32微控制器中按键中断功能的实现方法,包括按键1、按键2和按键3的初始化过程及对应的中断处理函数。通过配置GPIO、EXTI等寄存器来实现外部中断,并详细展示了如何设置中断优先级、中断屏蔽等。

实现按键中断功能

//key.c
#include "key.h"

//按键1初始化
void key1_init()
{
	//使能GPIOF组控制器
	RCC->MP_AHB4ENSETR |= (0x1<<5);

	//设置GPIOF模式为输入模式
	GPIOF->MODER &= (~(0x3<<18));

	//设置中断选择寄存器
	EXTI->EXTICR3 &= (~(0xff<<8));
	EXTI->EXTICR3 |= (0x05<<8);
	//设置中断下降沿触发寄存器
	EXTI->FTSR1 |= (0x1<<9);
	//设置中断屏蔽寄存器
	EXTI->C1IMR1 |= (0x1<<9);

	//使能GICD层
	GICD->CTRL |= 0x1;
	//设置中断设置使能寄存器
	GICD->ISENABLER[3] |= (0x1<<3);
	//设置中断优先级寄存器
	GICD->IPRIORITYR[24] &= (~(0x1f<<27));
	GICD->IPRIORITYR[24] |= (0x1<<27);
	//设置中断目标分配寄存器
	GICD->ITARGETSR[24] &= (~(0x3<<24));
	GICD->ITARGETSR[24] |= (0x1<<24);

	//使能GICC层
	GICC->CTRL |= 0x1;
	//设置中断优先级屏蔽寄存器
	GICC->PMR &= (~(0x1f<<3));
	GICC->PMR |= (0x1f<<3);

}


//按键2初始化
void key2_init()
{
//	RCC->MP_AHB4ENSETR |= (0x1<<5);

	GPIOF->MODER &= (~(0x3<<14));

	EXTI->EXTICR2 &= (~(0xff<<24));
	EXTI->EXTICR2 |= (0x05<<24);
	EXTI->FTSR1 |= (0x1<<7);
	EXTI->C1IMR1 |= (0x1<<7);

	GICD->CTRL |= 0x1;
	GICD->ISENABLER[3] |= (0x1<<1);
	GICD->IPRIORITYR[24] &= (~(0x1f<<11));
	GICD->IPRIORITYR[24] |= (0x2<<11);
	GICD->ITARGETSR[24] &= (~(0x3<<8));
	GICD->ITARGETSR[24] |= (0x1<<8);

	GICC->CTRL |= 0x1;
	GICC->PMR &= (~(0x1f<<3));
	GICC->PMR |= (0x1f<<3);

}


//按键3初始化
void key3_init()
{
//	RCC->MP_AHB4ENSETR |= (0x1<<5);

	GPIOF->MODER &= (~(0x3<<16));

	EXTI->EXTICR3 &= (~(0xff));
	EXTI->EXTICR3 |= (0x05);
	EXTI->FTSR1 |= (0x1<<8);
	EXTI->C1IMR1 |= (0x1<<8);

	GICD->CTRL |= 0x1;
	GICD->ISENABLER[3] |= (0x1<<2);
	GICD->IPRIORITYR[24] &= (~(0x1f<<19));
	GICD->IPRIORITYR[24] |= (0x3<<19);
	GICD->ITARGETSR[24] &= (~(0x3<<16));
	GICD->ITARGETSR[24] |= (0x1<<16);

	GICC->CTRL |= 0x1;
	GICC->PMR &= (~(0x1f<<3));
	GICC->PMR |= (0x1f<<3);

}
//中断处理函数
#include "stm32mp1xx_gpio.h"
#include "stm32mp1xx_exti.h"
#include "stm32mp1xx_gic.h"

extern void printf(const char *fmt, ...);
unsigned int i = 0;
void do_irq(void) 
{
	int irq_num;
	//接收按下按键的中断号
	irq_num=GICC->IAR & 0x3ff;
	//判断是哪个按键按下
	switch (irq_num)
	{
	case 97:
			printf("---KEY2---\n");
			//清除中断挂起标志
			EXTI->FPR1 |= (0x1<<7);
			//清除GICD层挂起标志
			GICD->ICPENDR[3] |= (0x1<<1);
			break;
	case 98:
			printf("---KEY3---\n");
			EXTI->FPR1 |= (0x1<<8);
			GICD->ICPENDR[3] |= (0x1<<2);
			break;
	case 99:
			printf("---KEY1---\n");
			EXTI->FPR1 |= (0x1<<9);
			GICD->ICPENDR[3] |= (0x1<<3);
			break;
	default:break;
	}
	//清除中断号
	GICC->EOIR=irq_num;
}

[root@shenxjdb01-0-246 data]# ll 总用量 5310320 -rw-r----- 1 mysql mysql 56 9月 16 2021 auto.cnf -rw------- 1 mysql mysql 1676 9月 16 2021 ca-key.pem -rw-r--r-- 1 mysql mysql 1112 9月 16 2021 ca.pem -rw-r--r-- 1 mysql mysql 1112 9月 16 2021 client-cert.pem -rw------- 1 mysql mysql 1680 9月 16 2021 client-key.pem drwxr-x--- 2 mysql mysql 32 9月 16 2021 db_config drwxr-x--- 2 mysql mysql 26 4月 30 2023 db_ops -rw-r----- 1 mysql mysql 655360 8月 11 15:18 #ib_16384_0.dblwr -rw-r----- 1 mysql mysql 9043968 5月 16 15:15 #ib_16384_1.dblwr -rw-r----- 1 mysql mysql 4472 9月 16 2021 ib_buffer_pool -rw-r----- 1 mysql mysql 1073741824 8月 11 15:14 ibdata1 -rw-r----- 1 mysql mysql 2147483648 8月 11 15:18 ib_logfile0 -rw-r----- 1 mysql mysql 2147483648 8月 11 13:58 ib_logfile1 -rw-r----- 1 mysql mysql 12582912 3月 31 19:32 ibtmp1 -rw-r----- 1 mysql mysql 11368 6月 25 2023 innodb_status.2206 -rw-r----- 1 mysql mysql 60993 5月 9 2024 innodb_status.2211 -rw-r----- 1 mysql mysql 61994 9月 12 2024 innodb_status.2213 -rw-r----- 1 mysql mysql 7470 6月 10 2023 innodb_status.2214 -rw-r----- 1 mysql mysql 12108 9月 28 2024 innodb_status.2219 -rw-r----- 1 mysql mysql 11083 8月 2 2023 innodb_status.2225 -rw-r----- 1 mysql mysql 7896 8月 27 2023 innodb_status.2229 -rw-r----- 1 mysql mysql 13931 11月 28 2022 innodb_status.2232 -rw-r----- 1 mysql mysql 12401 12月 7 2022 innodb_status.2234 -rw-r----- 1 mysql mysql 18065 6月 3 2023 innodb_status.2238 -rw-r----- 1 mysql mysql 7480 6月 10 2023 innodb_status.2239 -rw-r----- 1 mysql mysql 14714 6月 14 2024 innodb_status.2242 -rw-r----- 1 mysql mysql 11883 9月 29 2024 innodb_status.2243 -rw-r----- 1 mysql mysql 7815 8月 13 2023 innodb_status.2248 -rw-r----- 1 mysql mysql 16014 3月 25 15:34 innodb_status.2256 -rw-r----- 1 mysql mysql 7883 2月 11 2024 innodb_status.2257 -rw-r----- 1 mysql mysql 10605 12月 24 2022 innodb_status.2258 -rw-r----- 1 mysql mysql 13327 6月 26 2023 innodb_status.2269 -rw-r----- 1 mysql mysql 74878 8月 11 15:18 innodb_status.2372 -rw-r----- 1 mysql mysql 42890 3月 31 18:21 innodb_status.2421 -rw-r----- 1 mysql mysql 40162 10月 30 2022 innodb_status.260539 drwxr-x--- 2 mysql mysql 187 3月 31 19:32 #innodb_temp drwxr-x--- 2 mysql mysql 143 9月 16 2021 mysql -rw-r----- 1 mysql mysql 46137344 8月 11 15:16 mysql.ibd srwxrwxrwx 1 mysql mysql 0 3月 31 19:32 mysql.sock -rw------- 1 mysql mysql 5 3月 31 19:32 mysql.sock.lock drwxr-x--- 2 mysql mysql 50 1月 9 2025 pay_center drwxr-x--- 2 mysql mysql 27 11月 25 2021 percona drwxr-x--- 2 mysql mysql 8192 9月 16 2021 performance_schema drwxr-x--- 2 mysql mysql 8192 6月 23 14:34 platform_report drwxr-x--- 2 mysql mysql 6 9月 29 2021 pos_service -rw------- 1 mysql mysql 1680 9月 16 2021 private_key.pem -rw-r--r-- 1 mysql mysql 452 9月 16 2021 public_key.pem drwxr-x--- 2 mysql mysql 24576 5月 26 18:43 pw_shenxj -rw-r--r-- 1 mysql mysql 1112 9月 16 2021 server-cert.pem -rw------- 1 mysql mysql 1680 9月 16 2021 server-key.pem -rw-r----- 1 mysql mysql 5 3月 31 19:32 shenxjdb01-0-246.pid -rw-r----- 1 mysql mysql 306 8月 11 03:54 shenxjdb01-0-246-relay-bin.000958 -rw-r----- 1 mysql mysql 409 8月 11 03:54 shenxjdb01-0-246-relay-bin.000959 -rw-r----- 1 mysql mysql 72 8月 11 03:54 shenxjdb01-0-246-relay-bin.index drwxr-x--- 2 mysql mysql 28 9月 16 2021 sys drwxr-x--- 2 mysql mysql 38 9月 16 2021 undolog drwxr-x--- 2 mysql mysql 8192 8月 5 10:29 zabbix_proxy 详细说明这个data中每个文件的作用
最新发布
08-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值