- 1、本文档共22页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Advanced Breakpoints for Native Applications
Chapter 7b – Assembly Debugging
Mithun Shanbhag
Advanced Breakpoints for Native Applications
Advanced Breakpoint Syntax
Viewing Register Contents
Pseudo – Registers
Thread Information Block
Debugging Injected Code
Exception Monitoring
Hardware Breakpoints
Advanced Breakpoint Syntax
The advanced breakpoint syntax is composed of two parts –
Context (think SCOPE).
Location.
Context -
{[function],[source file],[binary module]}
Location -
Expressed as source lines or function names.
Advanced Breakpoint Syntax (cont’d)
Simple Example –
In VS .NET, to set a breakpoint on line 20 of a file ‘TEST.CPP’, the CONTEXT LOCATION would be specified as –
{, TEST.CPP, }@20
Viewing Register Contents
The VS .NET debugger groups the Register Sets as follows -
CPU (GPR)
General purpose integer registers
CPU Segments
Segment Registers
Floating Point
General purpose floating-point registers
MMX
Pentium-Pro specific registers
SSE
Streaming SIMD Extensions (SSE) Registers (P3)
SSE-2
Streaming SIMD Extensions (SSE) Registers (P4)
3DNow!
Registers specific to AMD K6 and its successors
Register Stack
Groups of 8 registers for rapid floating-point math
Application Registers
Miscellaneous 64-bit registers
Branch Registers
64 bit registers for branching information
Flags
1 bit control / status flags
Effective Address
Registers used in Effective Address mode
Viewing Register Contents
Pseudo – Registers
Pseudo-Registers are not actual hardware registers.
Can be used in the ‘Watch’ window.
Can be used to set conditional breakpoints.
$ERR
Last error value; the same value returned by the GetLastError() API function.
$TIB
Thread information block for the current thread.
$CLK
Undocumented clock register; usable only in the Watch window.
$HANDLES
numbers of open handles in the current process.
$VFRAME
virtual frame pointer.
Pseudo – Registers (cont’d)
$ERR is a Pseudo-Register, which displays the last error code for current thread.
Works like the Win32 API call GetLastError().
Can be used with “, h
您可能关注的文档
- 22 SUSPENSE ACCOUNTS AND ERROR CORRECTION.pdf
- 22 Zygosity Diagnosis in the Absence of Genotypic Data An Approach Using Latent Class Analy.pdf
- 2488-7086-1-PB.pdf
- 246名女性皮肤老化特征及相关因素的调查分析.pdf
- 250万吨常减压流程图.pdf
- 25【英】长发公主Rapunzel.pdf
- 28.04.2011 Lecture 8 - Supply Chain Contracts.pdf
- 288-香港长期保险 业务的临时统计数字.pdf
- 29-热休克_PolyI_C上调草鱼GRP78基因表达.pdf
- 29cfr1910.134.c.doc
- Advanced OR and AI Methods in Transportation TRENDS IN MODELLING SUPPLY CHAIN AND LOGISTIC.pdf
- Advanced materials research.pdf
- Advantage of Third Party Logistics In Supply Chain Management.pdf
- Advantages of FOTA for Mobile Security.pdf
- Adv_Funct_Mater.23.5373.2013.pdf
- AFFIRMATIVE_ACTION.pdf
- Activity-oriented Instant Messaging for Coalition Operations.pdf
- AEV-product.pdf
- ADE7754_Features_March2003.pdf
- age-related effects on.pdf
文档评论(0)