diff --git a/diagnostics.sln b/diagnostics.sln index ed4beeecb2..91ac02996f 100644 --- a/diagnostics.sln +++ b/diagnostics.sln @@ -155,7 +155,6 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "inc", "inc", "{41BDFD6D-D16 src\shared\inc\readytoruninstructionset.h = src\shared\inc\readytoruninstructionset.h src\shared\inc\regdisp.h = src\shared\inc\regdisp.h src\shared\inc\registrywrapper.h = src\shared\inc\registrywrapper.h - src\shared\inc\releaseholder.h = src\shared\inc\releaseholder.h src\shared\inc\resource.h = src\shared\inc\resource.h src\shared\inc\runtimeinfo.h = src\shared\inc\runtimeinfo.h src\shared\inc\safemath.h = src\shared\inc\safemath.h @@ -333,6 +332,26 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "minipal", "minipal", "{D9A9 src\shared\native\minipal\utils.h = src\shared\native\minipal\utils.h EndProjectSection EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "inc", "inc", "{9E51C821-4095-4250-BD8A-2A29396DB1B4}" + ProjectSection(SolutionItems) = preProject + src\inc\corcompile.h = src\inc\corcompile.h + src\inc\ntimageex.h = src\inc\ntimageex.h + src\inc\releaseholder.h = src\inc\releaseholder.h + src\inc\stacktrace.h = src\inc\stacktrace.h + EndProjectSection +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "rt", "rt", "{D2D76252-D225-4B79-9DDB-A36867A4720E}" + ProjectSection(SolutionItems) = preProject + src\inc\rt\intsafe.h = src\inc\rt\intsafe.h + src\inc\rt\oaidl.h = src\inc\rt\oaidl.h + src\inc\rt\psapi.h = src\inc\rt\psapi.h + src\inc\rt\tchar.h = src\inc\rt\tchar.h + src\inc\rt\tlhelp32.h = src\inc\rt\tlhelp32.h + src\inc\rt\winapifamily.h = src\inc\rt\winapifamily.h + src\inc\rt\winternl.h = src\inc\rt\winternl.h + src\inc\rt\winver.h = src\inc\rt\winver.h + EndProjectSection +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Checked|Any CPU = Checked|Any CPU @@ -2365,6 +2384,8 @@ Global {06FB18BC-F4DD-4DB9-A566-551254CD1064} = {795B7A50-1B1F-406E-94E0-F9B35104EF22} {641F00F0-2693-451B-A96A-13E4E115BF0F} = {7852EDE4-93DF-4DB1-8A86-C521703811AF} {D9A91544-CDF8-4C68-BAD2-47F4968A8652} = {641F00F0-2693-451B-A96A-13E4E115BF0F} + {9E51C821-4095-4250-BD8A-2A29396DB1B4} = {19FAB78C-3351-4911-8F0C-8C6056401740} + {D2D76252-D225-4B79-9DDB-A36867A4720E} = {9E51C821-4095-4250-BD8A-2A29396DB1B4} EndGlobalSection GlobalSection(ExtensibilityGlobals) = postSolution SolutionGuid = {46465737-C938-44FC-BE1A-4CE139EBB5E0} diff --git a/eng/Versions.props b/eng/Versions.props index 9a19554cec..43f0cb8a71 100644 --- a/eng/Versions.props +++ b/eng/Versions.props @@ -56,7 +56,7 @@ 10.0.0-beta.24459.1 1.2.0-beta.406 7.0.0-beta.22316.2 - 10.0.18362 + 10.0.26100.1 13.0.1 10.0.0-alpha.1.24459.1 diff --git a/src/SOS/CMakeLists.txt b/src/SOS/CMakeLists.txt index ddee23f624..e1de7aff33 100644 --- a/src/SOS/CMakeLists.txt +++ b/src/SOS/CMakeLists.txt @@ -14,9 +14,9 @@ if(CLR_CMAKE_HOST_WIN32) add_compile_options(/Zl) # omit default library name in .OBJ add_subdirectory(runcommand) - if(NOT CLR_CMAKE_TARGET_ARCH_ARM64 AND NOT CLR_CMAKE_TARGET_ARCH_ARM) + if(NOT CLR_CMAKE_TARGET_ARCH_ARM) add_subdirectory(SOS.UnitTests/Debuggees/DesktopClrHost) - endif(NOT CLR_CMAKE_TARGET_ARCH_ARM64 AND NOT CLR_CMAKE_TARGET_ARCH_ARM) + endif(NOT CLR_CMAKE_TARGET_ARCH_ARM) endif(CLR_CMAKE_HOST_WIN32) add_compile_definitions(STRESS_LOG_ANALYZER) diff --git a/src/SOS/SOS.Extensions/DebuggerServices.cs b/src/SOS/SOS.Extensions/DebuggerServices.cs index f1f4caf563..82cb8872dd 100644 --- a/src/SOS/SOS.Extensions/DebuggerServices.cs +++ b/src/SOS/SOS.Extensions/DebuggerServices.cs @@ -82,9 +82,9 @@ public HResult GetDebuggeeType(out DEBUG_CLASS debugClass, out DEBUG_CLASS_QUALI return VTable.GetDebuggeeType(Self, out debugClass, out qualifier); } - public HResult GetExecutingProcessorType(out IMAGE_FILE_MACHINE type) + public HResult GetProcessorType(out IMAGE_FILE_MACHINE type) { - return VTable.GetExecutingProcessorType(Self, out type); + return VTable.GetProcessorType(Self, out type); } public HResult AddCommand(string command, string help, IEnumerable aliases) @@ -519,7 +519,7 @@ private readonly unsafe struct IDebuggerServicesVTable { public readonly delegate* unmanaged[Stdcall] GetOperatingSystem; public readonly delegate* unmanaged[Stdcall] GetDebuggeeType; - public readonly delegate* unmanaged[Stdcall] GetExecutingProcessorType; + public readonly delegate* unmanaged[Stdcall] GetProcessorType; public readonly delegate* unmanaged[Stdcall] AddCommand; public readonly delegate* unmanaged[Stdcall] OutputString; public readonly delegate* unmanaged[Stdcall] ReadVirtual; diff --git a/src/SOS/SOS.Extensions/TargetFromFromDebuggerServices.cs b/src/SOS/SOS.Extensions/TargetFromFromDebuggerServices.cs index aa8b378258..13fc5cd324 100644 --- a/src/SOS/SOS.Extensions/TargetFromFromDebuggerServices.cs +++ b/src/SOS/SOS.Extensions/TargetFromFromDebuggerServices.cs @@ -44,9 +44,10 @@ internal TargetFromDebuggerServices(DebuggerServices debuggerServices, IHost hos IsDump = true; } - hr = debuggerServices.GetExecutingProcessorType(out IMAGE_FILE_MACHINE type); + hr = debuggerServices.GetProcessorType(out IMAGE_FILE_MACHINE type); if (hr == HResult.S_OK) { + Debug.Assert(type is not IMAGE_FILE_MACHINE.ARM64X and not IMAGE_FILE_MACHINE.ARM64EC); Architecture = type switch { IMAGE_FILE_MACHINE.I386 => Architecture.X86, @@ -62,7 +63,7 @@ internal TargetFromDebuggerServices(DebuggerServices debuggerServices, IHost hos } else { - throw new PlatformNotSupportedException($"GetExecutingProcessorType() FAILED {hr:X8}"); + throw new PlatformNotSupportedException($"GetProcessorType() FAILED {hr:X8}"); } hr = debuggerServices.GetCurrentProcessId(out uint processId); diff --git a/src/SOS/SOS.Hosting/DbgEng/DebugControl.cs b/src/SOS/SOS.Hosting/DbgEng/DebugControl.cs index 50e0966688..097e8c1ac7 100644 --- a/src/SOS/SOS.Hosting/DbgEng/DebugControl.cs +++ b/src/SOS/SOS.Hosting/DbgEng/DebugControl.cs @@ -56,7 +56,7 @@ private static void AddDebugControl(VTableBuilder builder, SOSHost soshost) builder.AddMethod(new GetReturnOffsetDelegate((self, offset) => DebugClient.NotImplemented)); builder.AddMethod(new OutputStackTraceDelegate((self, outputControl, frames, frameSize, flags) => DebugClient.NotImplemented)); builder.AddMethod(new GetDebuggeeTypeDelegate(soshost.GetDebuggeeType)); - builder.AddMethod(new GetActualProcessorTypeDelegate((self, type) => DebugClient.NotImplemented)); + builder.AddMethod(new GetActualProcessorTypeDelegate(soshost.GetExecutingProcessorType)); builder.AddMethod(new GetExecutingProcessorTypeDelegate(soshost.GetExecutingProcessorType)); builder.AddMethod(new GetNumberPossibleExecutingProcessorTypesDelegate((self, number) => DebugClient.NotImplemented)); builder.AddMethod(new GetPossibleExecutingProcessorTypesDelegate((self, start, count, types) => DebugClient.NotImplemented)); diff --git a/src/SOS/SOS.Hosting/DbgEng/Interop/Enums/ImageFileMachine.cs b/src/SOS/SOS.Hosting/DbgEng/Interop/Enums/ImageFileMachine.cs index da1a4881e2..a8524a388f 100644 --- a/src/SOS/SOS.Hosting/DbgEng/Interop/Enums/ImageFileMachine.cs +++ b/src/SOS/SOS.Hosting/DbgEng/Interop/Enums/ImageFileMachine.cs @@ -35,6 +35,8 @@ public enum IMAGE_FILE_MACHINE : uint AMD64 = 0x8664, // AMD64 (K8) M32R = 0x9041, // M32R little-endian ARM64 = 0xAA64, // ARM64 Little-endian + ARM64EC = 0xA641, + ARM64X = 0xA64E, CEE = 0xC0EE, LOONGARCH64 = 0x6264, RISCV64 = 0x5064 diff --git a/src/SOS/SOS.Hosting/SOSHost.cs b/src/SOS/SOS.Hosting/SOSHost.cs index e78234871a..5a8cfb48b4 100644 --- a/src/SOS/SOS.Hosting/SOSHost.cs +++ b/src/SOS/SOS.Hosting/SOSHost.cs @@ -165,30 +165,16 @@ internal unsafe int GetExecutingProcessorType( IntPtr self, IMAGE_FILE_MACHINE* type) { - switch (Target.Architecture) - { - case Architecture.X64: - *type = IMAGE_FILE_MACHINE.AMD64; - break; - case Architecture.X86: - *type = IMAGE_FILE_MACHINE.I386; - break; - case Architecture.Arm: - *type = IMAGE_FILE_MACHINE.ARMNT; - break; - case Architecture.Arm64: - *type = IMAGE_FILE_MACHINE.ARM64; - break; - case (Architecture)6 /* Architecture.LoongArch64 */: - *type = IMAGE_FILE_MACHINE.LOONGARCH64; - break; - case (Architecture)9 /* Architecture.RiscV64 */: - *type = IMAGE_FILE_MACHINE.RISCV64; - break; - default: - *type = IMAGE_FILE_MACHINE.UNKNOWN; - break; - } + *type = Target.Architecture switch + { + Architecture.X64 => IMAGE_FILE_MACHINE.AMD64, + Architecture.X86 => IMAGE_FILE_MACHINE.I386, + Architecture.Arm => IMAGE_FILE_MACHINE.ARMNT, + Architecture.Arm64 => IMAGE_FILE_MACHINE.ARM64, + (Architecture)6 /* Architecture.LoongArch64 */=> IMAGE_FILE_MACHINE.LOONGARCH64, + (Architecture)9 /* Architecture.RiscV64 */=> IMAGE_FILE_MACHINE.RISCV64, + _ => IMAGE_FILE_MACHINE.UNKNOWN, + }; return HResult.S_OK; } diff --git a/src/SOS/SOS.UnitTests/ConfigFiles/Windows/Debugger.Tests.Config.txt b/src/SOS/SOS.UnitTests/ConfigFiles/Windows/Debugger.Tests.Config.txt index bf79961cf4..2d701b681b 100644 --- a/src/SOS/SOS.UnitTests/ConfigFiles/Windows/Debugger.Tests.Config.txt +++ b/src/SOS/SOS.UnitTests/ConfigFiles/Windows/Debugger.Tests.Config.txt @@ -124,7 +124,7 @@ - diff --git a/src/SOS/Strike/CMakeLists.txt b/src/SOS/Strike/CMakeLists.txt index 63124f3dc3..f0c7ab5410 100644 --- a/src/SOS/Strike/CMakeLists.txt +++ b/src/SOS/Strike/CMakeLists.txt @@ -30,9 +30,6 @@ if(CLR_CMAKE_HOST_ARCH_AMD64) message(STATUS "CLR_CMAKE_HOST_ARCH_AMD64") add_definitions(-DSOS_TARGET_AMD64=1) add_definitions(-D_TARGET_WIN64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_AMD64=1) - add_definitions(-DDBG_TARGET_WIN64=1) if (CLR_CMAKE_HOST_WIN32) add_definitions(-DSOS_TARGET_ARM64=1) endif(CLR_CMAKE_HOST_WIN32) @@ -43,43 +40,26 @@ elseif(CLR_CMAKE_HOST_ARCH_I386) add_definitions(-DSOS_TARGET_X86=1) add_definitions(-D_TARGET_X86_=1) add_definitions(-DTARGET_X86) - add_definitions(-DDBG_TARGET_X86=1) - add_definitions(-DDBG_TARGET_32BIT=1) if (CLR_CMAKE_HOST_WIN32) add_definitions(-DSOS_TARGET_ARM=1) endif(CLR_CMAKE_HOST_WIN32) elseif(CLR_CMAKE_HOST_ARCH_ARM) message(STATUS "CLR_CMAKE_HOST_ARCH_ARM") add_definitions(-DSOS_TARGET_ARM=1) - add_definitions(-D_TARGET_WIN32_=1) add_definitions(-D_TARGET_ARM_=1) - add_definitions(-DDBG_TARGET_ARM=1) - add_definitions(-DDBG_TARGET_32BIT=1) elseif(CLR_CMAKE_HOST_ARCH_ARM64) message(STATUS "CLR_CMAKE_HOST_ARCH_ARM64") add_definitions(-DSOS_TARGET_ARM64=1) add_definitions(-D_TARGET_WIN64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_ARM64=1) - add_definitions(-DDBG_TARGET_WIN64=1) elseif(CLR_CMAKE_HOST_ARCH_MIPS64) add_definitions(-DSOS_TARGET_MIPS64=1) add_definitions(-D_TARGET_WIN64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_MIPS64=1) - add_definitions(-DDBG_TARGET_WIN64=1) elseif(CLR_CMAKE_HOST_ARCH_RISCV64) add_definitions(-DSOS_TARGET_RISCV64=1) add_definitions(-D_TARGET_WIN64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_RISCV64=1) - add_definitions(-DDBG_TARGET_WIN64=1) elseif(CLR_CMAKE_HOST_ARCH_LOONGARCH64) add_definitions(-DSOS_TARGET_LOONGARCH64=1) add_definitions(-D_TARGET_WIN64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_LOONGARCH64=1) - add_definitions(-DDBG_TARGET_WIN64=1) endif() add_definitions(-DSTRIKE) diff --git a/src/SOS/Strike/clrma/managedanalysis.cpp b/src/SOS/Strike/clrma/managedanalysis.cpp index 04df2f2760..6adb3fa73a 100644 --- a/src/SOS/Strike/clrma/managedanalysis.cpp +++ b/src/SOS/Strike/clrma/managedanalysis.cpp @@ -70,8 +70,10 @@ ClrmaManagedAnalysis::QueryDebugClient(IUnknown* pUnknown) } switch (m_processorType) { - case IMAGE_FILE_MACHINE_ARM64: case IMAGE_FILE_MACHINE_AMD64: + case IMAGE_FILE_MACHINE_ARM64: + case IMAGE_FILE_MACHINE_ARM64X: + case IMAGE_FILE_MACHINE_ARM64EC: case IMAGE_FILE_MACHINE_LOONGARCH64: case IMAGE_FILE_MACHINE_RISCV64: m_pointerSize = 8; diff --git a/src/SOS/Strike/clrma/managedanalysis.h b/src/SOS/Strike/clrma/managedanalysis.h index a78852e9ef..02a80a3304 100644 --- a/src/SOS/Strike/clrma/managedanalysis.h +++ b/src/SOS/Strike/clrma/managedanalysis.h @@ -9,6 +9,7 @@ #include // IDL #include #include +#include #include #include #include @@ -21,14 +22,6 @@ #include #include -#ifndef IMAGE_FILE_MACHINE_RISCV64 -#define IMAGE_FILE_MACHINE_RISCV64 0x5064 // RISCV64 -#endif - -#ifndef IMAGE_FILE_MACHINE_LOONGARCH64 -#define IMAGE_FILE_MACHINE_LOONGARCH64 0x6264 // LOONGARCH64 -#endif - enum ClrmaGlobalFlags { LoggingEnabled = 0x01, // CLRMA logging enabled diff --git a/src/SOS/Strike/dbgengservices.cpp b/src/SOS/Strike/dbgengservices.cpp index 6dad478366..8d6bbaa64e 100644 --- a/src/SOS/Strike/dbgengservices.cpp +++ b/src/SOS/Strike/dbgengservices.cpp @@ -189,10 +189,24 @@ DbgEngServices::GetDebuggeeType( } HRESULT -DbgEngServices::GetExecutingProcessorType( +DbgEngServices::GetProcessorType( PULONG type) { - return m_control->GetExecutingProcessorType(type); + ULONG executingType; + HRESULT hr = m_control->GetExecutingProcessorType(&executingType); + if (FAILED(hr)) + { + return hr; + } + _ASSERTE(executingType != IMAGE_FILE_MACHINE_ARM64X); + *type = executingType; +#if defined(SOS_TARGET_AMD64) || defined(SOS_TARGET_ARM64) + if (executingType == IMAGE_FILE_MACHINE_ARM64EC) + { + *type = IMAGE_FILE_MACHINE_AMD64; + } +#endif // defined(SOS_TARGET_AMD64) || defined(SOS_TARGET_ARM64) + return S_OK; } HRESULT diff --git a/src/SOS/Strike/dbgengservices.h b/src/SOS/Strike/dbgengservices.h index 73eff8044d..c7cbb4092e 100644 --- a/src/SOS/Strike/dbgengservices.h +++ b/src/SOS/Strike/dbgengservices.h @@ -72,7 +72,7 @@ class DbgEngServices : public IDebuggerServices, public IRemoteMemoryService, pu PULONG debugClass, PULONG qualifier); - HRESULT STDMETHODCALLTYPE GetExecutingProcessorType( + HRESULT STDMETHODCALLTYPE GetProcessorType( PULONG type); HRESULT STDMETHODCALLTYPE AddCommand( diff --git a/src/SOS/Strike/disasmX86.cpp b/src/SOS/Strike/disasmX86.cpp index 11750ab77c..21db6e526a 100644 --- a/src/SOS/Strike/disasmX86.cpp +++ b/src/SOS/Strike/disasmX86.cpp @@ -620,7 +620,14 @@ void // #ifdef _WIN64 - ExtOut("%08x`%08x ", (ULONG)(InstrAddr >> 32), (ULONG)InstrAddr); + if (GetHost()->GetHostType() == IHost::HostType::DbgEng) + { + ExtOut("%08x`%08x ", (ULONG)(InstrAddr >> 32), (ULONG)InstrAddr); + } + else + { + ExtOut("%016llx ", InstrAddr); + } #else ExtOut("%08x ", (ULONG)InstrAddr); #endif diff --git a/src/SOS/Strike/exts.cpp b/src/SOS/Strike/exts.cpp index 81f304fd47..1bb392ba47 100644 --- a/src/SOS/Strike/exts.cpp +++ b/src/SOS/Strike/exts.cpp @@ -152,6 +152,15 @@ GetTargetMachine(ULONG processorType) targetMachine = ARM64Machine::GetInstance(); } #endif // SOS_TARGET_ARM64 + _ASSERTE(processorType != IMAGE_FILE_MACHINE_ARM64X); +#if defined(SOS_TARGET_AMD64) || defined(SOS_TARGET_ARM64) + if (processorType == IMAGE_FILE_MACHINE_ARM64EC) + { +#ifdef SOS_TARGET_AMD64 + targetMachine = AMD64Machine::GetInstance(); +#endif // SOS_TARGET_AMD64 + } +#endif // defined(SOS_TARGET_AMD64) || defined(SOS_TARGET_ARM64) #ifdef SOS_TARGET_RISCV64 if (processorType == IMAGE_FILE_MACHINE_RISCV64) { @@ -167,6 +176,46 @@ GetTargetMachine(ULONG processorType) return targetMachine; } +const char* +GetProcessorName(ULONG type) +{ + const char* architecture = "unknown"; + switch (type) + { + case IMAGE_FILE_MACHINE_AMD64: + architecture = "x64"; + break; + case IMAGE_FILE_MACHINE_I386: + architecture = "x86"; + break; + case IMAGE_FILE_MACHINE_ARM: + architecture = "arm"; + break; + case IMAGE_FILE_MACHINE_THUMB: + architecture = "thumb"; + break; + case IMAGE_FILE_MACHINE_ARMNT: + architecture = "armnt"; + break; + case IMAGE_FILE_MACHINE_ARM64: + architecture = "arm64"; + break; + case IMAGE_FILE_MACHINE_ARM64EC: + architecture = "arm64ec"; + break; + case IMAGE_FILE_MACHINE_ARM64X: + architecture = "arm64x"; + break; + case IMAGE_FILE_MACHINE_RISCV64: + architecture = "riscv64"; + break; + case IMAGE_FILE_MACHINE_LOONGARCH64: + architecture = "loongarch64"; + break; + } + return architecture; +} + HRESULT ArchQuery(void) { @@ -176,32 +225,19 @@ ArchQuery(void) g_targetMachine = GetTargetMachine(processorType); if (g_targetMachine == NULL) { - const char* architecture = ""; - switch (processorType) + const char* architecture = GetProcessorName(processorType); + const char* message = ""; +#if defined(SOS_TARGET_AMD64) || defined(SOS_TARGET_ARM64) + if (processorType == IMAGE_FILE_MACHINE_ARM64EC) + { + message = "Arm64ec targets require a x64 compatible SOS and debugger."; + } + else +#endif { - case IMAGE_FILE_MACHINE_AMD64: - architecture = "x64"; - break; - case IMAGE_FILE_MACHINE_I386: - architecture = "x86"; - break; - case IMAGE_FILE_MACHINE_ARM: - case IMAGE_FILE_MACHINE_THUMB: - case IMAGE_FILE_MACHINE_ARMNT: - architecture = "arm32"; - break; - case IMAGE_FILE_MACHINE_ARM64: - architecture = "arm64"; - break; - case IMAGE_FILE_MACHINE_RISCV64: - architecture = "riscv64"; - break; - case IMAGE_FILE_MACHINE_LOONGARCH64: - architecture = "loongarch64"; - break; + message = "A 32 bit target may require a 32 bit debugger or vice versa. In general, try to use the same bitness for the debugger and target process."; } - ExtErr("SOS does not support the current target architecture '%s' (0x%04x). A 32 bit target may require a 32 bit debugger or vice versa. In general, try to use the same bitness for the debugger and target process.\n", - architecture, processorType); + ExtErr("SOS does not support the current target architecture '%s' (0x%04x). %s\n", architecture, processorType, message); return E_FAIL; } return S_OK; diff --git a/src/SOS/Strike/exts.h b/src/SOS/Strike/exts.h index 31a15fd92c..5ee3a0c70d 100644 --- a/src/SOS/Strike/exts.h +++ b/src/SOS/Strike/exts.h @@ -55,14 +55,6 @@ // printing CDA values. #define CDA_TO_UL64(cda) ((ULONG64)(TO_TADDR(cda))) -#ifndef IMAGE_FILE_MACHINE_RISCV64 -#define IMAGE_FILE_MACHINE_RISCV64 0x5064 // RISCV64 -#endif // !IMAGE_FILE_MACHINE_RISCV64 - -#ifndef IMAGE_FILE_MACHINE_LOONGARCH64 -#define IMAGE_FILE_MACHINE_LOONGARCH64 0x6264 // LOONGARCH64 -#endif // !IMAGE_FILE_MACHINE_LOONGARCH64 - typedef struct _TADDR_RANGE { TADDR start; @@ -159,6 +151,9 @@ ExtQuery(PDEBUG_CLIENT client); HRESULT ExtInit(PDEBUG_CLIENT client); +const char* +GetProcessorName(ULONG type); + HRESULT ArchQuery(void); diff --git a/src/SOS/Strike/platformspecific.h b/src/SOS/Strike/platformspecific.h index 6a66df890d..88ac1a7368 100644 --- a/src/SOS/Strike/platformspecific.h +++ b/src/SOS/Strike/platformspecific.h @@ -14,6 +14,7 @@ // The main debugger code already has target platform definitions for CONTEXT. #include +#include #ifndef FEATURE_PAL @@ -42,14 +43,6 @@ struct DT_UNICODE_STRING #define DT_GDI_HANDLE_BUFFER_SIZE32 34 #define DT_GDI_HANDLE_BUFFER_SIZE64 60 -#ifndef IMAGE_FILE_MACHINE_ARMNT -#define IMAGE_FILE_MACHINE_ARMNT 0x01c4 // ARM Thumb-2 Little-Endian -#endif - -#ifndef IMAGE_FILE_MACHINE_ARM64 -#define IMAGE_FILE_MACHINE_ARM64 0xAA64 // ARM64 Little-Endian -#endif - #ifdef _TARGET_WIN64_ typedef ULONG DT_GDI_HANDLE_BUFFER[DT_GDI_HANDLE_BUFFER_SIZE64]; #else diff --git a/src/SOS/Strike/sos.def b/src/SOS/Strike/sos.def index 50b7ae3299..73f7ed5dac 100644 --- a/src/SOS/Strike/sos.def +++ b/src/SOS/Strike/sos.def @@ -141,6 +141,7 @@ EXPORTS pe=PrintException printexception=PrintException Printexception=PrintException + processor SaveModule savemodule=SaveModule SetHostRuntime diff --git a/src/SOS/Strike/strike.cpp b/src/SOS/Strike/strike.cpp index 59861b4411..bf8ac0e4bd 100644 --- a/src/SOS/Strike/strike.cpp +++ b/src/SOS/Strike/strike.cpp @@ -13618,6 +13618,27 @@ DECLARE_API(SetHostRuntime) return S_OK; } +DECLARE_API(processor) +{ + INIT_API_EXT(); + ULONG executingType; + if (SUCCEEDED(g_ExtControl->GetExecutingProcessorType(&executingType))) + { + ExtOut("Executing processor type: %04x '%s'\n", executingType, GetProcessorName(executingType)); + } + ULONG actualType; + if (SUCCEEDED(g_ExtControl->GetActualProcessorType(&actualType))) + { + ExtOut("Actual processor type: %04x '%s'\n", actualType, GetProcessorName(actualType)); + } + ULONG effectiveType; + if (SUCCEEDED(g_ExtControl->GetEffectiveProcessorType(&effectiveType))) + { + ExtOut("Effective processor type: %04x '%s'\n", effectiveType, GetProcessorName(effectiveType)); + } + return S_OK; +} + #endif // FEATURE_PAL // diff --git a/src/SOS/Strike/xplat/dbgeng.h b/src/SOS/Strike/xplat/dbgeng.h index 64a64fc916..146ecf1bdb 100644 --- a/src/SOS/Strike/xplat/dbgeng.h +++ b/src/SOS/Strike/xplat/dbgeng.h @@ -111,7 +111,14 @@ class DebugClient GetExecutingProcessorType( PULONG type) { - return m_lldbservices->GetExecutingProcessorType(type); + return m_lldbservices->GetProcessorType(type); + } + + HRESULT + GetActualProcessorType( + PULONG type) + { + return m_lldbservices->GetProcessorType(type); } HRESULT diff --git a/src/SOS/inc/debuggerservices.h b/src/SOS/inc/debuggerservices.h index e333177bc3..204a164525 100644 --- a/src/SOS/inc/debuggerservices.h +++ b/src/SOS/inc/debuggerservices.h @@ -37,7 +37,7 @@ IDebuggerServices : public IUnknown PULONG debugClass, PULONG qualifier) = 0; - virtual HRESULT STDMETHODCALLTYPE GetExecutingProcessorType( + virtual HRESULT STDMETHODCALLTYPE GetProcessorType( PULONG type) = 0; virtual HRESULT STDMETHODCALLTYPE AddCommand( diff --git a/src/SOS/inc/lldbservices.h b/src/SOS/inc/lldbservices.h index b31f251223..bef3f2ace6 100644 --- a/src/SOS/inc/lldbservices.h +++ b/src/SOS/inc/lldbservices.h @@ -321,7 +321,7 @@ ILLDBServices : public IUnknown // Returns the type of processor used in the // current processor context. - virtual HRESULT STDMETHODCALLTYPE GetExecutingProcessorType( + virtual HRESULT STDMETHODCALLTYPE GetProcessorType( PULONG type) = 0; // Executes the given command string. diff --git a/src/SOS/lldbplugin/CMakeLists.txt b/src/SOS/lldbplugin/CMakeLists.txt index a1656bfb71..76dc0ecc7b 100644 --- a/src/SOS/lldbplugin/CMakeLists.txt +++ b/src/SOS/lldbplugin/CMakeLists.txt @@ -20,50 +20,6 @@ if(SKIP_LLDBPLUGIN) set(REQUIRE_LLDBPLUGIN false) endif() -if(CLR_CMAKE_HOST_ARCH_AMD64) - add_definitions(-D_TARGET_AMD64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_AMD64=1) - add_definitions(-DDBG_TARGET_WIN64=1) - add_definitions(-DBIT64) -elseif(CLR_CMAKE_HOST_ARCH_I386) - add_definitions(-D_TARGET_X86_=1) - add_definitions(-DDBG_TARGET_32BIT=1) - add_definitions(-DDBG_TARGET_X86=1) -elseif(CLR_CMAKE_HOST_ARCH_ARM) - add_definitions(-D_TARGET_ARM_=1) - add_definitions(-DDBG_TARGET_32BIT=1) - add_definitions(-DDBG_TARGET_ARM=1) -elseif(CLR_CMAKE_HOST_ARCH_ARM64) - add_definitions(-D_TARGET_ARM64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_ARM64=1) - add_definitions(-DDBG_TARGET_WIN64=1) - add_definitions(-DBIT64) - SET(REQUIRE_LLDBPLUGIN false) -elseif(CLR_CMAKE_HOST_ARCH_MIPS64) - add_definitions(-D_TARGET_MIPS64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_MIPS64=1) - add_definitions(-DDBG_TARGET_WIN64=1) - add_definitions(-DBIT64) - SET(REQUIRE_LLDBPLUGIN false) -elseif(CLR_CMAKE_HOST_ARCH_RISCV64) - add_definitions(-D_TARGET_RISCV64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_RISCV64=1) - add_definitions(-DDBG_TARGET_WIN64=1) - add_definitions(-DBIT64) - SET(REQUIRE_LLDBPLUGIN false) -elseif(CLR_CMAKE_HOST_ARCH_LOONGARCH64) - add_definitions(-D_TARGET_LOONGARCH64_=1) - add_definitions(-DDBG_TARGET_64BIT=1) - add_definitions(-DDBG_TARGET_LOONGARCH64=1) - add_definitions(-DDBG_TARGET_WIN64=1) - add_definitions(-DBIT64) - SET(REQUIRE_LLDBPLUGIN false) -endif() - if(NOT $ENV{LLVM_HOME} STREQUAL "") set(LLDB_INCLUDE_DIR "$ENV{LLVM_HOME}/include") set(LLDB_LIB_DIR "$ENV{LLVM_HOME}/lib") diff --git a/src/SOS/lldbplugin/services.cpp b/src/SOS/lldbplugin/services.cpp index 182a74be46..9f8285b40e 100644 --- a/src/SOS/lldbplugin/services.cpp +++ b/src/SOS/lldbplugin/services.cpp @@ -223,17 +223,17 @@ LLDBServices::VirtualUnwind( DT_CONTEXT *dtcontext = (DT_CONTEXT*)context; lldb::SBFrame frameFound; -#ifdef DBG_TARGET_AMD64 +#ifdef TARGET_AMD64 DWORD64 spToFind = dtcontext->Rsp; -#elif DBG_TARGET_X86 +#elif TARGET_X86 DWORD spToFind = dtcontext->Esp; -#elif DBG_TARGET_ARM +#elif TARGET_ARM DWORD spToFind = dtcontext->Sp; -#elif DBG_TARGET_ARM64 +#elif TARGET_ARM64 DWORD64 spToFind = dtcontext->Sp; -#elif DBG_TARGET_RISCV64 +#elif TARGET_RISCV64 DWORD64 spToFind = dtcontext->Sp; -#elif DBG_TARGET_LOONGARCH64 +#elif TARGET_LOONGARCH64 DWORD64 spToFind = dtcontext->Sp; #else #error "spToFind undefined for this platform" @@ -447,20 +447,20 @@ LLDBServices::GetPageSize( } HRESULT -LLDBServices::GetExecutingProcessorType( +LLDBServices::GetProcessorType( PULONG type) { -#ifdef DBG_TARGET_AMD64 +#ifdef TARGET_AMD64 *type = IMAGE_FILE_MACHINE_AMD64; -#elif DBG_TARGET_ARM +#elif TARGET_ARM *type = IMAGE_FILE_MACHINE_ARMNT; -#elif DBG_TARGET_ARM64 +#elif TARGET_ARM64 *type = IMAGE_FILE_MACHINE_ARM64; -#elif DBG_TARGET_X86 +#elif TARGET_X86 *type = IMAGE_FILE_MACHINE_I386; -#elif DBG_TARGET_RISCV64 +#elif TARGET_RISCV64 *type = IMAGE_FILE_MACHINE_RISCV64; -#elif DBG_TARGET_LOONGARCH64 +#elif TARGET_LOONGARCH64 *type = IMAGE_FILE_MACHINE_LOONGARCH64; #else #error "Unsupported target" @@ -1629,7 +1629,7 @@ LLDBServices::GetContextFromFrame( /* const */ lldb::SBFrame& frame, DT_CONTEXT *dtcontext) { -#ifdef DBG_TARGET_AMD64 +#ifdef TARGET_AMD64 dtcontext->Rip = frame.GetPC(); dtcontext->Rsp = frame.GetSP(); dtcontext->Rbp = frame.GetFP(); @@ -1656,7 +1656,7 @@ LLDBServices::GetContextFromFrame( dtcontext->SegEs = GetRegister(frame, "es"); dtcontext->SegFs = GetRegister(frame, "fs"); dtcontext->SegGs = GetRegister(frame, "gs"); -#elif DBG_TARGET_ARM +#elif TARGET_ARM dtcontext->Pc = frame.GetPC(); dtcontext->Sp = frame.GetSP(); dtcontext->Lr = GetRegister(frame, "lr"); @@ -1675,7 +1675,7 @@ LLDBServices::GetContextFromFrame( dtcontext->R10 = GetRegister(frame, "r10"); dtcontext->R11 = GetRegister(frame, "r11"); dtcontext->R12 = GetRegister(frame, "r12"); -#elif DBG_TARGET_ARM64 +#elif TARGET_ARM64 dtcontext->Pc = frame.GetPC(); dtcontext->Sp = frame.GetSP(); dtcontext->Lr = GetRegister(frame, "x30"); @@ -1711,7 +1711,7 @@ LLDBServices::GetContextFromFrame( dtcontext->X26 = GetRegister(frame, "x26"); dtcontext->X27 = GetRegister(frame, "x27"); dtcontext->X28 = GetRegister(frame, "x28"); -#elif DBG_TARGET_X86 +#elif TARGET_X86 dtcontext->Eip = frame.GetPC(); dtcontext->Esp = frame.GetSP(); dtcontext->Ebp = frame.GetFP(); @@ -1730,7 +1730,7 @@ LLDBServices::GetContextFromFrame( dtcontext->SegEs = GetRegister(frame, "es"); dtcontext->SegFs = GetRegister(frame, "fs"); dtcontext->SegGs = GetRegister(frame, "gs"); -#elif DBG_TARGET_LOONGARCH64 +#elif TARGET_LOONGARCH64 dtcontext->Pc = frame.GetPC(); dtcontext->Sp = frame.GetSP(); dtcontext->Ra = GetRegister(frame, "ra"); diff --git a/src/SOS/lldbplugin/services.h b/src/SOS/lldbplugin/services.h index a69bb236a2..734f56bf2f 100644 --- a/src/SOS/lldbplugin/services.h +++ b/src/SOS/lldbplugin/services.h @@ -136,7 +136,7 @@ class LLDBServices : public ILLDBServices, public ILLDBServices2, public IDebugg HRESULT STDMETHODCALLTYPE GetPageSize( PULONG size); - HRESULT STDMETHODCALLTYPE GetExecutingProcessorType( + HRESULT STDMETHODCALLTYPE GetProcessorType( PULONG type); HRESULT STDMETHODCALLTYPE Execute( diff --git a/src/dbgshim/debugshim.cpp b/src/dbgshim/debugshim.cpp index 06cbe5f8af..6525aa97e4 100644 --- a/src/dbgshim/debugshim.cpp +++ b/src/dbgshim/debugshim.cpp @@ -11,16 +11,9 @@ #include "dbgutil.h" #include #include //has the CLR_ID_V4_DESKTOP guid in it +#include #include "palclr.h" -#ifndef IMAGE_FILE_MACHINE_ARMNT -#define IMAGE_FILE_MACHINE_ARMNT 0x01c4 // ARM Thumb-2 Little-Endian -#endif - -#ifndef IMAGE_FILE_MACHINE_ARM64 -#define IMAGE_FILE_MACHINE_ARM64 0xAA64 // ARM64 Little-Endian -#endif - //***************************************************************************** // CLRDebuggingImpl implementation (ICLRDebugging) //***************************************************************************** @@ -766,9 +759,9 @@ HRESULT CLRDebuggingImpl::FormatLongDacModuleName(_Inout_updates_z_(cchBuffer) W #endif const WCHAR* pDacBaseName = NULL; - if(m_skuId == CLR_ID_V4_DESKTOP) + if (m_skuId == CLR_ID_V4_DESKTOP) pDacBaseName = CLR_DAC_MODULE_NAME_W; - else if(m_skuId == CLR_ID_CORECLR || m_skuId == CLR_ID_PHONE_CLR || m_skuId == CLR_ID_ONECORE_CLR) + else if (m_skuId == CLR_ID_CORECLR || m_skuId == CLR_ID_PHONE_CLR || m_skuId == CLR_ID_ONECORE_CLR) pDacBaseName = CORECLR_DAC_MODULE_NAME_W; else { @@ -776,23 +769,33 @@ HRESULT CLRDebuggingImpl::FormatLongDacModuleName(_Inout_updates_z_(cchBuffer) W return E_UNEXPECTED; } + _ASSERTE(targetImageFileMachine != IMAGE_FILE_MACHINE_ARM64X && targetImageFileMachine != IMAGE_FILE_MACHINE_ARM64EC); + const WCHAR* pTargetArch = NULL; - if(targetImageFileMachine == IMAGE_FILE_MACHINE_I386) + if (targetImageFileMachine == IMAGE_FILE_MACHINE_I386) { pTargetArch = W("x86"); } - else if(targetImageFileMachine == IMAGE_FILE_MACHINE_AMD64) + else if (targetImageFileMachine == IMAGE_FILE_MACHINE_AMD64) { pTargetArch = W("amd64"); } - else if(targetImageFileMachine == IMAGE_FILE_MACHINE_ARMNT) + else if (targetImageFileMachine == IMAGE_FILE_MACHINE_ARMNT) { pTargetArch = W("arm"); } - else if(targetImageFileMachine == IMAGE_FILE_MACHINE_ARM64) + else if (targetImageFileMachine == IMAGE_FILE_MACHINE_ARM64) { pTargetArch = W("arm64"); } + else if (targetImageFileMachine == IMAGE_FILE_MACHINE_RISCV64) + { + pTargetArch = W("riscv64"); + } + else if (targetImageFileMachine == IMAGE_FILE_MACHINE_LOONGARCH64) + { + pTargetArch = W("loongarch64"); + } else { _ASSERTE(!"Unknown target image file machine type"); @@ -800,9 +803,9 @@ HRESULT CLRDebuggingImpl::FormatLongDacModuleName(_Inout_updates_z_(cchBuffer) W } const WCHAR* pBuildFlavor = W(""); - if(pVersion->dwFileFlags & VS_FF_DEBUG) + if (pVersion->dwFileFlags & VS_FF_DEBUG) { - if(pVersion->dwFileFlags & VS_FF_SPECIALBUILD) + if (pVersion->dwFileFlags & VS_FF_SPECIALBUILD) pBuildFlavor = W(".dbg"); else pBuildFlavor = W(".chk"); @@ -823,7 +826,7 @@ HRESULT CLRDebuggingImpl::FormatLongDacModuleName(_Inout_updates_z_(cchBuffer) W // validate the output buffer is larger than our estimate above _ASSERTE(cchBuffer >= minCchBuffer); - if(!(cchBuffer >= minCchBuffer)) return E_INVALIDARG; + if (!(cchBuffer >= minCchBuffer)) return E_INVALIDARG; swprintf_s(pBuffer, cchBuffer, W("%s_%s_%s_%u.%u.%u.%02u%s.dll"), pDacBaseName, diff --git a/src/inc/ntimageex.h b/src/inc/ntimageex.h new file mode 100644 index 0000000000..b249b74a4c --- /dev/null +++ b/src/inc/ntimageex.h @@ -0,0 +1,29 @@ +// Licensed to the .NET Foundation under one or more agreements. +// The .NET Foundation licenses this file to you under the MIT license. + +#pragma once + +#ifndef IMAGE_FILE_MACHINE_ARMNT +#define IMAGE_FILE_MACHINE_ARMNT 0x01c4 // ARM Thumb-2 Little-Endian +#endif + +#ifndef IMAGE_FILE_MACHINE_ARM64 +#define IMAGE_FILE_MACHINE_ARM64 0xAA64 // ARM64 Little-Endian +#endif + +#ifndef IMAGE_FILE_MACHINE_ARM64EC +#define IMAGE_FILE_MACHINE_ARM64EC 0xA641 +#endif + +#ifndef IMAGE_FILE_MACHINE_ARM64X +#define IMAGE_FILE_MACHINE_ARM64X 0xA64E +#endif + +#ifndef IMAGE_FILE_MACHINE_RISCV64 +#define IMAGE_FILE_MACHINE_RISCV64 0x5064 // RISCV64 +#endif + +#ifndef IMAGE_FILE_MACHINE_LOONGARCH64 +#define IMAGE_FILE_MACHINE_LOONGARCH64 0x6264 // LOONGARCH64 +#endif + diff --git a/src/shared/pal/src/init/pal.cpp b/src/shared/pal/src/init/pal.cpp index 871c220db0..f6ea18445d 100644 --- a/src/shared/pal/src/init/pal.cpp +++ b/src/shared/pal/src/init/pal.cpp @@ -87,6 +87,11 @@ int CacheLineSize; using namespace CorUnix; +#if defined(HOST_ARM64) +// Flag to check if atomics feature is available on +// the machine +bool g_arm64_atomics_present = false; +#endif Volatile init_count = 0; Volatile shutdown_intent = 0;