2011-06-28 10:03:10 +08:00
|
|
|
; RUN: llc < %s -march=x86 | FileCheck %s
|
2008-01-09 07:08:06 +08:00
|
|
|
; This should not load or store the top part of *P.
|
|
|
|
|
|
|
|
define void @test(i64* %P) nounwind {
|
2011-06-28 10:03:10 +08:00
|
|
|
; CHECK: test:
|
|
|
|
; CHECK: movl 4(%esp), %[[REGISTER:.*]]
|
|
|
|
; CHECK-NOT: 4(%[[REGISTER]])
|
|
|
|
; CHECK: ret
|
2008-01-09 07:08:06 +08:00
|
|
|
%tmp1 = load i64* %P, align 8 ; <i64> [#uses=1]
|
|
|
|
%tmp2 = xor i64 %tmp1, 1 ; <i64> [#uses=1]
|
|
|
|
store i64 %tmp2, i64* %P, align 8
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|