Files
clang-p2996/llvm/test/CodeGen/X86/patchable-prologue-tailcall.ll
Alexandre Ganea bb28442c0b [CodeGen][X86] Fix lowering of tailcalls when -ms-hotpatch is used (#77245)
Previously, tail jump pseudo-opcodes were skipped by the
`encodeInstruction()` call inside `X86AsmPrinter::LowerPATCHABLE_OP`.
This caused emission of a 2-byte NOP and dropping of the tail jump.

With this PR, we change `PATCHABLE_OP` to not wrap the first
`MachineInstr` anymore, but inserting itself before,
leaving the instruction unaltered. At lowering time in `X86AsmPrinter`,
we now "look ahead" for the next non-pseudo `MachineInstr` and
lower+encode it, to inspect its size. If the size is below what
`PATCHABLE_OP` expects, it inserts NOPs; otherwise it does nothing. That
way, now the first `MachineInstr` is always lowered as usual even if
`"patchable-function"="prologue-short-redirect"` is used.

Fixes https://github.com/llvm/llvm-project/issues/76879,
https://github.com/llvm/llvm-project/issues/76958 and
https://github.com/llvm/llvm-project/issues/59039
2024-01-22 14:19:08 -05:00

35 lines
970 B
LLVM

; RUN: llc -verify-machineinstrs -mtriple=x86_64-windows-msvc < %s | FileCheck %s --check-prefix=CHECK
; CHECK: f1:
; CHECK-NEXT: # %bb.0:
; CHECK-NEXT: jmp f0 # TAILCALL
; CHECK: f2:
; CHECK-NEXT: # %bb.0:
; CHECK-NEXT: jmp malloc # TAILCALL
define ptr @f1(i64 %count) "patchable-function"="prologue-short-redirect" {
entry:
%call = tail call ptr @f0(i64 %count)
ret ptr %call
}
declare ptr @f0(i64)
define noalias ptr @f2(i64 %count) "patchable-function"="prologue-short-redirect" {
entry:
%call = tail call ptr @malloc(i64 %count)
ret ptr %call
}
declare noalias ptr @malloc(i64) #0
attributes #0 = { allockind("alloc,uninitialized") allocsize(0) memory(inaccessiblemem: readwrite) "alloc-family"="malloc" }
!llvm.module.flags = !{!0, !1, !2, !3}
!0 = !{i32 1, !"wchar_size", i32 2}
!1 = !{i32 8, !"PIC Level", i32 2}
!2 = !{i32 7, !"uwtable", i32 2}
!3 = !{i32 1, !"MaxTLSAlign", i32 65536}