]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drivers: soc: xilinx: check return status of get_api_version()
authorJay Buddhabhatti <jay.buddhabhatti@amd.com>
Wed, 15 May 2024 11:23:45 +0000 (04:23 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 3 Aug 2024 07:00:38 +0000 (09:00 +0200)
commit 9b003e14801cf85a8cebeddc87bc9fc77100fdce upstream.

Currently return status is not getting checked for get_api_version
and because of that for x86 arch we are getting below smatch error.

    CC      drivers/soc/xilinx/zynqmp_power.o
drivers/soc/xilinx/zynqmp_power.c: In function 'zynqmp_pm_probe':
drivers/soc/xilinx/zynqmp_power.c:295:12: warning: 'pm_api_version' is
used uninitialized [-Wuninitialized]
    295 |         if (pm_api_version < ZYNQMP_PM_VERSION)
        |            ^
    CHECK   drivers/soc/xilinx/zynqmp_power.c
drivers/soc/xilinx/zynqmp_power.c:295 zynqmp_pm_probe() error:
uninitialized symbol 'pm_api_version'.

So, check return status of pm_get_api_version and return error in case
of failure to avoid checking uninitialized pm_api_version variable.

Fixes: b9b3a8be28b3 ("firmware: xilinx: Remove eemi ops for get_api_version")
Signed-off-by: Jay Buddhabhatti <jay.buddhabhatti@amd.com>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/r/20240515112345.24673-1-jay.buddhabhatti@amd.com
Signed-off-by: Michal Simek <michal.simek@amd.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/soc/xilinx/zynqmp_power.c

index 965b1143936abe3d826bbd15207374099643bba5..b82c01373f532f8898428e9227c0255a87da07ba 100644 (file)
@@ -190,7 +190,9 @@ static int zynqmp_pm_probe(struct platform_device *pdev)
        u32 pm_api_version;
        struct mbox_client *client;
 
-       zynqmp_pm_get_api_version(&pm_api_version);
+       ret = zynqmp_pm_get_api_version(&pm_api_version);
+       if (ret)
+               return ret;
 
        /* Check PM API version number */
        if (pm_api_version < ZYNQMP_PM_VERSION)