zig

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

commit 513b395f7f553e5caa3087d17c04f46b8bb407ef (tree)
parent 787a2c9d7a5fd0f6aaa10a406cda5bd2f4eb33a7
Author: Alex Rønne Petersen <alex@alexrp.com>
Date:   Fri, 19 Jun 2026 11:48:14 +0200

llvm: fix C ABI lowering for x32

closes https://codeberg.org/ziglang/zig/issues/35838

Diffstat:
Msrc/codegen/llvm/FuncGen.zig | 6+++---
1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/src/codegen/llvm/FuncGen.zig b/src/codegen/llvm/FuncGen.zig @@ -6663,7 +6663,7 @@ const ParamTypeIterator = struct { .async => { @panic("TODO implement async function lowering in the LLVM backend"); }, - .x86_64_sysv => return it.nextSystemV(ty), + .x86_64_sysv, .x86_64_x32 => return it.nextSystemV(ty), .x86_64_win => return it.nextWin64(ty), .x86_stdcall => { it.zig_index += 1; @@ -6940,7 +6940,7 @@ pub fn firstParamSRet(fn_info: InternPool.Key.FuncType, zcu: *Zcu, target: *cons return switch (fn_info.cc) { .auto => returnTypeByRef(zcu, target, return_type), - .x86_64_sysv => firstParamSRetSystemV(return_type, zcu, target), + .x86_64_sysv, .x86_64_x32 => firstParamSRetSystemV(return_type, zcu, target), .x86_64_win => x86_64_abi.classifyWindows(return_type, zcu, target, .ret) == .memory, .x86_sysv, .x86_win => isByRef(return_type, zcu), .x86_stdcall => !isScalar(zcu, return_type), @@ -6999,7 +6999,7 @@ pub fn lowerFnRetTy(o: *Object, fn_info: InternPool.Key.FuncType) Allocator.Erro switch (fn_info.cc) { .@"inline" => unreachable, .auto => return if (returnTypeByRef(zcu, target, return_type)) .void else o.lowerType(return_type), - .x86_64_sysv => return lowerSystemVFnRetTy(o, fn_info), + .x86_64_sysv, .x86_64_x32 => return lowerSystemVFnRetTy(o, fn_info), .x86_64_win => return lowerWin64FnRetTy(o, fn_info), .x86_stdcall => return if (isScalar(zcu, return_type)) o.lowerType(return_type) else .void, .x86_fastcall => return lowerX86FastcallFnRetTy(o, zcu, return_type),