[LLVMdev] TableGen syntax for matching a constant load
    Joerg Sonnenberger 
    joerg at britannica.bec.de
       
    Sat Feb 26 13:36:31 PST 2011
    
    
  
On Sat, Feb 26, 2011 at 01:07:39PM -0800, Jakob Stoklund Olesen wrote:
> 
> On Feb 25, 2011, at 7:27 PM, Joerg Sonnenberger wrote:
> 
> > I'm trying to add a X86 pattern to turn
> > 	movl $-1, %eax
> > into
> > 	orl $-1, $eax
> 
> Please make sure to measure the performance impact of doing this. You
> are creating a false dependency on the last instruction to write %eax,
> and the CPU won't be able to execute the following instructions in
> parallel.
I am primarily interested in size here, not speed.
> You may want to consider using xorl+decl instead. It is also three
> bytes, and there are no false dependencies. The xor idiom is recognized
> by processors as old as Pentium 4 as having no dependencies.
Any examples of how to create more than one instructions for a given
pattern? There are some other cases I could use this for.
Joerg
    
    
More information about the llvm-dev
mailing list