From mboxrd@z Thu Jan 1 00:00:00 1970 From: kishon@ti.com (Kishon Vijay Abraham I) Date: Thu, 26 May 2016 11:29:14 +0530 Subject: [PATCH] phy: exynos-mipi-video: avoid uninitialized variable use In-Reply-To: <14219690.YQPrXjp7cP@wuerfel> References: <1462971012-562097-1-git-send-email-arnd@arndb.de> <20160511185155.GB8265@kozik-lap> <14219690.YQPrXjp7cP@wuerfel> Message-ID: <574690B2.9010204@ti.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org Hi Arnd, On Thursday 26 May 2016 12:24 AM, Arnd Bergmann wrote: > On Wednesday, May 11, 2016 8:51:55 PM CEST Krzysztof Kozlowski wrote: >> On Wed, May 11, 2016 at 02:49:53PM +0200, Arnd Bergmann wrote: >>> A rework of the exynos-mipi-video driver caused a warning >>> about the new __set_phy_state function potentially accessing >>> a variable before its initialization: >>> >>> drivers/phy/phy-exynos-mipi-video.c: In function '__set_phy_state': >>> drivers/phy/phy-exynos-mipi-video.c:238:13: error: 'val' may be used uninitialized in this function [-Werror=maybe-uninitialized] >>> return val & data->resetn_val; >>> ~~~~^~~~~~~~~~~~~~~~~~ >>> drivers/phy/phy-exynos-mipi-video.c:235:6: note: 'val' was declared here >>> u32 val; >>> >>> The failure scenario here is the offset passed into a the >>> stub regmap_read() function that does not modify its output, >>> however regmap_read() can also fail for other reasons, so >>> adding error handling (in this case, returning zero from >>> is_running) seems the best solution. >>> >>> Note that this warning showed up with the ARM s5pv210_defconfig, >>> indicating that we most likely want to either enable CONFIG_REGMAP >>> in that defconfig as well, or disable the phy-exynos-mipi-video >>> driver. >>> >>> Signed-off-by: Arnd Bergmann >>> Fixes: 97a3042f7616 ("phy: exynos-mipi-video: Rewrite handling of phy registers") >>> --- >>> drivers/phy/phy-exynos-mipi-video.c | 6 +++++- >>> 1 file changed, 5 insertions(+), 1 deletion(-) >>> >>> diff --git a/drivers/phy/phy-exynos-mipi-video.c b/drivers/phy/phy-exynos-mipi-video.c >>> index cc093ebfda94..8b851f718123 100644 >>> --- a/drivers/phy/phy-exynos-mipi-video.c >>> +++ b/drivers/phy/phy-exynos-mipi-video.c >>> @@ -233,8 +233,12 @@ static inline int __is_running(const struct exynos_mipi_phy_desc *data, >>> struct exynos_mipi_video_phy *state) >>> { >>> u32 val; >> >> Other way would be to initialize val=0 since there is no real error code >> returned. Anyway: >> >> Reviewed-by: Krzysztof Kozlowski > > > This hasn't made it into linux-next yet, any chance we'll see it in -rc1 or -rc2? Not in -rc1. Mostly it'll go in -rc2. Generally I start queuing patches after -rc1 is tagged. Thanks Kishon