]> git.ipfire.org Git - thirdparty/kernel/linux.git/commit
dpll: zl3073x: Handle missing or corrupted flash configuration
authorIvan Vecera <ivecera@redhat.com>
Wed, 8 Oct 2025 14:14:45 +0000 (16:14 +0200)
committerJakub Kicinski <kuba@kernel.org>
Tue, 14 Oct 2025 00:24:36 +0000 (17:24 -0700)
commitfcb8b32a68fd40b0440cb9468cf6f6ab9de9f3c5
tree875712023058f1daf8809528015862fa50993879
parent0b4b77eff5f8cd9be062783a1c1e198d46d0a753
dpll: zl3073x: Handle missing or corrupted flash configuration

If the internal flash contains missing or corrupted configuration,
basic communication over the bus still functions, but the device
is not capable of normal operation (for example, using mailboxes).

This condition is indicated in the info register by the ready bit.
If this bit is cleared, the probe procedure times out while fetching
the device state.

Handle this case by checking the ready bit value in zl3073x_dev_start()
and skipping DPLL device and pin registration if it is cleared.
Do not report this condition as an error, allowing the devlink device
to be registered and enabling the user to flash the correct configuration.

Prior this patch:
[   31.112299] zl3073x-i2c 1-0070: Failed to fetch input state: -ETIMEDOUT
[   31.116332] zl3073x-i2c 1-0070: error -ETIMEDOUT: Failed to start device
[   31.136881] zl3073x-i2c 1-0070: probe with driver zl3073x-i2c failed with error -110

After this patch:
[   41.011438] zl3073x-i2c 1-0070: FW not fully ready - missing or corrupted config

Fixes: 75a71ecc24125 ("dpll: zl3073x: Register DPLL devices and pins")
Signed-off-by: Ivan Vecera <ivecera@redhat.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Link: https://patch.msgid.link/20251008141445.841113-1-ivecera@redhat.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/dpll/zl3073x/core.c
drivers/dpll/zl3073x/regs.h