[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <7bdbdd0e-9fcd-4f41-8352-18a98161f048@amd.com>
Date: Wed, 2 Oct 2024 12:54:26 +0200
From: Michal Simek <michal.simek@....com>
To: Ronak Jain <ronak.jain@....com>
Cc: linux-arm-kernel@...ts.infradead.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH] firmware: xilinx: add a warning print for unsupported
 feature
On 9/20/24 07:54, Ronak Jain wrote:
> As per the current code base, feature check API is used to check the
> version in zynqmp_pm_pinctrl_set_config() before requesting the
> firmware, and if the expected version is not found then it will
> return an error. So now when the latest kernel tries to access the
> tri-state functionality with older firmware, observe failure prints
> during booting.
> 
> The failure prints,
> [    1.204850] zynqmp-pinctrl firmware:zynqmp-firmware:pinctrl: failed to set: pin 37 param 2 value 0
> [    2.699455] zynqmp-pinctrl firmware:zynqmp-firmware:pinctrl: failed to set: pin 44 param 2 value 0
> [    2.708424] zynqmp-pinctrl firmware:zynqmp-firmware:pinctrl: failed to set: pin 46 param 2 value 0
> [    2.717387] zynqmp-pinctrl firmware:zynqmp-firmware:pinctrl: failed to set: pin 48 param 2 value 0
> 
> Now, these error prints mislead the user whether it is an actual
> failure or the feature itself is not there in the firmware. So, just
> to avoid confusion around this, add some debug prints before
> returning an error code. With that, it is easier to know whether it is
> an actual failure or the feature is unsupported.
> 
> Signed-off-by: Ronak Jain <ronak.jain@....com>
> ---
>   drivers/firmware/xilinx/zynqmp.c | 5 ++++-
>   1 file changed, 4 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/firmware/xilinx/zynqmp.c b/drivers/firmware/xilinx/zynqmp.c
> index 0b2ad46c8bce..cdb565c41119 100644
> --- a/drivers/firmware/xilinx/zynqmp.c
> +++ b/drivers/firmware/xilinx/zynqmp.c
> @@ -1245,8 +1245,11 @@ int zynqmp_pm_pinctrl_set_config(const u32 pin, const u32 param,
>   	if (pm_family_code == ZYNQMP_FAMILY_CODE &&
>   	    param == PM_PINCTRL_CONFIG_TRI_STATE) {
>   		ret = zynqmp_pm_feature(PM_PINCTRL_CONFIG_PARAM_SET);
> -		if (ret < PM_PINCTRL_PARAM_SET_VERSION)
> +		if (ret < PM_PINCTRL_PARAM_SET_VERSION) {
> +			pr_warn("The requested pinctrl feature is not supported in the current firmware.\n"
> +				"Expected firmware version is 2023.1 and above for this feature to work.\r\n");
>   			return -EOPNOTSUPP;
> +		}
>   	}
>   
>   	return zynqmp_pm_invoke_fn(PM_PINCTRL_CONFIG_PARAM_SET, NULL, 3, pin, param, value);
Applied.
M
Powered by blists - more mailing lists
 
