* Trivial clocksource driver
@ 2015-09-29 16:25 Mason
2015-09-29 18:32 ` Thomas Gleixner
0 siblings, 1 reply; 7+ messages in thread
From: Mason @ 2015-09-29 16:25 UTC (permalink / raw)
To: LKML; +Cc: Daniel Lezcano, Thomas Gleixner
Hello everyone,
I am trying to submit a new ARM port, and Arnd pointed out that the
clocksource code could not live in arch/arm/$PLATFORM, but had to
move to drivers/clocksource (and it had to support DT).
Did I understand correctly? Is this the right place to submit code
as provided below?
Regards.
#include <linux/delay.h> /* register_current_timer_delay */
#include <linux/clocksource.h> /* clocksource_register_hz */
#include <linux/sched_clock.h> /* sched_clock_register */
#include <linux/of_address.h> /* of_iomap */
#include <linux/clk.h> /* of_clk_get, clk_get_rate */
static void __iomem *xtal_in_cnt;
static struct delay_timer delay_timer;
static unsigned long read_xtal_counter(void)
{
return readl_relaxed(xtal_in_cnt);
}
static u64 read_sched_clock(void)
{
return read_xtal_counter();
}
static cycle_t read_clocksource(struct clocksource *cs)
{
return read_xtal_counter();
}
static struct clocksource tango_xtal = {
.name = "tango-xtal",
.rating = 350,
.read = read_clocksource,
.mask = CLOCKSOURCE_MASK(32),
.flags = CLOCK_SOURCE_IS_CONTINUOUS,
};
static void __init tango_clksrc_init(struct device_node *np)
{
struct clk *clk = of_clk_get(np, 0);
unsigned int xtal_freq = clk_get_rate(clk);
xtal_in_cnt = of_iomap(np, 0);
delay_timer.freq = xtal_freq;
delay_timer.read_current_timer = read_xtal_counter;
register_current_timer_delay(&delay_timer);
sched_clock_register(read_sched_clock, 32, xtal_freq);
clocksource_register_hz(&tango_xtal, xtal_freq);
}
CLOCKSOURCE_OF_DECLARE(tango, "sigma,xtal_in_cnt", tango_clksrc_init);
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: Trivial clocksource driver
2015-09-29 16:25 Trivial clocksource driver Mason
@ 2015-09-29 18:32 ` Thomas Gleixner
2015-09-29 19:49 ` Mason
0 siblings, 1 reply; 7+ messages in thread
From: Thomas Gleixner @ 2015-09-29 18:32 UTC (permalink / raw)
To: Mason; +Cc: LKML, Daniel Lezcano
On Tue, 29 Sep 2015, Mason wrote:
> Hello everyone,
>
> I am trying to submit a new ARM port, and Arnd pointed out that the
> clocksource code could not live in arch/arm/$PLATFORM, but had to
> move to drivers/clocksource (and it had to support DT).
>
> Did I understand correctly? Is this the right place to submit code
> as provided below?
Yes, drivers/clocksource is the right place. You just need to submit a
formal patch, which includes a proper subject line, changelog, plus
the necessary Makefile and Kconfig modifications.
> #include <linux/delay.h> /* register_current_timer_delay */
Please get rid of these silly tail comments. They provide absolutely
no value.
Other than that this looks reasonable.
Thanks,
tglx
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: Trivial clocksource driver
2015-09-29 18:32 ` Thomas Gleixner
@ 2015-09-29 19:49 ` Mason
2015-09-29 20:18 ` Måns Rullgård
0 siblings, 1 reply; 7+ messages in thread
From: Mason @ 2015-09-29 19:49 UTC (permalink / raw)
To: Thomas Gleixner; +Cc: LKML, Daniel Lezcano
On 29/09/2015 20:32, Thomas Gleixner wrote:
> On Tue, 29 Sep 2015, Mason wrote:
>
>> I am trying to submit a new ARM port, and Arnd pointed out that the
>> clocksource code could not live in arch/arm/$PLATFORM, but had to
>> move to drivers/clocksource (and it had to support DT).
>>
>> Did I understand correctly? Is this the right place to submit code
>> as provided below?
>
> Yes, drivers/clocksource is the right place. You just need to submit a
> formal patch, which includes a proper subject line, changelog, plus
> the necessary Makefile and Kconfig modifications.
OK, I'll send a formal patch tomorrow.
There are no Kconfig modifications, is that OK?
Also, that patch is part of a larger patch-set (most of the
patches intended for arch/arm). I should send you only the
clocksource patch, or the whole patch-set?
>> #include <linux/delay.h> /* register_current_timer_delay */
>
> Please get rid of these silly tail comments. They provide absolutely
> no value.
I will remove them, since you asked.
In my opinion, they serve one purpose: if code is refactored,
and the function call is removed, the comment is a reminder
to also remove the relevant include directive.
Do you disagree?
> Other than that this looks reasonable.
Just wanted to ask:
Can register_current_timer_delay, sched_clock_register, and
clocksource_register_hz be called in any order?
Regards.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: Trivial clocksource driver
2015-09-29 19:49 ` Mason
@ 2015-09-29 20:18 ` Måns Rullgård
2015-09-29 20:49 ` Thomas Gleixner
2015-09-29 21:12 ` Mason
0 siblings, 2 replies; 7+ messages in thread
From: Måns Rullgård @ 2015-09-29 20:18 UTC (permalink / raw)
To: Mason; +Cc: Thomas Gleixner, LKML, Daniel Lezcano
Mason <slash.tmp@free.fr> writes:
> On 29/09/2015 20:32, Thomas Gleixner wrote:
>
>> On Tue, 29 Sep 2015, Mason wrote:
>>
>>> I am trying to submit a new ARM port, and Arnd pointed out that the
>>> clocksource code could not live in arch/arm/$PLATFORM, but had to
>>> move to drivers/clocksource (and it had to support DT).
>>>
>>> Did I understand correctly? Is this the right place to submit code
>>> as provided below?
>>
>> Yes, drivers/clocksource is the right place. You just need to submit a
>> formal patch, which includes a proper subject line, changelog, plus
>> the necessary Makefile and Kconfig modifications.
>
> OK, I'll send a formal patch tomorrow.
> There are no Kconfig modifications, is that OK?
Why don't you use my driver? It's even simpler, and it works just fine
on the 87xx chip.
https://github.com/mansr/linux-tangox/blob/master/drivers/clocksource/clksrc-tangox.c
--
Måns Rullgård
mans@mansr.com
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: Trivial clocksource driver
2015-09-29 20:18 ` Måns Rullgård
@ 2015-09-29 20:49 ` Thomas Gleixner
2015-09-29 21:12 ` Mason
1 sibling, 0 replies; 7+ messages in thread
From: Thomas Gleixner @ 2015-09-29 20:49 UTC (permalink / raw)
To: Måns Rullgård; +Cc: Mason, LKML, Daniel Lezcano
[-- Attachment #1: Type: TEXT/PLAIN, Size: 1055 bytes --]
On Tue, 29 Sep 2015, Måns Rullgård wrote:
> Mason <slash.tmp@free.fr> writes:
>
> > On 29/09/2015 20:32, Thomas Gleixner wrote:
> >
> >> On Tue, 29 Sep 2015, Mason wrote:
> >>
> >>> I am trying to submit a new ARM port, and Arnd pointed out that the
> >>> clocksource code could not live in arch/arm/$PLATFORM, but had to
> >>> move to drivers/clocksource (and it had to support DT).
> >>>
> >>> Did I understand correctly? Is this the right place to submit code
> >>> as provided below?
> >>
> >> Yes, drivers/clocksource is the right place. You just need to submit a
> >> formal patch, which includes a proper subject line, changelog, plus
> >> the necessary Makefile and Kconfig modifications.
> >
> > OK, I'll send a formal patch tomorrow.
> > There are no Kconfig modifications, is that OK?
>
> Why don't you use my driver? It's even simpler, and it works just fine
> on the 87xx chip.
>
> https://github.com/mansr/linux-tangox/blob/master/drivers/clocksource/clksrc-tangox.c
Perhaps because that driver is not upstream either?
Thanks,
tglx
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: Trivial clocksource driver
2015-09-29 20:18 ` Måns Rullgård
2015-09-29 20:49 ` Thomas Gleixner
@ 2015-09-29 21:12 ` Mason
2015-09-29 21:55 ` Måns Rullgård
1 sibling, 1 reply; 7+ messages in thread
From: Mason @ 2015-09-29 21:12 UTC (permalink / raw)
To: Mans Rullgard; +Cc: Thomas Gleixner, LKML, Daniel Lezcano
Hello Mans,
On 29/09/2015 22:18, Måns Rullgård wrote:
> Mason writes:
>
>> On 29/09/2015 20:32, Thomas Gleixner wrote:
>>
>>> On Tue, 29 Sep 2015, Mason wrote:
>>>
>>>> I am trying to submit a new ARM port, and Arnd pointed out that the
>>>> clocksource code could not live in arch/arm/$PLATFORM, but had to
>>>> move to drivers/clocksource (and it had to support DT).
>>>>
>>>> Did I understand correctly? Is this the right place to submit code
>>>> as provided below?
>>>
>>> Yes, drivers/clocksource is the right place. You just need to submit a
>>> formal patch, which includes a proper subject line, changelog, plus
>>> the necessary Makefile and Kconfig modifications.
>>
>> OK, I'll send a formal patch tomorrow.
>> There are no Kconfig modifications, is that OK?
>
> Why don't you use my driver? It's even simpler, and it works just fine
> on the 87xx chip.
>
> https://github.com/mansr/linux-tangox/blob/master/drivers/clocksource/clksrc-tangox.c
As you know, I am using two of your complex drivers, namely
ethernet and interrupt controller (which would have taken me
several weeks to write). I will be submitting them upstream
shortly, is that OK with you?
I'm not using this particular driver of yours because I had
already written the code, and porting it to DT was a good
learning process. This is probably my only opportunity to
actually write any kind of code for this port.
Regards.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: Trivial clocksource driver
2015-09-29 21:12 ` Mason
@ 2015-09-29 21:55 ` Måns Rullgård
0 siblings, 0 replies; 7+ messages in thread
From: Måns Rullgård @ 2015-09-29 21:55 UTC (permalink / raw)
To: Mason; +Cc: Thomas Gleixner, LKML, Daniel Lezcano
Mason <slash.tmp@free.fr> writes:
> Hello Mans,
>
> On 29/09/2015 22:18, Måns Rullgård wrote:
>
>> Mason writes:
>>
>>> On 29/09/2015 20:32, Thomas Gleixner wrote:
>>>
>>>> On Tue, 29 Sep 2015, Mason wrote:
>>>>
>>>>> I am trying to submit a new ARM port, and Arnd pointed out that the
>>>>> clocksource code could not live in arch/arm/$PLATFORM, but had to
>>>>> move to drivers/clocksource (and it had to support DT).
>>>>>
>>>>> Did I understand correctly? Is this the right place to submit code
>>>>> as provided below?
>>>>
>>>> Yes, drivers/clocksource is the right place. You just need to submit a
>>>> formal patch, which includes a proper subject line, changelog, plus
>>>> the necessary Makefile and Kconfig modifications.
>>>
>>> OK, I'll send a formal patch tomorrow.
>>> There are no Kconfig modifications, is that OK?
>>
>> Why don't you use my driver? It's even simpler, and it works just fine
>> on the 87xx chip.
>>
>> https://github.com/mansr/linux-tangox/blob/master/drivers/clocksource/clksrc-tangox.c
>
> As you know, I am using two of your complex drivers, namely
> ethernet and interrupt controller (which would have taken me
> several weeks to write). I will be submitting them upstream
> shortly, is that OK with you?
I want to test them a bit more on the 87xx first. It's booting, but
there are a couple of niggles that should be looked into. Getting some
documentation would expedite that process.
> I'm not using this particular driver of yours because I had
> already written the code, and porting it to DT was a good
> learning process. This is probably my only opportunity to
> actually write any kind of code for this port.
You should still be using the existing clocksource_mmio helper. In
fact, that interface could be exposed using a generic DT binding.
--
Måns Rullgård
mans@mansr.com
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2015-09-29 21:55 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-09-29 16:25 Trivial clocksource driver Mason
2015-09-29 18:32 ` Thomas Gleixner
2015-09-29 19:49 ` Mason
2015-09-29 20:18 ` Måns Rullgård
2015-09-29 20:49 ` Thomas Gleixner
2015-09-29 21:12 ` Mason
2015-09-29 21:55 ` Måns Rullgård
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox