[PATCH] D55988: WIP: RegBankSelect: Support some more complex part mappings
Quentin Colombet via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Jan 23 13:46:16 PST 2019
qcolombet added inline comments.
================
Comment at: include/llvm/CodeGen/GlobalISel/RegisterBankInfo.h:629
+ /// be inserted.
+ virtual unsigned getBreakDownCost(const ValueMapping &ValMapping) const {
+ return std::numeric_limits<unsigned>::max();
----------------
arsenm wrote:
> qcolombet wrote:
> > arsenm wrote:
> > > qcolombet wrote:
> > > > arsenm wrote:
> > > > > qcolombet wrote:
> > > > > > I feel we miss a register bank in that prototype (what you'd referenced as CurBank).
> > > > > I had this initially, but then discovered it will always be null. The array of banks is present in ValMapping
> > > > The banks we have in the value mapping are the one we want to use (destination), not the one the value originates from (source), right?
> > > >
> > > > > then discovered it will always be null.
> > > >
> > > > Are you just patching up the destination in your case (i.e., things that are not assigned to any regbank yet)?
> > > >
> > > > I would have expected this information to be here and useful in cases like this:
> > > > orig: dest = op src
> > > > candidate mapping: dest.low = op.low src.low; dest.high = op.high src.high
> > > > Thus src has a regbank at this point, but dest doesn't.
> > > >
> > > > Although I am not a fan of such approach, we could take the convention for now that curbank == null means we are patching a definition and curbank != null means we are patching a source.
> > > > E.g.,
> > > > 1. dest = op => dest.low = op.low ; dest.high = op.high
> > > > vs.
> > > > 2. = op src => = op.low src.low ; = op.high src.high
> > > >
> > > > In #1 dest's regbank would be nullptr, in #2 src's regbank would be !nullptr.
> > > I based this off only seeing null, plus the above assert:
> > >
> > > assert((!IsSameNumOfValues || CurRegBank) && "We should not have to repair");
> > >
> > That's not exactly what the intent of the assert was.
> > // If MO does not have a register bank, we should have just been
> > // able to set one unless we have to break the value down.
> > assert((!IsSameNumOfValues || CurRegBank) && "We should not have to repair");
> >
> > This should be refined such that `CurRegBank == nullptr` is allowed only if MO is a definition.
> > Essentially what this assert does is making sure that the `breakdown == 1` code path will have non-nullptr values.
> I'm not sure I understand exactly what you're saying. For the AMDGPU usage, I don't there would be a case where the destination will have a bank assigned that will require splitting the source in this way, so maybe I'm just not seeing it.
Yes, the definition should almost never have a regbank, I am thinking about a case where we would decide to split the source because the instruction becomes cheaper.
E.g.,
```
A <regbank1>= ...
= op A
```
Where `op` could be mapped like this:
```
# Mapping by default
= op A<regbank1> # cost 12
;;;
# Alternative mapping
= op.low A.low<anotherBank> # cost 1
= op.high A.high<anotherBank> # cost 1
```
In that case, to compute the cost of breaking down A, knowing that A is mapped on <regbank1> could change the cost. That's why I think we need a way to pass that information in the API. The default would be nullptr, because A may not have a regbank yet.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D55988/new/
https://reviews.llvm.org/D55988
More information about the llvm-commits
mailing list