* [PATCH 1/2] arm64: mediatek: enable MTK_TIMER @ 2015-09-16 2:04 Yingjoe Chen 2015-09-16 2:04 ` [PATCH 2/2] arm64: dts: mt8173: add timer node Yingjoe Chen 2015-09-16 2:21 ` [PATCH 1/2] arm64: mediatek: enable MTK_TIMER Yingjoe Chen 0 siblings, 2 replies; 12+ messages in thread From: Yingjoe Chen @ 2015-09-16 2:04 UTC (permalink / raw) To: Matthias Brugger Cc: Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree, Arnd Bergmann, Catalin Marinas, linux-kernel, Rob Herring, linux-mediatek, Sascha Hauer, Olof Johansson, srv_heupstream, linux-arm-kernel, Daniel Kurtz, linux-clk, Yingjoe Chen Enable MTK_TIMER for MediaTek plaform, which will be used as schedule clock. Change-Id: Ib77a0bf01193102c755077b6e72e73e477b18e5f Signed-off-by: Yingjoe Chen <yingjoe.chen@mediatek.com> --- arch/arm64/Kconfig.platforms | 1 + 1 file changed, 1 insertion(+) diff --git a/arch/arm64/Kconfig.platforms b/arch/arm64/Kconfig.platforms index 23800a1..8176455 100644 --- a/arch/arm64/Kconfig.platforms +++ b/arch/arm64/Kconfig.platforms @@ -42,6 +42,7 @@ config ARCH_MEDIATEK bool "Mediatek MT65xx & MT81xx ARMv8 SoC" select ARM_GIC select PINCTRL + select MTK_TIMER help Support for Mediatek MT65xx & MT81xx ARMv8 SoCs -- 1.9.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-09-16 2:04 [PATCH 1/2] arm64: mediatek: enable MTK_TIMER Yingjoe Chen @ 2015-09-16 2:04 ` Yingjoe Chen 2015-09-17 13:51 ` Sudeep Holla 2015-09-16 2:21 ` [PATCH 1/2] arm64: mediatek: enable MTK_TIMER Yingjoe Chen 1 sibling, 1 reply; 12+ messages in thread From: Yingjoe Chen @ 2015-09-16 2:04 UTC (permalink / raw) To: Matthias Brugger Cc: Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree, Arnd Bergmann, Catalin Marinas, linux-kernel, Rob Herring, linux-mediatek, Sascha Hauer, Olof Johansson, srv_heupstream, linux-arm-kernel, Daniel Kurtz, linux-clk, Eddie Huang, Yingjoe Chen From: Daniel Kurtz <djkurtz@chromium.org> Add device node to enable GPT timer. This timer will be used as sched clock source. Change-Id: Idc4e3f0ee80b5c36cae6f0f2328f94aafcca1253 Signed-off-by: Daniel Kurtz <djkurtz@chromium.org> Signed-off-by: Eddie Huang <eddie.huang@mediatek.com> Signed-off-by: Yingjoe Chen <yingjoe.chen@mediatek.com> --- arch/arm64/boot/dts/mediatek/mt8173.dtsi | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/arch/arm64/boot/dts/mediatek/mt8173.dtsi b/arch/arm64/boot/dts/mediatek/mt8173.dtsi index d18ee42..d763803 100644 --- a/arch/arm64/boot/dts/mediatek/mt8173.dtsi +++ b/arch/arm64/boot/dts/mediatek/mt8173.dtsi @@ -238,6 +238,15 @@ reg = <0 0x10007000 0 0x100>; }; + timer: timer@10008000 { + compatible = "mediatek,mt8173-timer", + "mediatek,mt6577-timer"; + reg = <0 0x10008000 0 0x1000>; + interrupts = <GIC_SPI 144 IRQ_TYPE_LEVEL_LOW>; + clocks = <&infracfg CLK_INFRA_CLK_13M>, + <&topckgen CLK_TOP_RTC_SEL>; + }; + pwrap: pwrap@1000d000 { compatible = "mediatek,mt8173-pwrap"; reg = <0 0x1000d000 0 0x1000>; -- 1.9.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-09-16 2:04 ` [PATCH 2/2] arm64: dts: mt8173: add timer node Yingjoe Chen @ 2015-09-17 13:51 ` Sudeep Holla [not found] ` <55FAC570.8040307-5wv7dgnIgG8@public.gmane.org> 0 siblings, 1 reply; 12+ messages in thread From: Sudeep Holla @ 2015-09-17 13:51 UTC (permalink / raw) To: Yingjoe Chen, Matthias Brugger Cc: Sudeep Holla, Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree@vger.kernel.org, Arnd Bergmann, Catalin Marinas, linux-kernel@vger.kernel.org, Rob Herring, linux-mediatek@lists.infradead.org, Sascha Hauer, Olof Johansson, srv_heupstream@mediatek.com, linux-arm-kernel@lists.infradead.org, Daniel Kurtz, linux-clk@vger.kernel.org, Eddie Huang <eddie.huan> On 16/09/15 03:04, Yingjoe Chen wrote: > From: Daniel Kurtz <djkurtz@chromium.org> > > Add device node to enable GPT timer. This timer will be > used as sched clock source. > Interesting any known issues with or advantage over the arch timers to prefer it as sched clock source. I see even arch timers are present in DT, hence the question. Or is it just a incorrect commit log ? How does this get selected as sched clock source ? I don't see sched_clock_register in mtk_timer.c To be clear, I am not against adding this timer support, but just want to know is it preferred for sched clock source ? if yes why ? better resolution ? > Change-Id: Idc4e3f0ee80b5c36cae6f0f2328f94aafcca1253 ^ Should be dropped > Signed-off-by: Daniel Kurtz <djkurtz@chromium.org> > Signed-off-by: Eddie Huang <eddie.huang@mediatek.com> > Signed-off-by: Yingjoe Chen <yingjoe.chen@mediatek.com> > --- > arch/arm64/boot/dts/mediatek/mt8173.dtsi | 9 +++++++++ > 1 file changed, 9 insertions(+) > > diff --git a/arch/arm64/boot/dts/mediatek/mt8173.dtsi b/arch/arm64/boot/dts/mediatek/mt8173.dtsi > index d18ee42..d763803 100644 > --- a/arch/arm64/boot/dts/mediatek/mt8173.dtsi > +++ b/arch/arm64/boot/dts/mediatek/mt8173.dtsi > @@ -238,6 +238,15 @@ > reg = <0 0x10007000 0 0x100>; > }; > > + timer: timer@10008000 { > + compatible = "mediatek,mt8173-timer", Missing documentation ? I am referring upstream and it might be in some patches already queued perhaps ? Regards, Sudeep ^ permalink raw reply [flat|nested] 12+ messages in thread
[parent not found: <55FAC570.8040307-5wv7dgnIgG8@public.gmane.org>]
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node [not found] ` <55FAC570.8040307-5wv7dgnIgG8@public.gmane.org> @ 2015-09-17 14:56 ` Yingjoe Chen 2015-09-17 16:13 ` Sudeep Holla 2015-09-17 16:41 ` Mark Rutland 0 siblings, 2 replies; 12+ messages in thread From: Yingjoe Chen @ 2015-09-17 14:56 UTC (permalink / raw) To: Sudeep Holla Cc: Matthias Brugger, Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Arnd Bergmann, Catalin Marinas, linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Rob Herring, linux-mediatek-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org, Sascha Hauer, Olof Johansson, srv_heupstream-NuS5LvNUpcJWk0Htik3J/w@public.gmane.org, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org, Daniel Kurtz, linux-clk-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Thu, 2015-09-17 at 14:51 +0100, Sudeep Holla wrote: > > On 16/09/15 03:04, Yingjoe Chen wrote: > > From: Daniel Kurtz <djkurtz-F7+t8E8rja9g9hUCZPvPmw@public.gmane.org> > > > > Add device node to enable GPT timer. This timer will be > > used as sched clock source. > > > > Interesting any known issues with or advantage over the arch timers > to prefer it as sched clock source. I see even arch timers are present > in DT, hence the question. Or is it just a incorrect commit log ? > > How does this get selected as sched clock source ? I don't see > sched_clock_register in mtk_timer.c > > To be clear, I am not against adding this timer support, but just want > to know is it preferred for sched clock source ? if yes why ? better > resolution ? Hi Sudeep, Thanks for your review. I hit the send too soon and missed cover letter, please see: http://lists.infradead.org/pipermail/linux-mediatek/2015-September/002303.html The main reason to use GPT as sched clock is it won't stop during idle. > > Change-Id: Idc4e3f0ee80b5c36cae6f0f2328f94aafcca1253 > > ^ Should be dropped > > > Signed-off-by: Daniel Kurtz <djkurtz-F7+t8E8rja9g9hUCZPvPmw@public.gmane.org> > > Signed-off-by: Eddie Huang <eddie.huang-NuS5LvNUpcJWk0Htik3J/w@public.gmane.org> > > Signed-off-by: Yingjoe Chen <yingjoe.chen-NuS5LvNUpcJWk0Htik3J/w@public.gmane.org> > > --- > > arch/arm64/boot/dts/mediatek/mt8173.dtsi | 9 +++++++++ > > 1 file changed, 9 insertions(+) > > > > diff --git a/arch/arm64/boot/dts/mediatek/mt8173.dtsi b/arch/arm64/boot/dts/mediatek/mt8173.dtsi > > index d18ee42..d763803 100644 > > --- a/arch/arm64/boot/dts/mediatek/mt8173.dtsi > > +++ b/arch/arm64/boot/dts/mediatek/mt8173.dtsi > > @@ -238,6 +238,15 @@ > > reg = <0 0x10007000 0 0x100>; > > }; > > > > + timer: timer@10008000 { > > + compatible = "mediatek,mt8173-timer", > > Missing documentation ? I am referring upstream and it might be in some > patches already queued perhaps ? This is documented in Documentation/devicetree/bindings/timer/mediatek,mtk-timer.txt. Do you mean I should add "mediatek,mt8173-timer" to that file? Joe.C -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-09-17 14:56 ` Yingjoe Chen @ 2015-09-17 16:13 ` Sudeep Holla 2015-10-01 14:33 ` Yingjoe Chen 2015-09-17 16:41 ` Mark Rutland 1 sibling, 1 reply; 12+ messages in thread From: Sudeep Holla @ 2015-09-17 16:13 UTC (permalink / raw) To: Yingjoe Chen Cc: Sudeep Holla, Matthias Brugger, Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree@vger.kernel.org, Arnd Bergmann, Catalin Marinas, linux-kernel@vger.kernel.org, Rob Herring, linux-mediatek@lists.infradead.org, Sascha Hauer, Olof Johansson, srv_heupstream@mediatek.com, linux-arm-kernel@lists.infradead.org, Daniel Kurtz, "linux-clk@vger.kernel.org" <linux-cl> On 17/09/15 15:56, Yingjoe Chen wrote: > On Thu, 2015-09-17 at 14:51 +0100, Sudeep Holla wrote: >> >> On 16/09/15 03:04, Yingjoe Chen wrote: >>> From: Daniel Kurtz <djkurtz@chromium.org> >>> >>> Add device node to enable GPT timer. This timer will be >>> used as sched clock source. >>> >> >> Interesting any known issues with or advantage over the arch timers >> to prefer it as sched clock source. I see even arch timers are present >> in DT, hence the question. Or is it just a incorrect commit log ? >> >> How does this get selected as sched clock source ? I don't see >> sched_clock_register in mtk_timer.c >> >> To be clear, I am not against adding this timer support, but just want >> to know is it preferred for sched clock source ? if yes why ? better >> resolution ? > > Hi Sudeep, > > Thanks for your review. > > I hit the send too soon and missed cover letter, please see: > http://lists.infradead.org/pipermail/linux-mediatek/2015-September/002303.html > OK > The main reason to use GPT as sched clock is it won't stop during idle. > > I think your are confusing the system counter with arch timers. System counter is always-on, but the arch timers(logic implementing timers comparators) might not be off when the processor is powered down. I think you need this timer and are using it for low power idle states in which case you will use this as a clock event and not clock source. It will be used as a hardware broadcast event source. There's no call to sched_clock_register in mtk_timer.c, so it can't be the sched clock, so you need to fix the commit log. [...] >>> diff --git a/arch/arm64/boot/dts/mediatek/mt8173.dtsi b/arch/arm64/boot/dts/mediatek/mt8173.dtsi >>> index d18ee42..d763803 100644 >>> --- a/arch/arm64/boot/dts/mediatek/mt8173.dtsi >>> +++ b/arch/arm64/boot/dts/mediatek/mt8173.dtsi >>> @@ -238,6 +238,15 @@ >>> reg = <0 0x10007000 0 0x100>; >>> }; >>> >>> + timer: timer@10008000 { >>> + compatible = "mediatek,mt8173-timer", >> >> Missing documentation ? I am referring upstream and it might be in some >> patches already queued perhaps ? > > This is documented in > Documentation/devicetree/bindings/timer/mediatek,mtk-timer.txt. > Do you mean I should add "mediatek,mt8173-timer" to that file? > Yes Regards, Sudeep ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-09-17 16:13 ` Sudeep Holla @ 2015-10-01 14:33 ` Yingjoe Chen 2015-10-01 15:32 ` Sudeep Holla 0 siblings, 1 reply; 12+ messages in thread From: Yingjoe Chen @ 2015-10-01 14:33 UTC (permalink / raw) To: Sudeep Holla Cc: Matthias Brugger, Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree@vger.kernel.org, Arnd Bergmann, Catalin Marinas, linux-kernel@vger.kernel.org, Rob Herring, linux-mediatek@lists.infradead.org, Sascha Hauer, Olof Johansson, srv_heupstream@mediatek.com, linux-arm-kernel@lists.infradead.org, Daniel Kurtz, linux-clk@vger.kernel.org On Thu, 2015-09-17 at 17:13 +0100, Sudeep Holla wrote: > > On 17/09/15 15:56, Yingjoe Chen wrote: > > On Thu, 2015-09-17 at 14:51 +0100, Sudeep Holla wrote: > >> > >> On 16/09/15 03:04, Yingjoe Chen wrote: > >>> From: Daniel Kurtz <djkurtz@chromium.org> > >>> > >>> Add device node to enable GPT timer. This timer will be > >>> used as sched clock source. > >>> > >> > >> Interesting any known issues with or advantage over the arch timers > >> to prefer it as sched clock source. I see even arch timers are present > >> in DT, hence the question. Or is it just a incorrect commit log ? > >> > >> How does this get selected as sched clock source ? I don't see > >> sched_clock_register in mtk_timer.c > >> > >> To be clear, I am not against adding this timer support, but just want > >> to know is it preferred for sched clock source ? if yes why ? better > >> resolution ? > > > > Hi Sudeep, > > > > Thanks for your review. > > > > I hit the send too soon and missed cover letter, please see: > > http://lists.infradead.org/pipermail/linux-mediatek/2015-September/002303.html > > > > OK > > > The main reason to use GPT as sched clock is it won't stop during idle. > > > > > > I think your are confusing the system counter with arch timers. System > counter is always-on, but the arch timers(logic implementing timers > comparators) might not be off when the processor is powered down. > > I think you need this timer and are using it for low power idle states > in which case you will use this as a clock event and not clock source. > It will be used as a hardware broadcast event source. > > There's no call to sched_clock_register in mtk_timer.c, so it can't be > the sched clock, so you need to fix the commit log. Hi Sudeep, Sorry for late reply. For sched_clock_register, please see http://lists.infradead.org/pipermail/linux-mediatek/2015-July/001547.html which was accepted in https://git.linaro.org/people/daniel.lezcano/linux.git/shortlog/refs/heads/clockevents/4.4 You are right it is also used as clock event. I think we don't need to mention those detail in commit message, so I'll change to just: "Add device node to enable GPT timer." > > [...] > > >>> diff --git a/arch/arm64/boot/dts/mediatek/mt8173.dtsi b/arch/arm64/boot/dts/mediatek/mt8173.dtsi > >>> index d18ee42..d763803 100644 > >>> --- a/arch/arm64/boot/dts/mediatek/mt8173.dtsi > >>> +++ b/arch/arm64/boot/dts/mediatek/mt8173.dtsi > >>> @@ -238,6 +238,15 @@ > >>> reg = <0 0x10007000 0 0x100>; > >>> }; > >>> > >>> + timer: timer@10008000 { > >>> + compatible = "mediatek,mt8173-timer", > >> > >> Missing documentation ? I am referring upstream and it might be in some > >> patches already queued perhaps ? > > > > This is documented in > > Documentation/devicetree/bindings/timer/mediatek,mtk-timer.txt. > > Do you mean I should add "mediatek,mt8173-timer" to that file? > > > > Yes Will do in next round. Thanks Joe.C ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-10-01 14:33 ` Yingjoe Chen @ 2015-10-01 15:32 ` Sudeep Holla 2015-10-02 14:00 ` Yingjoe Chen 0 siblings, 1 reply; 12+ messages in thread From: Sudeep Holla @ 2015-10-01 15:32 UTC (permalink / raw) To: Yingjoe Chen Cc: Sudeep Holla, Matthias Brugger, Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Arnd Bergmann, Catalin Marinas, linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Rob Herring, linux-mediatek-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org, Sascha Hauer, Olof Johansson, srv_heupstream-NuS5LvNUpcJWk0Htik3J/w@public.gmane.org, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org, Daniel Kurtz, "linux-clk-u79uwXL29TY76Z2rM5mHXA@public.gmane.org" <linux-cl> On 01/10/15 15:33, Yingjoe Chen wrote: > On Thu, 2015-09-17 at 17:13 +0100, Sudeep Holla wrote: >> [...] >> >> I think your are confusing the system counter with arch timers. System >> counter is always-on, but the arch timers(logic implementing timers >> comparators) might not be off when the processor is powered down. >> >> I think you need this timer and are using it for low power idle states >> in which case you will use this as a clock event and not clock source. >> It will be used as a hardware broadcast event source. >> >> There's no call to sched_clock_register in mtk_timer.c, so it can't be >> the sched clock, so you need to fix the commit log. > > Hi Sudeep, > > Sorry for late reply. > > For sched_clock_register, please see > http://lists.infradead.org/pipermail/linux-mediatek/2015-July/001547.html > which was accepted in > https://git.linaro.org/people/daniel.lezcano/linux.git/shortlog/refs/heads/clockevents/4.4 > The commit message makes no sense to me. The counters should continue to work as long as they are in always-on domain. Only timers are lost when you enter deeper idle states. So I agree with using MTK timer as broadcast timer/eventsource. You still didn't answer what's the need to use MTK timer as sched clocksource ? Regards, Sudeep -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-10-01 15:32 ` Sudeep Holla @ 2015-10-02 14:00 ` Yingjoe Chen 0 siblings, 0 replies; 12+ messages in thread From: Yingjoe Chen @ 2015-10-02 14:00 UTC (permalink / raw) To: Sudeep Holla Cc: Matthias Brugger, Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree@vger.kernel.org, Arnd Bergmann, Catalin Marinas, linux-kernel@vger.kernel.org, Rob Herring, linux-mediatek@lists.infradead.org, Sascha Hauer, Olof Johansson, srv_heupstream@mediatek.com, linux-arm-kernel@lists.infradead.org, Daniel Kurtz, linux-clk@vger.kernel.org On Thu, 2015-10-01 at 16:32 +0100, Sudeep Holla wrote: > > On 01/10/15 15:33, Yingjoe Chen wrote: > > On Thu, 2015-09-17 at 17:13 +0100, Sudeep Holla wrote: > >> > > [...] > > >> > >> I think your are confusing the system counter with arch timers. System > >> counter is always-on, but the arch timers(logic implementing timers > >> comparators) might not be off when the processor is powered down. > >> > >> I think you need this timer and are using it for low power idle states > >> in which case you will use this as a clock event and not clock source. > >> It will be used as a hardware broadcast event source. > >> > >> There's no call to sched_clock_register in mtk_timer.c, so it can't be > >> the sched clock, so you need to fix the commit log. > > > > Hi Sudeep, > > > > Sorry for late reply. > > > > For sched_clock_register, please see > > http://lists.infradead.org/pipermail/linux-mediatek/2015-July/001547.html > > which was accepted in > > https://git.linaro.org/people/daniel.lezcano/linux.git/shortlog/refs/heads/clockevents/4.4 > > > > The commit message makes no sense to me. The counters should continue to > work as long as they are in always-on domain. Only timers are lost > when you enter deeper idle states. So I agree with using MTK timer as > broadcast timer/eventsource. You still didn't answer what's the need > to use MTK timer as sched clocksource ? Hi, Sudeep, ARM ARM said the counter should be in always-on domain, but unfortunately that not true for mt8173. The last CPU enter idle can choose to enter deep idle mode and the counter value would be lost. Our firmware backup/recover the counter so it looks like it is stopped. That's why I thought we need to use it as sched clocksource. On mt8173, we will fix the firmware to add missing counts, so it will looks like the counter keep counting. But other mediatek platform have similar issue, and the 2 counter have same resolution, so I still want to keep using GPT as sched clocksource. Joe.C ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-09-17 14:56 ` Yingjoe Chen 2015-09-17 16:13 ` Sudeep Holla @ 2015-09-17 16:41 ` Mark Rutland 2015-10-01 14:50 ` Yingjoe Chen 1 sibling, 1 reply; 12+ messages in thread From: Mark Rutland @ 2015-09-17 16:41 UTC (permalink / raw) To: Yingjoe Chen Cc: Sudeep Holla, James Liao, srv_heupstream@mediatek.com, Arnd Bergmann, devicetree@vger.kernel.org, Catalin Marinas, Michael Turquette, Daniel Lezcano, Stephen Boyd, linux-kernel@vger.kernel.org, Daniel Kurtz, Olof Johansson, Rob Herring, linux-mediatek@lists.infradead.org, Sascha Hauer, Matthias Brugger, Thomas Gleixner, Eddie Huang, linux-clk@vger.kernel.org, linux-arm-kernel On Thu, Sep 17, 2015 at 03:56:56PM +0100, Yingjoe Chen wrote: > On Thu, 2015-09-17 at 14:51 +0100, Sudeep Holla wrote: > > > > On 16/09/15 03:04, Yingjoe Chen wrote: > > > From: Daniel Kurtz <djkurtz@chromium.org> > > > > > > Add device node to enable GPT timer. This timer will be > > > used as sched clock source. > > > > > > > Interesting any known issues with or advantage over the arch timers > > to prefer it as sched clock source. I see even arch timers are present > > in DT, hence the question. Or is it just a incorrect commit log ? > > > > How does this get selected as sched clock source ? I don't see > > sched_clock_register in mtk_timer.c > > > > To be clear, I am not against adding this timer support, but just want > > to know is it preferred for sched clock source ? if yes why ? better > > resolution ? > > Hi Sudeep, > > Thanks for your review. > > I hit the send too soon and missed cover letter, please see: > http://lists.infradead.org/pipermail/linux-mediatek/2015-September/002303.html > > The main reason to use GPT as sched clock is it won't stop during idle. You don't mean sched clock, you just mean a clock_event_device. A sched_clock is a high-precision clocksource that is read from (which by definition requires the CPUs to be non-idle). It doesn't have anything to do with interrupts and therefore cannot wake devices from idle. While the clock_event_device for the generic timer can't necessarily wake CPUs from idle. The generic timer system counter counts even if CPUs are idle, so the generic timer is fine as a sched_clock. Thanks, Mark. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/2] arm64: dts: mt8173: add timer node 2015-09-17 16:41 ` Mark Rutland @ 2015-10-01 14:50 ` Yingjoe Chen 0 siblings, 0 replies; 12+ messages in thread From: Yingjoe Chen @ 2015-10-01 14:50 UTC (permalink / raw) To: Mark Rutland Cc: Sudeep Holla, James Liao, srv_heupstream@mediatek.com, Arnd Bergmann, devicetree@vger.kernel.org, Catalin Marinas, Michael Turquette, Daniel Lezcano, Stephen Boyd, linux-kernel@vger.kernel.org, Daniel Kurtz, Olof Johansson, Rob Herring, linux-mediatek@lists.infradead.org, Sascha Hauer, Matthias Brugger, Thomas Gleixner, Eddie Huang, linux-clk@vger.kernel.org, linux-arm-kernel@ On Thu, 2015-09-17 at 17:41 +0100, Mark Rutland wrote: > On Thu, Sep 17, 2015 at 03:56:56PM +0100, Yingjoe Chen wrote: > > On Thu, 2015-09-17 at 14:51 +0100, Sudeep Holla wrote: > > > > > > On 16/09/15 03:04, Yingjoe Chen wrote: > > > > From: Daniel Kurtz <djkurtz@chromium.org> > > > > > > > > Add device node to enable GPT timer. This timer will be > > > > used as sched clock source. > > > > > > > > > > Interesting any known issues with or advantage over the arch timers > > > to prefer it as sched clock source. I see even arch timers are present > > > in DT, hence the question. Or is it just a incorrect commit log ? > > > > > > How does this get selected as sched clock source ? I don't see > > > sched_clock_register in mtk_timer.c > > > > > > To be clear, I am not against adding this timer support, but just want > > > to know is it preferred for sched clock source ? if yes why ? better > > > resolution ? > > > > Hi Sudeep, > > > > Thanks for your review. > > > > I hit the send too soon and missed cover letter, please see: > > http://lists.infradead.org/pipermail/linux-mediatek/2015-September/002303.html > > > > The main reason to use GPT as sched clock is it won't stop during idle. > > You don't mean sched clock, you just mean a clock_event_device. > > A sched_clock is a high-precision clocksource that is read from (which > by definition requires the CPUs to be non-idle). It doesn't have > anything to do with interrupts and therefore cannot wake devices from > idle. > > While the clock_event_device for the generic timer can't necessarily > wake CPUs from idle. The generic timer system counter counts even if > CPUs are idle, so the generic timer is fine as a sched_clock. Hi, Mark, Thanks for your info and sorry for late reply. I notice ARM ARM said the arch timer shouldn't stop when idle, but unfortunately that not true for mt8173. The last CPU enter idle can choose to enter deep idle mode and the counter value would be lost. Our firmware backup/recover the counter so it looks like it is stopped. We will change the firmware to add missing count when back from deep idle to make it looks like the counter never stop. Joe.C ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 1/2] arm64: mediatek: enable MTK_TIMER 2015-09-16 2:04 [PATCH 1/2] arm64: mediatek: enable MTK_TIMER Yingjoe Chen 2015-09-16 2:04 ` [PATCH 2/2] arm64: dts: mt8173: add timer node Yingjoe Chen @ 2015-09-16 2:21 ` Yingjoe Chen 2015-09-27 14:00 ` Matthias Brugger 1 sibling, 1 reply; 12+ messages in thread From: Yingjoe Chen @ 2015-09-16 2:21 UTC (permalink / raw) To: Matthias Brugger Cc: Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree, Arnd Bergmann, Catalin Marinas, linux-kernel, Rob Herring, linux-mediatek, Sascha Hauer, Olof Johansson, srv_heupstream, linux-arm-kernel, Daniel Kurtz, linux-clk On Wed, 2015-09-16 at 10:04 +0800, Yingjoe Chen wrote: > Enable MTK_TIMER for MediaTek plaform, which will be used as > schedule clock. Sorry, sending this series too early without cover letter and removing Change-Id. Here's the cover letter: This is actually v3 of "add GPT timer support for mt8173" series. This is based on v4.3-rc1 + clockevents-4.4[1] and James's mediatek-clk tree[2]. Changes compare to previous version[3]: - the first two mtk_timer related changes are removed because they are replaced/accepted in clockevents tree. - Remove 'add 13mhz clock for MT8173' because it is accepted in mediatek-clk tree. - Kconfig.platforms path change. So we only have 2 patches left here. Matthias, can you take these and help to remove the Change-Id? Daniel Kurtz (1): arm64: dts: mt8173: add timer node Yingjoe Chen (1): arm64: mediatek: enable MTK_TIMER [1] https://git.linaro.org/people/daniel.lezcano/linux.git clockevents/4.4 [2] http://lists.infradead.org/pipermail/linux-mediatek/2015-August/002069.html [3] http://lists.infradead.org/pipermail/linux-mediatek/2015-July/001544.html ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 1/2] arm64: mediatek: enable MTK_TIMER 2015-09-16 2:21 ` [PATCH 1/2] arm64: mediatek: enable MTK_TIMER Yingjoe Chen @ 2015-09-27 14:00 ` Matthias Brugger 0 siblings, 0 replies; 12+ messages in thread From: Matthias Brugger @ 2015-09-27 14:00 UTC (permalink / raw) To: Yingjoe Chen Cc: Daniel Lezcano, Thomas Gleixner, Stephen Boyd, Michael Turquette, James Liao, devicetree, Arnd Bergmann, Catalin Marinas, linux-kernel, Rob Herring, linux-mediatek, Sascha Hauer, Olof Johansson, srv_heupstream, linux-arm-kernel, Daniel Kurtz, linux-clk On 16/09/15 04:21, Yingjoe Chen wrote: > On Wed, 2015-09-16 at 10:04 +0800, Yingjoe Chen wrote: >> Enable MTK_TIMER for MediaTek plaform, which will be used as >> schedule clock. > > Sorry, sending this series too early without cover letter and removing > Change-Id. Here's the cover letter: > > > This is actually v3 of "add GPT timer support for mt8173" series. This > is based on v4.3-rc1 + clockevents-4.4[1] and James's mediatek-clk > tree[2]. > > Changes compare to previous version[3]: > - the first two mtk_timer related changes are removed because they are > replaced/accepted in clockevents tree. > - Remove 'add 13mhz clock for MT8173' because it is accepted in > mediatek-clk tree. > - Kconfig.platforms path change. > > So we only have 2 patches left here. > Matthias, can you take these and help to remove the Change-Id? Yes I can take this two patches, but I don't see the mediatek-clk tree accepted by the maintainers yet. As far as I can see, without the 13 MHz clock [1], the sched clock won't work. [1] https://github.com/jamesjjliao/linux/commit/add5e89d657fa6c0e5a517890f996c796b768064 > > > Daniel Kurtz (1): > arm64: dts: mt8173: add timer node > > Yingjoe Chen (1): > arm64: mediatek: enable MTK_TIMER > > > > [1] > https://git.linaro.org/people/daniel.lezcano/linux.git clockevents/4.4 > [2] > http://lists.infradead.org/pipermail/linux-mediatek/2015-August/002069.html > [3] > http://lists.infradead.org/pipermail/linux-mediatek/2015-July/001544.html > > > > ^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2015-10-02 14:00 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-09-16  2:04 [PATCH 1/2] arm64: mediatek: enable MTK_TIMER Yingjoe Chen
2015-09-16  2:04 ` [PATCH 2/2] arm64: dts: mt8173: add timer node Yingjoe Chen
2015-09-17 13:51   ` Sudeep Holla
     [not found]     ` <55FAC570.8040307-5wv7dgnIgG8@public.gmane.org>
2015-09-17 14:56       ` Yingjoe Chen
2015-09-17 16:13         ` Sudeep Holla
2015-10-01 14:33           ` Yingjoe Chen
2015-10-01 15:32             ` Sudeep Holla
2015-10-02 14:00               ` Yingjoe Chen
2015-09-17 16:41         ` Mark Rutland
2015-10-01 14:50           ` Yingjoe Chen
2015-09-16  2:21 ` [PATCH 1/2] arm64: mediatek: enable MTK_TIMER Yingjoe Chen
2015-09-27 14:00   ` Matthias Brugger
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).