From ef530fe71f47d7ae6fe12bfc60d876ea9ac25917 Mon Sep 17 00:00:00 2001 From: Michael Kinney Date: Mon, 27 Apr 2015 19:51:46 +0000 Subject: [PATCH] SourceLevelDebugPkg/PeCoffExtraActionLibDebug: Support IA32 processors without debug extensions Use CPUID Leaf 01 to detect support for debug extensions. Force use of software breakpoints if debug extensions are not supported. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Michael Kinney Reviewed-by: Jordan Justen git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17219 6f19259b-4bc3-4df7-8a09-765794883524 --- .../PeCoffExtraActionLib.c | 13 ++++++++++++- .../PeCoffExtraActionLibDebug.inf | 4 ++-- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLib.c b/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLib.c index 84cfe19efc..87420709f6 100644 --- a/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLib.c +++ b/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLib.c @@ -1,7 +1,7 @@ /** @file PE/Coff Extra Action library instances. - Copyright (c) 2010 - 2013, Intel Corporation. All rights reserved.
+ Copyright (c) 2010 - 2015, Intel Corporation. All rights reserved.
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 @@ -65,6 +65,7 @@ PeCoffLoaderExtraActionCommon ( IA32_DESCRIPTOR IdtDescriptor; IA32_IDT_GATE_DESCRIPTOR OriginalIdtEntry; BOOLEAN IdtEntryHooked; + UINT32 RegEdx; ASSERT (ImageContext != NULL); @@ -79,6 +80,16 @@ PeCoffLoaderExtraActionCommon ( IdtEntryHooked = FALSE; LoadImageMethod = PcdGet8 (PcdDebugLoadImageMethod); + if (LoadImageMethod == DEBUG_LOAD_IMAGE_METHOD_IO_HW_BREAKPOINT) { + // + // If the CPU does not support Debug Extensions(CPUID:01 EDX:BIT2) + // then force use of DEBUG_LOAD_IMAGE_METHOD_SOFT_INT3 + // + AsmCpuid (1, NULL, NULL, NULL, &RegEdx); + if ((RegEdx & BIT2) == 0) { + LoadImageMethod = DEBUG_LOAD_IMAGE_METHOD_SOFT_INT3; + } + } AsmReadIdtr (&IdtDescriptor); if (LoadImageMethod == DEBUG_LOAD_IMAGE_METHOD_SOFT_INT3) { if (!CheckDebugAgentHandler (&IdtDescriptor, SOFT_INT_VECTOR_NUM)) { diff --git a/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLibDebug.inf b/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLibDebug.inf index 717aa97d87..e53f1d936c 100644 --- a/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLibDebug.inf +++ b/SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLibDebug.inf @@ -1,7 +1,7 @@ ## @file # PeCoffExtraAction Library to support source level debug. # -# Copyright (c) 2010 - 2014, Intel Corporation. All rights reserved.
+# Copyright (c) 2010 - 2015, Intel Corporation. All rights reserved.
# # This program and the accompanying materials # are licensed and made available under the terms and conditions of the BSD License @@ -19,7 +19,7 @@ MODULE_UNI_FILE = PeCoffExtraActionLib.uni FILE_GUID = 8F01CBD5-E069-44d7-90C9-35F0318603AD MODULE_TYPE = BASE - VERSION_STRING = 0.7 + VERSION_STRING = 0.8 LIBRARY_CLASS = PeCoffExtraActionLib # -- 2.39.2