From 6d3378e7aa0b009e63c362bd696866e1d8a6d4a2 Mon Sep 17 00:00:00 2001 From: Jonghyun Park Date: Wed, 7 Dec 2016 15:37:07 +0900 Subject: [PATCH] [x86/Linux] Port StubLinkerCPU::EmitSetup (dotnet/coreclr#8494) This commit ports StubLinkerCPU::EmitSetup to x86/Linux. Commit migrated from https://github.com/dotnet/coreclr/commit/375948e39cf1a946b3d8048ca51cd4e548f94648 --- src/coreclr/src/vm/i386/stublinkerx86.cpp | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/src/coreclr/src/vm/i386/stublinkerx86.cpp b/src/coreclr/src/vm/i386/stublinkerx86.cpp index fb2b1fe857bd3..63b9e87367779 100644 --- a/src/coreclr/src/vm/i386/stublinkerx86.cpp +++ b/src/coreclr/src/vm/i386/stublinkerx86.cpp @@ -2866,7 +2866,6 @@ VOID StubLinkerCPU::EmitSetup(CodeLabel *pForwardRef) { STANDARD_VM_CONTRACT; -#ifndef FEATURE_PAL #ifdef FEATURE_IMPLICIT_TLS DWORD idx = 0; TLSACCESSMODE mode = TLSACCESS_GENERIC; @@ -2889,6 +2888,7 @@ VOID StubLinkerCPU::EmitSetup(CodeLabel *pForwardRef) switch (mode) { case TLSACCESS_WNT: +#ifndef FEATURE_PAL { unsigned __int32 tlsofs = offsetof(TEB, TlsSlots) + (idx * sizeof(void*)); @@ -2896,6 +2896,9 @@ VOID StubLinkerCPU::EmitSetup(CodeLabel *pForwardRef) EmitBytes(code, sizeof(code)); Emit32(tlsofs); } +#else // !FEATURE_PAL + _ASSERTE("TLSACCESS_WNT mode is not supported"); +#endif // !FEATURE_PAL break; case TLSACCESS_GENERIC: @@ -2926,10 +2929,6 @@ VOID StubLinkerCPU::EmitSetup(CodeLabel *pForwardRef) X86EmitDebugTrashReg(kECX); X86EmitDebugTrashReg(kEDX); #endif - -#else // FEATURE_PAL - PORTABILITY_ASSERT("StubLinkerCPU::EmitSetup"); -#endif // FEATURE_PAL } VOID StubLinkerCPU::EmitRareSetup(CodeLabel *pRejoinPoint, BOOL fThrow)