MDK5安装以及stm32简单程序编译

本文介绍了在Win10系统中如何安装MDK5,包括MDK5的简介、下载、安装、注册过程,以及如何安装STM32 pack支持包。此外,还详细讲解了STM32简单程序的编译步骤,包括创建新项目、设置芯片、编写代码和调试程序。

Win10系统下MDK5安装以及stm32pack软件简单程序的编译

一、MDK5的安装。

1、MDK5简介。

MDK 是 Microcontroller Development Kit 的缩写,ARM 公司出品,是目前针对 ARM 处理器,尤其是 Cortex-M 内核处理器的最佳开发工具。MDK5 向后兼容 MDK4 和 MDK3 等,以前的项目同样可以在 MDK5 上进行开发(但是头文件方面得全部自己添加),MDK5 同时加强了针对 Cortex-M 微控制器开发的支持,并且对传统的开发模式和界面进行升级,MDK5 由两个部分组成:MDK Tools 和 Software Packs。

2、MDK5下载。

MDK5 是目前应用比较广泛的工具软件之一,可到 KEIL 的官网网址:
https://www.keil.com/download/product/下载最新版本。其它版本可参考安装。

3、MDK5安装。

3.1 右键点击安装包mdk_510.exe,如下图所示。

在这里插入图片描述

3.2出现安装向导界面,点击“Next”。

在这里插入图片描述

3.3勾选“I agree to …”,点击“Next”。

在这里插入图片描述

3.4选择mdk5软件和支持包路径,也可以保持默认,再点击“Next”。

在这里插入图片描述

3.5填写各种注册信息,之后点击“Next”。

在这里插入图片描述

3.6安装过程需要稍微等几分钟。

在这里插入图片描述

3.7等待安装时间完成之后弹出以下界面,点击“安装”。

在这里插入图片描述

3.8安装完成,之后点击“Finish”。

在这里插入图片描述

3.9完成之后,会弹出自动更新“支持包”,可以直接退出,自己下载安装包进行安装。

在这里插入图片描述

4.安装stm32 pack支持包,依次双击下图pack后缀图标

在这里插入图片描述
但当双击至第三个图标时会出现报错
在这里插入图片描述
不过报错可以不用管,因为对于初学者来说不太必要。

5.进行MDK-5.10注册。

5.1解压缩下图中的压缩包“keygen”

在这里插入图片描述

5.2解压缩完成之后出现以下图标。打开图标。

在这里插入图片描述

5.3出现以下画面

在这里插入图片描述

5.4此时获得CID码需要进行以下步骤

1)打开桌面keil图标,需要以管理员的身份运行
在这里插入图片描述
2)点击左上角file,打开 License Management…
在这里插入图片描述
3)将出现的界面中CID码进行复制
在这里插入图片描述
4)将复制的CID码粘贴至下图CID框中。将Target框中选择ARM。然后点击Generate,将以上出现的字符复制。在这里插入图片描述
5)将复制的字符粘贴至下图,点击Add LIC。在这里插入图片描述
至此注册完成。

二、stm32pack软件简单程序的编译。

1.建立一个新的文件。

1.1打开keil软件,点击project中的New uVision Project,创建一个新的项目。

在这里插入图片描述

1.2选择要使用的芯片。之后点击ok。

在这里插入图片描述

1.3进行设置,点击ok,完成工程创建
在这里插入图片描述

2.使用一段代码程序。

2.1代码

//宏定义,用于存放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);//延时时间
     }
}

2.1调试程序如图所示。

在这里插入图片描述

2.2点击上图setting图标,显示下图,点击ok。

在这里插入图片描述

2.3编译。

在这里插入图片描述
至此编译成功,实验结束。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值