[U-Boot] [PATCH 1/2] LPC2468 support
Wolfgang Denk
wd at denx.de
Wed Mar 25 10:47:29 CET 2009
Dear Remco Poelstra,
In message <49C9EB4D.5050503 at duran-audio.com> you wrote:
>
> >> --- u-boot-orig/cpu/arm720t/interrupts.c 2009-03-18 00:42:12.000000000 +0100
> >> +++ u-boot-cleanup/cpu/arm720t/interrupts.c 2009-03-24 11:48:50.000000000 +0100
> >> @@ -29,7 +29,11 @@
> >> #include <common.h>
> >> #include <clps7111.h>
> >> #include <asm/proc-armv/ptrace.h>
> >> +#if defined(CONFIG_LPC2468)
> >> +#include <asm/arch/immap.h>
> >> +#else
> >> #include <asm/hardware.h>
> >> +#endif
> >
> > Is there no way we can do without such a #ifdef here?
>
> The problem is that start.S needs hardware.h, but the code in immap.h
> should not be included in start.S, so I can not merge hardware.h and immap.h
Why not? I'm not aware of such a restriction?
> >> diff -upNr u-boot-orig/cpu/arm720t/start.S u-boot-cleanup/cpu/arm720t/start.S
> >> --- u-boot-orig/cpu/arm720t/start.S 2009-03-18 00:42:12.000000000 +0100
> >> +++ u-boot-cleanup/cpu/arm720t/start.S 2009-03-24 11:52:35.000000000 +0100
> >> @@ -127,7 +127,7 @@ reset:
> >> bl cpu_init_crit
> >> #endif
> >>
> >> -#ifdef CONFIG_LPC2292
> >> +#if defined(CONFIG_LPC2292) || defined(CONFIG_LPC2468)
> >
> > Is there no way to combine this code with the one for the LPC2292?
>
> I'm sorry, it is combined in this case, no?
I would like to avoid the ever growing list of
#if defined(this) || defined(that) || defined(...) || ...
Maybe we can have a common #define that covers the common case?
> >> diff -upNr u-boot-orig/include/asm-arm/arch-lpc24xx/hardware.h u-boot-cleanup/include/asm-arm/arch-lpc24xx/hardware.h
> >> --- u-boot-orig/include/asm-arm/arch-lpc24xx/hardware.h 1970-01-01 01:00:00.000000000 +0100
> >> +++ u-boot-cleanup/include/asm-arm/arch-lpc24xx/hardware.h 2009-03-24 11:54:44.000000000 +0100
> >> @@ -0,0 +1,32 @@
> >> +#ifndef __ASM_ARCH_HARDWARE_H
> >> +#define __ASM_ARCH_HARDWARE_H
> >> +
> >> +/*
...
> >> + */
> >> +
> >> +#if defined(CONFIG_LPC2468)
> >> +#else
> >> +#error No hardware file defined for this configuration
> >> +#endif
> >> +
> >> +#endif /* __ASM_ARCH_HARDWARE_H */
> >
> > Ummm... What exactly is this file needed for?
>
> I don't need it, but start.S wants to include it. See my comment about
> the #ifdef's. Other architectures left it empty too, so it seemed the
> best option to me.
Hm... that doesn't really make sense to me. Also, the error checking
in this file makes little sense to me.
> >> +/* Macros for reading/writing registers */
> >> +#define PUT8(reg, value) (*(volatile unsigned char*)(reg) = (value))
> >> +#define PUT16(reg, value) (*(volatile unsigned short*)(reg) = (value))
> >> +#define PUT32(reg, value) (*(volatile unsigned int*)(reg) = (value))
> >> +#define GET8(reg) (*(volatile unsigned char*)(reg))
> >> +#define GET16(reg) (*(volatile unsigned short*)(reg))
> >> +#define GET32(reg) (*(volatile unsigned int*)(reg))
> >
> > Do you clain these are proper accessor functions for your processor?
>
> Yes I do. They are straight from the LPC2292 code, so once they were
> considered OK. I checked out the the write{s,l,b} functions in asm/io.h,
> but although they look similar, for some reason they simply don't work.
> Given the similarities between the write{s,l,b} and the PUT* functions,
> what is the problem with those? Furthermore, the ARM architecture
> doesn't use any kind of special instructions for accessing registers,
> everything is memory mapped.
I'm not an expert for this processor, but I wonder it there might be
some form of sync instruction (or memory barrier or similar) needed?
Best regards,
Wolfgang Denk
--
DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd at denx.de
Given a choice between two theories, take the one which is funnier.
More information about the U-Boot
mailing list