diff --git a/lib/zig.h b/lib/zig.h index e636785f1e0a..7f9b1ffe0772 100644 --- a/lib/zig.h +++ b/lib/zig.h @@ -222,6 +222,12 @@ #define zig_restrict #endif +#if zig_has_attribute(no_builtin) +#define zig_no_builtin __attribute__((no_builtin)) +#else +#define zig_no_builtin +#endif + #if zig_has_attribute(aligned) || defined(zig_tinyc) #define zig_under_align(alignment) __attribute__((aligned(alignment))) #elif defined(zig_msvc) diff --git a/src/codegen/c.zig b/src/codegen/c.zig index 56466b439597..02ffad54e52a 100644 --- a/src/codegen/c.zig +++ b/src/codegen/c.zig @@ -1790,8 +1790,17 @@ pub const DeclGen = struct { else => unreachable, } } - if (fn_val.getFunction(zcu)) |func| if (func.analysisUnordered(ip).branch_hint == .cold) - try w.writeAll("zig_cold "); + + if (fn_val.getFunction(zcu)) |func| { + const func_analysis = func.analysisUnordered(ip); + + if (func_analysis.branch_hint == .cold) + try w.writeAll("zig_cold "); + + if (kind == .complete and func_analysis.disable_intrinsics or dg.mod.no_builtin) + try w.writeAll("zig_no_builtin "); + } + if (fn_info.return_type == .noreturn_type) try w.writeAll("zig_noreturn "); var trailing = try renderTypePrefix(dg.pass, &dg.ctype_pool, zcu, w, fn_ctype, .suffix, .{});