zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit f1cff4fa4a28d42ac9055f94ee9a8f7fd2831cd7 (tree)
parent a3f05b80f1c26ca905e01c6d3a8a288a9f1d9e25
Author: Andrew Kelley <andrew@ziglang.org>
Date:   Thu,  9 Jun 2022 15:09:16 -0700

Sema: avoid use of undefined value for generic fn calls

I saw some issues in Valgrind which are fixed after this commit.

Diffstat:
Msrc/Sema.zig | 11++++++++---
1 file changed, 8 insertions(+), 3 deletions(-)

diff --git a/src/Sema.zig b/src/Sema.zig @@ -7026,9 +7026,14 @@ fn funcCommon( }); }; - // stage1 bug workaround - const cc_workaround = cc orelse undefined; - const align_workaround = alignment orelse @as(u32, undefined); + // These locals are pulled out from the init expression below to work around + // a stage1 compiler bug. + // In the case of generic calling convention, or generic alignment, we use + // default values which are only meaningful for the generic function, *not* + // the instantiation, which can depend on comptime parameters. + // Related proposal: https://github.com/ziglang/zig/issues/11834 + const cc_workaround = cc orelse .Unspecified; + const align_workaround = alignment orelse 0; break :fn_ty try Type.Tag.function.create(sema.arena, .{ .param_types = param_types,