Received: by 2002:a05:7412:a9a2:b0:e2:908c:2ebd with SMTP id o34csp1022900rdh; Fri, 27 Oct 2023 02:24:14 -0700 (PDT) X-Google-Smtp-Source: AGHT+IG9adgbu6vd4/NFe+A45FuMgrBdM2CHv4XzGZmXASMUIEWvVoNoPpvGia6XIj3yfOHPOX5b X-Received: by 2002:a81:c64c:0:b0:59c:aea:d877 with SMTP id q12-20020a81c64c000000b0059c0aead877mr1831454ywj.40.1698398654019; Fri, 27 Oct 2023 02:24:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698398654; cv=none; d=google.com; s=arc-20160816; b=OLCV4pSCHdjGnWNQx6t3YALy0z14Hyr5RtEaRVQN3NYACBhG9lHxha8f5YKXp12zki TdbEMg3rblqGal0Q0kp+cYJd0VUuWQL84wC/mF5o4NOdlQCWCKP3jsovDzV8cFo4DgnI vjKBORTpXESkpFTujupGNQ6Y84WCyntlBRjmXBdDsuuv4yHyrC3vmzR1JaoBpIsCAH1R oD5MWdZG/oy6cDCUt2XbXLk8p/2H/CR+sMrOb8cU4iNkuOwGROcks+UZWuytnnm3Pkg9 xz8hzlEysHAr5+S8tw7s3sWirc4ZqsxOiM4ABa25O1a+Csfkd6XuCz3ChPdk6GHeZeP2 KPfQ== 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=6exYCELW+P2aOZYZKxP3F6c5s1wPkfJbNq2UEeEuRXI=; fh=aBkVWO+56m1DAXEnCqNCs5KTc/kn1ynpKtSPPcHsIbA=; b=CwLmIKH/BWHYQ8qIJdT3NR16wBK8LO8uxf50Naf6B7G5sDoQEwxACdjAwbK4pdR9jw 7GdiP0VsZy33jrhbSIauNvKA5Pw7I3F/HrQDcNFFruHI4DSL5gh7+hz8Z1S7V++Z0K9M DyXOIeJR1Jww041IErFMDovX2IsxOJ39bkMFMAwAZZJdc3SBWS3tdKVevMw2l6ZOvAKD 91IR1qluLVZX55wzOZ0Bx4viC97NXVXjnzZhSOk5Rettu6Ir+fEnQ1+aErvxJw80Og0B rZw56IcYtC6guti/+6tmB1rsxBaANUbA8XrM6RbLgc5pwREOp997swLzkjWKtwwotUh0 9jlg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from pete.vger.email (pete.vger.email. [23.128.96.36]) by mx.google.com with ESMTPS id e67-20020a0df546000000b00583acdad086si1820163ywf.542.2023.10.27.02.24.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 27 Oct 2023 02:24:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) client-ip=23.128.96.36; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 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 pete.vger.email (Postfix) with ESMTP id CA78B8089861; Fri, 27 Oct 2023 02:24:10 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229636AbjJ0JX6 convert rfc822-to-8bit (ORCPT + 99 others); Fri, 27 Oct 2023 05:23:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40758 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234901AbjJ0JX5 (ORCPT ); Fri, 27 Oct 2023 05:23:57 -0400 Received: from ex01.ufhost.com (ex01.ufhost.com [61.152.239.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5B6621A5; Fri, 27 Oct 2023 02:23:53 -0700 (PDT) Received: from EXMBX165.cuchost.com (unknown [175.102.18.54]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "EXMBX165", Issuer "EXMBX165" (not verified)) by ex01.ufhost.com (Postfix) with ESMTP id 4ABE824E1F0; Fri, 27 Oct 2023 17:23:50 +0800 (CST) Received: from EXMBX061.cuchost.com (172.16.6.61) by EXMBX165.cuchost.com (172.16.6.75) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Fri, 27 Oct 2023 17:23:50 +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; Fri, 27 Oct 2023 17:23:49 +0800 Message-ID: <540136d4-6f8f-49a6-80ff-cc621f2f462b@starfivetech.com> Date: Fri, 27 Oct 2023 17:17:30 +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: 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=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email 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 (pete.vger.email [0.0.0.0]); Fri, 27 Oct 2023 02:24:11 -0700 (PDT) On 2023/10/25 22:39, Daniel Lezcano wrote: > > Hi Xingyu, > > > On 25/10/2023 11:04, Xingyu Wu wrote: >> 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 > > In this case, you should change the platform config and select the timer from there. Remove the depends on ARCH_STARFIVE so it is possible enable cross test compilation. Otherwise COMPILE_TEST will not work on other platforms. > > [ ... ] > It is not a kernel timer or clocksource. It will not work on other platforms and is just used on the JH7110 SoC. I think I needn't remove it. Maybe I modify to this: bool "Timer for the STARFIVE JH7110 SoC" if COMPILE_TEST depends on ARCH_STARFIVE || COMPILE_TEST >>>> +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. > > The kernel only needs one clocksource. Usually multiple clockevents are per-cpu based system. > > The driver does not seem to have a per cpu timer but just initializing multiple clockevents which will end up unused, wasting energy. > > The board of the StarFive JH7110 SoC has two types of timer : riscv-timer and jh7110-timer. It boots by riscv-timer(clocksource) and the jh7110-timer is optional and additional. I think I should initialize the four channels of jh7110-timer as clockevents not clocksource pre-cpu. Thanks, Xingyu Wu