mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-27 13:30:05 +00:00
[x86] Do not convert to cmp32 for Atom arch by Sergey Okunev
Differential Revision: http://llvm-reviews.chandlerc.com/D2824 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@205288 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a07c1ab4e6
commit
1d75829ddc
@ -9810,12 +9810,14 @@ SDValue X86TargetLowering::EmitCmp(SDValue Op0, SDValue Op1, unsigned X86CC,
|
||||
|
||||
if ((Op0.getValueType() == MVT::i8 || Op0.getValueType() == MVT::i16 ||
|
||||
Op0.getValueType() == MVT::i32 || Op0.getValueType() == MVT::i64)) {
|
||||
// Do the comparison at i32 if it's smaller. This avoids subregister
|
||||
// aliasing issues. Keep the smaller reference if we're optimizing for
|
||||
// size, however, as that'll allow better folding of memory operations.
|
||||
// Do the comparison at i32 if it's smaller, besides the Atom case.
|
||||
// This avoids subregister aliasing issues. Keep the smaller reference
|
||||
// if we're optimizing for size, however, as that'll allow better folding
|
||||
// of memory operations.
|
||||
if (Op0.getValueType() != MVT::i32 && Op0.getValueType() != MVT::i64 &&
|
||||
!DAG.getMachineFunction().getFunction()->getAttributes().hasAttribute(
|
||||
AttributeSet::FunctionIndex, Attribute::MinSize)) {
|
||||
AttributeSet::FunctionIndex, Attribute::MinSize) &&
|
||||
!Subtarget->isAtom()) {
|
||||
unsigned ExtendOp =
|
||||
isX86CCUnsigned(X86CC) ? ISD::ZERO_EXTEND : ISD::SIGN_EXTEND;
|
||||
Op0 = DAG.getNode(ExtendOp, dl, MVT::i32, Op0);
|
||||
|
36
test/CodeGen/X86/atom-cmpb.ll
Normal file
36
test/CodeGen/X86/atom-cmpb.ll
Normal file
@ -0,0 +1,36 @@
|
||||
; RUN: llc < %s -march=x86 -mcpu=atom | FileCheck %s
|
||||
; CHECK: movl
|
||||
; CHECK: movb
|
||||
; CHECK: movb
|
||||
; CHECK: cmpb
|
||||
; CHECK: notb
|
||||
; CHECK: notb
|
||||
|
||||
; Test for checking of cancel conversion to cmp32 in Atom case
|
||||
; in function 'X86TargetLowering::EmitCmp'
|
||||
|
||||
define i8 @run_test(i8* %rd_p) {
|
||||
entry:
|
||||
%incdec.ptr = getelementptr inbounds i8* %rd_p, i64 1
|
||||
%ld1 = load i8* %rd_p, align 1
|
||||
%incdec.ptr1 = getelementptr inbounds i8* %rd_p, i64 2
|
||||
%ld2 = load i8* %incdec.ptr, align 1
|
||||
%x4 = xor i8 %ld1, -1
|
||||
%x5 = xor i8 %ld2, -1
|
||||
%cmp34 = icmp ult i8 %ld2, %ld1
|
||||
br i1 %cmp34, label %if.then3, label %if.else
|
||||
|
||||
if.then3:
|
||||
%sub7 = sub i8 %x4, %x5
|
||||
br label %if.end4
|
||||
|
||||
if.else:
|
||||
%sub8 = sub i8 %x5, %x4
|
||||
br label %if.end4
|
||||
|
||||
if.end4:
|
||||
%res = phi i8 [ %sub7, %if.then3 ], [ %sub8, %if.else ]
|
||||
ret i8 %res
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user