嵌入式入门小程序

一、安装Proteus

1、proteus简介
2、proteu安装

二、简单51程序仿真和设计

1、编写led流水灯原理图2、编写51程序

3、开始仿真

三、一个通过寄存器方式,用某一个GPIO端口点亮LED的stm32的简单程序

四、总结

五、参考资料

一、安装Proteus

1、proteus简介

Proteus 是一款用于嵌入式单片机仿真的软件,用于在打PCB板之前对软件程序和硬件电路的正确性进行仿真验证。

(1)、Proteus一般会和Keil软件进行联合仿真,在Proteus中绘制系统的电路图,在Keil软件中编写对应的程序后生成Hex文件。
(2)、Proteus的仿真结果仅供参考,只能在一定程度上验证系统的可能性。实际实物系统还需要进行进一步的调试。

2、proteu安装

参考http://t.csdn.cn/Jc1GL ,这里有详细的安装过程,感谢博主Half_A的分享。

二、简单51程序仿真和设计

1、编写led流水灯原理图

在这里插入图片描述

2、编写51程序

在这里插入图片描述

3、开始仿真

在这里插入图片描述

三、一个通过寄存器方式,用某一个GPIO端口点亮LED的stm32的简单程序

使用MDK编译stm32简单程序(闪烁LED)
1.新建工程
在菜单栏点击Project中的New uVision Project,在想要的存储地址新建文件夹名为“点亮LED”

进入该文件夹将项目命名为project并保存,之后选择我们的单片机–STM32F103RB(在我们的STM32最小板的芯片上写了相应的型号),之后点击OK。

输入以下代码

#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);//延时
}
}`

在右边的工具栏中找到Source Goupe 1,右击,点击Add Existing Files to Group ‘Source Goupe 1’

点击Keil工具箱的魔术棒,点击Debug里的ST-Link Debuggeer,点击旁边的Settings,勾选ST-LINK/V2和SW

在这里插入图片描述

后点击确定,进行编译,编译成功后点击LOAD即可看到LED闪烁

在这里插入图片描述

四、总结

​ 通过本次,我学习到了如何使用Proteus和Keil进行仿真实验,Proteus一般会和Keil软件进行联合使用,我们需要在Proteus中绘制系统的电路图,在Keil软件中编写对应的程序后生成Hex文件,在Proteus中添加Hex文件才能运行成功。

五、参考资料

http://t.csdn.cn/tSnGU

学习到了如何使用Proteus和Keil进行仿真实验,Proteus一般会和Keil软件进行联合使用,我们需要在Proteus中绘制系统的电路图,在Keil软件中编写对应的程序后生成Hex文件,在Proteus中添加Hex文件才能运行成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值