Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2856780pxj; Mon, 17 May 2021 11:24:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxlq5yyR5+6AfPVAT0Obh47E/ZruGFVIx8VJWz/wTTAmkDiG0f6vuBvY8vIAEbyrJkhG/K2 X-Received: by 2002:a17:906:c01a:: with SMTP id e26mr1328411ejz.300.1621275896807; Mon, 17 May 2021 11:24:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621275896; cv=none; d=google.com; s=arc-20160816; b=AbpRCA4tqX+UOOYD7ATJr7gwVeZoG5QjMosEmMgHQP8LV+n60sc9xrvoe/SYAQ03fP DIA3P9bYPYRi31WfLaOERfZ5HbUwF70lmpBak8zOQVGmCRUrRlxZkcm4TRAlNxR+/06n PTVneggc+9fq/fBoqN+7IlrtF0W6PPlYWL6sTBTp0mrA07n75JOxAQZMriQEijgXVqrz 0WV1eW08a8qokft9PsvrTW7+bfrhPGe+1JlTSeo90eXtOiIPn6nRRk9KEVXblUlLFsos BaMBANtjOOXXleIN0FpMuPAHWNBItyhTQxaRMGZIBMf6L/lzc/7FIo76+/AO2qCGsv/n wwWA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=JC3u0mjKcxElwl3nnfbSjAaYU5OM1G2ZgSpR7nWkBo8=; b=oql2FJRWlLrfgg+B0lHRtCrsjWigawn/9ow7V0dvLTaSg8XpWvllDYOTbkt+cGJR7u 64GaYUyWYEjwShxfzPDojoqh9PuRHBNxtHBWsvohAxcmS6BnxgYnD2b4fKbunT5Pfu0V OnIyrv8Z7cnIiiK7bRf2ZgbVt/6a2mFt6bwMKqWTpjfzz606/JDLX9h8M69vY2c/OtmP 1ZdcIuyEmOy2VB/ipU4lG7ra8k0BLZ189hJTXM0HtLBs5otPzxWWn4OziX0vNUoAzql2 FZXGd+MEfHPUm5v7aYjQULwj8fzlhaJjYB5GRKGmwUh33WJoptCdiLf+A+qk9bElgBYW zeuw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ispras.ru Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x10si5475850ejb.330.2021.05.17.11.24.31; Mon, 17 May 2021 11:24:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ispras.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237110AbhEQMuk (ORCPT + 99 others); Mon, 17 May 2021 08:50:40 -0400 Received: from mail.ispras.ru ([83.149.199.84]:47958 "EHLO mail.ispras.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231591AbhEQMuj (ORCPT ); Mon, 17 May 2021 08:50:39 -0400 Received: from hellwig.intra.ispras.ru (unknown [10.10.2.182]) by mail.ispras.ru (Postfix) with ESMTPS id 167104076B58; Mon, 17 May 2021 12:49:21 +0000 (UTC) From: Evgeny Novikov To: Maxime Ripard Cc: Evgeny Novikov , Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, ldv-project@linuxtesting.org Subject: [PATCH] media: v4l: cadence: Handle errors of clk_prepare_enable() Date: Mon, 17 May 2021 15:49:18 +0300 Message-Id: <20210517124918.18641-1-novikov@ispras.ru> X-Mailer: git-send-email 2.26.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Handle errors of clk_prepare_enable() in csi2tx_get_resources(). Found by Linux Driver Verification project (linuxtesting.org). Signed-off-by: Evgeny Novikov --- drivers/media/platform/cadence/cdns-csi2tx.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/drivers/media/platform/cadence/cdns-csi2tx.c b/drivers/media/platform/cadence/cdns-csi2tx.c index e4d08acfbb49..765ae408970a 100644 --- a/drivers/media/platform/cadence/cdns-csi2tx.c +++ b/drivers/media/platform/cadence/cdns-csi2tx.c @@ -436,6 +436,7 @@ static int csi2tx_get_resources(struct csi2tx_priv *csi2tx, struct resource *res; unsigned int i; u32 dev_cfg; + int ret; res = platform_get_resource(pdev, IORESOURCE_MEM, 0); csi2tx->base = devm_ioremap_resource(&pdev->dev, res); @@ -454,7 +455,12 @@ static int csi2tx_get_resources(struct csi2tx_priv *csi2tx, return PTR_ERR(csi2tx->esc_clk); } - clk_prepare_enable(csi2tx->p_clk); + ret = clk_prepare_enable(csi2tx->p_clk); + if (ret) { + dev_err(&pdev->dev, "Couldn't prepare and enable p_clk\n"); + return ret; + } + dev_cfg = readl(csi2tx->base + CSI2TX_DEVICE_CONFIG_REG); clk_disable_unprepare(csi2tx->p_clk); -- 2.26.2