1/*
2 * Copyright (C) 2008-2009 Texas Instruments Inc
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 *
18 * Driver name : VPFE Capture driver
19 *    VPFE Capture driver allows applications to capture and stream video
20 *    frames on DaVinci SoCs (DM6446, DM355 etc) from a YUV source such as
21 *    TVP5146 or  Raw Bayer RGB image data from an image sensor
22 *    such as Microns' MT9T001, MT9T031 etc.
23 *
24 *    These SoCs have, in common, a Video Processing Subsystem (VPSS) that
25 *    consists of a Video Processing Front End (VPFE) for capturing
26 *    video/raw image data and Video Processing Back End (VPBE) for displaying
27 *    YUV data through an in-built analog encoder or Digital LCD port. This
28 *    driver is for capture through VPFE. A typical EVM using these SoCs have
29 *    following high level configuration.
30 *
31 *
32 *    decoder(TVP5146/		YUV/
33 * 	     MT9T001)   -->  Raw Bayer RGB ---> MUX -> VPFE (CCDC/ISIF)
34 *    				data input              |      |
35 *							V      |
36 *						      SDRAM    |
37 *							       V
38 *							   Image Processor
39 *							       |
40 *							       V
41 *							     SDRAM
42 *    The data flow happens from a decoder connected to the VPFE over a
43 *    YUV embedded (BT.656/BT.1120) or separate sync or raw bayer rgb interface
44 *    and to the input of VPFE through an optional MUX (if more inputs are
45 *    to be interfaced on the EVM). The input data is first passed through
46 *    CCDC (CCD Controller, a.k.a Image Sensor Interface, ISIF). The CCDC
47 *    does very little or no processing on YUV data and does pre-process Raw
48 *    Bayer RGB data through modules such as Defect Pixel Correction (DFC)
49 *    Color Space Conversion (CSC), data gain/offset etc. After this, data
50 *    can be written to SDRAM or can be connected to the image processing
51 *    block such as IPIPE (on DM355 only).
52 *
53 *    Features supported
54 *  		- MMAP IO
55 *		- Capture using TVP5146 over BT.656
56 *		- support for interfacing decoders using sub device model
57 *		- Work with DM355 or DM6446 CCDC to do Raw Bayer RGB/YUV
58 *		  data capture to SDRAM.
59 *    TODO list
60 *		- Support multiple REQBUF after open
61 *		- Support for de-allocating buffers through REQBUF
62 *		- Support for Raw Bayer RGB capture
63 *		- Support for chaining Image Processor
64 *		- Support for static allocation of buffers
65 *		- Support for USERPTR IO
66 *		- Support for STREAMON before QBUF
67 *		- Support for control ioctls
68 */
69#include <linux/module.h>
70#include <linux/slab.h>
71#include <linux/init.h>
72#include <linux/platform_device.h>
73#include <linux/interrupt.h>
74#include <media/v4l2-common.h>
75#include <linux/io.h>
76#include <media/davinci/vpfe_capture.h>
77#include "ccdc_hw_device.h"
78
79static int debug;
80static u32 numbuffers = 3;
81static u32 bufsize = (720 * 576 * 2);
82
83module_param(numbuffers, uint, S_IRUGO);
84module_param(bufsize, uint, S_IRUGO);
85module_param(debug, int, 0644);
86
87MODULE_PARM_DESC(numbuffers, "buffer count (default:3)");
88MODULE_PARM_DESC(bufsize, "buffer size in bytes (default:720 x 576 x 2)");
89MODULE_PARM_DESC(debug, "Debug level 0-1");
90
91MODULE_DESCRIPTION("VPFE Video for Linux Capture Driver");
92MODULE_LICENSE("GPL");
93MODULE_AUTHOR("Texas Instruments");
94
95/* standard information */
96struct vpfe_standard {
97	v4l2_std_id std_id;
98	unsigned int width;
99	unsigned int height;
100	struct v4l2_fract pixelaspect;
101	/* 0 - progressive, 1 - interlaced */
102	int frame_format;
103};
104
105/* ccdc configuration */
106struct ccdc_config {
107	/* This make sure vpfe is probed and ready to go */
108	int vpfe_probed;
109	/* name of ccdc device */
110	char name[32];
111};
112
113/* data structures */
114static struct vpfe_config_params config_params = {
115	.min_numbuffers = 3,
116	.numbuffers = 3,
117	.min_bufsize = 720 * 480 * 2,
118	.device_bufsize = 720 * 576 * 2,
119};
120
121/* ccdc device registered */
122static struct ccdc_hw_device *ccdc_dev;
123/* lock for accessing ccdc information */
124static DEFINE_MUTEX(ccdc_lock);
125/* ccdc configuration */
126static struct ccdc_config *ccdc_cfg;
127
128const struct vpfe_standard vpfe_standards[] = {
129	{V4L2_STD_525_60, 720, 480, {11, 10}, 1},
130	{V4L2_STD_625_50, 720, 576, {54, 59}, 1},
131};
132
133/* Used when raw Bayer image from ccdc is directly captured to SDRAM */
134static const struct vpfe_pixel_format vpfe_pix_fmts[] = {
135	{
136		.fmtdesc = {
137			.index = 0,
138			.type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
139			.description = "Bayer GrRBGb 8bit A-Law compr.",
140			.pixelformat = V4L2_PIX_FMT_SBGGR8,
141		},
142		.bpp = 1,
143	},
144	{
145		.fmtdesc = {
146			.index = 1,
147			.type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
148			.description = "Bayer GrRBGb - 16bit",
149			.pixelformat = V4L2_PIX_FMT_SBGGR16,
150		},
151		.bpp = 2,
152	},
153	{
154		.fmtdesc = {
155			.index = 2,
156			.type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
157			.description = "Bayer GrRBGb 8bit DPCM compr.",
158			.pixelformat = V4L2_PIX_FMT_SGRBG10DPCM8,
159		},
160		.bpp = 1,
161	},
162	{
163		.fmtdesc = {
164			.index = 3,
165			.type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
166			.description = "YCbCr 4:2:2 Interleaved UYVY",
167			.pixelformat = V4L2_PIX_FMT_UYVY,
168		},
169		.bpp = 2,
170	},
171	{
172		.fmtdesc = {
173			.index = 4,
174			.type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
175			.description = "YCbCr 4:2:2 Interleaved YUYV",
176			.pixelformat = V4L2_PIX_FMT_YUYV,
177		},
178		.bpp = 2,
179	},
180	{
181		.fmtdesc = {
182			.index = 5,
183			.type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
184			.description = "Y/CbCr 4:2:0 - Semi planar",
185			.pixelformat = V4L2_PIX_FMT_NV12,
186		},
187		.bpp = 1,
188	},
189};
190
191/*
192 * vpfe_lookup_pix_format()
193 * lookup an entry in the vpfe pix format table based on pix_format
194 */
195static const struct vpfe_pixel_format *vpfe_lookup_pix_format(u32 pix_format)
196{
197	int i;
198
199	for (i = 0; i < ARRAY_SIZE(vpfe_pix_fmts); i++) {
200		if (pix_format == vpfe_pix_fmts[i].fmtdesc.pixelformat)
201			return &vpfe_pix_fmts[i];
202	}
203	return NULL;
204}
205
206/*
207 * vpfe_register_ccdc_device. CCDC module calls this to
208 * register with vpfe capture
209 */
210int vpfe_register_ccdc_device(struct ccdc_hw_device *dev)
211{
212	int ret = 0;
213	printk(KERN_NOTICE "vpfe_register_ccdc_device: %s\n", dev->name);
214
215	BUG_ON(!dev->hw_ops.open);
216	BUG_ON(!dev->hw_ops.enable);
217	BUG_ON(!dev->hw_ops.set_hw_if_params);
218	BUG_ON(!dev->hw_ops.configure);
219	BUG_ON(!dev->hw_ops.set_buftype);
220	BUG_ON(!dev->hw_ops.get_buftype);
221	BUG_ON(!dev->hw_ops.enum_pix);
222	BUG_ON(!dev->hw_ops.set_frame_format);
223	BUG_ON(!dev->hw_ops.get_frame_format);
224	BUG_ON(!dev->hw_ops.get_pixel_format);
225	BUG_ON(!dev->hw_ops.set_pixel_format);
226	BUG_ON(!dev->hw_ops.set_image_window);
227	BUG_ON(!dev->hw_ops.get_image_window);
228	BUG_ON(!dev->hw_ops.get_line_length);
229	BUG_ON(!dev->hw_ops.getfid);
230
231	mutex_lock(&ccdc_lock);
232	if (NULL == ccdc_cfg) {
233		/*
234		 * TODO. Will this ever happen? if so, we need to fix it.
235		 * Proabably we need to add the request to a linked list and
236		 * walk through it during vpfe probe
237		 */
238		printk(KERN_ERR "vpfe capture not initialized\n");
239		ret = -EFAULT;
240		goto unlock;
241	}
242
243	if (strcmp(dev->name, ccdc_cfg->name)) {
244		/* ignore this ccdc */
245		ret = -EINVAL;
246		goto unlock;
247	}
248
249	if (ccdc_dev) {
250		printk(KERN_ERR "ccdc already registered\n");
251		ret = -EINVAL;
252		goto unlock;
253	}
254
255	ccdc_dev = dev;
256unlock:
257	mutex_unlock(&ccdc_lock);
258	return ret;
259}
260EXPORT_SYMBOL(vpfe_register_ccdc_device);
261
262/*
263 * vpfe_unregister_ccdc_device. CCDC module calls this to
264 * unregister with vpfe capture
265 */
266void vpfe_unregister_ccdc_device(struct ccdc_hw_device *dev)
267{
268	if (NULL == dev) {
269		printk(KERN_ERR "invalid ccdc device ptr\n");
270		return;
271	}
272
273	printk(KERN_NOTICE "vpfe_unregister_ccdc_device, dev->name = %s\n",
274		dev->name);
275
276	if (strcmp(dev->name, ccdc_cfg->name)) {
277		/* ignore this ccdc */
278		return;
279	}
280
281	mutex_lock(&ccdc_lock);
282	ccdc_dev = NULL;
283	mutex_unlock(&ccdc_lock);
284	return;
285}
286EXPORT_SYMBOL(vpfe_unregister_ccdc_device);
287
288/*
289 * vpfe_get_ccdc_image_format - Get image parameters based on CCDC settings
290 */
291static int vpfe_get_ccdc_image_format(struct vpfe_device *vpfe_dev,
292				 struct v4l2_format *f)
293{
294	struct v4l2_rect image_win;
295	enum ccdc_buftype buf_type;
296	enum ccdc_frmfmt frm_fmt;
297
298	memset(f, 0, sizeof(*f));
299	f->type = V4L2_BUF_TYPE_VIDEO_OUTPUT;
300	ccdc_dev->hw_ops.get_image_window(&image_win);
301	f->fmt.pix.width = image_win.width;
302	f->fmt.pix.height = image_win.height;
303	f->fmt.pix.bytesperline = ccdc_dev->hw_ops.get_line_length();
304	f->fmt.pix.sizeimage = f->fmt.pix.bytesperline *
305				f->fmt.pix.height;
306	buf_type = ccdc_dev->hw_ops.get_buftype();
307	f->fmt.pix.pixelformat = ccdc_dev->hw_ops.get_pixel_format();
308	frm_fmt = ccdc_dev->hw_ops.get_frame_format();
309	if (frm_fmt == CCDC_FRMFMT_PROGRESSIVE)
310		f->fmt.pix.field = V4L2_FIELD_NONE;
311	else if (frm_fmt == CCDC_FRMFMT_INTERLACED) {
312		if (buf_type == CCDC_BUFTYPE_FLD_INTERLEAVED)
313			f->fmt.pix.field = V4L2_FIELD_INTERLACED;
314		else if (buf_type == CCDC_BUFTYPE_FLD_SEPARATED)
315			f->fmt.pix.field = V4L2_FIELD_SEQ_TB;
316		else {
317			v4l2_err(&vpfe_dev->v4l2_dev, "Invalid buf_type\n");
318			return -EINVAL;
319		}
320	} else {
321		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid frm_fmt\n");
322		return -EINVAL;
323	}
324	return 0;
325}
326
327/*
328 * vpfe_config_ccdc_image_format()
329 * For a pix format, configure ccdc to setup the capture
330 */
331static int vpfe_config_ccdc_image_format(struct vpfe_device *vpfe_dev)
332{
333	enum ccdc_frmfmt frm_fmt = CCDC_FRMFMT_INTERLACED;
334	int ret = 0;
335
336	if (ccdc_dev->hw_ops.set_pixel_format(
337			vpfe_dev->fmt.fmt.pix.pixelformat) < 0) {
338		v4l2_err(&vpfe_dev->v4l2_dev,
339			"couldn't set pix format in ccdc\n");
340		return -EINVAL;
341	}
342	/* configure the image window */
343	ccdc_dev->hw_ops.set_image_window(&vpfe_dev->crop);
344
345	switch (vpfe_dev->fmt.fmt.pix.field) {
346	case V4L2_FIELD_INTERLACED:
347		/* do nothing, since it is default */
348		ret = ccdc_dev->hw_ops.set_buftype(
349				CCDC_BUFTYPE_FLD_INTERLEAVED);
350		break;
351	case V4L2_FIELD_NONE:
352		frm_fmt = CCDC_FRMFMT_PROGRESSIVE;
353		/* buffer type only applicable for interlaced scan */
354		break;
355	case V4L2_FIELD_SEQ_TB:
356		ret = ccdc_dev->hw_ops.set_buftype(
357				CCDC_BUFTYPE_FLD_SEPARATED);
358		break;
359	default:
360		return -EINVAL;
361	}
362
363	/* set the frame format */
364	if (!ret)
365		ret = ccdc_dev->hw_ops.set_frame_format(frm_fmt);
366	return ret;
367}
368/*
369 * vpfe_config_image_format()
370 * For a given standard, this functions sets up the default
371 * pix format & crop values in the vpfe device and ccdc.  It first
372 * starts with defaults based values from the standard table.
373 * It then checks if sub device support g_mbus_fmt and then override the
374 * values based on that.Sets crop values to match with scan resolution
375 * starting at 0,0. It calls vpfe_config_ccdc_image_format() set the
376 * values in ccdc
377 */
378static int vpfe_config_image_format(struct vpfe_device *vpfe_dev,
379				    const v4l2_std_id *std_id)
380{
381	struct vpfe_subdev_info *sdinfo = vpfe_dev->current_subdev;
382	struct v4l2_mbus_framefmt mbus_fmt;
383	struct v4l2_pix_format *pix = &vpfe_dev->fmt.fmt.pix;
384	int i, ret = 0;
385
386	for (i = 0; i < ARRAY_SIZE(vpfe_standards); i++) {
387		if (vpfe_standards[i].std_id & *std_id) {
388			vpfe_dev->std_info.active_pixels =
389					vpfe_standards[i].width;
390			vpfe_dev->std_info.active_lines =
391					vpfe_standards[i].height;
392			vpfe_dev->std_info.frame_format =
393					vpfe_standards[i].frame_format;
394			vpfe_dev->std_index = i;
395			break;
396		}
397	}
398
399	if (i ==  ARRAY_SIZE(vpfe_standards)) {
400		v4l2_err(&vpfe_dev->v4l2_dev, "standard not supported\n");
401		return -EINVAL;
402	}
403
404	vpfe_dev->crop.top = 0;
405	vpfe_dev->crop.left = 0;
406	vpfe_dev->crop.width = vpfe_dev->std_info.active_pixels;
407	vpfe_dev->crop.height = vpfe_dev->std_info.active_lines;
408	pix->width = vpfe_dev->crop.width;
409	pix->height = vpfe_dev->crop.height;
410
411	/* first field and frame format based on standard frame format */
412	if (vpfe_dev->std_info.frame_format) {
413		pix->field = V4L2_FIELD_INTERLACED;
414		/* assume V4L2_PIX_FMT_UYVY as default */
415		pix->pixelformat = V4L2_PIX_FMT_UYVY;
416		v4l2_fill_mbus_format(&mbus_fmt, pix,
417				V4L2_MBUS_FMT_YUYV10_2X10);
418	} else {
419		pix->field = V4L2_FIELD_NONE;
420		/* assume V4L2_PIX_FMT_SBGGR8 */
421		pix->pixelformat = V4L2_PIX_FMT_SBGGR8;
422		v4l2_fill_mbus_format(&mbus_fmt, pix,
423				V4L2_MBUS_FMT_SBGGR8_1X8);
424	}
425
426	/* if sub device supports g_mbus_fmt, override the defaults */
427	ret = v4l2_device_call_until_err(&vpfe_dev->v4l2_dev,
428			sdinfo->grp_id, video, g_mbus_fmt, &mbus_fmt);
429
430	if (ret && ret != -ENOIOCTLCMD) {
431		v4l2_err(&vpfe_dev->v4l2_dev,
432			"error in getting g_mbus_fmt from sub device\n");
433		return ret;
434	}
435	v4l2_fill_pix_format(pix, &mbus_fmt);
436	pix->bytesperline = pix->width * 2;
437	pix->sizeimage = pix->bytesperline * pix->height;
438
439	/* Sets the values in CCDC */
440	ret = vpfe_config_ccdc_image_format(vpfe_dev);
441	if (ret)
442		return ret;
443
444	/* Update the values of sizeimage and bytesperline */
445	if (!ret) {
446		pix->bytesperline = ccdc_dev->hw_ops.get_line_length();
447		pix->sizeimage = pix->bytesperline * pix->height;
448	}
449	return ret;
450}
451
452static int vpfe_initialize_device(struct vpfe_device *vpfe_dev)
453{
454	int ret = 0;
455
456	/* set first input of current subdevice as the current input */
457	vpfe_dev->current_input = 0;
458
459	/* set default standard */
460	vpfe_dev->std_index = 0;
461
462	/* Configure the default format information */
463	ret = vpfe_config_image_format(vpfe_dev,
464				&vpfe_standards[vpfe_dev->std_index].std_id);
465	if (ret)
466		return ret;
467
468	/* now open the ccdc device to initialize it */
469	mutex_lock(&ccdc_lock);
470	if (NULL == ccdc_dev) {
471		v4l2_err(&vpfe_dev->v4l2_dev, "ccdc device not registered\n");
472		ret = -ENODEV;
473		goto unlock;
474	}
475
476	if (!try_module_get(ccdc_dev->owner)) {
477		v4l2_err(&vpfe_dev->v4l2_dev, "Couldn't lock ccdc module\n");
478		ret = -ENODEV;
479		goto unlock;
480	}
481	ret = ccdc_dev->hw_ops.open(vpfe_dev->pdev);
482	if (!ret)
483		vpfe_dev->initialized = 1;
484
485	/* Clear all VPFE/CCDC interrupts */
486	if (vpfe_dev->cfg->clr_intr)
487		vpfe_dev->cfg->clr_intr(-1);
488
489unlock:
490	mutex_unlock(&ccdc_lock);
491	return ret;
492}
493
494/*
495 * vpfe_open : It creates object of file handle structure and
496 * stores it in private_data  member of filepointer
497 */
498static int vpfe_open(struct file *file)
499{
500	struct vpfe_device *vpfe_dev = video_drvdata(file);
501	struct vpfe_fh *fh;
502
503	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_open\n");
504
505	if (!vpfe_dev->cfg->num_subdevs) {
506		v4l2_err(&vpfe_dev->v4l2_dev, "No decoder registered\n");
507		return -ENODEV;
508	}
509
510	/* Allocate memory for the file handle object */
511	fh = kmalloc(sizeof(struct vpfe_fh), GFP_KERNEL);
512	if (NULL == fh) {
513		v4l2_err(&vpfe_dev->v4l2_dev,
514			"unable to allocate memory for file handle object\n");
515		return -ENOMEM;
516	}
517	/* store pointer to fh in private_data member of file */
518	file->private_data = fh;
519	fh->vpfe_dev = vpfe_dev;
520	mutex_lock(&vpfe_dev->lock);
521	/* If decoder is not initialized. initialize it */
522	if (!vpfe_dev->initialized) {
523		if (vpfe_initialize_device(vpfe_dev)) {
524			mutex_unlock(&vpfe_dev->lock);
525			return -ENODEV;
526		}
527	}
528	/* Increment device usrs counter */
529	vpfe_dev->usrs++;
530	/* Set io_allowed member to false */
531	fh->io_allowed = 0;
532	/* Initialize priority of this instance to default priority */
533	fh->prio = V4L2_PRIORITY_UNSET;
534	v4l2_prio_open(&vpfe_dev->prio, &fh->prio);
535	mutex_unlock(&vpfe_dev->lock);
536	return 0;
537}
538
539static void vpfe_schedule_next_buffer(struct vpfe_device *vpfe_dev)
540{
541	unsigned long addr;
542
543	vpfe_dev->next_frm = list_entry(vpfe_dev->dma_queue.next,
544					struct videobuf_buffer, queue);
545	list_del(&vpfe_dev->next_frm->queue);
546	vpfe_dev->next_frm->state = VIDEOBUF_ACTIVE;
547	addr = videobuf_to_dma_contig(vpfe_dev->next_frm);
548
549	ccdc_dev->hw_ops.setfbaddr(addr);
550}
551
552static void vpfe_schedule_bottom_field(struct vpfe_device *vpfe_dev)
553{
554	unsigned long addr;
555
556	addr = videobuf_to_dma_contig(vpfe_dev->cur_frm);
557	addr += vpfe_dev->field_off;
558	ccdc_dev->hw_ops.setfbaddr(addr);
559}
560
561static void vpfe_process_buffer_complete(struct vpfe_device *vpfe_dev)
562{
563	struct timeval timevalue;
564
565	do_gettimeofday(&timevalue);
566	vpfe_dev->cur_frm->ts = timevalue;
567	vpfe_dev->cur_frm->state = VIDEOBUF_DONE;
568	vpfe_dev->cur_frm->size = vpfe_dev->fmt.fmt.pix.sizeimage;
569	wake_up_interruptible(&vpfe_dev->cur_frm->done);
570	vpfe_dev->cur_frm = vpfe_dev->next_frm;
571}
572
573/* ISR for VINT0*/
574static irqreturn_t vpfe_isr(int irq, void *dev_id)
575{
576	struct vpfe_device *vpfe_dev = dev_id;
577	enum v4l2_field field;
578	int fid;
579
580	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "\nStarting vpfe_isr...\n");
581	field = vpfe_dev->fmt.fmt.pix.field;
582
583	/* if streaming not started, don't do anything */
584	if (!vpfe_dev->started)
585		goto clear_intr;
586
587	/* only for 6446 this will be applicable */
588	if (NULL != ccdc_dev->hw_ops.reset)
589		ccdc_dev->hw_ops.reset();
590
591	if (field == V4L2_FIELD_NONE) {
592		/* handle progressive frame capture */
593		v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
594			"frame format is progressive...\n");
595		if (vpfe_dev->cur_frm != vpfe_dev->next_frm)
596			vpfe_process_buffer_complete(vpfe_dev);
597		goto clear_intr;
598	}
599
600	/* interlaced or TB capture check which field we are in hardware */
601	fid = ccdc_dev->hw_ops.getfid();
602
603	/* switch the software maintained field id */
604	vpfe_dev->field_id ^= 1;
605	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "field id = %x:%x.\n",
606		fid, vpfe_dev->field_id);
607	if (fid == vpfe_dev->field_id) {
608		/* we are in-sync here,continue */
609		if (fid == 0) {
610			/*
611			 * One frame is just being captured. If the next frame
612			 * is available, release the current frame and move on
613			 */
614			if (vpfe_dev->cur_frm != vpfe_dev->next_frm)
615				vpfe_process_buffer_complete(vpfe_dev);
616			/*
617			 * based on whether the two fields are stored
618			 * interleavely or separately in memory, reconfigure
619			 * the CCDC memory address
620			 */
621			if (field == V4L2_FIELD_SEQ_TB) {
622				vpfe_schedule_bottom_field(vpfe_dev);
623			}
624			goto clear_intr;
625		}
626		/*
627		 * if one field is just being captured configure
628		 * the next frame get the next frame from the empty
629		 * queue if no frame is available hold on to the
630		 * current buffer
631		 */
632		spin_lock(&vpfe_dev->dma_queue_lock);
633		if (!list_empty(&vpfe_dev->dma_queue) &&
634		    vpfe_dev->cur_frm == vpfe_dev->next_frm)
635			vpfe_schedule_next_buffer(vpfe_dev);
636		spin_unlock(&vpfe_dev->dma_queue_lock);
637	} else if (fid == 0) {
638		/*
639		 * out of sync. Recover from any hardware out-of-sync.
640		 * May loose one frame
641		 */
642		vpfe_dev->field_id = fid;
643	}
644clear_intr:
645	if (vpfe_dev->cfg->clr_intr)
646		vpfe_dev->cfg->clr_intr(irq);
647
648	return IRQ_HANDLED;
649}
650
651/* vdint1_isr - isr handler for VINT1 interrupt */
652static irqreturn_t vdint1_isr(int irq, void *dev_id)
653{
654	struct vpfe_device *vpfe_dev = dev_id;
655
656	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "\nInside vdint1_isr...\n");
657
658	/* if streaming not started, don't do anything */
659	if (!vpfe_dev->started) {
660		if (vpfe_dev->cfg->clr_intr)
661			vpfe_dev->cfg->clr_intr(irq);
662		return IRQ_HANDLED;
663	}
664
665	spin_lock(&vpfe_dev->dma_queue_lock);
666	if ((vpfe_dev->fmt.fmt.pix.field == V4L2_FIELD_NONE) &&
667	    !list_empty(&vpfe_dev->dma_queue) &&
668	    vpfe_dev->cur_frm == vpfe_dev->next_frm)
669		vpfe_schedule_next_buffer(vpfe_dev);
670	spin_unlock(&vpfe_dev->dma_queue_lock);
671
672	if (vpfe_dev->cfg->clr_intr)
673		vpfe_dev->cfg->clr_intr(irq);
674
675	return IRQ_HANDLED;
676}
677
678static void vpfe_detach_irq(struct vpfe_device *vpfe_dev)
679{
680	enum ccdc_frmfmt frame_format;
681
682	frame_format = ccdc_dev->hw_ops.get_frame_format();
683	if (frame_format == CCDC_FRMFMT_PROGRESSIVE)
684		free_irq(vpfe_dev->ccdc_irq1, vpfe_dev);
685}
686
687static int vpfe_attach_irq(struct vpfe_device *vpfe_dev)
688{
689	enum ccdc_frmfmt frame_format;
690
691	frame_format = ccdc_dev->hw_ops.get_frame_format();
692	if (frame_format == CCDC_FRMFMT_PROGRESSIVE) {
693		return request_irq(vpfe_dev->ccdc_irq1, vdint1_isr,
694				    IRQF_DISABLED, "vpfe_capture1",
695				    vpfe_dev);
696	}
697	return 0;
698}
699
700/* vpfe_stop_ccdc_capture: stop streaming in ccdc/isif */
701static void vpfe_stop_ccdc_capture(struct vpfe_device *vpfe_dev)
702{
703	vpfe_dev->started = 0;
704	ccdc_dev->hw_ops.enable(0);
705	if (ccdc_dev->hw_ops.enable_out_to_sdram)
706		ccdc_dev->hw_ops.enable_out_to_sdram(0);
707}
708
709/*
710 * vpfe_release : This function deletes buffer queue, frees the
711 * buffers and the vpfe file  handle
712 */
713static int vpfe_release(struct file *file)
714{
715	struct vpfe_device *vpfe_dev = video_drvdata(file);
716	struct vpfe_fh *fh = file->private_data;
717	struct vpfe_subdev_info *sdinfo;
718	int ret;
719
720	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_release\n");
721
722	/* Get the device lock */
723	mutex_lock(&vpfe_dev->lock);
724	/* if this instance is doing IO */
725	if (fh->io_allowed) {
726		if (vpfe_dev->started) {
727			sdinfo = vpfe_dev->current_subdev;
728			ret = v4l2_device_call_until_err(&vpfe_dev->v4l2_dev,
729							 sdinfo->grp_id,
730							 video, s_stream, 0);
731			if (ret && (ret != -ENOIOCTLCMD))
732				v4l2_err(&vpfe_dev->v4l2_dev,
733				"stream off failed in subdev\n");
734			vpfe_stop_ccdc_capture(vpfe_dev);
735			vpfe_detach_irq(vpfe_dev);
736			videobuf_streamoff(&vpfe_dev->buffer_queue);
737		}
738		vpfe_dev->io_usrs = 0;
739		vpfe_dev->numbuffers = config_params.numbuffers;
740	}
741
742	/* Decrement device usrs counter */
743	vpfe_dev->usrs--;
744	/* Close the priority */
745	v4l2_prio_close(&vpfe_dev->prio, fh->prio);
746	/* If this is the last file handle */
747	if (!vpfe_dev->usrs) {
748		vpfe_dev->initialized = 0;
749		if (ccdc_dev->hw_ops.close)
750			ccdc_dev->hw_ops.close(vpfe_dev->pdev);
751		module_put(ccdc_dev->owner);
752	}
753	mutex_unlock(&vpfe_dev->lock);
754	file->private_data = NULL;
755	/* Free memory allocated to file handle object */
756	kfree(fh);
757	return 0;
758}
759
760/*
761 * vpfe_mmap : It is used to map kernel space buffers
762 * into user spaces
763 */
764static int vpfe_mmap(struct file *file, struct vm_area_struct *vma)
765{
766	/* Get the device object and file handle object */
767	struct vpfe_device *vpfe_dev = video_drvdata(file);
768
769	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_mmap\n");
770
771	return videobuf_mmap_mapper(&vpfe_dev->buffer_queue, vma);
772}
773
774/*
775 * vpfe_poll: It is used for select/poll system call
776 */
777static unsigned int vpfe_poll(struct file *file, poll_table *wait)
778{
779	struct vpfe_device *vpfe_dev = video_drvdata(file);
780
781	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_poll\n");
782
783	if (vpfe_dev->started)
784		return videobuf_poll_stream(file,
785					    &vpfe_dev->buffer_queue, wait);
786	return 0;
787}
788
789/* vpfe capture driver file operations */
790static const struct v4l2_file_operations vpfe_fops = {
791	.owner = THIS_MODULE,
792	.open = vpfe_open,
793	.release = vpfe_release,
794	.unlocked_ioctl = video_ioctl2,
795	.mmap = vpfe_mmap,
796	.poll = vpfe_poll
797};
798
799/*
800 * vpfe_check_format()
801 * This function adjust the input pixel format as per hardware
802 * capabilities and update the same in pixfmt.
803 * Following algorithm used :-
804 *
805 *	If given pixformat is not in the vpfe list of pix formats or not
806 *	supported by the hardware, current value of pixformat in the device
807 *	is used
808 *	If given field is not supported, then current field is used. If field
809 *	is different from current, then it is matched with that from sub device.
810 *	Minimum height is 2 lines for interlaced or tb field and 1 line for
811 *	progressive. Maximum height is clamped to active active lines of scan
812 *	Minimum width is 32 bytes in memory and width is clamped to active
813 *	pixels of scan.
814 *	bytesperline is a multiple of 32.
815 */
816static const struct vpfe_pixel_format *
817	vpfe_check_format(struct vpfe_device *vpfe_dev,
818			  struct v4l2_pix_format *pixfmt)
819{
820	u32 min_height = 1, min_width = 32, max_width, max_height;
821	const struct vpfe_pixel_format *vpfe_pix_fmt;
822	u32 pix;
823	int temp, found;
824
825	vpfe_pix_fmt = vpfe_lookup_pix_format(pixfmt->pixelformat);
826	if (NULL == vpfe_pix_fmt) {
827		/*
828		 * use current pixel format in the vpfe device. We
829		 * will find this pix format in the table
830		 */
831		pixfmt->pixelformat = vpfe_dev->fmt.fmt.pix.pixelformat;
832		vpfe_pix_fmt = vpfe_lookup_pix_format(pixfmt->pixelformat);
833	}
834
835	/* check if hw supports it */
836	temp = 0;
837	found = 0;
838	while (ccdc_dev->hw_ops.enum_pix(&pix, temp) >= 0) {
839		if (vpfe_pix_fmt->fmtdesc.pixelformat == pix) {
840			found = 1;
841			break;
842		}
843		temp++;
844	}
845
846	if (!found) {
847		/* use current pixel format */
848		pixfmt->pixelformat = vpfe_dev->fmt.fmt.pix.pixelformat;
849		/*
850		 * Since this is currently used in the vpfe device, we
851		 * will find this pix format in the table
852		 */
853		vpfe_pix_fmt = vpfe_lookup_pix_format(pixfmt->pixelformat);
854	}
855
856	/* check what field format is supported */
857	if (pixfmt->field == V4L2_FIELD_ANY) {
858		/* if field is any, use current value as default */
859		pixfmt->field = vpfe_dev->fmt.fmt.pix.field;
860	}
861
862	/*
863	 * if field is not same as current field in the vpfe device
864	 * try matching the field with the sub device field
865	 */
866	if (vpfe_dev->fmt.fmt.pix.field != pixfmt->field) {
867		/*
868		 * If field value is not in the supported fields, use current
869		 * field used in the device as default
870		 */
871		switch (pixfmt->field) {
872		case V4L2_FIELD_INTERLACED:
873		case V4L2_FIELD_SEQ_TB:
874			/* if sub device is supporting progressive, use that */
875			if (!vpfe_dev->std_info.frame_format)
876				pixfmt->field = V4L2_FIELD_NONE;
877			break;
878		case V4L2_FIELD_NONE:
879			if (vpfe_dev->std_info.frame_format)
880				pixfmt->field = V4L2_FIELD_INTERLACED;
881			break;
882
883		default:
884			/* use current field as default */
885			pixfmt->field = vpfe_dev->fmt.fmt.pix.field;
886			break;
887		}
888	}
889
890	/* Now adjust image resolutions supported */
891	if (pixfmt->field == V4L2_FIELD_INTERLACED ||
892	    pixfmt->field == V4L2_FIELD_SEQ_TB)
893		min_height = 2;
894
895	max_width = vpfe_dev->std_info.active_pixels;
896	max_height = vpfe_dev->std_info.active_lines;
897	min_width /= vpfe_pix_fmt->bpp;
898
899	v4l2_info(&vpfe_dev->v4l2_dev, "width = %d, height = %d, bpp = %d\n",
900		  pixfmt->width, pixfmt->height, vpfe_pix_fmt->bpp);
901
902	pixfmt->width = clamp((pixfmt->width), min_width, max_width);
903	pixfmt->height = clamp((pixfmt->height), min_height, max_height);
904
905	/* If interlaced, adjust height to be a multiple of 2 */
906	if (pixfmt->field == V4L2_FIELD_INTERLACED)
907		pixfmt->height &= (~1);
908	/*
909	 * recalculate bytesperline and sizeimage since width
910	 * and height might have changed
911	 */
912	pixfmt->bytesperline = (((pixfmt->width * vpfe_pix_fmt->bpp) + 31)
913				& ~31);
914	if (pixfmt->pixelformat == V4L2_PIX_FMT_NV12)
915		pixfmt->sizeimage =
916			pixfmt->bytesperline * pixfmt->height +
917			((pixfmt->bytesperline * pixfmt->height) >> 1);
918	else
919		pixfmt->sizeimage = pixfmt->bytesperline * pixfmt->height;
920
921	v4l2_info(&vpfe_dev->v4l2_dev, "adjusted width = %d, height ="
922		 " %d, bpp = %d, bytesperline = %d, sizeimage = %d\n",
923		 pixfmt->width, pixfmt->height, vpfe_pix_fmt->bpp,
924		 pixfmt->bytesperline, pixfmt->sizeimage);
925	return vpfe_pix_fmt;
926}
927
928static int vpfe_querycap(struct file *file, void  *priv,
929			       struct v4l2_capability *cap)
930{
931	struct vpfe_device *vpfe_dev = video_drvdata(file);
932
933	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_querycap\n");
934
935	cap->version = VPFE_CAPTURE_VERSION_CODE;
936	cap->capabilities = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_STREAMING;
937	strlcpy(cap->driver, CAPTURE_DRV_NAME, sizeof(cap->driver));
938	strlcpy(cap->bus_info, "VPFE", sizeof(cap->bus_info));
939	strlcpy(cap->card, vpfe_dev->cfg->card_name, sizeof(cap->card));
940	return 0;
941}
942
943static int vpfe_g_fmt_vid_cap(struct file *file, void *priv,
944				struct v4l2_format *fmt)
945{
946	struct vpfe_device *vpfe_dev = video_drvdata(file);
947	int ret = 0;
948
949	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_g_fmt_vid_cap\n");
950	/* Fill in the information about format */
951	*fmt = vpfe_dev->fmt;
952	return ret;
953}
954
955static int vpfe_enum_fmt_vid_cap(struct file *file, void  *priv,
956				   struct v4l2_fmtdesc *fmt)
957{
958	struct vpfe_device *vpfe_dev = video_drvdata(file);
959	const struct vpfe_pixel_format *pix_fmt;
960	int temp_index;
961	u32 pix;
962
963	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_enum_fmt_vid_cap\n");
964
965	if (ccdc_dev->hw_ops.enum_pix(&pix, fmt->index) < 0)
966		return -EINVAL;
967
968	/* Fill in the information about format */
969	pix_fmt = vpfe_lookup_pix_format(pix);
970	if (NULL != pix_fmt) {
971		temp_index = fmt->index;
972		*fmt = pix_fmt->fmtdesc;
973		fmt->index = temp_index;
974		return 0;
975	}
976	return -EINVAL;
977}
978
979static int vpfe_s_fmt_vid_cap(struct file *file, void *priv,
980				struct v4l2_format *fmt)
981{
982	struct vpfe_device *vpfe_dev = video_drvdata(file);
983	const struct vpfe_pixel_format *pix_fmts;
984	int ret = 0;
985
986	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_s_fmt_vid_cap\n");
987
988	/* If streaming is started, return error */
989	if (vpfe_dev->started) {
990		v4l2_err(&vpfe_dev->v4l2_dev, "Streaming is started\n");
991		return -EBUSY;
992	}
993
994	/* Check for valid frame format */
995	pix_fmts = vpfe_check_format(vpfe_dev, &fmt->fmt.pix);
996
997	if (NULL == pix_fmts)
998		return -EINVAL;
999
1000	/* store the pixel format in the device  object */
1001	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1002	if (ret)
1003		return ret;
1004
1005	/* First detach any IRQ if currently attached */
1006	vpfe_detach_irq(vpfe_dev);
1007	vpfe_dev->fmt = *fmt;
1008	/* set image capture parameters in the ccdc */
1009	ret = vpfe_config_ccdc_image_format(vpfe_dev);
1010	mutex_unlock(&vpfe_dev->lock);
1011	return ret;
1012}
1013
1014static int vpfe_try_fmt_vid_cap(struct file *file, void *priv,
1015				  struct v4l2_format *f)
1016{
1017	struct vpfe_device *vpfe_dev = video_drvdata(file);
1018	const struct vpfe_pixel_format *pix_fmts;
1019
1020	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_try_fmt_vid_cap\n");
1021
1022	pix_fmts = vpfe_check_format(vpfe_dev, &f->fmt.pix);
1023	if (NULL == pix_fmts)
1024		return -EINVAL;
1025	return 0;
1026}
1027
1028/*
1029 * vpfe_get_subdev_input_index - Get subdev index and subdev input index for a
1030 * given app input index
1031 */
1032static int vpfe_get_subdev_input_index(struct vpfe_device *vpfe_dev,
1033					int *subdev_index,
1034					int *subdev_input_index,
1035					int app_input_index)
1036{
1037	struct vpfe_config *cfg = vpfe_dev->cfg;
1038	struct vpfe_subdev_info *sdinfo;
1039	int i, j = 0;
1040
1041	for (i = 0; i < cfg->num_subdevs; i++) {
1042		sdinfo = &cfg->sub_devs[i];
1043		if (app_input_index < (j + sdinfo->num_inputs)) {
1044			*subdev_index = i;
1045			*subdev_input_index = app_input_index - j;
1046			return 0;
1047		}
1048		j += sdinfo->num_inputs;
1049	}
1050	return -EINVAL;
1051}
1052
1053/*
1054 * vpfe_get_app_input - Get app input index for a given subdev input index
1055 * driver stores the input index of the current sub device and translate it
1056 * when application request the current input
1057 */
1058static int vpfe_get_app_input_index(struct vpfe_device *vpfe_dev,
1059				    int *app_input_index)
1060{
1061	struct vpfe_config *cfg = vpfe_dev->cfg;
1062	struct vpfe_subdev_info *sdinfo;
1063	int i, j = 0;
1064
1065	for (i = 0; i < cfg->num_subdevs; i++) {
1066		sdinfo = &cfg->sub_devs[i];
1067		if (!strcmp(sdinfo->name, vpfe_dev->current_subdev->name)) {
1068			if (vpfe_dev->current_input >= sdinfo->num_inputs)
1069				return -1;
1070			*app_input_index = j + vpfe_dev->current_input;
1071			return 0;
1072		}
1073		j += sdinfo->num_inputs;
1074	}
1075	return -EINVAL;
1076}
1077
1078static int vpfe_enum_input(struct file *file, void *priv,
1079				 struct v4l2_input *inp)
1080{
1081	struct vpfe_device *vpfe_dev = video_drvdata(file);
1082	struct vpfe_subdev_info *sdinfo;
1083	int subdev, index ;
1084
1085	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_enum_input\n");
1086
1087	if (vpfe_get_subdev_input_index(vpfe_dev,
1088					&subdev,
1089					&index,
1090					inp->index) < 0) {
1091		v4l2_err(&vpfe_dev->v4l2_dev, "input information not found"
1092			 " for the subdev\n");
1093		return -EINVAL;
1094	}
1095	sdinfo = &vpfe_dev->cfg->sub_devs[subdev];
1096	memcpy(inp, &sdinfo->inputs[index], sizeof(struct v4l2_input));
1097	return 0;
1098}
1099
1100static int vpfe_g_input(struct file *file, void *priv, unsigned int *index)
1101{
1102	struct vpfe_device *vpfe_dev = video_drvdata(file);
1103
1104	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_g_input\n");
1105
1106	return vpfe_get_app_input_index(vpfe_dev, index);
1107}
1108
1109
1110static int vpfe_s_input(struct file *file, void *priv, unsigned int index)
1111{
1112	struct vpfe_device *vpfe_dev = video_drvdata(file);
1113	struct vpfe_subdev_info *sdinfo;
1114	int subdev_index, inp_index;
1115	struct vpfe_route *route;
1116	u32 input = 0, output = 0;
1117	int ret = -EINVAL;
1118
1119	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_s_input\n");
1120
1121	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1122	if (ret)
1123		return ret;
1124
1125	/*
1126	 * If streaming is started return device busy
1127	 * error
1128	 */
1129	if (vpfe_dev->started) {
1130		v4l2_err(&vpfe_dev->v4l2_dev, "Streaming is on\n");
1131		ret = -EBUSY;
1132		goto unlock_out;
1133	}
1134
1135	if (vpfe_get_subdev_input_index(vpfe_dev,
1136					&subdev_index,
1137					&inp_index,
1138					index) < 0) {
1139		v4l2_err(&vpfe_dev->v4l2_dev, "invalid input index\n");
1140		goto unlock_out;
1141	}
1142
1143	sdinfo = &vpfe_dev->cfg->sub_devs[subdev_index];
1144	route = &sdinfo->routes[inp_index];
1145	if (route && sdinfo->can_route) {
1146		input = route->input;
1147		output = route->output;
1148	}
1149
1150	ret = v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1151					 video, s_routing, input, output, 0);
1152
1153	if (ret) {
1154		v4l2_err(&vpfe_dev->v4l2_dev,
1155			"vpfe_doioctl:error in setting input in decoder\n");
1156		ret = -EINVAL;
1157		goto unlock_out;
1158	}
1159	vpfe_dev->current_subdev = sdinfo;
1160	vpfe_dev->current_input = index;
1161	vpfe_dev->std_index = 0;
1162
1163	/* set the bus/interface parameter for the sub device in ccdc */
1164	ret = ccdc_dev->hw_ops.set_hw_if_params(&sdinfo->ccdc_if_params);
1165	if (ret)
1166		goto unlock_out;
1167
1168	/* set the default image parameters in the device */
1169	ret = vpfe_config_image_format(vpfe_dev,
1170				&vpfe_standards[vpfe_dev->std_index].std_id);
1171unlock_out:
1172	mutex_unlock(&vpfe_dev->lock);
1173	return ret;
1174}
1175
1176static int vpfe_querystd(struct file *file, void *priv, v4l2_std_id *std_id)
1177{
1178	struct vpfe_device *vpfe_dev = video_drvdata(file);
1179	struct vpfe_subdev_info *sdinfo;
1180	int ret = 0;
1181
1182	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_querystd\n");
1183
1184	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1185	sdinfo = vpfe_dev->current_subdev;
1186	if (ret)
1187		return ret;
1188	/* Call querystd function of decoder device */
1189	ret = v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1190					 video, querystd, std_id);
1191	mutex_unlock(&vpfe_dev->lock);
1192	return ret;
1193}
1194
1195static int vpfe_s_std(struct file *file, void *priv, v4l2_std_id *std_id)
1196{
1197	struct vpfe_device *vpfe_dev = video_drvdata(file);
1198	struct vpfe_subdev_info *sdinfo;
1199	int ret = 0;
1200
1201	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_s_std\n");
1202
1203	/* Call decoder driver function to set the standard */
1204	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1205	if (ret)
1206		return ret;
1207
1208	sdinfo = vpfe_dev->current_subdev;
1209	/* If streaming is started, return device busy error */
1210	if (vpfe_dev->started) {
1211		v4l2_err(&vpfe_dev->v4l2_dev, "streaming is started\n");
1212		ret = -EBUSY;
1213		goto unlock_out;
1214	}
1215
1216	ret = v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1217					 core, s_std, *std_id);
1218	if (ret < 0) {
1219		v4l2_err(&vpfe_dev->v4l2_dev, "Failed to set standard\n");
1220		goto unlock_out;
1221	}
1222	ret = vpfe_config_image_format(vpfe_dev, std_id);
1223
1224unlock_out:
1225	mutex_unlock(&vpfe_dev->lock);
1226	return ret;
1227}
1228
1229static int vpfe_g_std(struct file *file, void *priv, v4l2_std_id *std_id)
1230{
1231	struct vpfe_device *vpfe_dev = video_drvdata(file);
1232
1233	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_g_std\n");
1234
1235	*std_id = vpfe_standards[vpfe_dev->std_index].std_id;
1236	return 0;
1237}
1238/*
1239 *  Videobuf operations
1240 */
1241static int vpfe_videobuf_setup(struct videobuf_queue *vq,
1242				unsigned int *count,
1243				unsigned int *size)
1244{
1245	struct vpfe_fh *fh = vq->priv_data;
1246	struct vpfe_device *vpfe_dev = fh->vpfe_dev;
1247
1248	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_buffer_setup\n");
1249	*size = vpfe_dev->fmt.fmt.pix.sizeimage;
1250	if (vpfe_dev->memory == V4L2_MEMORY_MMAP &&
1251		vpfe_dev->fmt.fmt.pix.sizeimage > config_params.device_bufsize)
1252		*size = config_params.device_bufsize;
1253
1254	if (*count < config_params.min_numbuffers)
1255		*count = config_params.min_numbuffers;
1256	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
1257		"count=%d, size=%d\n", *count, *size);
1258	return 0;
1259}
1260
1261static int vpfe_videobuf_prepare(struct videobuf_queue *vq,
1262				struct videobuf_buffer *vb,
1263				enum v4l2_field field)
1264{
1265	struct vpfe_fh *fh = vq->priv_data;
1266	struct vpfe_device *vpfe_dev = fh->vpfe_dev;
1267	unsigned long addr;
1268	int ret;
1269
1270	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_buffer_prepare\n");
1271
1272	/* If buffer is not initialized, initialize it */
1273	if (VIDEOBUF_NEEDS_INIT == vb->state) {
1274		vb->width = vpfe_dev->fmt.fmt.pix.width;
1275		vb->height = vpfe_dev->fmt.fmt.pix.height;
1276		vb->size = vpfe_dev->fmt.fmt.pix.sizeimage;
1277		vb->field = field;
1278
1279		ret = videobuf_iolock(vq, vb, NULL);
1280		if (ret < 0)
1281			return ret;
1282
1283		addr = videobuf_to_dma_contig(vb);
1284		/* Make sure user addresses are aligned to 32 bytes */
1285		if (!ALIGN(addr, 32))
1286			return -EINVAL;
1287
1288		vb->state = VIDEOBUF_PREPARED;
1289	}
1290	return 0;
1291}
1292
1293static void vpfe_videobuf_queue(struct videobuf_queue *vq,
1294				struct videobuf_buffer *vb)
1295{
1296	/* Get the file handle object and device object */
1297	struct vpfe_fh *fh = vq->priv_data;
1298	struct vpfe_device *vpfe_dev = fh->vpfe_dev;
1299	unsigned long flags;
1300
1301	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_buffer_queue\n");
1302
1303	/* add the buffer to the DMA queue */
1304	spin_lock_irqsave(&vpfe_dev->dma_queue_lock, flags);
1305	list_add_tail(&vb->queue, &vpfe_dev->dma_queue);
1306	spin_unlock_irqrestore(&vpfe_dev->dma_queue_lock, flags);
1307
1308	/* Change state of the buffer */
1309	vb->state = VIDEOBUF_QUEUED;
1310}
1311
1312static void vpfe_videobuf_release(struct videobuf_queue *vq,
1313				  struct videobuf_buffer *vb)
1314{
1315	struct vpfe_fh *fh = vq->priv_data;
1316	struct vpfe_device *vpfe_dev = fh->vpfe_dev;
1317	unsigned long flags;
1318
1319	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_videobuf_release\n");
1320
1321	/*
1322	 * We need to flush the buffer from the dma queue since
1323	 * they are de-allocated
1324	 */
1325	spin_lock_irqsave(&vpfe_dev->dma_queue_lock, flags);
1326	INIT_LIST_HEAD(&vpfe_dev->dma_queue);
1327	spin_unlock_irqrestore(&vpfe_dev->dma_queue_lock, flags);
1328	videobuf_dma_contig_free(vq, vb);
1329	vb->state = VIDEOBUF_NEEDS_INIT;
1330}
1331
1332static struct videobuf_queue_ops vpfe_videobuf_qops = {
1333	.buf_setup      = vpfe_videobuf_setup,
1334	.buf_prepare    = vpfe_videobuf_prepare,
1335	.buf_queue      = vpfe_videobuf_queue,
1336	.buf_release    = vpfe_videobuf_release,
1337};
1338
1339/*
1340 * vpfe_reqbufs. currently support REQBUF only once opening
1341 * the device.
1342 */
1343static int vpfe_reqbufs(struct file *file, void *priv,
1344			struct v4l2_requestbuffers *req_buf)
1345{
1346	struct vpfe_device *vpfe_dev = video_drvdata(file);
1347	struct vpfe_fh *fh = file->private_data;
1348	int ret = 0;
1349
1350	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_reqbufs\n");
1351
1352	if (V4L2_BUF_TYPE_VIDEO_CAPTURE != req_buf->type) {
1353		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid buffer type\n");
1354		return -EINVAL;
1355	}
1356
1357	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1358	if (ret)
1359		return ret;
1360
1361	if (vpfe_dev->io_usrs != 0) {
1362		v4l2_err(&vpfe_dev->v4l2_dev, "Only one IO user allowed\n");
1363		ret = -EBUSY;
1364		goto unlock_out;
1365	}
1366
1367	vpfe_dev->memory = req_buf->memory;
1368	videobuf_queue_dma_contig_init(&vpfe_dev->buffer_queue,
1369				&vpfe_videobuf_qops,
1370				vpfe_dev->pdev,
1371				&vpfe_dev->irqlock,
1372				req_buf->type,
1373				vpfe_dev->fmt.fmt.pix.field,
1374				sizeof(struct videobuf_buffer),
1375				fh, NULL);
1376
1377	fh->io_allowed = 1;
1378	vpfe_dev->io_usrs = 1;
1379	INIT_LIST_HEAD(&vpfe_dev->dma_queue);
1380	ret = videobuf_reqbufs(&vpfe_dev->buffer_queue, req_buf);
1381unlock_out:
1382	mutex_unlock(&vpfe_dev->lock);
1383	return ret;
1384}
1385
1386static int vpfe_querybuf(struct file *file, void *priv,
1387			 struct v4l2_buffer *buf)
1388{
1389	struct vpfe_device *vpfe_dev = video_drvdata(file);
1390
1391	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_querybuf\n");
1392
1393	if (V4L2_BUF_TYPE_VIDEO_CAPTURE != buf->type) {
1394		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid buf type\n");
1395		return  -EINVAL;
1396	}
1397
1398	if (vpfe_dev->memory != V4L2_MEMORY_MMAP) {
1399		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid memory\n");
1400		return -EINVAL;
1401	}
1402	/* Call videobuf_querybuf to get information */
1403	return videobuf_querybuf(&vpfe_dev->buffer_queue, buf);
1404}
1405
1406static int vpfe_qbuf(struct file *file, void *priv,
1407		     struct v4l2_buffer *p)
1408{
1409	struct vpfe_device *vpfe_dev = video_drvdata(file);
1410	struct vpfe_fh *fh = file->private_data;
1411
1412	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_qbuf\n");
1413
1414	if (V4L2_BUF_TYPE_VIDEO_CAPTURE != p->type) {
1415		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid buf type\n");
1416		return -EINVAL;
1417	}
1418
1419	/*
1420	 * If this file handle is not allowed to do IO,
1421	 * return error
1422	 */
1423	if (!fh->io_allowed) {
1424		v4l2_err(&vpfe_dev->v4l2_dev, "fh->io_allowed\n");
1425		return -EACCES;
1426	}
1427	return videobuf_qbuf(&vpfe_dev->buffer_queue, p);
1428}
1429
1430static int vpfe_dqbuf(struct file *file, void *priv,
1431		      struct v4l2_buffer *buf)
1432{
1433	struct vpfe_device *vpfe_dev = video_drvdata(file);
1434
1435	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_dqbuf\n");
1436
1437	if (V4L2_BUF_TYPE_VIDEO_CAPTURE != buf->type) {
1438		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid buf type\n");
1439		return -EINVAL;
1440	}
1441	return videobuf_dqbuf(&vpfe_dev->buffer_queue,
1442				      buf, file->f_flags & O_NONBLOCK);
1443}
1444
1445static int vpfe_queryctrl(struct file *file, void *priv,
1446		struct v4l2_queryctrl *qctrl)
1447{
1448	struct vpfe_device *vpfe_dev = video_drvdata(file);
1449	struct vpfe_subdev_info *sdinfo;
1450
1451	sdinfo = vpfe_dev->current_subdev;
1452
1453	return v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1454					 core, queryctrl, qctrl);
1455
1456}
1457
1458static int vpfe_g_ctrl(struct file *file, void *priv, struct v4l2_control *ctrl)
1459{
1460	struct vpfe_device *vpfe_dev = video_drvdata(file);
1461	struct vpfe_subdev_info *sdinfo;
1462
1463	sdinfo = vpfe_dev->current_subdev;
1464
1465	return v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1466					 core, g_ctrl, ctrl);
1467}
1468
1469static int vpfe_s_ctrl(struct file *file, void *priv, struct v4l2_control *ctrl)
1470{
1471	struct vpfe_device *vpfe_dev = video_drvdata(file);
1472	struct vpfe_subdev_info *sdinfo;
1473
1474	sdinfo = vpfe_dev->current_subdev;
1475
1476	return v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1477					 core, s_ctrl, ctrl);
1478}
1479
1480/*
1481 * vpfe_calculate_offsets : This function calculates buffers offset
1482 * for top and bottom field
1483 */
1484static void vpfe_calculate_offsets(struct vpfe_device *vpfe_dev)
1485{
1486	struct v4l2_rect image_win;
1487
1488	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_calculate_offsets\n");
1489
1490	ccdc_dev->hw_ops.get_image_window(&image_win);
1491	vpfe_dev->field_off = image_win.height * image_win.width;
1492}
1493
1494/* vpfe_start_ccdc_capture: start streaming in ccdc/isif */
1495static void vpfe_start_ccdc_capture(struct vpfe_device *vpfe_dev)
1496{
1497	ccdc_dev->hw_ops.enable(1);
1498	if (ccdc_dev->hw_ops.enable_out_to_sdram)
1499		ccdc_dev->hw_ops.enable_out_to_sdram(1);
1500	vpfe_dev->started = 1;
1501}
1502
1503/*
1504 * vpfe_streamon. Assume the DMA queue is not empty.
1505 * application is expected to call QBUF before calling
1506 * this ioctl. If not, driver returns error
1507 */
1508static int vpfe_streamon(struct file *file, void *priv,
1509			 enum v4l2_buf_type buf_type)
1510{
1511	struct vpfe_device *vpfe_dev = video_drvdata(file);
1512	struct vpfe_fh *fh = file->private_data;
1513	struct vpfe_subdev_info *sdinfo;
1514	unsigned long addr;
1515	int ret = 0;
1516
1517	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_streamon\n");
1518
1519	if (V4L2_BUF_TYPE_VIDEO_CAPTURE != buf_type) {
1520		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid buf type\n");
1521		return -EINVAL;
1522	}
1523
1524	/* If file handle is not allowed IO, return error */
1525	if (!fh->io_allowed) {
1526		v4l2_err(&vpfe_dev->v4l2_dev, "fh->io_allowed\n");
1527		return -EACCES;
1528	}
1529
1530	sdinfo = vpfe_dev->current_subdev;
1531	ret = v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1532					video, s_stream, 1);
1533
1534	if (ret && (ret != -ENOIOCTLCMD)) {
1535		v4l2_err(&vpfe_dev->v4l2_dev, "stream on failed in subdev\n");
1536		return -EINVAL;
1537	}
1538
1539	/* If buffer queue is empty, return error */
1540	if (list_empty(&vpfe_dev->buffer_queue.stream)) {
1541		v4l2_err(&vpfe_dev->v4l2_dev, "buffer queue is empty\n");
1542		return -EIO;
1543	}
1544
1545	/* Call videobuf_streamon to start streaming * in videobuf */
1546	ret = videobuf_streamon(&vpfe_dev->buffer_queue);
1547	if (ret)
1548		return ret;
1549
1550
1551	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1552	if (ret)
1553		goto streamoff;
1554	/* Get the next frame from the buffer queue */
1555	vpfe_dev->next_frm = list_entry(vpfe_dev->dma_queue.next,
1556					struct videobuf_buffer, queue);
1557	vpfe_dev->cur_frm = vpfe_dev->next_frm;
1558	/* Remove buffer from the buffer queue */
1559	list_del(&vpfe_dev->cur_frm->queue);
1560	/* Mark state of the current frame to active */
1561	vpfe_dev->cur_frm->state = VIDEOBUF_ACTIVE;
1562	/* Initialize field_id and started member */
1563	vpfe_dev->field_id = 0;
1564	addr = videobuf_to_dma_contig(vpfe_dev->cur_frm);
1565
1566	/* Calculate field offset */
1567	vpfe_calculate_offsets(vpfe_dev);
1568
1569	if (vpfe_attach_irq(vpfe_dev) < 0) {
1570		v4l2_err(&vpfe_dev->v4l2_dev,
1571			 "Error in attaching interrupt handle\n");
1572		ret = -EFAULT;
1573		goto unlock_out;
1574	}
1575	if (ccdc_dev->hw_ops.configure() < 0) {
1576		v4l2_err(&vpfe_dev->v4l2_dev,
1577			 "Error in configuring ccdc\n");
1578		ret = -EINVAL;
1579		goto unlock_out;
1580	}
1581	ccdc_dev->hw_ops.setfbaddr((unsigned long)(addr));
1582	vpfe_start_ccdc_capture(vpfe_dev);
1583	mutex_unlock(&vpfe_dev->lock);
1584	return ret;
1585unlock_out:
1586	mutex_unlock(&vpfe_dev->lock);
1587streamoff:
1588	ret = videobuf_streamoff(&vpfe_dev->buffer_queue);
1589	return ret;
1590}
1591
1592static int vpfe_streamoff(struct file *file, void *priv,
1593			  enum v4l2_buf_type buf_type)
1594{
1595	struct vpfe_device *vpfe_dev = video_drvdata(file);
1596	struct vpfe_fh *fh = file->private_data;
1597	struct vpfe_subdev_info *sdinfo;
1598	int ret = 0;
1599
1600	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_streamoff\n");
1601
1602	if (V4L2_BUF_TYPE_VIDEO_CAPTURE != buf_type) {
1603		v4l2_err(&vpfe_dev->v4l2_dev, "Invalid buf type\n");
1604		return -EINVAL;
1605	}
1606
1607	/* If io is allowed for this file handle, return error */
1608	if (!fh->io_allowed) {
1609		v4l2_err(&vpfe_dev->v4l2_dev, "fh->io_allowed\n");
1610		return -EACCES;
1611	}
1612
1613	/* If streaming is not started, return error */
1614	if (!vpfe_dev->started) {
1615		v4l2_err(&vpfe_dev->v4l2_dev, "device started\n");
1616		return -EINVAL;
1617	}
1618
1619	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1620	if (ret)
1621		return ret;
1622
1623	vpfe_stop_ccdc_capture(vpfe_dev);
1624	vpfe_detach_irq(vpfe_dev);
1625
1626	sdinfo = vpfe_dev->current_subdev;
1627	ret = v4l2_device_call_until_err(&vpfe_dev->v4l2_dev, sdinfo->grp_id,
1628					video, s_stream, 0);
1629
1630	if (ret && (ret != -ENOIOCTLCMD))
1631		v4l2_err(&vpfe_dev->v4l2_dev, "stream off failed in subdev\n");
1632	ret = videobuf_streamoff(&vpfe_dev->buffer_queue);
1633	mutex_unlock(&vpfe_dev->lock);
1634	return ret;
1635}
1636
1637static int vpfe_cropcap(struct file *file, void *priv,
1638			      struct v4l2_cropcap *crop)
1639{
1640	struct vpfe_device *vpfe_dev = video_drvdata(file);
1641
1642	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_cropcap\n");
1643
1644	if (vpfe_dev->std_index >= ARRAY_SIZE(vpfe_standards))
1645		return -EINVAL;
1646
1647	memset(crop, 0, sizeof(struct v4l2_cropcap));
1648	crop->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
1649	crop->bounds.width = crop->defrect.width =
1650		vpfe_standards[vpfe_dev->std_index].width;
1651	crop->bounds.height = crop->defrect.height =
1652		vpfe_standards[vpfe_dev->std_index].height;
1653	crop->pixelaspect = vpfe_standards[vpfe_dev->std_index].pixelaspect;
1654	return 0;
1655}
1656
1657static int vpfe_g_crop(struct file *file, void *priv,
1658			     struct v4l2_crop *crop)
1659{
1660	struct vpfe_device *vpfe_dev = video_drvdata(file);
1661
1662	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_g_crop\n");
1663
1664	crop->c = vpfe_dev->crop;
1665	return 0;
1666}
1667
1668static int vpfe_s_crop(struct file *file, void *priv,
1669			     struct v4l2_crop *crop)
1670{
1671	struct vpfe_device *vpfe_dev = video_drvdata(file);
1672	int ret = 0;
1673
1674	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_s_crop\n");
1675
1676	if (vpfe_dev->started) {
1677		/* make sure streaming is not started */
1678		v4l2_err(&vpfe_dev->v4l2_dev,
1679			"Cannot change crop when streaming is ON\n");
1680		return -EBUSY;
1681	}
1682
1683	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1684	if (ret)
1685		return ret;
1686
1687	if (crop->c.top < 0 || crop->c.left < 0) {
1688		v4l2_err(&vpfe_dev->v4l2_dev,
1689			"doesn't support negative values for top & left\n");
1690		ret = -EINVAL;
1691		goto unlock_out;
1692	}
1693
1694	/* adjust the width to 16 pixel boundary */
1695	crop->c.width = ((crop->c.width + 15) & ~0xf);
1696
1697	/* make sure parameters are valid */
1698	if ((crop->c.left + crop->c.width >
1699		vpfe_dev->std_info.active_pixels) ||
1700	    (crop->c.top + crop->c.height >
1701		vpfe_dev->std_info.active_lines)) {
1702		v4l2_err(&vpfe_dev->v4l2_dev, "Error in S_CROP params\n");
1703		ret = -EINVAL;
1704		goto unlock_out;
1705	}
1706	ccdc_dev->hw_ops.set_image_window(&crop->c);
1707	vpfe_dev->fmt.fmt.pix.width = crop->c.width;
1708	vpfe_dev->fmt.fmt.pix.height = crop->c.height;
1709	vpfe_dev->fmt.fmt.pix.bytesperline =
1710		ccdc_dev->hw_ops.get_line_length();
1711	vpfe_dev->fmt.fmt.pix.sizeimage =
1712		vpfe_dev->fmt.fmt.pix.bytesperline *
1713		vpfe_dev->fmt.fmt.pix.height;
1714	vpfe_dev->crop = crop->c;
1715unlock_out:
1716	mutex_unlock(&vpfe_dev->lock);
1717	return ret;
1718}
1719
1720
1721static long vpfe_param_handler(struct file *file, void *priv,
1722		bool valid_prio, int cmd, void *param)
1723{
1724	struct vpfe_device *vpfe_dev = video_drvdata(file);
1725	int ret = 0;
1726
1727	v4l2_dbg(2, debug, &vpfe_dev->v4l2_dev, "vpfe_param_handler\n");
1728
1729	if (vpfe_dev->started) {
1730		/* only allowed if streaming is not started */
1731		v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
1732			"device already started\n");
1733		return -EBUSY;
1734	}
1735
1736	ret = mutex_lock_interruptible(&vpfe_dev->lock);
1737	if (ret)
1738		return ret;
1739
1740	switch (cmd) {
1741	case VPFE_CMD_S_CCDC_RAW_PARAMS:
1742		v4l2_warn(&vpfe_dev->v4l2_dev,
1743			  "VPFE_CMD_S_CCDC_RAW_PARAMS: experimental ioctl\n");
1744		if (ccdc_dev->hw_ops.set_params) {
1745			ret = ccdc_dev->hw_ops.set_params(param);
1746			if (ret) {
1747				v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
1748					"Error setting parameters in CCDC\n");
1749				goto unlock_out;
1750			}
1751			if (vpfe_get_ccdc_image_format(vpfe_dev,
1752						       &vpfe_dev->fmt) < 0) {
1753				v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
1754					"Invalid image format at CCDC\n");
1755				goto unlock_out;
1756			}
1757		} else {
1758			ret = -EINVAL;
1759			v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
1760				"VPFE_CMD_S_CCDC_RAW_PARAMS not supported\n");
1761		}
1762		break;
1763	default:
1764		ret = -EINVAL;
1765	}
1766unlock_out:
1767	mutex_unlock(&vpfe_dev->lock);
1768	return ret;
1769}
1770
1771
1772/* vpfe capture ioctl operations */
1773static const struct v4l2_ioctl_ops vpfe_ioctl_ops = {
1774	.vidioc_querycap	 = vpfe_querycap,
1775	.vidioc_g_fmt_vid_cap    = vpfe_g_fmt_vid_cap,
1776	.vidioc_enum_fmt_vid_cap = vpfe_enum_fmt_vid_cap,
1777	.vidioc_s_fmt_vid_cap    = vpfe_s_fmt_vid_cap,
1778	.vidioc_try_fmt_vid_cap  = vpfe_try_fmt_vid_cap,
1779	.vidioc_enum_input	 = vpfe_enum_input,
1780	.vidioc_g_input		 = vpfe_g_input,
1781	.vidioc_s_input		 = vpfe_s_input,
1782	.vidioc_querystd	 = vpfe_querystd,
1783	.vidioc_s_std		 = vpfe_s_std,
1784	.vidioc_g_std		 = vpfe_g_std,
1785	.vidioc_queryctrl	 = vpfe_queryctrl,
1786	.vidioc_g_ctrl		 = vpfe_g_ctrl,
1787	.vidioc_s_ctrl		 = vpfe_s_ctrl,
1788	.vidioc_reqbufs		 = vpfe_reqbufs,
1789	.vidioc_querybuf	 = vpfe_querybuf,
1790	.vidioc_qbuf		 = vpfe_qbuf,
1791	.vidioc_dqbuf		 = vpfe_dqbuf,
1792	.vidioc_streamon	 = vpfe_streamon,
1793	.vidioc_streamoff	 = vpfe_streamoff,
1794	.vidioc_cropcap		 = vpfe_cropcap,
1795	.vidioc_g_crop		 = vpfe_g_crop,
1796	.vidioc_s_crop		 = vpfe_s_crop,
1797	.vidioc_default		 = vpfe_param_handler,
1798};
1799
1800static struct vpfe_device *vpfe_initialize(void)
1801{
1802	struct vpfe_device *vpfe_dev;
1803
1804	/* Default number of buffers should be 3 */
1805	if ((numbuffers > 0) &&
1806	    (numbuffers < config_params.min_numbuffers))
1807		numbuffers = config_params.min_numbuffers;
1808
1809	/*
1810	 * Set buffer size to min buffers size if invalid buffer size is
1811	 * given
1812	 */
1813	if (bufsize < config_params.min_bufsize)
1814		bufsize = config_params.min_bufsize;
1815
1816	config_params.numbuffers = numbuffers;
1817
1818	if (numbuffers)
1819		config_params.device_bufsize = bufsize;
1820
1821	/* Allocate memory for device objects */
1822	vpfe_dev = kzalloc(sizeof(*vpfe_dev), GFP_KERNEL);
1823
1824	return vpfe_dev;
1825}
1826
1827/*
1828 * vpfe_probe : This function creates device entries by register
1829 * itself to the V4L2 driver and initializes fields of each
1830 * device objects
1831 */
1832static __init int vpfe_probe(struct platform_device *pdev)
1833{
1834	struct vpfe_subdev_info *sdinfo;
1835	struct vpfe_config *vpfe_cfg;
1836	struct resource *res1;
1837	struct vpfe_device *vpfe_dev;
1838	struct i2c_adapter *i2c_adap;
1839	struct video_device *vfd;
1840	int ret = -ENOMEM, i, j;
1841	int num_subdevs = 0;
1842
1843	/* Get the pointer to the device object */
1844	vpfe_dev = vpfe_initialize();
1845
1846	if (!vpfe_dev) {
1847		v4l2_err(pdev->dev.driver,
1848			"Failed to allocate memory for vpfe_dev\n");
1849		return ret;
1850	}
1851
1852	vpfe_dev->pdev = &pdev->dev;
1853
1854	if (NULL == pdev->dev.platform_data) {
1855		v4l2_err(pdev->dev.driver, "Unable to get vpfe config\n");
1856		ret = -ENODEV;
1857		goto probe_free_dev_mem;
1858	}
1859
1860	vpfe_cfg = pdev->dev.platform_data;
1861	vpfe_dev->cfg = vpfe_cfg;
1862	if (NULL == vpfe_cfg->ccdc ||
1863	    NULL == vpfe_cfg->card_name ||
1864	    NULL == vpfe_cfg->sub_devs) {
1865		v4l2_err(pdev->dev.driver, "null ptr in vpfe_cfg\n");
1866		ret = -ENOENT;
1867		goto probe_free_dev_mem;
1868	}
1869
1870	/* Allocate memory for ccdc configuration */
1871	ccdc_cfg = kmalloc(sizeof(struct ccdc_config), GFP_KERNEL);
1872	if (NULL == ccdc_cfg) {
1873		v4l2_err(pdev->dev.driver,
1874			 "Memory allocation failed for ccdc_cfg\n");
1875		goto probe_free_lock;
1876	}
1877
1878	mutex_lock(&ccdc_lock);
1879
1880	strncpy(ccdc_cfg->name, vpfe_cfg->ccdc, 32);
1881	/* Get VINT0 irq resource */
1882	res1 = platform_get_resource(pdev, IORESOURCE_IRQ, 0);
1883	if (!res1) {
1884		v4l2_err(pdev->dev.driver,
1885			 "Unable to get interrupt for VINT0\n");
1886		ret = -ENODEV;
1887		goto probe_free_ccdc_cfg_mem;
1888	}
1889	vpfe_dev->ccdc_irq0 = res1->start;
1890
1891	/* Get VINT1 irq resource */
1892	res1 = platform_get_resource(pdev, IORESOURCE_IRQ, 1);
1893	if (!res1) {
1894		v4l2_err(pdev->dev.driver,
1895			 "Unable to get interrupt for VINT1\n");
1896		ret = -ENODEV;
1897		goto probe_free_ccdc_cfg_mem;
1898	}
1899	vpfe_dev->ccdc_irq1 = res1->start;
1900
1901	ret = request_irq(vpfe_dev->ccdc_irq0, vpfe_isr, IRQF_DISABLED,
1902			  "vpfe_capture0", vpfe_dev);
1903
1904	if (0 != ret) {
1905		v4l2_err(pdev->dev.driver, "Unable to request interrupt\n");
1906		goto probe_free_ccdc_cfg_mem;
1907	}
1908
1909	/* Allocate memory for video device */
1910	vfd = video_device_alloc();
1911	if (NULL == vfd) {
1912		ret = -ENOMEM;
1913		v4l2_err(pdev->dev.driver, "Unable to alloc video device\n");
1914		goto probe_out_release_irq;
1915	}
1916
1917	/* Initialize field of video device */
1918	vfd->release		= video_device_release;
1919	vfd->fops		= &vpfe_fops;
1920	vfd->ioctl_ops		= &vpfe_ioctl_ops;
1921	vfd->tvnorms		= 0;
1922	vfd->current_norm	= V4L2_STD_PAL;
1923	vfd->v4l2_dev 		= &vpfe_dev->v4l2_dev;
1924	snprintf(vfd->name, sizeof(vfd->name),
1925		 "%s_V%d.%d.%d",
1926		 CAPTURE_DRV_NAME,
1927		 (VPFE_CAPTURE_VERSION_CODE >> 16) & 0xff,
1928		 (VPFE_CAPTURE_VERSION_CODE >> 8) & 0xff,
1929		 (VPFE_CAPTURE_VERSION_CODE) & 0xff);
1930	/* Set video_dev to the video device */
1931	vpfe_dev->video_dev	= vfd;
1932
1933	ret = v4l2_device_register(&pdev->dev, &vpfe_dev->v4l2_dev);
1934	if (ret) {
1935		v4l2_err(pdev->dev.driver,
1936			"Unable to register v4l2 device.\n");
1937		goto probe_out_video_release;
1938	}
1939	v4l2_info(&vpfe_dev->v4l2_dev, "v4l2 device registered\n");
1940	spin_lock_init(&vpfe_dev->irqlock);
1941	spin_lock_init(&vpfe_dev->dma_queue_lock);
1942	mutex_init(&vpfe_dev->lock);
1943
1944	/* Initialize field of the device objects */
1945	vpfe_dev->numbuffers = config_params.numbuffers;
1946
1947	/* Initialize prio member of device object */
1948	v4l2_prio_init(&vpfe_dev->prio);
1949	/* register video device */
1950	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
1951		"trying to register vpfe device.\n");
1952	v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev,
1953		"video_dev=%x\n", (int)&vpfe_dev->video_dev);
1954	vpfe_dev->fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
1955	ret = video_register_device(vpfe_dev->video_dev,
1956				    VFL_TYPE_GRABBER, -1);
1957
1958	if (ret) {
1959		v4l2_err(pdev->dev.driver,
1960			"Unable to register video device.\n");
1961		goto probe_out_v4l2_unregister;
1962	}
1963
1964	v4l2_info(&vpfe_dev->v4l2_dev, "video device registered\n");
1965	/* set the driver data in platform device */
1966	platform_set_drvdata(pdev, vpfe_dev);
1967	/* set driver private data */
1968	video_set_drvdata(vpfe_dev->video_dev, vpfe_dev);
1969	i2c_adap = i2c_get_adapter(vpfe_cfg->i2c_adapter_id);
1970	num_subdevs = vpfe_cfg->num_subdevs;
1971	vpfe_dev->sd = kmalloc(sizeof(struct v4l2_subdev *) * num_subdevs,
1972				GFP_KERNEL);
1973	if (NULL == vpfe_dev->sd) {
1974		v4l2_err(&vpfe_dev->v4l2_dev,
1975			"unable to allocate memory for subdevice pointers\n");
1976		ret = -ENOMEM;
1977		goto probe_out_video_unregister;
1978	}
1979
1980	for (i = 0; i < num_subdevs; i++) {
1981		struct v4l2_input *inps;
1982
1983		sdinfo = &vpfe_cfg->sub_devs[i];
1984
1985		/* Load up the subdevice */
1986		vpfe_dev->sd[i] =
1987			v4l2_i2c_new_subdev_board(&vpfe_dev->v4l2_dev,
1988						  i2c_adap,
1989						  &sdinfo->board_info,
1990						  NULL);
1991		if (vpfe_dev->sd[i]) {
1992			v4l2_info(&vpfe_dev->v4l2_dev,
1993				  "v4l2 sub device %s registered\n",
1994				  sdinfo->name);
1995			vpfe_dev->sd[i]->grp_id = sdinfo->grp_id;
1996			/* update tvnorms from the sub devices */
1997			for (j = 0; j < sdinfo->num_inputs; j++) {
1998				inps = &sdinfo->inputs[j];
1999				vfd->tvnorms |= inps->std;
2000			}
2001		} else {
2002			v4l2_info(&vpfe_dev->v4l2_dev,
2003				  "v4l2 sub device %s register fails\n",
2004				  sdinfo->name);
2005			goto probe_sd_out;
2006		}
2007	}
2008
2009	/* set first sub device as current one */
2010	vpfe_dev->current_subdev = &vpfe_cfg->sub_devs[0];
2011
2012	/* We have at least one sub device to work with */
2013	mutex_unlock(&ccdc_lock);
2014	return 0;
2015
2016probe_sd_out:
2017	kfree(vpfe_dev->sd);
2018probe_out_video_unregister:
2019	video_unregister_device(vpfe_dev->video_dev);
2020probe_out_v4l2_unregister:
2021	v4l2_device_unregister(&vpfe_dev->v4l2_dev);
2022probe_out_video_release:
2023	if (!video_is_registered(vpfe_dev->video_dev))
2024		video_device_release(vpfe_dev->video_dev);
2025probe_out_release_irq:
2026	free_irq(vpfe_dev->ccdc_irq0, vpfe_dev);
2027probe_free_ccdc_cfg_mem:
2028	kfree(ccdc_cfg);
2029probe_free_lock:
2030	mutex_unlock(&ccdc_lock);
2031probe_free_dev_mem:
2032	kfree(vpfe_dev);
2033	return ret;
2034}
2035
2036/*
2037 * vpfe_remove : It un-register device from V4L2 driver
2038 */
2039static int __devexit vpfe_remove(struct platform_device *pdev)
2040{
2041	struct vpfe_device *vpfe_dev = platform_get_drvdata(pdev);
2042
2043	v4l2_info(pdev->dev.driver, "vpfe_remove\n");
2044
2045	free_irq(vpfe_dev->ccdc_irq0, vpfe_dev);
2046	kfree(vpfe_dev->sd);
2047	v4l2_device_unregister(&vpfe_dev->v4l2_dev);
2048	video_unregister_device(vpfe_dev->video_dev);
2049	kfree(vpfe_dev);
2050	kfree(ccdc_cfg);
2051	return 0;
2052}
2053
2054static int vpfe_suspend(struct device *dev)
2055{
2056	return 0;
2057}
2058
2059static int vpfe_resume(struct device *dev)
2060{
2061	return 0;
2062}
2063
2064static const struct dev_pm_ops vpfe_dev_pm_ops = {
2065	.suspend = vpfe_suspend,
2066	.resume = vpfe_resume,
2067};
2068
2069static struct platform_driver vpfe_driver = {
2070	.driver = {
2071		.name = CAPTURE_DRV_NAME,
2072		.owner = THIS_MODULE,
2073		.pm = &vpfe_dev_pm_ops,
2074	},
2075	.probe = vpfe_probe,
2076	.remove = __devexit_p(vpfe_remove),
2077};
2078
2079module_platform_driver(vpfe_driver);
2080