//GPIOA8是 LED0
//GPIOA13是 KEY0 仅包含启动代码 STM32F10x.s
#define GPIOA_CRL (*(volatile unsigned long *)(0x40000000+0x10000+0x0800+0x00))
#define GPIOA_CRH (*(volatile unsigned long *)(0x40000000+0x10000+0x0800+0x04))
#define GPIOA_IDR (*(volatile unsigned long *)(0x40000000+0x10000+0x0800+0x08))
#define GPIOA_ODR (*(volatile unsigned long *)(0x40000000+0x10000+0x0800+0x0C))
#define RCC_APB2ENR (*(volatile unsigned long *)(0x40000000+0x20000+0x1000+0x18))
void delay(unsigned long i) //超级不精确的软延时
{
int j;
while(i--)
{
for(j=0;j<1500;j++)
{}
}
}
int main(void)
{
u8 keyflag=1; //按键进入标志,防止一次按键多次判断的简易做法
RCC_APB2ENR= 1<<2; //打开PA时钟,默认启用内部8M时钟
GPIOA_CRH &= 0XFFFFFFF0; //准备配置PA8 ,PA8是LED0
GPIOA_CRH |= 0X00000003; //PA8 推挽输出
GPIOA_ODR |= 1<<8; //PA8 输出高,即先关闭led
GPIOA_CRH &= 0XFF0FFFFF; //准备配置PA13 ,PA13是KEY0
GPIOA_CRH |= 0X00800000; //配置PA13为带上拉下拉输入
while(1)
{
if(!checkBit(GPIOA_IDR,13)) //键被按下的话,执行led反转
{
if(keyflag)
{
keyflag=0;
GPIOA_ODR = revBit(GPIOA_ODR,8); //第8位反转,revBit是宏
}
}
else
{
keyflag=1;
}
delay(10); //简易消抖
}
}
//checkBit 和revBit都是关于位的宏
//#define BIT(n) (1<<(n))
//#define revBit(val,n) ((val)^(BIT(n)))
//#define checkBit(val,n) (((val)&(BIT(n)))>>(n))
上一篇:stm32笔记:解决mdk编辑代码时的各种乱码问题
下一篇:stm32笔记: 将用户自定义关键字从MDK3.8 搬到 MDK4.70A
推荐阅读最新更新时间:2024-03-16 15:33
设计资源 培训 开发板 精华推荐
- 帮助他人,成就自己:EEWORLD月度问答榜(第6期)
- 是德科技有奖直播:湾区圆桌派-穿越频谱壁垒:毫米波技术的创新之路
- 看视频赢京东卡 | 泰享实测之水哥秘籍
- 现场抽取PS5等诸多好礼 SiFive RISC-V 中国技术论坛 上海、北京、深圳 3场线下活动邀您出席!
- 免费测评| TDK-Lambda 电源降压模块
- 看视频赢京东卡 PI汽车专用解决方案学习中心正式上线
- 创意改装大比拼:给你一个升压板和净化器,你能改装成啥?
- DIY FPGA初级学习板
- Digi-Key KOL视频来袭~欢迎进入MicroPython的奇妙世界
- 有奖直播:TI MSP430TM集成可配置信号链模块在传感测量领域的应用