基于MDK5的STM32103程序编译

    科技2026-03-02  9

    目录

    1.基于MDK5的STM32103程序编译1.1 使用MDK5创建一个新工程1.2 添加main.c文件1.3 编译程序 2.使用Proteus 进行51芯片仿真2.1构建电路2.2编程代码

    1.基于MDK5的STM32103程序编译

    1.1 使用MDK5创建一个新工程

    首先在project->new project中创建一个新工程,选用STM32F103RB芯片后成功创建。

    接着弹出配置界面,我们按如下的选项配置。

    这样我们就成功的创建了工程

    1.2 添加main.c文件

    点击左上角空白页,新建一个text文件

    将如下的代码复制到text文件中

    //宏定义,用于存放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

    右键Source Group 1,选择Add Existing Files to Group …,将刚才保存的main.c文件添加到Source Group 1中

    1.3 编译程序

    点击左上角编译按钮,开始编译程序,main.c: 1 warning, 0 errors,表示编译成功

    2.使用Proteus 进行51芯片仿真

    2.1构建电路

    在proteus 8 professional中新建一个project,建新的选项都默认缺省

    在pick parts中找到我们构建电路的几中元器件,包括51芯片,电阻电容等。

    将他们在工作区摆放出来后,用2D Graphics line mode将元器件连接起来,连接好后的效果如下 在Tool中选择Electrical Rules Cheak,检查电路是否符合逻辑,显示 No ERC errors found,电路连接正确

    2.2编程代码

    将如下代码利用MDK5编译为HEX文件,然后在proteus中导入该.hex文件

    //代码来自于网络 #include<reg51.h> //定义头文件 sbit LED=P0^0; //定义引脚 int i,j; void main() //main代表主函数,程序执行的部分 { while(1) { LED=0; for(i=100;i>0;i--) //利用for循环实现了延时 for(j=11;j>0;j--); LED=1; for(i=100;i>0;i--) for(j=11;j>0;j--); } }

    运行结果如下:

    Processed: 0.016, SQL: 9