




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一. vmware 下安装:windows 7 ultimate x86 中文版1、vmware (请使用尽可能新的版本以对tools的支持) 的设置 打开相应 vmware 虚拟机上的 “Virtaul Machine Settings”- “Hardware”选项中 - 点击 “Add” 添加一个串口设备 Seiall Port- “Next” - 在 Serial Port 里选中“Output to named pipe” - “next” - “Finish” 最后,回到 “Virtual Machine Settings”页面时,在“I/O Mode” 里选中“Yield CPU on poll” 这样 vmware 的设置就好了。注意看清楚:Serial Port 1还是Serial Port 2,接下来会用到。2、windbg 的使用创建windbg.exe所在目录的环境变量后,在桌面写个批处理,保存为vmware_win7.bat 内容如下: 在桌面上建一个便捷方式,命令行是:windbg -b -k com:port=/./pipe/com_1,baud=115200,pipe 这样在开启 vmware 中的 windows 7 后运行这个便捷方式,windbg 与 guest OS “win7” 就建立成联线方式。二、guest OS - win7 中设定1、在 bootmgr 中下断点 在 vista 及后续的 windows 已经取消了 ntldr 模块管理引导,转而以 bootmgr 模块管理引导系统。 在我的 windows 7中要设定在哪个部分进行调试。 windws 7 可调试部分有 4 个:bootmgr 模块、winload 模块、WinResume 模块以及 windows 内核模块 Nt 模块可以在上述的 4 个模块下断点进行调式(1) 以管理员身份运行“命令提示符”(2) 在“命令提示符”窗口中,输入以下命令:bcdedit /set bootmgr bootdebug onbcdedit /set bootmgr debugtype serialbcdedit /set bootmgr debugport 1bcdedit /set bootmgr baudrate 115200注意一个细节,bcdedit /set bootmgr debugport 1这一行最后的1 对应Serial Port 1,所以如果是Serial Port 2 则设置为bcdedit /set bootmgr debugport 2 否则连不上。bcdedit /set bootmgr bootdebug onbcdedit /set bootmgr debugtype serialbcdedit /set bootmgr debugport 1bcdedit /set bootmgr baudrate 115200在提示命令成功后,这样就在 windows7 中的 bootmgr 模块建立起可调试的机制。在运行 windows7 时到达 bootmgr 时就停止加载,vmware 中是黑屏,它正等待 serial port 的响应,运行 windbg 后,windbg 就和 windws 7 中的 bootmgr 建立起联线了下面是我的 windbg 在 bootmgr 模式下断点的响应信息:Microsoft (R) Windows Debugger Version 6.11.0001.404 X86Copyright (c) Microsoft Corporation. All rights reserved.Opened/./pipe/com_1Waiting to reconnect.BD: Boot Debugger InitializedConnected to Windows Boot Debugger 7600 x86 compatible target at (Mon May 9 13:25:27.631 2011 (GMT+8), ptr64 FALSEKernel Debugger connection established. (Initial Breakpoint requested)Symbol search path is: SRV*c:/symbols*/download/symbolsExecutable search path is:Windows Boot Debugger Kernel Version 7600 UPFreex86 compatibleMachine Name:Primary image base = 0x00400000 Loaded module list = 0x00491b80System Uptime: not availableBreak instruction exception - code 80000003 (first chance)bootmgr!RtlpBreakWithStatusInstruction:004436bc cc int 3;=Primary image base = 0x00400000 Loaded module list = 0x00491b80 bootmgr 被加载到基地址是 0x00400000bootmgr!RtlpBreakWithStatusInstruction: 目前处在 bootmgr 模块中查看:kd x bootmgr!*00430724 bootmgr!TpmApiAuthSessCreateOSAP = 0045dc5c bootmgr!CmpGetIndexElementSize = 004689a4 bootmgr!RcConsoleBaudRates = 004356cd bootmgr!OsxmlBrowser:OsxmlBrowser = 00437683 bootmgr!XslStylesheet:getContents = 0040d032 bootmgr!BlockIoPcatConventionalInt13 = 00420202 bootmgr!BlLogData = 0041cda5 bootmgr!NetClose = 0043bf31 bootmgr!XslTemplate:getContents = 0042ab94 bootmgr!MmTrSelectPageTableMappingAddress = 0041796b bootmgr!FileIoOpen = .2、在 winload 模块下断点同样在“命令提示符”中使用命令bcdedit /enum这条命令显示当前可用模块的 GUIDMicrosoft Windows 版本 6.1.7600版权所有 (c) 2009 Microsoft Corporation。保留所有权利。C:/Windows/system32bcdedit /enumWindows 启动管理器-标识符 bootmgrdevice partition=C:description Windows Boot Managerlocale zh-CNinherit globalsettingsdebugtype Serialdebugport 2baudrate 115200bootdebug Yesdefault currentresumeobject 8bf63dd6-79ea-11e0-9d42-db726cb22836displayorder currenttoolsdisplayorder memdiagtimeout 30Windows 启动加载器-标识符 currentdevice partition=C:path /Windows/system32/winload.exedescription Windows 7locale zh-CNinherit bootloadersettingsrecoverysequence 8bf63dd8-79ea-11e0-9d42-db726cb22836recoveryenabled Yesosdevice partition=C:systemroot /Windowsresumeobject 8bf63dd6-79ea-11e0-9d42-db726cb22836nx OptIn3、在内核模块 Nt 模块下断点 打开 windws 7 的“控制面板”- “管理工具” - “系统配置” - 打开“引导”页面 - 点击“高级选项” - 在高级启动选项里,选中“调试” - 点击“确定”就行了。注意端口的选择同上。com1或com2对应。 这样就在 nt 模块下了断点Microsoft (R) Windows Debugger Version 6.11.0001.404 X86Copyright (c) Microsoft Corporation. All rights reserved.Opened/./pipe/com_1Waiting to reconnect.Connected to Windows 7 7600 x86 compatible target at (Mon May 9 14:37:37.001 2011 (GMT+8), ptr64 FALSEKernel Debugger connection established. (Initial Breakpoint requested)Symbol search path is: SRV*c:/symbols*/download/symbolsExecutable search path is:Windows 7 Kernel Version 7600 MP (1 procs) Free x86 compatibleProduct: WinNt, suite: TerminalServer SingleUserTSBuilt by: 7600.16385.x86fre.win7_rtm.090713-1255Machine Name:Kernel base = 0x83c47000 PsLoadedModuleList = 0x83d8f810Debug session time: Mon May 9 14:37:32.656 2011 (GMT+8)System Uptime: 0 days 0:00:04.828Break instruction exception - code 80000003 (first chance)* * You are seeing this message because you pressed either * CTRL+C (if you run kd.exe) or, * CTRL+BREAK (if you run WinDBG), * on your debugger machines keyboard. * * THIS IS NOT A BUG OR A SYSTEM CRASH * * If you did not intend to break into the debugger, press the g key, then * press the Enter key now. This message might immediately reappear. If it * does, press g and Enter again. * *nt!RtlpBreakWithStatusInstruction:83cb2394 cc int 3kd gBreak instruction exception - code 80000003 (first chance)* * You are seeing this message because you pressed either * CTRL+C (if you run kd.exe) or, * CTRL+BREAK (if you run WinDBG), * on your debugger machines keyboard. * * THIS IS NOT A BUG OR A SYSTEM CRASH * * If you did not intend to break into the debugger, press the g key, then * press the Enter key now. This message might immediately reappear. If it * does, press g and Enter again. * *nt!RtlpBreakWithStatusInstruction:83cb2394 cc int 3kd gKDTARGET: Refreshing KD connection三、 windbg 加载符号 在 windbg 的 File - Symbol File path - 设定为: SRV*d:/symbols*/download/symbols 回到 windbg 命令行,使用命令 .reload 命令,可以自动加载符号相关命令:C:/Usersbcdedit /?BCDEDIT - 启动配置数据存储编辑器Bcdedit.exe 命令行工具用于修改启动配置数据存储。启动配置数据存储包含启动配置参数并控制操作系统的启动方式。这些参数以前位于Boot.ini文件中(在基于 BIOS 的操作系统中)或位于稳定RAM 项中(在基于可扩展固件接口的操作系统中)。可以使用 Bcdedit.exe 在启动配置数据存储中添加、删除、编辑和附加项。有关命令和选项的详细信息,请键入 bcdedit.exe /? 。例如,若要显示有关 /createstore 命令的详细信息,请键入: bcdedit.exe /? /createstore有关本帮助文件中按字母顺序排列的主题列表,请运行 bcdedit /? TOPICS。对存储执行的命令=/createstore 新建空的启动配置数据存储。/export 将系统存储的内容导出到文件。以后可以使用该文件还原系统 存储的状态。/import 使用 /export 命令创建的备份文件来还原系统存储的状态。/sysstore 设置系统存储设备(仅影响EFI 系统,在重新启动后不再有效, 且仅用于系统存储设备不确定的情况下)。对存储中的项执行的命令=/copy 复制存储中的项。/create 在存储中新建项。/delete 删除存储中的项。/mirror 创建存储中项的镜像。运行 bcdedit /? ID 可获得有关这些命令使用的标识符的信息。对项选项执行的命令=/deletevalue 删除存储中的项选项。/set 设置存储中的项选项值。运行 bcdedit /? TYPES 可获得这些命令使用的数据类型的列表。运行 bcdedit /? FORMATS 可获得有效数据格式的列表。控制输出的命令=/enum 列出存储中的项。/v 命令行选项,完整显示项标识符,而不是使用已知标识符的名称。 单独使用命令 /v 可完整显示活动类型的项标识符。单独运行 bcdedit 等同于运行 bcdedit /enum ACTIVE。控制启动管理器的命令=/bootsequence 为启动管理器设置一次性启动序列。/default 设置启动管理器将使用的默认项。/displayorder 设置启动管理器显示多重引导菜单的顺序。/timeout 设置启动管理器的超时值。/toolsdisplayorder 设置启动管理器显示工具菜单的顺序。控制启动应用程序紧急管理服务的命令=/bootems 启用或禁用启动应用程序的紧急管理服务。/ems 启用或禁用操作系统项的紧急管理服务。/emssettings 设置全局紧急管理服务参数。控制调试的命令=/bootdebug 启用或禁用启动应用程序的启动调试。/dbgsettings 设置全局调试程序参数。/debug 启用或禁用操作系统项的内核调试。/hypervisorsettings 设置虚拟机监控程序的参数。C:/Usersbcdedit /set /?此命令设置引导配置数据存储中的项选项值。bcdedit /store /set /addfirst | /addlast | /remove 指定要使用的存储。如果未指定此选项,则使用系统存储。 有关详细信息,请运行 bcdedit /? store。 指定要修改的项的标识符。如果未指定,则使用 current。 有关标识符的详细信息,请运行 bcdedit /? ID。 指定将创建或修改的选项数据类型。 有关数据类型的详细信息,请运行 bcdedit /? TYPES。 指定应分配给该选项的值。 的格式取决于指定的数据类型。 有关数据格式的详细信息,请运行 bcdedit /? FORMATS。 /addfirst 仅当数据类型是对象列表时才能使用此开关。 将指定的项标识符添加到列表的顶部。 如果已指定此开关,则只能指定一个项标识符。 如果所指定的标识符已在列表中,请将它移到列表顶部。 /addlast 仅当数据类型是对象列表时才能使用此开关。 将指定的项标识符添加到列表的结尾。 如果已指定此开关,则只能指定一个项标识符。 如果所指定的标识符已在列表中,它将被移到列表结尾。 /remove 仅当数据类型是对象列表时才能使用此开关。 请从列表中删除指定的项标识符。 如果已指定此开关,则只能指定一个项标识符。 如果此标识符不在列表中,则操作无效。 如果正在删除最后一项,则此数据类型值也将被删除。示例:对于指定的操作系统项,下列命令将应用程序设备设置到 C: 分区: 注意: 使用 hd_partiton= 语法显式禁用自动 VHD检测,并 创建与启动虚拟机兼容的项目,例如, bcdedit /store Foocd /set default device hd_partition=F:对于指定的操作系统项,下列命令将操作系统设备设置到 VHD 文件(C:/vdisks/vdisk01.vhd) bcdedit /set cbd971bf-b7b8-4885-951a-fa03044f5d71 osdevice vhd=C:/vdisks/disk01.vhd对于指定的操作系统项,下列命令将应用程序路径设置到 /windows/system32/winload.exe: bcdedit /set cbd971bf-b7b8-4885-951a-fa03044f5d71 path /windows/system32/winload.exe对于当前的操作系统启动项,下列命令将 NX策略设置到 OptIn。 bcdedit /set nx optinC:/Usersbcdedit /? ID标识符很多 Bcdedit 命令需要标识符。标识符可以唯一标识存储中包含的项。标识符采取全局唯一标识符的形式,或称为 GUID。GUID 具有以下格式,其中每个“x”代表一个十六进制数。 xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx例如: d2b69192-8f14-11da-a31f-ea816ab185e9破折号(-)的放
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年自考专科本科题库及答案
- 2025年材料员基础知识试题库附含参考答案
- 岗前安全培训教育
- 2025年手卫生知识试题及答案解析
- 2025年法学真题及答案
- 2025年大学生国学知识竞赛题库及答案
- 智慧教育移动学习资源库创新创业项目商业计划书
- 森林可持续经营管理创新创业项目商业计划书
- 坚果与健康管理咨询服务创新创业项目商业计划书
- 小白菜品牌国际化创新创业项目商业计划书
- 【大班幼儿叙事能力的培养策略11000字(论文)】
- 医院物业司梯礼仪服务标准
- 商务礼仪情景模拟实训试题参考
- 喀斯特地貌(全套课件)
- 《上海市奉贤区小区机动车停放管理工作调查报告》4300字
- 水中总氯的测定方法确认实验报告(HJ586)
- 国家开放大学《现代汉语专题》章节自测参考答案
- 老舍《我的母亲》 中职课件
- 教科版二年级(上)科学1.5各种各样的天气(课件)
- 分段函数-完整版获奖课件
- 信访人的权利、义务和禁止行为告知书
评论
0/150
提交评论