aboutsummaryrefslogtreecommitdiff
path: root/lld/test/ELF/x86-64-retpoline-znow-static-iplt.s
blob: 01cc1ec4579b914481cc845f70bdfd67d71d5e75 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
# REQUIRES: x86
# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t.o
# RUN: ld.lld -z retpolineplt -z now %t.o -o %t
# RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s

#0x2011a9+5 + 34 = 0x2011d0 (foo@plt)
# CHECK:      <_start>:
# CHECK-NEXT:  2011a9:       callq   34

#Static IPLT header due to -z retpolineplt
# CHECK:       00000000002011b0 <.plt>:
# CHECK-NEXT:  2011b0:       callq   11 <.plt+0x10>
# CHECK-NEXT:  2011b5:       pause
# CHECK-NEXT:  2011b7:       lfence
#foo@plt
# CHECK:       2011d0:       movq    4105(%rip), %r11
# CHECK-NEXT:  2011d7:       jmp     -44 <.plt>

.type foo STT_GNU_IFUNC
.globl foo
foo:
  ret

.globl _start
_start:
  call foo