public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* 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