In timer_write(), we switch() on the address offset to handle
registers that need special-casing, with a default case that handles
both "unsupported (64-bit mode) register" and "can just write value
to st->regs[]". However, as Coverity points out, every register is
covered by the special-casing, so the "write to st->regs[]" code path
is dead. (timer_read() has a similar structure but there several
registers do go through the default code path.)
Replace the dead code with an assertion.
CID:
1613905
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id:
20260512134750.
3543639-1-peter.maydell@linaro.org
break;
default:
- if (addr < R_TIM1_MAX) {
- st->regs[addr] = value;
- } else {
- qemu_log_mask(LOG_GUEST_ERROR,
- TYPE_MSS_TIMER": 64-bit mode not supported\n");
- return;
- }
- break;
+ /* All non-64-bit regs covered by the switch cases */
+ assert(addr >= R_TIM1_MAX);
+ qemu_log_mask(LOG_GUEST_ERROR,
+ TYPE_MSS_TIMER": 64-bit mode not supported\n");
+ return;
}
timer_update_irq(st);
}