1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 20:23:11 +01:00
llvm-mirror/test/MC
Simon Wallis c6b11bb4ce Clang crash targeting ARM or Thumb when assembling a prel31 relocation variant
Summary:
In the assembler or inline assembler,
attempting to use an invalid fixup type
gives a crash with a segmentation fault.

__attribute__((naked))
void foo(void) {
 __asm__("mov r9, :lower16:bar(prel31)");
}

This should give a proper error message when building for ARM or Thumb.
This brings it in line with AARCH64.

This fixes all 8 instances of llvm_unreachable("Unsupported Modifier");
in ARM/MCTargetDesc/ARMELFObjectWriter.cpp.
A test is provided for each instance.

Reviewers: llvm-commits, MarkMurrayARM

Reviewed By: MarkMurrayARM

Subscribers: kristof.beyls, hiraditya, danielkiss

Tags: #llvm

Differential Revision: https://reviews.llvm.org/D79782

Change-Id: I6971ba37f129cc453568fe71514ccb2ac9d16831
2020-05-13 13:52:30 +01:00
..
AArch64
AMDGPU [AMDGPU][MC][GFX9+] Enabled clamp for v_add_i32 and v_sub_i32 2020-05-13 14:17:20 +03:00
ARM Clang crash targeting ARM or Thumb when assembling a prel31 relocation variant 2020-05-13 13:52:30 +01:00
AsmParser
AVR
BPF
COFF
Disassembler [AMDGPU][MC][GFX9+] Enabled clamp for v_add_i32 and v_sub_i32 2020-05-13 14:17:20 +03:00
ELF
Hexagon
Lanai
MachO
Mips [mips] Fix typo in FileCheck directives - replace \0xa0 char by space. NFC 2020-05-13 12:09:30 +03:00
MSP430
PowerPC
RISCV
Sparc
SystemZ
WebAssembly [WebAssembly] Implement pseudo-min/max SIMD instructions 2020-05-12 09:39:01 -07:00
X86