mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-24 08:33:39 +00:00
17f0cd3cc1
implements something out of Target/README.txt producing: _foo: ## @foo movl 4(%esp), %eax movapd LCPI1_0, %xmm0 movapd %xmm0, (%eax) ret $4 instead of: _foo: ## @foo movl 4(%esp), %eax movapd _b, %xmm0 mulpd LCPI1_0, %xmm0 addpd _a, %xmm0 movapd %xmm0, (%eax) ret $4 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@84942 91177308-0d34-0410-b5e6-96231b3b80d8
90 lines
2.0 KiB
LLVM
90 lines
2.0 KiB
LLVM
; RUN: opt < %s -instcombine -S | FileCheck %s
|
|
|
|
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"
|
|
|
|
@test1 = constant {{i32,i8},i32} {{i32,i8} { i32 -559038737, i8 186 }, i32 -889275714 }
|
|
@test2 = constant double 1.0
|
|
@test3 = constant {i64, i64} { i64 123, i64 112312312 }
|
|
|
|
; Simple load
|
|
define i32 @test1() {
|
|
%r = load i32* getelementptr ({{i32,i8},i32}* @test1, i32 0, i32 0, i32 0)
|
|
ret i32 %r
|
|
; @test1
|
|
; CHECK: ret i32 -559038737
|
|
}
|
|
|
|
; PR3152
|
|
; Load of first 16 bits of 32-bit value.
|
|
define i16 @test2() {
|
|
%r = load i16* bitcast(i32* getelementptr ({{i32,i8},i32}* @test1, i32 0, i32 0, i32 0) to i16*)
|
|
ret i16 %r
|
|
|
|
; @test2
|
|
; CHECK: ret i16 -16657
|
|
}
|
|
|
|
; Load of second 16 bits of 32-bit value.
|
|
define i16 @test3() {
|
|
%r = load i16* getelementptr(i16* bitcast(i32* getelementptr ({{i32,i8},i32}* @test1, i32 0, i32 0, i32 0) to i16*), i32 1)
|
|
ret i16 %r
|
|
|
|
; @test3
|
|
; CHECK: ret i16 -8531
|
|
}
|
|
|
|
; Load of 8 bit field + tail padding.
|
|
define i16 @test4() {
|
|
%r = load i16* getelementptr(i16* bitcast(i32* getelementptr ({{i32,i8},i32}* @test1, i32 0, i32 0, i32 0) to i16*), i32 2)
|
|
ret i16 %r
|
|
; @test4
|
|
; CHECK: ret i16 186
|
|
}
|
|
|
|
; Load of double bits.
|
|
define i64 @test6() {
|
|
%r = load i64* bitcast(double* @test2 to i64*)
|
|
ret i64 %r
|
|
|
|
; @test6
|
|
; CHECK: ret i64 4607182418800017408
|
|
}
|
|
|
|
; Load of double bits.
|
|
define i16 @test7() {
|
|
%r = load i16* bitcast(double* @test2 to i16*)
|
|
ret i16 %r
|
|
|
|
; @test7
|
|
; CHECK: ret i16 0
|
|
}
|
|
|
|
; Double load.
|
|
define double @test8() {
|
|
%r = load double* bitcast({{i32,i8},i32}* @test1 to double*)
|
|
ret double %r
|
|
|
|
; @test8
|
|
; CHECK: ret double 0xDEADBEBA
|
|
}
|
|
|
|
|
|
; i128 load.
|
|
define i128 @test9() {
|
|
%r = load i128* bitcast({i64, i64}* @test3 to i128*)
|
|
ret i128 %r
|
|
|
|
; @test9
|
|
; CHECK: ret i128 112312312
|
|
}
|
|
|
|
; vector load.
|
|
define <2 x i64> @test10() {
|
|
%r = load <2 x i64>* bitcast({i64, i64}* @test3 to <2 x i64>*)
|
|
ret <2 x i64> %r
|
|
|
|
; @test10
|
|
; CHECK: ret <2 x i64> <i64 112312312, i64 0>
|
|
}
|
|
|