IAR生成HEX文件
关于hex文件的产生方法
1. 关于hex文件的产生方法:在STVD下如何产生HEX文件,在STVD的Project -> Setting -> Post-Build Commands 栏内添加: chex -fi -o $(OutputPath)$(T argetSName).hex $(OutputPath)$(TargetSName).sm82. 将memory models选择mods或modsl应用注意:使用的是STVD自动生成的stm8_interrupt_vector.c文件时,在使用modsl模式编译时,必须将extern void _stext(); /* startup routine */ 这句改为extern @near void _stext(); /* startup routine */ 需要增加@near 关键字。
程序大于32k后,要把const数据,main还有中断函数等定位到32k(地址64k)以内,不然程序会跑飞,而且编译链接的时候也不会报错。
3. 仿真调试利用STM8小板上的3个LED灯,了解仿真环境。
利用建好的环境,修改main.c文件,修改后的如下#i nclude "STM8S207R.h"void main(void){_asm("sim");PD_DDR |= 0x0D;PD_CR1 |= 0x0D;PD_CR2 = 0x00;_asm("nop");PD_ODR |=0x01;_asm("nop");PD_ODR |=0x04;_asm("nop");PD_ODR |=0x08;_asm("nop");PD_ODR &=~0x0D;_asm("nop");_asm("rim");while(1);}把 STM8S207R.h 文件放在建好的工程目录下,与main.c文件在用一个目录下。
生成HEX步骤
五、应用软件调试程
1、建立一个新工程单击Project菜单,在弹出的下拉菜单中选中New Project 选项
2、然后选择你要保存的路径,输入工程文件的名字,比如保存到C51目录里,工程文件的名字为C51,然后点击保存.
3、这时会弹出一个对话框,要求你选择单片机的型号.我这里用Atmel 的89c52,选择89c52之后,右边一栏是对这个单片机的基本的说明,然后点击确定.
4、单击“File”菜单,再在下拉菜单中单击“New”选项然后把上面的程序复制到这个新建文件里,以1fengzhong.ASM为扩展名保存。
5、然后单击“Add File to Group ‘Source Group 1’”
6、选中1fengzhong.asm,然后单击“Add”在“Source Group 1”文件夹中多了一个子项“1fengzhong.asm”
7、单击“Project”菜单,再在下拉菜单中单击“option for target“target1”选项,在弹出的对话框中单击“OUT PUT”选项,在create executable和create hex 这两个选项中打勾。
8、译成功退出KEILC。
9、运行STC,单击Open File选项,找到用Keil C 生成的“1fengzhong.hex”文件,串口选用COM1,其他设置默认。
10、连接好小信号系统板与电脑之间的连线,接好小信号系统板的电源(5V)此时不通电。
11、单击STC的“Download”键,然后接通小信号系统板电源。
IARAVR怎么生成HEX文件啊
IAR A VR怎么生成HEX文件啊IAR同时输出多个文件的说明,在IAR225E(30天限时版)中通过。
操作步骤:1、在Project->Options->XLINK->Include中观察该Project使用了哪个XCL文件。
2、在该XLC文件中加入以下两行:-Ointel-extended,(CODE)=.hex-Ointel-extended,(XDA TA)=.eep3、在Project->Options->XLINK->Output->Format->Other中选择UBROF6格式输出。
以下为MAP文件的部分内容,生成了与Project名称相同的三个文件:test.dbg:兼容于A VR STUDIO的调试文件(也可以任意指定文件名)test.hex:INTEL HEX格式的程序代码文件test.eep:INTEL HEX格式的EEPROM初始化数据文件。
############################################################################## ### ## IAR Universal Linker V4.53F/WIN ## ## Link time = 20/Jan/2001 14:49:35 ## Target CPU = A90 ## List file = "D:\IAR Systems\user_A vr\Debug\List\test.map" ## Output file 1 = "D:\IAR Systems\user_A vr\Debug\Exe\test.dbg" ## Format: ubrof6 ## UBROF version 6.0.0 ## Output file 2 = "D:\IAR Systems\user_A vr\Debug\Exe\test.hex" ## Format: intel-extended, variant: -y(CODE) ## Output file 3 = "D:\IAR Systems\user_A vr\Debug\Exe\test.eep" ## Format: intel-extended, variant: -y(XDA TA) #注意:1、可以修改IAR Embedded Workbench安装位置中所有cfg?s.xcl cfg?l.xcl cfg?t.xcl文件,这样就不需每次修改了,对Project->Options->XLINK->Output->Format中其余两个选项没有影响。
IAR如何生成HEX文件
IAR如何生成HEX文件
IAR菜单栏中,红色框选中的就是下载及调试(download and debug),仿真时使用。
看一下iar的简单教程,设置好之后,保证程序没有语法等错误,
进行下面三步pile;2.make;3.download and debug,即可以单步调试。
其实步骤3也就是把程序下载到单片机中了。
IAR生成Hex文件,基本都是在linker的output里面设置。
基本步骤如下:
1.下载及仿真调试
点击project菜单栏中的option选项,(或用快捷键Alt+F7,直接出现下图示界面),按图示选择,点击OK后,确定仿真器连接好,就直接在IAR菜单栏中,点红色框选中的下载及调试(download and debug),就可以仿真了,这时程序已经下载到单片机中了。
2.只生成Hex文件,不仿真。
点击LINKER 的OUTPUT中选项中的other选项,overfile里的选项就是要生成的HEX文件名称,点击OK后,rebuild all一下就可以在程序文件Debug---Exe---发现HEX文件
注意:仿真和HEX文件生成不能同时设置,即,LINKER 的OUTPUT 中选项中选择的是other选项,只能用来生成HEX文件,不能仿真,要想用IAR仿真和调试程序,只能将LINKER 的OUTPUT中选项中选择Debug information for C-SPY选项。
IAR使用下载步骤
1.以下是使用下载工具使用步骤,
IAR for 430 使用步骤:项目名->右击(options)->General Options ->选择芯片
Linker->Output->生成.txt文件
下载软件:SF_BSL430.exe
2.以下是用JTAX进行在线调试步骤:
IAR for 430 使用步骤:项目名->右击(options)->General Options ->选择芯片
Linker->Output->生成.d43文件
Debugger->Driver选择FET Debugger->FET Debugger->选择下载端口
然后点击中间那个就可以了
3.IAR forcc2530使用步骤:项目名->右击(options)->Linker->Output->生成.hex文件(这里要注意,如果是在编译的时候Format要选择Other,编译完成后在下载的时候,要勾选上面的而不是Other)
下载用软件Texas Instruments SmartRF Flash Programmer
其中这里选择芯片,如果没有,就多按几下复位键
在其下方的框内选择要进行下载的文件,点击Perform actions 最后在IAR中点击下面一行最后的那个按钮。
IAR编译CC2530生成HEX文件
IAR编译ZStack-CC2530,生成HEX文件完全配置IAR编译ZStack-CC2530为可下载运行的HEX文件的正确配置:1. 正确配置输出文件格式:菜单选择Project-Options-Linker-Output-Format,选择Other。
右边的Output下拉框 选intel-extended,Format variant 下拉框选None,Module-local下拉框选Include all2.还是在菜单Project-Options-Linker-Output标签中,勾上Override default选项,把编辑框中的文件名的后缀改为hex以上两步都是大多数人熟知的,下面这一步是针对大型程序编译下载所必须的,也是大部分写zstack教程的人所没有提到的。
3. 找到f8w2530.xcl文件,并打开。
(这个文件在"Projects/zstack/Tools/CC2530DB/"目录下,也可以通过IAR编 译环境的左侧Workspace窗口点开Tools文件夹看到)在f8w2530.xcl文件中找到两行被注释掉的语句://-M(CODE)[(_CODEBANK_START+_FIRST_BANK_ADDR)-(_CODEBANK_END+_FIRST_B ANK_ADDR)]*///_NR_OF_BANKS+_FIRST_BANK_ADDR=0x8000把这两行前面的"//"去掉,保存,重新编译,OK!(注: 去掉这两行的"//"后在编译输出成hex格式时没有问题,但在debug模式下编译会提示警告:Warning[w69]: Address translation (-M, -b# or -b@) has no effect on the output format 'debug'. The output file will be generated but noaddress translation will be performed. 不过并不会影响debug调试的使用。
iar生成hex
如何输出HEX文件?方法一最好用)在配置文件后面加入以下代码,便可输出HEX文件,A90文件与HEX文件一样,SLISP都能识别.如图Override default 目录下的那个文件中最后面加入以下代码// Output File-Ointel-extended,(XDATA)=.eep //产生eeprom文件-Ointel-extended,(CODE)=.A90 //产生烧写文件-Ointel-extended,(CODE)=.hex //产生烧写文件或者不在配置文件后面加,直接在如下图的地方加入命令方法二)Output 选择zax-i这个方法会出现一点小问题,如果有__eeprom 则会出下面的错误提示,__flash 没事。
Error[e133]: The output format intel-standard cannot handle multiple address spaces. Use format variants (-y -O) to specify which address space is wanted (.hex 和.eep不能同时放到一个文件中,如果没有.eep文件生成就不会报错,可以正常使用了)中断向量的使用IAR中定义中断函数的格式是/////////////////////////////////#pragma vector=中断向量__interrupt void 中断服务程序(void){//中断处理程序}/////////////////////////////////////中断的初始化要另外加入代码,可在主程序内加入。
如下是各个中断函数的定义。
//中断定义#include <iom16.h>#pragma vector=INT0_vect__interrupt void INT0_Server(void){}#pragma vector=INT1_vect__interrupt void INT1_Server(void){}#pragma vector=TIMER2_COMP_vect__interrupt void TIMER2_COMP_Server(void){}#pragma vector=TIMER2_OVF_vect__interrupt void TIMER2_OVF_Server(void){}#pragma vector=TIMER1_CAPT_vect__interrupt void TIMER1_CAPT_Server(void){}#pragma vector=TIMER1_COMPA_vect__interrupt void TIMER1_COMPA_Server(void){}#pragma vector=TIMER1_COMPB_vect__interrupt void TIMER1_COMPB_Server(void){}#pragma vector=TIMER1_OVF_vect__interrupt void TIMER1_OVF_Server(void){}#pragma vector=TIMER0_OVF_vect__interrupt void TIMER0_OVF_Server(void) {}#pragma vector=SPI_STC_vect__interrupt void SPI_STC_Server(void){}#pragma vector=USART_RXC_vect__interrupt void USART_RXC_Server(void) {}#pragma vector=USART_UDRE_vect__interrupt void USART_UDRE_Server(void) {}#pragma vector=USART_TXC_vect__interrupt void USART_TXC_Server(void) {}#pragma vector=ADC_vect__interrupt void ADC_Server(void){}#pragma vector=EE_RDY_vect__interrupt void EE_RDY_Server(void){}#pragma vector=ANA_COMP_vect__interrupt void ANA_COMP_Server(void) {}#pragma vector=TWI_vect__interrupt void TWI_Server(void){}#pragma vector=INT2_vect__interrupt void INT2_Server(void){}#pragma vector=TIMER0_COMP_vect__interrupt void TIMER0_COMP_Server(void) {}#pragma vector=SPM_RDY_vect__interrupt void SPM_RDY_Server(void){}如何把常数字符串定义在flash 空间?法一:unsigned char __flash temptab[] = {1,2,3,4,5};法二:__flash unsigned char temptab[] = {1,2,3,4,5};法三:#pragma type_attribute=__flashunsigned char temptab[]={1,2,3,4,5};法四:const unsigned char temptab[]={1,2,3,4,5};注:第三种方式用#pragma说明后,下面的定义的变量将都在FLASH空间了,用于定义一批FLASH变量,但实际上一般只能作为常量使用了.心得1图中CSTACK的大小调整大小可在编译后的632 bytes of DATA memory (+ 22 absolute ) 中看到。
用keil生成hex文件
用keil生成hex文件
1、建立mcs51源文件,选择new project建立管理项目
2、选择被仿真的51器件
3、建立源文件
输入汇编语言源程序
4、点击如图图标,对源程序进行编译、链接
在下面的图形中,会显示是否有语法错误,如有着调入源程序改正,如没有则可进行下一步,生成扩展名为“hex”的二进制文件。
5、生成“hex”文件
1)鼠标指向项目文件夹
2)压下鼠标右件,选择如图中的选项,进入
3)在下图中选择,“output”
将Creat HEX File打勾建立“hex”文件,在Name of Executable 给可执行文件取名,在Select Folder for Objects 选择存放路径,然后确定。
4)点击图标再次进行汇编,汇编后即可得到扩展名为“hex”的可执行二进制文件。
ARMIAR如何生成hex.
本文来自网络收集,感谢原创:幻磁帝国IAR EWARM5.20学习笔记(基于LPC2132)---从零起步 --在proteus中仿真运行(幻磁帝国原创)一:创建一个最简洁的工程模板目的:IARM EWARM5.20编程入门,学会怎么用EWARM5.20版来创建自己的工程。
1.1 新建一个空的工程文件夹,这里起名为MyEWARMstartup1.2 新建EWARM工程创建一个空的EWARM工程:点击OK,选择刚才新建的文件夹,工程取名为MyEWARMsartatup,保存。
这样一个本文来自网络收集,感谢原创:幻磁帝国空的新的工程文件就建好了。
1.3 拷贝IAR EWARM安装目录下例程中的启动文件本例用的是LPC2132,顾找到软件安装目录下的LPC213x的例程进去找到config文件夹,这个文件夹中装的就是LPC2132的启动文件可以看到这个文件加下面有四个文件Flash.icf Flash.mac RAM.icf 和 ram.mac。
本文来自网络收集,感谢原创:幻磁帝国暂且不用理会这几个文件的具体内容,只要知道它是启动文件就可以了。
拷贝config文件夹,复制到先前建立的工程文件夹MyEWARMstartup中。
到此,准备工作基本完成。
1.4 工程设置右键点击workspace中的工程名,选择Options,对工程进行相关设置。
再Generral options中选择具体的ARM型号,这里选择LPC2132第二个要设置的选项是Output Converter,即输出文件的设置,这里设置如下,生成hex文件,文件的目录可以直接加到hex文件名前面的。
如:D:\ MyEWARMsartatup.hex本文来自网络收集,感谢原创:幻磁帝国接下来就是至关重要的启动代码的链接设置了,打开Linker选项如下,congfig选项卡中默认是没有勾选Override default的。
这时候就要用到先前我们拷贝的config文件夹中的东东了,也就是启动文件了。
转Keil生成的Hex文件详解
4.项目建好后,这样 的 空项目是无用 的 ,接下来需要给项目添加文件,选中,在弹出对话框里选中“ Add Files to Group
‘ Source G”ro,up如1图’:
转 Keil 生成的 Hex 文件详解
Keil Uv2 生成 Hex 文件详细过程
2009-12-31 15:38:44| 分类: 51单片机 |
步骤: 1.打开 Keil Uv2开发环境 2.现在开始新建项目, Project->New Project,确定项目保存路径,并给新建 项目命名,之后点选“保存”。 。。
5.这时已经可以在新增文件上进行编程,很多奇思异想都可以实现拉,条件是编出来 的程序,机器能识别,不然。 。。嘿嘿。。。
程序编写出来了,直接编译 的 执行程序, 51单片机是不认 的 ,就像对一个只 会中国话 的中国老太太说英语,这就产生了语言障碍,所以还得翻译成“ .hex” 格式文件,那么这里别忘了设置 Target 和 Output 两个属性,如图:
这时再按“ F7”开始编译,如果程序没写错,就能看到 “ Build target ‘Target 1 ’ Compiling
…… –0 Error(s) , 0 Warning(s).” 那么恭喜,你已经 生成 了可以在单片机上跑 的程序了!
单片机C语言第三课生成HEX文件和最小化系统
第三课生成HEX文件和最小化系统在开始C语言地主要内容时,我们先来看看如何用KEIL uVISION2来编译生成用于烧写芯片地HEX文件.HEX 文件格式是Intel公司提出地按地址排列地数据信息,数据宽度为字节,所有数据使用16进制数字表示, 常用来保存单片机或其他处理器地目标程序代码.它保存物理程序存储区中地目标代码映象.一般地编程器都支持这种格式.我们先来打开第一课做地第一项目,打开它地所在目录,找到test.Uv2地文件就可以打开先前地项目了.然后右击图3-1中地1项目文件夹,弹出项目功能菜单,选Options for Target'Target1',弹出项目选项设置窗口,同样先选中项目文件夹图标,这时在Project菜单中也有一样地菜单可选.打开项目选项窗口,转到Output选项页图3-2所示,图中1是选择编译输出地路径,2是设置编译输出生成地文件名,3则是决定是否要创建HEX文件,选中它就可以输出HEX文件到指定地路径中.选好了?好,我们再将它重新编译一次,很快在编译信息窗口中就显示HEX文件创建到指定地路径中了,如图3-3.这样我们就可用自己地编程器所附带地软件去读取并烧到芯片了,再用实验板看结果,至于编程器或仿真器品种繁多具体方法就看它地说明书了,这里也不做讨论.(技巧:一、在图3-1中地1里地项目文件树形目录中,先选中对象,再单击它就可对它进行重命名操作,双击文件图标便可打开文件.二、在Project下拉菜单地最下方有最近编辑过地项目路径保存,这里可以快速打开最近在编辑地项目.)图3-1项目功能菜单图3-2 项目选项窗口图3-3 编译信息窗口或许您已把编译好地文件烧到了芯片上,如果您购买或自制了带串口输出元件地学习实验板,那您就可以把串口和PC机串口相联用串口调试软件或Windows地超级终端,将其波特率设为1200,就可以看到不停输出地"Hello World!"字样.也许您还没有实验板,那这里先说说AT89C51地最小化系统,再以一实例程序验证最小化系统是否在运行,这个最小化系统也易于自制用于实验.图3-4便是AT89C51地最小化系统,不过为了让我们可以看出它是在运行地,我加了一个电阻和一个LED,用以显示它地状态,晶振可以根据自己地情况使用,一般实验板上是用11.0592MHz或12MHz,使用前者地好外是可以产生标准地串口波特率,后者则一个机器周期为1微秒,便于做精确定时.在自己做实验里,注意地是VCC是+5V地,不能高于此值,否则将损坏单片机,太低则不能正常工作.在31脚要接高电平,这样我们才能执行片内地程序,如接低电平则使用片外地程序存储器.下面,我们建一个新地项目名为OneLED来验证最小化系统是否可以工作(所有地例程都可在我地主页下面下载到,网址: 或 ).程序如下:#include <AT89X51.h> //预处理命令void main(void) //主函数名{//这是第一种注释方式unsigned int a; //定义变量a为int类型do{//do while组成循环for (a=0; a<50000; a++); //这是一个循环P1_0 =0; //设P1.0口为低电平,点亮LEDfor (a=0; a<50000; a++); //这是一个循环P1_0 = 1; //设P1.0口为高电平,熄灭LED}while(1);}图3-4 AT89C51最小化系统这里先讲讲KEIL C编译器所支持地注释语句.一种是以"//"符号开始地语句,符号之后地语句都被视为注释,直到有回车换行.另一种是在""符号之内地为注释.注释不会被C编译器所编译.一个C应用程序中应有一个main主函数,main函数可以调用别地功能函数,但其它功能函数不允许调用main函数.不论main函数放在程序中地那个位置,总是先被执行.用上面学到地知识编译写好地OneLED程序,并把它烧到刚做好地最小化系统中.上电,刚开始时LED是不亮地(因为上电复位后所有地IO口都置1引脚为高电平),然后延时一段时间(for (a=0; a<50000; a++)这句在运行),LED亮,再延时,LED熄灭,然后交替亮、灭.第一个真正地小应用就做完,呵呵,先不要管它是否实用哦.如果没有这样地效果那么您就要认真检查一下电路或编译烧写地步骤了.版权申明本文部分内容,包括文字、图片、以及设计等在网上搜集整理.版权为个人所有This article includes some parts, including text, pictures, and design. Copyright is personal ownership.用户可将本文地内容或服务用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律地规定,不得侵犯本网站及相关权利人地合法权利.除此以外,将本文任何内容或服务用于其他用途时,须征得本人及相关权利人地书面许可,并支付报酬.Users may use the contents or services of this article for personal study, research or appreciation, and othernon-commercial or non-profit purposes, but at the same time, they shall abide by the provisions of copyright law and other relevant laws, and shall not infringe upon the legitimate rights of this website and its relevant obligees. In addition, when any content or service of this article is used for other purposes, written permission and remuneration shall be obtained from the person concerned and the relevant obligee.转载或引用本文内容必须是以新闻性或资料性公共免费信息为使用目地地合理、善意引用,不得对本文内容原意进行曲解、修改,并自负版权等法律责任.Reproduction or quotation of the content of this article must be reasonable and good-faith citation for the use of news or informative public free information. It shall not misinterpret or modify the original intention of the content of this article, and shall bear legal liability such as copyright.。
小技巧之实现IAR下S19、Bin、Hex文件格式转换
小技巧之实现IAR下S19、Bin、Hex文件格式转换今天有点小激动,搞了大半年的课题终于有点成果了,眼泪哗哗的,太不容易了,哈哈。
所以趁着心情大好手感大好的时候,抓紧更更博客了。
另外从零入手系列好久没更新了,也有博友问我啥时候更新,哎,大家的热情我还是很感激的,最近一直在搞FPGA 这块,Kinetis 那部分放下一段时间了,不过用不了多长时间就会继续更新了。
其实FPGA 搞了一段时间发现还是搞ARM 更顺手些,习惯了C 的顺序编程,FPGA 的并行编程一时之间还真转不过这个弯来,哈哈~本篇内容自己早就想好了,只不过不是被事耽搁就是手感不好就没有写出来,今天就拿出来说说吧,不然再过段时间就被我尘封在大脑皮层的深处了,呵呵。
其实内容很简单,无非就是对IAR 环境的设置(咳咳,可以说一点技术含量都没有),不过本篇博客核心思想是开阔一下大家的思路原来这样就可以。
另外本篇最后给出了用CW 自带的格式转换工具的用法链接,那部分是从飞思卡尔技术社区的安版主写的,有兴趣的可以去看看。
下面进入正题吧:首先说说这三个文件格式的来头。
bin 文件是我们最常见的二进制文件,它是纯数据文件,也即是所见即所得,所以如果我们想看看需要下载到单片机flash 的数据的大小,最简单的方法就是查看我们编译连接后生成的bin 文件大小;hex 文件则是Intel 很早就推出的一种文件格式(Intel 还是一如既往的很牛逼啊有木有),它除了有效数据信息之外还包含了一些多余信息(包括地址信息,校验码之类的等等信息),所以hex 文件是很大的,而最终下到单片机的flash 里的仍是其中的有效数据段,而其他的信息段则是作为flash 编程软件的辅助信息的(包括地址信息)。
因此我们常见的问题就来了,如果烧写或者下载Bin文件时,软件会弹出首地址框输入相应地址信息,而在烧写Hex 文件的时候则。
Keil生成的Hex文件详解
Keil HEX文件是由一行行符合Intel HEX文件格式的文本所构成的ASCII文本文件。
在Intel HEX文件中,每一行包含一个HEX记录。
这些记录由对应机器语言码和/或常量数据的十六进制编码数字组成。
Intel HEX文件通常用于传输将被存于ROM或者EPROM中的程序和数据。
大多数EPROM编程器或模拟器使用Intel HEX文件。
记录格式Intel HEX由任意数量的十六进制记录组成。
每个记录包含5个域,它们按以下格式排列::llaaaatt[dd...]cc每一组字母对应一个不同的域,每一个字母对应一个十六进制编码的数字。
每一个域由至少两个十六进制编码数字组成,它们构成一个字节,就像以下描述的那样:: 每个Intel HEX记录都由冒号开头.ll 是数据长度域,它代表记录当中数据字节(dd)的数量.aaaa 是地址域,它代表记录当中数据的起始地址.tt 是代表HEX记录类型的域,它可能是以下数据当中的一个:00 –数据记录01 –文件结束记录02 –扩展段地址记录04 –扩展线性地址记录dd 是数据域,它代表一个字节的数据.一个记录可以有许多数据字节.记录当中数据字节的数量必须和数据长度域(ll)中指定的数字相符.cc 是校验和域,它表示这个记录的校验和.校验和的计算是通过将记录当中所有十六进制编码数字对的值相加,以256为模进行以下补足.数据记录Intel HEX文件由任意数量以回车换行符结束的数据记录组成.数据记录外观如下::10 2462 00 464C5549442050524F46494C4500464C 33其中:10 是这个记录当中数据字节的数量.2462 是数据将被下载到存储器当中的地址.00 是记录类型(数据记录)464C…464C是数据.33 是这个记录的校验和.扩展线性地址记录(HEX386)扩展线性地址记录也叫作32位地址记录或HEX386记录.这些记录包含数据地址的高16位.扩展线性地址记录总是有两个数据字节,外观如下::02000004FFFFFC其中:02 是这个记录当中数据字节的数量.0000 是地址域,对于扩展线性地址记录,这个域总是0000.04 是记录类型04(扩展线性地址记录)FFFF 是地址的高16位.FC 是这个记录的校验和,计算方法如下:01h + NOT(02h + 00h + 00h + 04h + FFh + FFh).当一个扩展线性地址记录被读取,存储于数据域的扩展线性地址被保存,它被应用于从Intel HEX文件读取来的随后的记录.线性地址保持有效,直到它被另外一个扩展地址记录所改变. 通过把记录当中的地址域与被移位的来自扩展线性地址记录的地址数据相加获得数据记录的绝对存储器地址.以下的例子演示了这个过程..来自数据记录地址域的地址2462扩展线性地址记录的数据域+ FFFF------------绝对存储器地址FFFF2462扩展段地址记录(HEX86)扩展段地址记录也叫HEX86记录,它包括4-19位数据地址段.扩展段地址记录总是有两个数据字节,外观如下::020*********EA其中:02 是记录当中数据字节的数量.0000 是地址域.对于扩展段地址记录,这个域总是0000.02 是记录类型02(扩展段地址记录)1200 是地址段.EA 是这个记录的校验和,计算方法如下:01h + NOT(02h + 00h + 00h + 02h + 12h + 00h).当一个扩展段地址记录被读取,存储于数据域的扩展段地址被保存,它被应用于从Intel HEX 文件读取来的随后的记录.段地址保持有效,直到它被另外一个扩展地址记录所改变.通过把记录当中的地址域与被移位的来自扩展段地址记录的地址数据相加获得数据记录的绝对存储器地址.以下的例子演示了这个过程..来自数据记录地址域的地址2462扩展段地址记录数据域+ 1200---------绝对存储器地址00014462文件结束(EOF)记录Intel HEX文件必须以文件结束(EOF)记录结束.这个记录的记录类型域的值必须是01.EOF记录外观总是如下::00000001FF其中:00 是记录当中数据字节的数量.0000 是数据被下载到存储器当中的地址.在文件结束记录当中地址是没有意义被忽略的.0000h是典型的地址.01 是记录类型01(文件结束记录)FF 是这个记录的校验和,计算方法如下:01h + NOT(00h + 00h + 00h + 01h).:02 0000 04 0800 F2:10 0000 00 7806002051040008690200086B020008 0D注意:地址是大开端,0800+0000 = 0x0800000078060020是MSP初始值,其实为0x20000678,是小开端。
IAR操作文档
IAR编译器操作文档一、工程建立:打开,进入IAR 工程环境,弹出如下对话框:在此可以选择,新建工程或者打开原来已有的工程,以新建工程为例,点击:弹出如下对话框:按照自己所熟悉的语言选择对应的Project templates (工程模板),在此以C语言为例,点击OK,保存工程,后缀为.ewp;然后进入界面,保存工作组:后缀为.eww;工程建立完毕。
二、基础选项设置:1、选择芯片型号,以0537为例,在工程上点右键,如图选择:点击进入,如下图:0537 flash 有BANK区,选择如下:2、输出HEX文件,步骤一,如下图:人为将.d26改成.hex即可;3、输出map文件:4、debugger 选项:若要硬件仿真,选择如下:若要软件仿真,如下图:三、基本语法1、变量定义:A、saddr区域的定义:__saddr unsigned char xyz;对应map为:SADDR_ZRelative segment, address: FE20 - FE20 (0x1 bytes), align: 0 Segment part 3. Intra module refs: initENTRY ADDRESS REF BYxyz FE20B、扩展RAM区域定义:1)、#pragma dataseg=IXRAM__no_init unsigned char sec_cou; // __no_init 不能少;#pragma dataseg=default外部调用声明:extern __no_init unsigned char sec_cou;或extern unsigned char sec_cou;对应map为:IXRAMRelative segment, address: E000 - E001 (0x1 bytes), align: 0 Segment part 11. Intra module refs: Timer_UserENTRY ADDRESS REF BYsec_cou E000 main2)、typedef struct UartMode{uint8 bytGetOneCmdFlag;uint8 bytGetLen;uint8 bytUartBusyFlag;uint8 bytSourceComm;}UARTMODE;#pragma dataseg=IXRAM__no_init UARTMODE tempdata;#pragma dataseg=defaultTempdata. bytGetOneCmdFlag/ Tempdata. bytGetLen……对应map为:IXRAMRelative segment, address: F000 - F006 (0x7 bytes), align: 0 Segment part 2. Intra module refs: main ENTRY ADDRESS REF BY tempdata F000C、常数定义:#pragma location = "OPTBYTE"__root const unsigned char opbyte[] = {0x7F,0x01,0x00,0x00,0x03};对应map为:OPTBYTERelative segment, address: 0080 - 0084 (0x5 bytes), align: 0 Segment part 7. ROOT.ENTRY ADDRESS REF BYopbyte 00802、BANK 定义:1)常量定义BANK#pragma location = "BANK3"const unsigned int a=1000;对应map为:BANK3Relative segment, address: 00038000 - 00038001 (0x2 bytes), align: 1 Segment part 15. Intra module refs: mainENTRY ADDRESS REF BYa 000380002)函数定义BANK#pragma location = "BANK4"__banked void add_2(void){}外部调用声明:extern __banked void add_2(void); //__banked不能少;对应map为:BANK4Relative segment, address: 00048007 - 00048018 (0x12 bytes), align: 0Segment part 17.ENTRY ADDRESS REF BYadd_2 00048007 main (main) 3)文件定义BANK:在对应的文件上点右键,选择option,如下:如下选择配置:3、中断声明#pragma vector = INTTM000_vect或#pragma vector = 0x0020 __interrupt void Timer_User (void){}4、位变量定义:typedef struct{unsigned char B0:1;unsigned char B1:1;unsigned char B2:1;unsigned char B3:1;unsigned char B4:1;unsigned char B5:1;unsigned char B6:1;unsigned char B7:1;}_MYFLAG;extern __saddr volatile _MYFLAG Flag2_sys; #define Flag1Sec Flag2_sys.B1#define Flag1000ms Flag2_sys.B2#define IS_IR_SEND Flag2_sys.B3#define IR_TX Flag2_sys.B4王工:你好!时钟切换配置见如下://内部8M切换外部主时钟OSCCTL=0X41; //X1振荡模式;/* EXCLK OSCSEL 高速系统时钟引脚操作模式0 0 I/O端口模式0 1 X1振荡模式1 0 I/O端口模式1 1 外部时钟输入模式*/PCC=0X00;MSTOP=0; // 1: X1 stopMCM=0X07; //MCM=5,7 选择高速系统时钟,外部硬件选择高速系统时钟while(!MCS);RSTOP=1; //1: 内部8M停止//内部切换副时钟OSCCTL=0x70;MSTOP=1;PCC = 0;CSS=1;while(CLS);RSTOP=1;王工:您好!多谢支持!您的例程有两种:1 内部8M切换外部主时钟2 内部切换副时钟我还需要“外部主时钟切换到内部8M”,不知道能否实现?。
单片机烧录文件HEX文件格式说明
HEX文件格式说明在我讲解《微型计算机控制技术》的时候,一个学生问我关于HEX的内容解释时,我的解释不够清晰,感觉不太,我下课后立刻上网查找收集资料,并且整理如下,同时发给学生一份。
整理如下:概念描述HEX文件格式是一种能够烧写到单片机中,被单片机执行的文件格式。
可以使用不同的编辑器将C 或汇编源文件编译成HEX文件,如IAR,KEIL等。
Hex文件是遵循Hex文件格式的ASCII文本文件。
在Hex文件的每一行中都包含了一个hex记录。
这些记录是由一些代表机器语言代码和常量的16进制数据组成。
Hex文件常用来传输要存储在ROM、EPROM或者Flash中的程序和数据。
大部分的EPROM编程器都能使用Hex文件。
格式介绍Hex由任意数量的十六进制记录组成。
每个记录包含6个域,它们按下列格式排列。
| MARK | RECLEN | OFFSET | RECTYP | DA TA | CHKSUM |,实际表示如下例1::04010C00303230005D用以下表1解释上述格式:1Byte(8 bit)用表 1 HEX格式组成| MARK |——(1Byte)Start Code(冒号):每个HEX记录都由冒号开头;| RECLEN |——(1Byte)Byte count(本行数据长度):是数据长度域,它代表记录中数据的字节量,如例1中的04表示本条记录中有4个字节的数据;| OFFSET |——(2 Byte)Address(本行数据的起始地址):是地址域,它代表记录当中数据的起始地址;如例1中的010C表示本条记录中第一个数据30的地址为010C。
| RECTYP |-----> (1 Byte)Record type(数据类型):是代表HEX记录类型的域,它可能是以下数据当中的一个:例子中的00表示该行为数据记录。
表 2 数据类型对照表| DATA |——(n Byte)Data(数据):是数据域,一个记录可以有许多数据字节.记录当中数据字节的数量必须和数据长度域中指定的数字相符;最多0xFF个。
KEIL里如何生成HE文件
KEIL里如何生成HE文件Keil是一款广泛应用于嵌入式系统开发的集成开发环境(IDE),它可以用于多种微控制器平台的软件开发。
在Keil中生成HEX文件是非常常见的操作,HEX文件是一种可以由微控制器系统直接加载和执行的文件格式。
下面将介绍如何在Keil中生成HEX文件。
首先,在Keil中创建一个新的工程或打开一个已有的工程。
在工程文件夹中,可以看到一个名为“.uvproj”的工程文件,双击打开该文件进入Keil工程界面。
接下来,点击菜单栏上的“Project”选项,然后选择“Options for Target 'Target1'”(其中的'Target1'是目标设备的名称,可能因工程而异,可以根据实际工程情况进行选择)。
选项对话框中会展示一系列的选项和设置,其中有一个叫做“Output”或“输出”的选项。
在这个选项下,可以选择代码生成器的输出格式。
对于生成HEX文件,需要确保选择了可执行文件格式为HEX文件。
在代码生成器的输出格式选项中,可能还会有一些列的子选项,比如选择HEX文件的存储路径和文件名等。
在这些选项中,可以设置HEX文件保存的路径和名称,可以根据需要进行自定义。
通常,HEX文件的名称会和工程名称以及生成的可执行文件名称相关联,以便于在工程文件夹中进行识别和管理。
设置完以上选项后,点击确定,保存更改,然后重新编译工程。
编译过程完成后,可以在指定保存路径中找到生成的HEX文件。
此外,在Keil中还可以通过在工程文件上点击右键,选择“Open in Windows Explorer”或“在Windows资源管理器中打开”(可能因Keil版本而异)来直接打开工程所在的文件夹。
在文件夹中,可以找到生成的HEX文件以及其他相关的编译输出文件。
总结来说1.创建工程或打开已有工程;2. 进入“Project” -> “Options for Target 'Target1'”;3. 在选项对话框中找到“Output”或“输出”选项;4.设置可执行文件格式为HEX文件,并设置HEX文件的保存路径和名称;5.保存设置,重新编译工程;6.在指定保存路径中找到生成的HEX文件。