keil软件的安装与环境配置及编译一个简单的stm32程序


一、keil软件安装及环境配置?

1、软件包下载

  • MDK_531网盘分享

链接:https://pan.baidu.com/s/1v_vewYs851_FT-ndZWAldA
提取码:swsj

2、安装过程

  • 下载软件包进行解压后,点击exe文件进行安装
    在这里插入图片描述
  • 点击next继续

在这里插入图片描述

  • agree然后next
    在这里插入图片描述

  • 切换软件路径与支持包路径
    在这里插入图片描述

  • 随意填写Name和e-mail然后next
    在这里插入图片描述

  • 点击安装
    在这里插入图片描述

  • 等待加载

  • 在这里插入图片描述

  • 点击finish完成安装
    在这里插入图片描述

他会打开keil,关掉即可。

3、支持包安装

点击pack文件进行
在这里插入图片描述
一路next即可。

4、注册

  • 以管理员身份运行keil,点击File,找到License Management并点击。
    在这里插入图片描述
  • 在安装包中,找到kegen_new2032,打开该文件夹,点击运行keygen_new2032.exe。
    在这里插入图片描述

复制keil中的CID粘贴到keygen_new2032.exe中,target选arm,点击Generate会生成一个注册码。复制注册码到New License IDCode(LIC)中,点击右方的add,并close。

这样整个安装流程就结束了。

二、LED程序

1.新建一个工程

  • 点击project进行创建一个工程

在这里插入图片描述

填写工程名并保存,然后在Search中搜索STM32F103RB

  • 勾选下面的选项,点击ok,创建完毕。
    在这里插入图片描述

2.新建.C文件

在这里插入图片描述

  • 代码
//宏定义,用于存放stm32寄存器映射
#define PERIPH_BASE           ((unsigned int)0x40000000)//AHB
#define APB2PERIPH_BASE       (PERIPH_BASE + 0x10000)
#define GPIOA_BASE            (APB2PERIPH_BASE + 0x0800)
//GPIOA_BASE=0x40000000+0x10000+0x0800=0x40010800,该地址为GPIOA的基地址
#define GPIOB_BASE            (APB2PERIPH_BASE + 0x0C00)
//GPIOB_BASE=0x40000000+0x10000+0x0C00=0x40010C00,该地址为GPIOB的基地址
#define GPIOC_BASE            (APB2PERIPH_BASE + 0x1000)
//GPIOC_BASE=0x40000000+0x10000+0x1000=0x40011000,该地址为GPIOC的基地址
#define GPIOD_BASE            (APB2PERIPH_BASE + 0x1400)
//GPIOD_BASE=0x40000000+0x10000+0x1400=0x40011400,该地址为GPIOD的基地址
#define GPIOE_BASE            (APB2PERIPH_BASE + 0x1800)
//GPIOE_BASE=0x40000000+0x10000+0x0800=0x40011800,该地址为GPIOE的基地址
#define GPIOF_BASE            (APB2PERIPH_BASE + 0x1C00)
//GPIOF_BASE=0x40000000+0x10000+0x0800=0x40011C00,该地址为GPIOF的基地址
#define GPIOG_BASE            (APB2PERIPH_BASE + 0x2000)
//GPIOG_BASE=0x40000000+0x10000+0x0800=0x40012000,该地址为GPIOG的基地址
#define GPIOA_ODR_Addr    (GPIOA_BASE+12) //0x4001080C
#define GPIOB_ODR_Addr    (GPIOB_BASE+12) //0x40010C0C
#define GPIOC_ODR_Addr    (GPIOC_BASE+12) //0x4001100C
#define GPIOD_ODR_Addr    (GPIOD_BASE+12) //0x4001140C
#define GPIOE_ODR_Addr    (GPIOE_BASE+12) //0x4001180C
#define GPIOF_ODR_Addr    (GPIOF_BASE+12) //0x40011A0C   
#define GPIOG_ODR_Addr    (GPIOG_BASE+12) //0x40011E0C 
 
#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
#define MEM_ADDR(addr)  *((volatile unsigned long  *)(addr))
 
 #define LED0  MEM_ADDR(BITBAND(GPIOA_ODR_Addr,8))
//#define LED0 *((volatile unsigned long *)(0x422101a0)) //PA8
//定义typedef类型别名
typedef  struct
{
   volatile  unsigned  int  CR;
   volatile  unsigned  int  CFGR;
   volatile  unsigned  int  CIR;
   volatile  unsigned  int  APB2RSTR;
   volatile  unsigned  int  APB1RSTR;
   volatile  unsigned  int  AHBENR;
   volatile  unsigned  int  APB2ENR;
   volatile  unsigned  int  APB1ENR;
   volatile  unsigned  int  BDCR;
   volatile  unsigned  int  CSR;
} RCC_TypeDef;
 
#define RCC ((RCC_TypeDef *)0x40021000)
//定义typedef类型别名
typedef  struct
{
volatile  unsigned  int  CRL;
volatile  unsigned  int  CRH;
volatile  unsigned  int  IDR;
volatile  unsigned  int  ODR;
volatile  unsigned  int  BSRR;
volatile  unsigned  int  BRR;
volatile  unsigned  int  LCKR;
} GPIO_TypeDef;
//GPIOA指向地址GPIOA_BASE,GPIOA_BASE地址存放的数据类型为GPIO_TypeDef
#define GPIOA ((GPIO_TypeDef *)GPIOA_BASE)
 
void  LEDInit( void )
{
     RCC->APB2ENR|=1<<2;  //GPIOA 时钟开启
     GPIOA->CRH&=0XFFFFFFF0;
     GPIOA->CRH|=0X00000003; 
}
 
//粗略延时
void  Delay_ms( volatile  unsigned  int  t)
{
     unsigned  int  i,n;
     for (n=0;n<t;n++)
         for (i=0;i<800;i++);
}

int main(void)
{
	 LEDInit();
     while (1)
     {
         LED0=0;//LED熄灭
         Delay_ms(500);//延时时间
         LED0=1;//LED亮
         Delay_ms(500);//延时时间
     }
}

  • 点击保存,命名为main.c.在这里插入图片描述

  • 在工程里添加main.c文件,右击Source Group 1,点击下面选项:
    在这里插入图片描述

  • 选中main.c文件
    在这里插入图片描述

3.编译程序

编译之前先点击魔法棒,选中Output,勾选Create HEX File
则会生成一个hex文件供后面分析

  • 点击编译

在这里插入图片描述
在这里插入图片描述

4.调试程序

  • 点击魔法棒,选中Debug,勾选并设置下面选项。
    在这里插入图片描述

  • 然后在弹出的窗口中,确定Ports1JTAG,Reset可以为Autodetect或SYSRESEETREQ。
    在这里插入图片描述

  • 点击放大镜进行调试
    在这里插入图片描述

三、分析hex文件

打开工程目录的object下的hex文件
在这里插入图片描述

  • 概念

HEX文件格式是一种能够烧写到单片机中,被单片机执行的文件格式。

在这里插入图片描述
在这里插入图片描述

  • 举例分析一下
  • 1

:020000040800F2
冒号表示数据开始,然后02表示数据长度,接着2个字节0000表示起始基地址,04,表示开始扩展线性地址记录(下面的一长串的就是他的扩展),然后0800就是前面02表示的数据,最后还有一个字节校验码。

  • 2

:10000000600600206D0100087501000877010008F6
10表示有十个数据,0000和上面的0000就构成了第一条数据的地址00000000,接着一个字节的00,表示数据类型为数据记录,接着就是10个字节的数据,600600206D0100087501000877010008(这里感觉不止10个字节),完蛋,理解错了?希望有大佬能在评论区指点一下。

四、总结

没有硬件的接入,我们只能说是走一遍流程,学会使用MDK从建立一个工程到写代码、编译程序、调试等。

五、参考资料

https://blog.csdn.net/ssj925319/article/details/108919862
https://blog.csdn.net/qq_43279579/article/details/108880667?utm_source=app

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

混子王江江

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值