mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
Probably not a good idea to convert a single vector load into a memcpy. We
don't do this now, but add a test case to prevent this from happening in the future. Additional test for rdar://9892684 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@145879 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f68a26b5d8
commit
dce42b75dc
@ -1371,6 +1371,8 @@ Value *llvm::isBytewiseValue(Value *V) {
|
||||
return Val;
|
||||
}
|
||||
|
||||
// FIXME: Vector types (e.g., <4 x i32> <i32 -1, i32 -1, i32 -1, i32 -1>).
|
||||
|
||||
// Conceptually, we could handle things like:
|
||||
// %a = zext i8 %X to i16
|
||||
// %b = shl i16 %a, 8
|
||||
|
@ -236,3 +236,15 @@ define void @test7(i32* nocapture %c) nounwind optsize {
|
||||
; CHECK: call void @llvm.memset.p0i8.i64(i8* %5, i8 -1, i64 20, i32 4, i1 false)
|
||||
ret void
|
||||
}
|
||||
|
||||
%struct.test8 = type { [4 x i32] }
|
||||
|
||||
define void @test8() {
|
||||
entry:
|
||||
%memtmp = alloca %struct.test8, align 16
|
||||
%0 = bitcast %struct.test8* %memtmp to <4 x i32>*
|
||||
store <4 x i32> <i32 -1, i32 -1, i32 -1, i32 -1>, <4 x i32>* %0, align 16
|
||||
ret void
|
||||
; CHECK: @test8
|
||||
; CHECK: store <4 x i32> <i32 -1, i32 -1, i32 -1, i32 -1>, <4 x i32>* %0, align 16
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user