- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
tornado调试培训 提 纲 crossWind Tornado调试概述 crossWind (tornado debugger) browser windSh(tornado shell) WindView crossWind调试器 重要步骤: 1、配置tools-target server-config a、在target name/ip address中输入目标板子的ip地址。 b、在back end 处选上wdprpc,如果网络不好,可以在timeout中输入2s c、在core file and symbols的文件中选上需要调试的vxWorks或vxWorks.st d、memory cache Size 设置为10000。 e、这样就可以启动这个target server了 crossWind调试器 重要步骤 2、Debug-Source search path 中加上你要调试的原代码的路径。 crossWind调试器-常用功能 breakPoint:设置断点,当任务执行到本断点后会stop,前提是我们设置了 auto attach to task,在没有设置此选项的情况下,必须手工attach 到某一任务。 有全局断点和任务断点 Step: 单步功能,跟其他调试环境类似。 Watch: 设置watch 变量。 Variable:变量查看,主要是当前被调试的函数的局部变量和全局变量。 注意: Watch Variable和显示的变量值可能会不对,最好去和内存中去确认,或者看寄存器或者打印。(arm) Registers: 查看寄存器当前值。 Memory:查看内存值。 crossWind调试器-常用功能 Back trace: 栈回溯,通过栈回溯,可以看到函数的调用关系,针对每一个栈帧,可以查看调用时各个函数的执行环境,包括参数、寄存器等。 Attach: attach到某一运行任务,attach之后,整个任务便在调试器的控制之下。 Run: 创建一个任务,并执行,调试器会自动attach到这个任务。 Diassemble: 反汇编能力,可以和c语言同时对应显示 crossWind调试器 常见问题: 1、 如果在taskSpawn的时候选项中设置了 VX_UNBREAKABLE ,那么就不能设置断点调试。 2、如果打开了优化开关,O2那么无法单步调试,代码和汇编对不上。 3、 编译时没有使用-g编译开关。 会无法设置断点 4、断点位置不准确 ,和代码对不上,可能是由于链接的不是该原代码文件,或者代码和target server的版本有差异 browser Tornado调试概述 crossWind (tornado debugger) browser windSh(tornado shell) WindView Browser-堆栈 1、察看stack信息 可以察看当前stack使用量 可以察看最大stack的使用量 注意: 如果在taskSpawn的时候选项中设置了 VX_NO_STACK_FILL,那么就无法察看stack的使用量。 在shell中用checkStack也可以察看stack的使用 Browser-spy Spy : 察看cpu占有率。 当感觉系统运行很慢时,可以用spy察看哪些任务占cpu太多时间了。 注: 有的tornado显示用不了spy,那么可能要把spyLib.o 这个文件copy到lib/objppc603gnuvx目录下。 Browser-其它 任务信息 i,ti 内存信息 memShow Module 信息 windSh(tornado shell) Tornado调试概述 crossWind (tornado debugger) browser windSh(tornado shell) WindView Windsh-任务信息 i 所有任务的名字,入口函数,tid,优先权,当前pc,sp,错误号等 注意:如果显示中任务名为空,则很有可能发生了越栈现象。tid就是tcb块开始的地址,可以通过这个地址察看和修改里面的内容 ti (参数为任务名或tid) 显示任务tcb块的完整信息。通常关注信息是: 堆栈的信息(栈头,栈尾,最大使用栈的大小) 寄存器(sp(ppc里的r1)的值,pc的值,函数参数值(ppc的r3,r4,r5),fp(如ppc的r31)) Windsh-任务信息 sp 函数名,参数值 发起一个新的任务,任务名
文档评论(0)