[U-Boot] [PATCH 1/2] at91: move a/a/c/arm926ejs/at91/clock.c -> a/a/lib/at91

Reinhard Meyer u-boot at emk-elektronik.de
Thu Jun 9 12:23:03 CEST 2011


Dear Andreas Bießmann,
> Dear Reinhard Meyer,
> 
> Am 09.06.2011 11:38, schrieb Reinhard Meyer:
>> Dear Andreas Bießmann,
>>> The at91/clock.c is copied from linux kernel and has support for both
>>> arm920t and arm926ejs core devices. Therefore this patch moves this
>>> generic at91/clock.c to a new place at arch/arm/lib/at91 to be used from
>>> at91 family devices.
>>>
>>> We build a new libat91-common.o to provide the required symbols to both
>>> cpu types.
>>>
>>> Signed-off-by: Andreas Bießmann <andreas.devel at googlemail.com>
>>> ---
>>>  Makefile                             |    3 +
>>>  arch/arm/cpu/arm926ejs/at91/Makefile |    1 -
>>>  arch/arm/cpu/arm926ejs/at91/clock.c  |  215 ----------------------------------
>>>  arch/arm/lib/at91/Makefile           |   45 +++++++
>>>  arch/arm/lib/at91/clock.c            |  215 ++++++++++++++++++++++++++++++++++
>>>  5 files changed, 263 insertions(+), 216 deletions(-)
>>>  delete mode 100644 arch/arm/cpu/arm926ejs/at91/clock.c
>>>  create mode 100644 arch/arm/lib/at91/Makefile
>>>  create mode 100644 arch/arm/lib/at91/clock.c
>>
>> Please use the "git-mv" command to move the file "clock.c".
> 
> I did it that way ... but I think there was another trick for
> git-format-patch ... will have a look for that
> 
>> On any account, we should discuss about opening a subdir lib scheme first.
>> Currently arch/arm/lib does not have any subdirectories.
> 
> Well as described in cover letter this was discussed before. See the
> other discussion on gmane:
> http://mid.gmane.org/BANLkTimn29vmAYGb5csMdCYS-xx6zD_6Zw@mail.gmail.com

Sorry, I had forgotten already about that discussion, it was even
marked "important" in my e-Mail program... and I wanted to comment then
but was too busy with other things ;)

> 
> I think this solution was preferred by Albert too. But I'm open for
> another solution, so lets see what possibilities you have.

What other files do you see (in the future) to be in arch/arm/lib/at91?
For just clock.c, it seems like an overkill... Can we (on the long run)
move _all_ files from the at91 subdirs there, like *_devices.c, reset.c,
timer.c, at91sam9_watchdog.c? Then it would make sense to me...

if YES, ignore the following ideas:
{
When I look at the #ifdef's near the end of clock.c I get an uneasy feeling;)

With more Atmel SoCs coming up which must have additional clock domains
(e.g. with 2x EMAC, CAN, etc) I can imagine this file to become more and
more ugly.

I currently have rough ideas to add to the discussion:

1. move the SoC specific clock stuff into <SoC>_devices.c - even if that
means some duplication (the get_*_clk_rate() functions could possibly be
inlined and put into the header file ?)

2. introduce <SoC>_clock.c (if one does not like the clock stuff in "devices")

3. similar to drivers/watchdog we could have drivers/clock and put
at91sam9_clock.c there. On that account, the hardware specific timer
functions of any new timer scheme could be placed there as well.
}

> 
>> I _do_ see the problems of the current ARM directory structure which makes
>> the ARM core a more important criteria than SoC family especially in the
>> Atmel context where the SoCs have identical peripheral blocks but can have
>> different ARM cores.
> 
> correct

Best Regards,
Reinhard


More information about the U-Boot mailing list