16进制Motorola S-records 文件格式
S12 BootLoader中文
data:image/s3,"s3://crabby-images/ef4da/ef4daf1914656fed9519dcadffae2c43a63444e7" alt="S12 BootLoader中文"
两次下载的概念:
• • •
接受Host传来的程序到RAM中并运行(其实是接受Bootloader); RAM中刚收到的Bootloader负责来更新代码或数据; 最小的Boot程序和最大的灵活性.
Freescale Semiconductor Confidential and Proprietary Information. Freescale™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. © Freescale Semiconductor, Inc. 2006.
T
BootLoader的一般工作原理
主 控 程 序 主机端 目标文件解释程序 命令生成程序 通信程序 其它程序 主 控 程 序 引导程序 通信程序 目标文件解释程序 命令解释程序 NVM编程擦除程序
ECU ECT端
SCI / CAN
Freescale Semiconductor Confidential and Proprietary Information. Freescale™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. © Freescale Semiconductor, Inc. 2006.
Mot文件格式介绍
data:image/s3,"s3://crabby-images/3ba94/3ba94501028555eb523f6a26133137ad0e80ed6f" alt="Mot文件格式介绍"
mot文件单片机常用输出格式:--Motorola S-records(S19文件)Motorola S-records16进制文件格式是嵌入式中除intel hex之外很常见的格式,下面是它的格式:+-------------------//------------------//-----------------------+| type(hex1) | count(hex 1) | address | data | checksum(从count累加到checksum,总和为0xFF) |+-------------------//------------------//-----------------------+∙S0 :标识记录,地址域长度为2个字节,并用0000填充,数据区记录了一些模块名称和版本之类的信息∙S1 :数据记录,地址域长度为2个字节,数据区域为数据内容。
∙S2 :数据记录,地址域长度为3个字节,数据区域为数据内容。
∙S3 :数据记录,地址域长度为4个字节,数据区域为数据内容。
∙S5 :统计记录,地址域长度为2个字节,内容是之前数据记录(S1,S2,S3)的个数,数据区域空。
∙S7 : 运行记录,地址域长度为4个字节,内容是程序启动的地址,数据域空。
∙S8 :运行记录,地址域长度为3个字节,内容是程序启动的地址,数据域空。
∙S9 :运行记录,地址域长度为2个字节,内容是程序启动的地址,数据域空。
下面是一个例子,大家看看:S02B0000433A5C446F63756D656E747320616E642053657474696E67735C7A6F75642E 4143434F554E54535C7DS208010000FFFFFFFFFAS30800020000000000F5S5030002FAS9030000FC第一行:没什么,开个头而已。
第二行:地址0x10000有4个0xFF第三行:地址0x20000有3个0x00第四行:标明之前有两条数据记录第五行:程序从0x0000地址开始运行关于checksum的算法和intel hex不太一样,checksum = 0xFF - (从count段开始所有字节的总和)。
S19文件格式详解
data:image/s3,"s3://crabby-images/57870/578700596f96592c44249dc211b81bcc76d22d68" alt="S19文件格式详解"
S19文件格式详解S-record格式文件是Freescale CodeWarrior编译器生成的后缀名为.S19的程序文件,是一段直接烧写进MCU的ASCII码,英文全称问Motorola format for EEPROM programming。
【注意:编者】:上面“是一段直接烧写进MCU的ASCII码”,这样说可能会误导初学者,因为并不是直接将ASCII码写进MCU,写进MCU前还要对S19文件进行一个解析,把有用的机器代码分解出来,然后再进行写入,写入的也不是ASCII而是二进制码。
网上有关S-record格式文件的资料很少,经过我的收集和实验,整理出以下文档,方便大家对Freescale单片机做深入了解。
1、格式定义及含义S-record每行最大是78个字节,156个字符S-record formattype(类型):2个字符。
用来描述记录的类型 (S0,S1,S2,S3,S5,S7,S8,S9)。
count(计数):2个字符。
用来组成和说明了一个16进制的值,显示了在记录中剩余成对字符的计数。
address(地址):4或6或8个字节。
用来组成和说明了一个16进制的值,显示了数据应该装载的地址,这部分的长度取决于载入地址的字节数。
2个字节的地址占用4个字符,3个字节的地址占用6个字符,4个字节的地址占用8个字符。
data(数据):0—64字符。
用来组成和说明一个代表了内存载入数据或者描述信息的16进制的值。
checksum(校验和):2个字符。
这些字符当被配对并换算成16进制数据的时候形成了一个最低有效字符节,该字符节用来表达作为补充数据,地址和数据库的字符对所代表的(字节的)补码的byte总和。
即计数值、地址场和数据场的若干字符以两个字符为一对,将它们相加求和,和的溢出部分不计,只保留最低两位字符NN,checksum =0xFF-0xNN。
S0 Record:记录类型是“S0” (0x5330)。
16进制数据的几种格式
data:image/s3,"s3://crabby-images/fd714/fd714959d4996e2e5855c5022af2b38695319607" alt="16进制数据的几种格式"
16进制数据的几种格式(实用版)目录1.16 进制数据的基本概念2.16 进制数据的几种格式3.16 进制数据的应用场景正文1.16 进制数据的基本概念16 进制数据,顾名思义,是一种以 16 为基数的数制系统。
在计算机科学中,16 进制数据主要用于表示颜色值、整数以及字符等。
与 10 进制和 2 进制相比,16 进制更加直观易读,因此在很多编程语言和数据处理场景中得到了广泛应用。
16 进制数的基数为 16,每位数可以使用 0-9 和 A-F 的字符表示,其中 A-F 代表 10-15。
2.16 进制数据的几种格式16 进制数据主要有以下几种格式:(1) 十六进制字符串:这是最常用的一种 16 进制数据表示形式。
在十六进制字符串中,每两位字符代表一个 16 进制数,如"1A"表示十进制的 26。
十六进制字符串可以用于表示颜色值(如#00FFFF 表示蓝色)、整数(如 1A 表示 26)等。
(2) 十六进制整数:十六进制整数与十六进制字符串类似,只不过它只包含数字,没有字母。
例如,十六进制整数"1A"表示十进制的 26。
(3) 十六进制颜色值:这是一种特殊的十六进制数据表示形式,主要用于表示颜色。
在十六进制颜色值中,每两位字符代表一个颜色通道的值(如红、绿、蓝等)。
例如,十六进制颜色值"#00FFFF"表示蓝色,其中"#"符号表示颜色值,"00"表示红色的最小值,"FF"表示红色的最大值,"FF"表示蓝色的最大值,"00"表示蓝色的最小值。
3.16 进制数据的应用场景16 进制数据在计算机科学中有广泛的应用,主要包括以下几个方面:(1) 配置文件:很多软件和操作系统的配置文件采用十六进制数据表示,以便于程序员直接修改和调试。
例如,Windows 操作系统的注册表就是以十六进制数据格式存储的。
hex 格式解析
data:image/s3,"s3://crabby-images/3eefc/3eefcd4a5f73e6452573e570f5be905e2f30fe9c" alt="hex 格式解析"
hex 格式解析HEX格式是一种常用的二进制文件格式,主要用于存储程序和数据。
它是一种文本文件,由一行行符合HEX文件格式的文本组成。
在这些文本中,每一行包含一个HEX记录。
这些记录由对应机器语言码和/或常量数据的十六进制编码字节组成。
HEX文件通常用于传输将被存储在ROM或EPROM中的程序和数据。
大多数EPROM编程器或仿真器使用HEX文件。
HEX文件格式主要有两种:Intel HEX和Motorola SREC(也称为Mot)。
Intel HEX文件由一行行符合Intel HEX文件格式的文本组成。
在Intel HEX文件中,每一行包含一个HEX记录。
这些记录由对应机器语言码和/或常量数据的十六进制编码字节组成。
Motorola SREC文件则是另一种HEX格式,它按照不同的编码方式组织数据。
要解析HEX文件,可以将其拆分成以下几个部分:1. 文件头:文件头包含文件类型、版本和起始地址等信息。
文件头通常位于文件的开头,用于指示文件的类型和结构。
2. 数据记录:数据记录是HEX文件中的基本单元,包含机器语言码和/或常量数据的十六进制编码字节。
每一行都是一个数据记录,它们按照顺序排列在文件中。
3. 数据记录之间的分隔符:HEX文件中的数据记录之间使用分隔符进行分隔。
常见的分隔符有:空格、制表符(TAB)、换行符(CR)等。
4. 文件尾:文件尾是HEX文件的最后一个部分,它表示文件的结束。
文件尾通常包含一个表示文件结束的特定字符或字节序列。
在解析HEX文件时,需要关注以下几个方面:1. 确定文件类型和格式:根据文件头信息,判断文件的类型和格式。
2. 提取数据记录:从文件中提取数据记录,解析记录中的机器语言码和常量数据。
3. 处理记录之间的分隔符:去除记录之间的分隔符,以便将数据记录合并为一个连续的数据流。
4. 检查文件尾:确认文件是否完整,以及文件尾是否正确。
5. 分析数据:根据解析出的数据记录,分析文件中的程序和数据。
motorola协议格式
data:image/s3,"s3://crabby-images/e6dd9/e6dd95c7d3b6ba22dd568f8d1f911d9fd177b3ad" alt="motorola协议格式"
Motorola协议格式是一种常见的通信协议格式,它采用大端(Big Endian)方式进行数据传输。
在这种格式下,数据的最高位(Most Significant Bit,MSB)被放置在传输序列的开头,而最低位(Least Significant Bit,LSB)被放置在传输序列的末尾。
例如,如果要在CAN数据帧中发送一个16位的数值,采用Motorola格式进行发送的顺序应该是先发送高字节(MSB),然后发送低字节(LSB)。
如果这个数值是0x1234,那么按照Motorola格式发送的顺序应该是0x12和0x34。
需要注意的是,不同的硬件和通信协议可能会采用不同的字节序方式进行数据传输,因此在解析CAN数据时,应该先确认所使用的通信协议的字节序方式,以便正确地解析和解释数据。
mot文件解析
data:image/s3,"s3://crabby-images/01de6/01de65311219bad689d8fc731465971ce0cacc8a" alt="mot文件解析"
mot文件格式2010-12-03 17:05单片机常用输出格式--Motorola S-records(S19文件)Motorola S-records 16进制文件格式是嵌入式中除intel hex之外很常见的格式,下面是它的格式:+-------------------//------------------//-----------------------+| type(hex1) | count(hex 1) | address | data | checksum(从count累加到checksum,总和为0xFF) |+-------------------//------------------//-----------------------+S0 :标识记录,地址域长度为2个字节,并用0000填充,数据区记录了一些模块名称和版本之类的信息S1 :数据记录,地址域长度为2个字节,数据区域为数据内容。
S2 :数据记录,地址域长度为3个字节,数据区域为数据内容。
S3 :数据记录,地址域长度为4个字节,数据区域为数据内容。
S5 :统计记录,地址域长度为2个字节,内容是之前数据记录(S1,S2,S3)的个数,数据区域空。
S7 : 运行记录,地址域长度为4个字节,内容是程序启动的地址,数据域空。
S8 :运行记录,地址域长度为3个字节,内容是程序启动的地址,数据域空。
S9 :运行记录,地址域长度为2个字节,内容是程序启动的地址,数据域空。
下面是一个例子,大家看看:S02B0000433A5C446F63756D656E747320616E642053657474696E67735C7A6F75642E4143434F554E54535C7DS208010000FFFFFFFFFAS30800020000000000F5S5030002FAS9030000FC第一行:没什么,开个头而已。
第二行:地址0x10000有4个0xFF第三行:地址0x20000有3个0x00第四行:标明之前有两条数据记录第五行:程序从0x0000地址开始运行关于checksum的算法和intel hex不太一样,checksum = 0xFF - (从count段开始所有字节的总和)。
十六进制文件格式
data:image/s3,"s3://crabby-images/f229a/f229a2b58244ff93e77086c3596acfb633703f00" alt="十六进制文件格式"
十六进制文件格式HEX格式内容含义HEX文件格式是我们经常遇到的一种文件格式,因为几乎所有的编程烧录文件都为HEX格式。
首先,HEX文件中是包含了地址信息的。
这和BIN文件不同,BIN文件中只包含了数据信息。
所以我们在烧写或者下载HEX文件的时候,一般不需要我们指定地址,但是在烧写BIN 文件的时候,用户是一定要指定地址信息的。
二、HEX文件都是由记录组成的。
它的每一行都是一个记录来的。
它是由任意数量的十六进制数组成。
每个记录包含五个域,它们以以下格式排列的::aabbbbcc[dd…]ee上面每一组不同的字母代表不同的一个域,每个字母代表一个十六进制的数字,每一个域至少由两个十六进制编码数字组成,每两个十六进制编码数字组成一个字节。
具体描述如下:1、每个HEX记录都由冒号开头;2、aa表示这个记录中的数据长度域,它代表记录当中数据字节[dd…]的字节数量。
3、bbbb是地址域,它代表记录当中数据的起始地址。
4、cc 是代表HEX记录类型的域,它可能是以下数据当中的一个:00 –数据记录01 –文件结束记录02 –扩展段地址记录04 –扩展线性地址记录5、dd 是数据域,它代表一个字节的数据,一个记录可以有许多数据字节。
记录当中数据字节的数量必须和数据长度域(aa)中指定的数字相符。
6、ee 是校验和域,它表示这个记录的校验和。
校验和的计算是通过将记录当中所有十六进制编码数字对的值相加,以256为模进行以下补足。
比如:前面AduC7026的LED实验中的HEX文件内容为::020*********F2 。
1:1000000018F09FE518F09FE518F09FE518F09FE5C0 。
2:1000100018F09FE50000A0E118F09FE518F09FE5BB:100020004000080074030800700308006C03080017:100030006803080000000000640308006003080073:1000400078009FE50110A0E3041480E50110A0E30F:10005000081480E5F410A0E30C1480E560009FE52F:10006000DBF021E300D0A0E1040040E2D7F021E37F:1000700000D0A0E1040040E2D1F021E300D0A0E1F3:10008000040040E2D2F021E300D0A0E1800040E291:10009000D3F021E300D0A0E1040040E210F021E31E:1000A00000D0A0E11C009FE5010010E318E09F05CF:1000B00018E09F1510FF2FE1FEFFFFEAFEE7C046A4:1000C0000000FFFF900401003D010800B800080097:1000D000BD0008000000000000000000000000005B:1000E00000000000AA2108480160012107480160C2:1000F0005522074802600748016000210648016058:10010000F4210648016070471004FFFF1404FFFF4C:100110001804FFFF0404FFFF0804FFFF0C04FFFFA7:1001200004E005490A1C0139002AFBD1011C0138F1:100130000029F6D17047C046E8030000664806C8AB:100140000B1C134305D000230B70491C9142FBD1BB:10015000F5E76248C01C0323984306C80B1C1343F1:1001600006D00378401C0B70491C9142F9D1F1E78D:1001700000B5FFF7B7FFF0235948016899430160C4:10018000584A59480168114301600F2457480168D3:10019000A1430160564C5748016821430160534810:1001A0000168994301605348016811430160524A54 :1001B0004E48016891430160504A4E48016811431E :1001C00001604F4A49480168914301604D4A4948DE :1001D0000168114301604C4A4C4801689143016039 :1001E0004B4A4C480168114301604B4A474801683B :1001F00091430160494A4748016811430160484AF8 :100200004248016891430160464A424801681143EF :1002100001604549454801604548FFF781FF454970 :10022000454801604248FFF77BFF3F494248016073 :100230003F48FFF775FF41493F4801603C48FFF7E1 :100240006FFF3F493C4801603948FFF769FF3D496E :100250003D4801603648FFF763FF3C493A4801607A :100260003348FFF75DFF3A49374801603048FFF7F0 :1002700057FF2D49374801602D48FFF751FF2D49A1 :10028000354801602A48FFF74BFF27493248016093 :100290002748FFF745FF29492F4801602448FFF709 :1002A0003FFF27492C4801602148FFF739FF2549C6 :1002B0002A4801601E48FFF733FF244927480160A0 :1002C0001B48FFF72DFF2249244801601848FFF71B :1002D00027FF9EE700BDC046D4000800DC000800F0 :1002E00000F4FFFF0000000220F4FFFF0CF4FFFF0A :1002F0000000000150F4FFFF000F000000000004A8 :1003000000F000000000000800000F0008F4FFFFEC :100310000000001040F4FFFF0000F000000000208B :100320000000000F000000400000020024F4FFFF66 :100330002C0100000000010054F4FFFF0000040045 :10034000000008000000100044F4FFFF000020003F :100350000000400028F4FFFF58F4FFFF48F4FFFFBF:10036000FEFFFFEAFEFFFFEAFEFFFFEAFEFFFFEAF5:08037000FEFFFFEAFEFFFFEAB9:00000001FF它的第二行为::1000000018F09FE518F09FE518F09FE518F09FE5C0容易知道:它的ee为:C0,计算过程如下:C0=0x01+not(0x10+0x00+0x00+0x00+0x18+0xF0+…+0xE5)文件结束(EOF)记录Intel HEX文件必须以文件结束(EOF)记录结束.这个记录的记录类型域的值必须是01.EOF记录外观总是如下::00000001FF其中:00 是记录当中数据字节的数量。
IAR Embedded Workbench用户指南
data:image/s3,"s3://crabby-images/d3f03/d3f030029b14308468dfe8c4b4ae357eeb176b36" alt="IAR Embedded Workbench用户指南"
IAR Embedded Workbench用户指南IAR Embedded Workbench for ARM是IAR Systems公司为ARM微处理器开发的一个集成开发环境(下面简称IAR EWARM)。
比较其他的ARM开发环境,IAR EWARM具有入门容易、使用方便和代码紧凑等特点。
故在这里介绍给打算学习使用或正在使用ARM 芯片的朋友们共同探讨。
IAR Systems公司目前推出的最新版本是IAR Embedded Workbench for ARM version 4.30,并提供一个32k代码限制、但没有时间限制的免费评估版。
有兴趣的朋友可以到IAR 公司的网站/ewarm或南京万利电子的网站(本地网站)去寻找和下载。
IAR EWARM中包含一个全软件的模拟程序(simulator)。
用户不需要任何硬件支持就可以模拟各种ARM内核、外部设备甚至中断的软件运行环境。
从中可以了解和评估IAR EWARM的功能和使用方法。
我们编译整理的这本快速用户指南采用评估版软件安装目录C:\Program files\IAR System\Embedded workbench 4.0\ARM\tutor下的教程为例,一步一步介绍 IAR EWARM 的使用方法。
该教程采用了两个C语言程序,tutor.c 和utilities.c。
它们不和任何特定的硬件关联,所以介绍中的全部操作都是用模拟程序完成的。
如果用户已经购买了IAR的JTAG 仿真器J-Link,则可以在真实的目标板上运行。
IAR EWARM的主要特点如下:z高度优化的IAR ARM C/C++ Compilerz IAR ARM Assemblerz一个通用的IAR XLINK Linkerz IAR XAR和XLIB建库程序和IAR DLIB C/C++运行库z功能强大的编辑器z项目管理器z命令行实用程序z IAR C-SPY调试器(先进的高级语言调试器)下面我们分步介绍如何使用IAR EWARM一.生成一个新项目EWARM是按项目进行管理的,它提供了应用程序和库程序的项目模板。
汽车诊断K线的特点
data:image/s3,"s3://crabby-images/668ea/668ea33891b74636def6d84e1be83fee673f3ebe" alt="汽车诊断K线的特点"
汽车诊断K线的特点1、诊断K线通讯特点根据SAE规定的OBD标准,车辆行业使用K、L线进行诊断和标定。
通过K线对某个控制单元进行查询,通过K线、测试仪和控制单元可进行数据交换。
换句话说,即通过K线数据被双向传送(从测试仪到控制单元以及从控制单元到测试仪)。
最近生产的车上都装有K线。
而L线则是用来对控制单元进行查询的导线,此线在目前生产的车辆中已经不存在。
由于串口的普及,所以K线实现起来更容易。
而逻辑电平的改变,只是需要转换电路。
因此本系统采用K线的通讯方式。
由于K线只是一根线,而PC机与控制单元都要向对方发出信息,所以可以判定此线是半双工串行通讯。
K线通讯主要有以下特点:(1) 双方采用半双工异步串行通讯。
(2) 工作电压范围为8~18V。
(3) 使用环境温度为-40°C~125°C。
(4) 最大速度是50kbps。
(5) 支持大电流。
(6) 与单片机CMOS电平无缝连接。
(7) 具有对地线保护作用。
(8) 串行通讯码的每个单元包括10位二进制数据,分别为起始位、8位数据、停止位,每个单元发送完毕后设有空闲等待。
(9) 双方的通讯以“行”为单位轮流发送,即PC机发送一行消息后,ECU再发送一行消息,反之亦然。
(10) 一信息行由下列数据组成:第一位数据表示本行还要发送多少数据;第二个数据用来表示关键码,表示此次用来完成什么样的操作,如开始参数、写数据到EEPROM中等;第三个数据表示要发送的数据。
(11) 在一信息行中,还包括用于校验的反码,一方每发出一个数据后,对方必须对回应此数据的反码进行校验;由于K线是单线通讯,所以只有在正确处理回应数据的反码进行校验时,才能保证通讯的顺利进行。
(12) 至于PC机在每一个功能块中如何发出命令,ECU是如何给出相应信息的,在软件结构中会做说明。
2、K线通讯定义在车辆网络中,为准确、可靠地通讯,必须确定一个固定的通讯波特率。
假设诊断设备及其连接导线的电容为C TE,K线对地电容为C OBW,车辆ECU的电容为C ECU,定义为:设计时以上各电容必须满足以下关系:12V电源供电:C ECU+C OBW≤7.2nF;C TE≤2nF;24V电源供电:C ECU+C OBW≤5nF;C TE≤2nF。
十六进制打印格式
data:image/s3,"s3://crabby-images/7ee55/7ee5511f51c6d57d5abda03402913399aa25a7fd" alt="十六进制打印格式"
十六进制打印格式在计算机科学和编程领域中,十六进制打印格式是一种常用的数据显示格式。
十六进制数是一种在数值表示中使用16个符号(0-9和字母A-F)的方法。
十六进制打印格式广泛应用于调试和数据处理的场景。
本文将介绍十六进制打印格式的概念、用途以及如何使用。
一、概述十六进制打印格式是指将数据以十六进制的形式进行显示和打印。
相比于十进制,十六进制打印格式更加紧凑,便于观察和分析二进制数据。
在计算机内部,数据存储和传输经常使用二进制表示,但对于人类来说,二进制表示并不直观。
因此,将二进制数据转换为十六进制,可以更好地理解和分析数据。
二、应用场景十六进制打印格式在各种编程语言、软件开发工具以及硬件外设的调试中广泛应用。
以下是一些常见的应用场景:1. 调试信息显示:在软件开发中,程序员可以使用十六进制打印格式显示程序中的变量和内存数据,便于观察程序运行时的数据变化。
2. 网络数据分析:在网络通信中,数据往往以二进制形式传输。
使用十六进制打印格式可以更好地观察和分析网络数据包的内容和结构。
3. 文件解析:对于二进制文件,使用十六进制打印格式可以更好地理解文件的结构,从而方便进行解析和处理。
4. 嵌入式开发:在嵌入式系统开发中,硬件设备的寄存器或传感器采集的数据常以十六进制格式输出,开发人员可以通过观察这些数据来验证硬件功能和调试程序。
三、使用方法在不同的编程语言和工具中,使用十六进制打印格式的方法略有不同。
下面是一些常见的方法:1. printf函数:在C语言中,可以使用printf函数并指定格式化字符串为"%x"来将数据以十六进制形式打印出来。
例如,可以使用printf("%x", num) 来以十六进制打印变量num的值。
2. 调试工具:许多IDE(集成开发环境)和调试工具都提供了以十六进制形式显示数据的功能。
例如,GDB是一个常用的调试器,可以使用其命令"print /x num"来以十六进制显示变量num的值。
GP系列刷机升级方法
data:image/s3,"s3://crabby-images/37ad7/37ad7dba41b48a5a222c131fb4883498740e6f6c" alt="GP系列刷机升级方法"
转GP系列刷机升级方法本人于上月购买GP338PULS的机器,自己是一个MOTO控,因为没有扩频和手置,一直在研究,现在研究的扩频部分基本没有问题,手置还在研究中,自己研究的成果不敢独享,其中也包括了真正HAM的无私帮助和指导。
我慢慢放教材和帖子出来。
希望不对的地方广大HAM给你指正修改和没有修改的338刷机文件.rar (10.04 KB) 下载次数: 0GPXX扩频刷机软件.rar (126.08 KB) 下载次数: 188S和328 332 都可以用这个软件进行刷机升级,还是说明一点,刷机有风险,用了扩频文件后机器要上综测调整,请HAM注意。
我这样的做法我相信会得到大家的支持。
我只是搞技术的。
对于MOTO只是爱好。
没有涉及到经济方面,我希望让HAM都得到实惠和技术。
大家共同学习。
如有不对请大家包涵还要说明的是,这些研究成果不是我一个人,其中感谢南京的陈哥,铁岭的朋友(排名不分先后)。
谢谢大家还是希望下载的朋友留一个言,这样是对我辛勤劳动的肯定,谢谢THANK YOU发帖后很多HAM文我怎么用,哎~我把切图给大家。
先连接你的88s或者328 338 等设备到电脑。
运行GPXX扩频刷机软件.exe点击选择你的端口号,如果是323的就是COM1或者COM2,USB的就是其他端口,这个设置一下点击第一个菜单,选择需要的写入文件。
你们下载的文件里面有源文件或者是扩频后的文件。
点击选择子菜单第2个,就可以写入对讲机了。
等写入完成后,重启一下对讲机,就ok了。
本软件适用范围,88S 338 328 小码片数据丢失,88S 338 328 扩频。
有个区域使用的问题,你该asia软件里面有,修改为亚洲的就OK了郑重说明一下,刷机要慎重。
我下载了这个软件,也写了,频是扩了,但也出现了问题,机器只能发,不能收。
楼主很热心,通过远程帮了我很多,但问题一直没解决,今天在本地找了一个朋友帮助看了一下,他说是由于新版与旧版的问题,我的机器是旧版的,但楼主给的软件是新版版的,所以写完后就出问题了。
S19与HEX文件格式解析
data:image/s3,"s3://crabby-images/9f310/9f3106441432ce67b5069c50f93140f64e8c3663" alt="S19与HEX文件格式解析"
S19格式与HEX格式详解2019.03 S19 与 HEX文件中的所有字节都是可打印的 ASCII 字符,可用任何文本编辑器打开查看S19S-record格式文件是Freescale CodeWarrior编译器生成的后缀名为.S19的程序文件,是一段直接烧写进MCU的ASCII码,英文全称问Motorola format for EEPROM programming。
S19 格式是每一行为一个记录,每个记录由 6 个部分组成,除起始代码外,均用十六进制数大端格式表示:1.起始代码:一个大写字母“S”,表示一个新记录的开始。
2.记录类型:1 个十六进制位,取值 0~9,定义记录块的类型,详见下文。
3.字节数:2 个十六进制位,表示地址、数据、校验和的总字节数。
4.地址:4, 6 或 8 个十六进制位,具体的长度由记录类型决定,表示本条记录在内存中的起始地址。
5.实际数据:2n 个十六进制字符,n 为前面指定的字节数的值减去地址和校验和的长度。
6.校验和:2 个十六进制字符,为字节数、地址和实际数据的所有字节(两个十六进制位)的和对 0xFF 取模,再求反码得到。
一个完整的MOTOROLA S-Record格式数据包含如下区域:<type> <length> <address> <data> <checksum>各字段的意思分别如下:<type>:标示记录的类型,该字段占据1-byte。
它可以有如下数值:“S0”, “S1”, “S2”, “S3”, “S5”, “S7”, “S8” , “S9”“S0” -- 记录描述信息“S1”, “S2”, “S3” -- 记录存储的数据。
这三者的区别在于地址(address)的长度不同,S1为2-byte,S2为3-byte,以及S3为4-byte。
“S5” -- 包含了“S1”, “S2”, “S3”的信息。
s19文件格式说明
data:image/s3,"s3://crabby-images/d3f9c/d3f9c6d3e41f73e5ecfd8ee6dff9dd7f926ddae3" alt="s19文件格式说明"
S-record格式文件是Freescale CodeWarrior编译器生成的后缀名为.S19的程序文件,是一段直接烧写进MCU的ASCII码,英文全称问Motorola format for EEPROMprogramming。
1、格式定义及含义S-record每行最大是78个字节,156个字符S-record formattypetype(类型):2个字符。
用来描述记录的类型(S0,S1,S2,S3,S5,S7,S8,S9)。
count(计数):2个字符。
用来组成和说明了一个16进制的值,显示了在记录中剩余成对字符的计数。
address(地址):4或6或8个字节。
用来组成和说明了一个16进制的值,显示了数据应该装载的地址,这部分的长度取决于载入地址的字节数。
2个字节的地址占用4个字符,3个字节的地址占用6个字符,4个字节的地址占用8个字符。
data(数据):0—64字符。
用来组成和说明一个代表了内存载入数据或者描述信息的16进制的值。
checksum(校验和):2个字符。
这些字符当被配对并换算成16进制数据的时候形成了一个最低有效字符节,该字符节用来表达作为补充数据,地址和数据库的字符对所代表的(字节的)补码的byte总和。
即计数值、地址场和数据场的若干字符以两个字符为一对,将它们相加求和,和的溢出部分不计,只保留最低两位字符NN,checksum =0xFF-0xNN。
S0 Record:记录类型是“S0” (0x5330)。
地址场没有被用,用零置位(0x00)。
数据场中的信息被划分为以下四个子域:name(名称):20个字符,用来编码单元名称ver(版本):2个字符,用来编码版本号rev(修订版本):2个字符,用来编码修订版本号description(描述):0-36个字符,用来编码文本注释此行表示程序的开始,不需烧入memory。
S1 Record:记录类型是“S1” (0x5331)。
4.3.1U-Boot代码结构分析
data:image/s3,"s3://crabby-images/20fa0/20fa0cfec79e228aee7f58ebe255b3fcd771cbec" alt="4.3.1U-Boot代码结构分析"
4.3.1U-Boot代码结构分析4.3 Bootloader之U-BootU-Boot是在PPC-Boot的基础上进化⽽来的⼀个开放源码的嵌⼊式BootROM程序,本⼩节将使⽤1.1.4版本的代码来分析U-Boot的代码结构,以及如何将它移植到基于S3C2410X的开发板上来。
4.3.1 U-Boot代码结构分析U-Boot4-9所⽰。
board:这个⽬录存放了所有U-Boot⽀持的⽬标板的⼦⽬录,如board/smdk2410/*就和我们的开发平台fs2410相类似。
要将U-Boot移植到⾃⼰的S3C2410X⽬标板上,必须参考这个⽬录下的内容,⽐如对Flash 以及Flash宽度和⼤⼩的定制等就要修改其中的flash.c。
cpu:这个⽬录存放了U-Boot⽀持的CPU类型,因为我们的开发平台是S3C2410X,所以只关⼼cpu/arm920t,CPU相关的⽂件主要是初始化⼀个执⾏环境,包括中断的初始化;start.S是整个u-boot.bin ⽬标可执⾏代码的第⼀段代码,它们是从Flash开始运⾏的,其主要⼯作就是对整个U-Boot⽬标代码的重定位,即将U-Boot转移到内存中去运⾏。
common:这个⽬录存放了U-Boot的⼀些公共命令的实现,像那些以cmd_*.c为名字的⽂件就是对应U-Boot的每个命令的实现代码,我们通常关⼼cmd_boot.c和cmd_bootm.c(它们和内核的引导相关)。
drivers:这个⽬录中存放了各种外设接⼝的驱动程序。
fs:这个⽬录中存放了U-Boot⽀持的⽂件系统。
lib_arm:这个⽬录存放了ARM平台公共的接⼝代码。
include:这个⽬录存放头⽂件的公共⽬录,其中的include/configs/smdk2410.h定义了所有和S3C2410X 相关的资源的配置参数,我们往往只需修改这个⽂件就可以配置⽬标板的参数,如波特率、引导参数、物理内存映射等。
CAN总线常见的两种编码格式(IntelMotorola)
data:image/s3,"s3://crabby-images/e11f5/e11f5dc48805fa4f755819d78bec74db3fbd2aa1" alt="CAN总线常见的两种编码格式(IntelMotorola)"
CAN总线常见的两种编码格式(IntelMotorola)
在汽车电⼦⾏业的开发或者测试中,我们经常会看到CAN总线信号的常见的两种编码格式:Intel格式与Motorola格式。
讲解这两种格式之前,我们先来了解⼀些⼤端模式和⼩端模式,会对后⾯理解这两种编码格式有很⼤的帮助。
⼀、⼤端模式和⼩端模式
⼤端模式(Big-Endian):⾼字节存低地址,低字节存⾼地址
⼩端模式(Little-Endian):⾼字节存⾼地址,低字节存低地址
单纯的从概念描述上可能⽐较难理解,我们来看⼀个实例,⼗六进制数---0x12345678,分别来看⼀下这个数据在两种模式下的存储情况:数据0x12345678,共四个字节,从⾼字节到低字节依次为12、34、56、78
将这个数据以⼤端的⽅式存放在数组data[3]中为:
将这个数据以⼩端的⽅式存放在数组data[3]中为:
⼆、Intel格式与Motorola格式
1.当⼀个信号的长度不超过1个字节(8bit),且不跨字节时,Intel格式与Motorola格式编码结果是完全⼀样的,如图:
2.当⼀个信号的长度不超过1个字节(8bit),但是跨字节时,Intel格式与Motorola格式编码结果是不⼀样的MSB:⾼位字节 LSB:低位字节
Motorola格式(类似于⼤端模式):从⾼地址开始存储
Intel格式(类似于⼩端模式):从低地址开始存储。
s19文件格式说明
data:image/s3,"s3://crabby-images/eb17d/eb17d54029ce4930a4cab8dd4f9df9e4f5670583" alt="s19文件格式说明"
S5 Record:记录类型是“S5” (0x5335)。
地址场由2字节的值说明,包含了先前传输的S1、S2、S3记录的计数。
没有数据场。
S7 Record:记录类型是“S7” (0x5337)。
地址场由4字节的地址说明,包含了开始执行地址。
没有数据场。
此行表示程序的结束,不需烧入memory。
S8 Record:记录类型是“S8” (0x5338)。
地址场由3字节的地址说明,包含了开始执行地址。
没有数据场。
此行表示程序的结束,不需烧入memory。
S9 Record:记录类型是“S9” (0x5339)。
地址场由2字节的地址说明,包含了开始执行地址。
没有数据场。
此行表示程序的结束,不需烧入memory。
根据不同的描述信息,在以上三种不同的结束行中选择一种使用。
2、EXAMPLE2.1 example IS19文件首行:S021*********B50524F47202020313143524541544544204259204541535 936384B6D首行翻译信息:S0 0000 6 8 K P R O G 1 1 C R E A T E D B Y E A S Y 6 8 K色块图例:module name version number revision number checksum checksum的算法:0x21+0x00+0x00+0x36+0x38+0x4B+0x50+0x52+0x4F+0x47+0x20+0x20+0x20+0x31+0 x31+0x43+0x52+0x45+0x41+0x54+0x45+0x44+0x20+0x42+0x59+0x20+0x45+0x41+0x53+0x59+0x36+0x38+0x4B=0x792checksum=0xFF-0x92=6D注意:EASy68K总是用S8 record作为结束行。
2.2 example IIS123C000CF1400790011CC09395B105A124A8046304A8000300001C01BC B73140007340027色块图例:type count address data checksum2.3 example IIIS224308000C61E877C1516C6197B151ACE04C07E15187A153EC74A90F9 301D026A01C6017BF0色块图例:type count address data checksum3、另附STM8S207RB 8位单片机的程序S19文件:S013000044656275675C43617244494E2E736D3872S1238080408000005F00010400010500011E00011E00021E00041E00031E00091E000 61EC6S12380A000051E00071E00081E00651E00661E00681E00671E006D1E006A1E00691E 006C36S12380C043000143000043000243000367000044000A44000B44000C44000D4400144 40049S12380E01544001644001744001844001944001A44001B44001C44001D44001E0182D E02B6S123810082DB0382D80482D50582D20682CF0782CC0882C90982C60A82C30B82C0 0C82BDB6S1*******D82BA0E82B70F82B41182B11282AE1382AB1482A81582A51682A218829 F208211S1*******C21829922829623829324829025828D26828A2882872B82842C82812D827 E3443S1238160827B36827837827538827240826F41826C4282694382664482634582604682 5D47S123818047825A54825755825456825160824E61824B6282486382456D824200823F8 98286S12381A03C415423504F330D0A00415423504F320D0A00415423504F310D0A004154 234D9AS12381C0450D0A004154234D440D0A004154234D430D0A004154234D410D0A00415 4234328S12381E04D0D0A00415423434C0D0A00415423434B0D0A00415423434F0D0A00415 4234300............。
十六进制打印格式 -回复
data:image/s3,"s3://crabby-images/7d3ee/7d3ee937b607c4693ea7160e41f22321781fa38e" alt="十六进制打印格式 -回复"
十六进制打印格式-回复标题:深入理解与应用十六进制打印格式在计算机科学中,十六进制是一种常用的数字表示方式,特别是在处理二进制数据或者进行低级别的编程时。
十六进制打印格式,也就是将数据以十六进制的形式输出,是程序员理解和调试代码的重要工具。
本文将详细解析十六进制打印格式,从基础概念到实际应用,一步一步带你走进这个神秘而又实用的世界。
一、十六进制基础十六进制,简称为Hex或Hexadecimal,是一种基数为16的计数系统。
在十六进制中,我们使用0-9和A-F(或a-f)这16个符号来表示数值。
其中,A-F(或a-f)分别代表十进制的10-15。
例如,十进制的数25在十六进制中表示为19,这是因为25除以16商为1余9,所以高位是1,低位是9,即19。
同样,十六进制的19转换为十进制则是1*16^1 + 9*16^0 = 25。
二、十六进制打印格式在编程中,我们常常需要将数据以特定的格式输出,十六进制打印格式就是其中之一。
这种格式通常用于显示二进制数据或者内存地址等信息。
在大多数编程语言中,都有内置的函数或者操作符可以将数据转换为十六进制并输出。
例如,在C语言中,我们可以使用"x"或者"X"格式化字符串来打印整数的十六进制表示。
以下是一个简单的C语言示例:c#include <stdio.h>int main() {int num = 25;printf("The hexadecimal representation of d is x\n", num, num);return 0;}运行这段代码,输出结果将是"The hexadecimal representation of 25 is 19"。
三、十六进制打印格式的应用1. 显示二进制数据:在处理图像、音频、视频等二进制数据时,十六进制打印格式可以帮助我们直观地查看和理解数据的内容。
16进制Motorola S-records 文件格式
data:image/s3,"s3://crabby-images/22b55/22b55cc3703942cca86562073aaf113755038759" alt="16进制Motorola S-records 文件格式"
S16 进制 Motorola S-records 文件格式 点击数:2358 发布日期:2006-1-9 19:06:00 【收藏】 【评论】 【打印】 【编程爱好者论坛】 【关闭】 Tag:Motorola s-recordsMotorola S-records 16 进制文件的另一种常见格式,Fujitsu 平台的 Softune 编译出来就是这种格式 这篇文章介绍了一下各个数据记录的意义。
The following fairly complete description of Motorola S-records was f ound a number of years ago on the man pages of a UNIX system. ------------------------------------------------------------------------------NAME srec - S-record file and record format DESCRIPTION An S-record file consists of a sequence of specially formatted ASCII character strings. An S-record will be less than or equal to 78 bytes in length. The order of S-records within a file is of no significance and no par ticular order may be assumed. The general format of an S-record follows: +-------------------//------------------//-----------------------+ | type | count | address | data | checksum | +-------------------//------------------//-----------------------+ type -- A char[2] field. These characters describe the type of record (S0, S1, S2, S3, S5, S7, S8, or S9). count -- A char[2] field. These characters when paired and interprete d as a hexadecimal value, display the count of remaining character pa irs in the record. address -- A char[4,6, or 8] field. These characters grouped and inte rpreted as a hexadecimal value, display the address at which the data field is to be loaded into memory. The length of the field depends o n the number of bytes necessary to hold the address. A 2-byte address uses 4 characters, a 3-byte address uses 6 characters, and a 4-byte address uses 8 characters. data -- A char [0-64] field. These characters when paired and interpreted as hexadecimal values represent the memory loadable data or desc riptive information. checksum -- A char[2] field. These characters when paired and interpr eted as a hexadecimal value display the least significant byte of the ones complement of the sum of the byte values represented by the pai rs of characters making up the count, the address, and the data field s. Each record is terminated with a line feed. If any additional or diff erent record terminator(s) or delay characters are needed during tran smission to the target system it is the responsibility of the transmi tting program to provide them. S0 Record. The type of record is 'S0' (0x5330). The address field is unused and will be filled with zeros (0x0000). The header information within the data field is divided into the following subfields.mname is char[20] and is the module name. ver is char[2] and is the version number. rev is char[2] and is the revision number. description is char[0-36] and is a text comment. Each of the subfields is composed of ASCII bytes whose associated cha racters, when paired, represent one byte hexadecimal values in the ca se of the version and revision numbers, or represent the hexadecimal values of the ASCII characters comprising the module name and descrip tion. S1 Record. The type of record field is 'S1' (0x5331). The address fie ld is intrepreted as a 2-byte address. The data field is composed of memory loadable data. S2 Record. The type of record field is 'S2' (0x5332). The address fie ld is intrepreted as a 3-byte address. The data field is composed of memory loadable data. S3 Record. The type of record field is 'S3' (0x5333). The address fie ld is intrepreted as a 4-byte address. The data field is composed of memory loadable data. S5 Record. The type of record field is 'S5' (0x5335). The address fie ld is intrepreted as a 2-byte value and contains the count of S1, S2, and S3 records previously transmitted. There is no data field.S7 Record. The type of record field is 'S7' (0x5337). The address fie ld contains the starting execution address and is intrepreted as 4-by te address. There is no data field. S8 Record. The type of record field is 'S8' (0x5338). The address fie ld contains the starting execution address and is intrepreted as 3-by te address. There is no data field. S9 Record. The type of record field is 'S9' (0x5339). The address fie ld contains the starting execution address and is intrepreted as 2-by te address. There is no data field. EXAMPLE Shown below is a typical S-record format file. S00600004844521B S1130000285F245F2212226A000424290008237C2A S11300100002000800082629001853812341001813 S113002041E900084E42234300182342000824A952 S107003000144ED492 S5030004F8 S9030000FC The file consists of one S0 record, four S1 records, one S5 record an d an S9 record. The S0 record is comprised as follows: S0 S-record type S0, indicating it is a header record. 06 Hexadecimal 06 (decimal 6), indicating that six character pairs (o r ASCII bytes) follow. 00 00 Four character 2-byte address field, zeroes in this example. 48 44 52 ASCII H, D, and R - "HDR". 1B The checksum. The first S1 record is comprised as follows: S1 S-record type S1, indicating it is a data record to be loaded at a 2-byte address. 13 Hexadecimal 13 (decimal 19), indicating that nineteen character pa irs, representing a 2 byte address, 16 bytes of binary data, and a 1 byte checksum, follow. 00 00 Four character 2-byte address field; hexidecimal address 0x0000, where the data which follows is to be loaded.28 5F 24 5F 22 12 22 6A 00 04 24 29 00 08 23 7C Sixteen character pai rs representing the actual binary data. 2A The checksum. The second and third S1 records each contain 0x13 (19) character pair s and are ended with checksums of 13 and 52, respectively. The fourth S1 record contains 07 character pairs and has a checksum of 92. The S5 record is comprised as follows: S5 S-record type S5, indicating it is a count record indicating the n umber of S1 records 03 Hexadecimal 03 (decimal 3), indicating that three character pairs follow. 00 04 Hexadecimal 0004 (decimal 4), indicating that there are four da ta records previous to this record. F8 The checksum. The S9 record is comprised as follows: S9 S-record type S9, indicating it is a termination record. 03 Hexadecimal 03 (decimal 3), indicating that three character pairs follow. 00 00 The address field, hexadecimal 0 (decimal 0) indicating the sta rting execution address. FC The checksum.------------------------------------------------------------------------------Instructor Notes There isn't any evidence that Motorola ever has made use of the heade r information within the data field of the S0 record, as described ab ove. This must have been used by some third party vendors. This is the only place that a 78-byte limit on total record length or 64-byte limit on data length is documented. These values shouldn't b e trusted for the general case. The count field can have values in the range of 0x3 (2 bytes of addre ss + 1 byte checksum = 3, a not very useful record) to 0xff; this is the count of remaining character pairs, including checksum. If you write code to convert S-Records, you should always assume that a record can be as long as 514 (decimal) characters in length (255 * 2 = 510, plus 4 characters for the type and count fields), plus any terminating character(s). That is, in establishing an input buffer inC, you would declare it to be an array of 515 chars, thus leaving ro om for the terminating null character.引用地址: 引用地址:/trackback.asp?id=9455S-Record 格式详解新一篇: 新一篇 很工作狂//========================================== ============================== //TITLE: // S-Record 格式详解 //AUTHOR: // // // norains Friday 25-April-2008 NULL //DATE: //Environment: //=============================================== ========================= 一个完整的 MOTOROLA S-Record 格式数据包含如下区域: <type> <length> <address> <data> <checksum>各字段的意思分别如下: <type>:标示记录的类型,该字段占据 1-byte。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
S16 进制 Motorola S-records 文件格式 点击数:2358 发布日期:2006-1-9 19:06:00 【收藏】 【评论】 【打印】 【编程爱好者论坛】 【关闭】 Tag:Motorola s-recordsMotorola S-records 16 进制文件的另一种常见格式,Fujitsu 平台的 Softune 编译出来就是这种格式 这篇文章介绍了一下各个数据记录的意义。
The following fairly complete description of Motorola S-records was f ound a number of years ago on the man pages of a UNIX system. ------------------------------------------------------------------------------NAME srec - S-record file and record format DESCRIPTION An S-record file consists of a sequence of specially formatted ASCII character strings. An S-record will be less than or equal to 78 bytes in length. The order of S-records within a file is of no significance and no par ticular order may be assumed. The general format of an S-record follows: +-------------------//------------------//-----------------------+ | type | count | address | data | checksum | +-------------------//------------------//-----------------------+ type -- A char[2] field. These characters describe the type of record (S0, S1, S2, S3, S5, S7, S8, or S9). count -- A char[2] field. These characters when paired and interprete d as a hexadecimal value, display the count of remaining character pa irs in the record. address -- A char[4,6, or 8] field. These characters grouped and inte rpreted as a hexadecimal value, display the address at which the data field is to be loaded into memory. The length of the field depends o n the number of bytes necessary to hold the address. A 2-byte address uses 4 characters, a 3-byte address uses 6 characters, and a 4-byte address uses 8 characters. data -- A char [0-64] field. These characters when paired and interpreted as hexadecimal values represent the memory loadable data or desc riptive information. checksum -- A char[2] field. These characters when paired and interpr eted as a hexadecimal value display the least significant byte of the ones complement of the sum of the byte values represented by the pai rs of characters making up the count, the address, and the data field s. Each record is terminated with a line feed. If any additional or diff erent record terminator(s) or delay characters are needed during tran smission to the target system it is the responsibility of the transmi tting program to provide them. S0 Record. The type of record is 'S0' (0x5330). The address field is unused and will be filled with zeros (0x0000). The header information within the data field is divided into the following subfields.mname is char[20] and is the module name. ver is char[2] and is the version number. rev is char[2] and is the revision number. description is char[0-36] and is a text comment. Each of the subfields is composed of ASCII bytes whose associated cha racters, when paired, represent one byte hexadecimal values in the ca se of the version and revision numbers, or represent the hexadecimal values of the ASCII characters comprising the module name and descrip tion. S1 Record. The type of record field is 'S1' (0x5331). The address fie ld is intrepreted as a 2-byte address. The data field is composed of memory loadable data. S2 Record. The type of record field is 'S2' (0x5332). The address fie ld is intrepreted as a 3-byte address. The data field is composed of memory loadable data. S3 Record. The type of record field is 'S3' (0x5333). The address fie ld is intrepreted as a 4-byte address. The data field is composed of memory loadable data. S5 Record. The type of record field is 'S5' (0x5335). The address fie ld is intrepreted as a 2-byte value and contains the count of S1, S2, and S3 records previously transmitted. There is no data field.S7 Record. The type of record field is 'S7' (0x5337). The address fie ld contains the starting execution address and is intrepreted as 4-by te address. There is no data field. S8 Record. The type of record field is 'S8' (0x5338). The address fie ld contains the starting execution address and is intrepreted as 3-by te address. There is no data field. S9 Record. The type of record field is 'S9' (0x5339). The address fie ld contains the starting execution address and is intrepreted as 2-by te address. There is no data field. EXAMPLE Shown below is a typical S-record format file. S00600004844521B S1130000285F245F2212226A000424290008237C2A S11300100002000800082629001853812341001813 S113002041E900084E42234300182342000824A952 S107003000144ED492 S5030004F8 S9030000FC The file consists of one S0 record, four S1 records, one S5 record an d an S9 record. The S0 record is comprised as follows: S0 S-record type S0, indicating it is a header record. 06 Hexadecimal 06 (decimal 6), indicating that six character pairs (o r ASCII bytes) follow. 00 00 Four character 2-byte address field, zeroes in this example. 48 44 52 ASCII H, D, and R - "HDR". 1B The checksum. The first S1 record is comprised as follows: S1 S-record type S1, indicating it is a data record to be loaded at a 2-byte address. 13 Hexadecimal 13 (decimal 19), indicating that nineteen character pa irs, representing a 2 byte address, 16 bytes of binary data, and a 1 byte checksum, follow. 00 00 Four character 2-byte address field; hexidecimal address 0x0000, where the data which follows is to be loaded.28 5F 24 5F 22 12 22 6A 00 04 24 29 00 08 23 7C Sixteen character pai rs representing the actual binary data. 2A The checksum. The second and third S1 records each contain 0x13 (19) character pair s and are ended with checksums of 13 and 52, respectively. The fourth S1 record contains 07 character pairs and has a checksum of 92. The S5 record is comprised as follows: S5 S-record type S5, indicating it is a count record indicating the n umber of S1 records 03 Hexadecimal 03 (decimal 3), indicating that three character pairs follow. 00 04 Hexadecimal 0004 (decimal 4), indicating that there are four da ta records previous to this record. F8 The checksum. The S9 record is comprised as follows: S9 S-record type S9, indicating it is a termination record. 03 Hexadecimal 03 (decimal 3), indicating that three character pairs follow. 00 00 The address field, hexadecimal 0 (decimal 0) indicating the sta rting execution address. FC The checksum.------------------------------------------------------------------------------Instructor Notes There isn't any evidence that Motorola ever has made use of the heade r information within the data field of the S0 record, as described ab ove. This must have been used by some third party vendors. This is the only place that a 78-byte limit on total record length or 64-byte limit on data length is documented. These values shouldn't b e trusted for the general case. The count field can have values in the range of 0x3 (2 bytes of addre ss + 1 byte checksum = 3, a not very useful record) to 0xff; this is the count of remaining character pairs, including checksum. If you write code to convert S-Records, you should always assume that a record can be as long as 514 (decimal) characters in length (255 * 2 = 510, plus 4 characters for the type and count fields), plus any terminating character(s). That is, in establishing an input buffer inC, you would declare it to be an array of 515 chars, thus leaving ro om for the terminating null character.引用地址: 引用地址:/trackback.asp?id=9455S-Record 格式详解新一篇: 新一篇 很工作狂//========================================== ============================== //TITLE: // S-Record 格式详解 //AUTHOR: // // // norains Friday 25-April-2008 NULL //DATE: //Environment: //=============================================== ========================= 一个完整的 MOTOROLA S-Record 格式数据包含如下区域: <type> <length> <address> <data> <checksum>各字段的意思分别如下: <type>:标示记录的类型,该字段占据 1-byte。