stm32f10x.h文件用于添加寄存器地址及结构体定义,这里就不放进来了,对片上外设基地址,GPIOB的外设基地址,做了定义。然后GPIOB寄存器地址,强制转换成指针,方便下面使用。
/*
*工程模板(寄存器版本)
*/
#include "stm32f10x.h"
/**
* 主函数
*/
int main(void)
{
// 开启GPIOB 端口时钟,
//RCC_APB2ENR寄存器显示第三位,为GPIOB的时钟使能,1位IO端口B时钟开启,所以该位置1!
RCC_APB2ENR |= (1<<3);
//清空控制PB0的端口位
//0x0000 1111 左移4个0位,等于没有移动。0x0F,四个1,就是给CRL后4位清0!
//这里有一个问题,为什么控制PB0端口,是需要操作CRL寄存器,还没看到联系点???!!!从电路图也没有看到相关的联系呢??
//答:CRL控制着端口的低8位IO, 32位,4bit分成一组,后4bit控制一个IO,共计8个IO可以控制。CRH控制着端口的高8位IO,这样总共可以控制16个IO。
GPIO总共分为A B C D E五组,每组就是16个端口,共计80个端口!!!所以 GPIOB_CRL 可控制B区域管辖的16个端口.
GPIOB_CRL &= ~( 0x0F<< (4*0));
// 配置PB0为通用推挽输出,速度为10M------这句话决定了CRL最后4位为 00 01.
//CRL最后一位置1.0001 左移4个0位。
GPIOB_CRL |= (1<<4*0);
// PB0 输出 低电平
//0000 0001 左移0位,表示ODR最后一位置0.
GPIOB_ODR &= ~(1<<0);
while(1);
}
// 函数为空,目的是为了骗过编译器不报错
void SystemInit(void)
{
}
/*********************************************END OF FILE**********************/