blob: d97432b607cef3780db5f33eca04d91857084bec [file] [log] [blame]
// RUN: not llvm-mc --triple thumbv6m %s 2>&1 | FileCheck %s --check-prefixes=CHECK,THUMB1
// RUN: not llvm-mc --triple thumbv7m %s 2>&1 | FileCheck %s --check-prefixes=CHECK,THUMB2
// This test checks reporting of errors of the form "you should have
// used :lower16: in this immediate field", during initial reading of
// the source file.
//
// For errors that are reported at object-file output time, see
// lower-upper-errors-2.s.
// CHECK: :[[@LINE+1]]:10: error: Immediate expression for Thumb movs requires :lower0_7:, :lower8_15:, :upper0_7: or :upper8_15:
movs r0, #foo
// CHECK: :[[@LINE+1]]:10: error: Immediate expression for Thumb adds requires :lower0_7:, :lower8_15:, :upper0_7: or :upper8_15:
adds r0, #foo
// THUMB2: :[[@LINE+1]]:10: error: immediate expression for mov requires :lower16: or :upper16
movw r0, #foo
// THUMB2: :[[@LINE+1]]:10: error: immediate expression for mov requires :lower16: or :upper16
movt r0, #foo
// With a Thumb2 wide add instruction available, this case isn't an error
// while reading the source file. It only causes a problem when an object
// file is output, and it turns out there's no suitable relocation to ask
// for the value of an external symbol to be turned into a Thumb shifted
// immediate field. And in this case the other errors in this source file
// cause assembly to terminate before reaching the object-file output stage
// (even if a test run had had -filetype=obj).
// THUMB1: :[[@LINE+2]]:14: error: Immediate expression for Thumb adds requires :lower0_7:, :lower8_15:, :upper0_7: or :upper8_15:
// THUMB2-NOT: :[[@LINE+1]]:{{[0-9]+}}: error:
adds r0, r0, #foo
// Similarly for this version, which _must_ be the wide encoding due
// to the use of a high register and the lack of flag-setting.
// THUMB1: :[[@LINE+2]]:1: error: invalid instruction
// THUMB2-NOT: :[[@LINE+1]]:{{[0-9]+}}: error:
add r9, r0, #foo
// CHECK: :[[@LINE+1]]:10: error: Immediate expression for Thumb movs requires :lower0_7:, :lower8_15:, :upper0_7: or :upper8_15:
movs r0, :lower16:#foo
// This is invalid in either architecture: in Thumb1 it can't use a
// high register, and in Thumb2 it can't use :upper8_15:. But the
// Thumb2 case won't cause an error until output.
// THUMB1: :[[@LINE+2]]:1: error: invalid instruction
// THUMB2-NOT: :[[@LINE+1]]:{{[0-9]+}}: error:
movs r11, :upper8_15:#foo