Skip to content

Commit

Permalink
fix(module): Fix ARM trampoline
Browse files Browse the repository at this point in the history
The previous trampoline was tested on a simulator but for normal,
non-Thumb mode.

This commit marks the first successful boot of `lxmonika` on 32-bit
ARM Windows. See #3.
  • Loading branch information
trungnt2910 committed Nov 24, 2024
1 parent 0f2bf24 commit 3c75c32
Showing 1 changed file with 14 additions and 2 deletions.
16 changes: 14 additions & 2 deletions lxmonika/src/module.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -608,8 +608,9 @@ MdlpPatchTrampoline(
// jmp eax
0xFF, 0xE0
#elif defined(_M_ARM)
// ldr pc, [pc, #-0x4]
0x04, 0xF0, 0x1F, 0xE5,
// ldr pc, [pc, #-0x0] -> Windows ARM32 uses Thumb mode.
// pc points 1 instructions ahead.
0x5F, 0xF8, 0x00, 0xF0,
// .addr
0x00, 0x00, 0x00, 0x00
#else
Expand All @@ -624,6 +625,13 @@ MdlpPatchTrampoline(
#elif defined(_M_IX86)
memcpy(chShellCode + 1, &pHook, sizeof(PVOID));
#elif defined(_M_ARM)
// All Thumb function pointers have least significant bit set to 1.
// For the MEMORY ADDRESS to copy to, clear this bit.
pOriginal = (PVOID)(((SIZE_T)pOriginal) & ~1);

// For the JUMP TARGET (pHook), however,
// we need to keep this bit to indicate thumb mode.

memcpy(chShellCode + 4, &pHook, sizeof(PVOID));
#else
#error Put Address into Trampoline!
Expand All @@ -634,6 +642,10 @@ MdlpPatchTrampoline(
}
else // pHook == NULL, unhooking
{
#if defined(_M_ARM)
pOriginal = (PVOID)(((SIZE_T)pOriginal) & ~1);
#endif

MA_RETURN_IF_FAIL(MdlpGodMemcpy(pOriginal, pBytes, MDL_TRAMPOLINE_SIZE));
}

Expand Down

0 comments on commit 3c75c32

Please sign in to comment.