Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp5654721ybn; Sun, 29 Sep 2019 03:02:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqyloS6vRD5l1GymLs88sxcj3ufZRz7rzW0eYDAMh0b5GcsYgdVFEj1Tk0XMEADQ2TWJWtZq X-Received: by 2002:a17:906:d8c8:: with SMTP id re8mr14855654ejb.130.1569751360656; Sun, 29 Sep 2019 03:02:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569751360; cv=none; d=google.com; s=arc-20160816; b=T0x16TG+xWVqYoku1cEr2RltICG6dMmOJrs7aHyEZFNa+8GJZSTDKquuFTCfZHe4Xx 1qM716uZGprE0eZlmWDgStrxIBxM8epYckb2hnOguEaS/+xajiqG4ynrAyHIjPgab83K bkeG2pWf7114JHRf8ewZY1XOWho9iaxszgfVQWMjeNflsos+543JOGq9tIwlOIzfibuC j/fem4XvE5y+lTADcTOMNLJr25QSremasrBrheCoHN96Mi00n/yvlbc1Faty3XYEEV03 Dkty8/Gw27tCYGg4r5G0+Se44IySBRJT/80XeZpdCTSQc9iJhuVbG4+HZnbma2v0R6zl nyEA== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=ZeRS0GoLkKgv4d/TcQs5tTBQaLtEUhmc3nWIhpoYfd8=; b=oQ9L699S1xeA9XWmuciChFS02crPEvpM0OdmlrtCX114cYaLXi1+vgMMYQbqCLhIVa Zs377broF9Ee8QyqRd90cidD28HK0ZHL/1iYrYgciyxskoobKbDYSVSE0Kd9yiobMl8F dnZADion4EYVlddfTnZeWuJdC5CYz/W31om5RNyhtbCIjQfZdwYEq+NZk7ARt26uuJGF 0Miyx5mvbUxjyV7g5RSlOtEUeoM7jznuqNTEMypATj90zvzTmuI8i/aQTWplwkHz3o6Z jt8M5q8MtAJrFxPxKYOJzGX7qBLEuF/lYqBHgGAAJw7BX1igGqpEn3atXCOrnzAJpTKo TnvA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ingics-com.20150623.gappssmtp.com header.s=20150623 header.b=GJrC4f9o; 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 c26si5231731edx.353.2019.09.29.03.02.16; Sun, 29 Sep 2019 03:02:40 -0700 (PDT) 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; dkim=pass header.i=@ingics-com.20150623.gappssmtp.com header.s=20150623 header.b=GJrC4f9o; 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 S1728962AbfI2J7P (ORCPT + 99 others); Sun, 29 Sep 2019 05:59:15 -0400 Received: from mail-pf1-f193.google.com ([209.85.210.193]:36315 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725924AbfI2J7P (ORCPT ); Sun, 29 Sep 2019 05:59:15 -0400 Received: by mail-pf1-f193.google.com with SMTP id y22so3861465pfr.3 for ; Sun, 29 Sep 2019 02:59:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ingics-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=ZeRS0GoLkKgv4d/TcQs5tTBQaLtEUhmc3nWIhpoYfd8=; b=GJrC4f9ohfOuNQdPUt//FcvxufzqDki+yuufUdcl//wyAGb28s6PzgJ9vYPCbxcAEX gBwuZWSxTdUFM2PV7v+/zsWKBBxG6QOyDrnFIrjaWTR2W2/qV5bV/RYtiNJAmDXoNUmE AYtDtK4zAwZkFVtzX/8WBK35si9XDk1qSx7XLGNsvBxpWLToLdNs3DdR292Xej1CIVHs Vh5ReVsA9qnVdLzOVLaSiblJ1LswofIwwi6CAXLUEomAQADkRVQ+c6oCpOtgJ6FoaOZN bmnd4QnVc/TYGFOj0/Cdt0PX7fbC+jDgi3tb/qgItNFz2EOK3ixmBdGpnPsN6hhXYFSl BOmA== 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:mime-version :content-transfer-encoding; bh=ZeRS0GoLkKgv4d/TcQs5tTBQaLtEUhmc3nWIhpoYfd8=; b=HVLL+HB9vmVvCdN0Rmwu4Kq7jFXDBDLBplFgbYLUA5CZdvsi8co8RWfjdAnrTRu6Rv gODXinlwS83ctzVol9QpxKgi2fRoidTGUhSkD9mGL4UqXuz4o83D1fJf2VDo5baLJhem nJFi7zJV8uHieRvYJ+bYNJ2GBQDhQIXQxsiLAsmGwXu0vBl2gOq09ZDBuLzTMiBZg1Z8 JsEvB2UETguFg++PXy0xv9sf7Sk4EzIENPXa0LkigrYL5NhzyX556YYT3VuE3w50jNY3 OwNoIHEflLlYJy1m5p7VC9e2bgPb+HM6+BmeOI+F6wMzuca/N+lLx7p5lI+idPmsEzRn 3wxA== X-Gm-Message-State: APjAAAXIRRVbB2LGBYZqX07lt24l1yU0f+yScMOZ/NyKcG2DUCj9gfsD yy05vn4y102yWyBB7knC0AA9Zw== X-Received: by 2002:a17:90a:3ae7:: with SMTP id b94mr20459543pjc.63.1569751154549; Sun, 29 Sep 2019 02:59:14 -0700 (PDT) Received: from localhost.localdomain (122-117-179-2.HINET-IP.hinet.net. [122.117.179.2]) by smtp.gmail.com with ESMTPSA id w14sm21337343pge.56.2019.09.29.02.59.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 29 Sep 2019 02:59:13 -0700 (PDT) From: Axel Lin To: Mark Brown Cc: Nishanth Menon , "Andrii . Tseglytskyi" , Liam Girdwood , linux-kernel@vger.kernel.org, Axel Lin Subject: [PATCH] regulator: ti-abb: Fix timeout in ti_abb_wait_txdone/ti_abb_clear_all_txdone Date: Sun, 29 Sep 2019 17:58:48 +0800 Message-Id: <20190929095848.21960-1-axel.lin@ingics.com> X-Mailer: git-send-email 2.20.1 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 ti_abb_wait_txdone() may return -ETIMEDOUT when ti_abb_check_txdone() returns true in the latest iteration of the while loop because the timeout value is abb->settling_time + 1. Similarly, ti_abb_clear_all_txdone() may return -ETIMEDOUT when ti_abb_check_txdone() returns false in the latest iteration of the while loop. Fix it. Signed-off-by: Axel Lin --- drivers/regulator/ti-abb-regulator.c | 26 ++++++++------------------ 1 file changed, 8 insertions(+), 18 deletions(-) diff --git a/drivers/regulator/ti-abb-regulator.c b/drivers/regulator/ti-abb-regulator.c index cced1ffb896c..89b9314d64c9 100644 --- a/drivers/regulator/ti-abb-regulator.c +++ b/drivers/regulator/ti-abb-regulator.c @@ -173,19 +173,14 @@ static int ti_abb_wait_txdone(struct device *dev, struct ti_abb *abb) while (timeout++ <= abb->settling_time) { status = ti_abb_check_txdone(abb); if (status) - break; + return 0; udelay(1); } - if (timeout > abb->settling_time) { - dev_warn_ratelimited(dev, - "%s:TRANXDONE timeout(%duS) int=0x%08x\n", - __func__, timeout, readl(abb->int_base)); - return -ETIMEDOUT; - } - - return 0; + dev_warn_ratelimited(dev, "%s:TRANXDONE timeout(%duS) int=0x%08x\n", + __func__, timeout, readl(abb->int_base)); + return -ETIMEDOUT; } /** @@ -205,19 +200,14 @@ static int ti_abb_clear_all_txdone(struct device *dev, const struct ti_abb *abb) status = ti_abb_check_txdone(abb); if (!status) - break; + return 0; udelay(1); } - if (timeout > abb->settling_time) { - dev_warn_ratelimited(dev, - "%s:TRANXDONE timeout(%duS) int=0x%08x\n", - __func__, timeout, readl(abb->int_base)); - return -ETIMEDOUT; - } - - return 0; + dev_warn_ratelimited(dev, "%s:TRANXDONE timeout(%duS) int=0x%08x\n", + __func__, timeout, readl(abb->int_base)); + return -ETIMEDOUT; } /** -- 2.20.1