Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp516371ybc; Sat, 16 Nov 2019 03:49:15 -0800 (PST) X-Google-Smtp-Source: APXvYqzyPNUtnrG8sMNveduM38kiUxeV1C1nClki0jzr3FKhtXB7kvfTOalLv973ycvvlHTbHWgx X-Received: by 2002:a17:906:3285:: with SMTP id 5mr8747533ejw.143.1573904955123; Sat, 16 Nov 2019 03:49:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573904955; cv=none; d=google.com; s=arc-20160816; b=cduJWs/qmCx1JKI/StjtneJ17/Zu88PoTQXxP2VPkNSzDLV8rEbaE+sLzVJegeXZgl cb/rPzS01enX+Qamo5bfdb28F18D5TvN9gm7Fhl4yU0NLS3bJXVWc3lQZd3CU0oU1//i PZ3537nV3BJiDzAhzgKlXq+/kz+vwANiKswSEwnU+n/qxoPAY0NwL0FTsk71d9XGisxL PRnYNx4JIi4BTaYal5euoKzpFD/ciQhvquPPRKdAxc2aD+UQ0tfkLN+HLkjbystIqz+0 gV56qxv0TncyqN0ySFK+pAKz0hke8Z4OYsuwCBAp0unlxukMh0HTaI2r0RA+FqJ1ywwk 79+g== 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=hYZLZ+t7zW9QpC69y3DTNhSSDoe8rUBNplslYwkF1mk=; b=oGaaivj6xNvP4A6gDVtX+/j8t1SRec1muhjGsOelwo/4gPhz2s7baalbZ5N1KuMk+s dP3RNaJ+C6nPyf6E/Zo1ztWkgUcHNY6outNOQKqFKdtDchjBZeFINNO0dTzFC4mzsoh6 B3R3CN9lmI94iiZDcyDtP0cTHFCP7PcEZnHoj6fL6aScY/BrZ2JMwif4dbMRlP4mRSke gjYgML2gbGIEH0XTQwb/YEp0nyhHQLZggcDFDUDA8RtgwvshGj3PWAtlsBA7Hj4HGL6o wbDGNkPKwMjj3ZBH85WRl5cBbl2Bl7cdoQ/itq9C7sfF4ZmoqwCi9TkuLD992tER87ie hlOQ== 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 w47si9015536edd.326.2019.11.16.03.48.50; Sat, 16 Nov 2019 03:49:15 -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 S1727521AbfKPLqd (ORCPT + 99 others); Sat, 16 Nov 2019 06:46:33 -0500 Received: from mail-wr1-f65.google.com ([209.85.221.65]:33096 "EHLO mail-wr1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726794AbfKPLqc (ORCPT ); Sat, 16 Nov 2019 06:46:32 -0500 Received: by mail-wr1-f65.google.com with SMTP id w9so13817127wrr.0; Sat, 16 Nov 2019 03:46:31 -0800 (PST) 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; bh=hYZLZ+t7zW9QpC69y3DTNhSSDoe8rUBNplslYwkF1mk=; b=hNwHoNzk/uvJrn+JxoCqulz7jJxt2FAzMGnH3MaJkz2T1cx38hbvRHV8pnI504jgaG HSoTCY80cIIKgIZICacgPSvFpqSotzWhKTrBl/KLDwC/24CT0q/bh7gf+Z7eV9782qil XORkOSaXopgaMkGYkyjwvV2JfwfUo4PAbuL95JUuPoUVZSwwEjy1wRUaKeF4R5JjOYc3 zVkLmDHAyW033W+035Vnr7e+1zyRYHUv4eGXQoRM2ZHkAD48yMHwpxjoZgdXGBJTVf4R yXGZ6lxe50OEzkwi8WaJcvD5iO/SnaIbcJurFBriBKedcg39ov4Ge39sdO7yIT7DqUOs I2cA== X-Gm-Message-State: APjAAAW7U01wOJQHy0njxNi53q9h0YbNF1DXHPt8uABulZPzYzAOgaxr fqZpU58x5+PqHFq1WqCoG34= X-Received: by 2002:adf:e94e:: with SMTP id m14mr21057939wrn.233.1573904790163; Sat, 16 Nov 2019 03:46:30 -0800 (PST) Received: from localhost.localdomain (2001-1c06-18c6-e000-2463-1bcb-8fa3-05f8.cable.dynamic.v6.ziggo.nl. [2001:1c06:18c6:e000:2463:1bcb:8fa3:5f8]) by smtp.gmail.com with ESMTPSA id f17sm11918869wmj.40.2019.11.16.03.46.29 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 16 Nov 2019 03:46:29 -0800 (PST) From: Kars de Jong To: Alessandro Zummo , Alexandre Belloni Cc: linux-rtc@vger.kernel.org, linux-kernel@vger.kernel.org, Kars de Jong , Geert Uytterhoeven Subject: [PATCH] rtc: msm6242: Remove unneeded msm6242_set()/msm6242_clear() functions Date: Sat, 16 Nov 2019 12:46:20 +0100 Message-Id: <20191116114620.9193-1-jongk@linux-m68k.org> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The msm6242_set()/msm6242_clear() functions are used when writing to Control Register D to set or clear the HOLD bit when reading the current time from the RTC. Doing this with a read-modify-write cycle will potentially clear an interrupt condition which occurs between the read and the write. The datasheet states the following about this: When writing the HOLD or 30 second adjust bits of register D, it is necessary to write the IRQ FLAG bit to a "1". Since the only other bits in the register are the 30 second adjust bit (which is not used) and the BUSY bit (which is read-only), the read-modify-write cycle can be replaced by a simple write with the IRQ FLAG bit set to 1 and the other bits (except HOLD) set to 0. Cc: Geert Uytterhoeven Tested-by: Kars de Jong Signed-off-by: Kars de Jong --- drivers/rtc/rtc-msm6242.c | 20 ++++---------------- 1 file changed, 4 insertions(+), 16 deletions(-) diff --git a/drivers/rtc/rtc-msm6242.c b/drivers/rtc/rtc-msm6242.c index b1f2bedee77e..80e364baac53 100644 --- a/drivers/rtc/rtc-msm6242.c +++ b/drivers/rtc/rtc-msm6242.c @@ -88,28 +88,16 @@ static inline void msm6242_write(struct msm6242_priv *priv, unsigned int val, __raw_writel(val, &priv->regs[reg]); } -static inline void msm6242_set(struct msm6242_priv *priv, unsigned int val, - unsigned int reg) -{ - msm6242_write(priv, msm6242_read(priv, reg) | val, reg); -} - -static inline void msm6242_clear(struct msm6242_priv *priv, unsigned int val, - unsigned int reg) -{ - msm6242_write(priv, msm6242_read(priv, reg) & ~val, reg); -} - static void msm6242_lock(struct msm6242_priv *priv) { int cnt = 5; - msm6242_set(priv, MSM6242_CD_HOLD, MSM6242_CD); + msm6242_write(priv, MSM6242_CD_HOLD|MSM6242_CD_IRQ_FLAG, MSM6242_CD); while ((msm6242_read(priv, MSM6242_CD) & MSM6242_CD_BUSY) && cnt) { - msm6242_clear(priv, MSM6242_CD_HOLD, MSM6242_CD); + msm6242_write(priv, MSM6242_CD_IRQ_FLAG, MSM6242_CD); udelay(70); - msm6242_set(priv, MSM6242_CD_HOLD, MSM6242_CD); + msm6242_write(priv, MSM6242_CD_HOLD|MSM6242_CD_IRQ_FLAG, MSM6242_CD); cnt--; } @@ -120,7 +108,7 @@ static void msm6242_lock(struct msm6242_priv *priv) static void msm6242_unlock(struct msm6242_priv *priv) { - msm6242_clear(priv, MSM6242_CD_HOLD, MSM6242_CD); + msm6242_write(priv, MSM6242_CD_IRQ_FLAG, MSM6242_CD); } static int msm6242_read_time(struct device *dev, struct rtc_time *tm) -- 2.17.1