diff options
| author | David Rubin <daviru007@icloud.com> | 2024-09-15 14:41:00 -0700 |
|---|---|---|
| committer | mlugg <mlugg@mlugg.co.uk> | 2024-09-16 16:42:42 +0100 |
| commit | 7f60d2e4658ad78839ce0fce63a95dbcb893a256 (patch) | |
| tree | a8706d5a8eff95360b271173be2f7cac09f4d3b6 /src | |
| parent | 1365be5d02429dbbbfab43133d399b2af42047c5 (diff) | |
| download | zig-7f60d2e4658ad78839ce0fce63a95dbcb893a256.tar.gz zig-7f60d2e4658ad78839ce0fce63a95dbcb893a256.zip | |
riscv: fix up `ptr_elem_val` to not doubly lock
Diffstat (limited to 'src')
| -rw-r--r-- | src/arch/riscv64/CodeGen.zig | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/src/arch/riscv64/CodeGen.zig b/src/arch/riscv64/CodeGen.zig index 0c6da840eb..73fa0460de 100644 --- a/src/arch/riscv64/CodeGen.zig +++ b/src/arch/riscv64/CodeGen.zig @@ -3897,7 +3897,7 @@ fn airArrayElemVal(func: *Func, inst: Air.Inst.Index) !void { if (array_ty.isVector(zcu)) { // we need to load the vector, vslidedown to get the element we want - // and store that element at in a load frame. + // and store that element in a load frame. const src_reg, const src_lock = try func.allocReg(.vector); defer func.register_manager.unlockReg(src_lock); @@ -3970,12 +3970,15 @@ fn airPtrElemVal(func: *Func, inst: Air.Inst.Index) !void { }; defer if (index_lock) |lock| func.register_manager.unlockReg(lock); - const elem_ptr_reg = if (base_ptr_mcv.isRegister() and func.liveness.operandDies(inst, 0)) - base_ptr_mcv.register - else - try func.copyToTmpRegister(base_ptr_ty, base_ptr_mcv); - const elem_ptr_lock = func.register_manager.lockRegAssumeUnused(elem_ptr_reg); - defer func.register_manager.unlockReg(elem_ptr_lock); + const elem_ptr_reg, const elem_ptr_lock = if (base_ptr_mcv.isRegister() and + func.liveness.operandDies(inst, 0)) + .{ base_ptr_mcv.register, null } + else blk: { + const reg, const lock = try func.allocReg(.int); + try func.genSetReg(base_ptr_ty, reg, base_ptr_mcv); + break :blk .{ reg, lock }; + }; + defer if (elem_ptr_lock) |lock| func.register_manager.unlockReg(lock); try func.genBinOp( .ptr_add, |
