STM32:Keil MDK(uVision v4.10)开发环境搭建

发布者:机器人总动员最新更新时间:2017-09-21 来源: eefocus关键字:STM32  Keil  MDK  开发环境 手机看文章 扫描二维码
随时随地手机看文章

集成开发环境(IDE):Keil公司的RealView MDK(uVision V4.10)

源文件编辑器:EditPlus(我在用的)/UltraEdit/SourceInsight/IDE自带的编辑器 

串口工具:SecureCRT(一个专业的超级终端工具,支持很多接口(包括串口)和协议,推荐使用。)

 

RealView MDK 工程配置:(keil开发环境搭建核心步骤)

1、新建文件夹,文件夹名如:Template
2、在文件夹Template下新建文件夹:User/ Project/ Output/ Listing/ Libraries/CMSIS/ Libraries/FWlib/ Doc/
3、在Project/文件夹下建立项目文件夹,如RTX/
4、keil软件中【Project】→【New uVision Project】找到该文件夹打开,并输入实际项目名称,如RTX保存;
5、选择芯片型号:我们是STM32F103ZET6,有64K SRAM,512K Flash,因此选择【STMicroelectronice】→【STM32F103ZE】→OK,拷贝启动代码选择【否】;
6、修改左侧窗口Project中的Target1名称,删除Source Group 1
7、在工程文件夹下拷贝所需的库文件:
    1) User/下拷贝ST库3.5.0源码\STM32F10x_StdPeriph_Lib_V3.5.0\Project\STM32F10x_StdPeriph_Template\文件夹下的-4个files
    2) Libraries/FWlib/下拷贝ST库3.5.0源码\STM32F10x_StdPeriph_Lib_V3.5.0\Libraries\STM32F10x_StdPeriph_Driver\文件夹下的-2个dir
    3) Libraries/CMSIS/下拷贝ST库3.5.0源码\STM32F10x_StdPeriph_Lib_V3.5.0\Libraries\CMSIS\CM3\DeviceSupport\ST\STM32F10x\文件夹下的-1个dir,-3个files
       还需拷贝ST库3.5.0源码\STM32F10x_StdPeriph_Lib_V3.5.0\Libraries\CMSIS\CM3\CoreSupport\文件夹下的
    4) Doc/下一般放readme.txt说明文档;
8、在keil软件左侧Project窗口的Template下建立5组文件夹:点击图标【file Extensions】→【Groups】→【Add Files】
    Groups:STARTUP/  CMSIS/  FWLIB/  USER/  DOC/
    files:
        STARTUP/startup_stm32f10x_hd.s
        CMSIS/(CMSIS/下所有*.c *.h文件)
        FWLIB/(src/下.c文件,根据实际工程所需进行添加)
        USER/(User/下所有.c .h文件)
        注意事项:拷贝过来的.s .c .h文件如有带锁的,表明只读,需要在windows文件夹下全选右键去掉【只读】
9、选项卡【Target Options】↓
   【Target】 (√)Use MicroLIB
   【Output】→Select Folder for Objects...→Output/打开
                      (√)Create HEX File
   【Listing】→Select Folder for Listings...→Listings/打开
   【C/C++】→Define: STM32F10X_HD, USE_STDPERIPH_DRIVER
                      (√)One ELF Section per Function
    →Include Paths: ..\..\Libraries\CMSIS;..\..\User;..\..\Libraries\FWlib\inc
    添加 --diag_suppress=870 控制,可以避免中文字符串告警。

如果开发板使用J-Link调试的话,还需配置以下选项:
    【Debug】
     >>Flash Download→(√)Use: J-LINK/J-Trace Cortex ;  (√)Run to main()
     →Settings→(√)Erase Full C ; (√)Reset and Run
     >> Add→STM32F10x High-density Flash→Add
     >> Debug→(√)Port: JTAG ; (√)MAX Clock:10MHz
    【Utilities】(√)Use Target Driver...(√)J-LINK/J-Trace Cortex

keil的虚拟串口Debug调试:
需要在【Target Options】-【Debug】中设置为 Use Simulator 模式,开启 【View】-【command window】输入命令:
MODE COM1 115200,0,8,1
ASSIGN COM1 S1OUT
虚拟串口软件 VSPD 开启两个COM,使用secureCRT连接另外一个COM口,查看接收情况
技巧:
【Debug】选项卡下左侧 Initialization File 中点击【...】 新增一个默认调试命令的.ini文件,如debug.ini,将两行命令复制进去即可在调试时自动加载两个链接COM1串口配置的命令。



关于STM32学习的一些观点

坚定信念选择ST固件库:

不要再思考固件库开发还是寄存器开发这种问题了。 99%的有实际产品开发经验的工程师都会告诉你,使用ST的固件库开发STM32应用是最佳的选择。这套固件库写的非常规范,很严谨,没有一定的C语言功底和程序架构设计功底是写不出来这种代码的。你如果觉得固件库过于复杂,太乱了,只能说明一个问题:你没有参与过大型软件开发、你的C语言还没学习到位、你还没有程序架构设计的概念。
我们要做的是学会如何看懂固件库、学习如何使用固件库。 深入的话可以借鉴固件库的写法构建我们自己的外设驱动。
可能有些人会反驳,不学习寄存器,感觉学习地不深入。我的观点是:寄存器是最没有学习价值的,硬件功能复杂了必须通过一些寄存器的某些bit来配置和选择硬件功能。我们需要大量的时间来记忆、梳理寄存器每个bit之间的关系。我认为是不值得的。你不如将这个时间花在学习ST固件库是如何梳理、归纳这些硬件功能,也就是学习C程序设计方法。
我们也不是完全让你不去了解寄存器功能,在极个别时候,我们也会使用寄存器直接操作。不过我们也就是将ST固件库的函数展开以提高代码执行效率。

 

选择性学习:

(这个可能适合很多上进心很强的童鞋,总想把STM32搞精搞透,甚至不只是单片机,FPGA等等等等的技术,人生苦短,抓住精华,尽力而为!)

STM32的功能实在太多,和STM32相关的软件组件也多如牛毛。而人的精力是有限,你就算学习一辈子,也不可能学会所有的东西。人的一生,时间是最为宝贵的,我们一定要将时间用在刀刃上。别人做好的开源的第三方的代码,如果你测试应用过,没有问题,那他就属于你的了,你只要学会怎么移植和使用它就足够了。如果别人已经移植好了,那就更方便了,直接拿来使用即可。没有必要再花精力深入代码去研究别人的程序结构了。比如FatFS、 uIP、 ST固件库、 uCOS、 emWin。除非你是做基础研究或者查找BUG。

我们一定要将时间腾出来去学习和掌握更多的软件模块。这样,当项目来临时,你就可以从容应对。

 

构建自己的代码库:

(根据自己的代码风格,以及常用的模块,建立自己的小代码库,这样以后用到的时候,直接拿来改一改,自己的东西自己心里清楚,用着明了,心里也踏实,也利于项目的快速启动和建立)

自己验证过的代码,要学会收集整理。变为自己代码库的一部分。日积月累。等到做产品和项目时,80%以上的代码来自于代码库。做产品很多时候就是搭积木。你的代码库越丰富,做起产品来也就越快越好。一些好的工程框架也要学会收集整理。我们在很多时候做项目,都是直接复制某个相近的工程。不可能每次都去重新新建一个工程。好比盖房子,你可以直接拿砖砌,而不用在花时间去造转。


关键字:STM32  Keil  MDK  开发环境 引用地址:STM32:Keil MDK(uVision v4.10)开发环境搭建

上一篇:STM32:GPIO基础与对应管脚操作库函数
下一篇:ARM:UART串口异步通信驱动编程

推荐阅读最新更新时间:2024-03-16 15:37

STM32常用数据类型 u8、u16、u32
1.unsigned int 32 (C语言标准表达方法) 2.uint32_t ; 3.u32; 这三种方式都是在表达同一个意思。ST 搞这么多花样,无非是想开发人员在写代码时定义数据类型能少写几个符号,然后又因为前后版本升级,为了兼容旧版本(主要是V2.0)才会出现这么多表示方法。不管他怎么换,都是基于标准C来的,看清楚以下几个文件你就OK了:core_cm3.h ;stm32f10x.h ; stdint.h; 其中每个文件大概作用如下: stdint.h 这里放着C语言的标准表达方式//第36行开始 typedef signed char int8_t; // 标准表达方式
[单片机]
STM32的瘦肉精含量快速检测系统
引言 本设计在传统的免疫法基础上进行改良,采用了激光诱导荧光技术和荧光免疫分析法,实现了对瘦肉精的快速、定量、精确检测,具有高分辨率、快速响应、高灵敏度、抗干扰能力强等优点。 1 检测系统的工作原理与组成 1.1 光学检测原理 本设计选用的半导体激光器的光功率最大是5 mW,最大工作电流是40 mA,正常工作电流35 mA,正常工作电压是2.2 V,最大反向工作电压是2 V,波长范围是630~640 nm,中心波长为638 nm。激发出来的荧光波长为680 nm,所选用的光敏二极管S5106能够感应的波长范围是320~1 100 nm,接收灵敏度最高的是960 nm的光,接收荧光的灵敏度约为0.45。 半导体激光器打出
[单片机]
<font color='red'>STM32</font>的瘦肉精含量快速检测系统
STM32硬件错误的调试技巧
在用Keil对STM32的程序进行仿真时程序有时会跑飞,停止仿真程序会停在HardFault_Handler函数里的死循环while(1)中。 这说明STM32出现了硬件错误。 硬件错误中断 STM32出现硬件错误可能有以下原因: 数组越界操作; 内存溢出,访问越界; 堆栈溢出,程序跑飞; 中断处理错误; 遇到这种情况,可以通过以下2种方式来定位到出错代码段。 方法1: 在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击STOP停止仿真。 示例 1.2 在Keil菜单栏点击View——Registers Window,在寄存器查看窗口查找R14(LR)的值。 如果R
[单片机]
<font color='red'>STM32</font>硬件错误的调试技巧
STM32 ST-LINK 下载后不明原因的无法启动
更换ST-LINK 后,下载程序无法启动,程序下载正常,就是无法启动,换了一块不同的板子还是这个现象 纠结于: 1. 晶振没有正常起震 2. ST-LINK 驱动问题 3. 程序出错 4.... 一万个草泥马飘过 搜索度娘的方法,都没有效果,用MDK在线调试,显示启动后莫名复位,有一种程序跑飞的感觉 后来偶然发现有网友提到 WDG_SW st-link utility 文档上解释如下 如果不选择该项,上电将自动开启看门狗,我的天!!! 选中该选项后,程序正常运行了 因为之前没有注意到这个,换了个环境,偏偏遇到这个问题,抓耳挠腮了一个晚上
[单片机]
<font color='red'>STM32</font> ST-LINK 下载后不明原因的无法启动
S3C2440之MMU驱动代码模板(RealView MDK
好记心不如烂笔头,为方便以后查看代码及代码重复利用,这里贴出自己写的S3C2440 MMU代码库。使用友善MINI2440开发板,开发环境为RealView MDK 4.22。 该源码结构简单明了,原始工程下载地址: 点击打开链接 Register 0, ID code register: unsigned int MMU_ReadID(void) { unsigned int id; __asm( mrc p15, 0, id, c0, c0, 0 ); return id; } Register 0, cache type register: unsigned int
[单片机]
ucOS_II移植:Stm32启动代码分析
用的编译工具是keil,在用keil建立stm32工程时,一般会产生一个启动文件,STM32F10x.s,在st提供的库函数里,用cortexm3_macro.s和stm32f10x_vector.s来代替这个文件。不过内容都大同小异。 我在csdn上搜到了一个在stm32上移植好的ucos,打算在这个代码的基础上,添加注释,先学别人的,然后再自己移植。 我获得的这份例程,使用了startup_stm32f10x_md.s作为启动文件,其中,删去了部分采用扩展SRAM的代码。 其文件内容为 startup_stm32f10x_md.s ;******** (C) COPYRIGHT2010 STMicroelectronics
[单片机]
STM32学习笔记(一)----系统时钟
STM32的系统时钟来源可分为三个:HSI(高速内部时钟)、HSE(高速外部时钟)、PLL (经PLL倍频后的时钟信号)。 在设置系统时钟时,要先重置下RCC- CR 及 RCC- CFGR 寄存器,具体可参照STM32 的官方库,里面每个步骤都有详细说明的。下面大概地说一下关于系统时钟选择的设置: 1)以HSI作为系统时钟来源: RCC- CFGR SW=00 -----------------------------------------------------------------------------------------------
[单片机]
STM32开发中的位带操作机制
为了像51单片机一样能够对某个管脚单独操作,引入了位带操作这样的操作机制。 如下图,位带(Bit band)区就是就是你想单独操作的IO的区域,比如PA1、PA2。而位带别名区就是你给每一位重新起了个名字的那一片地址区域。可以看下表,M3内核存储器映射表,你能看到1M内存的BitBand区,还有与之对应的32M内存的BitBand别名区,因为你将每一位膨胀成为了一个32位的地址,所以相应的别名区的内存也会是位带区的32倍。 想进行位带操作,应该先去找该位对应的别名区的地址,找到了这个地址,对这个地址进行操作,那么实际上也就是对该位进行操作了。 官方给出了如下相应的计算公式: AliasAddr=0x42000000+((A‐0
[单片机]
<font color='red'>STM32</font>开发中的位带操作机制
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
热门活动
换一批
更多
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

更多每日新闻
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved