Intel® UEFI Development Kit Debugger Tool (Version 1.5) Configuration and Setup Guide
Total Page:16
File Type:pdf, Size:1020Kb
Intel® UEFI Development Kit Debugger Tool (version 1.5) Configuration and Setup Guide Version 1.11 July 7, 2015 ii INFORMATION IN THIS DOCUMENT IS PROVIDED IN CONNECTION WITH INTEL® PRODUCTS. NO LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPERTY RIGHTS IS GRANTED BY THIS DOCUMENT. EXCEPT AS PROVIDED IN INTEL’S TERMS AND CONDITIONS OF SALE FOR SUCH PRODUCTS, INTEL ASSUMES NO LIABILITY WHATSOEVER, AND INTEL DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY RELATING TO SALE AND/OR USE OF INTEL PRODUCTS INCLUDING LIABILITY OR WARRANTIES RELATING TO FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT. Intel products are not intended for use in medical, life saving, or life sustaining applications. Intel may make changes to specifications and product descriptions at any time, without notice. Designers must not rely on the absence or characteristics of any features or instructions marked “reserved” or “undefined.” Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them. The Intel® UEFI Development Kit Debugger Tool may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request. Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order. Intel®, Intel® UEFI Development Kit Debugger Tool, Intel® UDK Debugger Tool, and the Intel® logo are trademarks or registered trademarks of Intel® Corporation or its subsidiaries in the United States and other countries. Other names and brands may be claimed as the property of others. Copyright© 2012 - 2015 Intel Corporation. All rights reserved. iii iv Contents 1 Configuration Overview................................................................................................................................................... 1 1.1 Document Purpose and Organization ...................................................................................................... 1 1.1.1 Configuration and Build ............................................................................................................ 1 1.1.2 Windows .......................................................................................................................................... 1 1.1.3 Linux .................................................................................................................................................. 1 1.1.4 Debugging Tips and Appendix ............................................................................................... 1 1.2 Tool Introduction .............................................................................................................................................. 2 1.3 Configuration ...................................................................................................................................................... 2 1.3.1 Supported platforms.................................................................................................................. 2 1.3.2 Host and target configurations .............................................................................................. 3 1.3.3 Target configuration ................................................................................................................... 4 1.3.4 Connection between host and target machines ............................................................. 6 1.4 OVMF platform and the debug process ................................................................................................... 6 2 Build the Firmware Image ................................................................................................................................................ 7 2.1 Introduction ......................................................................................................................................................... 7 2.1.1 Linux Platforms ............................................................................................................................ 7 2.1.2 Windows Platforms .................................................................................................................... 7 2.2 Modify the configuration files for the firmware used by the target machine .......................... 7 2.2.1 Select the appropriate libraries ............................................................................................. 8 2.2.2 Turn debugging on or off ....................................................................................................... 10 2.2.3 Configure a serial port for debug usage ........................................................................... 11 2.2.4 Configure the USB 2.0 debug port ..................................................................................... 13 2.2.5 Additional configuration requirements ............................................................................ 15 2.2.6 Update the CPU driver on ECP-based platforms ......................................................... 17 2.2.7 Build the image and update flash memory before debugging source-level code ........................................................................................................................................................... 19 3 Setup the Windows Debug Environment ................................................................................................................ 21 3.1 Introduction ....................................................................................................................................................... 21 3.2 Install the Windows Debugger on HOST ............................................................................................... 22 3.3 Install the Intel Debugger Tool on HOST .............................................................................................. 22 3.4 Connect HOST and TARGET ....................................................................................................................... 22 4 Use the Debug Solution on a Windows Platform ............................................................................................... 25 4.1 Introduction ....................................................................................................................................................... 25 4.2 Supported features ........................................................................................................................................ 25 4.3 General debug flow ........................................................................................................................................ 25 v 4.3.1 Start a WinDbg debug session ............................................................................................. 26 4.3.2 Start a WinDbg session using late attach ........................................................................ 28 4.3.3 End the WinDbg session ......................................................................................................... 29 4.4 Basic WinDbg debugging operations ...................................................................................................... 30 4.4.1 Basic procedures ....................................................................................................................... 30 4.4.2 WinDbg extension commands ............................................................................................. 31 smmentrybreak ............................................................................................................................................... 31 bootscriptentrybreak .................................................................................................................................... 31 resetdelay .......................................................................................................................................................... 31 cpuid ........................................................................................................................................................... 32 loadthis ........................................................................................................................................................... 32 !py mmio ........................................................................................................................................................... 32 !py pci ........................................................................................................................................................... 33 !py mtrr ........................................................................................................................................................... 33 !py DumpHobs ................................................................................................................................................. 33 !py DumpVariable ........................................................................................................................................... 34 !py DumpS3Script S3ScriptTableAddress............................................................................................ 34 !py ShowEfiDevicePath DevicePathAddress