aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoratil <atilkurtulmus@gmail.com>2021-03-19 07:28:27 +0300
committeratil <atilkurtulmus@gmail.com>2021-03-19 07:28:27 +0300
commit5f5dfdc00eafd5ce0c357576489507ea5eebacfe (patch)
treeed252441316a0430a6bff2c9adc43353a7436e3a
parent333741222827db990ef2bce11873816e66bc1633 (diff)
return by pointer on linux
-rw-r--r--src/check_type.cpp2
-rw-r--r--src/ir_print.cpp6
2 files changed, 3 insertions, 5 deletions
diff --git a/src/check_type.cpp b/src/check_type.cpp
index e6e12ab1b..85c425ad4 100644
--- a/src/check_type.cpp
+++ b/src/check_type.cpp
@@ -2423,7 +2423,7 @@ bool abi_compat_return_by_pointer(gbAllocator a, ProcCallingConvention cc, Type
}
}
- if (build_context.ODIN_OS == "windows") {
+ if (build_context.ODIN_OS == "windows" || build_context.ODIN_OS == "linux" ) {
i64 size = 8*type_size_of(abi_return_type);
switch (size) {
case 0:
diff --git a/src/ir_print.cpp b/src/ir_print.cpp
index d6f46ce4d..d6b387de1 100644
--- a/src/ir_print.cpp
+++ b/src/ir_print.cpp
@@ -339,8 +339,7 @@ void ir_print_proc_type_without_pointer(irFileBuffer *f, irModule *m, Type *t) {
// ir_fprintf(f, "* sret noalias ");
// ir_write_string(f, str_lit("* noalias "));
ir_write_string(f, str_lit("*"));
- if (build_context.ODIN_OS == "darwin" ||
- build_context.ODIN_OS == "linux") {
+ if (build_context.ODIN_OS == "darwin") {
ir_fprintf(f, " byval");
}
if (param_count > 0 || t->Proc.calling_convention == ProcCC_Odin) {
@@ -2456,8 +2455,7 @@ void ir_print_proc(irFileBuffer *f, irModule *m, irProcedure *proc) {
if (proc_type->return_by_pointer) {
ir_print_type(f, m, reduce_tuple_to_single_type(proc_type->results));
ir_write_str_lit(f, "* sret noalias ");
- if (build_context.ODIN_OS == "darwin" ||
- build_context.ODIN_OS == "linux") {
+ if (build_context.ODIN_OS == "darwin") {
ir_fprintf(f, "byval ");
}
ir_write_str_lit(f, "%agg.result");