diff options
author | Wojciech Bieganski <wbieganski@antmicro.com> | 2015-08-26 15:26:19 +0200 |
---|---|---|
committer | Marcel Ziswiler <marcel.ziswiler@toradex.com> | 2016-11-21 15:05:08 +0100 |
commit | 017168237562b4d3af7d0aa5da9bca3a00b9a1d6 (patch) | |
tree | 868dbf9f15a118cc1fddc3cf085e9871b4414db9 /arch | |
parent | d6ab5bcf5f16ba7dcecbd54de4304cc977cba456 (diff) |
OV5640 camera support
known issues:
- works only in 1080p mode,
- vertical synchronisation glitches,
- setting queue-size in gstreamer greater than 1
results in blinking image
- every start of streaming requires reloading of
the modules
Acked-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
Acked-by: Dominik Sliwa <dominik.sliwa@toradex.com>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mach-tegra/board-ardbeg-sensors.c | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/arch/arm/mach-tegra/board-ardbeg-sensors.c b/arch/arm/mach-tegra/board-ardbeg-sensors.c index 37ba9ab3326c..c57d94f329cb 100644 --- a/arch/arm/mach-tegra/board-ardbeg-sensors.c +++ b/arch/arm/mach-tegra/board-ardbeg-sensors.c @@ -403,6 +403,47 @@ static struct platform_device ardbeg_ap1302_soc_camera_device = { }; #endif +#if IS_ENABLED(CONFIG_SOC_CAMERA_OV5640) +static int ardbeg_ov5640_power(struct device *dev, int enable) + { + if(enable) { + tegra_io_dpd_disable(&csia_io); + } else { + tegra_io_dpd_enable(&csia_io); + } + return 0; + } + +static struct i2c_board_info ardbeg_ov5640_camera_i2c_device = { + I2C_BOARD_INFO("ov5640", 0x3c), +}; + +static struct tegra_camera_platform_data ardbeg_ov5640_camera_platform_data = { + .flip_v = 0, + .flip_h = 0, + .port = TEGRA_CAMERA_PORT_CSI_A, + .lanes = 2, + .continuous_clk = 0, +}; + +static struct soc_camera_link ov5640_iclink = { + .bus_id = 0, /* This must match the .id of tegra_vi01_device */ + .board_info = &ardbeg_ov5640_camera_i2c_device, + .module_name = "ov5640", + .i2c_adapter_id = 2, + .power = ardbeg_ov5640_power, + .priv = &ardbeg_ov5640_camera_platform_data, +}; + +static struct platform_device ardbeg_ov5640_soc_camera_device = { + .name = "soc-camera-pdrv", + .id = 3, + .dev = { + .platform_data = &ov5640_iclink, + }, +}; +#endif + static struct regulator *ardbeg_vcmvdd; static int ardbeg_get_extra_regulators(void) @@ -1608,6 +1649,9 @@ static int ardbeg_camera_init(void) #if IS_ENABLED(CONFIG_SOC_CAMERA_AP1302) platform_device_register(&ardbeg_ap1302_soc_camera_device); #endif +#if IS_ENABLED(CONFIG_SOC_CAMERA_OV5640) + platform_device_register(&ardbeg_ov5640_soc_camera_device); +#endif return 0; } |