Received: by 2002:a05:7412:251c:b0:e2:908c:2ebd with SMTP id w28csp2423937rda; Wed, 25 Oct 2023 02:12:23 -0700 (PDT) X-Google-Smtp-Source: AGHT+IG7JnB6X/vPoLmpy3OmhdYUzfh9+92QT6pG93/dQh72HEL6Hk67aSIq3iaXztqY1vztIg1r X-Received: by 2002:a25:ab8a:0:b0:da0:3938:7ac6 with SMTP id v10-20020a25ab8a000000b00da039387ac6mr4759488ybi.15.1698225142991; Wed, 25 Oct 2023 02:12:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698225142; cv=none; d=google.com; s=arc-20160816; b=jhXbQWzfwSiuCI5RY3P41Luoa8yvYYWiTsedqSLVV+oIWvtebU7zaHeGNmgqQSvJVo CawkhmrD9t68DwD+uWqQOYwqRCz0hGgCGqVttCWV9FA3dtOZeLCsRQc2g5f60toSZP4k nVHC5pg8y3fYmTKAzX49BSvBvnvUOTS3k2uJsOaZ/kvp/rAA2TGxLQ2qEaGx6q7rN3Na uJ6HofB0fh4ZEmWLUTvz+NiR7YKKn+qoCCrS6WY52DgnDMcmwcAZiaQ1wpi9fDrw71oe cAKa4F065QRb/K8V7zHtOf1AvhZRth2FSzQ0P5EZD8BndEZPWvsua6dZe/lEfANC0VRn wSTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=kSKFySwB83Eu802FAuML1Y4OhvmdNvxB6tuaz46B1iM=; fh=aBkVWO+56m1DAXEnCqNCs5KTc/kn1ynpKtSPPcHsIbA=; b=gW/2w5yUOEETkw8iINGSQpy9ANEpXQa4e4XtUPA3ATEN515Vp88HgOGjXrp5UdIRmJ R/86H9X5VN7VfOmpj0+rO07bU94jTC5RlVB5ZsCXKhFzwO23y100pnsuM6QdGuXVvQs2 BiEnQKLS2KnTzDXQilTp8LpkG7n9IEvOmxKCO+CHoHeWL8WPZDe/Poaw8LMSm4m/HOZI jESFH1iyoW4trbW9x4ZJ0IvK+YaVFuWhCuykTLoCJXu++avOaGCrpMqMMCp5JnVPdMzo fyLdIjHiFmuET2mphzkawHyesAf8TKB3QQgmZEWnNksRR4ytYOp9ELggTf8HKG4Gh6ar 0+Dg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from snail.vger.email (snail.vger.email. [2620:137:e000::3:7]) by mx.google.com with ESMTPS id p144-20020a25d896000000b00d9adecded1bsi10270305ybg.627.2023.10.25.02.12.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 25 Oct 2023 02:12:22 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) client-ip=2620:137:e000::3:7; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 1FFB0807C856; Wed, 25 Oct 2023 02:11:19 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232823AbjJYJLP convert rfc822-to-8bit (ORCPT + 99 others); Wed, 25 Oct 2023 05:11:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53312 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231648AbjJYJLN (ORCPT ); Wed, 25 Oct 2023 05:11:13 -0400 Received: from ex01.ufhost.com (ex01.ufhost.com [61.152.239.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3EF13B9; Wed, 25 Oct 2023 02:11:08 -0700 (PDT) Received: from EXMBX166.cuchost.com (unknown [175.102.18.54]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "EXMBX166", Issuer "EXMBX166" (not verified)) by ex01.ufhost.com (Postfix) with ESMTP id CFD9B24E203; Wed, 25 Oct 2023 17:10:59 +0800 (CST) Received: from EXMBX061.cuchost.com (172.16.6.61) by EXMBX166.cuchost.com (172.16.6.76) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Wed, 25 Oct 2023 17:10:59 +0800 Received: from [192.168.125.131] (183.27.99.126) by EXMBX061.cuchost.com (172.16.6.61) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Wed, 25 Oct 2023 17:10:58 +0800 Message-ID: Date: Wed, 25 Oct 2023 17:04:42 +0800 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v7 2/3] clocksource: Add JH7110 timer driver Content-Language: en-US To: Daniel Lezcano , Thomas Gleixner , Emil Renner Berthing , Christophe JAILLET CC: , , "Rob Herring" , Krzysztof Kozlowski , Paul Walmsley , Palmer Dabbelt , Albert Ou , Philipp Zabel , Walker Chen , Samin Guo , , Conor Dooley References: <20231019053501.46899-1-xingyu.wu@starfivetech.com> <20231019053501.46899-3-xingyu.wu@starfivetech.com> <3f76f965-7c7b-109e-2ee0-3033e332e84b@linaro.org> From: Xingyu Wu In-Reply-To: <3f76f965-7c7b-109e-2ee0-3033e332e84b@linaro.org> Content-Type: text/plain; charset="UTF-8" X-Originating-IP: [183.27.99.126] X-ClientProxiedBy: EXCAS062.cuchost.com (172.16.6.22) To EXMBX061.cuchost.com (172.16.6.61) X-YovoleRuleAgent: yovoleflag Content-Transfer-Encoding: 8BIT X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Wed, 25 Oct 2023 02:11:19 -0700 (PDT) On 2023/10/24 22:56, Daniel Lezcano wrote: > > Hi Xingyu, > > > On 19/10/2023 07:35, Xingyu Wu wrote: >> Add timer driver for the StarFive JH7110 SoC. > > As it is a new timer, please add a proper nice description explaining the timer hardware, thanks. OK. Will add the description in next version. > >> Signed-off-by: Xingyu Wu >> --- >>   MAINTAINERS                        |   7 + >>   drivers/clocksource/Kconfig        |  11 + >>   drivers/clocksource/Makefile       |   1 + >>   drivers/clocksource/timer-jh7110.c | 380 +++++++++++++++++++++++++++++ >>   4 files changed, 399 insertions(+) >>   create mode 100644 drivers/clocksource/timer-jh7110.c >> >> diff --git a/MAINTAINERS b/MAINTAINERS >> index 7a7bd8bd80e9..91c09b399131 100644 >> --- a/MAINTAINERS >> +++ b/MAINTAINERS >> @@ -20473,6 +20473,13 @@ S:    Maintained >>   F:    Documentation/devicetree/bindings/sound/starfive,jh7110-tdm.yaml >>   F:    sound/soc/starfive/jh7110_tdm.c >>   +STARFIVE JH7110 TIMER DRIVER >> +M:    Samin Guo >> +M:    Xingyu Wu >> +S:    Supported >> +F:    Documentation/devicetree/bindings/timer/starfive,jh7110-timer.yaml >> +F:    drivers/clocksource/timer-jh7110.c >> + >>   STARFIVE JH71X0 CLOCK DRIVERS >>   M:    Emil Renner Berthing >>   M:    Hal Feng >> diff --git a/drivers/clocksource/Kconfig b/drivers/clocksource/Kconfig >> index 0ba0dc4ecf06..821abcc1e517 100644 >> --- a/drivers/clocksource/Kconfig >> +++ b/drivers/clocksource/Kconfig >> @@ -641,6 +641,17 @@ config RISCV_TIMER >>         is accessed via both the SBI and the rdcycle instruction.  This is >>         required for all RISC-V systems. >>   +config STARFIVE_JH7110_TIMER >> +    bool "Timer for the STARFIVE JH7110 SoC" >> +    depends on ARCH_STARFIVE || COMPILE_TEST > > You may want to use ARCH_STARFIVE only if the platform can make this timer optional. Otherwise, set the option from the platform Kconfig and put the bool "bla bla" if COMPILE_TEST Yes, this timer only be used on the StarFive SoC. So I intend to modify to this: bool "Timer for the STARFIVE JH7110 SoC" if COMPILE_TEST depends on ARCH_STARFIVE > >> +    select TIMER_OF >> +    select CLKSRC_MMIO >> +    default ARCH_STARFIVE > > no "default" Will drop it. > >> +    help >> +      This enables the timer for StarFive JH7110 SoC. On RISC-V platform, >> +      the system has started RISCV_TIMER, but you can also use this timer >> +      which can provide four channels to do a lot more things on JH7110 SoC. >> + >>   config CLINT_TIMER >>       bool "CLINT Timer for the RISC-V platform" if COMPILE_TEST >>       depends on GENERIC_SCHED_CLOCK && RISCV >> diff --git a/drivers/clocksource/Makefile b/drivers/clocksource/Makefile >> index 368c3461dab8..b66ac05ec086 100644 >> --- a/drivers/clocksource/Makefile >> +++ b/drivers/clocksource/Makefile >> @@ -80,6 +80,7 @@ obj-$(CONFIG_INGENIC_TIMER)        += ingenic-timer.o >>   obj-$(CONFIG_CLKSRC_ST_LPC)        += clksrc_st_lpc.o >>   obj-$(CONFIG_X86_NUMACHIP)        += numachip.o >>   obj-$(CONFIG_RISCV_TIMER)        += timer-riscv.o >> +obj-$(CONFIG_STARFIVE_JH7110_TIMER)    += timer-jh7110.o >>   obj-$(CONFIG_CLINT_TIMER)        += timer-clint.o >>   obj-$(CONFIG_CSKY_MP_TIMER)        += timer-mp-csky.o >>   obj-$(CONFIG_GX6605S_TIMER)        += timer-gx6605s.o >> diff --git a/drivers/clocksource/timer-jh7110.c b/drivers/clocksource/timer-jh7110.c >> new file mode 100644 >> index 000000000000..71de29a3ec91 >> --- /dev/null >> +++ b/drivers/clocksource/timer-jh7110.c >> @@ -0,0 +1,380 @@ >> +// SPDX-License-Identifier: GPL-2.0 >> +/* >> + * Starfive JH7110 Timer driver >> + * >> + * Copyright (C) 2022-2023 StarFive Technology Co., Ltd. >> + * >> + * Author: >> + * Xingyu Wu >> + * Samin Guo >> + */ >> + >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include > > Please double check the headers and remove the pointless ones. Will fix. > > >> +/* Bias: Ch0-0x0, Ch1-0x40, Ch2-0x80, and so on. */ >> +#define JH7110_TIMER_CH_LEN        0x40 >> +#define JH7110_TIMER_CH_BASE(x)        ((x) * JH7110_TIMER_CH_LEN) >> +#define JH7110_TIMER_CH_MAX        4 >> + >> +#define JH7110_CLOCK_SOURCE_RATING    200 >> +#define JH7110_VALID_BITS        32 >> +#define JH7110_DELAY_US            0 >> +#define JH7110_TIMEOUT_US        10000 >> +#define JH7110_CLOCKEVENT_RATING    300 >> +#define JH7110_TIMER_MAX_TICKS        0xffffffff >> +#define JH7110_TIMER_MIN_TICKS        0xf >> +#define JH7110_TIMER_RELOAD_VALUE    0 >> + >> +#define JH7110_TIMER_INT_STATUS        0x00 /* RO[0:4]: Interrupt Status for channel0~4 */ >> +#define JH7110_TIMER_CTL        0x04 /* RW[0]: 0-continuous run, 1-single run */ >> +#define JH7110_TIMER_LOAD        0x08 /* RW: load value to counter */ >> +#define JH7110_TIMER_ENABLE        0x10 /* RW[0]: timer enable register */ >> +#define JH7110_TIMER_RELOAD        0x14 /* RW: write 1 or 0 both reload counter */ >> +#define JH7110_TIMER_VALUE        0x18 /* RO: timer value register */ >> +#define JH7110_TIMER_INT_CLR        0x20 /* RW: timer interrupt clear register */ >> +#define JH7110_TIMER_INT_MASK        0x24 /* RW[0]: timer interrupt mask register */ >> + >> +#define JH7110_TIMER_INT_CLR_ENA    BIT(0) >> +#define JH7110_TIMER_INT_CLR_AVA_MASK    BIT(1) >> + >> +struct jh7110_clkevt { >> +    struct clock_event_device evt; >> +    struct clocksource cs; >> +    bool cs_is_valid; >> +    struct clk *clk; >> +    struct reset_control *rst; >> +    u32 rate; >> +    u32 reload_val; >> +    void __iomem *base; >> +    char name[sizeof("jh7110-timer.chX")]; >> +}; >> + >> +struct jh7110_timer_priv { >> +    struct clk *pclk; >> +    struct reset_control *prst; >> +    struct jh7110_clkevt clkevt[JH7110_TIMER_CH_MAX]; > > Why do you need several clock events and clock sources ? This timer has four counters (channels) which run independently. So each counter can have its own clock event and clock source to configure different settings. > > [ ... ] > > Thanks, Xingyu Wu