mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-26 01:33:45 +02:00 
			
		
		
		
	Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Pete Batard <pete@akeo.ie> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Dandan Bi <dandan.bi@intel.com> Reviewed-by: Jiewen.yao@intel.com
		
			
				
	
	
		
			163 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| 
 | |
| Copyright (c) 2007, 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
 | |
| which 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.
 | |
| 
 | |
| 
 | |
| **/
 | |
| 
 | |
| #include "Edb.h"
 | |
| 
 | |
| /**
 | |
| 
 | |
|   Check whether current IP is EBC CALL instruction (NOTE: CALLEX is exclusive)
 | |
| 
 | |
|   @param  Address   - EBC IP address.
 | |
| 
 | |
|   @retval TRUE  - Current IP is EBC CALL instruction
 | |
|   @retval FALSE - Current IP is not EBC CALL instruction
 | |
| 
 | |
| **/
 | |
| BOOLEAN
 | |
| IsEBCCALL (
 | |
|   IN UINTN            Address
 | |
|   )
 | |
| {
 | |
|   if (GET_OPCODE(Address) != OPCODE_CALL) {
 | |
|     return FALSE;
 | |
|   }
 | |
| 
 | |
|   if (GET_OPERANDS (Address) & OPERAND_M_NATIVE_CALL) {
 | |
|     return FALSE;
 | |
|   } else {
 | |
|     return TRUE;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   Check whether current IP is EBC RET instruction.
 | |
| 
 | |
|   @param  Address   - EBC IP address.
 | |
| 
 | |
|   @retval TRUE  - Current IP is EBC RET instruction
 | |
|   @retval FALSE - Current IP is not EBC RET instruction
 | |
| 
 | |
| **/
 | |
| BOOLEAN
 | |
| IsEBCRET (
 | |
|   IN UINTN            Address
 | |
|   )
 | |
| {
 | |
|   if (GET_OPCODE(Address) != OPCODE_RET) {
 | |
|     return FALSE;
 | |
|   }
 | |
| 
 | |
|   if (GET_OPERANDS (Address) != 0) {
 | |
|     return FALSE;
 | |
|   } else {
 | |
|     return TRUE;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   DebuggerCommand - StepInto.
 | |
| 
 | |
|   @param  CommandArg      - The argument for this command
 | |
|   @param  DebuggerPrivate - EBC Debugger private data structure
 | |
|   @param  ExceptionType   - Exception type.
 | |
|   @param  SystemContext   - EBC system context.
 | |
| 
 | |
|   @retval EFI_DEBUG_CONTINUE - formal return value
 | |
| 
 | |
| **/
 | |
| EFI_DEBUG_STATUS
 | |
| DebuggerStepInto (
 | |
|   IN     CHAR16                    *CommandArg,
 | |
|   IN     EFI_DEBUGGER_PRIVATE_DATA *DebuggerPrivate,
 | |
|   IN     EFI_EXCEPTION_TYPE        ExceptionType,
 | |
|   IN OUT EFI_SYSTEM_CONTEXT        SystemContext
 | |
|   )
 | |
| {
 | |
|   SystemContext.SystemContextEbc->Flags |= VMFLAGS_STEP;
 | |
| 
 | |
|   return EFI_DEBUG_BREAK;
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   DebuggerCommand - StepOver.
 | |
| 
 | |
|   @param  CommandArg      - The argument for this command
 | |
|   @param  DebuggerPrivate - EBC Debugger private data structure
 | |
|   @param  ExceptionType   - Exception type.
 | |
|   @param  SystemContext   - EBC system context.
 | |
| 
 | |
|   @retval EFI_DEBUG_CONTINUE - formal return value
 | |
| 
 | |
| **/
 | |
| EFI_DEBUG_STATUS
 | |
| DebuggerStepOver (
 | |
|   IN     CHAR16                    *CommandArg,
 | |
|   IN     EFI_DEBUGGER_PRIVATE_DATA *DebuggerPrivate,
 | |
|   IN     EFI_EXCEPTION_TYPE        ExceptionType,
 | |
|   IN OUT EFI_SYSTEM_CONTEXT        SystemContext
 | |
|   )
 | |
| {
 | |
|   if (IsEBCCALL((UINTN)SystemContext.SystemContextEbc->Ip)) {
 | |
|     //
 | |
|     // Check CALL (NOTE: CALLEX is exclusive)
 | |
|     //
 | |
|     DebuggerPrivate->FeatureFlags |= EFI_DEBUG_FLAG_EBC_STEPOVER;
 | |
|   } else {
 | |
|     //
 | |
|     // Other instruction including CALLEX
 | |
|     //
 | |
|     SystemContext.SystemContextEbc->Flags |= VMFLAGS_STEP;
 | |
|   }
 | |
| 
 | |
|   return EFI_DEBUG_BREAK;
 | |
| }
 | |
| 
 | |
| /**
 | |
| 
 | |
|   DebuggerCommand - StepOut.
 | |
| 
 | |
|   @param  CommandArg      - The argument for this command
 | |
|   @param  DebuggerPrivate - EBC Debugger private data structure
 | |
|   @param  ExceptionType   - Exception type.
 | |
|   @param  SystemContext   - EBC system context.
 | |
| 
 | |
|   @retval EFI_DEBUG_CONTINUE - formal return value
 | |
| 
 | |
| **/
 | |
| EFI_DEBUG_STATUS
 | |
| DebuggerStepOut (
 | |
|   IN     CHAR16                    *CommandArg,
 | |
|   IN     EFI_DEBUGGER_PRIVATE_DATA *DebuggerPrivate,
 | |
|   IN     EFI_EXCEPTION_TYPE        ExceptionType,
 | |
|   IN OUT EFI_SYSTEM_CONTEXT        SystemContext
 | |
|   )
 | |
| {
 | |
|   if (IsEBCRET((UINTN)SystemContext.SystemContextEbc->Ip)) {
 | |
|     //
 | |
|     // Check RET
 | |
|     //
 | |
|     SystemContext.SystemContextEbc->Flags |= VMFLAGS_STEP;
 | |
|   } else {
 | |
|     //
 | |
|     // Other instruction
 | |
|     //
 | |
|     DebuggerPrivate->FeatureFlags |= EFI_DEBUG_FLAG_EBC_STEPOUT;
 | |
|   }
 | |
| 
 | |
|   return EFI_DEBUG_BREAK;
 | |
| }
 |