2019-02-06 04:15:03 +08:00
|
|
|
// REQUIRES: msp430-registered-target
|
2019-07-21 06:50:50 +08:00
|
|
|
// RUN: %clang_cc1 -mframe-pointer=all -triple msp430 -S %s -o - | FileCheck %s --check-prefix=FP_ENFORCED
|
2019-02-06 04:15:03 +08:00
|
|
|
// RUN: %clang_cc1 -triple msp430 -S %s -o - | FileCheck %s --check-prefix=FP_DEFAULT
|
|
|
|
|
|
|
|
// Check the frame pointer is not used on MSP430 by default, but can be forcibly turned on.
|
|
|
|
|
|
|
|
// FP_ENFORCED: push r4
|
|
|
|
// FP_ENFORCED: mov r4, r4
|
|
|
|
// FP_ENFORCED: pop r4
|
|
|
|
// FP_DEFAULT: .globl fp_elim_check
|
|
|
|
// FP_DEFAULT-NOT: push r4
|
|
|
|
// FP_DEFAULT: mov r4, r4
|
|
|
|
// FP_DEFAULT-NOT: pop r4
|
|
|
|
|
|
|
|
void fp_elim_check()
|
|
|
|
{
|
|
|
|
asm volatile ("mov r4, r4");
|
|
|
|
}
|
|
|
|
|