ARM开发环境入门(嵌入式作业二)

一.MDK5软件和stm32包的安装

1.打开我们下载好的mdk5安装包里面的mdk_510.exe,如下图所示:在这里插入图片描述
2.在出现提示框之后,点击next进行下一步:在这里插入图片描述
3.勾选箭头所示的条文,点击next进行下一步:在这里插入图片描述
4.选择要安装到的存储位置,进行下一步操作(注意:在选择安装位置时,安装位置文件的名称要用英文名,不能出现中文字符和汉字,否则在后续的安装过程中可能会出现安装失败的问题和一些错误的弹框):在这里插入图片描述

5.编辑自己相应的名称和邮箱,再进行下一步:在这里插入图片描述
6.等待安装:在这里插入图片描述
7.点击finish完成mdk5的安装:在这里插入图片描述
8.mdk5完成安装之后,会弹出一个窗口框,我们点击ok后关闭即可:在这里插入图片描述
9.再进行stm32包的安装,我们首先安装第一个箭头的包:在这里插入图片描述
10.第一个包点击打开之后,出现该提示框,点击next继续等待安装完毕点击finish即可:在这里插入图片描述
11.再安装第二三个包,与上一述步骤一样(但安装第三个包时会发现:当双击第三个包,会出现安装失败,是因为2.2.0版本的pack只支持更高版本的MDK软件,如若想安装上这个pack,可以去下载最新的MDK,这里我们只做学习用,1.0.4版本的足够用,没有影响)
在这里插入图片描述
至此mdk5和stm32均已安装完毕,将进行下面的步骤用于激活。

二.MDK5软件的注册

1.前面我们已经安装好了mdk5软件,现在我们将进行注册并激活它,首先我们应将电脑防火墙关闭(不关闭防火墙可能会导致注册失败):在这里插入图片描述
2.打开我们安装包里面箭头所示的文件:在这里插入图片描述
3.会出现如下窗口,我们将箭头所示的C51选择更改为ARM,暂时不要关闭该窗口:在这里插入图片描述
4.我们再以管理员身份运行我们安装好的的keil软件:在这里插入图片描述
5.打开之后点击File,再点击箭头所示的选项在这里插入图片描述
6.会出现下面弹窗,我们再将箭头所指的CID复制下来,返回前面第3步出现的弹框上进行粘贴:在这里插入图片描述
7.粘贴CID之后,点击图中的Generate可以得到一串字符,将其复制下来:在这里插入图片描述
8.将复制的这串字符粘贴到第6步出现的框中,再点击Add LIC,出现下图上小箭头所示的提示时,就证明注册成功了:在这里插入图片描述
9.注册成功之后我们就可以使用该软件进行工作学习了:在这里插入图片描述

三.STM32简单程序编译

我们进行一个LED闪烁的实验。
(开始之前我们需要进行一些参数的设置)如下图所示:
在这里插入图片描述点击箭头所示的选项进入设置更改如下即可(这样就会避免在后续粘贴代码过程中的中文注释出现乱码):
在这里插入图片描述

1.a.首先打开我们的keil软件,新建一个工程,如图所示:在这里插入图片描述
然后输入工程名称并保存:在这里插入图片描述
1.b.在弹出的窗口中选择箭头所示的选项:在这里插入图片描述
1.c.勾选对应的选项,再点击OK即可,至此工程创建完毕:在这里插入图片描述
2.a.创建main.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);//延时时间
     }
}

2.b.将复制粘贴好的代码进行保存,即点击箭头所示按钮,再输入文件名保存即可生成main.c文件:在这里插入图片描述
2.c.再在Target中找到source group 1,右键点击,点击箭头所指的选项在这里插入图片描述
打开后将main文件Add进去,在进行编译:在这里插入图片描述
按照箭头所示对main.c编译之后无错误就代表编译成功!:在这里插入图片描述

四.安装并熟悉Proteus电路仿真软件,并完成一个51程序设计和仿真。

( 因为之前proteus在电脑上已经安装,这里不再做描述,具体可以参考:链接: link.里面有安装教程的描述。)
1.新建工程,按箭头所示进行选择相应的选项:在这里插入图片描述
之后出现该文本框,再点击是:在这里插入图片描述
2.因为后续需要一个.hex文件,所以需要先修改一下设置,按下列步骤进行:在这里插入图片描述
3.在左上角点击“File ”中选择“New”,建立新文件,进行编辑,编辑之后再进行编译,编译结果无错误如图:在这里插入图片描述
4.上面新文件的编辑编译的程序如下:

#include <reg51.h>

void delayms(unsigned int m)      //延时程序
{
	unsigned int a,b;
	for(a=0; a<m; a++)
		for(b=0; b<120; b++);
}		  

unsigned int a[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};//分别显示0 1 2 3 4 5 6 7 8 9

void main (void)
{	  
		unsigned char n;
	                        //定义初始化
		while(1)
		{
			for(n=0; n<10; n++)	//0-9循环显示
			{
			   P0 = a[n];           //数码管输出
			   delayms(500);
		    }	
		}
}

5.因为步骤3中编译无错误已经生成了.hex文件,所以现在进行后面的步骤
6.打开proteus软件,新建一个工程进去添加如下元件:在这里插入图片描述
7.将原件连接成0-9计时器的电路原理图:在这里插入图片描述
8.双击电路图的芯片,添加.hex文件并确定:在这里插入图片描述
9.运行仿真,得到如下结果,可以发现能够正常计数:在这里插入图片描述
最后,仿真无误,0-9计时器仿真结束,能够实现相关功能。

五.小结

通过本次实验,让我学会了如何正确的安装MDK5和stm32包,并在过程中学到了很多新的知识和技巧;同时也深化了我对keil5软件的使用和掌握。能够正确的将keil5和proteus结合运用并进行仿真实验,收益颇丰!本次作业的完成参考了该博客:https://blog.csdn.net/qq_45189556/article/details/108944460
https://blog.csdn.net/qq_45907958/article/details/108951335
对此表示感谢!
最后附上MDK官方下载地址: http://www.keil.com/download/product/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值