[PATCH] [ARM] kirkwood: combine support for openrd base/client support

Dieter Kiermaier dk-arm-linux at gmx.de
Fri Oct 9 10:00:44 EDT 2009


Hi Alexander,


> Based on the work done by Dhaval Vasa to add OpenRD Base support (and 
> the unmerged Client) support, this patch adds support for the 
> Kirkwood OpenRD Client board.
> 
> I was 'inspired' by the work Hartley Sweeten had done in flattening 
> mach-ep93xx into a single setup.c file; as there is really not much 
> difference between the OpenRD Base and Client boards I think it is 
> appropriate to do the same here.
> 
> Signed-off-by: Alexander Clouter <alex at digriz.org.uk>
> 
> diff --git a/arch/arm/mach-kirkwood/Kconfig b/arch/arm/mach-kirkwood/Kconfig
> index 0aca451..8e9ac7d 100644
> --- a/arch/arm/mach-kirkwood/Kconfig
> +++ b/arch/arm/mach-kirkwood/Kconfig
> @@ -38,12 +38,23 @@ config MACH_TS219
>  	  Say 'Y' here if you want your kernel to support the
>  	  QNAP TS-119 and TS-219 Turbo NAS devices.
>  
> +config MACH_OPENRD
> +        bool
> +
>  config MACH_OPENRD_BASE
>  	bool "Marvell OpenRD Base Board"
> +	select MACH_OPENRD
>  	help
>  	  Say 'Y' here if you want your kernel to support the
>  	  Marvell OpenRD Base Board.
>  
> +config MACH_OPENRD_CLIENT
> +	bool "Marvell OpenRD Client Board"
> +	select MACH_OPENRD
> +	help
> +	  Say 'Y' here if you want your kernel to support the
> +	  Marvell OpenRD Client Board.
> +
>  endmenu
>  
>  endif
> diff --git a/arch/arm/mach-kirkwood/Makefile b/arch/arm/mach-kirkwood/Makefile
> index 80ab0ec..5ad19dd 100644
> --- a/arch/arm/mach-kirkwood/Makefile
> +++ b/arch/arm/mach-kirkwood/Makefile
> @@ -6,6 +6,6 @@ obj-$(CONFIG_MACH_RD88F6281)		+= rd88f6281-setup.o
>  obj-$(CONFIG_MACH_MV88F6281GTW_GE)	+= mv88f6281gtw_ge-setup.o
>  obj-$(CONFIG_MACH_SHEEVAPLUG)		+= sheevaplug-setup.o
>  obj-$(CONFIG_MACH_TS219)		+= ts219-setup.o
> -obj-$(CONFIG_MACH_OPENRD_BASE)		+= openrd_base-setup.o
> +obj-$(CONFIG_MACH_OPENRD)		+= openrd-setup.o
>  
>  obj-$(CONFIG_CPU_IDLE)			+= cpuidle.o
> diff --git a/arch/arm/mach-kirkwood/openrd-setup.c b/arch/arm/mach-kirkwood/openrd-setup.c
> new file mode 100644
> index 0000000..6bdeeab
> --- /dev/null
> +++ b/arch/arm/mach-kirkwood/openrd-setup.c
> @@ -0,0 +1,109 @@
> +/*
> + * arch/arm/mach-kirkwood/openrd-setup.c
> + *
> + * Marvell OpenRD (Base|Client) Board Setup
> + *
> + * 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/kernel.h>
> +#include <linux/init.h>
> +#include <linux/platform_device.h>
> +#include <linux/mtd/partitions.h>
> +#include <linux/ata_platform.h>
> +#include <linux/mv643xx_eth.h>
> +#include <asm/mach-types.h>
> +#include <asm/mach/arch.h>
> +#include <mach/kirkwood.h>
> +#include <plat/mvsdio.h>
> +#include "common.h"
> +#include "mpp.h"
> +
> +static struct mtd_partition openrd_nand_parts[] = {
> +	{
> +		.name = "u-boot",
> +		.offset = 0,
> +		.size = SZ_1M
> +	}, {
> +		.name = "uImage",
> +		.offset = MTDPART_OFS_NXTBLK,
> +		.size = SZ_4M
> +	}, {
> +		.name = "root",
> +		.offset = MTDPART_OFS_NXTBLK,
> +		.size = MTDPART_SIZ_FULL
> +	},
> +};
> +
> +static struct mv643xx_eth_platform_data openrd_ge00_data = {
> +	.phy_addr	= MV643XX_ETH_PHY_ADDR(8),
> +};
> +
> +#ifdef CONFIG_MACH_OPENRD_CLIENT
> +static struct mv643xx_eth_platform_data openrd_ge01_data = {
> +	.phy_addr	= MV643XX_ETH_PHY_ADDR(18),
> +};
> +#endif
> +
> +static struct mv_sata_platform_data openrd_sata_data = {
> +	.n_ports	= 2,
> +};
> +
> +static struct mvsdio_platform_data openrd_mvsdio_data = {
> +	.gpio_card_detect = 29,	/* MPP29 used as SD card detect */
> +};
> +
> +static unsigned int openrd_mpp_config[] __initdata = {
> +	MPP29_GPIO,
> +	0
> +};
> +
> +static void __init openrd_init(void)
> +{
> +	/*
> +	 * Basic setup. Needs to be called early.
> +	 */
> +	kirkwood_init();
> +	kirkwood_mpp_conf(openrd_mpp_config);
> +
> +	kirkwood_uart0_init();
> +	kirkwood_nand_init(ARRAY_AND_SIZE(openrd_nand_parts), 25);
> +
> +	kirkwood_ehci_init();
> +
> +	kirkwood_ge00_init(&openrd_ge00_data);
> +#ifdef CONFIG_MACH_OPENRD_CLIENT
> +	if (machine_is_openrd_client())
> +		kirkwood_ge01_init(&openrd_ge01_data);
> +#endif

shouldn't it be enough to have the if(machine_is.... statement?
I didn't see why you test #ifdef, too?

Additionally it would be nice, if you could integrate the i2c / pcie init in your patch?
Please see Simons patch at:
http://lists.infradead.org/pipermail/linux-arm-kernel/2009-October/001950.html

I have to leave now, but on monday I will do the test of your patch on my openrd-base board!

Many thanks,
Dieter



More information about the linux-arm-kernel mailing list