Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp387885yba; Thu, 18 Apr 2019 03:04:02 -0700 (PDT) X-Google-Smtp-Source: APXvYqxZk/cGNju0ajeiMyLTdVPCENx0dEEk45jqEOHOjozL+EzVcHmYSHA3E42MQjr1Oq6YVOYy X-Received: by 2002:a17:902:822:: with SMTP id 31mr68768316plk.41.1555581842517; Thu, 18 Apr 2019 03:04:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555581842; cv=none; d=google.com; s=arc-20160816; b=VHUNBA0UksJccZz5JJVBzL9+bHKEADYeskX8uNGU89Cc5dLAD7zfMYZWOQlJ9odYhI g4N95RIrJYkc5uVskYPnLdOhcDEu7sT72KAnNIDOfe7/8LMQVnBzSLQpUn5anpI7GLru 9QYXBjZpYMvsP1dqdy7nkK2+zEckqYLyEvvq5oZTvLxC+xJjT0lJqxp6B4pZIe+oyriV RZxy6ZSjTseWxS09lUIzhPyKDf7ffly/a0soIrLL9d2V5xYKxgh/9rfDLR39tv9mu1Xj y9seCgwuU/AgZc1a2FYM5SzsDi82ZRUwdiLA0r5YV+TmI6K+hb4+LoTILFhFh5Wxm8ga WQMQ== 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; bh=ehs1uWBRxu66n/JIm3jD/rnKXPuKSp/KylwlTZQC20Q=; b=v9TX1m//b75WpLpZ5U843pglmmnJCAcpoq7hkQh6tigHKcPgSwn1rF0PLoj12T+5uG 1ASHnApV0nFuOt6QxKZ2TpbI8D9pyapHQktuifaQJ0LUPyc3XUqr1ZXp/99UrZJ5mF47 krFVsN4GpyY2VgOzzxba5V86BFkkyZTsyzAxMYttotAKe3uDketGQtPbCVm4cTcB+PhJ IVE3aFXzickZYo1Ah3vjs7cEuAAtnVkIOQeVp/nTrWHGxTx6U1Uj1xz+rToWg8i2z6rN sP2iSpfAR9U2ch2X5F/12eb7la813cuTtqUdKhCOv4tR1fvIiUc0emEP9SiWyUaB7keO ej7g== 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 m7si1476008pgg.78.2019.04.18.03.03.47; Thu, 18 Apr 2019 03:04:02 -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; 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 S2388703AbfDRKBK (ORCPT + 99 others); Thu, 18 Apr 2019 06:01:10 -0400 Received: from relay10.mail.gandi.net ([217.70.178.230]:37425 "EHLO relay10.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388683AbfDRKBI (ORCPT ); Thu, 18 Apr 2019 06:01:08 -0400 Received: from localhost (alyon-652-1-176-226.w109-212.abo.wanadoo.fr [109.212.207.226]) (Authenticated sender: alexandre.belloni@bootlin.com) by relay10.mail.gandi.net (Postfix) with ESMTPSA id 8720C240015; Thu, 18 Apr 2019 10:01:05 +0000 (UTC) From: Alexandre Belloni To: linux-rtc@vger.kernel.org Cc: Paul Cercueil , Mathieu Malaterre , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Alexandre Belloni Subject: [PATCH 6/7] rtc: jz4740: rework invalid time detection Date: Thu, 18 Apr 2019 12:00:44 +0200 Message-Id: <20190418100045.29288-6-alexandre.belloni@bootlin.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190418100045.29288-1-alexandre.belloni@bootlin.com> References: <20190418100045.29288-1-alexandre.belloni@bootlin.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 The scratchpad register is used to detect an invalid time when power to the RTC has been lost. Instead of deleting that precious information and set the time to the UNIX epoch, forward it to userspace. Signed-off-by: Alexandre Belloni --- drivers/rtc/rtc-jz4740.c | 21 +++++++++------------ 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/drivers/rtc/rtc-jz4740.c b/drivers/rtc/rtc-jz4740.c index fa15ad9fbe13..c9e16d857fa8 100644 --- a/drivers/rtc/rtc-jz4740.c +++ b/drivers/rtc/rtc-jz4740.c @@ -157,6 +157,9 @@ static int jz4740_rtc_read_time(struct device *dev, struct rtc_time *time) uint32_t secs, secs2; int timeout = 5; + if (jz4740_rtc_reg_read(rtc, JZ_REG_RTC_SCRATCHPAD) != 0x12345678) + return -EINVAL; + /* If the seconds register is read while it is updated, it can contain a * bogus value. This can be avoided by making sure that two consecutive * reads have the same value. @@ -180,8 +183,13 @@ static int jz4740_rtc_read_time(struct device *dev, struct rtc_time *time) static int jz4740_rtc_set_time(struct device *dev, struct rtc_time *time) { struct jz4740_rtc *rtc = dev_get_drvdata(dev); + int ret; + + ret = jz4740_rtc_reg_write(rtc, JZ_REG_RTC_SEC, rtc_tm_to_time64(time)); + if (ret) + return ret; - return jz4740_rtc_reg_write(rtc, JZ_REG_RTC_SEC, rtc_tm_to_time64(time)); + return jz4740_rtc_reg_write(rtc, JZ_REG_RTC_SCRATCHPAD, 0x12345678); } static int jz4740_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alrm) @@ -308,7 +316,6 @@ static int jz4740_rtc_probe(struct platform_device *pdev) { int ret; struct jz4740_rtc *rtc; - uint32_t scratchpad; struct resource *mem; const struct platform_device_id *id = platform_get_device_id(pdev); const struct of_device_id *of_id = of_match_device( @@ -376,16 +383,6 @@ static int jz4740_rtc_probe(struct platform_device *pdev) return ret; } - scratchpad = jz4740_rtc_reg_read(rtc, JZ_REG_RTC_SCRATCHPAD); - if (scratchpad != 0x12345678) { - ret = jz4740_rtc_reg_write(rtc, JZ_REG_RTC_SCRATCHPAD, 0x12345678); - ret = jz4740_rtc_reg_write(rtc, JZ_REG_RTC_SEC, 0); - if (ret) { - dev_err(&pdev->dev, "Could not write to RTC registers\n"); - return ret; - } - } - if (np && of_device_is_system_power_controller(np)) { if (!pm_power_off) { /* Default: 60ms */ -- 2.20.1