aboutsummaryrefslogtreecommitdiff
path: root/src/ir_print.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-03-13 08:52:23 +0000
committergingerBill <bill@gingerbill.org>2020-03-13 08:52:23 +0000
commit06e364b9bd0761aa6445d8c630ee283694925b05 (patch)
treeaf5f119e9f5b6cd27e65bb6e4f36e7c1b7a06f59 /src/ir_print.cpp
parentce90509a072939c7cebde40523d66f92e5354327 (diff)
Apply byval to sret for System V ABI
Diffstat (limited to 'src/ir_print.cpp')
-rw-r--r--src/ir_print.cpp12
1 files changed, 10 insertions, 2 deletions
diff --git a/src/ir_print.cpp b/src/ir_print.cpp
index d5271444d..fb224648d 100644
--- a/src/ir_print.cpp
+++ b/src/ir_print.cpp
@@ -338,9 +338,13 @@ void ir_print_proc_type_without_pointer(irFileBuffer *f, irModule *m, Type *t) {
ir_write_string(f, str_lit(" ("));
if (t->Proc.return_by_pointer) {
ir_print_type(f, m, reduce_tuple_to_single_type(t->Proc.results));
- // ir_fprintf(f, "* sret noalias ");
+ ir_fprintf(f, "* sret noalias ");
+ if (build_context.ODIN_OS == "darwin" ||
+ build_context.ODIN_OS == "linux") {
+ ir_fprintf(f, "byval ");
+ }
// ir_write_string(f, str_lit("* noalias "));
- ir_write_string(f, str_lit("*"));
+ // ir_write_string(f, str_lit("*"));
if (param_count > 0 || t->Proc.calling_convention == ProcCC_Odin) {
ir_write_string(f, str_lit(", "));
}
@@ -2379,6 +2383,10 @@ 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") {
+ ir_fprintf(f, "byval ");
+ }
ir_write_str_lit(f, "%agg.result");
param_index += 1;
}