[U-Boot] [PATCH v2 15/17] SPEAr : Basic spear1300 architecture support added

Vipin KUMAR vipin.kumar at st.com
Mon May 3 13:14:50 CEST 2010


On 5/3/2010 6:03 AM, Tom Rix wrote:
> 
> Expand the commit log to describe this new part.
> Include a URL reference to where it can be reviewed.
> 
OK would be done in patch v3

> Vipin KUMAR wrote:
>> Signed-off-by: Vipin Kumar <vipin.kumar at st.com>
>> ---
>>  arch/arm/cpu/arm_cortexa8/spear13xx/Makefile    |   52 ++++
>>  arch/arm/cpu/arm_cortexa8/spear13xx/cache.S     |  112 ++++++++
>>  arch/arm/cpu/arm_cortexa8/spear13xx/cpu.c       |   99 +++++++
>>  arch/arm/cpu/arm_cortexa8/spear13xx/reset.c     |   47 ++++
>>  arch/arm/cpu/arm_cortexa8/spear13xx/timer.c     |  136 ++++++++++
>>  arch/arm/include/asm/arch-spear13xx/hardware.h  |   40 +++
>>  arch/arm/include/asm/arch-spear13xx/spr_gpt.h   |   85 ++++++
>>  arch/arm/include/asm/arch-spear13xx/spr_misc.h  |  317
>> +++++++++++++++++++++++
>>  arch/arm/include/asm/arch-spear13xx/sys_proto.h |   32 +++
>>  9 files changed, 920 insertions(+), 0 deletions(-)
>>  create mode 100644 arch/arm/cpu/arm_cortexa8/spear13xx/Makefile
>>  create mode 100644 arch/arm/cpu/arm_cortexa8/spear13xx/cache.S
>>  create mode 100644 arch/arm/cpu/arm_cortexa8/spear13xx/cpu.c
>>  create mode 100755 arch/arm/cpu/arm_cortexa8/spear13xx/reset.c
>>  create mode 100644 arch/arm/cpu/arm_cortexa8/spear13xx/timer.c
>>  create mode 100644 arch/arm/include/asm/arch-spear13xx/hardware.h
>>  create mode 100644 arch/arm/include/asm/arch-spear13xx/spr_gpt.h
>>  create mode 100644 arch/arm/include/asm/arch-spear13xx/spr_misc.h
>>  create mode 100644 arch/arm/include/asm/arch-spear13xx/sys_proto.h
>>
>> diff --git a/arch/arm/cpu/arm_cortexa8/spear13xx/Makefile
>> b/arch/arm/cpu/arm_cortexa8/spear13xx/Makefile
>> new file mode 100644
>> index 0000000..4157164
>> --- /dev/null
>> +++ b/arch/arm/cpu/arm_cortexa8/spear13xx/Makefile
>> @@ -0,0 +1,52 @@
>> +#
>> +# (C) Copyright 2000-2003
>> +# Wolfgang Denk, DENX Software Engineering, wd at denx.de.
>> +#
>> +# (C) Copyright 2008
>> +# Guennadi Liakhovetki, DENX Software Engineering, <lg at denx.de>
>> +#
>> +# See file CREDITS for list of people who contributed to this
>> +# project.
>> +#
>> +# This program is free software; you can redistribute it and/or
>> +# modify it under the terms of the GNU General Public License as
>> +# published by the Free Software Foundation; either version 2 of
>> +# the License, or (at your option) any later version.
>> +#
>> +# This program is distributed in the hope that it will be useful,
>> +# but WITHOUT ANY WARRANTY; without even the implied warranty of
>> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
>> +# GNU General Public License for more details.
>> +#
>> +# You should have received a copy of the GNU General Public License
>> +# along with this program; if not, write to the Free Software
>> +# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> +# MA 02111-1307 USA
>> +#
>> +
>> +include $(TOPDIR)/config.mk
>> +
>> +LIB    = $(obj)lib$(SOC).a
>> +
>> +COBJS    += timer.o
>> +COBJS    += reset.o
>> +COBJS    += cpu.o
>> +
>> +SOBJS    = cache.o
>> +
>> +SRCS    := $(SOBJS:.o=.S) $(COBJS:.o=.c)
>> +OBJS    := $(addprefix $(obj),$(COBJS) $(SOBJS))
>> +
>> +all:     $(obj).depend $(LIB)
>> +
>> +$(LIB):    $(OBJS)
>> +    $(AR) $(ARFLAGS) $@ $(OBJS)
>> +
>> +#########################################################################
>>
>> +
>> +# defines $(obj).depend target
>> +include $(SRCTREE)/rules.mk
>> +
>> +sinclude $(obj).depend
>> +
>> +#########################################################################
>>
>> diff --git a/arch/arm/cpu/arm_cortexa8/spear13xx/cache.S
>> b/arch/arm/cpu/arm_cortexa8/spear13xx/cache.S
>> new file mode 100644
>> index 0000000..b3d1fb0
>> --- /dev/null
>> +++ b/arch/arm/cpu/arm_cortexa8/spear13xx/cache.S
>> @@ -0,0 +1,112 @@
>> +/*
>> + * (C) Copyright 2009
>> + * Vipin Kumar, ST Micoelectronics, vipin.kumar at st.com.
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
> 
> This cache.S is extremely similar to  s5pc1xx/cache.S
> And to a lesser degree the omap3/cache.S.
> When a work is based on another work, the original work MUST
> be acknowledged.
> 
> 
Sure. Would be done in v3 patch

Ideally, this is effectively cpu specific code. Cortex-A9 needs data 
cache invalidation before enabling data cache. Ideally, this common code
should be moved to a generic cache.S within arch/arm/cpu/cortexa8/
Please comment more

>> + *
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +.global invalidate_dcache
>> +
>> +/*
>> + *    invalidate_dcache()
>> + *
>> + *    Invalidate the whole D-cache.
>> + *
>> + *    Corrupted registers: r0-r5, r7, r9-r11
>> + *
>> + *    - mm    - mm_struct describing address space
>> + */
>> +invalidate_dcache:
>> +    stmfd    r13!, {r0 - r5, r7, r9 - r12, r14}
>> +
>> +    mrc    p15, 1, r0, c0, c0, 1        @ read clidr
>> +    ands    r3, r0, #0x7000000        @ extract loc from clidr
>> +    mov    r3, r3, lsr #23            @ left align loc bit field
>> +    beq    finished_inval            @ if loc is 0, then no need to
>> +                        @ clean
>> +    mov    r10, #0                @ start clean at cache level 0
>> +inval_loop1:
>> +    add    r2, r10, r10, lsr #1        @ work out 3x current cache
>> +                        @ level
>> +    mov    r1, r0, lsr r2            @ extract cache type bits from
>> +                        @ clidr
>> +    and    r1, r1, #7            @ mask of the bits for current
>> +                        @ cache only
>> +    cmp    r1, #2                @ see what cache we have at
>> +                        @ this level
>> +    blt    skip_inval            @ skip if no cache, or just
>> +                        @ i-cache
>> +    mcr    p15, 2, r10, c0, c0, 0        @ select current cache level
>> +                        @ in cssr
>> +    mov    r2, #0                @ operand for mcr SBZ
>> +    mcr    p15, 0, r2, c7, c5, 4        @ flush prefetch buffer to
>> +                        @ sych the new cssr&csidr,
>> +                        @ with armv7 this is 'isb',
>> +                        @ but we compile with armv5
>> +    mrc    p15, 1, r1, c0, c0, 0        @ read the new csidr
>> +    and    r2, r1, #7            @ extract the length of the
>> +                        @ cache lines
>> +    add    r2, r2, #4            @ add 4 (line length offset)
>> +    ldr    r4, =0x3ff
>> +    ands    r4, r4, r1, lsr #3        @ find maximum number on the
>> +                        @ way size
>> +    clz    r5, r4                @ find bit position of way
>> +                        @ size increment
>> +    ldr    r7, =0x7fff
>> +    ands    r7, r7, r1, lsr #13        @ extract max number of the
>> +                        @ index size
>> +inval_loop2:
>> +    mov    r9, r4                @ create working copy of max
>> +                        @ way size
>> +inval_loop3:
>> +    orr    r11, r10, r9, lsl r5        @ factor way and cache number
>> +                        @ into r11
>> +    orr    r11, r11, r7, lsl r2        @ factor index number into r11
>> +    mcr    p15, 0, r11, c7, c6, 2        @ invalidate by set/way
>> +    subs    r9, r9, #1            @ decrement the way
>> +    bge    inval_loop3
>> +    subs    r7, r7, #1            @ decrement the index
>> +    bge    inval_loop2
>> +skip_inval:
>> +    add    r10, r10, #2            @ increment cache number
>> +    cmp    r3, r10
>> +    bgt    inval_loop1
>> +finished_inval:
>> +    mov    r10, #0                @ swith back to cache level 0
>> +    mcr    p15, 2, r10, c0, c0, 0        @ select current cache level
>> +                        @ in cssr
>> +    mcr    p15, 0, r10, c7, c5, 4        @ flush prefetch buffer,
>> +                        @ with armv7 this is 'isb',
>> +                        @ but we compile with armv5
>> +
>> +    ldmfd    r13!, {r0 - r5, r7, r9 - r12, pc}
>> +
>> +.global l2_cache_enable
>> +/*
>> + * l2_cache_enable
>> + */
>> +l2_cache_enable:
>> +    bx    r14
>> +
>> +.global l2_cache_disable
>> +/*
>> + * l2_cache_disable
>> + */
>> +l2_cache_disable:
>> +    bx    r14
>> diff --git a/arch/arm/cpu/arm_cortexa8/spear13xx/cpu.c
>> b/arch/arm/cpu/arm_cortexa8/spear13xx/cpu.c
>> new file mode 100644
>> index 0000000..5a0ae56
>> --- /dev/null
>> +++ b/arch/arm/cpu/arm_cortexa8/spear13xx/cpu.c
>> @@ -0,0 +1,99 @@
>> +/*
>> + * (C) Copyright 2009
>> + * Vipin Kumar, ST Micoelectronics, vipin.kumar at st.com.
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
>> + *
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#include <common.h>
>> +#include <asm/io.h>
>> +#include <asm/arch/hardware.h>
>> +#include <asm/arch/spr_misc.h>
>> +
>> +u32 get_device_type(void)
>> +{
>> +    return 0;
>> +}
>> +
> 
> This is needed for omap3.
> Remove
> 

Actually, a genric file arch/arm/arm_cortexa8/cpu.c calls a function in
the following way.
invalidate_dcache(get_device_type());
This forces each platform using cpu code for arm_cortexa8 to define
get_device_type(). Should I change the generic file as well ?

>> +#ifdef CONFIG_ARCH_CPU_INIT
>> +int arch_cpu_init(void)
>> +{
>> +    struct misc_regs *const misc_p =
>> +        (struct misc_regs *)CONFIG_SPEAR_MISCBASE;
>> +    u32 perip1_clk_enb, perip2_clk_enb;
>> +#if defined(CONFIG_NAND_FSMC)
>> +    u32 fsmc_cfg;
>> +#endif
>> +    perip1_clk_enb = readl(&misc_p->perip1_clk_enb);
>> +    perip2_clk_enb = readl(&misc_p->perip2_clk_enb);
>> +
>> +    perip1_clk_enb |= GPT1_CLKEN;
>> +
>> +#if defined(CONFIG_PL011_SERIAL)
>> +    perip1_clk_enb |= UART_CLKEN;
>> +#endif
>> +
>> +#if defined(CONFIG_DESIGNWARE_ETH)
>> +    /* writel(SYNT_CLK_ENB | SYNT_FIN_FULL | SYNT_X_1 | SYNT_Y_5,
>> +            &misc_p->gmac_clk_synt); */
> 
> This is dead code
> Remove.
> 

OK

>> +    writel(PHY_IF_GMII | CLK_SEL_OSCI3, &misc_p->gmac_clk_cfg);
>> +
>> +    perip1_clk_enb |= GETH_CLKEN;
>> +#endif
>> +
>> +#if defined(CONFIG_DW_UDC)
>> +    perip1_clk_enb |= UDC_UPD_CLKEN;
>> +#endif
>> +
>> +#if defined(CONFIG_DW_I2C)
>> +    perip1_clk_enb |= I2C_CLKEN;
>> +#endif
>> +
>> +#if defined(CONFIG_ST_SMI)
>> +    perip1_clk_enb |= SMI_CLKEN;
>> +#endif
>> +
>> +#if defined(CONFIG_NAND_FSMC)
>> +    fsmc_cfg = readl(&misc_p->fsmc_cfg);
>> +    fsmc_cfg &= ~DEV_SEL_MSK;
>> +    fsmc_cfg |= DEV_SEL_NAND;
>> +#if defined(CONFIG_BOARD_NAND_16BIT)
>> +    fsmc_cfg |= DEV_WIDTH_16;
> 
> Similar 16BIT is never defined.
> Remove dead code
> 

These can be defined in the board configuration file and recompiled to
support NAND 16 bit devices. The idea is to define either one of 
CONFIG_BOARD_NAND_8BIT or CONFIG_BOARD_NAND_16BIT to support the NAND
device 

>> +#elif defined(CONFIG_BOARD_NAND_8BIT)
>> +    fsmc_cfg |= DEV_WIDTH_8;
>> +#endif
>> +    writel(fsmc_cfg, &misc_p->fsmc_cfg);
>> +
>> +    perip1_clk_enb |= FSMC_CLKEN;
>> +#endif
>> +
>> +    writel(perip1_clk_enb, &misc_p->perip1_clk_enb);
>> +    writel(perip2_clk_enb, &misc_p->perip2_clk_enb);
>> +
>> +    return 0;
>> +}
>> +#endif
>> +
>> +#ifdef CONFIG_DISPLAY_CPUINFO
>> +int print_cpuinfo(void)
>> +{
>> +    printf("CPU:   SPEAr1300\n");
>> +    return 0;
>> +}
>> +#endif
>> diff --git a/arch/arm/cpu/arm_cortexa8/spear13xx/reset.c
>> b/arch/arm/cpu/arm_cortexa8/spear13xx/reset.c
>> new file mode 100755
>> index 0000000..9a43f85
>> --- /dev/null
>> +++ b/arch/arm/cpu/arm_cortexa8/spear13xx/reset.c
>> @@ -0,0 +1,47 @@
>> +/*
>> + * (C) Copyright 2009
>> + * Vipin Kumar, ST Micoelectronics, vipin.kumar at st.com.
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
>> + *
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#include <common.h>
>> +#include <asm/io.h>
>> +#include <asm/arch/hardware.h>
>> +#include <asm/arch/spr_misc.h>
>> +
>> +void reset_cpu(ulong ignored)
>> +{
>> +    struct misc_regs *misc_regs_p =
>> +        (struct misc_regs *)CONFIG_SPEAR_MISCBASE;
>> +
>> +    printf("System is going to reboot ...\n");
>> +
>> +    /*
>> +     * This 1 second delay will allow the above message
>> +     * to be printed before reset
>> +     */
>> +    udelay((1000 * 1000));
>> +
>> +    writel(0x01, &misc_regs_p->sys_sw_res);
>> +
>> +    /* system will restart */
>> +    while (1)
>> +        ;
>> +}
>> diff --git a/arch/arm/cpu/arm_cortexa8/spear13xx/timer.c
>> b/arch/arm/cpu/arm_cortexa8/spear13xx/timer.c
>> new file mode 100644
>> index 0000000..d114a4a
>> --- /dev/null
>> +++ b/arch/arm/cpu/arm_cortexa8/spear13xx/timer.c
>> @@ -0,0 +1,136 @@
>> +/*
>> + * (C) Copyright 2009
>> + * Vipin Kumar, ST Micoelectronics, vipin.kumar at st.com.
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
>> + *
> 
> Looks like this was based on
>  ../arm926ejs/spear/timer.c
> Please state this even if you are the author of both
> 

OK.

>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#include <common.h>
>> +#include <asm/io.h>
>> +#include <asm/arch/hardware.h>
>> +#include <asm/arch/spr_gpt.h>
>> +#include <asm/arch/spr_misc.h>
>> +
>> +#define GPT_TICKS    (CONFIG_SPEAR_HZ_CLOCK / (1 << prescaler))
>> +#define GPT_RESOLUTION    (GPT_TICKS / CONFIG_SPEAR_HZ)
>> +#define READ_TIMER()    (readl(&gpt_regs_p->count) & GPT_FREE_RUNNING)
>> +
>> +static struct gpt_regs *const gpt_regs_p =
>> +    (struct gpt_regs *)CONFIG_SPEAR_TIMERBASE;
>> +
>> +static ulong timestamp;
>> +static ulong lastdec;
>> +static const u32 prescaler = GPT_PRESCALER_16;
>> +
>> +int timer_init(void)
>> +{
>> +    /* disable timers */
>> +    writel(prescaler | GPT_MODE_AUTO_RELOAD, &gpt_regs_p->control);
>> +
>> +    /* load value for free running */
>> +    writel(GPT_FREE_RUNNING, &gpt_regs_p->compare);
>> +
>> +    /* auto reload, start timer */
>> +    writel(readl(&gpt_regs_p->control) | GPT_ENABLE,
>> &gpt_regs_p->control);
>> +
>> +    reset_timer_masked();
>> +
>> +    return 0;
>> +}
>> +
>> +/*
>> + * timer without interrupts
>> + */
>> +
>> +void reset_timer(void)
>> +{
>> +    reset_timer_masked();
>> +}
>> +
>> +ulong get_timer(ulong base)
>> +{
>> +    return (get_timer_masked() / GPT_RESOLUTION) - base;
>> +}
>> +
>> +void set_timer(ulong t)
>> +{
>> +    timestamp = t;
>> +}
>> +
>> +void __udelay(unsigned long usec)
>> +{
>> +    ulong tmo;
>> +    ulong start = get_timer_masked();
>> +    ulong tenudelcnt = GPT_TICKS / (1000 * 100);
> 
> Expand this variable name so it means something.
> This is a concatenation of abbreviations
> 
OK. I would use ticks_in_ten_us in v3 patch

> May consider using unsigned long long if exceeding 32 bits
> 
>> +    ulong rndoff;
>> +
>> +    rndoff = (usec % 10) ? 1 : 0;
>> +
>> +    /* tenudelcnt timer tick gives 10 microsecconds delay */
>> +    tmo = ((usec / 10) + rndoff) * tenudelcnt;
>> +
>> +    while ((ulong) (get_timer_masked() - start) < tmo)
>> +        ;
>> +}
>> +
>> +void reset_timer_masked(void)
>> +{
>> +    /* reset time */
>> +    lastdec = READ_TIMER();
>> +    timestamp = 0;
>> +}
>> +
>> +ulong get_timer_masked(void)
>> +{
>> +    ulong now = READ_TIMER();
>> +
>> +    if (now >= lastdec) {
>> +        /* normal mode */
>> +        timestamp += now - lastdec;
>> +    } else {
>> +        /* we have an overflow ... */
>> +        timestamp += now + GPT_FREE_RUNNING - lastdec;
>> +    }
>> +    lastdec = now;
>> +
>> +    return timestamp;
>> +}
>> +
>> +void udelay_masked(unsigned long usec)
>> +{
>> +    return udelay(usec);
>> +}
>> +
>> +/*
>> + * This function is derived from PowerPC code (read timebase as long
>> long).
>> + * On ARM it just returns the timer value.
>> + */
>> +unsigned long long get_ticks(void)
>> +{
>> +    return get_timer(0);
>> +}
>> +
>> +/*
>> + * This function is derived from PowerPC code (timebase clock
>> frequency).
>> + * On ARM it returns the number of timer ticks per second.
>> + */
>> +ulong get_tbclk(void)
>> +{
>> +    return CONFIG_SPEAR_HZ;
>> +}
>> diff --git a/arch/arm/include/asm/arch-spear13xx/hardware.h
>> b/arch/arm/include/asm/arch-spear13xx/hardware.h
>> new file mode 100644
>> index 0000000..384260a
>> --- /dev/null
>> +++ b/arch/arm/include/asm/arch-spear13xx/hardware.h
>> @@ -0,0 +1,40 @@
>> +/*
>> + * (C) Copyright 2009
>> + * Vipin Kumar, STMicroelectronics, <vipin.kumar at st.com>
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
>> + *
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#ifndef _ASM_ARCH_HARDWARE_H
>> +#define _ASM_ARCH_HARDWARE_H
> 
> Change this to something non generic
> with SPEAR13XX in it somewhere.
> 
OK

>> +
>> +#define CONFIG_SYS_USBD_BASE            (0xE1100000)
>> +#define CONFIG_SYS_PLUG_BASE            (0xE1200000)
>> +#define CONFIG_SYS_FIFO_BASE            (0xE1000800)
>> +#define CONFIG_SYS_SMI_BASE            (0xFC000000)
>> +#define CONFIG_SPEAR_TIMERBASE            (0xE0380000)
>> +#define CONFIG_SPEAR_MISCBASE            (0xE0700000)
>> +#define CONFIG_SYS_I2C_BASE            (0xE0280000)
>> +#define CONFIG_SPEAR_ETHBASE            (0xE2000000)
>> +#define CONFIG_SYS_FSMC_BASE            (0xB0000000)
>> +
>> +#define CONFIG_SYS_NAND_CLE            (1 << 16)
>> +#define CONFIG_SYS_NAND_ALE            (1 << 17)
>> +
>> +#endif /* _ASM_ARCH_HARDWARE_H */
>> diff --git a/arch/arm/include/asm/arch-spear13xx/spr_gpt.h
>> b/arch/arm/include/asm/arch-spear13xx/spr_gpt.h
>> new file mode 100644
>> index 0000000..ad464cb
>> --- /dev/null
>> +++ b/arch/arm/include/asm/arch-spear13xx/spr_gpt.h
>> @@ -0,0 +1,85 @@
>> +/*
>> + * (C) Copyright 2009
>> + * Vipin Kumar, ST Micoelectronics, vipin.kumar at st.com.
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
>> + *
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#ifndef _SPR_GPT_H
>> +#define _SPR_GPT_H
>> +
>> +struct gpt_regs {
>> +    u8 reserved[0x80];
>> +    u32 control;
>> +    u32 status;
>> +    u32 compare;
>> +    u32 count;
>> +    u32 capture_re;
>> +    u32 capture_fe;
>> +};
>> +
>> +/*
>> + * TIMER_CONTROL register settings
>> + */
>> +
>> +#define GPT_PRESCALER_MASK        0x000F
>> +#define GPT_PRESCALER_1            0x0000
>> +#define GPT_PRESCALER_2         0x0001
>> +#define GPT_PRESCALER_4         0x0002
>> +#define GPT_PRESCALER_8         0x0003
>> +#define GPT_PRESCALER_16        0x0004
>> +#define GPT_PRESCALER_32        0x0005
>> +#define GPT_PRESCALER_64        0x0006
>> +#define GPT_PRESCALER_128        0x0007
>> +#define GPT_PRESCALER_256        0x0008
>> +
>> +#define GPT_MODE_SINGLE_SHOT        0x0010
>> +#define GPT_MODE_AUTO_RELOAD        0x0000
>> +
>> +#define GPT_ENABLE            0x0020
>> +
>> +#define GPT_CAPT_MODE_MASK        0x00C0
>> +#define GPT_CAPT_MODE_NONE        0x0000
>> +#define GPT_CAPT_MODE_RE        0x0040
>> +#define GPT_CAPT_MODE_FE        0x0080
>> +#define GPT_CAPT_MODE_BOTH        0x00C0
>> +
>> +#define GPT_INT_MATCH            0x0100
>> +#define GPT_INT_FE            0x0200
>> +#define GPT_INT_RE            0x0400
>> +
>> +/*
>> + * TIMER_STATUS register settings
>> + */
>> +
>> +#define GPT_STS_MATCH            0x0001
>> +#define GPT_STS_FE            0x0002
>> +#define GPT_STS_RE            0x0004
>> +
>> +/*
>> + * TIMER_COMPARE register settings
>> + */
>> +
>> +#define GPT_FREE_RUNNING        0xFFFF
>> +
>> +/* Timer, HZ specific defines */
>> +#define CONFIG_SPEAR_HZ            (1000)
>> +#define CONFIG_SPEAR_HZ_CLOCK        (24000000)
>> +
>> +#endif
>> diff --git a/arch/arm/include/asm/arch-spear13xx/spr_misc.h
>> b/arch/arm/include/asm/arch-spear13xx/spr_misc.h
>> new file mode 100644
>> index 0000000..0b24843
>> --- /dev/null
>> +++ b/arch/arm/include/asm/arch-spear13xx/spr_misc.h
>> @@ -0,0 +1,317 @@
>> +/*
>> + * (C) Copyright 2000-2009
>> + * Vipin Kumar, ST Microelectronics, vipin.kumar at st.com
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
>> + *
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.     See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#ifndef __SPR13XX_MISC_H
>> +#define __SPR13XX_MISC_H
>> +
>> +struct misc_regs {
>> +    u32 soc_cfg;                /* 0x000 */
>> +    u32 bootstrap_cfg;            /* 0x004 */
>> +    u8  reserved_1[0x100 - 0x8];
>> +    u32 pcm_cfg;                /* 0x100 */
>> +    u32 pcm_wkup_cfg;            /* 0x104 */
>> +    u32 switch_ctr;                /* 0x108 */
>> +    u8  reserved_2[0x200 - 0x10c];
>> +    u32 sys_clk_ctrl;            /* 0x200 */
>> +    u32 sys_sw_res;                /* 0x204 */
>> +    u32 sys_clk_plltimer;            /* 0x208 */
>> +    u32 sys_clk_oscitimer;            /* 0x20c */
>> +    u32 pll_cfg;                /* 0x210 */
>> +    u32 pll1_ctr;                /* 0x214 */
>> +    u32 pll1_frq;                /* 0x218 */
>> +    u32 pll1_mod;                /* 0x21c */
>> +    u32 pll2_ctr;                /* 0x220 */
>> +    u32 pll2_frq;                /* 0x224 */
>> +    u32 pll2_mod;                /* 0x228 */
>> +    u32 pll3_ctr;                /* 0x22c */
>> +    u32 pll3_frq;                /* 0x230 */
>> +    u32 pll3_mod;                /* 0x234 */
>> +    u32 pll4_ctr;                /* 0x238 */
>> +    u32 pll4_frq;                /* 0x23C */
>> +    u32 pll4_mod;                /* 0x240 */
>> +    u32 perip_clk_cfg;            /* 0x244 */
>> +    u32 gmac_clk_cfg;            /* 0x248 */
>> +    u32 c3_clk_synt;            /* 0x24c */
>> +    u32 clcd_clk_synt;            /* 0x250 */
>> +    u32 uart_clk_synt;            /* 0x254 */
>> +    u32 gmac_clk_synt;            /* 0x258 */
>> +    u32 mcif_sd_clk_synt;            /* 0x25c */
>> +    u32 mcif_cfxd_clk_synt;            /* 0x260 */
>> +    u32 ras_clk_synt0;            /* 0x264 */
>> +    u32 ras_clk_synt1;            /* 0x268 */
>> +    u32 ras_clk_synt2;            /* 0x26c */
>> +    u32 ras_clk_synt3;            /* 0x270 */
>> +    u32 perip1_clk_enb;            /* 0x274 */
>> +    u32 perip2_clk_enb;            /* 0x278 */
>> +    u32 perip1_sw_rst;            /* 0x27c */
>> +    u32 perip2_sw_rst;            /* 0x280 */
>> +    u32 ras_clk_enb;            /* 0x284 */
>> +    u32 ras_sw_rst;                /* 0x288 */
>> +    u32 pll1_synt;                /* 0x28c */
>> +    u32 i2s_clk_cfg;            /* 0x290 */
>> +    u8  reserved_3[0x300 - 0x294];
>> +    u32 dmac_hs_sel;            /* 0x300 */
>> +    u32 dmac_sel;                /* 0x304 */
>> +    u32 dmac_flow_sel;            /* 0x308 */
>> +    u32 dmac_dir_sel;            /* 0x30c */
>> +    u32 dmac_cfg;                /* 0x310 */
>> +    u32 usbphy_gen_cfg;            /* 0x314 */
>> +    u32 usbphy_p1_cfg;            /* 0x318 */
>> +    u32 usbphy_p2_cfg;            /* 0x31c */
>> +    u32 usbphy_p3_cfg;            /* 0x320 */
>> +    u32 pcie_cfg;                /* 0x324 */
>> +    u32 pcie_miphy_cfg;            /* 0x328 */
>> +    u32 perip_cfg;                /* 0x32c */
>> +    u32 fsmc_cfg;                /* 0x330 */
>> +    u32 mpmc_ctr_sts;            /* 0x334 */
>> +    u8  reserved_4[0x400 - 0x338];
>> +    u32 expi_clk_cfg;            /* 0x400 */
>> +    u32 expi_cfg;                /* 0x404 */
>> +    u32 expi_dmachs_flex;            /* 0x408 */
>> +    u8  reserved_5[0x500 - 0x40C];
>> +    u32 prc1_lock_ctr;            /* 0x500 */
>> +    u32 prc2_lock_ctr;            /* 0x504 */
>> +    u32 prc1_irq_ctr;            /* 0x508 */
>> +    u8  reserved_6[0x51c - 0x50c];
>> +    u32 prc2_irq_ctr;            /* 0x51c */
>> +    u8  reserved_7[0x600 - 0x520];
>> +    u32 pad_pu_cfg_1;            /* 0x600 */
>> +    u32 pad_pu_cfg_2;            /* 0x604 */
>> +    u32 pad_pu_cfg_3;            /* 0x608 */
>> +    u32 pad_pu_cfg_4;            /* 0x60c */
>> +    u32 pad_pu_cfg_5;            /* 0x610 */
>> +    u32 pad_pu_cfg_6;            /* 0x614 */
>> +    u32 pad_pu_cfg_7;            /* 0x618 */
>> +    u32 pad_pu_cfg_8;            /* 0x61c */
>> +    u32 pad_pd_cfg_1;            /* 0x620 */
>> +    u32 pad_pd_cfg_2;            /* 0x624 */
>> +    u32 pad_pd_cfg_3;            /* 0x628 */
>> +    u32 pad_pd_cfg_4;            /* 0x62c */
>> +    u32 pad_pd_cfg_5;            /* 0x630 */
>> +    u32 pad_pd_cfg_6;            /* 0x634 */
>> +    u32 pad_pd_cfg_7;            /* 0x638 */
>> +    u32 pad_pd_cfg_8;            /* 0x63c */
>> +    u32 pad_sleep_cfg;            /* 0x640 */
>> +    u32 pad_hyst_cfg;            /* 0x644 */
>> +    u32 pad_drv_cfg;            /* 0x648 */
>> +    u32 pad_slew_cfg;            /* 0x64c */
>> +    u32 pad_function_en_1;            /* 0x650 */
>> +    u32 pad_function_en_2;            /* 0x654 */
>> +    u32 pad_function_en_3;            /* 0x658 */
>> +    u32 ddr_pad_cfg;            /* 0x65c */
>> +    u8  reserved_8[0x6C4 - 0x660];
>> +    u32 thsens_cfg;                /* 0x6C4 */
>> +    u8  reserved_9[0x700 - 0x6C8];
>> +    u32 comp_1_cfg;                /* 0x700 */
>> +    u32 comp_2_cfg;                /* 0x704 */
>> +    u32 comp3v3_1_cfg;            /* 0x708 */
>> +    u32 comp3v3_2_cfg;            /* 0x70c */
>> +    u32 compddr_cfg;            /* 0x710 */
>> +    u8  reserved_10[0x800 - 0x714];
>> +    u32 otp_prog_ctr;            /* 0x800 */
>> +    u32 otp_wdata1_1;            /* 0x804 */
>> +    u32 otp_wdata1_2;            /* 0x808 */
>> +    u32 otp_wdata1_3;            /* 0x80c */
>> +    u32 otp_wdata1_4;            /* 0x810 */
>> +    u32 otp_wdata1_5;            /* 0x814 */
>> +    u32 otp_wdata1_6;            /* 0x818 */
>> +    u32 otp_wdata1_7;            /* 0x81c */
>> +    u32 otp_wdata1_8;            /* 0x820 */
>> +    u32 otp_wdata2_1;            /* 0x824 */
>> +    u32 otp_wdata2_2;            /* 0x828 */
>> +    u32 otp_wdata2_3;            /* 0x82c */
>> +    u32 otp_wdata2_4;            /* 0x830 */
>> +    u32 otp_wdata2_5;            /* 0x834 */
>> +    u32 otp_wdata2_6;            /* 0x838 */
>> +    u32 otp_wdata2_7;            /* 0x83c */
>> +    u32 otp_wdata2_8;            /* 0x840 */
>> +    u32 otp_mask_1;                /* 0x844 */
>> +    u32 otp_mask_2;                /* 0x848 */
>> +    u32 otp_mask_3;                /* 0x84c */
>> +    u32 otp_mask_4;                /* 0x850 */
>> +    u32 otp_mask_5;                /* 0x854 */
>> +    u32 otp_mask_6;                /* 0x858 */
>> +    u32 otp_mask_7;                /* 0x85c */
>> +    u32 otp_mask_8;                /* 0x860 */
>> +    u32 otp_rdata1_1;            /* 0x864 */
>> +    u32 otp_rdata1_2;            /* 0x868 */
>> +    u32 otp_rdata1_3;            /* 0x86c */
>> +    u32 otp_rdata1_4;            /* 0x870 */
>> +    u32 otp_rdata1_5;            /* 0x874 */
>> +    u32 otp_rdata1_6;            /* 0x878 */
>> +    u32 otp_rdata1_7;            /* 0x87c */
>> +    u32 otp_rdata1_8;            /* 0x880 */
>> +    u32 otp_rdata2_1;            /* 0x884 */
>> +    u32 otp_rdata2_2;            /* 0x888 */
>> +    u32 otp_rdata2_3;            /* 0x88c */
>> +    u32 otp_rdata2_4;            /* 0x890 */
>> +    u32 otp_rdata2_5;            /* 0x894 */
>> +    u32 otp_rdata2_6;            /* 0x898 */
>> +    u32 otp_rdata2_7;            /* 0x89c */
>> +    u32 otp_rdata2_8;            /* 0x8a0 */
>> +    u32 otp_rdatam_1;            /* 0x8a4 */
>> +    u32 otp_rdatam_2;            /* 0x8a8 */
>> +    u32 otp_rdatam_3;            /* 0x8ac */
>> +    u32 otp_rdatam_4;            /* 0x8b0 */
>> +    u32 otp_rdatam_5;            /* 0x8b4 */
>> +    u32 otp_rdatam_6;            /* 0x8b8 */
>> +    u32 otp_rdatam_7;            /* 0x8bc */
>> +    u32 otp_rdatam_8;            /* 0x8c0 */
>> +    u8  reserved_11[0x900 - 0x8c4];
>> +    u32 a9sm_clusterid;            /* 0x900 */
>> +    u32 a9sm_status;            /* 0x904 */
>> +    u32 a9sm_debug;                /* 0x908 */
>> +    u32 a9sm_filter;            /* 0x90c */
>> +    u32 a9sm_parity_cfg;            /* 0x910 */
>> +    u32 a9sm_parity_err;            /* 0x914 */
>> +    u8  reserved_12[0xa00 - 0x918];
>> +    u32 die_id_1;                /* 0xa00 */
>> +    u32 die_id_2;                /* 0xa04 */
>> +    u32 die_id_3;                /* 0xa08 */
>> +    u32 die_id_4;                /* 0xa0c */
>> +    u32 die_id_valid;            /* 0xa10 */
>> +    u8  reserved_13[0xb00 - 0xa14];
>> +    u32 ras1_gpp_inp;            /* 0xb00 */
>> +    u32 ras2_gpp_inp;            /* 0xb04 */
>> +    u32 ras1_gpp_out;            /* 0xb08 */
>> +    u32 ras2_gpp_out;            /* 0xb0c */
>> +    u8  reserved_14[0x1000 - 0xb10];
>> +    u32 miphy_test;                /* 0x1000 */
>> +    u32 pcie_mstr_p1;            /* 0x1004 */
>> +    u32 pcie_awmisc_p1;            /* 0x1008 */
>> +    u32 pcie_armisc_p1;            /* 0x100c */
>> +    u32 pcie_mstr_p2;            /* 0x1010 */
>> +    u32 pcie_awmisc_p2;            /* 0x1014 */
>> +    u32 pcie_armisc_p2;            /* 0x1018 */
>> +    u32 pcie_mstr_p3;            /* 0x101c */
>> +    u32 pcie_awmisc_p3;            /* 0x1020 */
>> +    u32 pcie_armisc_p3;            /* 0x1024 */
>> +};
>> +
>> +/* sys_clk_ctrl definitions */
>> +#define SYS_MODE_MASK                (7 << 0)
>> +#define SYS_MODE_REQ_DOZE            (1 << 0)
>> +#define SYS_MODE_REQ_SLOW            (2 << 0)
>> +#define SYS_MODE_REQ_NORMAL            (4 << 0)
>> +#define PLL_TIMEOUT_ENB                (1 << 3)
>> +#define XTAL_TIMEOUT_ENB            (1 << 4)
>> +#define SYS_STATE_MASK                (0xF << 16)
>> +#define SYS_STATE_NORMAL            (0xF << 16)
>> +
>> +/* sys_clk_*timer definitions */
>> +#define PLL_TIM                    (0xff << 3)
>> +#define OSCI_TIM                (0xff << 3)
>> +
>> +/* pll_freq definitions in MHz */
>> +#define FREQ_1000                (0xFA000106)
>> +#define FREQ_996                (0x53000004)
>> +#define FREQ_332                (0x53000203)
>> +
>> +/* pll_ctr definitions */
>> +#define PLLLOCK                    (1 << 0)
>> +#define PLLENABLE                (1 << 1)
>> +
>> +/* perip_clk_cfg definitions */
>> +#define MPMC_CLK_PLL4                (1 << 10)
>> +
>> +/* perip*_[clk_enb/sw_rst] definitions */
>> +#define BUS_CLKEN                (1 << 0)    /* perip1 */
>> +#define SYSROM_CLKEN                (1 << 1)
>> +#define AORAM_CLKEN                (1 << 2)
>> +#define SYSRAM_CLKEN                (1 << 3)
>> +#define FSMC_CLKEN                (1 << 4)
>> +#define SMI_CLKEN                (1 << 5)
>> +#define SD_CLKEN                (1 << 6)
>> +#define CFXD_CLKEN                (1 << 7)
>> +#define GETH_CLKEN                (1 << 8)
>> +#define UHC1_CLKEN                (1 << 9)
>> +#define UHC2_CLKEN                (1 << 10)
>> +#define UDC_UPD_CLKEN                (1 << 11)
>> +#define PCI1_CLKEN                (1 << 12)
>> +#define PCI2_CLKEN                (1 << 13)
>> +#define PCI3_CLKEN                (1 << 14)
>> +#define UART_CLKEN                (1 << 15)
>> +#define SSP_CLKEN                (1 << 17)
>> +#define I2C_CLKEN                (1 << 18)
>> +#define I2S_SLV_CLKEN                (1 << 19)
>> +#define I2S_MST_CLKEN                (1 << 20)
>> +#define GPT1_CLKEN                (1 << 21)
>> +#define GPT2_CLKEN                (1 << 22)
>> +#define GPIO1_CLKEN                (1 << 23)
>> +#define GPIO2_CLKEN                (1 << 24)
>> +#define DMA1_CLKEN                (1 << 25)
>> +#define DMA2_CLKEN                (1 << 26)
>> +#define CLCD_CLKEN                (1 << 27)
>> +#define JPEG_CLKEN                (1 << 28)
>> +#define C3_CLKEN                (1 << 29)
>> +#define ADC_CLKEN                (1 << 30)
>> +#define RTC_CLKEN                (1 << 31)
>> +
>> +#define DDR_CTRL_CLKEN                (1 << 0)    /* perip2 */
>> +#define DDR_CORE_CLKEN                (1 << 1)
>> +#define CPU_DBG_CLKEN                (1 << 2)
>> +#define KBD_CLKEN                (1 << 3)
>> +#define GPT3_CLKEN                (1 << 4)
>> +#define GPT4_CLKEN                (1 << 5)
>> +#define ACP_CLKEN                (1 << 6)
>> +#define I2S_REFOUT_CLKEN            (1 << 7)
>> +#define THSENS_CLKEN                (1 << 8)
>> +
>> +/* fsmc_cfg definitions */
>> +#define DEV_SEL_NOR                (0 << 0)
>> +#define DEV_SEL_NAND                (1 << 0)
>> +#define DEV_SEL_SRAM                (2 << 0)
>> +#define DEV_SEL_MSK                (3 << 0)
>> +#define NAND_BANK_0                (0 << 2)
>> +#define NAND_BANK_1                (1 << 2)
>> +#define NAND_BANK_2                (2 << 2)
>> +#define NAND_BANK_3                (3 << 2)
>> +#define DEV_WIDTH_8                (0 << 4)
>> +#define DEV_WIDTH_16                (1 << 4)
>> +
>> +/* usbphy_gen_cfg definitions */
>> +#define COMMON_PWDN                (1 << 0)
>> +#define USBPHY_POR                (1 << 12)
>> +#define USBPHY_RST                (1 << 13)
>> +#define UTMI_XFER_RST0                (1 << 14)
>> +#define UTMI_XFER_RST1                (1 << 15)
>> +#define UTMI_XFER_RST2                (1 << 16)
>> +#define USB_PLL_LOCK                (1 << 27)
>> +
>> +/* synth registers definitions */
>> +#define SYNT_CLK_ENB                (1 << 31)
>> +#define SYNT_FIN_FULL                (1 << 30)
>> +#define SYNT_X_1                (1 << 16)
>> +#define SYNT_Y_2                (2 << 0)
>> +#define SYNT_Y_5                (5 << 0)
>> +
>> +/* gmac_clk_cfg definitions */
>> +#define PHY_IF_GMII                (0 << 4)
>> +#define PHY_IF_RGMII                (1 << 4)
>> +#define PHY_IF_RMII                (4 << 4)
>> +#define GMII_SYNT_ENB                (1 << 3)
>> +#define CLK_SEL_PAD                (0 << 0)
>> +#define CLK_SEL_PLL2                (1 << 0)
>> +#define CLK_SEL_OSCI3                (2 << 0)
>> +
>> +#endif
>> diff --git a/arch/arm/include/asm/arch-spear13xx/sys_proto.h
>> b/arch/arm/include/asm/arch-spear13xx/sys_proto.h
>> new file mode 100644
>> index 0000000..e6cc3a9
>> --- /dev/null
>> +++ b/arch/arm/include/asm/arch-spear13xx/sys_proto.h
>> @@ -0,0 +1,32 @@
>> +/*
>> + * (C) Copyright 2009
>> + * Vipin Kumar, STMicroelectronics, <vipin.kumar at st.com>
>> + *
>> + * See file CREDITS for list of people who contributed to this
>> + * project.
>> + *
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU General Public License as
>> + * published by the Free Software Foundation; either version 2 of
>> + * the License, or (at your option) any later version.
>> + *
>> + * This program is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
>> + * GNU General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write to the Free Software
>> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#ifndef _SYS_PROTO_H_
>> +#define _SYS_PROTO_H_
>> +
>> +u32 get_device_type(void);
> 
> This is needed for omap3.  Remove
> 
Again, this becomes necessary if I want to use the generic cpu code

Regards
Vipin

> Tom
> 
>> +void invalidate_dcache(u32);
>> +void l2_cache_disable(void);
>> +void l2_cache_enable(void);
>> +
>> +#endif
> 
> 



More information about the U-Boot mailing list