[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <4c894d68-7d0e-49a0-b582-477bcc7f351d@acm.org>
Date: Thu, 2 Oct 2025 09:23:41 -0700
From: Bart Van Assche <bvanassche@....org>
To: Wonkon Kim <wkon.kim@...sung.com>, James.Bottomley@...senPartnership.com,
martin.petersen@...cle.com, peter.wang@...iatek.com,
linux-scsi@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH] ufs: core: Initialize a variable mode for PA_PWRMODE
On 10/2/25 12:00 AM, Wonkon Kim wrote:
> static bool ufshcd_is_pwr_mode_restore_needed(struct ufs_hba *hba)
> {
> struct ufs_pa_layer_attr *pwr_info = &hba->pwr_info;
> - u32 mode;
> + u32 mode = 0;
>
> ufshcd_dme_get(hba, UIC_ARG_MIB(PA_PWRMODE), &mode);
Since there is more code that passes a pointer to an uninitialized
variable to ufshcd_dme_get(), the untested patch below may be a better
solution:
diff --git a/drivers/ufs/core/ufshcd.c b/drivers/ufs/core/ufshcd.c
index 127b691402f9..5226fbca29ec 100644
--- a/drivers/ufs/core/ufshcd.c
+++ b/drivers/ufs/core/ufshcd.c
@@ -4277,8 +4277,8 @@ int ufshcd_dme_get_attr(struct ufs_hba *hba, u32
attr_sel,
get, UIC_GET_ATTR_ID(attr_sel),
UFS_UIC_COMMAND_RETRIES - retries);
- if (mib_val && !ret)
- *mib_val = uic_cmd.argument3;
+ if (mib_val)
+ *mib_val = ret == 0 ? uic_cmd.argument3 : 0;
if (peer && (hba->quirks & UFSHCD_QUIRK_DME_PEER_ACCESS_AUTO_MODE)
&& pwr_mode_change)
Powered by blists - more mailing lists