版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Gdb/Armulator源代码分析 作者Email: Anti_chen2000摘要Gdb/Armulator 是Gdb自带的arm7模拟器,是调试arm程序的一个好工具.而了解它的原码结构对扩展它的IO功能有重要意义.本文介绍了从Armulator的启动到其内部运作和IO扩展的大部分原代码功能.说明源代码用的是gdb-5.0.tar+ gdb-5.0-uclinux-armulator-20021127.patchA.和GDB间的通迅Armulato
2、r一般和Gdb通讯有两种方式,其一是在Gdb内部直接调用模拟器的相关函数,另一方法则是用pipe或socket传递RDP协议来连接Gdb和Amulator.而第一种方法是现在Gdb/Armulator所真正使用的(第二种是早期使用的方法),下面就分析了函数直接调用法. 函数直接调用这个方法是由Steve (sac) 修改原RDP方法而来的,Steve本人的描述如下:/*This directory contains the standard release of the ARMulator fromAdvanced RISC Machines, and was ftp''d f
3、rom.ftp.cl.cam.ac.uk:/arm/gnuIt likes to use TCP/IP between the simulator and the host, which isnice, but is a pain to use under anything non-unix.I''ve added created a new Makefile.in (the original in Makefile.orig)to build a version of the simulator without the TCP/IP stuff, and awrapper.c
4、 to link directly into gdb and the run command.It should be possible (barring major changes in the layout ofthe armulator) to upgrade the simulator by copying all the filesout of a release into this directory and renaming the Makefile.(Except that I changed armos.c to work more simply with oursimula
5、tor rigs)*/gdb/target.c,/gdb/remote_sim.c以及在/sim/arm/wrapper.c是在Armulator和Gdb的通信中起着至关重要做用的几个文件.所有的Gdb调试命令最后都是通过在target.h里定义的target_ops结构中的函数指针调用在/sim/arm/wrapper.c中型如sim_xxx的函数完成的.以前这些sim_xxx函数是位于/sim/common中的,是建立RDP通讯的关键,代码修改后此目录中的文件不再有用,被wrapper.c取而代之了.以下是RDP 通讯和直接函数调用的图示:要清楚Armulator的执行过程就要从它的启动说
6、起,当你在Gdb中键入target sim 去激活Amulator后Gdb首先进行命令行解释,并将current_target指针指向sim变量,即将Armulator的调试函数集赋予Gdb,随后的函数调用堆栈如下:-àgdbsim_open () in remote-sim.c.-àsim_open() in /sim/arm/wrapper.c/*这里Amulator对调用参数进行分析处理*/-à*current_target->to_fetch_registers(-1) /*此函数指针实指向sim_fetch_register() in /sim/a
7、rm/wrapper.c*/-àsim_fetch_register(-1)/*此函数指针是在将current_target指向sim时,通过注册target_ops 结构完成挂接的*/sim_fetch_register (sd, rn, memory, length)ARMword regval;init ();file:/就在这,Amulator进行了初始化至此Armulator被装载完毕,其后Gdb就是通过target_ops(定义在target.h)结构中的各个函数指针来完成对它的调试工.B.Armulator 内部机制a.初始化从上述可知整个模拟器的初始化入口是在wrap
8、per.c中的init( )函数,那么它到底又做了些什么呢?(原始的Gdb5.0中的Armulator是模拟ARM7DTMI 的,而补丁代码修改了memory map 并添加了timer 和uart 的IO能力使其能够模拟AT91.因为后者是对前者的增强,所以我们的分析以后者为准)Once the armulator to reset ,the ARMul_NewState will be called.And its task is to malloc a ARMul_state stuct which saves the armulators states and initialize i
9、t .And the ARMul_MemoryInit() will malloc 4m ram for you.#1static void#2init ()#3#4static int done;#5if (!done)#6#7ARMul_EmulateInit ();file:/Call this routine once to set up the emulator''s tables.#8state = ARMul_NewState ();#9state->bigendSig = (big_endian ? HIGH : LOW);#10RMul_MemoryIn
10、it (state, mem_size);file:/原始代码中的内存初始,但现在无用#11ARMul_OSInit (state);file:/预装系统初始化#12ARMul_CoProInit (state);file:/协处理器初始#13state->verbose = verbosity;#14done = 1;#15file:/the below is added for AT91#16ARMul_SelectProcessor(state, ARM600);#17ARMul_SetCPSR(state, USER32MODE);#18ARMul_Reset(state);#1
11、9#20因为这是补丁代码,难免又冗余出现,实际10-11行的两处掉用是没有实际意义的,而12行是协处理器的初始化,因为并没又模拟协处理器所以此处只是以备扩展.重点的初始化过程是在ARMul_NewState()中的.首先它给模拟器的核心状态结构ARMul_State分配了空间,这个结构里保存了Armulator的所有方面的状态,包括arm寄存器,流水线状态等等.并赋予初值,我们以后就用state表示之.然后调用ARMul_Reset()进行更近一步的设置.而后者又主要完成模拟器内存结构的分配和rom映象的加载-/sim/arm/armmem.c/mem_reset(),IO设备的状态初始/si
12、m/arm/armio.c/io_reset(),你也可在这添加你的初始代码.到这就完成了Armulator的装载.(大家注意到18行也调用了ARMul_Reset(),这是一个BUG,使得模拟器进行了两次内存分配,而浪费了系统内存.此处可删去.)Memory map 是所有模拟器的关键.Armulator由AT91向其他MCU移植时Memory map又是首先要处理的.Armulator的各个内存区是由mem_bank_t结构来描述的:typedef struct mem_bank_t ARMword(*read_word)(ARMul_State *state, ARMword addr)
13、;void(*write_word)(ARMul_State *state, ARMword addr, ARMword data);unsigned longaddr, len;char*filename; mem_bank_t;file:/定义在armmem.h中Armulator的整个内存则是又此结构的数组static mem_bank_t mem_banks管理的.AT91的memory map如下:static mem_bank_t mem_banks = /* the yuk''s below are to work around a uClinux/mount o
14、ptions problem */ real_read_word,real_write_word,0x01000000, 0x00400000, , /* 2.4 */ real_read_word,_write_word,0x01400000, 0x00400000, "boot.rom", real_read_word,real_write_word,0x02000000, 0x00400000, , /* 2.0 */ real_read_word,real_write_word,0x02400000, 0x00001000, , /* yuk!*/ real_rea
15、d_word,_write_word,0x04000000, 0x00400000, "boot.rom", real_read_word,real_write_word,0x00000000, 0x00004000, , io_read_word,io_write_word,0xf0000000, 0x10000000, , fail_read_word,fail_write_word, 0, 0 ;根据mem_banks,mem_reset( )将分配空间,加载boot.rom文件.(原来的内存是由ARMul_MemoryExit( )释放的,但补丁后的代码就没了释放功
16、能,这也是需要纠正的地方)a.指令流Armulator 加载完成后,就开始等待Gdb的运行命令了.最终/sim/wrapper.c/sim_resume( )是启动arm指令执行的地方.Sim_resume( )根据Gdb的要求选择用/sim/arm/arminit.c/ARMul_DoInstr()还是用/sim/arm/arminit.c/ARMul_DoProg()来调用 流水线模拟函数/sim/arm/armemu.c/ARMul_Emulate32().ARMul_DoInstr()和ARMul_DoProg()的区别就是一个单步执行,一个连续执行指令. ARMul_DoProg()
17、又不停的判断state->Emulate是否为STOP,如果是,模拟器又将停下等待Gdb的调试.而在arm/armemu.c, /arm/armvirt.c 和 /arm/armsupp.c中的函数则模拟指令预取,指令译码,指令执行以及数据回写的功能.这三个文件时可以说时Armulator的核心!b.中断Armulator 的中断机制主要靠以下两个例程实现:1.IntPending(): 用来检测state中的各个中断标志是否置位,从而判断是否又需要中断.2.ARMul_Abort():当需要中断时,用来改变处理器模式,并将pc指向相应的中断向量.在流水线函数ARMul_Emulate3
18、2()执行当中,有多处调用IntPending() 去检测中断.而Ispending() 也十分简单,它仅仅判断state中的四个变量:State->Exception : 中断使能标志.State->NresetSig : reset 中断信号.State->NirqSig : irq 中断信号.State->NfiqSig : fiq 中断信号.所以当你的虚拟外设产生中断时,你只要调用/sim/arm/armio.c/ update_int()即可:static void update_int(ARMul_State *state)ARMwordrequests =
19、 state->sr & state->mr;state->NfiqSig = (requests & 0x000f) ? LOW : HIGH;state->NirqSig = (requests & 0xfff0) ? LOW : HIGH;b.读写操作无论是CPU指令还是Gdb调试时读写内存或IO空间,最后都将要落到/armvirt.c/getword(), /armvirt.c/putword()这两个函数身上.在原始代码中这两个函数马上就进行内存数组的读写了.而补丁代码的流程如下:-àgetword()
20、/putword()-àmmu_read_data()/mmu_write_data() in armmmu.c /*进行mmu的地址转换和cache 查询*/-àreal_read_data()/real_write_data() :读写ram,romio_read_data()/io_write_data() :读写IO空间_write_data()/fail_read_data()/fail_write_data() :非法读写,如地址错误,rom读操作等.可以看出最后几个函数的选择是由读写地址在相应的mem_bank_t结构中的读写函数指针决定的.c.设备同步写这篇文章的初衷是让读者能很快进入Armulator的移植和IO扩展的实际工作中去.所
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 35922-2025不透性石墨浸渍耐蚀作业技术规范
- 2026春招:学习成长企划顾问题目及答案
- 2026年桥梁设计中的地震动参数研究
- 2026年桥梁设计中的非线性分析与优化
- 2026年未来电气传动控制的研究方向
- 2026春招:维修技术员笔试题及答案
- 贩毒与吸毒的法律问题
- 住院部病患护理质量评估
- 2026年邯郸科技职业学院单招综合素质考试备考试题带答案解析
- 2026年黑龙江旅游职业技术学院单招职业技能考试参考题库带答案解析
- 2025年青岛卫生局事业单位考试及答案
- 纪委档案规范制度
- 杭州钱塘新区建设投资集团有限公司2025年度第三次公开招聘工作人员备考题库及完整答案详解
- 眼科质控课件
- 安徽信息会考题库及答案
- 2025年中级消防监控题库及答案
- 隧道施工废水处理人员培训方案
- 2025年射频识别技术面试题库及答案
- 拣货主管年终总结
- 糖尿病重症患者肠内营养血糖调控方案
- CSR社会责任管理手册
评论
0/150
提交评论