Received: by 2002:a05:6358:e9c4:b0:b2:91dc:71ab with SMTP id hc4csp2142554rwb; Fri, 5 Aug 2022 14:13:09 -0700 (PDT) X-Google-Smtp-Source: AA6agR5ivmGKA0Q+GFVG5yxkAwFJnGMa0WZYnJXDFhIxyFmBcJWPubmvRxhYZIaqQbQ/cMMs3gC/ X-Received: by 2002:a05:6402:ea7:b0:43a:ecea:76e with SMTP id h39-20020a0564020ea700b0043aecea076emr8222766eda.77.1659733988938; Fri, 05 Aug 2022 14:13:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659733988; cv=none; d=google.com; s=arc-20160816; b=D2vy6p+r3ZLCbq9uy4fL9N2BAcsFDuW7XGiDlYvyBljCErW1kwUf9fWCKBnmAuDGHE 9uFxbbB5MmE2l68AbM0XiNIB6TeewjfO0/RdgSYEqVSqYa6iP6fRH0UWmVhw4x7oAfaR +FDdzDpZ3s7tkcbxXOSEuVRFKAqJVoBWCBTA6FbD5m2nQbYRHJOQPUCmQL0XSn4xKQ9A SfwrHDJmdWYss5RFx1Aq6JkXPQTS0N6oUoSI60Fp2sdKjLsnZ/YjPOVdX5YJkFqliU/E syhBrZmoi2RYN4U1YhnwGuNt+MbEMPzS8mRMNDHxlkwQrDRI8eNFDNIBAL4knD5OjS64 lxig== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=MnVTdBUNuX8+w9V9/QiD+GbO6TA7c66LG3GUakY5RTU=; b=zLbXLU+QvDcIm6hShdx/9w0a40ozWZooKWAeDIpNWZMh/cjlBWFge9b90ktmv3/0WH snuTwf1qnDzctMjeMWsTC7l82wGcKMi1nXDXWq8+AhQTKp2R/tjqJk0Saa/T53S4jEDf SdJ44PTsJ0/GvHj9/3Qb/HqpYZLVPFvuRi1F5lePLj0c9NrFnnrmGm1mZRkDL9UnNfmu bG3tfHSAsY1Y/oMoc1usI30IFuZE8O6/XOUOWtfQa0Igty9IPcxmGEnY/FhCwNPk8lw7 tI4N9DevSLcgdVjEwIuiciJdbIeherGcseU6vLU6uERuaoPxQdI0Y+hdCBFHAVDy1jNV Q+7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=dPGDMhAO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x11-20020a50ba8b000000b0043ddc200046si636300ede.454.2022.08.05.14.12.38; Fri, 05 Aug 2022 14:13:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=dPGDMhAO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240504AbiHEUxj (ORCPT + 99 others); Fri, 5 Aug 2022 16:53:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33372 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234587AbiHEUxb (ORCPT ); Fri, 5 Aug 2022 16:53:31 -0400 Received: from mga11.intel.com (mga11.intel.com [192.55.52.93]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A727914D0F for ; Fri, 5 Aug 2022 13:53:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1659732810; x=1691268810; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=yUK1ZmvLOiqFQ/6rctVM5qooY+a4+dohGMG8XKuCOX4=; b=dPGDMhAOWn6vFm/LTftLYMvymCQjUp23DL7LS50mYyxA19z4R3hVdjpv bqBs7Kv5Rx0vWz/T5nLhtnl0uR4qlHJ6NcubiIKQcvAJMXfBR51uAGA0L Q2lI1F0mLTdTgOa2YKoMSKr6jst1v14YaNdVti56HXSnTaIRTCjc1QO6V FxJCBxdb4MicPitjV3TJ5tEf2ZfT68BTj1maM5hsXwqzIpyYSvGjCIQoK SDacfr7YYhr5jCT7lWA6rsT85bgG64VxyCdzY3ia6zOQ5g3IycAtv6d7D 9+ZNzTYpLCWsGaRPlLsFTeGleEdY/1iVNuo8ZOR0P3mCGj6kHbyreKy4y g==; X-IronPort-AV: E=McAfee;i="6400,9594,10430"; a="287853562" X-IronPort-AV: E=Sophos;i="5.93,216,1654585200"; d="scan'208";a="287853562" Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 Aug 2022 13:53:28 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.93,216,1654585200"; d="scan'208";a="706735347" Received: from black.fi.intel.com ([10.237.72.28]) by fmsmga002.fm.intel.com with ESMTP; 05 Aug 2022 13:53:26 -0700 Received: by black.fi.intel.com (Postfix, from userid 1003) id 41B9CD9; Fri, 5 Aug 2022 23:53:38 +0300 (EEST) From: Andy Shevchenko To: Andy Shevchenko , Mark Brown , Aidan MacDonald , linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , "Rafael J. Wysocki" Subject: [PATCH v1 2/5] regmap: mmio: Drop unneeded and duplicative checks around CLK calls Date: Fri, 5 Aug 2022 23:53:18 +0300 Message-Id: <20220805205321.19452-2-andriy.shevchenko@linux.intel.com> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220805205321.19452-1-andriy.shevchenko@linux.intel.com> References: <20220805205321.19452-1-andriy.shevchenko@linux.intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,RCVD_IN_DNSWL_HI,SPF_HELO_NONE, SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The commit 6b8e090ecc3d ("regmap: use IS_ERR() to check clk_get() results") assumes that CLK calls return the error pointer when clock is not found. However in the current code the described situation is simply impossible, because the regmap won't be created with missed clock if requested. The only way when it can be the case is what the above mentioned commit introduced by itself, when clock is not provided. Taking above into consideration, effectively revert the commit 6b8e090ecc3d and while at it, drop unneeded NULL checks since CLK calls are NULL-aware. Signed-off-by: Andy Shevchenko --- drivers/base/regmap/regmap-mmio.c | 25 +++++++++---------------- 1 file changed, 9 insertions(+), 16 deletions(-) diff --git a/drivers/base/regmap/regmap-mmio.c b/drivers/base/regmap/regmap-mmio.c index e83a2c3ba95a..e1923506a89a 100644 --- a/drivers/base/regmap/regmap-mmio.c +++ b/drivers/base/regmap/regmap-mmio.c @@ -146,16 +146,13 @@ static int regmap_mmio_write(void *context, unsigned int reg, unsigned int val) struct regmap_mmio_context *ctx = context; int ret; - if (!IS_ERR(ctx->clk)) { - ret = clk_enable(ctx->clk); - if (ret < 0) - return ret; - } + ret = clk_enable(ctx->clk); + if (ret < 0) + return ret; ctx->reg_write(ctx, reg, val); - if (!IS_ERR(ctx->clk)) - clk_disable(ctx->clk); + clk_disable(ctx->clk); return 0; } @@ -227,16 +224,13 @@ static int regmap_mmio_read(void *context, unsigned int reg, unsigned int *val) struct regmap_mmio_context *ctx = context; int ret; - if (!IS_ERR(ctx->clk)) { - ret = clk_enable(ctx->clk); - if (ret < 0) - return ret; - } + ret = clk_enable(ctx->clk); + if (ret < 0) + return ret; *val = ctx->reg_read(ctx, reg); - if (!IS_ERR(ctx->clk)) - clk_disable(ctx->clk); + clk_disable(ctx->clk); return 0; } @@ -245,7 +239,7 @@ static void regmap_mmio_free_context(void *context) { struct regmap_mmio_context *ctx = context; - if (!IS_ERR(ctx->clk) && !ctx->attached_clk) { + if (!ctx->attached_clk) { clk_unprepare(ctx->clk); clk_put(ctx->clk); } @@ -290,7 +284,6 @@ static struct regmap_mmio_context *regmap_mmio_gen_context(struct device *dev, ctx->regs = regs; ctx->val_bytes = config->val_bits / 8; ctx->relaxed_mmio = config->use_relaxed_mmio; - ctx->clk = ERR_PTR(-ENODEV); switch (regmap_get_val_endian(dev, ®map_mmio, config)) { case REGMAP_ENDIAN_DEFAULT: -- 2.35.1