Adjust MIMG writemask to only the used components
    Michel Dänzer 
    michel at daenzer.net
       
    Wed Apr  3 06:43:17 PDT 2013
    
    
  
On Mit, 2013-04-03 at 15:38 +0200, Christian König wrote: 
> Am 03.04.2013 15:19, schrieb Michel Dänzer:
> > On Mit, 2013-03-27 at 17:57 +0100, Christian König wrote:
> >> the attached patches dynamically adjust the writemask of MIMG
> >> instructions depending on the used components. Additional to that it
> >> also adjust the register class of MIMG instruction so that we also
> >> reduce register pressure.
> > There's mainly one thing that isn't clear to me: My understanding from
> > the ISA is that even if the instruction writemask operand has 'gaps',
> > e.g. 0x9, the enabled components will always be written to consecutive
> > VGPRs. So in this example, the instruction would write to two
> > consecutive VGPRs, one for component 0/'x' and one for component 3/'w'
> > of a four component vector. Is this handled correctly?
> >
> 
> Yes your understanding is correct, and it is indeed handled correctly.
> 
> I just analyze the used register components to figure out the needed 
> writemask and while doing so remember which instruction uses which 
> component. So after updating the writemask I just change the index of 
> the used component as well.
Excellent. Sounds and looks good to me then. 
-- 
Earthling Michel Dänzer           |                   http://www.amd.com
Libre software enthusiast         |          Debian, X and DRI developer
    
    
More information about the llvm-commits
mailing list