On Fri, 23 Nov 2012, twang13@xxxxxxxxxxx wrote: > From: Albert Wang <twang13@xxxxxxxxxxx> > > This patch adds the soc_camera support in mcam core. > > It creates the file mcam-core-soc.c and mcam-core-soc.h > to support soc_camera in mcam core. > > To use the soc_camera feature, platform driver, such as mmp-driver.c, > should also be modified. > > Signed-off-by: Libin Yang <lbyang@xxxxxxxxxxx> > Signed-off-by: Albert Wang <twang13@xxxxxxxxxxx> > --- > drivers/media/platform/marvell-ccic/Makefile | 2 + > .../media/platform/marvell-ccic/mcam-core-soc.c | 414 ++++++++++++++++++++ > .../media/platform/marvell-ccic/mcam-core-soc.h | 19 + > drivers/media/platform/marvell-ccic/mcam-core.c | 13 +- > drivers/media/platform/marvell-ccic/mcam-core.h | 37 ++ > include/media/mmp-camera.h | 3 + > 6 files changed, 485 insertions(+), 3 deletions(-) > create mode 100644 drivers/media/platform/marvell-ccic/mcam-core-soc.c > create mode 100644 drivers/media/platform/marvell-ccic/mcam-core-soc.h > > diff --git a/drivers/media/platform/marvell-ccic/Makefile b/drivers/media/platform/marvell-ccic/Makefile > index 595ebdf..b3e87d4 100755 > --- a/drivers/media/platform/marvell-ccic/Makefile > +++ b/drivers/media/platform/marvell-ccic/Makefile > @@ -4,3 +4,5 @@ cafe_ccic-y := cafe-driver.o mcam-core.o > obj-$(CONFIG_VIDEO_MMP_CAMERA) += mmp_camera_standard.o > mmp_camera_standard-y := mmp-driver.o mcam-core.o mcam-core-standard.o > > +obj-$(CONFIG_VIDEO_MMP_SOC_CAMERA) += mmp_camera_soc.o > +mmp_camera_soc-y := mmp-driver.o mcam-core.o mcam-core-soc.o > diff --git a/drivers/media/platform/marvell-ccic/mcam-core-soc.c b/drivers/media/platform/marvell-ccic/mcam-core-soc.c > new file mode 100644 > index 0000000..a0df8b4 > --- /dev/null > +++ b/drivers/media/platform/marvell-ccic/mcam-core-soc.c > @@ -0,0 +1,414 @@ > +/* > + * The Marvell camera soc core. This device appears in a number of settings, > + * so it needs platform-specific support outside of the core. > + * > + * Copyright (C) 2009-2012 Marvell International Ltd. > + * > + * Author: Libin Yang <lbyang@xxxxxxxxxxx> > + * Albert Wang <twang13@xxxxxxxxxxx> > + * > + */ > +#include <linux/kernel.h> > +#include <linux/module.h> > +#include <linux/fs.h> > +#include <linux/mm.h> > +#include <linux/i2c.h> > +#include <linux/interrupt.h> You really need the above 3 headers? > +#include <linux/spinlock.h> > +#include <linux/slab.h> > +#include <linux/device.h> > +#include <linux/wait.h> > +#include <linux/list.h> > +#include <linux/dma-mapping.h> > +#include <linux/delay.h> > +#include <linux/vmalloc.h> really? > +#include <linux/io.h> > +#include <linux/videodev2.h> > +#include <media/v4l2-device.h> > +#include <media/v4l2-ioctl.h> > +#include <media/v4l2-chip-ident.h> > +#include <media/videobuf2-vmalloc.h> and the 2 above? > +#include <media/videobuf2-dma-contig.h> > +#include <media/soc_camera.h> > +#include <media/soc_mediabus.h> please, double-check, which headers you really need. I don't mean, that only headers needed for compilation should be included, some helpers you should include explicitly, even if they're already included via some other headers. But headers, from which nothing is used, shouldn't be included "just in case" ;-) > + > +#include "mcam-core.h" > +#include "mcam-core-soc.h" > + > +static const enum v4l2_mbus_pixelcode mcam_def_mbus_code = > + V4L2_MBUS_FMT_YUYV8_2X8; > + > +static const struct soc_mbus_pixelfmt mcam_formats[] = { > + { > + .fourcc = V4L2_PIX_FMT_UYVY, > + .name = "YUV422PACKED", > + .bits_per_sample = 8, > + .packing = SOC_MBUS_PACKING_2X8_PADLO, > + .order = SOC_MBUS_ORDER_LE, > + }, > + { > + .fourcc = V4L2_PIX_FMT_YUV422P, > + .name = "YUV422PLANAR", > + .bits_per_sample = 8, > + .packing = SOC_MBUS_PACKING_2X8_PADLO, > + .order = SOC_MBUS_ORDER_LE, > + }, > + { > + .fourcc = V4L2_PIX_FMT_YUV420, > + .name = "YUV420PLANAR", > + .bits_per_sample = 12, > + .packing = SOC_MBUS_PACKING_NONE, > + .order = SOC_MBUS_ORDER_LE, > + }, > + { > + .fourcc = V4L2_PIX_FMT_YVU420, > + .name = "YVU420PLANAR", > + .bits_per_sample = 12, > + .packing = SOC_MBUS_PACKING_NONE, > + .order = SOC_MBUS_ORDER_LE, > + }, > +}; > + > +static const struct v4l2_pix_format mcam_def_pix_format = { > + .width = VGA_WIDTH, > + .height = VGA_HEIGHT, > + .pixelformat = V4L2_PIX_FMT_YUYV, > + .field = V4L2_FIELD_NONE, > + .bytesperline = VGA_WIDTH*2, > + .sizeimage = VGA_WIDTH*VGA_HEIGHT*2, > +}; Hm, you have the same (or similar) in mcam common code. We can duplicate it for now, but would be good to consolidate later. > + > +static int mcam_camera_add_device(struct soc_camera_device *icd) > +{ > + struct soc_camera_host *ici = to_soc_camera_host(icd->parent); > + struct mcam_camera *mcam = ici->priv; > + int ret = 0; > + > + if (mcam->icd) > + return -EBUSY; > + > + mcam->frame_complete = mcam_dma_contig_done; > + mcam->frame_state.frames = 0; > + mcam->frame_state.singles = 0; > + mcam->frame_state.delivered = 0; > + > + mcam->flags = 0; > + mcam->icd = icd; > + mcam->state = S_IDLE; > + mcam->dma_setup = mcam_ctlr_dma_contig; > + mcam_ctlr_power_up(mcam); > + mcam_ctlr_stop(mcam); > + mcam_set_config_needed(mcam, 1); > + mcam_reg_write(mcam, REG_CTRL1, > + C1_RESERVED | C1_DMAPOSTED); > + mcam_reg_write(mcam, REG_CLKCTRL, > + (mcam->mclk_src << 29) | mcam->mclk_div); > + cam_dbg(mcam, "camera: set sensor mclk = %dMHz\n", mcam->mclk_min); > + /* > + * Need sleep 1ms to wait for CCIC stable > + * This is a workround for OV5640 MIPI > + * TODO: Fix me in the future > + */ > + usleep_range(1000, 2000); > + > + /* > + * Mask all interrupts. > + */ > + mcam_reg_write(mcam, REG_IRQMASK, 0); > + ret = sensor_call(mcam, core, init, 0); > + /* > + * When sensor_call return -ENOIOCTLCMD, > + * means No ioctl command > + */ > + if ((ret < 0) && (ret != -ENOIOCTLCMD) && (ret != -ENODEV)) { > + dev_err(icd->parent, > + "camera: Failed to initialize subdev: %d\n", ret); > + return ret; > + } > + > + return 0; > +} > + > +static void mcam_camera_remove_device(struct soc_camera_device *icd) > +{ > + struct soc_camera_host *ici = to_soc_camera_host(icd->parent); > + struct mcam_camera *mcam = ici->priv; > + > + BUG_ON(icd != mcam->icd); > + cam_dbg(mcam, "Release %d frames, %d singles, %d delivered\n", > + mcam->frame_state.frames, mcam->frame_state.singles, > + mcam->frame_state.delivered); > + mcam_config_mipi(mcam, 0); > + mcam_ctlr_power_down(mcam); > + mcam->icd = NULL; > +} > + > +static int mcam_camera_set_fmt(struct soc_camera_device *icd, > + struct v4l2_format *f) > +{ > + struct soc_camera_host *ici = to_soc_camera_host(icd->parent); > + struct mcam_camera *mcam = ici->priv; > + const struct soc_camera_format_xlate *xlate = NULL; > + struct v4l2_mbus_framefmt mf; > + struct v4l2_pix_format *pix = &f->fmt.pix; > + int ret = 0; No need to initialise ret. > + > + cam_dbg(mcam, "camera: set_fmt: %c, width = %u, height = %u\n", > + pix->pixelformat, pix->width, pix->height); > + xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat); > + if (!xlate) { > + cam_err(mcam, "camera: format: %c not found\n", > + pix->pixelformat); > + return -EINVAL; > + } > + > + mf.width = pix->width; > + mf.height = pix->height; > + mf.field = V4L2_FIELD_NONE; > + mf.colorspace = pix->colorspace; > + mf.code = xlate->code; > + > + ret = sensor_call(mcam, video, s_mbus_fmt, &mf); > + if (ret < 0) { > + cam_err(mcam, "camera: set_fmt failed %d\n", __LINE__); > + return ret; > + } > + > + if (mf.code != xlate->code) { > + cam_err(mcam, "camera: wrong code %s %d\n", __func__, __LINE__); > + return -EINVAL; > + } > + > + pix->width = mf.width; > + pix->height = mf.height; > + pix->field = mf.field; > + pix->colorspace = mf.colorspace; > + mcam->pix_format.sizeimage = pix->sizeimage; > + icd->current_fmt = xlate; > + > + memcpy(&(mcam->pix_format), pix, sizeof(struct v4l2_pix_format)); > + mcam_ctlr_image(mcam); > + mcam_set_config_needed(mcam, 1); > + > + return ret; > +} > + > +static int mcam_camera_try_fmt(struct soc_camera_device *icd, > + struct v4l2_format *f) > +{ > + struct soc_camera_host *ici = to_soc_camera_host(icd->parent); > + struct mcam_camera *mcam = ici->priv; > + const struct soc_camera_format_xlate *xlate; > + struct v4l2_pix_format *pix = &f->fmt.pix; > + struct v4l2_mbus_framefmt mf; > + __u32 pixfmt = pix->pixelformat; > + int ret = 0; No need to initialise ret. > + > + xlate = soc_camera_xlate_by_fourcc(icd, pixfmt); > + if (!xlate) { > + cam_err(mcam, "camera: format: %c not found\n", > + pix->pixelformat); > + return -EINVAL; You shouldn't fail .try_fmt() (unless something really bad happens). Just pick up a default supported format. > + } > + > + if (pix->bytesperline < 0) > + return pix->bytesperline; > + > + /* > + * limit to sensor capabilities > + */ > + mf.width = pix->width; > + mf.height = pix->height; > + mf.field = V4L2_FIELD_NONE; > + mf.colorspace = pix->colorspace; > + mf.code = xlate->code; > + > + ret = sensor_call(mcam, video, try_mbus_fmt, &mf); > + if (ret < 0) > + return ret; > + > + pix->width = mf.width; > + pix->height = mf.height; > + pix->colorspace = mf.colorspace; > + > + switch (mf.field) { > + case V4L2_FIELD_ANY: > + case V4L2_FIELD_NONE: > + pix->field = V4L2_FIELD_NONE; > + break; > + default: > + cam_err(mcam, "camera: Field type %d unsupported.\n", mf.field); > + ret = -EINVAL; > + break; Also here: just hard-code NONE. > + } > + > + return ret; > +} > + > +static int mcam_camera_set_parm(struct soc_camera_device *icd, > + struct v4l2_streamparm *para) > +{ > + return 0; > +} Just don't implement it. > + > +static int mcam_camera_init_videobuf(struct vb2_queue *q, > + struct soc_camera_device *icd) > +{ > + q->type = V4L2_BUF_TYPE_VIDEO_CAPTURE; > + q->io_modes = VB2_USERPTR | VB2_MMAP; > + q->drv_priv = icd; > + q->ops = &mcam_soc_vb2_ops; > + q->mem_ops = &vb2_dma_contig_memops; > + q->buf_struct_size = sizeof(struct mcam_vb_buffer); > + > + return vb2_queue_init(q); > +} > + > +static unsigned int mcam_camera_poll(struct file *file, poll_table *pt) > +{ > + struct soc_camera_device *icd = file->private_data; > + > + return vb2_poll(&icd->vb2_vidq, file, pt); > +} > + > +static int mcam_camera_querycap(struct soc_camera_host *ici, > + struct v4l2_capability *cap) > +{ > + struct mcam_camera *mcam = ici->priv; > + > + cap->device_caps = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_STREAMING; > + cap->capabilities = cap->device_caps | V4L2_CAP_DEVICE_CAPS; > + > + strcpy(cap->card, mcam->card_name); > + strcpy(cap->driver, "marvell_ccic"); > + > + return 0; > +} > + > +static int mcam_camera_set_bus_param(struct soc_camera_device *icd) > +{ > + return 0; > +} > + > +static int mcam_camera_get_formats(struct soc_camera_device *icd, u32 idx, > + struct soc_camera_format_xlate *xlate) > +{ > + struct soc_camera_host *ici = to_soc_camera_host(icd->parent); > + struct mcam_camera *mcam = ici->priv; > + enum v4l2_mbus_pixelcode code; > + const struct soc_mbus_pixelfmt *fmt; > + int formats = 0, ret = 0, i; > + > + ret = sensor_call(mcam, video, enum_mbus_fmt, idx, &code); > + if (ret < 0) > + /* > + * No more formats > + */ > + return 0; > + > + fmt = soc_mbus_get_fmtdesc(code); > + if (!fmt) { > + cam_err(mcam, "camera: Invalid format #%u: %d\n", idx, code); > + return 0; > + } > + > + switch (code) { > + /* > + * Refer to mbus_fmt struct > + */ > + case V4L2_MBUS_FMT_UYVY8_2X8: > + /* > + * Add support for YUV420 and YUV422P > + */ > + formats = ARRAY_SIZE(mcam_formats); > + if (xlate) { > + for (i = 0; i < ARRAY_SIZE(mcam_formats); i++) { You can convert from V4L2_MBUS_FMT_UYVY8_2X8 to all these 4 formats? Wow... > + xlate->host_fmt = &mcam_formats[i]; > + xlate->code = code; > + xlate++; > + } > + } > + return formats; > + case V4L2_MBUS_FMT_JPEG_1X8: > + if (xlate) > + cam_err(mcam, "camera: Providing format: %s\n", Is this really an error? > + fmt->name); > + break; > + default: > + /* > + * camera controller can not support > + * this format, which might supported by the sensor > + */ > + cam_warn(mcam, "camera: Not support fmt: %s\n", fmt->name); > + return 0; > + } > + > + formats++; > + if (xlate) { > + xlate->host_fmt = fmt; > + xlate->code = code; > + xlate++; > + } > + > + return formats; > +} > + > +struct soc_camera_host_ops mcam_soc_camera_host_ops = { > + .owner = THIS_MODULE, > + .add = mcam_camera_add_device, > + .remove = mcam_camera_remove_device, > + .set_fmt = mcam_camera_set_fmt, > + .try_fmt = mcam_camera_try_fmt, > + .set_parm = mcam_camera_set_parm, > + .init_videobuf2 = mcam_camera_init_videobuf, > + .poll = mcam_camera_poll, > + .querycap = mcam_camera_querycap, > + .set_bus_param = mcam_camera_set_bus_param, > + .get_formats = mcam_camera_get_formats, > +}; > + > +int mcam_soc_camera_host_register(struct mcam_camera *mcam) > +{ > + mcam->soc_host.drv_name = "mmp-camera"; > + mcam->soc_host.ops = &mcam_soc_camera_host_ops; > + mcam->soc_host.priv = mcam; > + mcam->soc_host.v4l2_dev.dev = mcam->dev; > + mcam->soc_host.nr = mcam->ccic_id; > + return soc_camera_host_register(&mcam->soc_host); > +} > + > +int mccic_register(struct mcam_camera *cam) > +{ > + /* > + * Validate the requested buffer mode. > + */ > + if (!mcam_buffer_mode_supported(cam->buffer_mode)) { > + cam_err(cam, "marvell-cam: buffer mode %d unsupported\n", > + cam->buffer_mode); > + return -EINVAL; > + } > + > + mutex_init(&cam->s_mutex); > + cam->state = S_NOTREADY; > + mcam_set_config_needed(cam, 1); > + cam->pix_format = mcam_def_pix_format; > + cam->mbus_code = mcam_def_mbus_code; > + INIT_LIST_HEAD(&cam->buffers); > +/* mcam_ctlr_init(cam); */ Please, remove for the final submission. If you like you can put a comment like "TODO: add control support" > + > + return 0; > +} > + > +void mccic_shutdown(struct mcam_camera *cam) > +{ > + /* > + * If we have no users (and we really, really should have no > + * users) the device will already be powered down. Trying to > + * take it down again will wedge the machine, which is frowned > + * upon. > + */ > + if (cam->users > 0) { > + cam_warn(cam, "Removing a device with users!\n"); > + mcam_ctlr_power_down(cam); > + } > + vb2_queue_release(&cam->vb_queue); hm, something is missing here? > diff --git a/drivers/media/platform/marvell-ccic/mcam-core-soc.h b/drivers/media/platform/marvell-ccic/mcam-core-soc.h > new file mode 100644 > index 0000000..a5b5fa6 > --- /dev/null > +++ b/drivers/media/platform/marvell-ccic/mcam-core-soc.h > @@ -0,0 +1,19 @@ > +/* > + * Marvell camera core structures. > + * > + * Copyright (C) 2009-2012 Marvell International Ltd. > + * > + * Author: Libin Yang <lbyang@xxxxxxxxxxx> > + * Albert Wang <twang13@xxxxxxxxxxx> > + * > + */ > +extern const struct vb2_ops mcam_soc_vb2_ops; > + > +extern void mcam_ctlr_power_up(struct mcam_camera *cam); > +extern void mcam_ctlr_power_down(struct mcam_camera *cam); > +extern void mcam_dma_contig_done(struct mcam_camera *cam, int frame); > +extern void mcam_ctlr_stop(struct mcam_camera *cam); > +extern int mcam_config_mipi(struct mcam_camera *mcam, int enable); > +extern void mcam_ctlr_image(struct mcam_camera *cam); > +extern void mcam_set_config_needed(struct mcam_camera *cam, int needed); > +extern void mcam_ctlr_dma_contig(struct mcam_camera *cam); > diff --git a/drivers/media/platform/marvell-ccic/mcam-core.c b/drivers/media/platform/marvell-ccic/mcam-core.c > index 189463c..3b05d8c 100755 > --- a/drivers/media/platform/marvell-ccic/mcam-core.c > +++ b/drivers/media/platform/marvell-ccic/mcam-core.c > @@ -3,6 +3,12 @@ > * so it needs platform-specific support outside of the core. > * > * Copyright 2011 Jonathan Corbet corbet@xxxxxxx > + * > + * History: > + * Support Soc Camera > + * Support MIPI interface and Dual CCICs in Soc Camera mode > + * Sep-2012: Libin Yang <lbyang@xxxxxxxxxxx> > + * Albert Wang <twang13@xxxxxxxxxxx> Well, that'll be up to Jon to decide, but I think such "history" entries in file header comments aren't favoured... I think, you usually just add your copyright, where you add significant amounts of code. > */ > #include <linux/kernel.h> > #include <linux/module.h> > @@ -704,8 +710,7 @@ static void mcam_ctlr_irq_disable(struct mcam_camera *cam) > mcam_reg_clear_bit(cam, REG_IRQMASK, FRAMEIRQS); > } > > - > - > +#ifndef CONFIG_VIDEO_MRVL_SOC_CAMERA > void mcam_ctlr_init(struct mcam_camera *cam) Why do you have to disable this, if you commented it out in your mccic_register()? > { > unsigned long flags; > @@ -727,7 +732,7 @@ void mcam_ctlr_init(struct mcam_camera *cam) > mcam_reg_write_mask(cam, REG_CLKCTRL, 2, CLK_DIV_MASK); > spin_unlock_irqrestore(&cam->dev_lock, flags); > } > - > +#endif > > /* > * Stop the controller, and don't return until we're really sure that no > @@ -802,6 +807,7 @@ int __mcam_cam_reset(struct mcam_camera *cam) > return sensor_call(cam, core, reset, 0); > } > > +#ifndef CONFIG_VIDEO_MRVL_SOC_CAMERA Same here? In general, please, try to avoid adding preprocessor conditionals to the code. > /* > * We have found the sensor on the i2c. Let's try to have a > * conversation. > @@ -838,6 +844,7 @@ out: > mutex_unlock(&cam->s_mutex); > return ret; > } > +#endif > > /* > * Configure the sensor to match the parameters we have. Caller should > diff --git a/drivers/media/platform/marvell-ccic/mcam-core.h b/drivers/media/platform/marvell-ccic/mcam-core.h > index bba8aa0..e149aa3 100755 > --- a/drivers/media/platform/marvell-ccic/mcam-core.h > +++ b/drivers/media/platform/marvell-ccic/mcam-core.h > @@ -2,6 +2,12 @@ > * Marvell camera core structures. > * > * Copyright 2011 Jonathan Corbet corbet@xxxxxxx > + * > + * History: > + * Support Soc Camera > + * Support MIPI interface and Dual CCICs in Soc Camera mode > + * Sep-2012: Libin Yang <lbyang@xxxxxxxxxxx> > + * Albert Wang <twang13@xxxxxxxxxxx> > */ > #ifndef _MCAM_CORE_H > #define _MCAM_CORE_H > @@ -10,6 +16,8 @@ > #include <media/v4l2-common.h> > #include <media/v4l2-dev.h> > #include <media/videobuf2-core.h> > +#include <media/soc_camera.h> > +#include <media/soc_mediabus.h> > > /* > * Create our own symbols for the supported buffer modes, but, for now, > @@ -32,8 +40,13 @@ > #error One of the videobuf buffer modes must be selected in the config > #endif > > +#ifdef CONFIG_VIDEO_MRVL_SOC_CAMERA > +#define sensor_call(cam, o, f, args...) \ > + v4l2_subdev_call(soc_camera_to_subdev(cam->icd), o, f, ##args) > +#else > #define sensor_call(cam, o, f, args...) \ > v4l2_subdev_call(cam->sensor, o, f, ##args) > +#endif > > /* > * Debugging and related. > @@ -102,6 +115,10 @@ struct mmp_frame_state { > */ > #define NR_MCAM_CLK 4 > struct mcam_camera { > +#ifdef CONFIG_VIDEO_MRVL_SOC_CAMERA > + struct soc_camera_host soc_host; > + struct soc_camera_device *icd; > +#endif > /* > * These fields should be set by the platform code prior to > * calling mcam_register(). > @@ -115,6 +132,11 @@ struct mcam_camera { > short int use_smbus; /* SMBUS or straight I2c? */ > enum mcam_buffer_mode buffer_mode; > > + int mclk_min; > + int mclk_src; > + int mclk_div; > + char *card_name; > + > int ccic_id; > /* MIPI support */ > int bus_type; > @@ -260,10 +282,20 @@ static inline void mcam_reg_set_bit(struct mcam_camera *cam, > mcam_reg_write_mask(cam, reg, val, val); > } > > +#ifdef CONFIG_VIDEO_MRVL_SOC_CAMERA > +static inline struct mcam_camera *get_mcam(struct vb2_queue *vq) > +{ > + struct soc_camera_device *icd = container_of(vq, > + struct soc_camera_device, vb2_vidq); > + struct soc_camera_host *ici = to_soc_camera_host(icd->parent); > + return ici->priv; > +} > +#else > static inline struct mcam_camera *get_mcam(struct vb2_queue *vq) > { > return vb2_get_drv_priv(vq); > } > +#endif > > /* > * Functions for use by platform code. > @@ -275,6 +307,9 @@ void mccic_shutdown(struct mcam_camera *cam); > void mccic_suspend(struct mcam_camera *cam); > int mccic_resume(struct mcam_camera *cam); > #endif > +#ifdef CONFIG_VIDEO_MRVL_SOC_CAMERA > +int mcam_soc_camera_host_register(struct mcam_camera *mcam); > +#endif > > /* > * Register definitions for the m88alp01 camera interface. Offsets in bytes > @@ -378,6 +413,7 @@ int mccic_resume(struct mcam_camera *cam); > > /* Bits below C1_444ALPHA are not present in Cafe */ > #define REG_CTRL1 0x40 /* Control 1 */ > +#define C1_RESERVED 0x0000003c /* Reserved and shouldn't be changed */ > #define C1_CLKGATE 0x00000001 /* Sensor clock gate */ > #define C1_DESC_ENA 0x00000100 /* DMA descriptor enable */ > #define C1_DESC_3WORD 0x00000200 /* Three-word descriptors used */ > @@ -389,6 +425,7 @@ int mccic_resume(struct mcam_camera *cam); > #define C1_DMAB_MASK 0x06000000 > #define C1_TWOBUFS 0x08000000 /* Use only two DMA buffers */ > #define C1_PWRDWN 0x10000000 /* Power down */ > +#define C1_DMAPOSTED 0x40000000 /* DMA Posted Select */ > > #define REG_CTRL3 0x1ec /* CCIC parallel mode */ > #define REG_CLKCTRL 0x88 /* Clock control */ > diff --git a/include/media/mmp-camera.h b/include/media/mmp-camera.h > index e161ae0..36891ed 100755 > --- a/include/media/mmp-camera.h > +++ b/include/media/mmp-camera.h > @@ -6,6 +6,9 @@ struct mmp_camera_platform_data { > struct platform_device *i2c_device; > int sensor_power_gpio; > int sensor_reset_gpio; > + int mclk_min; > + int mclk_src; > + int mclk_div; > /* > * MIPI support > */ > -- > 1.7.9.5 > Thanks Guennadi --- Guennadi Liakhovetski, Ph.D. Freelance Open-Source Software Developer http://www.open-technology.de/ -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html