diff options
| author | Veikka Tuominen <git@vexu.eu> | 2022-03-11 13:12:32 +0200 |
|---|---|---|
| committer | Veikka Tuominen <git@vexu.eu> | 2022-03-11 13:12:32 +0200 |
| commit | cba68090a60c3de8eadbf8eb53e37620a1d66683 (patch) | |
| tree | 19d972a0c3cab03307218e9fb757fd3fdc44c8a3 /src/codegen/c.zig | |
| parent | db4262417009c0060e09a8cf8af088b76320aad0 (diff) | |
| download | zig-cba68090a60c3de8eadbf8eb53e37620a1d66683.tar.gz zig-cba68090a60c3de8eadbf8eb53e37620a1d66683.zip | |
stage2: implement `@shuffle` at runtime
Diffstat (limited to 'src/codegen/c.zig')
| -rw-r--r-- | src/codegen/c.zig | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/src/codegen/c.zig b/src/codegen/c.zig index 4a30bf023b..c179b65046 100644 --- a/src/codegen/c.zig +++ b/src/codegen/c.zig @@ -1716,6 +1716,7 @@ fn genBody(f: *Function, body: []const Air.Inst.Index) error{ AnalysisFail, OutO .tag_name => try airTagName(f, inst), .error_name => try airErrorName(f, inst), .splat => try airSplat(f, inst), + .shuffle => try airShuffle(f, inst), .aggregate_init => try airAggregateInit(f, inst), .union_init => try airUnionInit(f, inst), .prefetch => try airPrefetch(f, inst), @@ -3557,6 +3558,21 @@ fn airSplat(f: *Function, inst: Air.Inst.Index) !CValue { return f.fail("TODO: C backend: implement airSplat", .{}); } +fn airShuffle(f: *Function, inst: Air.Inst.Index) !CValue { + if (f.liveness.isUnused(inst)) return CValue.none; + + const inst_ty = f.air.typeOfIndex(inst); + const ty_op = f.air.instructions.items(.data)[inst].ty_op; + const operand = try f.resolveInst(ty_op.operand); + const writer = f.object.writer(); + const local = try f.allocLocal(inst_ty, .Const); + try writer.writeAll(" = "); + + _ = operand; + _ = local; + return f.fail("TODO: C backend: implement airShuffle", .{}); +} + fn airAggregateInit(f: *Function, inst: Air.Inst.Index) !CValue { if (f.liveness.isUnused(inst)) return CValue.none; |
