From patchwork Tue Jul 17 07:55:17 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "\(Exiting\) Baolin Wang" X-Patchwork-Id: 142110 Delivered-To: patch@linaro.org Received: by 2002:a2e:9754:0:0:0:0:0 with SMTP id f20-v6csp3348494ljj; Tue, 17 Jul 2018 00:56:06 -0700 (PDT) X-Google-Smtp-Source: AAOMgpc2/lgtynrr3beDnuqQzjPzlbpB8WxNswwSGiPAqcDa1eKZj0lbbjory9qaPNNc8NAKbRk8 X-Received: by 2002:a17:902:bd07:: with SMTP id p7-v6mr619430pls.32.1531814166740; Tue, 17 Jul 2018 00:56:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531814166; cv=none; d=google.com; s=arc-20160816; b=rvK7/h6k27cgahf5uW5zpoQzF+11LsMZevtqpTsTcKSNOO0Wm9zO7J53ZMfE4I35Bi /bMhwp9AYloBXS67IIRoO3EhrCFCSng/Q5BTlmCJe6NT8bJGdtthOxzrKrNNvtWggvv6 QNVlLanUwhXrpikA/k1E2+esjS1veKAL+iz9WNuNdjr+ZnAg5kw9cflcEBsblS/U9dP2 E5Ky1UbN+pwSHv7UPCihW0+uuFcQiYRwKB4bX218ZxZtP355GETOw5c4xK+Aq19H7Meq hkCgz5iYhamu/UVkMRi+WrQLemYyVEePFcyz3kTFek0mjt3v110KwqbwIHHKbYFr2Jsy 2Omw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=fGURDGdl/JLCtBIrVGtFaqQO0dTy+oPsnkiP/5Ymcxo=; b=kBxZYqK4qmJBNuRNTzHHw4NP9ArdvEUBus1WS08tNICy+YkwhzJW+kc+JTwal923BK S5ZIEzfM9sWGmke/nWTL/V/GiHEO4Hszdrx9i8iam6zNUarZGUHUP9RY0VcgCn5Gf65L 8cwv9p0LGVyZ492JMSu6QURNhkyzDIPh6CejBfQBQi8jOKi9xKT82HQEsjHKFslGR5R9 epd9K9B5KL4ViloPMiGtbT7eCELB67IyysyXvUJSXiUL+jnNjjAW9Sh3bWHe805bnL2G MAQy7JbnXpzwkPqTotnm0R/k4zGvCeEQpTYdhPxTJVWQytsnIRNd3NZqghTh98W285bA zVaA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=DbKTt1Sf; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w26-v6si325521pgk.372.2018.07.17.00.56.06; Tue, 17 Jul 2018 00:56:06 -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=@linaro.org header.s=google header.b=DbKTt1Sf; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729633AbeGQI1W (ORCPT + 31 others); Tue, 17 Jul 2018 04:27:22 -0400 Received: from mail-pl0-f65.google.com ([209.85.160.65]:36824 "EHLO mail-pl0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728304AbeGQI1V (ORCPT ); Tue, 17 Jul 2018 04:27:21 -0400 Received: by mail-pl0-f65.google.com with SMTP id e11-v6so107076plb.3 for ; Tue, 17 Jul 2018 00:56:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :in-reply-to:references; bh=fGURDGdl/JLCtBIrVGtFaqQO0dTy+oPsnkiP/5Ymcxo=; b=DbKTt1SfiQN/3EpERHDZ86Yc05unP7Hnp69x23v3efs8lIun+IzKxeNiWx3lTxrni3 vzMki2TYjsj72oWCUQKrfFDi4XJsrD1JevlEzZLR3EYbpUMGzZj4hs7ZF6qgYd1vGn7s TRzd0ij5/vBxzXktchBjrA7lWd07v4B2wnyEs= 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:in-reply-to:references; bh=fGURDGdl/JLCtBIrVGtFaqQO0dTy+oPsnkiP/5Ymcxo=; b=ZEqTh0YO97QMIKn+ICWQ7sIojQ49NVkojS7T1kk2HFJF6CC+ofKgRwWsCz6uY8Vz/p PCTI+aK1NA0dGdK5JPlyAW8LsmCb0Cr6oUWDZXiSwm5kOVQrMHttx6bGy1xy3BVpO2gF TTpBQhL451pu93lm9XnuW3d8iWMWOcBXKx7d27J4EZHLo1O7qIXn7nPSAncVtQH2+zJS Ouq7ng7Rz9RJu1J8EGZ78uyA61aGFvXE+TNyIsiVCtSW8djjimbCTHR4bWVXUmwznW4d 0Xyy7WC+Lkie8rVckHV0o81w/XEfGCJvR577lV3zSKkeEBMVTX4Cdx1Ew1Ka0fSZ+DxB wZSg== X-Gm-Message-State: AOUpUlF6zBs7mKl9cdG8tgovXgRgQ7xy/b935dyWUL3+Ze8mHVGR2/Kl 0fpNEtA8vwotrFljvz6cnptj3buWLlE= X-Received: by 2002:a17:902:201:: with SMTP id 1-v6mr594972plc.310.1531814161788; Tue, 17 Jul 2018 00:56:01 -0700 (PDT) Received: from baolinwangubtpc.spreadtrum.com ([117.18.48.102]) by smtp.gmail.com with ESMTPSA id j75-v6sm1462012pfj.102.2018.07.17.00.55.59 (version=TLS1 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 17 Jul 2018 00:56:01 -0700 (PDT) From: Baolin Wang To: tglx@linutronix.de, john.stultz@linaro.org, sboyd@kernel.org, arnd@arndb.de, broonie@kernel.org, daniel.lezcano@linaro.org Cc: linux-kernel@vger.kernel.org, baolin.wang@linaro.org Subject: [PATCH 2/2] clocksource: sprd: Register one always-on timer to compensate suspend time Date: Tue, 17 Jul 2018 15:55:17 +0800 Message-Id: <3d6de641eabb8f36ad2b6d4e948bfdeb2282c96a.1531812082.git.baolin.wang@linaro.org> X-Mailer: git-send-email 1.7.9.5 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since the clocksource framework has introduced one suspend clocksource to compensate the suspend time, this patch registers one always-on timer as the suspend clocksource. Signed-off-by: Baolin Wang --- Changes from RFC v1: - None. --- drivers/clocksource/timer-sprd.c | 50 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) -- 1.7.9.5 diff --git a/drivers/clocksource/timer-sprd.c b/drivers/clocksource/timer-sprd.c index ef9ebea..430cb99 100644 --- a/drivers/clocksource/timer-sprd.c +++ b/drivers/clocksource/timer-sprd.c @@ -156,4 +156,54 @@ static int __init sprd_timer_init(struct device_node *np) return 0; } +static struct timer_of suspend_to = { + .flags = TIMER_OF_BASE | TIMER_OF_CLOCK, +}; + +static u64 sprd_suspend_timer_read(struct clocksource *cs) +{ + return ~(u64)readl_relaxed(timer_of_base(&suspend_to) + + TIMER_VALUE_SHDW_LO) & cs->mask; +} + +static int sprd_suspend_timer_enable(struct clocksource *cs) +{ + sprd_timer_update_counter(timer_of_base(&suspend_to), + TIMER_VALUE_LO_MASK); + sprd_timer_enable(timer_of_base(&suspend_to), TIMER_CTL_PERIOD_MODE); + + return 0; +} + +static void sprd_suspend_timer_disable(struct clocksource *cs) +{ + sprd_timer_disable(timer_of_base(&suspend_to)); +} + +static struct clocksource suspend_clocksource = { + .name = "sprd_suspend_timer", + .rating = 200, + .read = sprd_suspend_timer_read, + .enable = sprd_suspend_timer_enable, + .disable = sprd_suspend_timer_disable, + .mask = CLOCKSOURCE_MASK(32), + .flags = CLOCK_SOURCE_IS_CONTINUOUS | CLOCK_SOURCE_SUSPEND_NONSTOP, +}; + +static int __init sprd_suspend_timer_init(struct device_node *np) +{ + int ret; + + ret = timer_of_init(np, &suspend_to); + if (ret) + return ret; + + clocksource_register_hz(&suspend_clocksource, + timer_of_rate(&suspend_to)); + + return 0; +} + TIMER_OF_DECLARE(sc9860_timer, "sprd,sc9860-timer", sprd_timer_init); +TIMER_OF_DECLARE(sc9860_persistent_timer, "sprd,sc9860-suspend-timer", + sprd_suspend_timer_init);