> + while ((READ_ONCE(reg_val) & CN23XX_PKT_INPUT_CTL_RST)
> &&
> + !(READ_ONCE(reg_val) & CN23XX_PKT_INPUT_CTL_QUIET))
> {
> + WRITE_ONCE(reg_val, octeon_read_csr64(
> + oct, CN23XX_SLI_IQ_PKT_CONTROL64(q_no)));
> + }
Busy-reading registers without any timeout. Couldn't there be corner cases [PCI
errors, etc.]?
[This is a recurring event in this patch]
> +static void cn23xx_disable_io_queues(struct octeon_device *oct) {
> + u64 d64 = 0ULL;
> + u32 d32 = 0ULL;
While true, why bother with the ULLs?
> +
> + /* Reset the doorbell register for this Input Queue. */
> + octeon_write_csr(oct, CN23XX_SLI_IQ_DOORBELL(q_no),
> 0xFFFFFFFF);
> + while (((octeon_read_csr64(
> + oct, CN23XX_SLI_IQ_DOORBELL(q_no))) != 0ULL) &&
!, not != 0.
> CN23XX_SLI_PKT_IOQ_RING_RST));
> + while (!(READ_ONCE(d64) & (0x1ULL << q_no)) && loop--) {
You can use BIT_ULL for this
> + /* Reset the doorbell register for this Output Queue. */
> + octeon_write_csr(oct, CN23XX_SLI_OQ_PKTS_CREDIT(q_no),
> + 0xFFFFFFFF);
> + while (((octeon_read_csr64(
> + oct, CN23XX_SLI_OQ_PKTS_CREDIT(q_no))) != 0ULL)
!, not != 0.