ARM开发环境入门--对stm32的简单编译以及使用Proteus对51程序的仿真设计

    科技2024-12-01  23

    文章目录

    一、作业目的二、mdk5软件的stm32包的安装问题三、stm32的简单程序编译四、安装protues完成一个51程序的设计和仿真

    一、作业目的

    . 安装mdk5软件和stm32包,熟悉mdk开发环境,完成一个stm32的简单程序的编译。安装过程可参考网上或者“STM32底座实验指导书”第1章。示例程序可以参考网上代码,或者“STM32底座实验指导书”第3章的“LED闪烁”。(注意,没有硬件之前,只能做程序的编译和仿真测试,无法下载到硬件上运行) 2. 安装并熟悉Proteus 电路仿真软件,完成一个51程序设计和仿真。

    二、mdk5软件的stm32包的安装问题

    1.在官网或者微信公众号下载mdk5安装包。 2.安装步骤参考微信公众号。 3.下载crack,分享其他博主的下载方法 在使用mdk5和crack应注意mdk5和crack都应以管理员运行。 成功后在许可与管理窗口显示为: 4.stm32下载与安装 官网下载或者其他博主分享的路径。 下载完成后直接运行.exe文件即可。

    三、stm32的简单程序编译

    1.创建新项目 2.创建后选择芯片 3.创建成功入如下: 找到startup_stm32f10x_hd.s文件(找不到可以在安装路径里直接搜索查看文件位置),注意修改下方文件类型 4.创建源文件main.c及代码输入 右击Source Group 1 然后选择Add New… 创建main.c文件 此时根据其他博主的文章链接来完成闪烁LED的代码编译。代码如下:

    #define PERIPH_BASE ((unsigned int)0x40000000) #define APB2PERIPH_BASE (PERIPH_BASE + 0x10000) #define GPIOA_BASE (APB2PERIPH_BASE + 0x0800) #define GPIOB_BASE (APB2PERIPH_BASE + 0x0C00) #define GPIOC_BASE (APB2PERIPH_BASE + 0x1000) #define GPIOD_BASE (APB2PERIPH_BASE + 0x1400) #define GPIOE_BASE (APB2PERIPH_BASE + 0x1800) #define GPIOF_BASE (APB2PERIPH_BASE + 0x1C00) #define GPIOG_BASE (APB2PERIPH_BASE + 0x2000) #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 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 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; #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; Delay_ms(500); LED0=1; Delay_ms(500); } } void SystemInit( void ) { }

    5.代码输入后点击编译: 编译成功:

    四、安装protues完成一个51程序的设计和仿真

    proteus仿真软件和keil在之前安装过,如需要,可在网上找到安装方法。 1.进入keil创建项目选择芯片C51: 2.创建新文本:

    3.输入代码:

    #include "reg51.h" //引用头文件reg51.h #include <intrins.h> //引用intrins.h函数,用于_nop_()指令 void delay_ms(int a) //创建delay_ms,设置延迟时间 a { int i,j; //定义变量i,j for(i=0;i<a;i++) { for(j=0;j<1000;j++) _nop_(); //_nop_等同于NOP指令,完成一个机器周期,清空存储的内容 } } void main(void) { while(1) { P0=0xfe; //P0口8个引脚被赋值成11111110,此时P0.0为低电平 delay_ms(100); //周期内循环,完成循环后_nop_清空内容 P0=0xfd; //P0口8个引脚被赋值成11111101,此时P0.1为低电平 delay_ms(100); P0=0xfb; //P0口8个引脚被赋值成11111011,此时P0.2为低电平 delay_ms(100); P0=0xf7; //P0口8个引脚被赋值成11110111,此时P0.3为低电平 delay_ms(100); P0=0xef; //P0口8个引脚被赋值成11101111,此时P0.4为低电平 delay_ms(100); P0=0xdf; //P0口8个引脚被赋值成11011111,此时P0.5为低电平 delay_ms(100); P0=0xbf; //P0口8个引脚被赋值成10111111,此时P0.6为低电平 delay_ms(100); P0=0x7f; //P0口8个引脚被赋值成01111111,此时P0.7为低电平 delay_ms(100); } }

    4.点击编译得到如下:

    点击目标选项: 再次点击output勾选create前方框: 5.在proteus里绘制流水灯仿真图: 6.双击C951原件在program file栏选择keil创建的HEX文件。 仿真如下:

    Processed: 0.012, SQL: 8