下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 一种软硬结合的嵌入式系统远程调试方法 一种软硬结合的嵌入式系统远程调试方法 类别:嵌入式系统
2、60; 摘要:介绍一种软硬件相结合来实现嵌入式系统远程调试的方法。其主要思想是,通过使用一个程序将串口和Telnet协议进行转换,主机通过Telnet从远端访问与嵌入式系统用串口直接相连的PC机,从而间接访问到嵌入式系统,获得调试信息、发送指令和更新固件;同时,通过附加的硬件电路,完成远端对嵌入式系统的电源和I/O的控制,从而获得更为全面的调试手段。 关键词:多维力传感器 MSC1210 微位移检测引 言 随着全球化的进程,越来越多的嵌入式系统的设计工作可能由地处两个相
3、距很远地方甚至两个国家的设计团队共同完成,或者设计在一个地方完成,制造在另外一个地方完成。于是,就有了这样一种情况,一个地方的工程师需要对处在另一个遥远地方的嵌入式系统进行程序调试和程序更新。当然,首先会想到的是可以在设计系统时,就使它支持网络接口,在嵌入式系统上面运行诸如Telnet的服务器端程序,这样,使用某种客户端程序就可以从远程访问到该嵌入式系统。但是,使用这种方法的成本太大,需要为嵌入式系统加上额外的网络通信接口芯片,还要为支持TCP/IP栈增加额外的程序存储器和数据存储器。本文介绍一整套通过硬件和软件来完成对嵌入式系统的远程调试方法。
4、 图11 基本方法 图1(a)是传统的嵌入式调试方法:主机PC通过串口与从机嵌入式系统相连,接收从嵌入式系统发来的调试信息并向嵌入式系统发送调试指令,主机和从机之间只能有几米或者几十米的距离。图1(b)是现在比较流行的远程嵌入式调试方法:主机PC和从机嵌入式系统分别通过以太网连接到网络上,主机通过诸如Telnet之类的协议向嵌入式系统接收调试信息和发送指令。本文介绍的方法是将这两者结合起来,位于远端的嵌入式系统与其相邻的PC2通过串口相连,主机PC1和从机PC2各自通过以太网连接到网络上,主机PC1
5、仍然通过Telnet协议(使用Windows自带的“超级终端”程序)与从机PC2通信,在从机PC2上运行一种我们设计的软件Telent2com,其将Telnet协议转换成串口的数据收发。为了能够更好地完成对远端的嵌入式系统的控制,还使用了Telnet协议中特殊的控制命令来通过串口的额外控制线和一定的硬件电路完成对嵌入式系统,如电源和I/O输入的控制,如图1(c)所示。 使用这种方法单从嵌入式系统的角度来说,基本上没有增加任何额外的电路和成本,仍和第一种方法一样对外使用串口进行通信。虽然增加了一台额外的PC机,但是对于那些在正常工作中不需要使用网络,
6、只在测试和调试时需要使用网络来完成调试和更新固件的嵌入式系统来说,这台额外的PC机只能算作是一个调试工具。 此外,由于增加了通过网络完成对嵌入式系统的电源和I/O输入的控制,相对于第2种方法,即使在调试中嵌入式系统由于某种原因死机了,仍能从远端通过控制电源,使系统上电复位;而对系统I/O输入的控制,则可以更好完成模拟系统与外界的交互模拟。 整个系统的工作由两部分构成: Telnet到串口之间通信协议转换的PC端程序; 使用串口控制线控制嵌入式系统电源和I/O输入的接口电路。
7、60; 图22 接口电路的设计 接口电路主要是完成将串口RXD和TXD以外的控制线(如RTS、CTS等)对嵌入式系统电源或者I/O输入进行控制。为了防止嵌入式系统可能对PC串口的影响,采用图2所示的电路。通过使用光耦来达到PC串口和嵌入式系统之间的电气隔离,通过使用继电器能够控制不同电压的电源和不同电平的信号。3 Telnet到串口转换的软件 Telnet是一种最基本的网络应用层协议,其通信协议由RFC0854定义。它是建立于TCP协议之上的
8、用于传送数据和控制信息的协议。在默认情况下,其使用TCP端口23。最初设计它的目的,是为建立一种基于网络的串行终端仿真协议。这也正是为什么可以使用Telnet协议传送串口数据的原因。 通过Telnet传送的数据基本以原来的格式(如果是0xFF数据,则以两个0xFF表示)填充到TCP消息的有效数据载荷区。对于控制信息(如转入二进制模式命令,以及我们自定义的控制电源和I/O的命令)则通过在控制命令前加IAC转意字符(0xFF)方式混杂在普通数据中传送。这样就可以避免像FTP协议使用额外的端口来传送控制信息的必要,降低程序的复杂度。
9、; 这里所要设计的Telnet到串口协议的转换程序(telnet2com)实际上是一个Telnet的服务器。它接受来自图1(c)中主机PC1客户端的Telnet链接请求,然后向PC1客户端通过Telnet协议发送其从串口接收到的数据,同时将接收到的Telnet数据发送到串口。 在Windows操作系统,大部分的服务器(如IIS)都是以Windows NT服务组件(service)的形式存在于系统中的,它们在系统启动后就一直运行在后台,等待事件的触发(如某个TCP端口是否有链接请求)。作为服务组件,其与一般Windows程序的不
10、同之处是:它必然包含名为NtServiceEntry的入口函数,当Windows开始运行一个服务组件时,首先运行这个入口函数,而非通常的main函数。void NtServiceEntry(char *sServiceName) SERVICE_TABLE_ENTRY dispatchTable = TEXT(sServiceName), (LPSERVICE_MAIN_FUNCTION)ServiceMain,
11、; NULL, NULL ; StartServiceCtrlDispatcher(dispatchTable); 在入口函数中,必须定义一个dispatchTable的结构,包括服务名称sServiceName以及服务的实际主函数ServiceMain,并通过StartServiceCtrlDispatcher函数真正完成服务的注册和运行。一旦一个服务组件启动后,除了不断监听某端口外,还需要
12、响应服务管理器(service mananger)的不同请求(如暂停服务)。因此将服务的实际功能设计成一个子进程bridgeThread,由服务的主进程调用该子进程,而服务的主进程则专门用来响应服务管理器的请求。 图3 图3是子进程bridgeThread的流程。首先,使用Winsock对特定端口进行监听。然后,通过消息循环,当接收到链接请求的事件后,将串口初始化。之后,消息循环就不断响应来自Telnet和串口的写请求,将Telnet的数据发送到串口,
13、直到收到Winsock断开链接的请求。 在接收到来自Telnet客户端发来的数据后发送到串口之前,必须扫描接收到数据中是否有IAC转义字符。如果有,必须将它们去掉,而且对于定义的如控制电源和I/O的命令必须进行相关的操作。反之,从串口接收的数据在发送到Telnet客户端之前,必须在所有的0xFF字符之前多加一个0xFF。下面是对从Telnet接收的数据进行扫描过程的代码。case WSA_READ:/Telnet收到数据事件 while(iBytes=ReadSocketData(&(g_lp
14、BridgeCfg-sockClient),sTcpBufferIn,MAXSIZE_TCPBUFFER)!=-1) /读数据 iPos = 0; iPosComBuffer = 0; while (iPos if(sTcpBufferIniPos=0xFF) /如果是IAC iPos+; switch(sT
15、cpBufferIniPos) case 0xff:/是否为正常数据0xFF sComBufferOutiPosComBuffer+=sTcpBufferIniPos+; break; default: handleCmd(sTcpBufferIniPos+); /命令处理
16、 else /如果不是 sComBufferOutiPosComBuffer+= sTcpBufferIniPos+;/写到Com缓冲 SetEnevnt(g_hEventCOM_WRITE);
17、/触发Com写事件 WSAResetEvent(g_hEventWSA_READ);/复位winsock读事件 break; 这里主要使用了Winsock的API来完成Telnet部分的数据读取;串口部分是通过将串口虚拟成一个文件,通过文件读写的API来完成的。此外,为了对串口其他控制线的控制,使用了GetCommState()和SetCommState()两个Windows API来完成。 在实验中,使用这样一套远程调试系统,曾与远在韩国的设计中心进行联合调试并进行嵌入式系统固件程序更新下载,虽然相对于本地下载速度慢了很多,但是仍然比其他方式(如电子邮件+手工下载)更为便捷,结果更为直观。4 总结 使用这样一套软硬件系统来完成嵌入式系统的远程调试,既节省了大量的人力物力,又节约了开发的时间。此外,如果它和配套的测试软件结合,可以突破一台电脑只有一两个串口,同时只能测试
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026中证中小投资者服务中心招聘考试备考题库及答案解析
- 2025年榆林市住房公积金管理中心招聘(19人)备考笔试试题及答案解析
- 2025年甘肃省新华书店招聘考试备考资料包(公共基础知识)备考考试试题及答案解析
- 2025四川广安岳池县妇幼保健院招聘护士2人备考笔试试题及答案解析
- 深度解析(2026)《GBT 25979-2010道路车辆 重型商用汽车列车和铰接客车 横向稳定性试验方法》
- 深度解析(2026)《GBT 25928-2010过程工业自动化系统出厂验收测试(FAT)、现场验收测试(SAT)、现场综合测试(SIT)规范》
- 深度解析(2026)《GBT 25848-2010耐酸陶瓷球拱》(2026年)深度解析
- 2025年哈尔滨市南岗区残疾人联合会补充招聘残疾人专职委员2人参考笔试题库附答案解析
- 深度解析(2026)《GBT 25732-2010粮油机械 液压榨油机》(2026年)深度解析
- 2025重庆市长寿区城市管理服务中心招聘数字城管工作人员3人参考考试试题及答案解析
- 2025年中国铁路上海局集团有限公司芜湖车务段客运服务人员招聘考试笔试备考题库及答案解析
- 2026年陕西省高考一模语文模拟试卷试题(含答案详解)
- 国家开放大学《Web开发基础》形考任务实验1-5参考答案
- 重大版英语六年级上册 Review 2 课件(共9张PPT)
- 工程委托单(通用模板)
- 饲料采购合同模板
- 2022年五子棋社团活动总结
- 储罐 (有限空间)作业安全告知牌及警示标志
- 解剖实习复习-感觉器及神经
- DB36T 1292-2020高速公路服务区污水处理(AO工艺)运维指南_(高清版)
- ISOIEC17025-2017实验室管理体系全套文件
评论
0/150
提交评论