[PATCH] ARM: shmobile: lager: Add internal USB PCI support

Sergei Shtylyov sergei.shtylyov at cogentembedded.com
Fri Feb 14 08:54:46 EST 2014


Hello.

On 14-02-2014 7:29, Magnus Damm wrote:

> From: Valentine Barshak <valentine.barshak at cogentembedded.com>

> This adds internal PCI USB host devices to R-Car H2 Lager board.

> Signed-off-by: Valentine Barshak <valentine.barshak at cogentembedded.com>
> [damm at opensource.se: Rebased and reworked to only include USB1 and USB2]
> Signed-off-by: Magnus Damm <damm at opensource.se>
> ---

>   Written against renesas-devel-v3.14-rc2-20140213

>   arch/arm/mach-shmobile/board-lager.c |   50 ++++++++++++++++++++++++++++++++++
>   1 file changed, 50 insertions(+)

> --- 0001/arch/arm/mach-shmobile/board-lager.c
> +++ work/arch/arm/mach-shmobile/board-lager.c	2014-02-14 12:16:26.000000000 +0900
> @@ -638,6 +638,48 @@ static struct resource sdhi2_resources[]
>   	DEFINE_RES_IRQ(gic_spi(167)),
>   };
>
> +/* Internal PCI1 */
> +static const struct resource pci1_resources[] __initconst = {
> +	DEFINE_RES_MEM(0xee0b0000, 0x10000),	/* CFG */
> +	DEFINE_RES_MEM(0xee0a0000, 0x10000),	/* MEM */
> +	DEFINE_RES_IRQ(gic_spi(112)),
> +};
> +
> +static const struct platform_device_info pci1_info __initconst = {
> +	.parent		= &platform_bus,
> +	.name		= "pci-rcar-gen2",
> +	.id		= 1,
> +	.res		= pci1_resources,
> +	.num_res	= ARRAY_SIZE(pci1_resources),
> +	.dma_mask	= DMA_BIT_MASK(32),
> +};
> +
> +static void __init lager_add_usb1_device(void)

    Actually, this adds PCI device, not USB, so the name is strange.
Also, I doubt that such functions are really necessary.

> +{
> +	platform_device_register_full(&pci1_info);
> +}
> +
> +/* Internal PCI2 */
> +static const struct resource pci2_resources[] __initconst = {
> +	DEFINE_RES_MEM(0xee0d0000, 0x10000),	/* CFG */
> +	DEFINE_RES_MEM(0xee0c0000, 0x10000),	/* MEM */
> +	DEFINE_RES_IRQ(gic_spi(113)),
> +};
> +
> +static const struct platform_device_info pci2_info __initconst = {
> +	.parent		= &platform_bus,
> +	.name		= "pci-rcar-gen2",
> +	.id		= 2,
> +	.res		= pci2_resources,
> +	.num_res	= ARRAY_SIZE(pci2_resources),
> +	.dma_mask	= DMA_BIT_MASK(32),
> +};
> +

    I suspect the PCI resources and info could be wrapped by macros and then 
instantiated by using only 2 lines.

WBR, Sergei




More information about the linux-arm-kernel mailing list