IO操作步骤
1)使能IO口时钟。RCC_APB2PeriphClockCmd()
2)初始化IO。GPIO_Init()
3)操作。GPIO_SetBits()设置1GPIO_ResetBits()设置0
硬件设计
板子:STM32F103ZET6精英版
原理图查找LED的IO:LED1(PE5) LED0(PB5)
观察:VCC3.3右边高电平,左边低电平LED才会亮,所以LED=0常亮
//使能PB,PE端口时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOE, ENABLE);
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出
配置外设的时候, 无论如何,都先使能外设的时钟
(详细介绍可以查别处)推挽输出:可输出高低电平,驱动功耗不大的数字器件,这里是LED灯
//位带操作
#define LED0 PBout(5)// PB5
#define LED1 PEout(5)// PE5
(开发指南库函数版本5.2.1)位带操作,就是将每个比特膨胀成32位字,访问字也就访问比特效果。
胡乱操作+随便遐想
- 一个while里面是一个功能,初始化的设置LED为0,初始化后能实现常亮
/*****************main.c********************/
int main(void)
{
delay_init(); //延时函数初始化
LED_Init(); //初始化与LED连接的硬件接口
// while(1)
// {
// LED0=0;
// LED1=1;
// delay_ms(300); //延时300ms
// LED0=1;
// LED1=0;
// delay_ms(300); //延时300ms
// }
}
/******************led.c*******************/
void LED_Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOE, ENABLE); //使能PB,PE端口时钟
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5; //LED0-->PB.5 端口配置
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //IO口速度为50MHz
GPIO_Init(GPIOB, &GPIO_InitStructure); //根据设定参数初始化GPIOB.5
GPIO_ResetBits(GPIOB,GPIO_Pin_5); //PB.5 输出高
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5; //LED1-->PE.5 端口配置, 推挽输出
GPIO_Init(GPIOE, &GPIO_InitStructure); //推挽输出 ,IO口速度为50MHz
GPIO_ResetBits(GPIOE,GPIO_Pin_5); //PE.5 输出高
}
- 改成开漏输出
没啥变化,还是可以走马灯,低灯进行控制,两者有区别,估计是没遇到
通过GPIO_ReadInputDataBit()查看端口电平状态与猜测无疑,就是输出中文老是乱码 - 使用close和open代替,0和1,毕竟有些情况下,你自己也不知道,1和0哪一个代表亮和灭,会导致粗心错误,采用枚举代替数值进行控制。
/*********led.h***********/
enum{
OPEN=0,
CLOSE=1
};
/***********main.c*************/
LED0=OPEN;
LED1=OPEN;
delay_ms(10000);
p = GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_5);
printf("B5: %d\r\n",p);
delay_ms(10000);
e = GPIO_ReadInputDataBit(GPIOE,GPIO_Pin_5);
printf("E5: %d\r\n",e);
LED1=CLOSE;
LED0=CLOSE;