mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-10-25 10:27:04 +00:00
Change the { } expression in tablegen to accept sized binary literals which are not just 0 and 1.
It also allows nested { } expressions, as now that they are sized, we can merge pull bits from the nested value.
In the current behaviour, everything in { } must have been convertible to a single bit.
However, now that binary literals are sized, its useful to be able to initialize a range of bits.
So, for example, its now possible to do
bits<8> x = { 0, 1, { 0b1001 }, 0, 0b0 }
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@215086 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -1302,17 +1302,28 @@ Init *TGParser::ParseSimpleValue(Record *CurRec, RecTy *ItemType,
|
||||
}
|
||||
Lex.Lex(); // eat the '}'
|
||||
|
||||
SmallVector<Init *, 16> NewBits(Vals.size());
|
||||
SmallVector<Init *, 16> NewBits;
|
||||
|
||||
// As we parse { a, b, ... }, 'a' is the highest bit, but we parse it
|
||||
// first. We'll first read everything in to a vector, then we can reverse
|
||||
// it to get the bits in the correct order for the BitsInit value.
|
||||
for (unsigned i = 0, e = Vals.size(); i != e; ++i) {
|
||||
// bits<n> values are allowed to initialize n bits.
|
||||
if (BitsInit *BI = dyn_cast<BitsInit>(Vals[i])) {
|
||||
for (unsigned i = 0, e = BI->getNumBits(); i != e; ++i)
|
||||
NewBits.push_back(BI->getBit((e - i) - 1));
|
||||
continue;
|
||||
}
|
||||
// All other values must be convertible to just a single bit.
|
||||
Init *Bit = Vals[i]->convertInitializerTo(BitRecTy::get());
|
||||
if (!Bit) {
|
||||
Error(BraceLoc, "Element #" + utostr(i) + " (" + Vals[i]->getAsString()+
|
||||
") is not convertable to a bit");
|
||||
return nullptr;
|
||||
}
|
||||
NewBits[Vals.size()-i-1] = Bit;
|
||||
NewBits.push_back(Bit);
|
||||
}
|
||||
std::reverse(NewBits.begin(), NewBits.end());
|
||||
return BitsInit::get(NewBits);
|
||||
}
|
||||
case tgtok::l_square: { // Value ::= '[' ValueList ']'
|
||||
|
||||
Reference in New Issue
Block a user