Re: [PATCH 2/3] scsi: ufs: core: Tolerate RX_FOM read failures in TX EQTR
From: Peter Wang (王信友)
Date: Tue Jun 23 2026 - 05:06:34 EST
On Sat, 2026-06-20 at 01:03 -0700, Can Guo wrote:
> @@ -494,22 +496,30 @@ static int ufshcd_get_rx_fom(struct ufs_hba
> *hba,
>
> /* Get FOM of host's TX lanes from device's RX_FOM. */
> for (lane = 0; lane < pwr_mode->lane_tx; lane++) {
> + h_iter->fom[lane] = 0;
> ret = ufshcd_dme_peer_get(hba,
> UIC_ARG_MIB_SEL(RX_FOM,
>
> UIC_ARG_MPHY_RX_GEN_SEL_INDEX(lane)),
> &fom);
> - if (ret)
> - return ret;
> + if (ret) {
> + dev_dbg(hba->dev, "Failed to get FOM for Host
> TX Lane %d: %d\n",
> + lane, ret);
> + continue;
> + }
>
Hi Can,
I suggest setting h_iter->fom[lane] = 0 when an error occurs,
as this approach is clearer and improves code efficiency,
for example:
if (ret) {
h_iter->fom[lane] = 0;
...
continue;
}
> h_iter->fom[lane] = (u8)fom;
> }
>
> /* Get FOM of device's TX lanes from host's RX_FOM. */
> for (lane = 0; lane < pwr_mode->lane_rx; lane++) {
> + d_iter->fom[lane] = 0;
> ret = ufshcd_dme_get(hba, UIC_ARG_MIB_SEL(RX_FOM,
>
> UIC_ARG_MPHY_RX_GEN_SEL_INDEX(lane)),
> &fom);
> - if (ret)
> - return ret;
> + if (ret) {
> + dev_dbg(hba->dev, "Failed to get FOM for
> Device TX Lane %d: %d\n",
> + lane, ret);
> + continue;
> + }
>
The same applies as above.
Thanks
Peter