"R_AARCH64_MOVW_UABS_G3": "patch_aarch64_16d",
# x86_64-unknown-linux-gnu:
"R_X86_64_64": "patch_64",
- "R_X86_64_GOTPCREL": "patch_32r",
"R_X86_64_GOTPCRELX": "patch_x86_64_32rx",
- "R_X86_64_PC32": "patch_32r",
+ "R_X86_64_PLT32": "patch_32r",
"R_X86_64_REX_GOTPCRELX": "patch_x86_64_32rx",
# x86_64-apple-darwin:
"X86_64_RELOC_BRANCH": "patch_32r",
offset -= 3
case Hole(
offset=offset,
- kind="IMAGE_REL_I386_REL32" | "X86_64_RELOC_BRANCH",
+ kind="IMAGE_REL_I386_REL32" | "R_X86_64_PLT32" | "X86_64_RELOC_BRANCH",
value=HoleValue.CONTINUE,
symbol=None,
- addend=-4,
- ) as hole:
+ addend=addend,
+ ) as hole if _signed(addend) == -4:
# jmp 5
jump = b"\xE9\x00\x00\x00\x00"
offset -= 1
) as hole:
# b #4
jump = b"\x00\x00\x00\x14"
- case Hole(
- offset=offset,
- kind="R_X86_64_GOTPCRELX",
- value=HoleValue.GOT,
- symbol="_JIT_CONTINUE",
- addend=addend,
- ) as hole:
- assert _signed(addend) == -4
- # jmp qword ptr [rip]
- jump = b"\xFF\x25\x00\x00\x00\x00"
- offset -= 2
case _:
return
if self.body[offset:] == jump and offset % alignment == 0:
args = ["-fms-runtime-lib=dll"]
target = _COFF(host, args=args)
elif re.fullmatch(r"x86_64-.*-linux-gnu", host):
- args = ["-fpic"]
+ args = ["-fno-pic", "-mcmodel=medium", "-mlarge-data-threshold=0"]
target = _ELF(host, args=args)
else:
raise ValueError(host)