mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
R600: Disable the BFE pattern
This pattern uses an SDNodeXForm, which isn't being emitted for some reason. I can get it to work by attaching the PatLeaf that has the XForm to the argument in the output pattern, but this results in an immediate being used in a register operand, which the backend can't handle yet. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@199918 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
cbf79028c3
commit
35f321dde5
@ -388,6 +388,11 @@ class SHA256MaPattern <Instruction BFI_INT, Instruction XOR> : Pat <
|
||||
|
||||
// Bitfield extract patterns
|
||||
|
||||
/*
|
||||
|
||||
XXX: The BFE pattern is not working correctly because the XForm is not being
|
||||
applied.
|
||||
|
||||
def legalshift32 : ImmLeaf <i32, [{return Imm >=0 && Imm < 32;}]>;
|
||||
def bfemask : PatLeaf <(imm), [{return isMask_32(N->getZExtValue());}],
|
||||
SDNodeXForm<imm, [{ return CurDAG->getTargetConstant(CountTrailingOnes_32(N->getZExtValue()), MVT::i32);}]>>;
|
||||
@ -397,6 +402,8 @@ class BFEPattern <Instruction BFE> : Pat <
|
||||
(BFE $x, $y, $z)
|
||||
>;
|
||||
|
||||
*/
|
||||
|
||||
// rotr pattern
|
||||
class ROTRPattern <Instruction BIT_ALIGN> : Pat <
|
||||
(rotr i32:$src0, i32:$src1),
|
||||
|
@ -1526,7 +1526,9 @@ let Predicates = [isEGorCayman] in {
|
||||
i32:$src2))],
|
||||
VecALU
|
||||
>;
|
||||
def : BFEPattern <BFE_UINT_eg>;
|
||||
// XXX: This pattern is broken, disabling for now. See comment in
|
||||
// AMDGPUInstructions.td for more info.
|
||||
// def : BFEPattern <BFE_UINT_eg>;
|
||||
|
||||
def BFI_INT_eg : R600_3OP <0x06, "BFI_INT", [], VecALU>;
|
||||
defm : BFIPatterns <BFI_INT_eg>;
|
||||
|
@ -1,5 +1,7 @@
|
||||
; RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s
|
||||
|
||||
; XFAIL: *
|
||||
|
||||
; CHECK: @bfe_def
|
||||
; CHECK: BFE_UINT
|
||||
define void @bfe_def(i32 addrspace(1)* %out, i32 %x) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user