[PATCH 02/11] ST SPEAr: Added basic header files for SPEAr3xx machine family
Viresh KUMAR
viresh.kumar at st.com
Wed Mar 10 01:01:22 EST 2010
Linus,
On 3/10/2010 2:12 AM, Linus Walleij wrote:
> Hi Viresh,
>
> 2010/3/3 Viresh KUMAR <viresh.kumar at st.com>:
>> (...)
>> diff --git a/arch/arm/mach-spear3xx/include/mach/debug-macro.S b/arch/arm/mach-spear3xx/include/mach/debug-macro.S
>> + .macro busyuart, rd, rx
>> +1002: ldr \rd, [\rx, #UART01x_FR] @ FLAG REGISTER
>> + tst \rd, #UART011_FR_TXFE @ TX_EMPTY
>> + beq 1002b
>> + .endm
>
> Apart from that the base offset is named SPEAR6XX_ICM1_UART0_BASE
> this is the same file in 3xx and 6xx series. Can you rename the base offset
> to SPEARXXX_ICM1_UART0_BASE or something similar in both machines
> and move this file to plat-spear/include/plat/debug-macro.S?
OK. This will be done.
>
> You'll probably need mach/include/mach/debug-macro.S to
> #include <plat/debug-macro.S> I think.
>
I think so.
>> diff --git a/arch/arm/mach-spear6xx/include/mach/dma.h b/arch/arm/mach-spear6xx/include/mach/dma.h
>> new file mode 100644
>> index 0000000..c4afd17
>> --- /dev/null
>> +++ b/arch/arm/mach-spear6xx/include/mach/dma.h
>> @@ -0,0 +1,17 @@
>> +/*
>> + * arch/arm/mach-spear6xx/include/mach/dma.h
>> + *
>> + * Generic SPEAr6XX machine family DMA support
>> + *
>> + * Copyright (C) 2009 ST Microelectronics
>> + * Rajeev Kumar<rajeev-dlh.kumar at st.com>
>> + *
>> + * This file is licensed under the terms of the GNU General Public
>> + * License version 2. This program is licensed "as is" without any
>> + * warranty of any kind, whether express or implied.
>> + */
>> +
>> +#ifndef __ASM_ARCH_DMA_H
>> +#define __ASM_ARCH_DMA_H
>> +
>> +#endif /* __ASM_ARCH_DMA_H */
>
> Is this file needed? (Perhaps...) Anyway, the name of that #define should
> probably be __MACH_DMA_H if it shall match the filepath.
>
It is not required now, was required by earlier kernels. will be removed.
>> (...)
>> diff --git a/arch/arm/mach-spear3xx/include/mach/misc_regs.h b/arch/arm/mach-spear3xx/include/mach/misc_regs.h
>> new file mode 100755
>> index 0000000..d83dae9
>> +#ifndef __ASM_MACH_MISC_REGS_H
>> +#define __ASM_MACH_MISC_REGS_H
>
> It's not __ASM_MACH* really, but just __MACH* if it's supposed to follow
> the filename...
Will be done globally.
>
>> +
>> +#include <mach/spear.h>
>> +
>> +#define MISC_BASE VA_SPEAR3XX_ICM3_MISC_REG_BASE
>> +
>> +#define SOC_CFG_CTR ((unsigned int *)(MISC_BASE + 0x000))
>> +#define DIAG_CFG_CTR ((unsigned int *)(MISC_BASE + 0x004))
>> +#define PLL1_CTR ((unsigned int *)(MISC_BASE + 0x008))
>> +#define PLL1_FRQ ((unsigned int *)(MISC_BASE + 0x00C))
>> +#define PLL1_MOD ((unsigned int *)(MISC_BASE + 0x010))
>> +#define PLL2_CTR ((unsigned int *)(MISC_BASE + 0x014))
>> +/* PLL_CTR register masks */
>> +#define PLL_ENABLE 2
>> +#define PLL_MODE_SHIFT 4
>> +#define PLL_MODE_MASK 0x3
>> +#define PLL_MODE_NORMAL 0
>> +#define PLL_MODE_FRACTION 1
>> +#define PLL_MODE_DITH_DSB 2
>> +#define PLL_MODE_DITH_SSB 3
>> +
>> +#define PLL2_FRQ ((unsigned int *)(MISC_BASE + 0x018))
>> +/* PLL FRQ register masks */
>> +#define PLL_DIV_N_SHIFT 0
>> +#define PLL_DIV_N_MASK 0xFF
>> +#define PLL_DIV_P_SHIFT 8
>> +#define PLL_DIV_P_MASK 0x7
>> +#define PLL_NORM_FDBK_M_SHIFT 24
>> +#define PLL_NORM_FDBK_M_MASK 0xFF
>> +#define PLL_DITH_FDBK_M_SHIFT 16
>> +#define PLL_DITH_FDBK_M_MASK 0xFFFF
>> +
>> +#define PLL2_MOD ((unsigned int *)(MISC_BASE + 0x01C))
>> +#define PLL_CLK_CFG ((unsigned int *)(MISC_BASE + 0x020))
>> +#define CORE_CLK_CFG ((unsigned int *)(MISC_BASE + 0x024))
>> +/* CORE CLK CFG register masks */
>> +#define PLL_HCLK_RATIO_SHIFT 10
>> +#define PLL_HCLK_RATIO_MASK 0x3
>> +#define HCLK_PCLK_RATIO_SHIFT 8
>> +#define HCLK_PCLK_RATIO_MASK 0x3
>> +
>> +#define PERIP_CLK_CFG ((unsigned int *)(MISC_BASE + 0x028))
>> +/* PERIP_CLK_CFG register masks */
>> +#define UART_CLK_SHIFT 4
>> +#define UART_CLK_MASK 0x1
>> +#define FIRDA_CLK_SHIFT 5
>> +#define FIRDA_CLK_MASK 0x3
>> +#define GPT0_CLK_SHIFT 8
>> +#define GPT1_CLK_SHIFT 11
>> +#define GPT2_CLK_SHIFT 12
>> +#define GPT_CLK_MASK 0x1
>> +#define AUX_CLK_PLL3_MASK 0
>> +#define AUX_CLK_PLL1_MASK 1
>> +
>> +#define PERIP1_CLK_ENB ((unsigned int *)(MISC_BASE + 0x02C))
>> +/* PERIP1_CLK_ENB register masks */
>> +#define UART_CLK_ENB 3
>> +#define SSP_CLK_ENB 5
>> +#define I2C_CLK_ENB 7
>> +#define JPEG_CLK_ENB 8
>> +#define FIRDA_CLK_ENB 10
>> +#define GPT1_CLK_ENB 11
>> +#define GPT2_CLK_ENB 12
>> +#define ADC_CLK_ENB 15
>> +#define RTC_CLK_ENB 17
>> +#define GPIO_CLK_ENB 18
>> +#define DMA_CLK_ENB 19
>> +#define SMI_CLK_ENB 21
>> +#define GMAC_CLK_ENB 23
>> +#define USBD_CLK_ENB 24
>> +#define USBH_CLK_ENB 25
>> +#define C3_CLK_ENB 31
>> +
>> +#define SOC_CORE_ID ((unsigned int *)(MISC_BASE + 0x030))
>> +#define RAS_CLK_ENB ((unsigned int *)(MISC_BASE + 0x034))
>> +#define PERIP1_SOF_RST ((unsigned int *)(MISC_BASE + 0x038))
>> +/* PERIP1_SOF_RST register masks */
>> +#define JPEG_SOF_RST 8
>> +
>> +#define SOC_USER_ID ((unsigned int *)(MISC_BASE + 0x03C))
>> +#define RAS_SOF_RST ((unsigned int *)(MISC_BASE + 0x040))
>> +#define PRSC1_CLK_CFG ((unsigned int *)(MISC_BASE + 0x044))
>> +#define PRSC2_CLK_CFG ((unsigned int *)(MISC_BASE + 0x048))
>> +#define PRSC3_CLK_CFG ((unsigned int *)(MISC_BASE + 0x04C))
>> +/* gpt synthesizer register masks */
>> +#define GPT_MSCALE_SHIFT 0
>> +#define GPT_MSCALE_MASK 0xFFF
>> +#define GPT_NSCALE_SHIFT 12
>> +#define GPT_NSCALE_MASK 0xF
>> +
>> +#define AMEM_CLK_CFG ((unsigned int *)(MISC_BASE + 0x050))
>> +#define EXPI_CLK_CFG ((unsigned int *)(MISC_BASE + 0x054))
>> +#define CLCD_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x05C))
>> +#define FIRDA_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x060))
>> +#define UART_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x064))
>> +#define GMAC_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x068))
>> +#define RAS1_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x06C))
>> +#define RAS2_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x070))
>> +#define RAS3_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x074))
>> +#define RAS4_CLK_SYNT ((unsigned int *)(MISC_BASE + 0x078))
>> +/* aux clk synthesiser register masks for irda to ras4 */
>> +#define AUX_EQ_SEL_SHIFT 30
>> +#define AUX_EQ_SEL_MASK 1
>> +#define AUX_EQ1_SEL 0
>> +#define AUX_EQ2_SEL 1
>> +#define AUX_XSCALE_SHIFT 16
>> +#define AUX_XSCALE_MASK 0xFFF
>> +#define AUX_YSCALE_SHIFT 0
>> +#define AUX_YSCALE_MASK 0xFFF
>> +
>> +#define ICM1_ARB_CFG ((unsigned int *)(MISC_BASE + 0x07C))
>> +#define ICM2_ARB_CFG ((unsigned int *)(MISC_BASE + 0x080))
>> +#define ICM3_ARB_CFG ((unsigned int *)(MISC_BASE + 0x084))
>> +#define ICM4_ARB_CFG ((unsigned int *)(MISC_BASE + 0x088))
>> +#define ICM5_ARB_CFG ((unsigned int *)(MISC_BASE + 0x08C))
>> +#define ICM6_ARB_CFG ((unsigned int *)(MISC_BASE + 0x090))
>> +#define ICM7_ARB_CFG ((unsigned int *)(MISC_BASE + 0x094))
>> +#define ICM8_ARB_CFG ((unsigned int *)(MISC_BASE + 0x098))
>> +#define ICM9_ARB_CFG ((unsigned int *)(MISC_BASE + 0x09C))
>> +#define DMA_CHN_CFG ((unsigned int *)(MISC_BASE + 0x0A0))
>> +#define USB2_PHY_CFG ((unsigned int *)(MISC_BASE + 0x0A4))
>> +#define GMAC_CFG_CTR ((unsigned int *)(MISC_BASE + 0x0A8))
>> +#define EXPI_CFG_CTR ((unsigned int *)(MISC_BASE + 0x0AC))
>> +#define PRC1_LOCK_CTR ((unsigned int *)(MISC_BASE + 0x0C0))
>> +#define PRC2_LOCK_CTR ((unsigned int *)(MISC_BASE + 0x0C4))
>> +#define PRC3_LOCK_CTR ((unsigned int *)(MISC_BASE + 0x0C8))
>> +#define PRC4_LOCK_CTR ((unsigned int *)(MISC_BASE + 0x0CC))
>> +#define PRC1_IRQ_CTR ((unsigned int *)(MISC_BASE + 0x0D0))
>> +#define PRC2_IRQ_CTR ((unsigned int *)(MISC_BASE + 0x0D4))
>> +#define PRC3_IRQ_CTR ((unsigned int *)(MISC_BASE + 0x0D8))
>> +#define PRC4_IRQ_CTR ((unsigned int *)(MISC_BASE + 0x0DC))
>> +#define PWRDOWN_CFG_CTR ((unsigned int *)(MISC_BASE + 0x0E0))
>> +#define COMPSSTL_1V8_CFG ((unsigned int *)(MISC_BASE + 0x0E4))
>> +#define COMPSSTL_2V5_CFG ((unsigned int *)(MISC_BASE + 0x0E8))
>> +#define COMPCOR_3V3_CFG ((unsigned int *)(MISC_BASE + 0x0EC))
>> +#define SSTLPAD_CFG_CTR ((unsigned int *)(MISC_BASE + 0x0F0))
>> +#define BIST1_CFG_CTR ((unsigned int *)(MISC_BASE + 0x0F4))
>> +#define BIST2_CFG_CTR ((unsigned int *)(MISC_BASE + 0x0F8))
>> +#define BIST3_CFG_CTR ((unsigned int *)(MISC_BASE + 0x0FC))
>> +#define BIST4_CFG_CTR ((unsigned int *)(MISC_BASE + 0x100))
>> +#define BIST5_CFG_CTR ((unsigned int *)(MISC_BASE + 0x104))
>> +#define BIST1_STS_RES ((unsigned int *)(MISC_BASE + 0x108))
>> +#define BIST2_STS_RES ((unsigned int *)(MISC_BASE + 0x10C))
>> +#define BIST3_STS_RES ((unsigned int *)(MISC_BASE + 0x110))
>> +#define BIST4_STS_RES ((unsigned int *)(MISC_BASE + 0x114))
>> +#define BIST5_STS_RES ((unsigned int *)(MISC_BASE + 0x118))
>> +#define SYSERR_CFG_CTR ((unsigned int *)(MISC_BASE + 0x11C))
>> +
>> +#endif /* __ASM_MACH_MISC_REGS_H */
>
> Personally I like to push down these definitions into the actual driver files,
> so that all PLL+CLK stuff goes into clock.c, all GPT stuff into timer.c etc.
> It has the convenience of easily finding everything in a single file and
> at the same time surely blocking some other driver from poking around
> in the same registers.
Background: This file defines miscellaneous registers for spear machines. They
provide features like enabling/disabling peripherals, clocks, selecting clock
sources, etc.
I wanted to keep this file because, i didn't wanted people using same
miscellaneous registers make different macros. It is actually like a module for
machines, and so this can be kept separate.
>
> If you want to keep this file anyway, move it from mach-spear3xx/include/mach
> to just mach-spear3xx and include like this: #include "misc_regs.h" and
> thus avoid the entire drivers/* tree (etc) from being able to #include
> <mach/misc_regs.h>
> because surely any machine-specific special driver using these very
> machine-specific
> registers will be in mach-spear3xx/ anyway.
Surely, any standard driver will not use them. Actually we have kept clock
framework code common to different machines in plat-spear.
And here we need to use misc_regs.h, for this reason i kept it in
mach/include/mach.
Is it Okay?
>
>> (...)
>> diff --git a/arch/arm/mach-spear3xx/include/mach/system.h b/arch/arm/mach-spear3xx/include/mach/system.h
>> new file mode 100644
>> index 0000000..b7bc53f
>> +
>> +#ifndef __ASM_MACH_SYSTEM_H
>> +#define __ASM_MACH_SYSTEM_H
>
> Again __MACH_SYSTEM_H
>
>> +
>> +#include <linux/io.h>
>> +#include <linux/sysctl_sp810.h>
>
> In regard to earlier comment:
> #include <asm/hardware/sysctl_sp810.h>
OK.
>
>> +#include <mach/spear.h>
>> +
>> +static inline void arch_idle(void)
>> +{
>> + /*
>> + * This should do all the clock switching
>> + * and wait for interrupt tricks
>> + */
>> + cpu_do_idle();
>> +}
>> +
>> +static inline void arch_reset(char mode, const char *cmd)
>> +{
>> + if (mode == 's') {
>> + /* software reset, Jump into ROM at address 0 */
>> + cpu_reset(0);
>> + } else {
>> + /* hardware reset, Use on-chip reset capability */
>> + sysctl_soft_reset(SPEAR3XX_ICM3_SYS_CTRL_BASE);
>> + }
>> +}
>> +
>> +#endif /* __ASM_MACH_SYSTEM_H */
>
> Again this file is identical to the same file for 6xx. Define a generic
> SPEAR_ICM3_SYS_CTRL_BASE or so and move to
> plat-spear/include/plat/system.h
>
OK.
> (I don't know how this works, perhaps you have to have a skeleton
> mach/include/mach/system.h that will just #include <plat/system.h>
> for this to work.)
Yes.
>
>> diff --git a/arch/arm/mach-spear3xx/include/mach/timex.h b/arch/arm/mach-spear3xx/include/mach/timex.h
>> new file mode 100644
>> index 0000000..29708db
>> --- /dev/null
>> +++ b/arch/arm/mach-spear3xx/include/mach/timex.h
>> @@ -0,0 +1,19 @@
>> +/*
>> + * arch/arm/mach-spear3xx/include/mach/timex.h
>> + *
>> + * SPEAr3XX machine family specific timex definitions
>> + *
>> + * Copyright (C) 2009 ST Microelectronics
>> + * Viresh Kumar<viresh.kumar at st.com>
>> + *
>> + * This file is licensed under the terms of the GNU General Public
>> + * License version 2. This program is licensed "as is" without any
>> + * warranty of any kind, whether express or implied.
>> + */
>> +
>> +#ifndef __ASM_MACH_TIMEX_H
>> +#define __ASM_MACH_TIMEX_H
>
> Again __MACH_TIMEX_H
OK
>
>> +
>> +#define CLOCK_TICK_RATE 48000000
>> +
>> +#endif /* __ASM_MACH_TIMEX_H */
>> diff --git a/arch/arm/mach-spear3xx/include/mach/uncompress.h b/arch/arm/mach-spear3xx/include/mach/uncompress.h
>> new file mode 100644
>> index 0000000..08ec3b1
>> --- /dev/null
>> +++ b/arch/arm/mach-spear3xx/include/mach/uncompress.h
>> @@ -0,0 +1,43 @@
>> +/*
>> + * arch/arm/mach-spear3xx/include/mach/uncompress.h
>> + *
>> + * Serial port stubs for kernel decompress status messages
>> + *
>> + * Copyright (C) 2009 ST Microelectronics
>> + * Viresh Kumar<viresh.kumar at st.com>
>> + *
>> + * This file is licensed under the terms of the GNU General Public
>> + * License version 2. This program is licensed "as is" without any
>> + * warranty of any kind, whether express or implied.
>> + */
>> +
>> +#include <linux/io.h>
>> +#include <linux/amba/serial.h>
>> +#include <mach/spear.h>
>> +
>> +#ifndef __ASM_MACH_UNCOMPRESS_H
>> +#define __ASM_MACH_UNCOMPRESS_H
>> +/*
>> + * This does not append a newline
>> + */
>> +static inline void putc(int c)
>> +{
>> + void __iomem *base = (void __iomem *)SPEAR3XX_ICM1_UART_BASE;
>> +
>> + while (readl(base + UART01x_FR) & UART01x_FR_TXFF)
>> + barrier();
>> +
>> + writel(c, base + UART01x_DR);
>> +}
>> +
>> +static inline void flush(void)
>> +{
>> +}
>> +
>> +/*
>> + * nothing to do
>> + */
>> +#define arch_decomp_setup()
>> +#define arch_decomp_wdog()
>> +
>> +#endif /* __ASM_MACH_UNCOMPRESS_H */
>
> Apart from that the base offset is named SPEAR6XX_ICM1_UART0_BASE
> this is the same file in 3xx and 6xx series. Can you rename the base offset
> to SPEARXXX_ICM1_UART0_BASE or something similar in both machines
> and move this file to plat-spear/include/plat/uncompress.h?
OK
>
> (Perhaps mach/include/mach/uncompress.h has to contain a single
> #include <plat/uncompress.h> I haven't tested.)
yes, this is required.
>
>> diff --git a/arch/arm/mach-spear3xx/include/mach/vmalloc.h b/arch/arm/mach-spear3xx/include/mach/vmalloc.h
>> new file mode 100644
>> index 0000000..4f236f3
>> --- /dev/null
>> +++ b/arch/arm/mach-spear3xx/include/mach/vmalloc.h
>> @@ -0,0 +1,22 @@
>> +/*
>> + * arch/arm/mach-spear3xx/include/mach/vmalloc.h
>> + *
>> + * Defining Vmalloc area for SPEAr3xx machine family
>> + *
>> + * Copyright (C) 2009 ST Microelectronics
>> + * Viresh Kumar<viresh.kumar at st.com>
>> + *
>> + * This file is licensed under the terms of the GNU General Public
>> + * License version 2. This program is licensed "as is" without any
>> + * warranty of any kind, whether express or implied.
>> + */
>> +
>> +#ifndef __ASM_MACH_VMALLOC_H
>> +#define __ASM_MACH_VMALLOC_H
>
> Again __MACH_VMALLOC_H
>
>> +
>> +#include <mach/memory.h>
>> +
>> +#define VMALLOC_SIZE (0x30000000)
>> +#define VMALLOC_END (PAGE_OFFSET + VMALLOC_SIZE)
>> +
>> +#endif /* __ASM_MACH_VMALLOC_H */
>
> This is exactly the same file as in spear6xx again move to plat-spear.
> Might need a single #include <plat/vmalloc.h>
>
> Most comments on this file are in relation to the 6xx header files, so they
> apply to that patch as well. Mostly "move to plat-spear" stuff. Just
> replace in the proper places.
>
> (The entry-macro is unique for both platforms though!)
OK. will be done.
viresh kumar.
More information about the linux-arm-kernel
mailing list