mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-17 03:07:06 +00:00
e6987587d6
tokenfactor in between the load/store. This allows us to optimize test7 into: _test7: ## @test7 ## BB#0: ## %entry movl (%rdx), %eax ## kill: SIL<def> ESI<kill> movb %sil, 5(%rdi) ret instead of: _test7: ## @test7 ## BB#0: ## %entry movl 4(%esp), %ecx movl $-65281, %eax ## imm = 0xFFFFFFFFFFFF00FF andl 4(%ecx), %eax movzbl 8(%esp), %edx shll $8, %edx addl %eax, %edx movl 12(%esp), %eax movl (%eax), %eax movl %edx, 4(%ecx) ret git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@101355 91177308-0d34-0410-b5e6-96231b3b80d8
128 lines
2.9 KiB
LLVM
128 lines
2.9 KiB
LLVM
; rdar://7860110
|
|
; RUN: llc < %s | FileCheck %s -check-prefix=X64
|
|
; RUN: llc -march=x86 < %s | FileCheck %s -check-prefix=X32
|
|
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-n8:16:32:64"
|
|
target triple = "x86_64-apple-darwin10.2"
|
|
|
|
define void @test1(i32* nocapture %a0, i8 zeroext %a1) nounwind ssp {
|
|
entry:
|
|
%A = load i32* %a0, align 4
|
|
%B = and i32 %A, -256 ; 0xFFFFFF00
|
|
%C = zext i8 %a1 to i32
|
|
%D = or i32 %C, %B
|
|
store i32 %D, i32* %a0, align 4
|
|
ret void
|
|
|
|
; X64: test1:
|
|
; X64: movb %sil, (%rdi)
|
|
|
|
; X32: test1:
|
|
; X32: movb 8(%esp), %al
|
|
; X32: movb %al, (%{{.*}})
|
|
}
|
|
|
|
define void @test2(i32* nocapture %a0, i8 zeroext %a1) nounwind ssp {
|
|
entry:
|
|
%A = load i32* %a0, align 4
|
|
%B = and i32 %A, -65281 ; 0xFFFF00FF
|
|
%C = zext i8 %a1 to i32
|
|
%CS = shl i32 %C, 8
|
|
%D = or i32 %B, %CS
|
|
store i32 %D, i32* %a0, align 4
|
|
ret void
|
|
; X64: test2:
|
|
; X64: movb %sil, 1(%rdi)
|
|
|
|
; X32: test2:
|
|
; X32: movb 8(%esp), %al
|
|
; X32: movb %al, 1(%{{.*}})
|
|
}
|
|
|
|
define void @test3(i32* nocapture %a0, i16 zeroext %a1) nounwind ssp {
|
|
entry:
|
|
%A = load i32* %a0, align 4
|
|
%B = and i32 %A, -65536 ; 0xFFFF0000
|
|
%C = zext i16 %a1 to i32
|
|
%D = or i32 %B, %C
|
|
store i32 %D, i32* %a0, align 4
|
|
ret void
|
|
; X64: test3:
|
|
; X64: movw %si, (%rdi)
|
|
|
|
; X32: test3:
|
|
; X32: movw 8(%esp), %ax
|
|
; X32: movw %ax, (%{{.*}})
|
|
}
|
|
|
|
define void @test4(i32* nocapture %a0, i16 zeroext %a1) nounwind ssp {
|
|
entry:
|
|
%A = load i32* %a0, align 4
|
|
%B = and i32 %A, 65535 ; 0x0000FFFF
|
|
%C = zext i16 %a1 to i32
|
|
%CS = shl i32 %C, 16
|
|
%D = or i32 %B, %CS
|
|
store i32 %D, i32* %a0, align 4
|
|
ret void
|
|
; X64: test4:
|
|
; X64: movw %si, 2(%rdi)
|
|
|
|
; X32: test4:
|
|
; X32: movw 8(%esp), %ax
|
|
; X32: movw %ax, 2(%{{.*}})
|
|
}
|
|
|
|
define void @test5(i64* nocapture %a0, i16 zeroext %a1) nounwind ssp {
|
|
entry:
|
|
%A = load i64* %a0, align 4
|
|
%B = and i64 %A, -4294901761 ; 0xFFFFFFFF0000FFFF
|
|
%C = zext i16 %a1 to i64
|
|
%CS = shl i64 %C, 16
|
|
%D = or i64 %B, %CS
|
|
store i64 %D, i64* %a0, align 4
|
|
ret void
|
|
; X64: test5:
|
|
; X64: movw %si, 2(%rdi)
|
|
|
|
; X32: test5:
|
|
; X32: movw 8(%esp), %ax
|
|
; X32: movw %ax, 2(%{{.*}})
|
|
}
|
|
|
|
define void @test6(i64* nocapture %a0, i8 zeroext %a1) nounwind ssp {
|
|
entry:
|
|
%A = load i64* %a0, align 4
|
|
%B = and i64 %A, -280375465082881 ; 0xFFFF00FFFFFFFFFF
|
|
%C = zext i8 %a1 to i64
|
|
%CS = shl i64 %C, 40
|
|
%D = or i64 %B, %CS
|
|
store i64 %D, i64* %a0, align 4
|
|
ret void
|
|
; X64: test6:
|
|
; X64: movb %sil, 5(%rdi)
|
|
|
|
|
|
; X32: test6:
|
|
; X32: movb 8(%esp), %al
|
|
; X32: movb %al, 5(%{{.*}})
|
|
}
|
|
|
|
define i32 @test7(i64* nocapture %a0, i8 zeroext %a1, i32* %P2) nounwind {
|
|
entry:
|
|
%OtherLoad = load i32 *%P2
|
|
%A = load i64* %a0, align 4
|
|
%B = and i64 %A, -280375465082881 ; 0xFFFF00FFFFFFFFFF
|
|
%C = zext i8 %a1 to i64
|
|
%CS = shl i64 %C, 40
|
|
%D = or i64 %B, %CS
|
|
store i64 %D, i64* %a0, align 4
|
|
ret i32 %OtherLoad
|
|
; X64: test7:
|
|
; X64: movb %sil, 5(%rdi)
|
|
|
|
|
|
; X32: test7:
|
|
; X32: movb 8(%esp), %cl
|
|
; X32: movb %cl, 5(%{{.*}})
|
|
}
|
|
|