Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1122827imu; Sat, 15 Dec 2018 15:03:59 -0800 (PST) X-Google-Smtp-Source: AFSGD/VhG+a7x/SJ514iifMgJugI5QPOrQHKKF6uSBblmruTb0ZLEw6SnNA5sPRdXXRj/dfAbe7z X-Received: by 2002:a17:902:34a:: with SMTP id 68mr8057642pld.268.1544915039298; Sat, 15 Dec 2018 15:03:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544915039; cv=none; d=google.com; s=arc-20160816; b=iEhnZtczCOUJlxmEt8RvdoQHWROcNf0ZSfV9biNGoJgZYXHWRglMgss3qcGEl7z2Jc W2qLW1H209SYA+nup51tS5TH+enaTnJ6HbnGHfJWqPBu8f+gbBGXoAYXAl66mQZqMc8I OtWAMg0JpiDMWlxUEo7eUAF3GlQqjkHbmR/gbiD1iQLH43nf+xC4s8wOxCMdl1CaWkUS nsSIB7LsFWfP2bVkqtoQyMkTZptriWKJIg7sapAwhvubZwDuBaYPUu3sVpKCXl7EYp5/ wklQhtHnCz7NHJ6+wKQvE4GbRzxwOIIpuyMs6moc+51HbMu+sODNurpBOsvRGIA9hq4p oMAg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=mtpRiGuwSB/EXraNSumHQ2MIkFjA/NsZRmPLx/9+ZJM=; b=UT33uqnxbIsh+dPhVVFoaKdEgnoxaUyRLkQB//RTI8+E5pbJGVbN4JpZ4SvI0mpnRy lbykfvb/JKbD5q74QaeecsQ6lk56j5ID0a0pMIGp85YrLd4sfr0O4//ezUNnI+IJL2c1 LzR6Okdqq2xUaLCYGf7CWwUsKiSU6f0RqI8UrYt/1Nr1iHKPsE/eeozzvfOroeeQ+Xv4 R+4nWf76VRL7IXhYi26MUPvlLzn30TUEgyIMTY8Er1y8wj/uYyoDibEZQRuZEme2U9/D 7qPH1yhEAlpRDqxrpdICl2iUbC6ylNOpDD1p0VeJjsaF0xQZoA2R4BS6Lsam1LxGxkCO ExtQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b6si7451419pgg.2.2018.12.15.15.03.29; Sat, 15 Dec 2018 15:03:59 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728813AbeLOXB5 (ORCPT + 99 others); Sat, 15 Dec 2018 18:01:57 -0500 Received: from mail.ispras.ru ([83.149.199.45]:39854 "EHLO mail.ispras.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727558AbeLOXB5 (ORCPT ); Sat, 15 Dec 2018 18:01:57 -0500 Received: from localhost.localdomain (unknown [85.140.177.69]) by mail.ispras.ru (Postfix) with ESMTPSA id 0D3B554006B; Sun, 16 Dec 2018 02:01:53 +0300 (MSK) From: Alexey Khoroshilov To: Oleksij Rempel , Jassi Brar Cc: Alexey Khoroshilov , linux-kernel@vger.kernel.org, ldv-project@linuxtesting.org Subject: [PATCH] mailbox: imx: Fix clk handling in imx_mu_probe() Date: Sun, 16 Dec 2018 02:01:44 +0300 Message-Id: <1544914904-3809-1-git-send-email-khoroshilov@ispras.ru> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Handling of devm_clk_get() suggests that the driver should support lack of priv->clk. But imx_mu_probe() fails on clk_prepare_enable(NULL) in that case. The patch removes the try to enable absent clk and adds error handling for mbox_controller_register(). Found by Linux Driver Verification project (linuxtesting.org). Signed-off-by: Alexey Khoroshilov --- drivers/mailbox/imx-mailbox.c | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/drivers/mailbox/imx-mailbox.c b/drivers/mailbox/imx-mailbox.c index 363d35d5e49d..ddde398f576e 100644 --- a/drivers/mailbox/imx-mailbox.c +++ b/drivers/mailbox/imx-mailbox.c @@ -292,10 +292,12 @@ static int imx_mu_probe(struct platform_device *pdev) priv->clk = NULL; } - ret = clk_prepare_enable(priv->clk); - if (ret) { - dev_err(dev, "Failed to enable clock\n"); - return ret; + if (priv->clk) { + ret = clk_prepare_enable(priv->clk); + if (ret) { + dev_err(dev, "Failed to enable clock\n"); + return ret; + } } for (i = 0; i < IMX_MU_CHANS; i++) { @@ -324,7 +326,13 @@ static int imx_mu_probe(struct platform_device *pdev) imx_mu_init_generic(priv); - return mbox_controller_register(&priv->mbox); + ret = mbox_controller_register(&priv->mbox); + if (ret) { + clk_disable_unprepare(priv->clk); + return ret; + } + + return 0; } static int imx_mu_remove(struct platform_device *pdev) -- 2.7.4