福德正神彩票!
led
翻开客服菜单
旧事静态
以后地位: 12V福德正神彩票 > 公司静态 > 位绑定-STM32的SRAM区映射的地点
位绑定-STM32的SRAM区映射的地点
公布工夫 : 2019-09-23 12:33 阅读量 : 2

位绑定
一、观点

A是你所要操纵的位区地点的地点,减失0x2000 0000是绝对0x2000 0000的偏移字节数,乘8是由于每个字节中有8个位,加n是你所要操纵的位在A这个字节中的位偏移量,最初再乘以4是由于位带操纵区外面一个位对应4个字节。得出的便是字节A中的n位在位带区中的地点。把对存放器某一位的操纵,映射到某个内存地点(只要最低位无效)。
益处:
代码服从更高,速率更快,变动的时分不需求多读一次存放器。
可以用作位绑定的内存地区:
片内内存地区、SRAM区 :0x2000 0000 ~ 0x200F FFFF 共1M
片上外设地区   :0x4000 0000 ~ 0x400F FFFF 共1M
二、公式
SRAM区映射的地点
AliasADDr = 0x22000000 + ((A - 0x20000000) * 8 + n) * 4 = 0x22000000 + ((A - 0x20000000) * 32 + n * 4   ,  n=0~7
片上外设区映射的地点
AliasADDr = 0x42000000 + ((A - 0x20000000) * 8 + n) * 4= 0x42000000 + ((A - 0x20000000) * 32 + n * 4
三、示例:
根本盘算示例:

1569215723873890.

#include "stm32f10x_map.h" 
#define PA0  GPIOA->BRR  
#define PA1  GPIOA->BSRR  
 
#define GPIOA_ODR_A  (GPIOA_BASE+0x0c) 
#define GPIOA_IDR_A  (GPIOA_BASE+0x08) 
#define GPIOB_ODR_A  (GPIOB_BASE+0x0c) 
#define GPIOB_IDR_A  (GPIOB_BASE+0x08) 
#define GPIOC_ODR_A  (GPIOC_BASE+0x0c) 
#define GPIOC_IDR_A  (GPIOC_BASE+0x08) 
#define GPIOD_ODR_A  (GPIOD_BASE+0x0c) 
#define GPIOD_IDR_A  (GPIOD_BASE+0x08) 
#define GPIOE_ODR_A  (GPIOE_BASE+0x0c) 
#define GPIOE_IDR_A  (GPIOE_BASE+0x08) 
 
#define BitBind(Addr,BitNum)    *((volatile unsigned long *)((Addr&0xF0000000)+0x2000000+((Addr&0xfffff)<<5)+(BitNum<<2))) 
 
#define PAout(n)  BitBind(GPIOA_ODR_A,n) //某位输入 
#define PAin(n)   BitBind(GPIOA_IDR_A,n)  //某位输出 
#define PBout(n)  BitBind(GPIOB_ODR_A,n)  
#define PBin(n)   BitBind(GPIOB_IDR_A,n)  
#define PCout(n)  BitBind(GPIOC_ODR_A,n)  
#define PCin(n)   BitBind(GPIOC_IDR_A,n)   
#define PDout(n)  BitBind(GPIOD_ODR_A,n)  
#define PDin(n)   BitBind(GPIOD_IDR_A,n) 
#define PEout(n)  BitBind(GPIOE_ODR_A,n)  
#define PEin(n)   BitBind(GPIOE_IDR_A,n)  
int main() 

    u32 *PAO3 = (u32 *)(0x42000000 + (0x4001080c-0x40000000)*32 + 3*4);         //内存地点界说一个指针,PA端口输入 第3位 
    u32 *PAI11 = (u32 *)(0x42000000 + (0x40010808-0x40000000)*32 + 11*4);       //绑定PA输出 第11个端口 
 
   //设置装备摆设     PA.0-7  推挽输入 50M 
   //       PA.8-15 输出 
    GPIOA->CRL = 0x33333333;         //CNF0=00   MODE0=11 
    GPIOA->CRH = 0x44444444;     //CNF0=01   MODE0=00 //模仿CNF0=00输出时,引脚变革不会惹起IDR变革,浮空输出CNF0=01 
   //       PA.0=PA.8... 
   while(1){ 
        if((GPIOA->IDR & 0x0100)==0x0100)  PA1 = 0x01; else PA0 = 0x01;  //复杂宏方法 
        if((GPIOA->IDR & 0x0200)==0x0200)  PA1 = 0x02; else PA0 = 0x02; 
        if((GPIOA->IDR & 0x0400)==0x0400)  PA1 = 0x04; else PA0 = 0x04; 
        if(*PAI11==1)  *PAO3 = 1; else *PAO3 = 0;  //指针方法 
        if(PAin(12)==1)  PAout(4)=1; else PAout(4)=0;   //宏 位绑定 
        if(PAin(13)==1)  PAout(5)=1; else PAout(5)=0; 
        if(PAin(14)==1)  PAout(6)=1; else PAout(6)=0; 
        if(PAin(15)==1)  PAout(7)=1; else PAout(7)=0; 
  } 
   return(1); 
        }          

标签: