|
102 | 102 | // CHECK-ABI-SOFT-MIPS16: "-target-feature" "+mips16"
|
103 | 103 | // CHECK-ABI-SOFT-MIPS16: "-msoft-float"
|
104 | 104 | // CHECK-ABI-SOFT-MIPS16: "-mfloat-abi" "soft"
|
| 105 | + |
| 106 | +/// On MIPS, don't accept constraint "f" for soft-float. |
| 107 | +// RUN: not %clang -S %s -o %t.s 2>&1 \ |
| 108 | +// RUN: -target mips-linux-gnu -msoft-float \ |
| 109 | +// RUN: -DSOFT_FLOAT_NO_CONSTRAINT_F \ |
| 110 | +// RUN: | FileCheck --check-prefix=CHECK-SOFTFLOAT-ASM-NO-F %s |
| 111 | +// CHECK-SOFTFLOAT-ASM-NO-F: error: invalid input constraint 'f' in asm |
| 112 | + |
| 113 | +#ifdef SOFT_FLOAT_NO_CONSTRAINT_F |
| 114 | +void read_float(float* p) { |
| 115 | + float result = *p; |
| 116 | + __asm__("" ::"f"(result)); |
| 117 | +} |
| 118 | +#endif // SOFT_FLOAT_NO_CONSTRAINT_F |
| 119 | + |
| 120 | +/// On MIPS, accept constraint "r" for soft-float. |
| 121 | +// RUN: %clang -S %s -o - -O2 2>&1 \ |
| 122 | +// RUN: -target mips-linux-gnu -msoft-float -mabi=32 \ |
| 123 | +// RUN: -DSOFT_FLOAT_USE_CONSTRAINT_R -DFLOAT=float \ |
| 124 | +// RUN: | FileCheck --check-prefix=CHECK-SOFTFLOAT-ASM-USE-R-3232 %s |
| 125 | +// CHECK-SOFTFLOAT-ASM-USE-R-3232: lw $2, 0($4) |
| 126 | +// |
| 127 | +// RUN: %clang -S %s -o - -O2 2>&1 \ |
| 128 | +// RUN: -target mips-linux-gnu -msoft-float -mabi=32 \ |
| 129 | +// RUN: -DSOFT_FLOAT_USE_CONSTRAINT_R -DFLOAT=double \ |
| 130 | +// RUN: | FileCheck --check-prefix=CHECK-SOFTFLOAT-ASM-USE-R-3264 %s |
| 131 | +// CHECK-SOFTFLOAT-ASM-USE-R-3264: lw $2, 4($4) |
| 132 | +// CHECK-SOFTFLOAT-ASM-USE-R-3264: lw $3, 0($4) |
| 133 | +// |
| 134 | +// RUN: %clang -S %s -o - -O2 2>&1 \ |
| 135 | +// RUN: -target mips-linux-gnu -msoft-float -mabi=64 \ |
| 136 | +// RUN: -DSOFT_FLOAT_USE_CONSTRAINT_R -DFLOAT=float \ |
| 137 | +// RUN: | FileCheck --check-prefix=CHECK-SOFTFLOAT-ASM-USE-R-6432 %s |
| 138 | +// CHECK-SOFTFLOAT-ASM-USE-R-6432: lw $2, 0($4) |
| 139 | +// |
| 140 | +// RUN: %clang -S %s -o - -O2 2>&1 \ |
| 141 | +// RUN: -target mips-linux-gnu -msoft-float -mabi=64 \ |
| 142 | +// RUN: -DSOFT_FLOAT_USE_CONSTRAINT_R -DFLOAT=double \ |
| 143 | +// RUN: | FileCheck --check-prefix=CHECK-SOFTFLOAT-ASM-USE-R-6464 %s |
| 144 | +// CHECK-SOFTFLOAT-ASM-USE-R-6464: ld $2, 0($4) |
| 145 | + |
| 146 | +#ifdef SOFT_FLOAT_USE_CONSTRAINT_R |
| 147 | +void read_float(FLOAT* p) { |
| 148 | + FLOAT result = *p; |
| 149 | + __asm__("" ::"r"(result)); |
| 150 | +} |
| 151 | +#endif // SOFT_FLOAT_USE_CONSTRAINT_R |
0 commit comments