|
|
185e5f |
diff --git a/src/debug/ee/amd64/dbghelpers.S b/src/debug/ee/amd64/dbghelpers.S
|
|
|
185e5f |
index 85ec80c701..864c4dc943 100644
|
|
|
185e5f |
--- a/src/debug/ee/amd64/dbghelpers.S
|
|
|
185e5f |
+++ b/src/debug/ee/amd64/dbghelpers.S
|
|
|
185e5f |
@@ -29,7 +29,7 @@ NESTED_ENTRY FuncEvalHijack, _TEXT, UnhandledExceptionHandlerUnix
|
|
|
185e5f |
//
|
|
|
185e5f |
// epilogue
|
|
|
185e5f |
//
|
|
|
185e5f |
- add rsp, 20h
|
|
|
185e5f |
+ add rsp, 0x20
|
|
|
185e5f |
TAILJMP_RAX
|
|
|
185e5f |
NESTED_END FuncEvalHijack, _TEXT
|
|
|
185e5f |
|
|
|
185e5f |
@@ -65,14 +65,14 @@ NESTED_ENTRY ExceptionHijack, _TEXT, UnhandledExceptionHandlerUnix
|
|
|
185e5f |
// its arguments on the stack. In x64, it gets its arguments in
|
|
|
185e5f |
// registers (set up for us by DacDbiInterfaceImpl::Hijack),
|
|
|
185e5f |
// and this stack space may be reused.
|
|
|
185e5f |
- mov rax, [rsp + 20h]
|
|
|
185e5f |
+ mov rax, [rsp + 0x20]
|
|
|
185e5f |
mov [rsp], rax
|
|
|
185e5f |
- mov rax, [rsp + 28h]
|
|
|
185e5f |
- mov [rsp + 8h], rax
|
|
|
185e5f |
- mov rax, [rsp + 30h]
|
|
|
185e5f |
- mov [rsp + 10h], rax
|
|
|
185e5f |
- mov rax, [rsp + 38h]
|
|
|
185e5f |
- mov [rsp + 18h], rax
|
|
|
185e5f |
+ mov rax, [rsp + 0x28]
|
|
|
185e5f |
+ mov [rsp + 0x8], rax
|
|
|
185e5f |
+ mov rax, [rsp + 0x30]
|
|
|
185e5f |
+ mov [rsp + 0x10], rax
|
|
|
185e5f |
+ mov rax, [rsp + 0x38]
|
|
|
185e5f |
+ mov [rsp + 0x18], rax
|
|
|
185e5f |
|
|
|
185e5f |
// DD Hijack primitive already set the stack. So just make the call now.
|
|
|
185e5f |
call C_FUNC(ExceptionHijackWorker)
|
|
|
185e5f |
@@ -93,7 +93,7 @@ NESTED_ENTRY ExceptionHijack, _TEXT, UnhandledExceptionHandlerUnix
|
|
|
185e5f |
//
|
|
|
185e5f |
// epilogue
|
|
|
185e5f |
//
|
|
|
185e5f |
- add rsp, 20h
|
|
|
185e5f |
+ add rsp, 0x20
|
|
|
185e5f |
TAILJMP_RAX
|
|
|
185e5f |
|
|
|
185e5f |
// Put a label here to tell the debugger where the end of this function is.
|
|
|
185e5f |
diff --git a/src/pal/inc/unixasmmacros.inc b/src/pal/inc/unixasmmacros.inc
|
|
|
185e5f |
index e7a5eba898..8a74e3f266 100644
|
|
|
185e5f |
--- a/src/pal/inc/unixasmmacros.inc
|
|
|
185e5f |
+++ b/src/pal/inc/unixasmmacros.inc
|
|
|
185e5f |
@@ -2,7 +2,7 @@
|
|
|
185e5f |
// The .NET Foundation licenses this file to you under the MIT license.
|
|
|
185e5f |
// See the LICENSE file in the project root for more information.
|
|
|
185e5f |
|
|
|
185e5f |
-#define INVALIDGCVALUE 0CCCCCCCDh
|
|
|
185e5f |
+#define INVALIDGCVALUE 0xCCCCCCCD
|
|
|
185e5f |
|
|
|
185e5f |
#if defined(__APPLE__)
|
|
|
185e5f |
#define C_FUNC(name) _##name
|
|
|
185e5f |
diff --git a/src/vm/amd64/JitHelpers_Fast.asm b/src/vm/amd64/JitHelpers_Fast.asm
|
|
|
185e5f |
index 83f7132688..5251387408 100644
|
|
|
185e5f |
--- a/src/vm/amd64/JitHelpers_Fast.asm
|
|
|
185e5f |
+++ b/src/vm/amd64/JitHelpers_Fast.asm
|
|
|
185e5f |
@@ -40,7 +40,7 @@ EXTERN g_GCShadow:QWORD
|
|
|
185e5f |
EXTERN g_GCShadowEnd:QWORD
|
|
|
185e5f |
endif
|
|
|
185e5f |
|
|
|
185e5f |
-INVALIDGCVALUE equ 0CCCCCCCDh
|
|
|
185e5f |
+INVALIDGCVALUE equ 0xCCCCCCCD
|
|
|
185e5f |
|
|
|
185e5f |
ifdef _DEBUG
|
|
|
185e5f |
extern JIT_WriteBarrier_Debug:proc
|
|
|
185e5f |
diff --git a/src/vm/amd64/JitHelpers_Slow.asm b/src/vm/amd64/JitHelpers_Slow.asm
|
|
|
185e5f |
index 0e26ae6dfd..80b7453d4f 100644
|
|
|
185e5f |
--- a/src/vm/amd64/JitHelpers_Slow.asm
|
|
|
185e5f |
+++ b/src/vm/amd64/JitHelpers_Slow.asm
|
|
|
185e5f |
@@ -48,7 +48,7 @@ g_pStringClass equ ?g_pStringClass@@3PEAVMethodTable@@EA
|
|
|
185e5f |
FramedAllocateString equ ?FramedAllocateString@@YAPEAVStringObject@@K@Z
|
|
|
185e5f |
JIT_NewArr1 equ ?JIT_NewArr1@@YAPEAVObject@@PEAUCORINFO_CLASS_STRUCT_@@_J@Z
|
|
|
185e5f |
|
|
|
185e5f |
-INVALIDGCVALUE equ 0CCCCCCCDh
|
|
|
185e5f |
+INVALIDGCVALUE equ 0xCCCCCCCD
|
|
|
185e5f |
|
|
|
185e5f |
extern JIT_NEW:proc
|
|
|
185e5f |
extern CopyValueClassUnchecked:proc
|
|
|
185e5f |
diff --git a/src/vm/amd64/jithelpers_fast.S b/src/vm/amd64/jithelpers_fast.S
|
|
|
185e5f |
index 6f955b0bee..5f68fc0ebf 100644
|
|
|
185e5f |
--- a/src/vm/amd64/jithelpers_fast.S
|
|
|
185e5f |
+++ b/src/vm/amd64/jithelpers_fast.S
|
|
|
185e5f |
@@ -81,14 +81,14 @@ LEAF_ENTRY JIT_WriteBarrier, _TEXT
|
|
|
185e5f |
// Update the write watch table if necessary
|
|
|
185e5f |
mov rax, rdi
|
|
|
185e5f |
movabs r10, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
- shr rax, 0Ch // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
+ shr rax, 0xC // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
movabs r11, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
add rax, r10
|
|
|
185e5f |
- cmp byte ptr [rax], 0h
|
|
|
185e5f |
+ cmp byte ptr [rax], 0x0
|
|
|
185e5f |
.byte 0x75, 0x06
|
|
|
185e5f |
// jne CheckCardTable
|
|
|
185e5f |
- mov byte ptr [rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
NOP_3_BYTE // padding for alignment of constant
|
|
|
185e5f |
|
|
|
185e5f |
@@ -112,27 +112,27 @@ LEAF_ENTRY JIT_WriteBarrier, _TEXT
|
|
|
185e5f |
|
|
|
185e5f |
// Touch the card table entry, if not already dirty.
|
|
|
185e5f |
shr rdi, 0x0B
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
shr rdi, 0x0A
|
|
|
185e5f |
|
|
|
185e5f |
movabs rax, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle_WriteWatch_PostGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_WriteWatch_PostGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -177,14 +177,14 @@ LEAF_ENTRY JIT_WriteBarrier, _TEXT
|
|
|
185e5f |
movabs rax, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
|
|
|
185e5f |
// Touch the card table entry, if not already dirty.
|
|
|
185e5f |
- shr rdi, 0Bh
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ shr rdi, 0x0B
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0x0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP_6_BYTE // padding for alignment of constant
|
|
|
185e5f |
@@ -194,14 +194,14 @@ LEAF_ENTRY JIT_WriteBarrier, _TEXT
|
|
|
185e5f |
// Touch the card bundle, if not already dirty.
|
|
|
185e5f |
// rdi is already shifted by 0xB, so shift by 0xA more
|
|
|
185e5f |
shr rdi, 0x0A
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -312,15 +312,15 @@ LEAF_ENTRY JIT_ByRefWriteBarrier, _TEXT
|
|
|
185e5f |
#ifdef FEATURE_USE_SOFTWARE_WRITE_WATCH_FOR_GC_HEAP
|
|
|
185e5f |
// Update the write watch table if necessary
|
|
|
185e5f |
PREPARE_EXTERNAL_VAR g_sw_ww_enabled_for_gc_heap, rax
|
|
|
185e5f |
- cmp byte ptr [rax], 0h
|
|
|
185e5f |
+ cmp byte ptr [rax], 0x0
|
|
|
185e5f |
je CheckCardTable_ByRefWriteBarrier
|
|
|
185e5f |
mov rax, rdi
|
|
|
185e5f |
- shr rax, 0Ch // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
+ shr rax, 0xC // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
PREPARE_EXTERNAL_VAR g_sw_ww_table, r10
|
|
|
185e5f |
add rax, qword ptr [r10]
|
|
|
185e5f |
- cmp byte ptr [rax], 0h
|
|
|
185e5f |
+ cmp byte ptr [rax], 0x0
|
|
|
185e5f |
jne CheckCardTable_ByRefWriteBarrier
|
|
|
185e5f |
- mov byte ptr [rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
CheckCardTable_ByRefWriteBarrier:
|
|
|
185e5f |
@@ -334,8 +334,8 @@ LEAF_ENTRY JIT_ByRefWriteBarrier, _TEXT
|
|
|
185e5f |
|
|
|
185e5f |
// move current rdi value into rcx and then increment the pointers
|
|
|
185e5f |
mov rcx, rdi
|
|
|
185e5f |
- add rsi, 8h
|
|
|
185e5f |
- add rdi, 8h
|
|
|
185e5f |
+ add rsi, 0x8
|
|
|
185e5f |
+ add rdi, 0x8
|
|
|
185e5f |
|
|
|
185e5f |
// Check if we need to update the card table
|
|
|
185e5f |
// Calc pCardByte
|
|
|
185e5f |
@@ -345,13 +345,13 @@ LEAF_ENTRY JIT_ByRefWriteBarrier, _TEXT
|
|
|
185e5f |
mov rax, [rax]
|
|
|
185e5f |
|
|
|
185e5f |
// Check if this card is dirty
|
|
|
185e5f |
- cmp byte ptr [rcx + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rcx + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
jne UpdateCardTable_ByRefWriteBarrier
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_ByRefWriteBarrier:
|
|
|
185e5f |
- mov byte ptr [rcx + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rcx + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
// Shift rcx by 0x0A more to get the card bundle byte (we shifted by 0x0B already)
|
|
|
185e5f |
@@ -361,13 +361,13 @@ LEAF_ENTRY JIT_ByRefWriteBarrier, _TEXT
|
|
|
185e5f |
add rcx, [rax]
|
|
|
185e5f |
|
|
|
185e5f |
// Check if this bundle byte is dirty
|
|
|
185e5f |
- cmp byte ptr [rcx], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rcx], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
jne UpdateCardBundle_ByRefWriteBarrier
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_ByRefWriteBarrier:
|
|
|
185e5f |
- mov byte ptr [rcx], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rcx], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -383,8 +383,8 @@ LEAF_ENTRY JIT_ByRefWriteBarrier, _TEXT
|
|
|
185e5f |
#endif
|
|
|
185e5f |
Exit_ByRefWriteBarrier:
|
|
|
185e5f |
// Increment the pointers before leaving
|
|
|
185e5f |
- add rdi, 8h
|
|
|
185e5f |
- add rsi, 8h
|
|
|
185e5f |
+ add rdi, 0x8
|
|
|
185e5f |
+ add rsi, 0x8
|
|
|
185e5f |
ret
|
|
|
185e5f |
LEAF_END JIT_ByRefWriteBarrier, _TEXT
|
|
|
185e5f |
|
|
|
185e5f |
diff --git a/src/vm/amd64/jithelpers_fastwritebarriers.S b/src/vm/amd64/jithelpers_fastwritebarriers.S
|
|
|
185e5f |
index 23c1115165..0fe0e57472 100644
|
|
|
185e5f |
--- a/src/vm/amd64/jithelpers_fastwritebarriers.S
|
|
|
185e5f |
+++ b/src/vm/amd64/jithelpers_fastwritebarriers.S
|
|
|
185e5f |
@@ -38,13 +38,13 @@ PATCH_LABEL JIT_WriteBarrier_PreGrow64_Patch_Label_CardTable
|
|
|
185e5f |
|
|
|
185e5f |
// Touch the card table entry, if not already dirty.
|
|
|
185e5f |
shr rdi, 0x0B
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable_PreGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_PreGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP_6_BYTE // padding for alignment of constant
|
|
|
185e5f |
@@ -55,14 +55,14 @@ PATCH_LABEL JIT_WriteBarrier_PreGrow64_Patch_Label_CardBundleTable
|
|
|
185e5f |
// Touch the card bundle, if not already dirty.
|
|
|
185e5f |
// rdi is already shifted by 0xB, so shift by 0xA more
|
|
|
185e5f |
shr rdi, 0x0A
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle_PreGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_PreGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -123,13 +123,13 @@ PATCH_LABEL JIT_WriteBarrier_PostGrow64_Patch_Label_CardTable
|
|
|
185e5f |
|
|
|
185e5f |
// Touch the card table entry, if not already dirty.
|
|
|
185e5f |
shr rdi, 0x0B
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable_PostGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_PostGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP_6_BYTE // padding for alignment of constant
|
|
|
185e5f |
@@ -140,14 +140,14 @@ PATCH_LABEL JIT_WriteBarrier_PostGrow64_Patch_Label_CardBundleTable
|
|
|
185e5f |
// Touch the card bundle, if not already dirty.
|
|
|
185e5f |
// rdi is already shifted by 0xB, so shift by 0xA more
|
|
|
185e5f |
shr rdi, 0x0A
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle_PostGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_PostGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -182,13 +182,13 @@ PATCH_LABEL JIT_WriteBarrier_SVR64_PatchLabel_CardTable
|
|
|
185e5f |
|
|
|
185e5f |
shr rdi, 0x0B
|
|
|
185e5f |
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable_SVR64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_SVR64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP_6_BYTE // padding for alignment of constant
|
|
|
185e5f |
@@ -198,14 +198,14 @@ PATCH_LABEL JIT_WriteBarrier_SVR64_PatchLabel_CardBundleTable
|
|
|
185e5f |
|
|
|
185e5f |
// Shift the address by 0xA more since already shifted by 0xB
|
|
|
185e5f |
shr rdi, 0x0A
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle_SVR64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_SVR64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -236,15 +236,15 @@ LEAF_ENTRY JIT_WriteBarrier_WriteWatch_PreGrow64, _TEXT
|
|
|
185e5f |
mov rax, rdi
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_PreGrow64_Patch_Label_WriteWatchTable
|
|
|
185e5f |
movabs r10, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
- shr rax, 0Ch // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
+ shr rax, 0xC // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_PreGrow64_Patch_Label_Lower
|
|
|
185e5f |
movabs r11, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
add rax, r10
|
|
|
185e5f |
- cmp byte ptr [rax], 0h
|
|
|
185e5f |
+ cmp byte ptr [rax], 0x0
|
|
|
185e5f |
.byte 0x75, 0x03
|
|
|
185e5f |
// jne CheckCardTable_WriteWatch_PreGrow64
|
|
|
185e5f |
- mov byte ptr [rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
CheckCardTable_WriteWatch_PreGrow64:
|
|
|
185e5f |
// Check the lower ephemeral region bound.
|
|
|
185e5f |
@@ -263,13 +263,13 @@ PATCH_LABEL JIT_WriteBarrier_WriteWatch_PreGrow64_Patch_Label_Lower
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_PreGrow64_Patch_Label_CardTable
|
|
|
185e5f |
movabs rax, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable_WriteWatch_PreGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_WriteWatch_PreGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
@@ -277,14 +277,14 @@ PATCH_LABEL JIT_WriteBarrier_WriteWatch_PreGrow64_Patch_Label_CardBundleTable
|
|
|
185e5f |
movabs rax, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
|
|
|
185e5f |
shr rdi, 0x0A
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle_WriteWatch_PreGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_WriteWatch_PreGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -314,15 +314,15 @@ LEAF_ENTRY JIT_WriteBarrier_WriteWatch_PostGrow64, _TEXT
|
|
|
185e5f |
mov rax, rdi
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_PostGrow64_Patch_Label_WriteWatchTable
|
|
|
185e5f |
movabs r10, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
- shr rax, 0Ch // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
+ shr rax, 0xC // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_PostGrow64_Patch_Label_Lower
|
|
|
185e5f |
movabs r11, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
add rax, r10
|
|
|
185e5f |
- cmp byte ptr [rax], 0h
|
|
|
185e5f |
+ cmp byte ptr [rax], 0x0
|
|
|
185e5f |
.byte 0x75, 0x06
|
|
|
185e5f |
// jne CheckCardTable_WriteWatch_PostGrow64
|
|
|
185e5f |
- mov byte ptr [rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
NOP_3_BYTE // padding for alignment of constant
|
|
|
185e5f |
|
|
|
185e5f |
@@ -358,13 +358,13 @@ PATCH_LABEL JIT_WriteBarrier_WriteWatch_PostGrow64_Patch_Label_CardTable
|
|
|
185e5f |
|
|
|
185e5f |
// Touch the card table entry, if not already dirty.
|
|
|
185e5f |
shr rdi, 0x0B
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable_WriteWatch_PostGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_WriteWatch_PostGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
@@ -372,14 +372,14 @@ PATCH_LABEL JIT_WriteBarrier_WriteWatch_PostGrow64_Patch_Label_CardTable
|
|
|
185e5f |
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_PostGrow64_Patch_Label_CardBundleTable
|
|
|
185e5f |
movabs rax, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
- cmp byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle_WriteWatch_PostGrow64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_WriteWatch_PostGrow64:
|
|
|
185e5f |
- mov byte ptr [rdi + rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + rax], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
@@ -417,25 +417,25 @@ LEAF_ENTRY JIT_WriteBarrier_WriteWatch_SVR64, _TEXT
|
|
|
185e5f |
mov rax, rdi
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_SVR64_PatchLabel_WriteWatchTable
|
|
|
185e5f |
movabs r10, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
- shr rax, 0Ch // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
+ shr rax, 0xC // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
NOP_2_BYTE // padding for alignment of constant
|
|
|
185e5f |
PATCH_LABEL JIT_WriteBarrier_WriteWatch_SVR64_PatchLabel_CardTable
|
|
|
185e5f |
movabs r11, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
add rax, r10
|
|
|
185e5f |
- cmp byte ptr [rax], 0h
|
|
|
185e5f |
+ cmp byte ptr [rax], 0x0
|
|
|
185e5f |
.byte 0x75, 0x03
|
|
|
185e5f |
// jne CheckCardTable_WriteWatch_SVR64
|
|
|
185e5f |
- mov byte ptr [rax], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rax], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
CheckCardTable_WriteWatch_SVR64:
|
|
|
185e5f |
shr rdi, 0x0B
|
|
|
185e5f |
- cmp byte ptr [rdi + r11], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + r11], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardTable_WriteWatch_SVR64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_WriteWatch_SVR64:
|
|
|
185e5f |
- mov byte ptr [rdi + r11], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + r11], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
NOP // padding for alignment of constant
|
|
|
185e5f |
@@ -444,13 +444,13 @@ PATCH_LABEL JIT_WriteBarrier_WriteWatch_SVR64_PatchLabel_CardBundleTable
|
|
|
185e5f |
movabs r11, 0xF0F0F0F0F0F0F0F0
|
|
|
185e5f |
|
|
|
185e5f |
shr rdi, 0x0A
|
|
|
185e5f |
- cmp byte ptr [rdi + r11], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + r11], 0xFF
|
|
|
185e5f |
.byte 0x75, 0x02
|
|
|
185e5f |
// jne UpdateCardBundle_WriteWatch_SVR64
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_WriteWatch_SVR64:
|
|
|
185e5f |
- mov byte ptr [rdi + r11], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + r11], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
diff --git a/src/vm/amd64/jithelpers_slow.S b/src/vm/amd64/jithelpers_slow.S
|
|
|
185e5f |
index f61b42afc7..aa2e8cc064 100644
|
|
|
185e5f |
--- a/src/vm/amd64/jithelpers_slow.S
|
|
|
185e5f |
+++ b/src/vm/amd64/jithelpers_slow.S
|
|
|
185e5f |
@@ -71,15 +71,15 @@ LEAF_ENTRY JIT_WriteBarrier_Debug, _TEXT
|
|
|
185e5f |
#ifdef FEATURE_USE_SOFTWARE_WRITE_WATCH_FOR_GC_HEAP
|
|
|
185e5f |
// Update the write watch table if necessary
|
|
|
185e5f |
PREPARE_EXTERNAL_VAR g_sw_ww_enabled_for_gc_heap, r10
|
|
|
185e5f |
- cmp byte ptr [r10], 0h
|
|
|
185e5f |
+ cmp byte ptr [r10], 0x0
|
|
|
185e5f |
je CheckCardTable_Debug
|
|
|
185e5f |
mov r10, rdi
|
|
|
185e5f |
- shr r10, 0Ch // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
+ shr r10, 0xC // SoftwareWriteWatch::AddressToTableByteIndexShift
|
|
|
185e5f |
PREPARE_EXTERNAL_VAR g_sw_ww_table, r11
|
|
|
185e5f |
add r10, qword ptr [r11]
|
|
|
185e5f |
- cmp byte ptr [r10], 0h
|
|
|
185e5f |
+ cmp byte ptr [r10], 0x0
|
|
|
185e5f |
jne CheckCardTable_Debug
|
|
|
185e5f |
- mov byte ptr [r10], 0FFh
|
|
|
185e5f |
+ mov byte ptr [r10], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
CheckCardTable_Debug:
|
|
|
185e5f |
@@ -99,13 +99,13 @@ LEAF_ENTRY JIT_WriteBarrier_Debug, _TEXT
|
|
|
185e5f |
mov r10, [r10]
|
|
|
185e5f |
|
|
|
185e5f |
// Check if this card is dirty
|
|
|
185e5f |
- cmp byte ptr [rdi + r10], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi + r10], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
jne UpdateCardTable_Debug
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardTable_Debug:
|
|
|
185e5f |
- mov byte ptr [rdi + r10], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi + r10], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
#ifdef FEATURE_MANUALLY_MANAGED_CARD_BUNDLES
|
|
|
185e5f |
// Shift rdi by 0x0A more to get the card bundle byte (we shifted by 0x0B already)
|
|
|
185e5f |
@@ -115,13 +115,13 @@ LEAF_ENTRY JIT_WriteBarrier_Debug, _TEXT
|
|
|
185e5f |
add rdi, [r10]
|
|
|
185e5f |
|
|
|
185e5f |
// Check if this bundle byte is dirty
|
|
|
185e5f |
- cmp byte ptr [rdi], 0FFh
|
|
|
185e5f |
+ cmp byte ptr [rdi], 0xFF
|
|
|
185e5f |
|
|
|
185e5f |
jne UpdateCardBundle_Debug
|
|
|
185e5f |
REPRET
|
|
|
185e5f |
|
|
|
185e5f |
UpdateCardBundle_Debug:
|
|
|
185e5f |
- mov byte ptr [rdi], 0FFh
|
|
|
185e5f |
+ mov byte ptr [rdi], 0xFF
|
|
|
185e5f |
#endif
|
|
|
185e5f |
|
|
|
185e5f |
ret
|
|
|
185e5f |
diff --git a/src/vm/amd64/virtualcallstubamd64.S b/src/vm/amd64/virtualcallstubamd64.S
|
|
|
185e5f |
index 59b5b77dba..38c33d498e 100644
|
|
|
185e5f |
--- a/src/vm/amd64/virtualcallstubamd64.S
|
|
|
185e5f |
+++ b/src/vm/amd64/virtualcallstubamd64.S
|
|
|
185e5f |
@@ -59,19 +59,19 @@ LEAF_ENTRY ResolveWorkerChainLookupAsmStub, _TEXT
|
|
|
185e5f |
jnz Fail_RWCLAS // If the BACKPATCH_FLAGS is set we will go directly to the ResolveWorkerAsmStub
|
|
|
185e5f |
|
|
|
185e5f |
MainLoop_RWCLAS:
|
|
|
185e5f |
- mov rax, [rax+18h] // get the next entry in the chain (don't bother checking the first entry again)
|
|
|
185e5f |
+ mov rax, [rax+0x18] // get the next entry in the chain (don't bother checking the first entry again)
|
|
|
185e5f |
test rax,rax // test if we hit a terminating NULL
|
|
|
185e5f |
jz Fail_RWCLAS
|
|
|
185e5f |
|
|
|
185e5f |
- cmp rdx, [rax+00h] // compare our MT with the one in the ResolveCacheElem
|
|
|
185e5f |
+ cmp rdx, [rax+0x0] // compare our MT with the one in the ResolveCacheElem
|
|
|
185e5f |
jne MainLoop_RWCLAS
|
|
|
185e5f |
- cmp r10, [rax+08h] // compare our DispatchToken with one in the ResolveCacheElem
|
|
|
185e5f |
+ cmp r10, [rax+0x8] // compare our DispatchToken with one in the ResolveCacheElem
|
|
|
185e5f |
jne MainLoop_RWCLAS
|
|
|
185e5f |
Success_RWCLAS:
|
|
|
185e5f |
PREPARE_EXTERNAL_VAR CHAIN_SUCCESS_COUNTER, rdx
|
|
|
185e5f |
sub qword ptr [rdx],1 // decrement success counter
|
|
|
185e5f |
jl Promote_RWCLAS
|
|
|
185e5f |
- mov rax, [rax+10h] // get the ImplTarget
|
|
|
185e5f |
+ mov rax, [rax+0x10] // get the ImplTarget
|
|
|
185e5f |
pop rdx
|
|
|
185e5f |
jmp rax
|
|
|
185e5f |
|