ARM按键中断控制事件

这篇具有很好参考价值的文章主要介绍了ARM按键中断控制事件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

设置按键中断,按键1按下,LED亮,再按一次,灭按键2按下,蜂鸣器响。再按一次,不响按键3按下,风扇转,再按一次,风扇停

src/key_it.c

#include"key_it.h"
//GPIO初始化
void all_led_init()
{
    //RCC使能
    RCC->MP_AHB4ENSETR  |= (0X1<<4);
    //设置PE10 PF10 PE8为输出
    GPIOE->MODER &= (~(0X3<<20));
    GPIOE->MODER |= (0X1<<20);
    //设置推挽输出
    GPIOE->OTYPER &= (~(0X1<<10)); 
    //设置三个管脚低速输出
    GPIOE->OSPEEDR &= (~(0X3<<20));
    //设置三个管脚输出时无上拉电阻和下拉电阻    
    GPIOE->PUPDR &= (~(0X3<<20));
}
void all_spi_init()
{
    //RCC使能
    RCC->MP_AHB4ENSETR  |= (0X3<<1);
    //设置PE10 PF10 PE8为输出
    GPIOB->MODER &= (~(0X3<<12));
    GPIOB->MODER |= (0X1<<12);
    //设置推挽输出
    GPIOB->OTYPER &= (~(0X1<<6)); 
    //设置三个管脚低速输出
    GPIOB->OSPEEDR &= (~(0X3<<12));
    //设置三个管脚输出时无上拉电阻和下拉电阻    
    GPIOB->PUPDR &= (~(0X3<<12));
}
void all_fan_init()
{
    //RCC使能
    RCC->MP_AHB4ENSETR  |= (0X3<<4);
    //设置PE10 PF10 PE8为输出
    GPIOE->MODER &= (~(0X3<<18));
    GPIOE->MODER |= (0X1<<18);
    //设置推挽输出
    GPIOE->OTYPER &= (~(0X1<<9)); 
    //设置三个管脚低速输出
    GPIOE->OSPEEDR &= (~(0X3<<18));
    //设置三个管脚输出时无上拉电阻和下拉电阻    
    GPIOE->PUPDR &= (~(0X3<<18));
}
//按键2的配置
void key2_it_config()
{
    //RCC使能GPIOF时钟
    RCC->MP_AHB4ENSETR |= (0x1<<5);
    //pf7
    GPIOF->MODER &= (~(0x3<<14));
    //pf7
    EXTI->EXTICR2 &=(~(0xFF<<24));
    EXTI->EXTICR2 |= (0x5<<24);
    //pf7
    EXTI->FTSR1 |= (0x1<<7);
    //PF7
    EXTI->C1IMR1 |= (0x1<<7);
    //PF7 97号中断
    GICD->ISENABLER[3] |= (0X1<<1); 
    //PF7
    GICD->IPRIORITYR[24] &= (~(0X1F<<11)); 
    //pf7 97中断
    GICD->ITARGETSR[24]  &= (~(0X3<<8));
    GICD->ITARGETSR[24] |= (0X1<<8);
}
//按键1 按键3以及GICC层的配置
void key_it_config()
{
    //RCC使能GPIOF时钟
    RCC->MP_AHB4ENSETR |= (0x1<<5);
    //设置PF9 PF7 PF8GPIO输入
    //PF9
    GPIOF->MODER &= (~(0x3<<18));
    //PF8
    GPIOF->MODER &= (~(0x3<<16));
    //设置PF9 PF7 PF8产生EXTI事件 EXTI_EXTICRx
    //pf8
    EXTI->EXTICR3 &=(~(0xFF<<0));
    EXTI->EXTICR3 |= (0x5<<0);
    //pf9
    EXTI->EXTICR3 &=(~(0xFF<<8));
    EXTI->EXTICR3 |= (0x5<<8);
    //设置事件触发方式为下降沿触发EXTI_FTSR1
    //pf8
    EXTI->FTSR1 |= (0x1<<8);
    //pf9
    EXTI->FTSR1 |= (0x1<<9);
    //设置EXTI事件触发不屏蔽EXTI_IMR1
    //PF8
    EXTI->C1IMR1 |= (0x1<<8);
    //PF9
    EXTI->C1IMR1 |= (0x1<<9);
    //使能中断能转发到特定的CPU接口层GICD_ISENABLERx
    //PF8 98号中断
    GICD->ISENABLER[3] |= (0X1<<2); 
    //PF9 99号中断
    GICD->ISENABLER[3] |= (0X1<<3); 
    //GICD_ISENABLERx设置中断优先级
    //PF8
    GICD->IPRIORITYR[24] &= (~(0X1F<<19)); 
    //PF9
    GICD->IPRIORITYR[24] &= (~(0X1F<<27)); 
    //设置当前中断被转发到哪一个CPU处理GICD_ITARGETSRx
    //pf8 98中断
    GICD->ITARGETSR[24]  &= (~(0X3<<16));
    GICD->ITARGETSR[24] |= (0X1<<16);
    //pf9 99中断
    GICD->ITARGETSR[24]  &= (~(0X3<<24));
    GICD->ITARGETSR[24] |= (0X1<<24);
    //使能组0转发中断GICD_CTLR
    GICD->CTRL |= 0X1;
    //设置中断优先级掩码GICC_PMR
    GICC->PMR |= (0x1F<<3);
 
    //使能CPU可以处理组0转发的中断GICC_CTLR
    GICC->CTRL |= 0X1;
 
    
}
     

src/do_irq.c

    #include "key_it.h"
    extern void printf(const char *fmt, ...);
    unsigned int i = 0;
    void do_irq(void) 
    {
        static int flag=0;
        static int flag1=0;
        static int flag2=0;
        int irqno;//保存中断号
            irqno=GICC->IAR & 0X3FF;
            switch(irqno)
            {
                case 99://key1
                    //按键1中断处理
                    //printf("KEY1 INT\n");
                        if(0==flag)
                        {
                            //LED1亮
                           GPIOE->ODR |= (0X1<<10);
                            flag=1;
                        }
                        else if(1==flag)
                        {
                            //LED1灭
                             GPIOE->ODR &= (~(0X1<<10));
                            flag=0;
                        }
            //清除挂起中断标志位GICD_ICPENDRx
                GICD->ICPENDR[3] |= (0x1<<3);
            //清除中断触发标志位EXTI_FPR1
                EXTI->FPR1 |= (0x1<<9);
                break;
            case 97://key2
                //按键2中断处理
                //printf("KEY2 INT\n");
                        if(0==flag1)
                        {
                            //蜂鸣器响
                           GPIOB->ODR |= (0X1<<6);
                            flag1=1;
                        }
                        else if(1==flag1)
                        {
                            //蜂鸣器不响
                             GPIOB->ODR &= (~(0X1<<6));
                            flag1=0;
                        }
        //清除挂起中断标志位GICD_ICPENDRx
        GICD->ICPENDR[3] |= (0x1<<1);
        //清除中断触发标志位EXTI_FPR1
        EXTI->FPR1 |= (0x1<<7);
                break;
            case 98://key3
                //按键3中断处理
               // printf("KEY3 INT\n");
                        if(0==flag2)
                        {
                            //风扇转
                           GPIOE->ODR |= (0X1<<9);
                            flag2=1;
                        }
                        else if(1==flag2)
                        {
                            //风扇停
                             GPIOE->ODR &= (~(0X1<<9));
                            flag2=0;
                        }
        //清除挂起中断标志位GICD_ICPENDRx
        GICD->ICPENDR[3] |= (0x1<<2);
        //清除中断触发标志位EXTI_FPR1
        EXTI->FPR1 |= (0x1<<8);
                break;
        }
        //清除处理完的中断号GICC_EOIR
        GICC->EOIR =irqno;
    }
 

include/key_it.h

#ifndef __KEY_IT_H__
#define __KEY_IT_H__
#include "stm32mp1xx_rcc.h"
#include "stm32mp1xx_gpio.h"
#include "stm32mp1xx_exti.h"
#include "stm32mp1xx_gic.h"
 
void key_it_config();
void key2_it_config();
void all_led_init();
void all_spi_init();
void all_fan_init();
 
#endif

main.c文章来源地址https://www.toymoban.com/news/detail-715353.html

#include "uart.h"
 
#include "key_it.h"
 
 
 
int main()
 
{
 
 
    uart4_init();//串口初始化
 
    all_led_init();
 
    //中断初始化
 
    key_it_config();
 
	key2_it_config();
 
    all_spi_init();
 
    all_fan_init();
 
    while(1)
 
    {
 
        //保证主程序不结束
 
    }  
 
	return 0;
 
 
}
 

到了这里,关于ARM按键中断控制事件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 探索嵌入式开发领域:单片机、ARM、Android底层的紧密联系

    作为一个曾编写ARM教程和参与Android产品开发的专家,我发现单片机、ARM、嵌入式开发和Android底层开发之间存在紧密的联系。对于那些希望在嵌入式开发领域发展的人来说,了解这些领域的知识至关重要。为了帮助你更好地学习这些内容,我总结了一些嵌入式资料,你可以在

    2024年02月11日
    浏览(46)
  • ARM_day7:按键中断

    实现三个按键中断,按键按下时,LED灯亮  mykey.h mykey.c main.c do_irq.c  

    2024年04月22日
    浏览(32)
  • ARM实验6-基于中断的按键处理程序实验

    一、实验名称:基于中断的按键处理程序实验 二、实验目的:         1.掌握ARM处理器的中断处理过程。         2.掌握ARM处理器中断服务程序的编写方法。         3.通过该编程实验,进一步巩固和强化学生ARM汇编编程的能,ARM应用程序框架,培养学生实际应用的

    2024年02月08日
    浏览(43)
  • 51单片机定时器中断按键消抖(无延时)

    单片机入门学习记录(二) 在机械按键的触点闭合和断开时,都会产生抖动,为了保证系统能正确识别按键的开关,就必须对按键的抖动进行处理。按键的抖动对于人类来说是感觉不到的,但对单片机来说,则是完全可以感应到的,而且还是一个很“漫长”的过程,因为单片

    2024年02月14日
    浏览(58)
  • 基于51单片机利用中断实现100以内的按键计数(Proteus仿真)

    https://mp.weixin.qq.com/s?__biz=Mzg4Mzc3NDUxOQ==mid=2247484090idx=3sn=ed67cb438e25cc13b32ac6c48ccebecbchksm=cf4307e2f8348ef424109aacc5bb64a6f20d53581d57f15377ec67383e01a69e7a0292b500f6token=3445295lang=zh_CN#rd https://mp.weixin.qq.com/s?__biz=Mzg4Mzc3NDUxOQ==mid=2247484090idx=3sn=ed67cb438e25cc13b32ac6c48ccebecbchksm=cf4307e2f8348ef424109aacc5bb64a6f20d535

    2024年02月04日
    浏览(40)
  • ARM按键控制灯光

    uartt.c main.c uartt.h

    2024年02月04日
    浏览(35)
  • 嵌入式学习---ARM中断控制系统

    硬件中断处理是实时系统设计的最重要、最关键的问题。 程序不断地查询各设备的状态,并做出相应的反应。该方式实现比较简单,常用在比较单一的系统中,比如一个温控系统中可以使用查询方式不断检测温度的变化。 特点:实现简单;但 CPU利用率很低 ,不适合多任务的

    2024年02月03日
    浏览(73)
  • 五、51单片机控制矩阵按键

    1.1、矩阵按键原理分析 这里矩阵按键为4*4的矩阵按键。 (1)矩阵按键横向和纵向分割。 (2)按键两端分别接不同的IO引脚。 (3)按键物理作用不变:按下按键两端接通,弹起按键两端断开。 1.2、矩阵按键的工作过程 JP4接P3端口,JP4_8接P3^7...JP4_1接P3^0。 (1)IO端口(P3)先输出0x0f,按键列

    2023年04月20日
    浏览(60)
  • 四、51单片机控制独立按键

    按键相关知识。 1.1、按键工作原理 (1)按键内部是机械结构,也就是内部是没有电路的。按键对外表现位四个引脚,但本质上只是两个,引脚是两两连在一起的。按键按下内部引脚导通,松开内部断开。 (2)电路连接与原理图中图标。 按键一端接地,一端接单片机IO口。  (3)按

    2023年04月14日
    浏览(59)
  • 51单片机-按键控制led灯

    1.开发环境介绍 使用C语言,环境为keil Keil C51是美国Keil Software公司出品的51系列兼容单片机C语言软件开发系统,与汇编相比,C语言在功能上、结构性、可读性、可维护性上有明显的优势,因而易学易用. 什么是单片机 单片机(Single-Chip Microcomputer)是一种集成电路芯片,把具

    2024年02月09日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包