STM32F10x GPIO配置 之 位绑定
扫描二维码
随时随地手机看文章
对GPIO进行未绑定,好处:加快对位操作的速度。1、位绑定公式(操作不同地址区域的位,用下面不同的公式)
/**************************************************************************************************
*硬件平台:STM32F103VC
*学习重点:GPIOx的位绑定
*实现功能:对于GPIOA端口的第八位输出跟随高八位的输入
**************************************************************************************************/
/*=============================================================================
*位绑定公式:
*1、SRAM区域:0X22000000----0X200FFFFF
*Aliasaddr=0X22000000+(A-0X20000000)*32+n*4
*2、片上外设区域:0X42000000----0X400FFFFF
*Aliasaddr=0X42000000+(A-0X40000000)*32+n*4
*参数解释:
*Aliasaddr:设置“端口GPIOx的第n位”的寄存器_相应位的实际地址
*A:端口GPIOx的基地址(GPIOx_BASE)+相应寄存器的偏移地址
*n:配置的是相应寄存器的第n位
*寄存器的偏移地址:CRLCRHIDRODRBSRRBRRLCKR
*00H04H08H0CH10H14H18H
=============================================================================*/
/*Includes------------------------------------------------------------------*/
#include"stm32f10x_lib.h"//包含了所有的头文件它是唯一一个用户需要包括在自己应用中的文件,起到应用和库之间界面的作用。
#include"stm32f10x_map.h"
/*-----------------------------------------------------------------------------------------------------------
*将GPIOA的第3位作为输出引脚,寄存器ODR的偏移地址为0X0C
*A=GPIOA_BASE+0X0C=(APB2PERIPH_BASE+0X0800)+0X0C=((PERIPR_BASE+0X1000)+0X0800)+0X0C
*=((0X40000000+0X1000)+0X0800)+0X0C=0X4001080C
*n=3(设置寄存器ODR的第3位)
*将GPIOA的第11位作为输入引脚,寄存器IDR的偏移地址为0X08
*A=GPIOA_BASE+0X08=(APB2PERIPH_BASE+0X0800)+0X08=((PERIPR_BASE+0X1000)+0X0800)+0X08
*=((0X40000000+0X1000)+0X0800)+0X08=0X40010808
*n=11(设置寄存器IDR的第11位)
------------------------------------------------------------------------------------------------------------*/
u32*PAO0=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+0*4);
u32*PAO1=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+1*4);
u32*PAO2=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+2*4);
u32*PAO3=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+3*4);
u32*PAO4=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+4*4);
u32*PAO5=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+5*4);
u32*PAO6=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+6*4);
u32*PAO7=(u32*)(0X42000000+(0X4001080C-0X40000000)*32+7*4);
u32*PAI8=(u32*)(0X42000000+(0X40010808-0X40000000)*32+8*4);
u32*PAI9=(u32*)(0X42000000+(0X40010808-0X40000000)*32+9*4);
u32*PAI10=(u32*)(0X42000000+(0X40010808-0X40000000)*32+10*4);
u32*PAI11=(u32*)(0X42000000+(0X40010808-0X40000000)*32+11*4);
u32*PAI12=(u32*)(0X42000000+(0X40010808-0X40000000)*32+12*4);
u32*PAI13=(u32*)(0X42000000+(0X40010808-0X40000000)*32+13*4);
u32*PAI14=(u32*)(0X42000000+(0X40010808-0X40000000)*32+14*4);
u32*PAI15=(u32*)(0X42000000+(0X40010808-0X40000000)*32+15*4);
/*Privatefunctions-----------------------------------------------------------------------------*/
/**************************************************************************************************
*FunctionName:main
*Description:从GPIOA.8-.16输入一个电平信号,GPIOA.0-.7口分别将对应引脚输入的电平信号输出
*Input:None
*Output:None
*Return:None
****************************************************************************************************/
intmain(void)
{
/*--------控制STM32引脚GPIOA.0GPIOA.1推挽输出高电平--------*/
//1、设置GPIOA的引脚的工作模式,即配置寄存器GPIOA_CRL、GPIOA_CRH
//GPIOA.0-.7推挽输出,速度50MHZ,GPIOA.8-.16浮空输入
GPIOA->CRL=0x33333333;//CNF0=00MODE0=11
GPIOA->CRH=0x44444444;//CNF0=01MODE0=00
//2、配置寄存器GPIOA_ODR、GPIOA_IDR,实现GPIOA.0输出跟随GPIOA.8的输入
while(1)
{
/*----------------------第0位----------------------*/
if(*PAI8==1)//寄存器GPIOA->IDR的第8位为1,表示从在GPIOA.8口输入了高电平
{
*PAO0=1;//对寄存器GPIOA->ODR的第0位置一
}
else
{
*PAO0=0;//对寄存器GPIOA->ODR的第0位清零
}
/*----------------------第1位----------------------*/
if(*PAI9==1)//寄存器GPIOA->IDR的第9位为1,表示从在GPIOA.9口输入了高电平
{
*PAO1 = 1 ; //对寄存器GPIOA->ODR的第1位置一