Files
c3c/test/test_suite/cast/implicit_infer_len_cast.c3t

47 lines
1.7 KiB
Plaintext

// #target: macos-x64
module test;
macro int test(int[2][2]* y)
{
$typeof(*y) z = *y;
return z[1][1];
}
fn void main()
{
int[2][*] x = { { 2, 3}, { 5, 6 }};
int[<2>][*] y = { { 1, 3 }};
int[<2>][*] z = y;
int[<2>][1] w = z;
int[<2>][] aa = { { 1, 3 }};
int[][*] bb = { { 1, 3 } };
test(&x);
}
/* #expect: test.ll
%x = alloca [2 x [2 x i32]], align 16
%y = alloca [1 x <2 x i32>], align 4
%z = alloca [1 x <2 x i32>], align 4
%w = alloca [1 x <2 x i32>], align 4
%aa = alloca %"int[<2>][]", align 8
%literal = alloca [1 x <2 x i32>], align 4
%bb = alloca [1 x %"int[]"], align 16
%literal1 = alloca [2 x i32], align 4
%z2 = alloca [2 x [2 x i32]], align 16
call void @llvm.memcpy.p0.p0.i32(ptr align 16 %x, ptr align 16 @.__const, i32 16, i1 false)
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %y, ptr align 4 @.__const.1, i32 8, i1 false)
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %z, ptr align 4 %y, i32 8, i1 false)
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %w, ptr align 4 %z, i32 8, i1 false)
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %literal, ptr align 4 @.__const.2, i32 8, i1 false)
%0 = insertvalue %"int[<2>][]" undef, ptr %literal, 0
%1 = insertvalue %"int[<2>][]" %0, i64 1, 1
store %"int[<2>][]" %1, ptr %aa, align 8
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %literal1, ptr align 4 @.__const.3, i32 8, i1 false)
%2 = insertvalue %"int[]" undef, ptr %literal1, 0
%3 = insertvalue %"int[]" %2, i64 2, 1
store %"int[]" %3, ptr %bb, align 16
call void @llvm.memcpy.p0.p0.i32(ptr align 16 %z2, ptr align 4 %x, i32 16, i1 false)
%ptradd = getelementptr inbounds i8, ptr %z2, i64 8
%ptradd3 = getelementptr inbounds i8, ptr %ptradd, i64 4
ret void