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:
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),