mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-27 06:54:30 +00:00
f374109a33
Summary: Intel documentation shows the memory operand as the first operand. But we currently treat it as the second operand. Conceptually the order doesn't matter since it doesn't write memory. We have aliases to parse with the operands in either order and the isel matching is commutable. For the register®ister form order does matter for the assembly parser. PR22995 was previously filed and fixed by changing the register®ister form from MRMSrcReg to MRMDestReg to match gas. Ideally the memory form should match by using MRMDestMem. I believe this supercedes D38025 which was trying to switch the register®ister form back to pre-PR22995. Reviewers: aymanmus, RKSimon, zvi Reviewed By: aymanmus Subscribers: llvm-commits Differential Revision: https://reviews.llvm.org/D38120 llvm-svn: 314639
73 lines
1.8 KiB
LLVM
73 lines
1.8 KiB
LLVM
; RUN: llc < %s | FileCheck %s
|
|
; rdar://5671654
|
|
; The loads should fold into the testl instructions, no matter how
|
|
; the inputs are commuted.
|
|
|
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
|
|
target triple = "x86_64-apple-darwin7"
|
|
|
|
define i32 @test(i32* %P, i32* %G) nounwind {
|
|
; CHECK-LABEL: test:
|
|
; CHECK-NOT: ret
|
|
; CHECK: testl %{{.*}}, (%{{.*}})
|
|
; CHECK: ret
|
|
|
|
entry:
|
|
%0 = load i32, i32* %P, align 4 ; <i32> [#uses=3]
|
|
%1 = load i32, i32* %G, align 4 ; <i32> [#uses=1]
|
|
%2 = and i32 %1, %0 ; <i32> [#uses=1]
|
|
%3 = icmp eq i32 %2, 0 ; <i1> [#uses=1]
|
|
br i1 %3, label %bb1, label %bb
|
|
|
|
bb: ; preds = %entry
|
|
%4 = tail call i32 @bar() nounwind ; <i32> [#uses=0]
|
|
ret i32 %0
|
|
|
|
bb1: ; preds = %entry
|
|
ret i32 %0
|
|
}
|
|
|
|
define i32 @test2(i32* %P, i32* %G) nounwind {
|
|
; CHECK-LABEL: test2:
|
|
; CHECK-NOT: ret
|
|
; CHECK: testl %{{.*}}, (%{{.*}})
|
|
; CHECK: ret
|
|
|
|
entry:
|
|
%0 = load i32, i32* %P, align 4 ; <i32> [#uses=3]
|
|
%1 = load i32, i32* %G, align 4 ; <i32> [#uses=1]
|
|
%2 = and i32 %0, %1 ; <i32> [#uses=1]
|
|
%3 = icmp eq i32 %2, 0 ; <i1> [#uses=1]
|
|
br i1 %3, label %bb1, label %bb
|
|
|
|
bb: ; preds = %entry
|
|
%4 = tail call i32 @bar() nounwind ; <i32> [#uses=0]
|
|
ret i32 %0
|
|
|
|
bb1: ; preds = %entry
|
|
ret i32 %0
|
|
}
|
|
|
|
define i32 @test3(i32* %P, i32* %G) nounwind {
|
|
; CHECK-LABEL: test3:
|
|
; CHECK-NOT: ret
|
|
; CHECK: testl %{{.*}}, (%{{.*}})
|
|
; CHECK: ret
|
|
|
|
entry:
|
|
%0 = load i32, i32* %P, align 4 ; <i32> [#uses=3]
|
|
%1 = load i32, i32* %G, align 4 ; <i32> [#uses=1]
|
|
%2 = and i32 %0, %1 ; <i32> [#uses=1]
|
|
%3 = icmp eq i32 %2, 0 ; <i1> [#uses=1]
|
|
br i1 %3, label %bb1, label %bb
|
|
|
|
bb: ; preds = %entry
|
|
%4 = tail call i32 @bar() nounwind ; <i32> [#uses=0]
|
|
ret i32 %1
|
|
|
|
bb1: ; preds = %entry
|
|
ret i32 %1
|
|
}
|
|
|
|
declare i32 @bar()
|