Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp2003746ybi; Mon, 1 Jul 2019 04:28:56 -0700 (PDT) X-Google-Smtp-Source: APXvYqxsxeuFnNIysRaIWaUydTgdWSGf5m+0TIh8if+ydPY1M5ju1YqYqj310l6JqwsHyvWt8AFs X-Received: by 2002:a63:f957:: with SMTP id q23mr24687776pgk.326.1561980536245; Mon, 01 Jul 2019 04:28:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561980536; cv=none; d=google.com; s=arc-20160816; b=GcTMwSr5mohcApUIEqsvGZPPCOw0oNKH9lqo7bdJQGJDbIBMAOCiklAOnS5df4bALU bhdIyoS3lCByW/8RqRFcinJZE/aL3IjdQYQQEr5yDjj7+Pb+C6BDWqhZps5v2D5Oi5/1 YwAUwVWumQ5Eh9eHXeyxA8JPqisH5rwwSeeICg8RfJIxLvk7ZzlQupDBgwJ/985oq0MS biL0Aobfo4n3Q5IU+YZhCiq3vvFguVmXr2DC9Xm08i/bK4ljcdpf3xDEnYiGcbmAOsxk F7w/DLHl3ZlT0k+FML2W/FfSCEYUEDKsHA8RzdNZZI6S122aX/Aj964X8eWm544TcLV4 uBSw== 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:message-id:date :subject:cc:to:from; bh=PPafZdXVM4Od6MIOpFexeYf6j7cxPvRhL5mvU4WGbLA=; b=KgcB2MfR9BKYWPQEioixMEhCpvkChz+JjhYO715SnnrmBdffi+7URMCdWusGOdUuVK 7j+y58iAcXsmvF8TAUohpqpFs4qvfU8xWcLElmS0Jxy4wUsSsRqpEog1HH5EsJLpIuuI gDfMG7XTe1oRpNFvp2C3hCDTsEO9/8iUSzJNO3bmheQ6UYT9nz8BWZOgauy3WAABCY4l PzswlWhYYWFsgy4kvk+Z3BjYpbKtXJuHdJwAAfOs49Z3LnEWMcS10grjl+Ti0Gr9YKe/ 4+fL8cd5qhkxNu3NBVhmXza0INZ4mPRb0AHvhPU+CREVWYb167urNOggQlu6SeadJVaf 5HPA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o4si10061739plb.274.2019.07.01.04.28.40; Mon, 01 Jul 2019 04:28:56 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727390AbfGAJsG (ORCPT + 99 others); Mon, 1 Jul 2019 05:48:06 -0400 Received: from inva020.nxp.com ([92.121.34.13]:33962 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728571AbfGAJsE (ORCPT ); Mon, 1 Jul 2019 05:48:04 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 1EDD61A0F55; Mon, 1 Jul 2019 11:48:02 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 2CBA81A09A5; Mon, 1 Jul 2019 11:47:51 +0200 (CEST) Received: from titan.ap.freescale.net (TITAN.ap.freescale.net [10.192.208.233]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id BCC9A402B6; Mon, 1 Jul 2019 17:47:19 +0800 (SGT) From: Anson.Huang@nxp.com To: daniel.lezcano@linaro.org, tglx@linutronix.de, robh+dt@kernel.org, mark.rutland@arm.com, shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, festevam@gmail.com, leonard.crestez@nxp.com, viresh.kumar@linaro.org, daniel.baluta@nxp.com, ping.bai@nxp.com, l.stach@pengutronix.de, abel.vesa@nxp.com, andrew.smirnov@gmail.com, ccaione@baylibre.com, angus@akkea.ca, agx@sigxcpu.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org Cc: Linux-imx@nxp.com Subject: [PATCH V4 3/5] clocksource: imx-sysctr: Make timer work with clock driver using platform driver model Date: Mon, 1 Jul 2019 17:38:24 +0800 Message-Id: <20190701093826.5472-3-Anson.Huang@nxp.com> X-Mailer: git-send-email 2.14.1 In-Reply-To: <20190701093826.5472-1-Anson.Huang@nxp.com> References: <20190701093826.5472-1-Anson.Huang@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Anson Huang On some i.MX8M platforms, clock driver uses platform driver model and it is NOT ready during timer initialization phase, the clock operations will fail and system counter driver will fail too. As all the i.MX8M platforms' system counter clock are from OSC which is always enabled, so it is no need to enable clock for system counter driver, the ONLY thing is to pass clock frequence to driver. To make system counter driver work for upper scenario, if DT's system counter node has property "clock-frequency" present, setting TIMER_OF_CLOCK_FREQUENCY flag to indicate timer-of driver to get clock frequency from DT directly instead of of_clk operation via clk APIs. Signed-off-by: Anson Huang --- Changes since V3: - remove the .prop_name initialization acording to timer-of changes in V4. --- drivers/clocksource/timer-imx-sysctr.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/drivers/clocksource/timer-imx-sysctr.c b/drivers/clocksource/timer-imx-sysctr.c index fd7d680..b82a549 100644 --- a/drivers/clocksource/timer-imx-sysctr.c +++ b/drivers/clocksource/timer-imx-sysctr.c @@ -98,7 +98,7 @@ static irqreturn_t sysctr_timer_interrupt(int irq, void *dev_id) } static struct timer_of to_sysctr = { - .flags = TIMER_OF_IRQ | TIMER_OF_CLOCK | TIMER_OF_BASE, + .flags = TIMER_OF_IRQ | TIMER_OF_BASE, .clkevt = { .name = "i.MX system counter timer", .features = CLOCK_EVT_FEAT_ONESHOT | @@ -130,6 +130,9 @@ static int __init sysctr_timer_init(struct device_node *np) { int ret = 0; + to_sysctr.flags |= of_find_property(np, "clock-frequency", NULL) ? + TIMER_OF_CLOCK_FREQUENCY : TIMER_OF_CLOCK; + ret = timer_of_init(np, &to_sysctr); if (ret) return ret; -- 2.7.4