mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 01:31:05 +00:00
Fix Neon intrinsic immediate range checking for some double-register operands.
Some quad-register intrinsics with lane operands only take a double-register operand for the vector containing the lane. The valid range of lane numbers is then half as big as you would expect from the quad-register type. Note: This currently has no effect because those intrinsics are now handled entirely in the header file using __builtin_shufflevector, which does its own range checking, but I want to use this for generating tests. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@121867 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
fea3b218d6
commit
06b04aaf5c
@ -1213,10 +1213,11 @@ void NeonEmitter::emitIntrinsic(raw_ostream &OS, Record *R) {
|
||||
OS << "\n";
|
||||
}
|
||||
|
||||
static unsigned RangeFromType(StringRef typestr) {
|
||||
static unsigned RangeFromType(const char mod, StringRef typestr) {
|
||||
// base type to get the type string for.
|
||||
bool quad = false, dummy = false;
|
||||
char type = ClassifyType(typestr, quad, dummy, dummy);
|
||||
type = ModType(mod, type, quad, dummy, dummy, dummy, dummy, dummy);
|
||||
|
||||
switch (type) {
|
||||
case 'c':
|
||||
@ -1359,7 +1360,8 @@ void NeonEmitter::runHeader(raw_ostream &OS) {
|
||||
|
||||
// Functions which do not have an immediate do not need to have range
|
||||
// checking code emitted.
|
||||
if (Proto.find('i') == std::string::npos)
|
||||
size_t immPos = Proto.find('i');
|
||||
if (immPos == std::string::npos)
|
||||
continue;
|
||||
|
||||
SmallVector<StringRef, 16> TypeVec;
|
||||
@ -1386,7 +1388,9 @@ void NeonEmitter::runHeader(raw_ostream &OS) {
|
||||
}
|
||||
rangestr += "u = RFT(TV" + shiftstr + ")";
|
||||
} else {
|
||||
rangestr = "u = " + utostr(RangeFromType(TypeVec[ti]));
|
||||
// The immediate generally refers to a lane in the preceding argument.
|
||||
assert(immPos > 0 && "unexpected immediate operand");
|
||||
rangestr = "u = " + utostr(RangeFromType(Proto[immPos-1], TypeVec[ti]));
|
||||
}
|
||||
// Make sure cases appear only once by uniquing them in a string map.
|
||||
namestr = MangleName(name, TypeVec[ti], ck);
|
||||
|
Loading…
x
Reference in New Issue
Block a user