#ifndef __KEY_H__
#define __KEY_H__
#include "stm32mp1xx_rcc.h"
#include "stm32mp1xx_gpio.h"
#include "stm32mp1xx_exti.h"
#include "stm32mp1xx_gic.h"
void hal_pf9_exti();
void hal_pf9_gicd();
void hal_pf9_gicc();
#endif
#include "key.h"
void hal_pf9_exti()
{
RCC->MP_AHB4ENSETR |= (0x1 << 5);
GPIOF->MODER &= (~(0x3 << 18));
GPIOF->MODER &= (~(0x3 << 14));
GPIOF->MODER &= (~(0x3 << 16));
EXTI->EXTICR3 &= (~(0xff << 8));
EXTI->EXTICR3 |= (0x05 << 8);
EXTI->EXTICR2 &= (~(0xff << 24));
EXTI->EXTICR2 |= (0x05 << 24);
EXTI->EXTICR3 &= (~(0xff << 0));
EXTI->EXTICR3 |= (0x05 << 0);
EXTI->FTSR1 |= (0x1 << 9);
EXTI->FTSR1 |= (0x1 << 7);
EXTI->FTSR1 |= (0x1 << 8);
EXTI->C1IMR1 |= (0x1 << 9);
EXTI->C1IMR1 |= (0x1 << 7);
EXTI->C1IMR1 |= (0x1 << 8);
}
void hal_pf9_gicd()
{
GICD->CTRL |= (0x1 << 0);
GICD->ISENABLER[3] |= (0x1 << 3);
GICD->ISENABLER[3] |= (0x1 << 1);
GICD->ISENABLER[3] |= (0x1 << 2);
GICD->IPRIORITYR[24] &= (~(0x1f << 27));
GICD->IPRIORITYR[24] &= (~(0x15 << 11));
GICD->IPRIORITYR[24] &= (~(0x1f << 19));
GICD->ITARGETSR[24] &= (~(0x3) << 24);
GICD->ITARGETSR[24] |= (0b11 << 24);
GICD->ITARGETSR[24] &= (~(0x3) << 8);
GICD->ITARGETSR[24] |= (0b11 << 8);
GICD->ITARGETSR[24] &= (~(0x3) << 16);
GICD->ITARGETSR[24] |= (0b11 << 16);
}
void hal_pf9_gicc()
{
GICC->CTRL |= 0x1;
GICC->PMR |= (0x1f << 3);
}
#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_pf9_exti();
hal_pf9_gicd();
hal_pf9_gicc();
while(1)
{
}
return 0;
}
#include "stm32mp1xx_gic.h"
#include "stm32mp1xx_exti.h"
extern void printf(const char *fmt, ...);
unsigned int num = 0;
void do_irq(void)
{
num = GICC->IAR & 0x3ff;
if(num == 99)
{
printf("this is key1!!!!!!!!!!\n");
EXTI->FPR1 |= (0x1 << 9 );
GICD->ICPENDR[3] |= (0x1 << 3);
}
else if(num == 97)
{
printf("this is key2!!!!!!!!!!\n");
EXTI->FPR1 |= (0x1 << 7 );
GICD->ICPENDR[3] |= (0x1 << 1);
}
else if(num == 98)
{
printf("this is key3!!!!!!!!!!\n");
EXTI->FPR1 |= (0x1 << 8 );
GICD->ICPENDR[3] |= (0x1 << 2);
}
GICC->EOIR &= (~(0x3ff));
GICC->EOIR |= num;
}