当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]Keil工程文件的建立、设置与目标文件的获得

Keil 工程文件的建立、设置与目标文件的获得
单片机开发中除必要的硬件外,同样离不开软件,我们写的汇编语言源程序要变为CPU
可以执行的机器码有两种方法,一种是手工汇编,另一种是机器汇编,目前已极少使用手工
汇编的方法了。机器汇编是通过汇编软件将源程序变为机器码,用于MCS-51 单片机的汇编
软件有早期的A51,随着单片机开发技术的不断发展,从普遍使用汇编语言到逐渐使用高级
语言开发,单片机的开发软件也在不断发展,Keil 软件是目前最流行开发MCS-51 系列单片
机的软件,这从近年来各仿真机厂商纷纷宣布全面支持Keil 即可看出。Keil 提供了包括C
编译器、宏汇编、连接器、库管理和一个功能强大的仿真调试器等在内的完整开发方案,通
过一个集成开发环境(uVision)将这些部份组合在一起。运行Keil 软件需要Pentium 或以
上的CPU,16MB或更多RAM、20M 以上空闲的硬盘空间、WIN98、NT、WIN2000、WINXP
等操作系统。掌握这一软件的使用对于使用51 系列单片机的爱好者来说是十分必要的,如
果你使用C 语言编程,那么Keil 几乎就是你的不二之选(目前在国内你只能买到该软件、
而你买的仿真机也很可能只支持该软件),即使不使用C 语言而仅用汇编语言编程,其方便
易用的集成环境、强大的软件仿真调试工具也会令你事半功倍。
我们将通过一些实例来学习Keil 软件的使用,在这一部份我们将学习如何输入源程序,
建立工程、对工程进行详细的设置,以及如何将源程序变为目标代码。图1 所示电路图使用
89C51 单片机作为主芯片,这种单片机性属于MCS-51 系列,其内部有4K 的FLASH ROM,
可以反复擦写,非常适于做实验。89C51 的P1 引脚上接8 个发光二极管,P3.2~P3.4 引脚上
接4 个按钮开关,我们的第一个任务是让接在P1 引脚上的发光二极管依次循环点亮。
一、Keil 工程的建立
首先启动Keil 软件的集成开发环境,这里假设读者已正确安装了该软件,可以从桌面上直接双击uVision 的图标以启动该软件。
UVison启动后,程序窗口的左边有一个工程管理窗口,该窗口有3 个标签,分别是Files、
Regs、和Books,这三个标签页分别显示当前项目的文件结构、CPU 的寄存器及部份特殊
功能寄存器的值(调试时才出现)和所选CPU 的附加说明文件,如果是第一次启动Keil,那么这三个标签页全是空的。
1、源文件的建立
使用菜单“File->New”或者点击工具栏的新建文件按钮,即可在项目窗口的右侧打开一个新的文本编缉窗口,在该窗口中输入以下汇编语言源程序,例1:
MOV A,#0FEH
MAIN: MOV P1,A
RL A
LCALL DELAY
AJMP MAIN
DELAY: MOV R7,#255
D1: MOV R6,#255
DJNZ R6,$

图1 简单的键盘、显示板

DJNZ R7,D1
RET
END
保存该文件,注意必须加上扩展名(汇编语言源程序一般用asm 或a51 为扩展名),这
里假定将文件保存为exam1.asm。需要说明的是,源文件就是一般的文本文件,不一定使用Keil 软件编写,可以使用任意文本编缉器编写,而且,Keil 的编缉器对汉字的支持不好,建议使用UltraEdit 之类的编缉软件进行源程序的输入。
2、建立工程文件
在项目开发中,并不是仅有一个源程序就行了,还要为这个项目选择CPU(Keil 支持数
百种CPU,而这些CPU 的特性并不完全相同),确定编译、汇编、连接的参数,指定调试
的方式,有一些项目还会有多个文件组成等,为管理和使用方便,Keil 使用工程(Project)
这一概念,将这些参数设置和所需的所有文件都加在一个工程中,只能对工程而不能对单一
的源程序进行编译(汇编)和连接等操作,下面我们就一步一步地来建立工程。
点击“Project->New Project… ”菜单,出现一个对话框,要求给将要建立的工程起一个
名字,你可以在编缉框中输入一个名字(设为exam1),不需要扩展名。点击“保存”按钮,出现第二个对话框,如图2所示,这个对话框要求选择目标CPU(即你所用芯片的型号),Keil 支持的CPU很多,我们选择Atmel 公司的89C51 芯片。点击ATMEL 前面的“+”号,展开该层,点击其中的89C51,然后再点击“确定”按钮,回到主界面,此时,在工程窗口的文件页中,出现了“Target
1”,前面有“+”号,点击“+”号展开,可以看到下一层的“ Source Group1”,这时的工程还是一个空的工程,里面什么文件也没有,需要手动把刚才编写好的源程序加入,点击“Source Group1”使其反白显示,然后,点击鼠标右键,出现一个下拉菜单,如图3 所示。选中其中的“Add file toGroup”Source Group1”,出现一个对话框,要求寻找源文件,注意,该对话框下面的“文件类型”默认为C source file(*.c),也就是以C 为扩展名的文件,而我们的文件是以asm 为扩展名的,所以在列表框中找不到exam1.asm,要将文件类型改掉,点击对话框中“文件类型”后的下拉列表,找到并选中“Asm Source File(*.a51,*.asm),这样,在列表框中就可以找到exam1.asm 文件了。
双击exam1.asm 文件,将文件加入项目,注

图2 选择目标CPU

图3 加入文件 [!--empirenews.page--]

意,在文件加入项目后,该对话框并不消失,等待继续加入其它文件,但初学时常会误认为操作没有成功而再次双击同一文件,这时会出现如图4 所示的对话框,提示你所选文件已在列表中,此时应点击“确定”,返回前一对话框,然后点击“Close”即可返回主界面,返回后,点击“SourceGroup 1”前的加号,会发现exam1.asm 文件已在其中。双击文件名,即打开该源程序。
二、工程的详细设置
工程建立好以后,还要对工程进行进一步的设置,以满足要求。
首先点击左边Project 窗口的Target 1,然后使用菜单“Project->Option for target ‘target1’”
即出现对工程设置的对话框,这个对话框可谓非常复杂,共有8 个页面,要全部搞清可不容
易,好在绝大部份设置项取默认值就行了。设置对话框中的Target 页面,如图5 所示,Xtal 后面的数值是晶振频率值,默认值是所选目标CPU 的最高可用频率值, 对于我们所选的AT89C51 而言是24M,该数值与最终产生的目标代码无关,仅用于软件模拟调试时显示程序执行时间。正确设置该数值可使显示时间与实际所用时间一致,一般将其设置成与你的硬件所用晶振频率相同,如果没必要了解程序执行的时间,也可以不设,这里设置为12。
Memory Model 用于设置RAM 使用情况,有三个选择项,Small 是所有变量都在单片
机的内部RAM 中;Compact 是可以使用一页外部扩展RAM,而Larget 则是可以使用全部
外部的扩展RAM。Code Model 用于设置ROM 空间的使用,同样也有三个选择项,即Small
模式,只用低于2K 的程序空间;Compact 模式,单个函数的代码量不能超过2K,整个程序
可以使用64K 程序空间;Larget 模式,可用全部64K 空间。Use on-chip ROM 选择项,确认
是否仅使用片内ROM(注意:选中该项并不会影响最终生成的目标代码量);Operating 项
是操作系统选择,Keil 提供了两种操作系统:Rtx tiny 和Rtx full,关于操作系统是另外一个
很大的话题了,通常我们不使用任何操作系统,即使用该项的默认值:None(不使用任何
操作系统);Off Chip Code memory 用以确定系统扩展ROM 的地址范围,Off Chip xData
memory 组用于确定系统扩展RAM 的地址范围,这些选择项必须根据所用硬件来决定,由
于该例是单片应用,未进行任何扩展,所以均不重新选择,按默认值设置。
设置对话框中的OutPut 页面,如图6 所示,这里面也有多个选择项,其中Creat Hex file
用于生成可执行代码文件(可以用编程器写入单片机芯片的HEX 格式文件,文件的扩展名
为.HEX),默认情况下该项未被选中,如果要写片做硬件实验,就必须选中该项,这一点是
初学者易疏忽的,在此特别提醒注意。选中Debug information 将会产生调试信息,这些信
息用于调试,如果需要对程序进行调试,应当选中该项。Browse information 是产生浏览信
息,该信息可以用菜单view->Browse 来查看,这里取默认值。按钮“ Select Folder for objects”

图4 重复加入文件的错误

图5 对目标进行设置

是用来选择最终的目标文件所在的文件夹,默认是与工程文件在同一个文件夹中。Name of Executable 用于指定最终生成的目标文件的名字,默认与工程的名字相同,这两项一般不需要更改。工程设置对话框中的其它各页面与C51 编译选项、A51 的汇编选项、BL51 连接器的连接选项等用法有关,这里均取默认值,不作任何修改。以下仅对一些有关页面中常用的选项作一个简单介绍。
Listing 标签页用于调整生成的列表文件选项。在汇编或编译完成后将产生(*.lst)的列
表文件,在连接完成后也将产生(*.m51)的列表文件,该页用于对列表文件的内容和形式
进行细致的调节,其中比较常用的选项是“C Compile Listing”下的“Assamble Code”项,
选中该项可以在列表文件中生成C 语言源程序所对应的汇编代码。
C51 标签页用于对Keil 的C51 编译器的编译过程进行控制,其中比较常用的是“Code
Optimization”组,如图7 所示,该组中Level 是优化等级,C51 在对源程序进行编译时,可
以对代码多至9 级优化,默认使用第8 级,一般不必修改,如果在编译中出现一些问题,可以降低优化级别试一试。Emphasis 是选择编译优先方式,第一项是代码量优化(最终生成的代码量小);第二项是速度优先(最终生成的代码速度快);第三项是缺省。默认的是速度优先,可根据需要更改。设置完成后按确认返回主界面,工程文件建立、设置完毕。
三、编译、连接
在设置好工程后,即可进行编译、连接。选择菜单Project->Build target,对当前工程进
行连接,如果当前文件已修改,软件会先对该文件进行编译,然后再连接以产生目标代码;
如果选择Rebuild All target files 将会
对当前工程中的所有文件重新进行编
译然后再连接,确保最终生产的目标
代码是最新的,而Translate … .项则仅
对该文件进行编译,不进行连接。
以上操作也可以通过工具栏按钮直
接进行。图8 是有关编译、设置的工具[!--empirenews.page--]
栏按钮,从左到右分别是:编译、编译
连接、全部重建、停止编译和对工程进
行设置。
编译过程中的信息将出现在输出窗
口中的Build 页中,如果源程序中有语
图8 有关编译、连接、项目设置的工具条

图7 代码生成控制

图6 对输出进行控制

图9 正确编译、连接之后的结果

法错误,会有错误报告出现,双击该行,可以定位到出错的位置,对源程序反复修改之后,
最终会得到如图9 所示的结果,提示获得了名为exam1.hex 的文件,该文件即可被编程器读
入并写到芯片中,同时还产生了一些其它相关的文件,可被用于Keil 的仿真与调试,这时
可以进入下一步调试的工作。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

利用LogiCoA™微控制器,以更低功耗实现与全数字控制电源同等的功能

关键字: 微控制器 电源 CPU

2024年4月18日 – 提供超丰富半导体和电子元器件™的业界知名新品引入 (NPI) 代理商贸泽电子 (Mouser Electronics) 很荣幸地宣布与Edge Impulse建立新的全球合作关系。Edge Im...

关键字: 机器学习 MCU CPU

无论您是在研究如何使用 10GigE 还是寻求所需考虑事项的建议,本文均提供有实践,帮助确保单相机 10GigE 视觉系统设置顺利并拥有良好性能。 我们列出了主机系统配置、布线和相机设置的实践。

关键字: 视觉系统 CPU 存储器

Apr. 16, 2024 ---- NVIDIA新一代平台Blackwell,包含B系列GPU及整合NVIDIA自家Grace Arm CPU的GB200等。TrendForce集邦咨询指出,GB200的前一代为GH2...

关键字: CPU GPU

人工智能是集合众多方向的综合性学科,在诸多应用领域均取得了显著成果[1]。随着航空领域人工智能技术研究的不断深入,面向开放式机载智能交互场景,人工智能的应用可解决诸多问题。例如智能感知、辅助决策等,可利用人工智能算法对多...

关键字: 人工智能 PCIe CPU

CPU针脚弯了,用工具调正就不会有影响。开机自检也通过,CPU 再出问题就不是针脚引起的问题。针脚只要不断就没有问题,有的CPU出厂的时候针脚就有点弯,这并不是什么大问题,只要用镊子轻轻地弄直就可以了。

关键字: CPU 针脚 开机自检

瑞典乌普萨拉,2024年3月27日 – 全球领先的嵌入式系统开发软件解决方案供应商IAR自豪地宣布:公司备受全球数百万开发者青睐的开发环境再次升级,已率先支持瑞萨首款通用32位RISC-V MCU,该 MCU 搭载了瑞萨...

关键字: MCU RISC-V CPU

联发科与高通骁龙的对决可以说是一场性能与价值的较量,那么,你对两者的芯片有了解吗?在移动设备领域,芯片制造商的竞争愈发激烈。其中,来自台湾的联发科(MediaTek)与美国的高通(Qualcomm)无疑是该领域的两大巨头...

关键字: 联发科 高通骁龙 CPU 处理器

云和超大规模服务运营商正不断增大计算密度。随着 Microsoft Cobalt、阿里巴巴的倚天 710、AmpereOne等配置 128 核或以上的 CPU 设计进入市场,单个封装可实现的性能更强,且下一代的目标还将远...

关键字: CPU 处理器

Arm Neoverse 旨在为从云到边缘的全场景基础设施用例提供高性能和出色能效。针对需要更高性能的工作负载和用例,Arm 推出了 Neoverse V 系列。其中,Neoverse V2 核心已被行业先行者广泛部署于...

关键字: 云计算 人工智能 CPU
关闭
关闭