• Lynn Boger's avatar
    cmd/asm,cmd/compile: clean up isel codegen on ppc64x · 7987238d
    Lynn Boger authored
    This cleans up the isel code generation in ssa for ppc64x.
    
    Current there is no isel op and the isel code is only
    generated from pseudo ops in ppc64/ssa.go, and only using
    operands with values 0 or 1. When the isel is generated,
    there is always a load of 1 into the temp register before it.
    
    This change implements the isel op so it can be used in PPC64.rules,
    and can recognize operand values other than 0 or 1. This also
    eliminates the forced load of 1, so it will be loaded only if
    needed.
    
    This will make the isel code generation consistent with other ops,
    and allow future rule changes that can take advantage of having
    a more general purpose isel rule.
    
    Change-Id: I363e1dbd3f7f5dfecb53187ad51cce409a8d1f8d
    Reviewed-on: https://go-review.googlesource.com/c/go/+/195057
    Run-TryBot: Lynn Boger <laboger@linux.vnet.ibm.com>
    TryBot-Result: Gobot Gobot <gobot@golang.org>
    Reviewed-by: default avatarCarlos Eduardo Seo <cseo@linux.vnet.ibm.com>
    7987238d
rewritePPC64.go 689 KB