mirror of https://github.com/microsoft/clang.git
Add a PPC inline asm constraint type for single CR bits
This adds support for the PPC "wc" inline asm constraint (used for allocating individual CR bits). Support for this constraint type was recently added to the LLVM PowerPC backend. Although gcc does not currently support allocating individual CR bits, this identifier choice has been coordinated with the gcc PowerPC team, and will be marked as reserved for this purpose in the gcc constraints.md file. Prior to this change, none of the multi-character PPC constraints were handled correctly (the '^' escape character was not being added as required by the parsing code in LLVM). This should now be fixed. I'll add tests for these other constraints as support is added for them in the backend. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@202658 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4dd639d7bb
commit
2052d938aa
|
@ -788,6 +788,7 @@ public:
|
|||
case 'f':// VSX vector register to hold vector float data
|
||||
case 's':// VSX vector register to hold scalar float data
|
||||
case 'a':// Any VSX register
|
||||
case 'c':// An individual CR bit
|
||||
break;
|
||||
default:
|
||||
return false;
|
||||
|
@ -863,6 +864,20 @@ public:
|
|||
}
|
||||
return true;
|
||||
}
|
||||
virtual std::string convertConstraint(const char *&Constraint) const {
|
||||
std::string R;
|
||||
switch (*Constraint) {
|
||||
case 'e':
|
||||
case 'w':
|
||||
// Two-character constraint; add "^" hint for later parsing.
|
||||
R = std::string("^") + std::string(Constraint, 2);
|
||||
Constraint++;
|
||||
break;
|
||||
default:
|
||||
return TargetInfo::convertConstraint(Constraint);
|
||||
}
|
||||
return R;
|
||||
}
|
||||
virtual const char *getClobbers() const {
|
||||
return "";
|
||||
}
|
||||
|
|
|
@ -0,0 +1,26 @@
|
|||
// RUN: %clang_cc1 -triple powerpc64-unknown-linux-gnu -O2 -emit-llvm -o - %s | FileCheck %s
|
||||
|
||||
_Bool test_wc_i1(_Bool b1, _Bool b2) {
|
||||
_Bool o;
|
||||
asm("crand %0, %1, %2" : "=wc"(o) : "wc"(b1), "wc"(b2) : );
|
||||
return o;
|
||||
// CHECK-LABEL: define zeroext i1 @test_wc_i1(i1 zeroext %b1, i1 zeroext %b2)
|
||||
// CHECK: call i8 asm "crand $0, $1, $2", "=^wc,^wc,^wc"(i1 %b1, i1 %b2)
|
||||
}
|
||||
|
||||
int test_wc_i32(int b1, int b2) {
|
||||
int o;
|
||||
asm("crand %0, %1, %2" : "=wc"(o) : "wc"(b1), "wc"(b2) : );
|
||||
return o;
|
||||
// CHECK-LABEL: signext i32 @test_wc_i32(i32 signext %b1, i32 signext %b2)
|
||||
// CHECK: call i32 asm "crand $0, $1, $2", "=^wc,^wc,^wc"(i32 %b1, i32 %b2)
|
||||
}
|
||||
|
||||
unsigned char test_wc_i8(unsigned char b1, unsigned char b2) {
|
||||
unsigned char o;
|
||||
asm("crand %0, %1, %2" : "=wc"(o) : "wc"(b1), "wc"(b2) : );
|
||||
return o;
|
||||
// CHECK-LABEL: zeroext i8 @test_wc_i8(i8 zeroext %b1, i8 zeroext %b2)
|
||||
// CHECK: call i8 asm "crand $0, $1, $2", "=^wc,^wc,^wc"(i8 %b1, i8 %b2)
|
||||
}
|
||||
|
Loading…
Reference in New Issue