diff options
Diffstat (limited to 'src/codegen/c.zig')
| -rw-r--r-- | src/codegen/c.zig | 47 |
1 files changed, 20 insertions, 27 deletions
diff --git a/src/codegen/c.zig b/src/codegen/c.zig index f2594209a5..c63cb27529 100644 --- a/src/codegen/c.zig +++ b/src/codegen/c.zig @@ -842,7 +842,8 @@ pub const DeclGen = struct { var index: usize = 0; var params_written: usize = 0; while (index < param_len) : (index += 1) { - if (dg.decl.ty.fnParamType(index).zigTypeTag() == .Void) continue; + const param_type = dg.decl.ty.fnParamType(index); + if (!param_type.hasRuntimeBitsIgnoreComptime()) continue; if (params_written > 0) { try w.writeAll(", "); } @@ -882,7 +883,7 @@ pub const DeclGen = struct { var params_written: usize = 0; var index: usize = 0; while (index < param_len) : (index += 1) { - if (fn_info.param_types[index].zigTypeTag() == .Void) continue; + if (!fn_info.param_types[index].hasRuntimeBitsIgnoreComptime()) continue; if (params_written > 0) { try bw.writeAll(", "); } @@ -1708,8 +1709,8 @@ fn genBody(f: *Function, body: []const Air.Inst.Index) error{ AnalysisFail, OutO .memcpy => try airMemcpy(f, inst), .set_union_tag => try airSetUnionTag(f, inst), .get_union_tag => try airGetUnionTag(f, inst), - .clz => try airCountZeroes(f, inst, "clz"), - .ctz => try airCountZeroes(f, inst, "ctz"), + .clz => try airBuiltinCall(f, inst, "clz"), + .ctz => try airBuiltinCall(f, inst, "ctz"), .popcount => try airBuiltinCall(f, inst, "popcount"), .byte_swap => try airBuiltinCall(f, inst, "byte_swap"), .bit_reverse => try airBuiltinCall(f, inst, "bit_reverse"), @@ -2625,8 +2626,11 @@ fn airCall( } try writer.writeAll("("); - for (args) |arg, i| { - if (i != 0) { + var args_written: usize = 0; + for (args) |arg| { + const ty = f.air.typeOf(arg); + if (!ty.hasRuntimeBitsIgnoreComptime()) continue; + if (args_written != 0) { try writer.writeAll(", "); } if (f.air.value(arg)) |val| { @@ -2635,6 +2639,7 @@ fn airCall( const val = try f.resolveInst(arg); try f.writeCValue(writer, val); } + args_written += 1; } try writer.writeAll(");\n"); return result_local; @@ -3351,35 +3356,23 @@ fn airBuiltinCall(f: *Function, inst: Air.Inst.Index, fn_name: [*:0]const u8) !C const inst_ty = f.air.typeOfIndex(inst); const local = try f.allocLocal(inst_ty, .Const); - const ty_op = f.air.instructions.items(.data)[inst].ty_op; - const writer = f.object.writer(); - const operand = try f.resolveInst(ty_op.operand); - - // TODO implement the function in zig.h and call it here - - try writer.print(" = {s}(", .{fn_name}); - try f.writeCValue(writer, operand); - try writer.writeAll(");\n"); - return local; -} - -fn airCountZeroes(f: *Function, inst: Air.Inst.Index, fn_name: [*:0]const u8) !CValue { - if (f.liveness.isUnused(inst)) return CValue.none; - - const inst_ty = f.air.typeOfIndex(inst); - const local = try f.allocLocal(inst_ty, .Const); const operand = f.air.instructions.items(.data)[inst].ty_op.operand; const operand_ty = f.air.typeOf(operand); const target = f.object.dg.module.getTarget(); const writer = f.object.writer(); - const zig_bits = operand_ty.intInfo(target).bits; - _ = toCIntBits(zig_bits) orelse + const int_info = operand_ty.intInfo(target); + const c_bits = toCIntBits(int_info.bits) orelse return f.fail("TODO: C backend: implement integer types larger than 128 bits", .{}); - try writer.print(" = zig_{s}(", .{fn_name}); + try writer.print(" = zig_{s}_", .{fn_name}); + const prefix_byte: u8 = switch (int_info.signedness) { + .signed => 'i', + .unsigned => 'u', + }; + try writer.print("{c}{d}(", .{ prefix_byte, c_bits }); try f.writeCValue(writer, try f.resolveInst(operand)); - try writer.print(", {d});\n", .{zig_bits}); + try writer.print(", {d});\n", .{int_info.bits}); return local; } |
