# RUN: llvm-mc -filetype=obj -triple x86_64 --x86-align-branch-boundary=32 --x86-align-branch=call+indirect %s | llvm-objdump -d --no-show-raw-insn - | FileCheck %s --check-prefixes=CHECK,X64
# RUN: llvm-mc -filetype=obj -triple i386 --x86-align-branch-boundary=32 --x86-align-branch=call+indirect %s | llvm-objdump -d --no-show-raw-insn - | FileCheck %s --check-prefixes=CHECK,X86
# Exercise cases where the instruction to be aligned has a variant symbol
# operand, and we can't add before it since linker may rewrite it.
.text
.global foo
foo:
.p2align 5
.rept 30
int3
.endr
# CHECK: 1d: int3
# X64: 1e: callq
# X86: 1e: calll
# CHECK: 23: int3
call ___tls_get_addr@PLT
int3
.p2align 5
.rept 30
int3
.endr
# CHECK: 5d: int3
# X64: 5e: callq *(%ecx)
# X64: 65: int3
# X86: 5e: calll *(%ecx)
# X86: 64: int3
call *___tls_get_addr@GOT(%ecx)
int3
.p2align 5
.rept 30
int3
.endr
# CHECK: 9d: int3
# X64: 9e: callq *(%eax)
# X64: a1: int3
# X86: 9e: calll *(%eax)
# X86: a0: int3
call *foo@tlscall(%eax)
int3
.p2align 5
.rept 30
int3
.endr
# CHECK: dd: int3
# X64: de: jmpq *(%eax)
# X64: e1: int3
# X86: de: jmpl *(%eax)
# X86: e0: int3
jmp *foo@tlscall(%eax)
int3