mirror of
https://github.com/c3lang/c3c.git
synced 2026-02-27 12:01:16 +00:00
81 lines
2.5 KiB
C
81 lines
2.5 KiB
C
// #target: macos-x64
|
|
module test;
|
|
struct Foo
|
|
{
|
|
char a;
|
|
char b;
|
|
char c;
|
|
}
|
|
|
|
fn int testing()
|
|
{
|
|
Foo y = getFoo(Foo { 4, 5, 6 });
|
|
return y.a + y.c;
|
|
}
|
|
|
|
fn Foo getFoo(Foo f)
|
|
{
|
|
return Foo { 1, 2, 3 };
|
|
}
|
|
|
|
/* #expect: test.ll
|
|
|
|
define i32 @test_testing() #0 {
|
|
entry:
|
|
%y = alloca %Foo, align 1
|
|
%literal = alloca %Foo, align 1
|
|
%tempcoerce = alloca i24, align 4
|
|
%result = alloca %Foo, align 1
|
|
%tempcoerce1 = alloca i24, align 4
|
|
%0 = getelementptr inbounds %Foo, %Foo* %literal, i32 0, i32 0
|
|
store i8 4, i8* %0, align 1
|
|
%1 = getelementptr inbounds %Foo, %Foo* %literal, i32 0, i32 1
|
|
store i8 5, i8* %1, align 1
|
|
%2 = getelementptr inbounds %Foo, %Foo* %literal, i32 0, i32 2
|
|
store i8 6, i8* %2, align 1
|
|
%3 = bitcast i24* %tempcoerce to i8*
|
|
%4 = bitcast %Foo* %literal to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %3, i8* align 1 %4, i32 3, i1 false)
|
|
%5 = load i24, i24* %tempcoerce, align 4
|
|
%6 = call i24 @test_getFoo(i24 %5)
|
|
store i24 %6, i24* %tempcoerce1, align 4
|
|
%7 = bitcast %Foo* %result to i8*
|
|
%8 = bitcast i24* %tempcoerce1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 1 %7, i8* align 4 %8, i32 3, i1 false)
|
|
%9 = bitcast %Foo* %y to i8*
|
|
%10 = bitcast %Foo* %result to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 1 %9, i8* align 1 %10, i32 3, i1 false)
|
|
%11 = getelementptr inbounds %Foo, %Foo* %y, i32 0, i32 0
|
|
%12 = load i8, i8* %11, align 1
|
|
%uisiext = zext i8 %12 to i32
|
|
%13 = getelementptr inbounds %Foo, %Foo* %y, i32 0, i32 2
|
|
%14 = load i8, i8* %13, align 1
|
|
%uisiext2 = zext i8 %14 to i32
|
|
%add = add i32 %uisiext, %uisiext2
|
|
ret i32 %add
|
|
}
|
|
|
|
; Function Attrs: nounwind
|
|
define i24 @test_getFoo(i24 %0) #0 {
|
|
entry:
|
|
%f = alloca %Foo, align 1
|
|
%tempcoerce = alloca i24, align 4
|
|
%literal = alloca %Foo, align 1
|
|
%tempcoerce1 = alloca i24, align 4
|
|
store i24 %0, i24* %tempcoerce, align 4
|
|
%1 = bitcast %Foo* %f to i8*
|
|
%2 = bitcast i24* %tempcoerce to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 1 %1, i8* align 4 %2, i32 3, i1 false)
|
|
%3 = getelementptr inbounds %Foo, %Foo* %literal, i32 0, i32 0
|
|
store i8 1, i8* %3, align 1
|
|
%4 = getelementptr inbounds %Foo, %Foo* %literal, i32 0, i32 1
|
|
store i8 2, i8* %4, align 1
|
|
%5 = getelementptr inbounds %Foo, %Foo* %literal, i32 0, i32 2
|
|
store i8 3, i8* %5, align 1
|
|
%6 = bitcast i24* %tempcoerce1 to i8*
|
|
%7 = bitcast %Foo* %literal to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %6, i8* align 1 %7, i32 3, i1 false)
|
|
%8 = load i24, i24* %tempcoerce1, align 4
|
|
ret i24 %8
|
|
}
|