Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp2667801ybz; Sun, 19 Apr 2020 06:55:49 -0700 (PDT) X-Google-Smtp-Source: APiQypLotIQhfl8J1HX8c2TaK1ubrYmUKy+FM4f72u45g0C96L9BQs+7pj6ErRtx5fhtKC1jAMt7 X-Received: by 2002:a17:907:214d:: with SMTP id rk13mr11990004ejb.220.1587304549211; Sun, 19 Apr 2020 06:55:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587304549; cv=none; d=google.com; s=arc-20160816; b=sJr/IofBZ4QehQmJi7+Irc+I9lr6lrkLY1eSb6E6R7aSzGTNbJvPvD38VwT7wyVohH OhjV26fyg/4IWv4xxuOHqNJ3fmzygw7lix1iRahYcIO0sAqvzjIOd9EzaBHmjcnlQpKq aRjjkkHi5cyMGkSiomqmjAqWFWUZWzRhi2lTvNYX6X01KDA7OdEhL5/KsMGfJ578t9pE c/ACr7tZ/QyeAP7X0vxL4Df5Oo693MaY4kaQpjEdvOuC4XvPMbLrPrgaqwybFGUCa6d+ BhjYbjhsaTHoPGV5nqPfMZdjh9kvL7bGXPpMjtRq+DZyguEtV7MKOm3BhHsGeQ/D1aLj 41+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=mhTS4tSvEeXvCLcgGfGf9aL3CMO3Qt9fZyLFwhxCOiU=; b=EQMfcIvPJAKnCv0qtKiEc3h/K17YifHbTqAcm+BYGtdfzNSlr86BS90MC7UndU4Xtv SMhTKEvrt7WqRiVKssbMnc/pY4jtGPFF1QVDZKseGBigB4ttxoPvAuTqbwOPVcU2Pq3T jnmny+b9WSnOgzRlGWJ9cxBvfOFOZ76CXieeynu1glRfV0EYy1KkfWHdZEG7gGSMx7W5 Pn4TZpjet9WdeKFi1NduXzAfEHQRsVUtrwgoLtjUWM/JcCGfBo0zzGrpdQblZA+LxsK5 wFagNOXHOcR9bH4B8annrMlFTGeNUrwEms6hNMD8j4PVfneTS+LWjM+OHcwnuMyUrRYV 5Zvw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=fOanMSm4; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a18si14536685ejy.194.2020.04.19.06.55.26; Sun, 19 Apr 2020 06:55:49 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=fOanMSm4; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726437AbgDSNwY (ORCPT + 99 others); Sun, 19 Apr 2020 09:52:24 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48142 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725949AbgDSNwX (ORCPT ); Sun, 19 Apr 2020 09:52:23 -0400 Received: from mail-pj1-x1042.google.com (mail-pj1-x1042.google.com [IPv6:2607:f8b0:4864:20::1042]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 27A42C061A0C for ; Sun, 19 Apr 2020 06:52:23 -0700 (PDT) Received: by mail-pj1-x1042.google.com with SMTP id a32so3350816pje.5 for ; Sun, 19 Apr 2020 06:52:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=mhTS4tSvEeXvCLcgGfGf9aL3CMO3Qt9fZyLFwhxCOiU=; b=fOanMSm4AgQ22mXAc6DFchfc3BNTM6NWPcbni7P3DuXg5x/ziJkh7IiD4X5JvPxwg7 f0QYdVge00ir/soYAMPRUSgXEq87TdpLojVq52f5YCMt8d3bqA0W1Z0ypGYce5EmJN6i heiAhRMgHaqFfAm0b5GZtFqBrFDh7gkLWZ8fErMV6GduA4WoNyBIGM9wGxqgB/XjKgms x/NfrROozqFpN44bwDR1GlKEWM11ulF/pz89w0YWVzOgXuc276OQJuWqJ+8Ca2rS4YdQ Pu4xE405KLgHSjMwP8YnMgwXZmazFN/pECaVMonlW1CKTYPHMxAYh/d+T2LBUUhwdsGD 7wXQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=mhTS4tSvEeXvCLcgGfGf9aL3CMO3Qt9fZyLFwhxCOiU=; b=LPmLTrHikbIu//4eeqhbpewTZc2a+q1N55GnKQGosgAuTmFlD/cHIConSG23Ue+eVd lRqZ8TpOZ6nZXYzxBThVtAtFCL1+SQuBoz5w3LoPJjuGCR+Er3Lz70XhXGi9HspVjdBb oclrT5UuCYPSliiUqP6TiWQqs+byTlSNIbnPph6kLNiqzz9PdlPy6Vqs7v/Ai2i6a5mR /xFCJYp9eYkvlx9L6ABVEWuDOE00w4LOJFugx+HkTzlwbYbLoer/k44PMHkUwnO+AjDJ 7iEo214DjcZvUgD4HQSaAnVGzpbL0OyyevFzyx15qfbvHv0TStkqVehlERgfLoMar1Qe gELQ== X-Gm-Message-State: AGi0PuZz+aKGQ8cXv/mH6V98LEkHWELwyT2rlaK5EuJ4AiD7aOgikMQi 05/k34vCNhg34S9EdwoFpoY= X-Received: by 2002:a17:90b:4c45:: with SMTP id np5mr15845394pjb.19.1587304342812; Sun, 19 Apr 2020 06:52:22 -0700 (PDT) Received: from localhost ([89.208.244.140]) by smtp.gmail.com with ESMTPSA id gv7sm7488007pjb.16.2020.04.19.06.52.21 (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Sun, 19 Apr 2020 06:52:22 -0700 (PDT) From: Dejin Zheng To: broonie@kernel.org, linux-kernel@vger.kernel.org Cc: Dejin Zheng Subject: [PATCH v1 1/2] regmap: redefined regmap_read_poll_timeout to simplify code Date: Sun, 19 Apr 2020 21:51:49 +0800 Message-Id: <20200419135150.14741-2-zhengdejin5@gmail.com> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200419135150.14741-1-zhengdejin5@gmail.com> References: <20200419135150.14741-1-zhengdejin5@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org use read_poll_timeout macro to redefined regmap_read_poll_timeout and also remove the duplicate code. Signed-off-by: Dejin Zheng --- include/linux/regmap.h | 25 +++++-------------------- 1 file changed, 5 insertions(+), 20 deletions(-) diff --git a/include/linux/regmap.h b/include/linux/regmap.h index 40b07168fd8e..299c1f6a03b4 100644 --- a/include/linux/regmap.h +++ b/include/linux/regmap.h @@ -17,6 +17,7 @@ #include #include #include +#include struct module; struct clk; @@ -122,26 +123,10 @@ struct reg_sequence { */ #define regmap_read_poll_timeout(map, addr, val, cond, sleep_us, timeout_us) \ ({ \ - u64 __timeout_us = (timeout_us); \ - unsigned long __sleep_us = (sleep_us); \ - ktime_t __timeout = ktime_add_us(ktime_get(), __timeout_us); \ - int __ret; \ - might_sleep_if(__sleep_us); \ - for (;;) { \ - __ret = regmap_read((map), (addr), &(val)); \ - if (__ret) \ - break; \ - if (cond) \ - break; \ - if ((__timeout_us) && \ - ktime_compare(ktime_get(), __timeout) > 0) { \ - __ret = regmap_read((map), (addr), &(val)); \ - break; \ - } \ - if (__sleep_us) \ - usleep_range((__sleep_us >> 2) + 1, __sleep_us); \ - } \ - __ret ?: ((cond) ? 0 : -ETIMEDOUT); \ + int __ret, __tmp; \ + __tmp = read_poll_timeout(regmap_read, __ret, __ret || (cond), \ + sleep_us, timeout_us, false, (map), (addr), &(val)); \ + __ret ?: __tmp; \ }) /** -- 2.25.0