TSM320F2812存储器分配图

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是基于 TMS320F28379D 单片机的库函数外部中断实现按键消抖的程序: ```c #include "F2837xD_Device.h" #include "F2837xD_Examples.h" #define DEBOUNCE_TIME 1000 // 消抖时间,单位:us void main(void) { InitSysCtrl(); // 初始化系统时钟 InitGpio(); // 初始化 GPIO EALLOW; GpioCtrlRegs.GPBPUD.bit.GPIO32 = 0; // 使能 GPIO32 引脚上的上拉电阻 GpioCtrlRegs.GPBDIR.bit.GPIO32 = 0; // 将 GPIO32 引脚设置为输入模式 GpioIntRegs.GPIOXINT1SEL.bit.GPIOSEL = 32; // 将 GPIO32 引脚与 XINT1 中断线连接 XBARARegs.XINT1MUX1TO16CFG.bit.MUX13 = 0; // 将 XINT1 中断线设置为 GPIO32 引脚 PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // 使能 PIE 模块 PieVectTable.XINT1_INT = &Xint1_ISR; // 将 XINT1_ISR 函数作为 XINT1 中断的服务函数 IER |= M_INT1; // 使能 INT1 中断 EINT; // 使能全局中断 EDIS; while(1) {} } __interrupt void Xint1_ISR(void) { static Uint32 last_time = 0; Uint32 current_time = CpuTimer0Regs.TIM.all; if ((current_time - last_time) > DEBOUNCE_TIME) { GpioDataRegs.GPBTOGGLE.bit.GPIO34 = 1; // 反转 GPIO34 引脚输出状态 } last_time = current_time; PieCtrlRegs.PIEACK.all = PIEACK_GROUP1; // 确认 INT1 中断 } ``` 程序的实现思路如下: 首先,初始化系统时钟和 GPIO;然后,使能 GPIO32 引脚上的上拉电阻,并将 GPIO32 引脚与 XINT1 中断线连接;接着,将 XINT1 中断线设置为 GPIO32 引脚,并将 XINT1_ISR 函数作为 XINT1 中断的服务函数;最后,在 XINT1 中断服务函数中添加按键消抖处理,并且反转 GPIO34 引脚输出状态。 需要注意的是,这个程序中使用了 CPU 定时器 0 来进行时间计数,需要提前进行 CPU 定时器的初始化。另外,该程序使用了 PIE 模块来实现中断控制,需要在程序中使能 PIE 模块,并且在中断服务函数的最后,使用 `PieCtrlRegs.PIEACK.all = PIEACK_GROUP1;` 命令来确认 INT1 中断。 希望这个程序能够帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值