Displaying 3 results from an estimated 3 matches for "spillalignment".
2009 Apr 28
1
[LLVMdev] Register class intersection
...Regs (subset means improper subset)
and A.SpillSize == B.SpillSize
Since the spill sizes differ, FR64 and VR128 have no sub/super class
relation.
I propose that we change the definition to:
A is a subclass of B iff A != B
and A.Regs is a subset of B.Regs
and A.SpillSize >= B.SpillSize
and A.SpillAlignment is divided by B.SpillAlignment
This would introduce two new subclass chains:
RFP80 subclass of RFP64 subclass of RFP32
VR128 subclass of FR64
Define intersection as described above:
intersection(A, B) = max { X | X subclass-eq A, X subclass-eq B }
The coalescer can then use NewRC = intersectio...
2016 Sep 24
2
RFC: Implement variable-sized register classes
...it works under the hood to the average backend
> writer.
I agree with the complexity, but I would hope that more documentation,
examples and explanations would clarify it.
> What if RegisterClass contained a `list<RCInfo>`. Each RCInfo contains
> RegTypes, RegSize, SpillSize, and SpillAlignment as well as a
> Predicate the determines whether this individual RCInfo is the one
> that should apply. To my taste this seems easier to understand than
> the {Int,ValueType,ValueTypeList}Select mechanism.
The "select" mechanism was intended to be extendable to be able to
select...
2016 Sep 20
7
RFC: Implement variable-sized register classes
...ke
precedence over the existing members RegTypes/Size/Alignment.
class RegisterClass {
...
ValueTypeListSelect VarRegTypes; // The names of these members
IntSelect VarRegSize; // could likely be improved...
IntSelect VarSpillSize; //
IntSelect VarSpillAlignment //
}
To fully implement the AddReg instruction, the target would then define
the register class:
class MyRegisterClass : RegisterClass<...> {
let VarRegTypes = ValueTypeListSelect<[Mode64, Mode128],
[[i64, v2i32, v4i16, v8i8], // Mode64...