From patchwork Wed May 15 21:58:07 2013 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sergei Shtylyov X-Patchwork-Id: 2574571 Return-Path: X-Original-To: patchwork-linux-sh@patchwork.kernel.org Delivered-To: patchwork-process-083081@patchwork2.kernel.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by patchwork2.kernel.org (Postfix) with ESMTP id 3F2B1DF2A2 for ; Wed, 15 May 2013 21:58:11 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753360Ab3EOV6K (ORCPT ); Wed, 15 May 2013 17:58:10 -0400 Received: from mail-la0-f44.google.com ([209.85.215.44]:40121 "EHLO mail-la0-f44.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753301Ab3EOV6J (ORCPT ); Wed, 15 May 2013 17:58:09 -0400 Received: by mail-la0-f44.google.com with SMTP id fr10so2321543lab.17 for ; Wed, 15 May 2013 14:58:07 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20120113; h=x-received:from:organization:to:subject:date:user-agent:cc :references:in-reply-to:mime-version:content-type :content-transfer-encoding:message-id:x-gm-message-state; bh=FHCClrEaIznRWbZmG1jJOBvfdasPZTcNIkBzboaZBxQ=; b=frNemjgLOODEnJK5zWfOZm9Mew2u8DbHnNEEv0TOKjWBEHN5KvKR06ECLzgss4a3AP VZUaKCJJPBjGdVcANcIqmffDakkDUbP6HDmCOTc/PJCu8VvKCw2hwULMOR/txLi9WAnZ LN01R8mONF11mgZMerk8isHfCdqFMWFoe5VzzWzNBnQIYk8SumPlCSs5WKFomkEnaAjK ty9eqLhuav8yS7J1/9siQ82xWSwnvcWHm9bq2eQw6Ys5kOTLykG6Rq+sD2Gay/v0hcvt yLLslVfDglfX3+VCUd4IhA1IKQH8qVK4Le20bInuHAuokO0DBjQKZ5LLkW8kn7sYP8qM AWNw== X-Received: by 10.112.158.106 with SMTP id wt10mr17835593lbb.75.1368655087537; Wed, 15 May 2013 14:58:07 -0700 (PDT) Received: from wasted.dev.rtsoft.ru (ppp91-76-88-47.pppoe.mtu-net.ru. [91.76.88.47]) by mx.google.com with ESMTPSA id ay3sm1934911lab.1.2013.05.15.14.58.05 for (version=TLSv1 cipher=RC4-SHA bits=128/128); Wed, 15 May 2013 14:58:06 -0700 (PDT) From: Sergei Shtylyov Organization: Cogent Embedded To: horms@verge.net.au, linux-sh@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH v4 2/3] ARM: shmobile: Marzen: add VIN and ADV7180 support Date: Thu, 16 May 2013 01:58:07 +0400 User-Agent: KMail/1.13.5 (Linux/2.6.32.26-175.fc12.i686.PAE; KDE/4.4.5; i686; ; ) Cc: magnus.damm@gmail.com, linux@arm.linux.org.uk, matsu@igel.co.jp, vladimir.barinov@cogentembedded.com, linux-media@vger.kernel.org References: <201305160153.29827.sergei.shtylyov@cogentembedded.com> In-Reply-To: <201305160153.29827.sergei.shtylyov@cogentembedded.com> MIME-Version: 1.0 Message-Id: <201305160158.08239.sergei.shtylyov@cogentembedded.com> X-Gm-Message-State: ALoCoQkB8dLtVOWX+1KwLx2Z6WMV4ZaXQ+fAqJ2q3fa9DGAz1wz94R723jJJOh/NrpoiYPvvSMVo Sender: linux-sh-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-sh@vger.kernel.org From: Vladimir Barinov Add ADV7180 platform devices on the Marzen board, configure VIN1/3 pins, and register VIN1/3 devices with the ADV7180 specific platform data. Signed-off-by: Vladimir Barinov [Sergei: removed superfluous tabulation and inserted empty lines in the macro definition, updated the copyrights, annotated VIN platform data as '__initdata'] Signed-off-by: Sergei Shtylyov --- Changes since version 3: - changed the VIN platform device names to be R8A7779 specific; Changes since version 2: - annotated 'vin_platform_data' as '__initdata' since they're kmemdup()'ed while registering the platform devices anyway. Changes since the original posting: - used a macro to define the camera platform devices; - updated the copyrights; - refreshed the patch. arch/arm/mach-shmobile/board-marzen.c | 44 +++++++++++++++++++++++++++++++++- 1 file changed, 43 insertions(+), 1 deletion(-) -- To unsubscribe from this list: send the line "unsubscribe linux-sh" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Index: renesas/arch/arm/mach-shmobile/board-marzen.c =================================================================== --- renesas.orig/arch/arm/mach-shmobile/board-marzen.c +++ renesas/arch/arm/mach-shmobile/board-marzen.c @@ -1,8 +1,9 @@ /* * marzen board support * - * Copyright (C) 2011 Renesas Solutions Corp. + * Copyright (C) 2011, 2013 Renesas Solutions Corp. * Copyright (C) 2011 Magnus Damm + * Copyright (C) 2013 Cogent Embedded, Inc. * * 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 @@ -37,6 +38,7 @@ #include #include #include +#include #include #include #include @@ -178,12 +180,40 @@ static struct platform_device leds_devic }, }; +static struct rcar_vin_platform_data vin_platform_data __initdata = { + .flags = RCAR_VIN_BT656, +}; + +#define MARZEN_CAMERA(idx) \ +static struct i2c_board_info camera##idx##_info = { \ + I2C_BOARD_INFO("adv7180", 0x20 + (idx)), \ +}; \ + \ +static struct soc_camera_link iclink##idx##_adv7180 = { \ + .bus_id = 1 + 2 * (idx), \ + .i2c_adapter_id = 0, \ + .board_info = &camera##idx##_info, \ +}; \ + \ +static struct platform_device camera##idx##_device = { \ + .name = "soc-camera-pdrv", \ + .id = idx, \ + .dev = { \ + .platform_data = &iclink##idx##_adv7180, \ + }, \ +}; + +MARZEN_CAMERA(0); +MARZEN_CAMERA(1); + static struct platform_device *marzen_devices[] __initdata = { ð_device, &sdhi0_device, &thermal_device, &hspi_device, &leds_device, + &camera0_device, + &camera1_device, }; static const struct pinctrl_map marzen_pinctrl_map[] = { @@ -219,6 +249,16 @@ static const struct pinctrl_map marzen_p /* USB2 */ PIN_MAP_MUX_GROUP_DEFAULT("ehci-platform.1", "pfc-r8a7779", "usb2", "usb2"), + /* VIN1 */ + PIN_MAP_MUX_GROUP_DEFAULT("r8a7779-vin.1", "pfc-r8a7779", + "vin1_clk", "vin1"), + PIN_MAP_MUX_GROUP_DEFAULT("r8a7779-vin.1", "pfc-r8a7779", + "vin1_data8", "vin1"), + /* VIN3 */ + PIN_MAP_MUX_GROUP_DEFAULT("r8a7779-vin.3", "pfc-r8a7779", + "vin3_clk", "vin3"), + PIN_MAP_MUX_GROUP_DEFAULT("r8a7779-vin.3", "pfc-r8a7779", + "vin3_data8", "vin3"), }; static void __init marzen_init(void) @@ -235,6 +275,8 @@ static void __init marzen_init(void) r8a7779_add_standard_devices(); r8a7779_add_usb_phy_device(&usb_phy_platform_data); + r8a7779_add_vin_device(1, &vin_platform_data); + r8a7779_add_vin_device(3, &vin_platform_data); platform_add_devices(marzen_devices, ARRAY_SIZE(marzen_devices)); }