mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-25 01:03:46 +02:00 
			
		
		
		
	1. Define the transfer protocol revision mechanism. Increase the revision number to 0.2 and inform user to use the latest one when the HOST software is too old. New HOST software will implement logic to handle all other revision mismatch cases. 2. Define new debug message packet to print the debug agent trace information by debug port channel. 3. Add check sum mechanism in the communication protocol between TARGET/HOST. 4. Introduced one "try" mechanism to avoid Debug Agent crashed by some invalid HOST command. 5. Enable the late-attach feature: Change the break in from "!" to "\xFC". Add a new short symbol "\xFA" for attach and a new debug command for detach. 6. Support Terminal work on debug port by install EFI Serial IO protocol upon Debug Communication Library. 7. Enable CPUID feature. 8. Enable the hardware data breakpoint. 9. add handshake to improve usb debug cable identify stability issue. 10.Refine all the communication protocol packet to improve extensibility and debugging performance. a. Use 64bit for IO port address. b. Add additional Width field to READ_MEMORY/WRITE_MEMORY. c. Add SEARCH_SIGNATURE support to speed the symbol finding for late attach. d. Remove READ_GROUP register. e. Add READ_ALL_REGISTERS support (WinDbg always requests to read all registers). 11.Move AcquireDebugPortControl () in advance to fix resource collision on IpiSentByApFlag. 12.Fix IO break point does not work issue in PEI phase. 13.Avoid BSP/APs collision when they met break point at the same time. 14.Solve a bug of calculating debug handle in sec phase. 15.Use mailbox content at Dxe phase but not clear it and reinitialize again. 16.Fix FP/MMX/XMM/IO/MSR access issue in both Gdb and WinDbg. Signed-off-by: Jeff Fan <jeff.fan@intel.com> Signed-off-by: Ruiyu Ni <ruiyu.ni@intel.com> Signed-off-by: Feng Tian <feng.tian@intel.com> Reviewed-by: Jeff Fan <jeff.fan@intel.com> Reviewed-by: Ruiyu Ni <ruiyu.ni@intel.com> Reviewed-by: Feng Tian <feng.tian@intel.com> git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13437 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			75 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ## @file  SourceLevelDebugPkg.dec
 | |
| #
 | |
| # This package provides target side modules to support source level debug.
 | |
| # The target side components includes the Debug Agent Library instance
 | |
| # to communicate with host side modules, Debug Communication Library and
 | |
| # instances to provide the communication I/O functions between Debug Agent
 | |
| # and host, PeCoffExtraActionLib instance to report symbol path information,
 | |
| # etc.
 | |
| #
 | |
| # Copyright (c) 2010 - 2012, Intel Corporation. All rights reserved.<BR>
 | |
| # This program and the accompanying materials are licensed and made available under 
 | |
| # the terms and conditions of the BSD License that accompanies this distribution.  
 | |
| # The full text of the license may be found at
 | |
| # http://opensource.org/licenses/bsd-license.php.                                                                          
 | |
| # 
 | |
| # THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     
 | |
| # WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.  
 | |
| #
 | |
| ##
 | |
| 
 | |
| [Defines]
 | |
|   DEC_SPECIFICATION              = 0x00010005
 | |
|   PACKAGE_NAME                   = SourceLevelDebugPkg
 | |
|   PACKAGE_GUID                   = DBF00C27-D8D7-443d-918B-4E85CDA1373B
 | |
|   PACKAGE_VERSION                = 0.80
 | |
| 
 | |
| [Includes]
 | |
|   Include
 | |
| 
 | |
| [Includes.IA32]
 | |
|   Include/Ia32
 | |
| 
 | |
| [Includes.X64]
 | |
|   Include/Ia32
 | |
| 
 | |
| [LibraryClasses]
 | |
|   ##  @libraryclass  Provides communication I/O functions between Debug Agent and HOST.
 | |
|   ##
 | |
|   DebugCommunicationLib|Include/Library/DebugCommunicationLib.h
 | |
| 
 | |
| [Guids]
 | |
|   ## MdeModule package token space guid
 | |
|   # Include/Guid/DebugAgentGuid.h
 | |
|   gEfiDebugAgentGuid       = {0x865a5a9b, 0xb85d, 0x474c, { 0x84, 0x55, 0x65, 0xd1, 0xbe, 0x84, 0x4b, 0xe2 }}
 | |
|   gEfiSourceLevelDebugPkgTokenSpaceGuid = {0x865a5aab, 0xb85d, 0x474c, { 0x84, 0x55, 0x65, 0xd1, 0xbe, 0x84, 0x4b, 0xe2 }}
 | |
| 
 | |
| [PcdsFixedAtBuild, PcdsPatchableInModule]
 | |
|   ## The memory BAR of usb debug port, it may be different with the memory bar of ehci host controller.
 | |
|   ## Note that the memory BAR address is only used before Pci bus resource allocation.
 | |
|   gEfiSourceLevelDebugPkgTokenSpaceGuid.PcdUsbDebugPortMemorySpaceBase|0xd0000000|UINT32|0x00000001
 | |
| 
 | |
|   ## The memory BAR of ehci host controller, in which usb debug feature is enabled.
 | |
|   ## Note that the memory BAR address is only used before Pci bus resource allocation.
 | |
|   gEfiSourceLevelDebugPkgTokenSpaceGuid.PcdUsbEhciMemorySpaceBase|0xd0000000|UINT32|0x00000002
 | |
| 
 | |
|   ## The pci address of ehci host controller, in which usb debug feature is enabled.
 | |
|   ## The format of pci address is :            
 | |
|   ##     -----------------------------------------------------------------------
 | |
|   ##     | Bits 28..31 | Bits 20..27 | Bits 15..19 | Bits 12..14 | Bits 00..11 |
 | |
|   ##     -----------------------------------------------------------------------
 | |
|   ##     |      0      |     Bus     |   Device    |   Function  |      0      |
 | |
|   ##     -----------------------------------------------------------------------
 | |
|   ##
 | |
|   ## For the value below, it means the pci address at bus 0x0, device 0x1D, function 0x7.
 | |
|   gEfiSourceLevelDebugPkgTokenSpaceGuid.PcdUsbEhciPciAddress|0x000EF000|UINT32|0x00000003
 | |
| 
 | |
|   ## The mask of exception numbers whose handlers would be ignored and cannot be replaced or 
 | |
|   ## hooked by Debug Agent Library.
 | |
|   gEfiSourceLevelDebugPkgTokenSpaceGuid.PcdExceptionsIgnoredByDebugger|0x00000000|UINT32|0x00000004
 | |
| 
 | |
|   ## The method to issue break point to Debug Agent Library when Loading/UnLoading image.  
 | |
|   ## 1: Use I/O Port 84 to issue hardware break point
 | |
|   ## 2: Use INT3 to issue software break point
 | |
|   gEfiSourceLevelDebugPkgTokenSpaceGuid.PcdDebugLoadImageMethod|0x1|UINT8|0x00000005
 |