STM32位带

2023-12-24 14:29:39
GPIO_SetBits(GPIOF,GPIO_Pin_9);

修改为

PFout(9)=1;
GPIO_ResetBits(GPIOF,GPIO_Pin_9);

修改为

PFout(9)=0;

位带的定义:

支持了位带操作后,可以使用普通的加载/存储指令来对单一的比特进行读写。在CM3 中,有两个区中实现了位带。其中一个是SRAM区的最低 1MB 范围,第二个则是片内外设区的最低1MB 范围。这两个位带中的地址除了可以像普通的RAM 一样使用外,它们还都有自己的“位带别名区”,位带别名区把每个比特膨胀成一个32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。例如使用位带操作的目的是能够像C51那样直接给i0口置高置低,例如在51单片机中这样就可以直接给P0^1口置位和复位,代码如下:

? P0^1=1;

? P0^1=0;

? ? ?位带操作就是让stm32系列单片机能够实现这样直接对位进行操作。在stm32开发过程中如果用库函数开发不使用位带操作给某个口置位和复位操作,代码如下:

?GPIO_SetBits(GPIO_IIC,IIC_SCL_Pin);

?GPIO_ResetBits(GPIO_IIC,IIC_SDA_Pin);

? ? ?如果采用位带操就能像C51那样快速而又简单的对IO口进行置位和复位操作。代码如下:

IIC_SCL=1;

IIC_SCL=0;
?

bitband.h

#ifndef __BITBAND_H
#define __BITBAND_H

#include "stm32f10x_conf.h"


#define BIT_BAND(ADDR,BITNUM) ((ADDR & 0xF0000000) + 0x2000000 + ((ADDR & 0xFFFFF) << 5) + (BITNUM << 2))

#define MEM_ADDR(ADDR) *(volatile unsigned int *)(ADDR)


#define BITBAND(ADDR,BITNUM) MEM_ADDR(BIT_BAND(ADDR,BITNUM))

#define GPIOA_IDR_ADDR (GPIOA_BASE + 0x08)
#define GPIOA_ODR_ADDR (GPIOA_BASE + 0x0C)

#define GPIOB_IDR_ADDR (GPIOB_BASE + 0x08)
#define GPIOB_ODR_ADDR (GPIOB_BASE + 0x0C)

#define GPIOC_IDR_ADDR (GPIOC_BASE + 0x08)
#define GPIOC_ODR_ADDR (GPIOC_BASE + 0x0C)

#define GPIOD_IDR_ADDR (GPIOD_BASE + 0x08)
#define GPIOD_ODR_ADDR (GPIOD_BASE + 0x0C)

#define PAOut(n) BITBAND(GPIOA_ODR_ADDR, n)
#define PAIn(n)  BITBAND(GPIOA_IDR_ADDR, n)

#define PBOut(n) BITBAND(GPIOB_ODR_ADDR, n)
#define PBIn(n)  BITBAND(GPIOB_IDR_ADDR, n)

#define PCOut(n) BITBAND(GPIOC_ODR_ADDR, n)
#define PCIn(n)  BITBAND(GPIOC_IDR_ADDR, n)

#define PDOut(n) BITBAND(GPIOD_ODR_ADDR, n)
#define PDIn(n)  BITBAND(GPIOD_IDR_ADDR, n)

#endif

文章来源:https://blog.csdn.net/qq_63507404/article/details/135178216
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。