Files
clang-p2996/lld/test/ELF/systemz-init-padding.s
Dominik Steenken 9f4a25e2a7 Add extended mnemonics (#97571)
This PR adds a number of thus-far missing extended mnemonics to the
assembler and disassembler for SystemZ.

The following mnemonics have been added and are supported for the
assembler and disassembler:

- `NOP(R)?`
- `LFI`
- `RISBG(N)?Z`

The following mnemonics have been added and are supported for the
assembler only:

- `JC(TH)?`
- `LLG(F|H)I`
- `NOT(G)?R`
2024-07-15 10:39:23 +02:00

28 lines
762 B
ArmAsm

# REQUIRES: systemz
# RUN: llvm-mc -filetype=obj -triple=s390x-unknown-linux %p/Inputs/systemz-init.s -o systemz-init.o
# RUN: llvm-mc -filetype=obj -triple=s390x-unknown-linux %s -o %t.o
# RUN: ld.lld -dynamic-linker /lib/ld64.so.1 %t.o systemz-init.o -o %t
# RUN: llvm-objdump -d --no-show-raw-insn -j .init %t | FileCheck %s
# glibc < 2.39 used to align .init and .fini code at a 4-byte boundary.
# When that happens, the linker must not pad the code with invalid
# instructions, e.g. null bytes.
.section .init,"ax",@progbits
brasl %r14, startup
# CHECK: <.init>:
# CHECK-NEXT: brasl %r14,
# CHECK-NEXT: nopr %r7
# CHECK-NEXT: lg %r4, 272(%r15)
.text
.globl startup
.p2align 4
startup:
br %r14
.globl main
.p2align 4
main:
br %r14