[PATCH 3/3] PalmZ72: Add support for OV9640 camera sensor

Marek Vasut marek.vasut at gmail.com
Wed Apr 21 08:11:37 EDT 2010


Dne St 21. dubna 2010 13:44:34 Eric Miao napsal(a):
> On Wed, Apr 21, 2010 at 5:41 PM, Marek Vasut <marek.vasut at gmail.com> wrote:
> > Dne So 22. srpna 2009 08:52:06 Marek Vasut napsal(a):
> >> From 777212ce6d3bacea76281aa3d74839a3c38b32a4 Mon Sep 17 00:00:00 2001
> >> From: Marek Vasut <marek.vasut at gmail.com>
> >> Date: Sat, 22 Aug 2009 05:15:10 +0200
> >> Subject: [PATCH 3/3] PalmZ72: Add support for OV9640 camera sensor
> > 
> > Hi, was this ever merged ?
> 
> Is the required change to ov9640 merged?

Looking at this more properly, this might need a revision. The ov9640 driver is 
in though.
Cheers!
> 
> > Cheers
> > 
> >> Signed-off-by: Marek Vasut <marek.vasut at gmail.com>
> >> ---
> >>  arch/arm/mach-pxa/include/mach/palmz72.h |    5 +
> >>  arch/arm/mach-pxa/palmz72.c              |  126
> >> +++++++++++++++++++++++++++++-
> >>  2 files changed, 130 insertions(+), 1 deletions(-)
> >> 
> >> diff --git a/arch/arm/mach-pxa/include/mach/palmz72.h b/arch/arm/mach-
> >> pxa/include/mach/palmz72.h
> >> index 2806ef6..745fa3c 100644
> >> --- a/arch/arm/mach-pxa/include/mach/palmz72.h
> >> +++ b/arch/arm/mach-pxa/include/mach/palmz72.h
> >> @@ -44,6 +44,11 @@
> >>  #define GPIO_NR_PALMZ72_BT_POWER             17
> >>  #define GPIO_NR_PALMZ72_BT_RESET             83
> >> 
> >> +/* Camera */
> >> +#define GPIO_NR_PALMZ72_CAM_PWDN             56
> >> +#define GPIO_NR_PALMZ72_CAM_RESET            57
> >> +#define GPIO_NR_PALMZ72_CAM_POWER            91
> >> +
> >>  /** Initial values **/
> >> 
> >>  /* Battery */
> >> diff --git a/arch/arm/mach-pxa/palmz72.c b/arch/arm/mach-pxa/palmz72.c
> >> index c3645aa..e4449ad 100644
> >> --- a/arch/arm/mach-pxa/palmz72.c
> >> +++ b/arch/arm/mach-pxa/palmz72.c
> >> @@ -30,6 +30,7 @@
> >>  #include <linux/wm97xx_batt.h>
> >>  #include <linux/power_supply.h>
> >>  #include <linux/usb/gpio_vbus.h>
> >> +#include <linux/i2c-gpio.h>
> >> 
> >>  #include <asm/mach-types.h>
> >>  #include <asm/mach/arch.h>
> >> @@ -44,8 +45,10 @@
> >>  #include <mach/pxa27x_keypad.h>
> >>  #include <mach/udc.h>
> >>  #include <mach/palmasoc.h>
> >> -
> >>  #include <mach/pm.h>
> >> +#include <mach/camera.h>
> >> +
> >> +#include <media/soc_camera.h>
> >> 
> >>  #include "generic.h"
> >>  #include "devices.h"
> >> @@ -120,6 +123,28 @@ static unsigned long palmz72_pin_config[]
> >> __initdata = { GPIO22_GPIO,        /* LCD border color */
> >>       GPIO96_GPIO,    /* lcd power */
> >> 
> >> +     /* PXA Camera */
> >> +     GPIO81_CIF_DD_0,
> >> +     GPIO48_CIF_DD_5,
> >> +     GPIO50_CIF_DD_3,
> >> +     GPIO51_CIF_DD_2,
> >> +     GPIO52_CIF_DD_4,
> >> +     GPIO53_CIF_MCLK,
> >> +     GPIO54_CIF_PCLK,
> >> +     GPIO55_CIF_DD_1,
> >> +     GPIO84_CIF_FV,
> >> +     GPIO85_CIF_LV,
> >> +     GPIO93_CIF_DD_6,
> >> +     GPIO108_CIF_DD_7,
> >> +
> >> +     GPIO56_GPIO,
> >> +     GPIO57_GPIO,
> >> +     GPIO91_GPIO,
> >> +
> >> +     /* I2C */
> >> +     GPIO117_GPIO,   /* I2C_SCL */
> >> +     GPIO118_GPIO,   /* I2C_SDA */
> >> +
> >>       /* Misc. */
> >>       GPIO0_GPIO      | WAKEUP_ON_LEVEL_HIGH, /* power detect */
> >>       GPIO88_GPIO,                            /* green led */
> >> @@ -493,6 +518,70 @@ static struct pxafb_mach_info palmz72_lcd_screen =
> >> { .lcd_conn       = LCD_COLOR_TFT_16BPP | LCD_PCLK_EDGE_FALL, };
> >> 
> >> +/**********************************************************************
> >> *** ***** + * SoC Camera
> >> +
> >> ************************************************************************
> >> *** ***/ +struct pxacamera_platform_data palmz72_pxacamera_platform_data
> >> = { +     .flags  = PXA_CAMERA_MASTER | PXA_CAMERA_DATAWIDTH_8 |
> >> +             PXA_CAMERA_PCLK_EN | PXA_CAMERA_MCLK_EN,
> >> +     .mclk_10khz = 2600,
> >> +};
> >> +
> >> +/* Board I2C devices. */
> >> +static struct i2c_board_info __initdata palmz72_i2c_device = {
> >> +     I2C_BOARD_INFO("ov9640", 0x30),
> >> +};
> >> +
> >> +static int palmz72_camera_power(struct device *dev, int power)
> >> +{
> >> +     gpio_set_value(GPIO_NR_PALMZ72_CAM_PWDN, !power);
> >> +     mdelay(50);
> >> +     return 0;
> >> +}
> >> +
> >> +static int palmz72_camera_reset(struct device *dev)
> >> +{
> >> +     gpio_set_value(GPIO_NR_PALMZ72_CAM_RESET, 1);
> >> +     mdelay(50);
> >> +     gpio_set_value(GPIO_NR_PALMZ72_CAM_RESET, 0);
> >> +     mdelay(50);
> >> +     return 0;
> >> +}
> >> +
> >> +static struct soc_camera_link palmz72_iclink = {
> >> +     .bus_id         = 0, /* Match id in pxa27x_device_camera in
> >> device.c */ +     .board_info     = &palmz72_i2c_device,
> >> +     .i2c_adapter_id = 0,
> >> +     .module_name    = "ov96xx",
> >> +     .power          = &palmz72_camera_power,
> >> +     .reset          = &palmz72_camera_reset,
> >> +     .flags          = SOCAM_DATAWIDTH_8,
> >> +};
> >> +
> >> +static struct i2c_gpio_platform_data palmz72_i2c_bus_data = {
> >> +     .sda_pin = 118,
> >> +     .scl_pin = 117,
> >> +     .udelay  = 10,
> >> +     .timeout = 100,
> >> +};
> >> +
> >> +static struct platform_device palmz72_i2c_bus_device = {
> >> +     .name           = "i2c-gpio",
> >> +     .id             = 0, /* we use this as a replacement for i2c-pxa
> >> */ +     .dev = {
> >> +             .platform_data = &palmz72_i2c_bus_data,
> >> +     }
> >> +};
> >> +
> >> +struct platform_device palmz72_camera = {
> >> +     .name   = "soc-camera-pdrv",
> >> +     .id     = -1,
> >> +     .dev    = {
> >> +             .platform_data  = &palmz72_iclink,
> >> +     },
> >> +};
> >> +
> >> +
> >>  #ifdef CONFIG_PM
> >> 
> >>  /* We have some black magic here
> >> @@ -576,6 +665,8 @@ static struct platform_device *devices[] __initdata
> >> = { &palmz72_asoc,
> >>       &power_supply,
> >>       &palmz72_gpio_vbus,
> >> +     &palmz72_i2c_bus_device,
> >> +     &palmz72_camera,
> >>  };
> >> 
> >>  /* setup udc GPIOs initial state */
> >> @@ -587,10 +678,41 @@ static void __init palmz72_udc_init(void)
> >>       }
> >>  }
> >> 
> >> +/* Here we request the camera GPIOs and configure them. We power up the
> >> camera + * module, deassert the reset pin, but put it into powerdown
> >> (low to no power + * consumption) mode. This allows up later to bring
> >> the module up fast. */ +static inline void __init
> >> palmz72_cam_init(void) +{
> >> +     if (gpio_request(GPIO_NR_PALMZ72_CAM_PWDN, "Camera PWDN"))
> >> +             goto err1;
> >> +     if (gpio_request(GPIO_NR_PALMZ72_CAM_RESET, "Camera RESET"))
> >> +             goto err2;
> >> +     if (gpio_request(GPIO_NR_PALMZ72_CAM_POWER, "Camera DVDD"))
> >> +             goto err3;
> >> +     if (gpio_direction_output(GPIO_NR_PALMZ72_CAM_POWER, 1))
> >> +             goto err4;
> >> +     if (gpio_direction_output(GPIO_NR_PALMZ72_CAM_RESET, 0))
> >> +             goto err4;
> >> +     if (gpio_direction_output(GPIO_NR_PALMZ72_CAM_PWDN, 0))
> >> +             goto err4;
> >> +     return;
> >> +
> >> +err4:
> >> +     gpio_free(GPIO_NR_PALMZ72_CAM_POWER);
> >> +err3:
> >> +     gpio_free(GPIO_NR_PALMZ72_CAM_RESET);
> >> +err2:
> >> +     gpio_free(GPIO_NR_PALMZ72_CAM_PWDN);
> >> +err1:
> >> +     printk(KERN_ERR "Camera GPIO init failed!\n");
> >> +     return;
> >> +}
> >> +
> >>  static void __init palmz72_init(void)
> >>  {
> >>       pxa2xx_mfp_config(ARRAY_AND_SIZE(palmz72_pin_config));
> >> 
> >> +     palmz72_cam_init();
> >>       set_pxa_fb_info(&palmz72_lcd_screen);
> >>       pxa_set_mci_info(&palmz72_mci_platform_data);
> >>       palmz72_udc_init();
> >> @@ -599,6 +721,8 @@ static void __init palmz72_init(void)
> >>       pxa_set_keypad_info(&palmz72_keypad_platform_data);
> >>       wm97xx_bat_set_pdata(&wm97xx_batt_pdata);
> >> 
> >> +     pxa_set_camera_info(&palmz72_pxacamera_platform_data);
> >> +
> >>       platform_add_devices(devices, ARRAY_SIZE(devices));
> >>  }
> > 
> > _______________________________________________
> > linux-arm-kernel mailing list
> > linux-arm-kernel at lists.infradead.org
> > http://lists.infradead.org/mailman/listinfo/linux-arm-kernel



More information about the linux-arm-kernel mailing list