• STM32(1)跑马灯


    建立LED初始化头文件

    建立头文件有点像C++中,头文件中可以添加宏定义以及函数原型,然后在.c文件中写入函数定义

    “sys.h”

    “sys.h"这个头文件中#include “stm32f10x.h”,所以自己写的文件不需要再引用"stm32f10x.h”
    还包括了IO口操作宏定义,IO口地址映射,IO口操作以及其他
    stm32 sys文件总结

    PBout(5)

    PBout(5)就是sys文件中的宏定义内容:#define PCout(n) BIT_ADDR(GPIOC_ODR_Addr,n) //输出
    它指向了控制PBn所在的寄存器,对其进行操作。
    #define LED0 PBout(5)//LED0
    这里的LED0就是指PB5这个IO口

    led.h 代码

    #ifndef _LED_H
    #define _LED_H
    #include "sys.h"
    
    //宏定义
    #define LED0 PBout(5)//LED0
    #define LED1 PEout(5)//LED1
    //led.c
     void LED_Init(void);
     #endif
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    建立LED初始化程序

    GPIO

    每个IO口都有7个寄存器来控制:
    2个32位端口配置寄存器CRL和CRH
    2个32位的数据寄存器IDR和ODR
    1个32位的置位/复位寄存器BSRR
    1个16位的复位寄存器BRR
    1个32位的锁存寄存器LCKR
    其中,CRL和CRH控制着每个IO口的模式及输出速率

    GPIO的八种工作模式

    GPIO_Mode_AIN 模拟输入
    GPIO_Mode_IN_FLOATING 浮空输入
    GPIO_Mode_IPD 下拉输入
    GPIO_Mode_IPU 上拉输入
    GPIO_Mode_Out_OD 开漏输出
    GPIO_Mode_Out_PP 推挽输出
    GPIO_Mode_AF_OD 复用开漏输出
    GPIO_Mode_AF_PP 复用推挽输出

    1、上拉输入、下拉输入可以用来检测外部信号,例如,按键等;
    2、浮空输入模式,由于输入阻抗较大,一般把这种模式用于标准通信协议的 I2C、 USART 的接收端;
    3、普通推挽输出模式一般应用在输出电平为 0 和 3.3V 的场合。而普通开漏输出模 式一般应用在电平不匹配的场合,如需要输出 5V 的高电平,就需要在外部一个上拉电 阻,电源为 5V,把 GPIO 设置为开漏模式,当输出高阻态时,由上拉电阻和电源向外输 出 5V 电平。
    4、对于相应的复用模式(复用输出来源片上外设),则是根据 GPIO 的复用功能来 选择,如 GPIO 的引脚用作串口的输出(USART/SPI/CAN),则使用复用推挽输出模式。 如果用在 I2C、SMBUS 这些需要线与功能的复用场合,就使用复用开漏模式。
    5、在使用任何一种开漏模式时,都需要接上拉电阻。

    GPIO_InitTypeDef

    GPIO_InitTypeDef是一个结构体类型,具体定义如下

    typedef struct
    {
      uint32_t Pin;       /*!< 指定要配置的GPIO引脚。
      uint32_t Mode;      /*!< 指定选定接点的操作模式。
      uint32_t Pull;      /*!< 指定选定接点的上拉或下拉激活。
      uint32_t Speed;     /*!< 指定选定接点的速度。
    }GPIO_InitTypeDef;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    a)GPIO_pins_define 中的所有可选择的值,代表各个引脚。

    #define GPIO_PIN_0                 ((uint16_t)0x0001)  /* Pin 0 selected    */
    #define GPIO_PIN_1                 ((uint16_t)0x0002)  /* Pin 1 selected    */
    #define GPIO_PIN_2                 ((uint16_t)0x0004)  /* Pin 2 selected    */
    #define GPIO_PIN_3                 ((uint16_t)0x0008)  /* Pin 3 selected    */
    #define GPIO_PIN_4                 ((uint16_t)0x0010)  /* Pin 4 selected    */
    #define GPIO_PIN_5                 ((uint16_t)0x0020)  /* Pin 5 selected    */
    #define GPIO_PIN_6                 ((uint16_t)0x0040)  /* Pin 6 selected    */
    #define GPIO_PIN_7                 ((uint16_t)0x0080)  /* Pin 7 selected    */
    #define GPIO_PIN_8                 ((uint16_t)0x0100)  /* Pin 8 selected    */
    #define GPIO_PIN_9                 ((uint16_t)0x0200)  /* Pin 9 selected    */
    #define GPIO_PIN_10                ((uint16_t)0x0400)  /* Pin 10 selected   */
    #define GPIO_PIN_11                ((uint16_t)0x0800)  /* Pin 11 selected   */
    #define GPIO_PIN_12                ((uint16_t)0x1000)  /* Pin 12 selected   */
    #define GPIO_PIN_13                ((uint16_t)0x2000)  /* Pin 13 selected   */
    #define GPIO_PIN_14                ((uint16_t)0x4000)  /* Pin 14 selected   */
    #define GPIO_PIN_15                ((uint16_t)0x8000)  /* Pin 15 selected   */
    #define GPIO_PIN_All               ((uint16_t)0xFFFF)  /* All pins selected */ 
    #define GPIO_PIN_MASK              0x0000FFFFU /* PIN mask for assert test */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    b)GPIO_mode_define 中的所有可选择的值,代表可选的GPIO配置模式。

    #define  GPIO_MODE_INPUT                        0x00000000U   /*!< 输入浮动模式 */             
    #define  GPIO_MODE_OUTPUT_PP                    0x00000001U   /*!< 输出推拉模式 */            
    #define  GPIO_MODE_OUTPUT_OD                    0x00000011U   /*!< 输出开漏模式 */               
    #define  GPIO_MODE_AF_PP                        0x00000002U   /*!< 交替功能推拉模式 */
    #define  GPIO_MODE_AF_OD                        0x00000012U   /*!< 交替功能开漏模式 */
     
    #define  GPIO_MODE_ANALOG                       0x00000003U   /*!< 模拟模式  */
        
    #define  GPIO_MODE_IT_RISING                    0x10110000U   /*!< 带上升沿触发检测的外部中断模式 */
    #define  GPIO_MODE_IT_FALLING                   0x10210000U   /*!< 带下降沿触发检测的外部中断模式 */
    #define  GPIO_MODE_IT_RISING_FALLING            0x10310000U   /*!< 带上升/下降沿触发检测的外部中断模式 */
     
    #define  GPIO_MODE_EVT_RISING                   0x10120000U   /*!< 具有上升沿触发检测的外部事件模式 */
    #define  GPIO_MODE_EVT_FALLING                  0x10220000U   /*!< 具有下降沿触发检测的外部事件模式 */
    #define  GPIO_MODE_EVT_RISING_FALLING           0x10320000U   /*!< 具有上升/下降沿触发检测的外部事件模式 */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    c)GPIO_pull_define 中的所有可选择的值,配置激活状态。通过设置GPIO中的PUPDR寄存器的值。

    #define  GPIO_NOPULL        0x00000000U   /*!< 无上拉或下拉激活  */
    #define  GPIO_PULLUP        0x00000001U   /*!< 上拉激活         */
    #define  GPIO_PULLDOWN      0x00000002U   /*!< 下拉激活         */
    
    • 1
    • 2
    • 3

    d)GPIO_speed_define 中的所有可选择的值,配置输出最大功率。通过设置GPIO中的OSPEEDR寄存器的值。

    #define  GPIO_SPEED_FREQ_LOW         0x00000000U  /*!< IO工作频率为2 MHz,请参阅产品数据表 */
    #define  GPIO_SPEED_FREQ_MEDIUM      0x00000001U  /*!< 范围12.5 MHz至50 MHz */
    #define  GPIO_SPEED_FREQ_HIGH        0x00000002U  /*!< 范围为25兆赫至100兆赫 */
    #define  GPIO_SPEED_FREQ_VERY_HIGH   0x00000003U  /*!< 范围50兆赫至200兆赫 */
    
    • 1
    • 2
    • 3
    • 4

    嵌入式开发(学习笔记:跑马灯)GPIO_InitTypeDef+SysTick_Type

    HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_Init)

    其实就是将对应的字节输入到对应的寄存器中来配置IO口
    HAL库-STM32F4 HAL_GPIO_Init()
    stm32库函数之GPIO_Init()详细解析

    HAL_GPIO_WritePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinSate)

    通过设置ODR寄存器的值来控制IO口的输出状态。ODR是一个端口输出数据寄存器,该寄存器可读写,从该寄存器读出来的数据可以用于判断当前IO口的输出状态。而向该寄存器写数据,则可以控制某个IO口的输出电平

    HAL_GPIO_ReadPin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin)

    读取某个IO口的状态。读的是IDR寄存器,该寄存器是端口输入数据寄存器,该寄存器是只读寄存器。

    __HAL_RCC_GPIOB_CLK_ENABLE()

    在配置STM32外设时,任何时候都要先使能该外设的时钟。
    用多少功能就使能多少功能,对每个外设的时钟都设置了开关,让用户可以精确地控制,关闭不需要的设备,达到节省供电的目的。如果不用的就完全关闭,尽可能降低芯片功耗。
    使能就是打开该功能。
    STM32时钟使能及应用总结

    led.c 代码

    #include"led.h"
    void LED_Init(void)
    {
    	GPIO_InitTypeDef GPIO_Initure;//创建GPIO初始化参数结构体
    	__HAL_RCC_GPIOB_CLK_ENABLE();//开启GPIOB时钟
    	__HAL_RCC_GPIOE_CLK_ENABLE();//开启GPIOE时钟
    	
    	//PB5初始化
    	GPIO_Initure.Pin=GPIO_PIN_5;//选择引脚
    	GPIO_Initure.Mode=GPIO_MODE_OUTPUT_PP;//输出输出模式
    	GPIO_Initure.Pull=GPIO_PULLUP;//上拉下拉
    	GPIO_Initure.Speed=GPIO_SPEED_FREQ_HIGH;//输出速度
    	HAL_GPIO_Init(GPIOB,&GPIO_Initure);//初始化函数
    	
    	//PE5初始化
    	GPIO_Initure.Pin=GPIO_PIN_5;//选择引脚
    	HAL_GPIO_Init(GPIOE,&GPIO_Initure);//初始化函数
    	
    	//HAL_GPIO_WritePin(GPIO组,IO口,输出状态),PinState:高电频——GPIO_PIN_SET; 低电频——GPIO_PIN_RESET
    	HAL_GPIO_WritePin(GPIOB,GPIO_PIN_5,GPIO_PIN_SET);//PB5置1,默认初始化后灭灯
    	HAL_GPIO_WritePin(GPIOE,GPIO_PIN_5,GPIO_PIN_SET);//PE5置1,默认初始化后灭灯
    	
    	
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    main代码

    #include "sys.h"
    #include "delay.h"
    #include "usart.h"
    #include "led.h"
    int main(void)
    {
    	HAL_Init();//初始化HAL库
    	Stm32_Clock_Init(RCC_PLL_MUL9);//设置时钟,72M
    	delay_init(72);//初始化延时函数
    	LED_Init();//初始化LED
    	while(1)
    	{
    		HAL_GPIO_WritePin(GPIOB,GPIO_PIN_5,GPIO_PIN_RESET);//LED0亮
    		HAL_GPIO_WritePin(GPIOE,GPIO_PIN_5,GPIO_PIN_SET);//LED1灭
    		delay_ms(500);//延时500ms
    		HAL_GPIO_WritePin(GPIOB,GPIO_PIN_5,GPIO_PIN_RESET);//LED0灭
    		HAL_GPIO_WritePin(GPIOE,GPIO_PIN_5,GPIO_PIN_SET);//LED1亮
    		delay_ms(500);//延时500ms
    		
    	}
    	
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
  • 相关阅读:
    x210项目重新回顾之十六rootfs再讨论
    小游戏sdk对接,提高用户黏度
    oracle的join语法及行专列
    Docker 网络
    一篇长文叙述Linux内核虚拟地址空间的基本概括
    基于FPGA的图像形态学腐蚀算法实现,包括tb测试文件和MATLAB辅助验证
    苦瓜功能稻降碳90% 国稻种芯-517:何登骥水稻旱作节水80%
    2022 年牛客多校第七场补题记录
    C++ 类和对象(二)构造函数、析构函数、拷贝构造函数
    JavaScript -- 07. 面向对象编程
  • 原文地址:https://blog.csdn.net/weixin_44918105/article/details/127410167