1 /*
2  * Zoran zr36057/zr36067 PCI controller driver, for the
3  * Pinnacle/Miro DC10/DC10+/DC30/DC30+, Iomega Buz, Linux
4  * Media Labs LML33/LML33R10.
5  *
6  * Copyright (C) 2000 Serguei Miridonov <mirsev@cicese.mx>
7  *
8  * Changes for BUZ by Wolfgang Scherr <scherr@net4you.net>
9  *
10  * Changes for DC10/DC30 by Laurent Pinchart <laurent.pinchart@skynet.be>
11  *
12  * Changes for LML33R10 by Maxim Yevtyushkin <max@linuxmedialabs.com>
13  *
14  * Changes for videodev2/v4l2 by Ronald Bultje <rbultje@ronald.bitfreak.net>
15  *
16  * Based on
17  *
18  * Miro DC10 driver
19  * Copyright (C) 1999 Wolfgang Scherr <scherr@net4you.net>
20  *
21  * Iomega Buz driver version 1.0
22  * Copyright (C) 1999 Rainer Johanni <Rainer@Johanni.de>
23  *
24  * buz.0.0.3
25  * Copyright (C) 1998 Dave Perks <dperks@ibm.net>
26  *
27  * bttv - Bt848 frame grabber driver
28  * Copyright (C) 1996,97,98 Ralph  Metzler (rjkm@thp.uni-koeln.de)
29  *                        & Marcus Metzler (mocm@thp.uni-koeln.de)
30  *
31  *
32  * This program is free software; you can redistribute it and/or modify
33  * it under the terms of the GNU General Public License as published by
34  * the Free Software Foundation; either version 2 of the License, or
35  * (at your option) any later version.
36  *
37  * This program is distributed in the hope that it will be useful,
38  * but WITHOUT ANY WARRANTY; without even the implied warranty of
39  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
40  * GNU General Public License for more details.
41  */
42 
43 #include <linux/init.h>
44 #include <linux/module.h>
45 #include <linux/delay.h>
46 #include <linux/slab.h>
47 #include <linux/pci.h>
48 #include <linux/vmalloc.h>
49 #include <linux/wait.h>
50 
51 #include <linux/interrupt.h>
52 #include <linux/i2c.h>
53 #include <linux/i2c-algo-bit.h>
54 
55 #include <linux/spinlock.h>
56 
57 #include <linux/videodev2.h>
58 #include <media/v4l2-common.h>
59 #include <media/v4l2-ioctl.h>
60 #include <media/v4l2-event.h>
61 #include "videocodec.h"
62 
63 #include <asm/byteorder.h>
64 #include <asm/io.h>
65 #include <linux/uaccess.h>
66 #include <linux/proc_fs.h>
67 
68 #include <linux/mutex.h>
69 #include "zoran.h"
70 #include "zoran_device.h"
71 #include "zoran_card.h"
72 
73 
74 const struct zoran_format zoran_formats[] = {
75 	{
76 		.name = "15-bit RGB LE",
77 		.fourcc = V4L2_PIX_FMT_RGB555,
78 		.colorspace = V4L2_COLORSPACE_SRGB,
79 		.depth = 15,
80 		.flags = ZORAN_FORMAT_CAPTURE |
81 			 ZORAN_FORMAT_OVERLAY,
82 		.vfespfr = ZR36057_VFESPFR_RGB555|ZR36057_VFESPFR_ErrDif|
83 			   ZR36057_VFESPFR_LittleEndian,
84 	}, {
85 		.name = "15-bit RGB BE",
86 		.fourcc = V4L2_PIX_FMT_RGB555X,
87 		.colorspace = V4L2_COLORSPACE_SRGB,
88 		.depth = 15,
89 		.flags = ZORAN_FORMAT_CAPTURE |
90 			 ZORAN_FORMAT_OVERLAY,
91 		.vfespfr = ZR36057_VFESPFR_RGB555|ZR36057_VFESPFR_ErrDif,
92 	}, {
93 		.name = "16-bit RGB LE",
94 		.fourcc = V4L2_PIX_FMT_RGB565,
95 		.colorspace = V4L2_COLORSPACE_SRGB,
96 		.depth = 16,
97 		.flags = ZORAN_FORMAT_CAPTURE |
98 			 ZORAN_FORMAT_OVERLAY,
99 		.vfespfr = ZR36057_VFESPFR_RGB565|ZR36057_VFESPFR_ErrDif|
100 			   ZR36057_VFESPFR_LittleEndian,
101 	}, {
102 		.name = "16-bit RGB BE",
103 		.fourcc = V4L2_PIX_FMT_RGB565X,
104 		.colorspace = V4L2_COLORSPACE_SRGB,
105 		.depth = 16,
106 		.flags = ZORAN_FORMAT_CAPTURE |
107 			 ZORAN_FORMAT_OVERLAY,
108 		.vfespfr = ZR36057_VFESPFR_RGB565|ZR36057_VFESPFR_ErrDif,
109 	}, {
110 		.name = "24-bit RGB",
111 		.fourcc = V4L2_PIX_FMT_BGR24,
112 		.colorspace = V4L2_COLORSPACE_SRGB,
113 		.depth = 24,
114 		.flags = ZORAN_FORMAT_CAPTURE |
115 			 ZORAN_FORMAT_OVERLAY,
116 		.vfespfr = ZR36057_VFESPFR_RGB888|ZR36057_VFESPFR_Pack24,
117 	}, {
118 		.name = "32-bit RGB LE",
119 		.fourcc = V4L2_PIX_FMT_BGR32,
120 		.colorspace = V4L2_COLORSPACE_SRGB,
121 		.depth = 32,
122 		.flags = ZORAN_FORMAT_CAPTURE |
123 			 ZORAN_FORMAT_OVERLAY,
124 		.vfespfr = ZR36057_VFESPFR_RGB888|ZR36057_VFESPFR_LittleEndian,
125 	}, {
126 		.name = "32-bit RGB BE",
127 		.fourcc = V4L2_PIX_FMT_RGB32,
128 		.colorspace = V4L2_COLORSPACE_SRGB,
129 		.depth = 32,
130 		.flags = ZORAN_FORMAT_CAPTURE |
131 			 ZORAN_FORMAT_OVERLAY,
132 		.vfespfr = ZR36057_VFESPFR_RGB888,
133 	}, {
134 		.name = "4:2:2, packed, YUYV",
135 		.fourcc = V4L2_PIX_FMT_YUYV,
136 		.colorspace = V4L2_COLORSPACE_SMPTE170M,
137 		.depth = 16,
138 		.flags = ZORAN_FORMAT_CAPTURE |
139 			 ZORAN_FORMAT_OVERLAY,
140 		.vfespfr = ZR36057_VFESPFR_YUV422,
141 	}, {
142 		.name = "4:2:2, packed, UYVY",
143 		.fourcc = V4L2_PIX_FMT_UYVY,
144 		.colorspace = V4L2_COLORSPACE_SMPTE170M,
145 		.depth = 16,
146 		.flags = ZORAN_FORMAT_CAPTURE |
147 			 ZORAN_FORMAT_OVERLAY,
148 		.vfespfr = ZR36057_VFESPFR_YUV422|ZR36057_VFESPFR_LittleEndian,
149 	}, {
150 		.name = "Hardware-encoded Motion-JPEG",
151 		.fourcc = V4L2_PIX_FMT_MJPEG,
152 		.colorspace = V4L2_COLORSPACE_SMPTE170M,
153 		.depth = 0,
154 		.flags = ZORAN_FORMAT_CAPTURE |
155 			 ZORAN_FORMAT_PLAYBACK |
156 			 ZORAN_FORMAT_COMPRESSED,
157 	}
158 };
159 #define NUM_FORMATS ARRAY_SIZE(zoran_formats)
160 
161 	/* small helper function for calculating buffersizes for v4l2
162 	 * we calculate the nearest higher power-of-two, which
163 	 * will be the recommended buffersize */
164 static __u32
165 zoran_v4l2_calc_bufsize (struct zoran_jpg_settings *settings)
166 {
167 	__u8 div = settings->VerDcm * settings->HorDcm * settings->TmpDcm;
168 	__u32 num = (1024 * 512) / (div);
169 	__u32 result = 2;
170 
171 	num--;
172 	while (num) {
173 		num >>= 1;
174 		result <<= 1;
175 	}
176 
177 	if (result > jpg_bufsize)
178 		return jpg_bufsize;
179 	if (result < 8192)
180 		return 8192;
181 	return result;
182 }
183 
184 /* forward references */
185 static void v4l_fbuffer_free(struct zoran_fh *fh);
186 static void jpg_fbuffer_free(struct zoran_fh *fh);
187 
188 /* Set mapping mode */
189 static void map_mode_raw(struct zoran_fh *fh)
190 {
191 	fh->map_mode = ZORAN_MAP_MODE_RAW;
192 	fh->buffers.buffer_size = v4l_bufsize;
193 	fh->buffers.num_buffers = v4l_nbufs;
194 }
195 static void map_mode_jpg(struct zoran_fh *fh, int play)
196 {
197 	fh->map_mode = play ? ZORAN_MAP_MODE_JPG_PLAY : ZORAN_MAP_MODE_JPG_REC;
198 	fh->buffers.buffer_size = jpg_bufsize;
199 	fh->buffers.num_buffers = jpg_nbufs;
200 }
201 static inline const char *mode_name(enum zoran_map_mode mode)
202 {
203 	return mode == ZORAN_MAP_MODE_RAW ? "V4L" : "JPG";
204 }
205 
206 /*
207  *   Allocate the V4L grab buffers
208  *
209  *   These have to be pysically contiguous.
210  */
211 
212 static int v4l_fbuffer_alloc(struct zoran_fh *fh)
213 {
214 	struct zoran *zr = fh->zr;
215 	int i, off;
216 	unsigned char *mem;
217 
218 	for (i = 0; i < fh->buffers.num_buffers; i++) {
219 		if (fh->buffers.buffer[i].v4l.fbuffer)
220 			dprintk(2,
221 				KERN_WARNING
222 				"%s: %s - buffer %d already allocated!?\n",
223 				ZR_DEVNAME(zr), __func__, i);
224 
225 		//udelay(20);
226 		mem = kmalloc(fh->buffers.buffer_size,
227 			      GFP_KERNEL | __GFP_NOWARN);
228 		if (!mem) {
229 			dprintk(1,
230 				KERN_ERR
231 				"%s: %s - kmalloc for V4L buf %d failed\n",
232 				ZR_DEVNAME(zr), __func__, i);
233 			v4l_fbuffer_free(fh);
234 			return -ENOBUFS;
235 		}
236 		fh->buffers.buffer[i].v4l.fbuffer = mem;
237 		fh->buffers.buffer[i].v4l.fbuffer_phys = virt_to_phys(mem);
238 		fh->buffers.buffer[i].v4l.fbuffer_bus = virt_to_bus(mem);
239 		for (off = 0; off < fh->buffers.buffer_size;
240 		     off += PAGE_SIZE)
241 			SetPageReserved(virt_to_page(mem + off));
242 		dprintk(4,
243 			KERN_INFO
244 			"%s: %s - V4L frame %d mem 0x%lx (bus: 0x%llx)\n",
245 			ZR_DEVNAME(zr), __func__, i, (unsigned long) mem,
246 			(unsigned long long)virt_to_bus(mem));
247 	}
248 
249 	fh->buffers.allocated = 1;
250 
251 	return 0;
252 }
253 
254 /* free the V4L grab buffers */
255 static void v4l_fbuffer_free(struct zoran_fh *fh)
256 {
257 	struct zoran *zr = fh->zr;
258 	int i, off;
259 	unsigned char *mem;
260 
261 	dprintk(4, KERN_INFO "%s: %s\n", ZR_DEVNAME(zr), __func__);
262 
263 	for (i = 0; i < fh->buffers.num_buffers; i++) {
264 		if (!fh->buffers.buffer[i].v4l.fbuffer)
265 			continue;
266 
267 		mem = fh->buffers.buffer[i].v4l.fbuffer;
268 		for (off = 0; off < fh->buffers.buffer_size;
269 		     off += PAGE_SIZE)
270 			ClearPageReserved(virt_to_page(mem + off));
271 		kfree(fh->buffers.buffer[i].v4l.fbuffer);
272 		fh->buffers.buffer[i].v4l.fbuffer = NULL;
273 	}
274 
275 	fh->buffers.allocated = 0;
276 }
277 
278 /*
279  *   Allocate the MJPEG grab buffers.
280  *
281  *   If a Natoma chipset is present and this is a revision 1 zr36057,
282  *   each MJPEG buffer needs to be physically contiguous.
283  *   (RJ: This statement is from Dave Perks' original driver,
284  *   I could never check it because I have a zr36067)
285  *
286  *   RJ: The contents grab buffers needs never be accessed in the driver.
287  *       Therefore there is no need to allocate them with vmalloc in order
288  *       to get a contiguous virtual memory space.
289  *       I don't understand why many other drivers first allocate them with
290  *       vmalloc (which uses internally also get_zeroed_page, but delivers you
291  *       virtual addresses) and then again have to make a lot of efforts
292  *       to get the physical address.
293  *
294  *   Ben Capper:
295  *       On big-endian architectures (such as ppc) some extra steps
296  *       are needed. When reading and writing to the stat_com array
297  *       and fragment buffers, the device expects to see little-
298  *       endian values. The use of cpu_to_le32() and le32_to_cpu()
299  *       in this function (and one or two others in zoran_device.c)
300  *       ensure that these values are always stored in little-endian
301  *       form, regardless of architecture. The zr36057 does Very Bad
302  *       Things on big endian architectures if the stat_com array
303  *       and fragment buffers are not little-endian.
304  */
305 
306 static int jpg_fbuffer_alloc(struct zoran_fh *fh)
307 {
308 	struct zoran *zr = fh->zr;
309 	int i, j, off;
310 	u8 *mem;
311 
312 	for (i = 0; i < fh->buffers.num_buffers; i++) {
313 		if (fh->buffers.buffer[i].jpg.frag_tab)
314 			dprintk(2,
315 				KERN_WARNING
316 				"%s: %s - buffer %d already allocated!?\n",
317 				ZR_DEVNAME(zr), __func__, i);
318 
319 		/* Allocate fragment table for this buffer */
320 
321 		mem = (void *)get_zeroed_page(GFP_KERNEL);
322 		if (!mem) {
323 			dprintk(1,
324 				KERN_ERR
325 				"%s: %s - get_zeroed_page (frag_tab) failed for buffer %d\n",
326 				ZR_DEVNAME(zr), __func__, i);
327 			jpg_fbuffer_free(fh);
328 			return -ENOBUFS;
329 		}
330 		fh->buffers.buffer[i].jpg.frag_tab = (__le32 *)mem;
331 		fh->buffers.buffer[i].jpg.frag_tab_bus = virt_to_bus(mem);
332 
333 		if (fh->buffers.need_contiguous) {
334 			mem = kmalloc(fh->buffers.buffer_size, GFP_KERNEL);
335 			if (mem == NULL) {
336 				dprintk(1,
337 					KERN_ERR
338 					"%s: %s - kmalloc failed for buffer %d\n",
339 					ZR_DEVNAME(zr), __func__, i);
340 				jpg_fbuffer_free(fh);
341 				return -ENOBUFS;
342 			}
343 			fh->buffers.buffer[i].jpg.frag_tab[0] =
344 				cpu_to_le32(virt_to_bus(mem));
345 			fh->buffers.buffer[i].jpg.frag_tab[1] =
346 				cpu_to_le32((fh->buffers.buffer_size >> 1) | 1);
347 			for (off = 0; off < fh->buffers.buffer_size; off += PAGE_SIZE)
348 				SetPageReserved(virt_to_page(mem + off));
349 		} else {
350 			/* jpg_bufsize is already page aligned */
351 			for (j = 0; j < fh->buffers.buffer_size / PAGE_SIZE; j++) {
352 				mem = (void *)get_zeroed_page(GFP_KERNEL);
353 				if (mem == NULL) {
354 					dprintk(1,
355 						KERN_ERR
356 						"%s: %s - get_zeroed_page failed for buffer %d\n",
357 						ZR_DEVNAME(zr), __func__, i);
358 					jpg_fbuffer_free(fh);
359 					return -ENOBUFS;
360 				}
361 
362 				fh->buffers.buffer[i].jpg.frag_tab[2 * j] =
363 					cpu_to_le32(virt_to_bus(mem));
364 				fh->buffers.buffer[i].jpg.frag_tab[2 * j + 1] =
365 					cpu_to_le32((PAGE_SIZE >> 2) << 1);
366 				SetPageReserved(virt_to_page(mem));
367 			}
368 
369 			fh->buffers.buffer[i].jpg.frag_tab[2 * j - 1] |= cpu_to_le32(1);
370 		}
371 	}
372 
373 	dprintk(4,
374 		KERN_DEBUG "%s: %s - %d KB allocated\n",
375 		ZR_DEVNAME(zr), __func__,
376 		(fh->buffers.num_buffers * fh->buffers.buffer_size) >> 10);
377 
378 	fh->buffers.allocated = 1;
379 
380 	return 0;
381 }
382 
383 /* free the MJPEG grab buffers */
384 static void jpg_fbuffer_free(struct zoran_fh *fh)
385 {
386 	struct zoran *zr = fh->zr;
387 	int i, j, off;
388 	unsigned char *mem;
389 	__le32 frag_tab;
390 	struct zoran_buffer *buffer;
391 
392 	dprintk(4, KERN_DEBUG "%s: %s\n", ZR_DEVNAME(zr), __func__);
393 
394 	for (i = 0, buffer = &fh->buffers.buffer[0];
395 	     i < fh->buffers.num_buffers; i++, buffer++) {
396 		if (!buffer->jpg.frag_tab)
397 			continue;
398 
399 		if (fh->buffers.need_contiguous) {
400 			frag_tab = buffer->jpg.frag_tab[0];
401 
402 			if (frag_tab) {
403 				mem = bus_to_virt(le32_to_cpu(frag_tab));
404 				for (off = 0; off < fh->buffers.buffer_size; off += PAGE_SIZE)
405 					ClearPageReserved(virt_to_page(mem + off));
406 				kfree(mem);
407 				buffer->jpg.frag_tab[0] = 0;
408 				buffer->jpg.frag_tab[1] = 0;
409 			}
410 		} else {
411 			for (j = 0; j < fh->buffers.buffer_size / PAGE_SIZE; j++) {
412 				frag_tab = buffer->jpg.frag_tab[2 * j];
413 
414 				if (!frag_tab)
415 					break;
416 				ClearPageReserved(virt_to_page(bus_to_virt(le32_to_cpu(frag_tab))));
417 				free_page((unsigned long)bus_to_virt(le32_to_cpu(frag_tab)));
418 				buffer->jpg.frag_tab[2 * j] = 0;
419 				buffer->jpg.frag_tab[2 * j + 1] = 0;
420 			}
421 		}
422 
423 		free_page((unsigned long)buffer->jpg.frag_tab);
424 		buffer->jpg.frag_tab = NULL;
425 	}
426 
427 	fh->buffers.allocated = 0;
428 }
429 
430 /*
431  *   V4L Buffer grabbing
432  */
433 
434 static int
435 zoran_v4l_set_format (struct zoran_fh           *fh,
436 		      int                        width,
437 		      int                        height,
438 		      const struct zoran_format *format)
439 {
440 	struct zoran *zr = fh->zr;
441 	int bpp;
442 
443 	/* Check size and format of the grab wanted */
444 
445 	if (height < BUZ_MIN_HEIGHT || width < BUZ_MIN_WIDTH ||
446 	    height > BUZ_MAX_HEIGHT || width > BUZ_MAX_WIDTH) {
447 		dprintk(1,
448 			KERN_ERR
449 			"%s: %s - wrong frame size (%dx%d)\n",
450 			ZR_DEVNAME(zr), __func__, width, height);
451 		return -EINVAL;
452 	}
453 
454 	bpp = (format->depth + 7) / 8;
455 
456 	/* Check against available buffer size */
457 	if (height * width * bpp > fh->buffers.buffer_size) {
458 		dprintk(1,
459 			KERN_ERR
460 			"%s: %s - video buffer size (%d kB) is too small\n",
461 			ZR_DEVNAME(zr), __func__, fh->buffers.buffer_size >> 10);
462 		return -EINVAL;
463 	}
464 
465 	/* The video front end needs 4-byte alinged line sizes */
466 
467 	if ((bpp == 2 && (width & 1)) || (bpp == 3 && (width & 3))) {
468 		dprintk(1,
469 			KERN_ERR
470 			"%s: %s - wrong frame alignment\n",
471 			ZR_DEVNAME(zr), __func__);
472 		return -EINVAL;
473 	}
474 
475 	fh->v4l_settings.width = width;
476 	fh->v4l_settings.height = height;
477 	fh->v4l_settings.format = format;
478 	fh->v4l_settings.bytesperline = bpp * fh->v4l_settings.width;
479 
480 	return 0;
481 }
482 
483 static int zoran_v4l_queue_frame(struct zoran_fh *fh, int num)
484 {
485 	struct zoran *zr = fh->zr;
486 	unsigned long flags;
487 	int res = 0;
488 
489 	if (!fh->buffers.allocated) {
490 		dprintk(1,
491 			KERN_ERR
492 			"%s: %s - buffers not yet allocated\n",
493 			ZR_DEVNAME(zr), __func__);
494 		res = -ENOMEM;
495 	}
496 
497 	/* No grabbing outside the buffer range! */
498 	if (num >= fh->buffers.num_buffers || num < 0) {
499 		dprintk(1,
500 			KERN_ERR
501 			"%s: %s - buffer %d is out of range\n",
502 			ZR_DEVNAME(zr), __func__, num);
503 		res = -EINVAL;
504 	}
505 
506 	spin_lock_irqsave(&zr->spinlock, flags);
507 
508 	if (fh->buffers.active == ZORAN_FREE) {
509 		if (zr->v4l_buffers.active == ZORAN_FREE) {
510 			zr->v4l_buffers = fh->buffers;
511 			fh->buffers.active = ZORAN_ACTIVE;
512 		} else {
513 			dprintk(1,
514 				KERN_ERR
515 				"%s: %s - another session is already capturing\n",
516 				ZR_DEVNAME(zr), __func__);
517 			res = -EBUSY;
518 		}
519 	}
520 
521 	/* make sure a grab isn't going on currently with this buffer */
522 	if (!res) {
523 		switch (zr->v4l_buffers.buffer[num].state) {
524 		default:
525 		case BUZ_STATE_PEND:
526 			if (zr->v4l_buffers.active == ZORAN_FREE) {
527 				fh->buffers.active = ZORAN_FREE;
528 				zr->v4l_buffers.allocated = 0;
529 			}
530 			res = -EBUSY;	/* what are you doing? */
531 			break;
532 		case BUZ_STATE_DONE:
533 			dprintk(2,
534 				KERN_WARNING
535 				"%s: %s - queueing buffer %d in state DONE!?\n",
536 				ZR_DEVNAME(zr), __func__, num);
537 			/* fall through */
538 		case BUZ_STATE_USER:
539 			/* since there is at least one unused buffer there's room for at least
540 			 * one more pend[] entry */
541 			zr->v4l_pend[zr->v4l_pend_head++ & V4L_MASK_FRAME] = num;
542 			zr->v4l_buffers.buffer[num].state = BUZ_STATE_PEND;
543 			zr->v4l_buffers.buffer[num].bs.length =
544 			    fh->v4l_settings.bytesperline *
545 			    zr->v4l_settings.height;
546 			fh->buffers.buffer[num] = zr->v4l_buffers.buffer[num];
547 			break;
548 		}
549 	}
550 
551 	spin_unlock_irqrestore(&zr->spinlock, flags);
552 
553 	if (!res && zr->v4l_buffers.active == ZORAN_FREE)
554 		zr->v4l_buffers.active = fh->buffers.active;
555 
556 	return res;
557 }
558 
559 /*
560  * Sync on a V4L buffer
561  */
562 
563 static int v4l_sync(struct zoran_fh *fh, int frame)
564 {
565 	struct zoran *zr = fh->zr;
566 	unsigned long flags;
567 
568 	if (fh->buffers.active == ZORAN_FREE) {
569 		dprintk(1,
570 			KERN_ERR
571 			"%s: %s - no grab active for this session\n",
572 			ZR_DEVNAME(zr), __func__);
573 		return -EINVAL;
574 	}
575 
576 	/* check passed-in frame number */
577 	if (frame >= fh->buffers.num_buffers || frame < 0) {
578 		dprintk(1,
579 			KERN_ERR "%s: %s - frame %d is invalid\n",
580 			ZR_DEVNAME(zr), __func__, frame);
581 		return -EINVAL;
582 	}
583 
584 	/* Check if is buffer was queued at all */
585 	if (zr->v4l_buffers.buffer[frame].state == BUZ_STATE_USER) {
586 		dprintk(1,
587 			KERN_ERR
588 			"%s: %s - attempt to sync on a buffer which was not queued?\n",
589 			ZR_DEVNAME(zr), __func__);
590 		return -EPROTO;
591 	}
592 
593 	mutex_unlock(&zr->lock);
594 	/* wait on this buffer to get ready */
595 	if (!wait_event_interruptible_timeout(zr->v4l_capq,
596 		(zr->v4l_buffers.buffer[frame].state != BUZ_STATE_PEND), 10*HZ)) {
597 		mutex_lock(&zr->lock);
598 		return -ETIME;
599 	}
600 	mutex_lock(&zr->lock);
601 	if (signal_pending(current))
602 		return -ERESTARTSYS;
603 
604 	/* buffer should now be in BUZ_STATE_DONE */
605 	if (zr->v4l_buffers.buffer[frame].state != BUZ_STATE_DONE)
606 		dprintk(2,
607 			KERN_ERR "%s: %s - internal state error\n",
608 			ZR_DEVNAME(zr), __func__);
609 
610 	zr->v4l_buffers.buffer[frame].state = BUZ_STATE_USER;
611 	fh->buffers.buffer[frame] = zr->v4l_buffers.buffer[frame];
612 
613 	spin_lock_irqsave(&zr->spinlock, flags);
614 
615 	/* Check if streaming capture has finished */
616 	if (zr->v4l_pend_tail == zr->v4l_pend_head) {
617 		zr36057_set_memgrab(zr, 0);
618 		if (zr->v4l_buffers.active == ZORAN_ACTIVE) {
619 			fh->buffers.active = zr->v4l_buffers.active = ZORAN_FREE;
620 			zr->v4l_buffers.allocated = 0;
621 		}
622 	}
623 
624 	spin_unlock_irqrestore(&zr->spinlock, flags);
625 
626 	return 0;
627 }
628 
629 /*
630  *   Queue a MJPEG buffer for capture/playback
631  */
632 
633 static int zoran_jpg_queue_frame(struct zoran_fh *fh, int num,
634 				 enum zoran_codec_mode mode)
635 {
636 	struct zoran *zr = fh->zr;
637 	unsigned long flags;
638 	int res = 0;
639 
640 	/* Check if buffers are allocated */
641 	if (!fh->buffers.allocated) {
642 		dprintk(1,
643 			KERN_ERR
644 			"%s: %s - buffers not yet allocated\n",
645 			ZR_DEVNAME(zr), __func__);
646 		return -ENOMEM;
647 	}
648 
649 	/* No grabbing outside the buffer range! */
650 	if (num >= fh->buffers.num_buffers || num < 0) {
651 		dprintk(1,
652 			KERN_ERR
653 			"%s: %s - buffer %d out of range\n",
654 			ZR_DEVNAME(zr), __func__, num);
655 		return -EINVAL;
656 	}
657 
658 	/* what is the codec mode right now? */
659 	if (zr->codec_mode == BUZ_MODE_IDLE) {
660 		zr->jpg_settings = fh->jpg_settings;
661 	} else if (zr->codec_mode != mode) {
662 		/* wrong codec mode active - invalid */
663 		dprintk(1,
664 			KERN_ERR
665 			"%s: %s - codec in wrong mode\n",
666 			ZR_DEVNAME(zr), __func__);
667 		return -EINVAL;
668 	}
669 
670 	if (fh->buffers.active == ZORAN_FREE) {
671 		if (zr->jpg_buffers.active == ZORAN_FREE) {
672 			zr->jpg_buffers = fh->buffers;
673 			fh->buffers.active = ZORAN_ACTIVE;
674 		} else {
675 			dprintk(1,
676 				KERN_ERR
677 				"%s: %s - another session is already capturing\n",
678 				ZR_DEVNAME(zr), __func__);
679 			res = -EBUSY;
680 		}
681 	}
682 
683 	if (!res && zr->codec_mode == BUZ_MODE_IDLE) {
684 		/* Ok load up the jpeg codec */
685 		zr36057_enable_jpg(zr, mode);
686 	}
687 
688 	spin_lock_irqsave(&zr->spinlock, flags);
689 
690 	if (!res) {
691 		switch (zr->jpg_buffers.buffer[num].state) {
692 		case BUZ_STATE_DONE:
693 			dprintk(2,
694 				KERN_WARNING
695 				"%s: %s - queing frame in BUZ_STATE_DONE state!?\n",
696 				ZR_DEVNAME(zr), __func__);
697 			/* fall through */
698 		case BUZ_STATE_USER:
699 			/* since there is at least one unused buffer there's room for at
700 			 *least one more pend[] entry */
701 			zr->jpg_pend[zr->jpg_que_head++ & BUZ_MASK_FRAME] = num;
702 			zr->jpg_buffers.buffer[num].state = BUZ_STATE_PEND;
703 			fh->buffers.buffer[num] = zr->jpg_buffers.buffer[num];
704 			zoran_feed_stat_com(zr);
705 			break;
706 		default:
707 		case BUZ_STATE_DMA:
708 		case BUZ_STATE_PEND:
709 			if (zr->jpg_buffers.active == ZORAN_FREE) {
710 				fh->buffers.active = ZORAN_FREE;
711 				zr->jpg_buffers.allocated = 0;
712 			}
713 			res = -EBUSY;	/* what are you doing? */
714 			break;
715 		}
716 	}
717 
718 	spin_unlock_irqrestore(&zr->spinlock, flags);
719 
720 	if (!res && zr->jpg_buffers.active == ZORAN_FREE)
721 		zr->jpg_buffers.active = fh->buffers.active;
722 
723 	return res;
724 }
725 
726 static int jpg_qbuf(struct zoran_fh *fh, int frame, enum zoran_codec_mode mode)
727 {
728 	struct zoran *zr = fh->zr;
729 	int res = 0;
730 
731 	/* Does the user want to stop streaming? */
732 	if (frame < 0) {
733 		if (zr->codec_mode == mode) {
734 			if (fh->buffers.active == ZORAN_FREE) {
735 				dprintk(1,
736 					KERN_ERR
737 					"%s: %s(-1) - session not active\n",
738 					ZR_DEVNAME(zr), __func__);
739 				return -EINVAL;
740 			}
741 			fh->buffers.active = zr->jpg_buffers.active = ZORAN_FREE;
742 			zr->jpg_buffers.allocated = 0;
743 			zr36057_enable_jpg(zr, BUZ_MODE_IDLE);
744 			return 0;
745 		} else {
746 			dprintk(1,
747 				KERN_ERR
748 				"%s: %s - stop streaming but not in streaming mode\n",
749 				ZR_DEVNAME(zr), __func__);
750 			return -EINVAL;
751 		}
752 	}
753 
754 	if ((res = zoran_jpg_queue_frame(fh, frame, mode)))
755 		return res;
756 
757 	/* Start the jpeg codec when the first frame is queued  */
758 	if (!res && zr->jpg_que_head == 1)
759 		jpeg_start(zr);
760 
761 	return res;
762 }
763 
764 /*
765  *   Sync on a MJPEG buffer
766  */
767 
768 static int jpg_sync(struct zoran_fh *fh, struct zoran_sync *bs)
769 {
770 	struct zoran *zr = fh->zr;
771 	unsigned long flags;
772 	int frame;
773 
774 	if (fh->buffers.active == ZORAN_FREE) {
775 		dprintk(1,
776 			KERN_ERR
777 			"%s: %s - capture is not currently active\n",
778 			ZR_DEVNAME(zr), __func__);
779 		return -EINVAL;
780 	}
781 	if (zr->codec_mode != BUZ_MODE_MOTION_DECOMPRESS &&
782 	    zr->codec_mode != BUZ_MODE_MOTION_COMPRESS) {
783 		dprintk(1,
784 			KERN_ERR
785 			"%s: %s - codec not in streaming mode\n",
786 			ZR_DEVNAME(zr), __func__);
787 		return -EINVAL;
788 	}
789 	mutex_unlock(&zr->lock);
790 	if (!wait_event_interruptible_timeout(zr->jpg_capq,
791 			(zr->jpg_que_tail != zr->jpg_dma_tail ||
792 			 zr->jpg_dma_tail == zr->jpg_dma_head),
793 			10*HZ)) {
794 		int isr;
795 
796 		btand(~ZR36057_JMC_Go_en, ZR36057_JMC);
797 		udelay(1);
798 		zr->codec->control(zr->codec, CODEC_G_STATUS,
799 					   sizeof(isr), &isr);
800 		mutex_lock(&zr->lock);
801 		dprintk(1,
802 			KERN_ERR
803 			"%s: %s - timeout: codec isr=0x%02x\n",
804 			ZR_DEVNAME(zr), __func__, isr);
805 
806 		return -ETIME;
807 
808 	}
809 	mutex_lock(&zr->lock);
810 	if (signal_pending(current))
811 		return -ERESTARTSYS;
812 
813 	spin_lock_irqsave(&zr->spinlock, flags);
814 
815 	if (zr->jpg_dma_tail != zr->jpg_dma_head)
816 		frame = zr->jpg_pend[zr->jpg_que_tail++ & BUZ_MASK_FRAME];
817 	else
818 		frame = zr->jpg_pend[zr->jpg_que_tail & BUZ_MASK_FRAME];
819 
820 	/* buffer should now be in BUZ_STATE_DONE */
821 	if (zr->jpg_buffers.buffer[frame].state != BUZ_STATE_DONE)
822 		dprintk(2,
823 			KERN_ERR "%s: %s - internal state error\n",
824 			ZR_DEVNAME(zr), __func__);
825 
826 	*bs = zr->jpg_buffers.buffer[frame].bs;
827 	bs->frame = frame;
828 	zr->jpg_buffers.buffer[frame].state = BUZ_STATE_USER;
829 	fh->buffers.buffer[frame] = zr->jpg_buffers.buffer[frame];
830 
831 	spin_unlock_irqrestore(&zr->spinlock, flags);
832 
833 	return 0;
834 }
835 
836 static void zoran_open_init_session(struct zoran_fh *fh)
837 {
838 	int i;
839 	struct zoran *zr = fh->zr;
840 
841 	/* Per default, map the V4L Buffers */
842 	map_mode_raw(fh);
843 
844 	/* take over the card's current settings */
845 	fh->overlay_settings = zr->overlay_settings;
846 	fh->overlay_settings.is_set = 0;
847 	fh->overlay_settings.format = zr->overlay_settings.format;
848 	fh->overlay_active = ZORAN_FREE;
849 
850 	/* v4l settings */
851 	fh->v4l_settings = zr->v4l_settings;
852 	/* jpg settings */
853 	fh->jpg_settings = zr->jpg_settings;
854 
855 	/* buffers */
856 	memset(&fh->buffers, 0, sizeof(fh->buffers));
857 	for (i = 0; i < MAX_FRAME; i++) {
858 		fh->buffers.buffer[i].state = BUZ_STATE_USER;	/* nothing going on */
859 		fh->buffers.buffer[i].bs.frame = i;
860 	}
861 	fh->buffers.allocated = 0;
862 	fh->buffers.active = ZORAN_FREE;
863 }
864 
865 static void zoran_close_end_session(struct zoran_fh *fh)
866 {
867 	struct zoran *zr = fh->zr;
868 
869 	/* overlay */
870 	if (fh->overlay_active != ZORAN_FREE) {
871 		fh->overlay_active = zr->overlay_active = ZORAN_FREE;
872 		zr->v4l_overlay_active = 0;
873 		if (!zr->v4l_memgrab_active)
874 			zr36057_overlay(zr, 0);
875 		zr->overlay_mask = NULL;
876 	}
877 
878 	if (fh->map_mode == ZORAN_MAP_MODE_RAW) {
879 		/* v4l capture */
880 		if (fh->buffers.active != ZORAN_FREE) {
881 			unsigned long flags;
882 
883 			spin_lock_irqsave(&zr->spinlock, flags);
884 			zr36057_set_memgrab(zr, 0);
885 			zr->v4l_buffers.allocated = 0;
886 			zr->v4l_buffers.active = fh->buffers.active = ZORAN_FREE;
887 			spin_unlock_irqrestore(&zr->spinlock, flags);
888 		}
889 
890 		/* v4l buffers */
891 		if (fh->buffers.allocated)
892 			v4l_fbuffer_free(fh);
893 	} else {
894 		/* jpg capture */
895 		if (fh->buffers.active != ZORAN_FREE) {
896 			zr36057_enable_jpg(zr, BUZ_MODE_IDLE);
897 			zr->jpg_buffers.allocated = 0;
898 			zr->jpg_buffers.active = fh->buffers.active = ZORAN_FREE;
899 		}
900 
901 		/* jpg buffers */
902 		if (fh->buffers.allocated)
903 			jpg_fbuffer_free(fh);
904 	}
905 }
906 
907 /*
908  *   Open a zoran card. Right now the flags stuff is just playing
909  */
910 
911 static int zoran_open(struct file *file)
912 {
913 	struct zoran *zr = video_drvdata(file);
914 	struct zoran_fh *fh;
915 	int res, first_open = 0;
916 
917 	dprintk(2, KERN_INFO "%s: %s(%s, pid=[%d]), users(-)=%d\n",
918 		ZR_DEVNAME(zr), __func__, current->comm, task_pid_nr(current), zr->user + 1);
919 
920 	mutex_lock(&zr->lock);
921 
922 	if (zr->user >= 2048) {
923 		dprintk(1, KERN_ERR "%s: too many users (%d) on device\n",
924 			ZR_DEVNAME(zr), zr->user);
925 		res = -EBUSY;
926 		goto fail_unlock;
927 	}
928 
929 	/* now, create the open()-specific file_ops struct */
930 	fh = kzalloc(sizeof(struct zoran_fh), GFP_KERNEL);
931 	if (!fh) {
932 		dprintk(1,
933 			KERN_ERR
934 			"%s: %s - allocation of zoran_fh failed\n",
935 			ZR_DEVNAME(zr), __func__);
936 		res = -ENOMEM;
937 		goto fail_unlock;
938 	}
939 	v4l2_fh_init(&fh->fh, video_devdata(file));
940 
941 	/* used to be BUZ_MAX_WIDTH/HEIGHT, but that gives overflows
942 	 * on norm-change! */
943 	fh->overlay_mask =
944 	    kmalloc(((768 + 31) / 32) * 576 * 4, GFP_KERNEL);
945 	if (!fh->overlay_mask) {
946 		dprintk(1,
947 			KERN_ERR
948 			"%s: %s - allocation of overlay_mask failed\n",
949 			ZR_DEVNAME(zr), __func__);
950 		res = -ENOMEM;
951 		goto fail_fh;
952 	}
953 
954 	if (zr->user++ == 0)
955 		first_open = 1;
956 
957 	/* default setup - TODO: look at flags */
958 	if (first_open) {	/* First device open */
959 		zr36057_restart(zr);
960 		zoran_open_init_params(zr);
961 		zoran_init_hardware(zr);
962 
963 		btor(ZR36057_ICR_IntPinEn, ZR36057_ICR);
964 	}
965 
966 	/* set file_ops stuff */
967 	file->private_data = fh;
968 	fh->zr = zr;
969 	zoran_open_init_session(fh);
970 	v4l2_fh_add(&fh->fh);
971 	mutex_unlock(&zr->lock);
972 
973 	return 0;
974 
975 fail_fh:
976 	v4l2_fh_exit(&fh->fh);
977 	kfree(fh);
978 fail_unlock:
979 	mutex_unlock(&zr->lock);
980 
981 	dprintk(2, KERN_INFO "%s: open failed (%d), users(-)=%d\n",
982 		ZR_DEVNAME(zr), res, zr->user);
983 
984 	return res;
985 }
986 
987 static int
988 zoran_close(struct file  *file)
989 {
990 	struct zoran_fh *fh = file->private_data;
991 	struct zoran *zr = fh->zr;
992 
993 	dprintk(2, KERN_INFO "%s: %s(%s, pid=[%d]), users(+)=%d\n",
994 		ZR_DEVNAME(zr), __func__, current->comm, task_pid_nr(current), zr->user - 1);
995 
996 	/* kernel locks (fs/device.c), so don't do that ourselves
997 	 * (prevents deadlocks) */
998 	mutex_lock(&zr->lock);
999 
1000 	zoran_close_end_session(fh);
1001 
1002 	if (zr->user-- == 1) {	/* Last process */
1003 		/* Clean up JPEG process */
1004 		wake_up_interruptible(&zr->jpg_capq);
1005 		zr36057_enable_jpg(zr, BUZ_MODE_IDLE);
1006 		zr->jpg_buffers.allocated = 0;
1007 		zr->jpg_buffers.active = ZORAN_FREE;
1008 
1009 		/* disable interrupts */
1010 		btand(~ZR36057_ICR_IntPinEn, ZR36057_ICR);
1011 
1012 		if (zr36067_debug > 1)
1013 			print_interrupts(zr);
1014 
1015 		/* Overlay off */
1016 		zr->v4l_overlay_active = 0;
1017 		zr36057_overlay(zr, 0);
1018 		zr->overlay_mask = NULL;
1019 
1020 		/* capture off */
1021 		wake_up_interruptible(&zr->v4l_capq);
1022 		zr36057_set_memgrab(zr, 0);
1023 		zr->v4l_buffers.allocated = 0;
1024 		zr->v4l_buffers.active = ZORAN_FREE;
1025 		zoran_set_pci_master(zr, 0);
1026 
1027 		if (!pass_through) {	/* Switch to color bar */
1028 			decoder_call(zr, video, s_stream, 0);
1029 			encoder_call(zr, video, s_routing, 2, 0, 0);
1030 		}
1031 	}
1032 	mutex_unlock(&zr->lock);
1033 
1034 	v4l2_fh_del(&fh->fh);
1035 	v4l2_fh_exit(&fh->fh);
1036 	kfree(fh->overlay_mask);
1037 	kfree(fh);
1038 
1039 	dprintk(4, KERN_INFO "%s: %s done\n", ZR_DEVNAME(zr), __func__);
1040 
1041 	return 0;
1042 }
1043 
1044 static int setup_fbuffer(struct zoran_fh *fh,
1045 	       void                      *base,
1046 	       const struct zoran_format *fmt,
1047 	       int                        width,
1048 	       int                        height,
1049 	       int                        bytesperline)
1050 {
1051 	struct zoran *zr = fh->zr;
1052 
1053 	/* (Ronald) v4l/v4l2 guidelines */
1054 	if (!capable(CAP_SYS_ADMIN) && !capable(CAP_SYS_RAWIO))
1055 		return -EPERM;
1056 
1057 	/* Don't allow frame buffer overlay if PCI or AGP is buggy, or on
1058 	   ALi Magik (that needs very low latency while the card needs a
1059 	   higher value always) */
1060 
1061 	if (pci_pci_problems & (PCIPCI_FAIL | PCIAGP_FAIL | PCIPCI_ALIMAGIK))
1062 		return -ENXIO;
1063 
1064 	/* we need a bytesperline value, even if not given */
1065 	if (!bytesperline)
1066 		bytesperline = width * ((fmt->depth + 7) & ~7) / 8;
1067 
1068 #if 0
1069 	if (zr->overlay_active) {
1070 		/* dzjee... stupid users... don't even bother to turn off
1071 		 * overlay before changing the memory location...
1072 		 * normally, we would return errors here. However, one of
1073 		 * the tools that does this is... xawtv! and since xawtv
1074 		 * is used by +/- 99% of the users, we'd rather be user-
1075 		 * friendly and silently do as if nothing went wrong */
1076 		dprintk(3,
1077 			KERN_ERR
1078 			"%s: %s - forced overlay turnoff because framebuffer changed\n",
1079 			ZR_DEVNAME(zr), __func__);
1080 		zr36057_overlay(zr, 0);
1081 	}
1082 #endif
1083 
1084 	if (!(fmt->flags & ZORAN_FORMAT_OVERLAY)) {
1085 		dprintk(1,
1086 			KERN_ERR
1087 			"%s: %s - no valid overlay format given\n",
1088 			ZR_DEVNAME(zr), __func__);
1089 		return -EINVAL;
1090 	}
1091 	if (height <= 0 || width <= 0 || bytesperline <= 0) {
1092 		dprintk(1,
1093 			KERN_ERR
1094 			"%s: %s - invalid height/width/bpl value (%d|%d|%d)\n",
1095 			ZR_DEVNAME(zr), __func__, width, height, bytesperline);
1096 		return -EINVAL;
1097 	}
1098 	if (bytesperline & 3) {
1099 		dprintk(1,
1100 			KERN_ERR
1101 			"%s: %s - bytesperline (%d) must be 4-byte aligned\n",
1102 			ZR_DEVNAME(zr), __func__, bytesperline);
1103 		return -EINVAL;
1104 	}
1105 
1106 	zr->vbuf_base = (void *) ((unsigned long) base & ~3);
1107 	zr->vbuf_height = height;
1108 	zr->vbuf_width = width;
1109 	zr->vbuf_depth = fmt->depth;
1110 	zr->overlay_settings.format = fmt;
1111 	zr->vbuf_bytesperline = bytesperline;
1112 
1113 	/* The user should set new window parameters */
1114 	zr->overlay_settings.is_set = 0;
1115 
1116 	return 0;
1117 }
1118 
1119 
1120 static int setup_window(struct zoran_fh *fh,
1121 			int x,
1122 			int y,
1123 			int width,
1124 			int height,
1125 			struct v4l2_clip __user *clips,
1126 			unsigned int clipcount,
1127 			void __user *bitmap)
1128 {
1129 	struct zoran *zr = fh->zr;
1130 	struct v4l2_clip *vcp = NULL;
1131 	int on, end;
1132 
1133 
1134 	if (!zr->vbuf_base) {
1135 		dprintk(1,
1136 			KERN_ERR
1137 			"%s: %s - frame buffer has to be set first\n",
1138 			ZR_DEVNAME(zr), __func__);
1139 		return -EINVAL;
1140 	}
1141 
1142 	if (!fh->overlay_settings.format) {
1143 		dprintk(1,
1144 			KERN_ERR
1145 			"%s: %s - no overlay format set\n",
1146 			ZR_DEVNAME(zr), __func__);
1147 		return -EINVAL;
1148 	}
1149 
1150 	if (clipcount > 2048) {
1151 		dprintk(1,
1152 			KERN_ERR
1153 			"%s: %s - invalid clipcount\n",
1154 			 ZR_DEVNAME(zr), __func__);
1155 		return -EINVAL;
1156 	}
1157 
1158 	/*
1159 	 * The video front end needs 4-byte alinged line sizes, we correct that
1160 	 * silently here if necessary
1161 	 */
1162 	if (zr->vbuf_depth == 15 || zr->vbuf_depth == 16) {
1163 		end = (x + width) & ~1;	/* round down */
1164 		x = (x + 1) & ~1;	/* round up */
1165 		width = end - x;
1166 	}
1167 
1168 	if (zr->vbuf_depth == 24) {
1169 		end = (x + width) & ~3;	/* round down */
1170 		x = (x + 3) & ~3;	/* round up */
1171 		width = end - x;
1172 	}
1173 
1174 	if (width > BUZ_MAX_WIDTH)
1175 		width = BUZ_MAX_WIDTH;
1176 	if (height > BUZ_MAX_HEIGHT)
1177 		height = BUZ_MAX_HEIGHT;
1178 
1179 	/* Check for invalid parameters */
1180 	if (width < BUZ_MIN_WIDTH || height < BUZ_MIN_HEIGHT ||
1181 	    width > BUZ_MAX_WIDTH || height > BUZ_MAX_HEIGHT) {
1182 		dprintk(1,
1183 			KERN_ERR
1184 			"%s: %s - width = %d or height = %d invalid\n",
1185 			ZR_DEVNAME(zr), __func__, width, height);
1186 		return -EINVAL;
1187 	}
1188 
1189 	fh->overlay_settings.x = x;
1190 	fh->overlay_settings.y = y;
1191 	fh->overlay_settings.width = width;
1192 	fh->overlay_settings.height = height;
1193 	fh->overlay_settings.clipcount = clipcount;
1194 
1195 	/*
1196 	 * If an overlay is running, we have to switch it off
1197 	 * and switch it on again in order to get the new settings in effect.
1198 	 *
1199 	 * We also want to avoid that the overlay mask is written
1200 	 * when an overlay is running.
1201 	 */
1202 
1203 	on = zr->v4l_overlay_active && !zr->v4l_memgrab_active &&
1204 	    zr->overlay_active != ZORAN_FREE &&
1205 	    fh->overlay_active != ZORAN_FREE;
1206 	if (on)
1207 		zr36057_overlay(zr, 0);
1208 
1209 	/*
1210 	 *   Write the overlay mask if clips are wanted.
1211 	 *   We prefer a bitmap.
1212 	 */
1213 	if (bitmap) {
1214 		/* fake value - it just means we want clips */
1215 		fh->overlay_settings.clipcount = 1;
1216 
1217 		if (copy_from_user(fh->overlay_mask, bitmap,
1218 				   (width * height + 7) / 8)) {
1219 			return -EFAULT;
1220 		}
1221 	} else if (clipcount) {
1222 		/* write our own bitmap from the clips */
1223 		vcp = vmalloc(sizeof(struct v4l2_clip) * (clipcount + 4));
1224 		if (vcp == NULL) {
1225 			dprintk(1,
1226 				KERN_ERR
1227 				"%s: %s - Alloc of clip mask failed\n",
1228 				ZR_DEVNAME(zr), __func__);
1229 			return -ENOMEM;
1230 		}
1231 		if (copy_from_user
1232 		    (vcp, clips, sizeof(struct v4l2_clip) * clipcount)) {
1233 			vfree(vcp);
1234 			return -EFAULT;
1235 		}
1236 		write_overlay_mask(fh, vcp, clipcount);
1237 		vfree(vcp);
1238 	}
1239 
1240 	fh->overlay_settings.is_set = 1;
1241 	if (fh->overlay_active != ZORAN_FREE &&
1242 	    zr->overlay_active != ZORAN_FREE)
1243 		zr->overlay_settings = fh->overlay_settings;
1244 
1245 	if (on)
1246 		zr36057_overlay(zr, 1);
1247 
1248 	/* Make sure the changes come into effect */
1249 	return wait_grab_pending(zr);
1250 }
1251 
1252 static int setup_overlay(struct zoran_fh *fh, int on)
1253 {
1254 	struct zoran *zr = fh->zr;
1255 
1256 	/* If there is nothing to do, return immediately */
1257 	if ((on && fh->overlay_active != ZORAN_FREE) ||
1258 	    (!on && fh->overlay_active == ZORAN_FREE))
1259 		return 0;
1260 
1261 	/* check whether we're touching someone else's overlay */
1262 	if (on && zr->overlay_active != ZORAN_FREE &&
1263 	    fh->overlay_active == ZORAN_FREE) {
1264 		dprintk(1,
1265 			KERN_ERR
1266 			"%s: %s - overlay is already active for another session\n",
1267 			ZR_DEVNAME(zr), __func__);
1268 		return -EBUSY;
1269 	}
1270 	if (!on && zr->overlay_active != ZORAN_FREE &&
1271 	    fh->overlay_active == ZORAN_FREE) {
1272 		dprintk(1,
1273 			KERN_ERR
1274 			"%s: %s - you cannot cancel someone else's session\n",
1275 			ZR_DEVNAME(zr), __func__);
1276 		return -EPERM;
1277 	}
1278 
1279 	if (on == 0) {
1280 		zr->overlay_active = fh->overlay_active = ZORAN_FREE;
1281 		zr->v4l_overlay_active = 0;
1282 		/* When a grab is running, the video simply
1283 		 * won't be switched on any more */
1284 		if (!zr->v4l_memgrab_active)
1285 			zr36057_overlay(zr, 0);
1286 		zr->overlay_mask = NULL;
1287 	} else {
1288 		if (!zr->vbuf_base || !fh->overlay_settings.is_set) {
1289 			dprintk(1,
1290 				KERN_ERR
1291 				"%s: %s - buffer or window not set\n",
1292 				ZR_DEVNAME(zr), __func__);
1293 			return -EINVAL;
1294 		}
1295 		if (!fh->overlay_settings.format) {
1296 			dprintk(1,
1297 				KERN_ERR
1298 				"%s: %s - no overlay format set\n",
1299 				ZR_DEVNAME(zr), __func__);
1300 			return -EINVAL;
1301 		}
1302 		zr->overlay_active = fh->overlay_active = ZORAN_LOCKED;
1303 		zr->v4l_overlay_active = 1;
1304 		zr->overlay_mask = fh->overlay_mask;
1305 		zr->overlay_settings = fh->overlay_settings;
1306 		if (!zr->v4l_memgrab_active)
1307 			zr36057_overlay(zr, 1);
1308 		/* When a grab is running, the video will be
1309 		 * switched on when grab is finished */
1310 	}
1311 
1312 	/* Make sure the changes come into effect */
1313 	return wait_grab_pending(zr);
1314 }
1315 
1316 /* get the status of a buffer in the clients buffer queue */
1317 static int zoran_v4l2_buffer_status(struct zoran_fh *fh,
1318 				    struct v4l2_buffer *buf, int num)
1319 {
1320 	struct zoran *zr = fh->zr;
1321 	unsigned long flags;
1322 
1323 	buf->flags = V4L2_BUF_FLAG_MAPPED | V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC;
1324 
1325 	switch (fh->map_mode) {
1326 	case ZORAN_MAP_MODE_RAW:
1327 		/* check range */
1328 		if (num < 0 || num >= fh->buffers.num_buffers ||
1329 		    !fh->buffers.allocated) {
1330 			dprintk(1,
1331 				KERN_ERR
1332 				"%s: %s - wrong number or buffers not allocated\n",
1333 				ZR_DEVNAME(zr), __func__);
1334 			return -EINVAL;
1335 		}
1336 
1337 		spin_lock_irqsave(&zr->spinlock, flags);
1338 		dprintk(3,
1339 			KERN_DEBUG
1340 			"%s: %s() - raw active=%c, buffer %d: state=%c, map=%c\n",
1341 			ZR_DEVNAME(zr), __func__,
1342 			"FAL"[fh->buffers.active], num,
1343 			"UPMD"[zr->v4l_buffers.buffer[num].state],
1344 			fh->buffers.buffer[num].map ? 'Y' : 'N');
1345 		spin_unlock_irqrestore(&zr->spinlock, flags);
1346 
1347 		buf->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
1348 		buf->length = fh->buffers.buffer_size;
1349 
1350 		/* get buffer */
1351 		buf->bytesused = fh->buffers.buffer[num].bs.length;
1352 		if (fh->buffers.buffer[num].state == BUZ_STATE_DONE ||
1353 		    fh->buffers.buffer[num].state == BUZ_STATE_USER) {
1354 			buf->sequence = fh->buffers.buffer[num].bs.seq;
1355 			buf->flags |= V4L2_BUF_FLAG_DONE;
1356 			buf->timestamp = fh->buffers.buffer[num].bs.timestamp;
1357 		} else {
1358 			buf->flags |= V4L2_BUF_FLAG_QUEUED;
1359 		}
1360 
1361 		if (fh->v4l_settings.height <= BUZ_MAX_HEIGHT / 2)
1362 			buf->field = V4L2_FIELD_TOP;
1363 		else
1364 			buf->field = V4L2_FIELD_INTERLACED;
1365 
1366 		break;
1367 
1368 	case ZORAN_MAP_MODE_JPG_REC:
1369 	case ZORAN_MAP_MODE_JPG_PLAY:
1370 
1371 		/* check range */
1372 		if (num < 0 || num >= fh->buffers.num_buffers ||
1373 		    !fh->buffers.allocated) {
1374 			dprintk(1,
1375 				KERN_ERR
1376 				"%s: %s - wrong number or buffers not allocated\n",
1377 				ZR_DEVNAME(zr), __func__);
1378 			return -EINVAL;
1379 		}
1380 
1381 		buf->type = (fh->map_mode == ZORAN_MAP_MODE_JPG_REC) ?
1382 			      V4L2_BUF_TYPE_VIDEO_CAPTURE :
1383 			      V4L2_BUF_TYPE_VIDEO_OUTPUT;
1384 		buf->length = fh->buffers.buffer_size;
1385 
1386 		/* these variables are only written after frame has been captured */
1387 		if (fh->buffers.buffer[num].state == BUZ_STATE_DONE ||
1388 		    fh->buffers.buffer[num].state == BUZ_STATE_USER) {
1389 			buf->sequence = fh->buffers.buffer[num].bs.seq;
1390 			buf->timestamp = fh->buffers.buffer[num].bs.timestamp;
1391 			buf->bytesused = fh->buffers.buffer[num].bs.length;
1392 			buf->flags |= V4L2_BUF_FLAG_DONE;
1393 		} else {
1394 			buf->flags |= V4L2_BUF_FLAG_QUEUED;
1395 		}
1396 
1397 		/* which fields are these? */
1398 		if (fh->jpg_settings.TmpDcm != 1)
1399 			buf->field = fh->jpg_settings.odd_even ?
1400 				V4L2_FIELD_TOP : V4L2_FIELD_BOTTOM;
1401 		else
1402 			buf->field = fh->jpg_settings.odd_even ?
1403 				V4L2_FIELD_SEQ_TB : V4L2_FIELD_SEQ_BT;
1404 
1405 		break;
1406 
1407 	default:
1408 
1409 		dprintk(5,
1410 			KERN_ERR
1411 			"%s: %s - invalid buffer type|map_mode (%d|%d)\n",
1412 			ZR_DEVNAME(zr), __func__, buf->type, fh->map_mode);
1413 		return -EINVAL;
1414 	}
1415 
1416 	buf->memory = V4L2_MEMORY_MMAP;
1417 	buf->index = num;
1418 	buf->m.offset = buf->length * num;
1419 
1420 	return 0;
1421 }
1422 
1423 static int
1424 zoran_set_norm (struct zoran *zr,
1425 		v4l2_std_id norm)
1426 {
1427 	int on;
1428 
1429 	if (zr->v4l_buffers.active != ZORAN_FREE ||
1430 	    zr->jpg_buffers.active != ZORAN_FREE) {
1431 		dprintk(1,
1432 			KERN_WARNING
1433 			"%s: %s called while in playback/capture mode\n",
1434 			ZR_DEVNAME(zr), __func__);
1435 		return -EBUSY;
1436 	}
1437 
1438 	if (!(norm & zr->card.norms)) {
1439 		dprintk(1,
1440 			KERN_ERR "%s: %s - unsupported norm %llx\n",
1441 			ZR_DEVNAME(zr), __func__, norm);
1442 		return -EINVAL;
1443 	}
1444 
1445 	if (norm & V4L2_STD_SECAM)
1446 		zr->timing = zr->card.tvn[2];
1447 	else if (norm & V4L2_STD_NTSC)
1448 		zr->timing = zr->card.tvn[1];
1449 	else
1450 		zr->timing = zr->card.tvn[0];
1451 
1452 	/* We switch overlay off and on since a change in the
1453 	 * norm needs different VFE settings */
1454 	on = zr->overlay_active && !zr->v4l_memgrab_active;
1455 	if (on)
1456 		zr36057_overlay(zr, 0);
1457 
1458 	decoder_call(zr, video, s_std, norm);
1459 	encoder_call(zr, video, s_std_output, norm);
1460 
1461 	if (on)
1462 		zr36057_overlay(zr, 1);
1463 
1464 	/* Make sure the changes come into effect */
1465 	zr->norm = norm;
1466 
1467 	return 0;
1468 }
1469 
1470 static int
1471 zoran_set_input (struct zoran *zr,
1472 		 int           input)
1473 {
1474 	if (input == zr->input) {
1475 		return 0;
1476 	}
1477 
1478 	if (zr->v4l_buffers.active != ZORAN_FREE ||
1479 	    zr->jpg_buffers.active != ZORAN_FREE) {
1480 		dprintk(1,
1481 			KERN_WARNING
1482 			"%s: %s called while in playback/capture mode\n",
1483 			ZR_DEVNAME(zr), __func__);
1484 		return -EBUSY;
1485 	}
1486 
1487 	if (input < 0 || input >= zr->card.inputs) {
1488 		dprintk(1,
1489 			KERN_ERR
1490 			"%s: %s - unsupported input %d\n",
1491 			ZR_DEVNAME(zr), __func__, input);
1492 		return -EINVAL;
1493 	}
1494 
1495 	zr->input = input;
1496 
1497 	decoder_call(zr, video, s_routing,
1498 			zr->card.input[input].muxsel, 0, 0);
1499 
1500 	return 0;
1501 }
1502 
1503 /*
1504  *   ioctl routine
1505  */
1506 
1507 static int zoran_querycap(struct file *file, void *__fh, struct v4l2_capability *cap)
1508 {
1509 	struct zoran_fh *fh = __fh;
1510 	struct zoran *zr = fh->zr;
1511 
1512 	strncpy(cap->card, ZR_DEVNAME(zr), sizeof(cap->card)-1);
1513 	strncpy(cap->driver, "zoran", sizeof(cap->driver)-1);
1514 	snprintf(cap->bus_info, sizeof(cap->bus_info), "PCI:%s",
1515 		 pci_name(zr->pci_dev));
1516 	cap->device_caps = V4L2_CAP_STREAMING | V4L2_CAP_VIDEO_CAPTURE |
1517 			   V4L2_CAP_VIDEO_OUTPUT | V4L2_CAP_VIDEO_OVERLAY;
1518 	cap->capabilities = cap->device_caps | V4L2_CAP_DEVICE_CAPS;
1519 	return 0;
1520 }
1521 
1522 static int zoran_enum_fmt(struct zoran *zr, struct v4l2_fmtdesc *fmt, int flag)
1523 {
1524 	unsigned int num, i;
1525 
1526 	for (num = i = 0; i < NUM_FORMATS; i++) {
1527 		if (zoran_formats[i].flags & flag && num++ == fmt->index) {
1528 			strncpy(fmt->description, zoran_formats[i].name,
1529 				sizeof(fmt->description) - 1);
1530 			/* fmt struct pre-zeroed, so adding '\0' not needed */
1531 			fmt->pixelformat = zoran_formats[i].fourcc;
1532 			if (zoran_formats[i].flags & ZORAN_FORMAT_COMPRESSED)
1533 				fmt->flags |= V4L2_FMT_FLAG_COMPRESSED;
1534 			return 0;
1535 		}
1536 	}
1537 	return -EINVAL;
1538 }
1539 
1540 static int zoran_enum_fmt_vid_cap(struct file *file, void *__fh,
1541 					    struct v4l2_fmtdesc *f)
1542 {
1543 	struct zoran_fh *fh = __fh;
1544 	struct zoran *zr = fh->zr;
1545 
1546 	return zoran_enum_fmt(zr, f, ZORAN_FORMAT_CAPTURE);
1547 }
1548 
1549 static int zoran_enum_fmt_vid_out(struct file *file, void *__fh,
1550 					    struct v4l2_fmtdesc *f)
1551 {
1552 	struct zoran_fh *fh = __fh;
1553 	struct zoran *zr = fh->zr;
1554 
1555 	return zoran_enum_fmt(zr, f, ZORAN_FORMAT_PLAYBACK);
1556 }
1557 
1558 static int zoran_enum_fmt_vid_overlay(struct file *file, void *__fh,
1559 					    struct v4l2_fmtdesc *f)
1560 {
1561 	struct zoran_fh *fh = __fh;
1562 	struct zoran *zr = fh->zr;
1563 
1564 	return zoran_enum_fmt(zr, f, ZORAN_FORMAT_OVERLAY);
1565 }
1566 
1567 static int zoran_g_fmt_vid_out(struct file *file, void *__fh,
1568 					struct v4l2_format *fmt)
1569 {
1570 	struct zoran_fh *fh = __fh;
1571 
1572 	fmt->fmt.pix.width = fh->jpg_settings.img_width / fh->jpg_settings.HorDcm;
1573 	fmt->fmt.pix.height = fh->jpg_settings.img_height * 2 /
1574 		(fh->jpg_settings.VerDcm * fh->jpg_settings.TmpDcm);
1575 	fmt->fmt.pix.sizeimage = zoran_v4l2_calc_bufsize(&fh->jpg_settings);
1576 	fmt->fmt.pix.pixelformat = V4L2_PIX_FMT_MJPEG;
1577 	if (fh->jpg_settings.TmpDcm == 1)
1578 		fmt->fmt.pix.field = (fh->jpg_settings.odd_even ?
1579 				V4L2_FIELD_SEQ_TB : V4L2_FIELD_SEQ_BT);
1580 	else
1581 		fmt->fmt.pix.field = (fh->jpg_settings.odd_even ?
1582 				V4L2_FIELD_TOP : V4L2_FIELD_BOTTOM);
1583 	fmt->fmt.pix.bytesperline = 0;
1584 	fmt->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M;
1585 
1586 	return 0;
1587 }
1588 
1589 static int zoran_g_fmt_vid_cap(struct file *file, void *__fh,
1590 					struct v4l2_format *fmt)
1591 {
1592 	struct zoran_fh *fh = __fh;
1593 	struct zoran *zr = fh->zr;
1594 
1595 	if (fh->map_mode != ZORAN_MAP_MODE_RAW)
1596 		return zoran_g_fmt_vid_out(file, fh, fmt);
1597 
1598 	fmt->fmt.pix.width = fh->v4l_settings.width;
1599 	fmt->fmt.pix.height = fh->v4l_settings.height;
1600 	fmt->fmt.pix.sizeimage = fh->v4l_settings.bytesperline *
1601 					fh->v4l_settings.height;
1602 	fmt->fmt.pix.pixelformat = fh->v4l_settings.format->fourcc;
1603 	fmt->fmt.pix.colorspace = fh->v4l_settings.format->colorspace;
1604 	fmt->fmt.pix.bytesperline = fh->v4l_settings.bytesperline;
1605 	if (BUZ_MAX_HEIGHT < (fh->v4l_settings.height * 2))
1606 		fmt->fmt.pix.field = V4L2_FIELD_INTERLACED;
1607 	else
1608 		fmt->fmt.pix.field = V4L2_FIELD_TOP;
1609 	return 0;
1610 }
1611 
1612 static int zoran_g_fmt_vid_overlay(struct file *file, void *__fh,
1613 					struct v4l2_format *fmt)
1614 {
1615 	struct zoran_fh *fh = __fh;
1616 	struct zoran *zr = fh->zr;
1617 
1618 	fmt->fmt.win.w.left = fh->overlay_settings.x;
1619 	fmt->fmt.win.w.top = fh->overlay_settings.y;
1620 	fmt->fmt.win.w.width = fh->overlay_settings.width;
1621 	fmt->fmt.win.w.height = fh->overlay_settings.height;
1622 	if (fh->overlay_settings.width * 2 > BUZ_MAX_HEIGHT)
1623 		fmt->fmt.win.field = V4L2_FIELD_INTERLACED;
1624 	else
1625 		fmt->fmt.win.field = V4L2_FIELD_TOP;
1626 
1627 	return 0;
1628 }
1629 
1630 static int zoran_try_fmt_vid_overlay(struct file *file, void *__fh,
1631 					struct v4l2_format *fmt)
1632 {
1633 	struct zoran_fh *fh = __fh;
1634 	struct zoran *zr = fh->zr;
1635 
1636 	if (fmt->fmt.win.w.width > BUZ_MAX_WIDTH)
1637 		fmt->fmt.win.w.width = BUZ_MAX_WIDTH;
1638 	if (fmt->fmt.win.w.width < BUZ_MIN_WIDTH)
1639 		fmt->fmt.win.w.width = BUZ_MIN_WIDTH;
1640 	if (fmt->fmt.win.w.height > BUZ_MAX_HEIGHT)
1641 		fmt->fmt.win.w.height = BUZ_MAX_HEIGHT;
1642 	if (fmt->fmt.win.w.height < BUZ_MIN_HEIGHT)
1643 		fmt->fmt.win.w.height = BUZ_MIN_HEIGHT;
1644 
1645 	return 0;
1646 }
1647 
1648 static int zoran_try_fmt_vid_out(struct file *file, void *__fh,
1649 					struct v4l2_format *fmt)
1650 {
1651 	struct zoran_fh *fh = __fh;
1652 	struct zoran *zr = fh->zr;
1653 	struct zoran_jpg_settings settings;
1654 	int res = 0;
1655 
1656 	if (fmt->fmt.pix.pixelformat != V4L2_PIX_FMT_MJPEG)
1657 		return -EINVAL;
1658 
1659 	settings = fh->jpg_settings;
1660 
1661 	/* we actually need to set 'real' parameters now */
1662 	if ((fmt->fmt.pix.height * 2) > BUZ_MAX_HEIGHT)
1663 		settings.TmpDcm = 1;
1664 	else
1665 		settings.TmpDcm = 2;
1666 	settings.decimation = 0;
1667 	if (fmt->fmt.pix.height <= fh->jpg_settings.img_height / 2)
1668 		settings.VerDcm = 2;
1669 	else
1670 		settings.VerDcm = 1;
1671 	if (fmt->fmt.pix.width <= fh->jpg_settings.img_width / 4)
1672 		settings.HorDcm = 4;
1673 	else if (fmt->fmt.pix.width <= fh->jpg_settings.img_width / 2)
1674 		settings.HorDcm = 2;
1675 	else
1676 		settings.HorDcm = 1;
1677 	if (settings.TmpDcm == 1)
1678 		settings.field_per_buff = 2;
1679 	else
1680 		settings.field_per_buff = 1;
1681 
1682 	if (settings.HorDcm > 1) {
1683 		settings.img_x = (BUZ_MAX_WIDTH == 720) ? 8 : 0;
1684 		settings.img_width = (BUZ_MAX_WIDTH == 720) ? 704 : BUZ_MAX_WIDTH;
1685 	} else {
1686 		settings.img_x = 0;
1687 		settings.img_width = BUZ_MAX_WIDTH;
1688 	}
1689 
1690 	/* check */
1691 	res = zoran_check_jpg_settings(zr, &settings, 1);
1692 	if (res)
1693 		return res;
1694 
1695 	/* tell the user what we actually did */
1696 	fmt->fmt.pix.width = settings.img_width / settings.HorDcm;
1697 	fmt->fmt.pix.height = settings.img_height * 2 /
1698 		(settings.TmpDcm * settings.VerDcm);
1699 	if (settings.TmpDcm == 1)
1700 		fmt->fmt.pix.field = (fh->jpg_settings.odd_even ?
1701 				V4L2_FIELD_SEQ_TB : V4L2_FIELD_SEQ_BT);
1702 	else
1703 		fmt->fmt.pix.field = (fh->jpg_settings.odd_even ?
1704 				V4L2_FIELD_TOP : V4L2_FIELD_BOTTOM);
1705 
1706 	fmt->fmt.pix.sizeimage = zoran_v4l2_calc_bufsize(&settings);
1707 	fmt->fmt.pix.bytesperline = 0;
1708 	fmt->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M;
1709 	return res;
1710 }
1711 
1712 static int zoran_try_fmt_vid_cap(struct file *file, void *__fh,
1713 					struct v4l2_format *fmt)
1714 {
1715 	struct zoran_fh *fh = __fh;
1716 	struct zoran *zr = fh->zr;
1717 	int bpp;
1718 	int i;
1719 
1720 	if (fmt->fmt.pix.pixelformat == V4L2_PIX_FMT_MJPEG)
1721 		return zoran_try_fmt_vid_out(file, fh, fmt);
1722 
1723 	for (i = 0; i < NUM_FORMATS; i++)
1724 		if (zoran_formats[i].fourcc == fmt->fmt.pix.pixelformat)
1725 			break;
1726 
1727 	if (i == NUM_FORMATS)
1728 		return -EINVAL;
1729 
1730 	bpp = DIV_ROUND_UP(zoran_formats[i].depth, 8);
1731 	v4l_bound_align_image(
1732 		&fmt->fmt.pix.width, BUZ_MIN_WIDTH, BUZ_MAX_WIDTH, bpp == 2 ? 1 : 2,
1733 		&fmt->fmt.pix.height, BUZ_MIN_HEIGHT, BUZ_MAX_HEIGHT, 0, 0);
1734 	return 0;
1735 }
1736 
1737 static int zoran_s_fmt_vid_overlay(struct file *file, void *__fh,
1738 					struct v4l2_format *fmt)
1739 {
1740 	struct zoran_fh *fh = __fh;
1741 	int res;
1742 
1743 	dprintk(3, "x=%d, y=%d, w=%d, h=%d, cnt=%d, map=0x%p\n",
1744 			fmt->fmt.win.w.left, fmt->fmt.win.w.top,
1745 			fmt->fmt.win.w.width,
1746 			fmt->fmt.win.w.height,
1747 			fmt->fmt.win.clipcount,
1748 			fmt->fmt.win.bitmap);
1749 	res = setup_window(fh, fmt->fmt.win.w.left, fmt->fmt.win.w.top,
1750 			   fmt->fmt.win.w.width, fmt->fmt.win.w.height,
1751 			   (struct v4l2_clip __user *)fmt->fmt.win.clips,
1752 			   fmt->fmt.win.clipcount, fmt->fmt.win.bitmap);
1753 	return res;
1754 }
1755 
1756 static int zoran_s_fmt_vid_out(struct file *file, void *__fh,
1757 					struct v4l2_format *fmt)
1758 {
1759 	struct zoran_fh *fh = __fh;
1760 	struct zoran *zr = fh->zr;
1761 	__le32 printformat = __cpu_to_le32(fmt->fmt.pix.pixelformat);
1762 	struct zoran_jpg_settings settings;
1763 	int res = 0;
1764 
1765 	dprintk(3, "size=%dx%d, fmt=0x%x (%4.4s)\n",
1766 			fmt->fmt.pix.width, fmt->fmt.pix.height,
1767 			fmt->fmt.pix.pixelformat,
1768 			(char *) &printformat);
1769 	if (fmt->fmt.pix.pixelformat != V4L2_PIX_FMT_MJPEG)
1770 		return -EINVAL;
1771 
1772 	if (fh->buffers.allocated) {
1773 		dprintk(1, KERN_ERR "%s: VIDIOC_S_FMT - cannot change capture mode\n",
1774 			ZR_DEVNAME(zr));
1775 		res = -EBUSY;
1776 		return res;
1777 	}
1778 
1779 	settings = fh->jpg_settings;
1780 
1781 	/* we actually need to set 'real' parameters now */
1782 	if (fmt->fmt.pix.height * 2 > BUZ_MAX_HEIGHT)
1783 		settings.TmpDcm = 1;
1784 	else
1785 		settings.TmpDcm = 2;
1786 	settings.decimation = 0;
1787 	if (fmt->fmt.pix.height <= fh->jpg_settings.img_height / 2)
1788 		settings.VerDcm = 2;
1789 	else
1790 		settings.VerDcm = 1;
1791 	if (fmt->fmt.pix.width <= fh->jpg_settings.img_width / 4)
1792 		settings.HorDcm = 4;
1793 	else if (fmt->fmt.pix.width <= fh->jpg_settings.img_width / 2)
1794 		settings.HorDcm = 2;
1795 	else
1796 		settings.HorDcm = 1;
1797 	if (settings.TmpDcm == 1)
1798 		settings.field_per_buff = 2;
1799 	else
1800 		settings.field_per_buff = 1;
1801 
1802 	if (settings.HorDcm > 1) {
1803 		settings.img_x = (BUZ_MAX_WIDTH == 720) ? 8 : 0;
1804 		settings.img_width = (BUZ_MAX_WIDTH == 720) ? 704 : BUZ_MAX_WIDTH;
1805 	} else {
1806 		settings.img_x = 0;
1807 		settings.img_width = BUZ_MAX_WIDTH;
1808 	}
1809 
1810 	/* check */
1811 	res = zoran_check_jpg_settings(zr, &settings, 0);
1812 	if (res)
1813 		return res;
1814 
1815 	/* it's ok, so set them */
1816 	fh->jpg_settings = settings;
1817 
1818 	map_mode_jpg(fh, fmt->type == V4L2_BUF_TYPE_VIDEO_OUTPUT);
1819 	fh->buffers.buffer_size = zoran_v4l2_calc_bufsize(&fh->jpg_settings);
1820 
1821 	/* tell the user what we actually did */
1822 	fmt->fmt.pix.width = settings.img_width / settings.HorDcm;
1823 	fmt->fmt.pix.height = settings.img_height * 2 /
1824 		(settings.TmpDcm * settings.VerDcm);
1825 	if (settings.TmpDcm == 1)
1826 		fmt->fmt.pix.field = (fh->jpg_settings.odd_even ?
1827 				V4L2_FIELD_SEQ_TB : V4L2_FIELD_SEQ_BT);
1828 	else
1829 		fmt->fmt.pix.field = (fh->jpg_settings.odd_even ?
1830 				V4L2_FIELD_TOP : V4L2_FIELD_BOTTOM);
1831 	fmt->fmt.pix.bytesperline = 0;
1832 	fmt->fmt.pix.sizeimage = fh->buffers.buffer_size;
1833 	fmt->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M;
1834 	return res;
1835 }
1836 
1837 static int zoran_s_fmt_vid_cap(struct file *file, void *__fh,
1838 					struct v4l2_format *fmt)
1839 {
1840 	struct zoran_fh *fh = __fh;
1841 	struct zoran *zr = fh->zr;
1842 	int i;
1843 	int res = 0;
1844 
1845 	if (fmt->fmt.pix.pixelformat == V4L2_PIX_FMT_MJPEG)
1846 		return zoran_s_fmt_vid_out(file, fh, fmt);
1847 
1848 	for (i = 0; i < NUM_FORMATS; i++)
1849 		if (fmt->fmt.pix.pixelformat == zoran_formats[i].fourcc)
1850 			break;
1851 	if (i == NUM_FORMATS) {
1852 		dprintk(1, KERN_ERR "%s: VIDIOC_S_FMT - unknown/unsupported format 0x%x\n",
1853 			ZR_DEVNAME(zr), fmt->fmt.pix.pixelformat);
1854 		return -EINVAL;
1855 	}
1856 
1857 	if ((fh->map_mode != ZORAN_MAP_MODE_RAW && fh->buffers.allocated) ||
1858 	    fh->buffers.active != ZORAN_FREE) {
1859 		dprintk(1, KERN_ERR "%s: VIDIOC_S_FMT - cannot change capture mode\n",
1860 				ZR_DEVNAME(zr));
1861 		res = -EBUSY;
1862 		return res;
1863 	}
1864 	if (fmt->fmt.pix.height > BUZ_MAX_HEIGHT)
1865 		fmt->fmt.pix.height = BUZ_MAX_HEIGHT;
1866 	if (fmt->fmt.pix.width > BUZ_MAX_WIDTH)
1867 		fmt->fmt.pix.width = BUZ_MAX_WIDTH;
1868 
1869 	map_mode_raw(fh);
1870 
1871 	res = zoran_v4l_set_format(fh, fmt->fmt.pix.width, fmt->fmt.pix.height,
1872 				   &zoran_formats[i]);
1873 	if (res)
1874 		return res;
1875 
1876 	/* tell the user the results/missing stuff */
1877 	fmt->fmt.pix.bytesperline = fh->v4l_settings.bytesperline;
1878 	fmt->fmt.pix.sizeimage = fh->v4l_settings.height * fh->v4l_settings.bytesperline;
1879 	fmt->fmt.pix.colorspace = fh->v4l_settings.format->colorspace;
1880 	if (BUZ_MAX_HEIGHT < (fh->v4l_settings.height * 2))
1881 		fmt->fmt.pix.field = V4L2_FIELD_INTERLACED;
1882 	else
1883 		fmt->fmt.pix.field = V4L2_FIELD_TOP;
1884 	return res;
1885 }
1886 
1887 static int zoran_g_fbuf(struct file *file, void *__fh,
1888 		struct v4l2_framebuffer *fb)
1889 {
1890 	struct zoran_fh *fh = __fh;
1891 	struct zoran *zr = fh->zr;
1892 
1893 	memset(fb, 0, sizeof(*fb));
1894 	fb->base = zr->vbuf_base;
1895 	fb->fmt.width = zr->vbuf_width;
1896 	fb->fmt.height = zr->vbuf_height;
1897 	if (zr->overlay_settings.format)
1898 		fb->fmt.pixelformat = fh->overlay_settings.format->fourcc;
1899 	fb->fmt.bytesperline = zr->vbuf_bytesperline;
1900 	fb->fmt.colorspace = V4L2_COLORSPACE_SRGB;
1901 	fb->fmt.field = V4L2_FIELD_INTERLACED;
1902 	fb->capability = V4L2_FBUF_CAP_LIST_CLIPPING;
1903 
1904 	return 0;
1905 }
1906 
1907 static int zoran_s_fbuf(struct file *file, void *__fh,
1908 		const struct v4l2_framebuffer *fb)
1909 {
1910 	struct zoran_fh *fh = __fh;
1911 	struct zoran *zr = fh->zr;
1912 	int i, res = 0;
1913 	__le32 printformat = __cpu_to_le32(fb->fmt.pixelformat);
1914 
1915 	for (i = 0; i < NUM_FORMATS; i++)
1916 		if (zoran_formats[i].fourcc == fb->fmt.pixelformat)
1917 			break;
1918 	if (i == NUM_FORMATS) {
1919 		dprintk(1, KERN_ERR "%s: VIDIOC_S_FBUF - format=0x%x (%4.4s) not allowed\n",
1920 			ZR_DEVNAME(zr), fb->fmt.pixelformat,
1921 			(char *)&printformat);
1922 		return -EINVAL;
1923 	}
1924 
1925 	res = setup_fbuffer(fh, fb->base, &zoran_formats[i], fb->fmt.width,
1926 			    fb->fmt.height, fb->fmt.bytesperline);
1927 
1928 	return res;
1929 }
1930 
1931 static int zoran_overlay(struct file *file, void *__fh, unsigned int on)
1932 {
1933 	struct zoran_fh *fh = __fh;
1934 	int res;
1935 
1936 	res = setup_overlay(fh, on);
1937 
1938 	return res;
1939 }
1940 
1941 static int zoran_streamoff(struct file *file, void *__fh, enum v4l2_buf_type type);
1942 
1943 static int zoran_reqbufs(struct file *file, void *__fh, struct v4l2_requestbuffers *req)
1944 {
1945 	struct zoran_fh *fh = __fh;
1946 	struct zoran *zr = fh->zr;
1947 	int res = 0;
1948 
1949 	if (req->memory != V4L2_MEMORY_MMAP) {
1950 		dprintk(2,
1951 				KERN_ERR
1952 				"%s: only MEMORY_MMAP capture is supported, not %d\n",
1953 				ZR_DEVNAME(zr), req->memory);
1954 		return -EINVAL;
1955 	}
1956 
1957 	if (req->count == 0)
1958 		return zoran_streamoff(file, fh, req->type);
1959 
1960 	if (fh->buffers.allocated) {
1961 		dprintk(2,
1962 				KERN_ERR
1963 				"%s: VIDIOC_REQBUFS - buffers already allocated\n",
1964 				ZR_DEVNAME(zr));
1965 		res = -EBUSY;
1966 		return res;
1967 	}
1968 
1969 	if (fh->map_mode == ZORAN_MAP_MODE_RAW &&
1970 	    req->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) {
1971 		/* control user input */
1972 		if (req->count < 2)
1973 			req->count = 2;
1974 		if (req->count > v4l_nbufs)
1975 			req->count = v4l_nbufs;
1976 
1977 		/* The next mmap will map the V4L buffers */
1978 		map_mode_raw(fh);
1979 		fh->buffers.num_buffers = req->count;
1980 
1981 		if (v4l_fbuffer_alloc(fh)) {
1982 			res = -ENOMEM;
1983 			return res;
1984 		}
1985 	} else if (fh->map_mode == ZORAN_MAP_MODE_JPG_REC ||
1986 		   fh->map_mode == ZORAN_MAP_MODE_JPG_PLAY) {
1987 		/* we need to calculate size ourselves now */
1988 		if (req->count < 4)
1989 			req->count = 4;
1990 		if (req->count > jpg_nbufs)
1991 			req->count = jpg_nbufs;
1992 
1993 		/* The next mmap will map the MJPEG buffers */
1994 		map_mode_jpg(fh, req->type == V4L2_BUF_TYPE_VIDEO_OUTPUT);
1995 		fh->buffers.num_buffers = req->count;
1996 		fh->buffers.buffer_size = zoran_v4l2_calc_bufsize(&fh->jpg_settings);
1997 
1998 		if (jpg_fbuffer_alloc(fh)) {
1999 			res = -ENOMEM;
2000 			return res;
2001 		}
2002 	} else {
2003 		dprintk(1,
2004 				KERN_ERR
2005 				"%s: VIDIOC_REQBUFS - unknown type %d\n",
2006 				ZR_DEVNAME(zr), req->type);
2007 		res = -EINVAL;
2008 		return res;
2009 	}
2010 	return res;
2011 }
2012 
2013 static int zoran_querybuf(struct file *file, void *__fh, struct v4l2_buffer *buf)
2014 {
2015 	struct zoran_fh *fh = __fh;
2016 	int res;
2017 
2018 	res = zoran_v4l2_buffer_status(fh, buf, buf->index);
2019 
2020 	return res;
2021 }
2022 
2023 static int zoran_qbuf(struct file *file, void *__fh, struct v4l2_buffer *buf)
2024 {
2025 	struct zoran_fh *fh = __fh;
2026 	struct zoran *zr = fh->zr;
2027 	int res = 0, codec_mode, buf_type;
2028 
2029 	switch (fh->map_mode) {
2030 	case ZORAN_MAP_MODE_RAW:
2031 		if (buf->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) {
2032 			dprintk(1, KERN_ERR
2033 				"%s: VIDIOC_QBUF - invalid buf->type=%d for map_mode=%d\n",
2034 				ZR_DEVNAME(zr), buf->type, fh->map_mode);
2035 			res = -EINVAL;
2036 			return res;
2037 		}
2038 
2039 		res = zoran_v4l_queue_frame(fh, buf->index);
2040 		if (res)
2041 			return res;
2042 		if (!zr->v4l_memgrab_active && fh->buffers.active == ZORAN_LOCKED)
2043 			zr36057_set_memgrab(zr, 1);
2044 		break;
2045 
2046 	case ZORAN_MAP_MODE_JPG_REC:
2047 	case ZORAN_MAP_MODE_JPG_PLAY:
2048 		if (fh->map_mode == ZORAN_MAP_MODE_JPG_PLAY) {
2049 			buf_type = V4L2_BUF_TYPE_VIDEO_OUTPUT;
2050 			codec_mode = BUZ_MODE_MOTION_DECOMPRESS;
2051 		} else {
2052 			buf_type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
2053 			codec_mode = BUZ_MODE_MOTION_COMPRESS;
2054 		}
2055 
2056 		if (buf->type != buf_type) {
2057 			dprintk(1, KERN_ERR
2058 				"%s: VIDIOC_QBUF - invalid buf->type=%d for map_mode=%d\n",
2059 				ZR_DEVNAME(zr), buf->type, fh->map_mode);
2060 			res = -EINVAL;
2061 			return res;
2062 		}
2063 
2064 		res = zoran_jpg_queue_frame(fh, buf->index, codec_mode);
2065 		if (res != 0)
2066 			return res;
2067 		if (zr->codec_mode == BUZ_MODE_IDLE &&
2068 		    fh->buffers.active == ZORAN_LOCKED)
2069 			zr36057_enable_jpg(zr, codec_mode);
2070 
2071 		break;
2072 
2073 	default:
2074 		dprintk(1, KERN_ERR
2075 			"%s: VIDIOC_QBUF - unsupported type %d\n",
2076 			ZR_DEVNAME(zr), buf->type);
2077 		res = -EINVAL;
2078 		break;
2079 	}
2080 	return res;
2081 }
2082 
2083 static int zoran_dqbuf(struct file *file, void *__fh, struct v4l2_buffer *buf)
2084 {
2085 	struct zoran_fh *fh = __fh;
2086 	struct zoran *zr = fh->zr;
2087 	int res = 0, buf_type, num = -1;	/* compiler borks here (?) */
2088 
2089 	switch (fh->map_mode) {
2090 	case ZORAN_MAP_MODE_RAW:
2091 		if (buf->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) {
2092 			dprintk(1, KERN_ERR
2093 				"%s: VIDIOC_QBUF - invalid buf->type=%d for map_mode=%d\n",
2094 				ZR_DEVNAME(zr), buf->type, fh->map_mode);
2095 			res = -EINVAL;
2096 			return res;
2097 		}
2098 
2099 		num = zr->v4l_pend[zr->v4l_sync_tail & V4L_MASK_FRAME];
2100 		if (file->f_flags & O_NONBLOCK &&
2101 		    zr->v4l_buffers.buffer[num].state != BUZ_STATE_DONE) {
2102 			res = -EAGAIN;
2103 			return res;
2104 		}
2105 		res = v4l_sync(fh, num);
2106 		if (res)
2107 			return res;
2108 		zr->v4l_sync_tail++;
2109 		res = zoran_v4l2_buffer_status(fh, buf, num);
2110 		break;
2111 
2112 	case ZORAN_MAP_MODE_JPG_REC:
2113 	case ZORAN_MAP_MODE_JPG_PLAY:
2114 	{
2115 		struct zoran_sync bs;
2116 
2117 		if (fh->map_mode == ZORAN_MAP_MODE_JPG_PLAY)
2118 			buf_type = V4L2_BUF_TYPE_VIDEO_OUTPUT;
2119 		else
2120 			buf_type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
2121 
2122 		if (buf->type != buf_type) {
2123 			dprintk(1, KERN_ERR
2124 				"%s: VIDIOC_QBUF - invalid buf->type=%d for map_mode=%d\n",
2125 				ZR_DEVNAME(zr), buf->type, fh->map_mode);
2126 			res = -EINVAL;
2127 			return res;
2128 		}
2129 
2130 		num = zr->jpg_pend[zr->jpg_que_tail & BUZ_MASK_FRAME];
2131 
2132 		if (file->f_flags & O_NONBLOCK &&
2133 		    zr->jpg_buffers.buffer[num].state != BUZ_STATE_DONE) {
2134 			res = -EAGAIN;
2135 			return res;
2136 		}
2137 		bs.frame = 0; /* suppress compiler warning */
2138 		res = jpg_sync(fh, &bs);
2139 		if (res)
2140 			return res;
2141 		res = zoran_v4l2_buffer_status(fh, buf, bs.frame);
2142 		break;
2143 	}
2144 
2145 	default:
2146 		dprintk(1, KERN_ERR
2147 			"%s: VIDIOC_DQBUF - unsupported type %d\n",
2148 			ZR_DEVNAME(zr), buf->type);
2149 		res = -EINVAL;
2150 		break;
2151 	}
2152 	return res;
2153 }
2154 
2155 static int zoran_streamon(struct file *file, void *__fh, enum v4l2_buf_type type)
2156 {
2157 	struct zoran_fh *fh = __fh;
2158 	struct zoran *zr = fh->zr;
2159 	int res = 0;
2160 
2161 	switch (fh->map_mode) {
2162 	case ZORAN_MAP_MODE_RAW:	/* raw capture */
2163 		if (zr->v4l_buffers.active != ZORAN_ACTIVE ||
2164 		    fh->buffers.active != ZORAN_ACTIVE) {
2165 			res = -EBUSY;
2166 			return res;
2167 		}
2168 
2169 		zr->v4l_buffers.active = fh->buffers.active = ZORAN_LOCKED;
2170 		zr->v4l_settings = fh->v4l_settings;
2171 
2172 		zr->v4l_sync_tail = zr->v4l_pend_tail;
2173 		if (!zr->v4l_memgrab_active &&
2174 		    zr->v4l_pend_head != zr->v4l_pend_tail) {
2175 			zr36057_set_memgrab(zr, 1);
2176 		}
2177 		break;
2178 
2179 	case ZORAN_MAP_MODE_JPG_REC:
2180 	case ZORAN_MAP_MODE_JPG_PLAY:
2181 		/* what is the codec mode right now? */
2182 		if (zr->jpg_buffers.active != ZORAN_ACTIVE ||
2183 		    fh->buffers.active != ZORAN_ACTIVE) {
2184 			res = -EBUSY;
2185 			return res;
2186 		}
2187 
2188 		zr->jpg_buffers.active = fh->buffers.active = ZORAN_LOCKED;
2189 
2190 		if (zr->jpg_que_head != zr->jpg_que_tail) {
2191 			/* Start the jpeg codec when the first frame is queued  */
2192 			jpeg_start(zr);
2193 		}
2194 		break;
2195 
2196 	default:
2197 		dprintk(1,
2198 			KERN_ERR
2199 			"%s: VIDIOC_STREAMON - invalid map mode %d\n",
2200 			ZR_DEVNAME(zr), fh->map_mode);
2201 		res = -EINVAL;
2202 		break;
2203 	}
2204 	return res;
2205 }
2206 
2207 static int zoran_streamoff(struct file *file, void *__fh, enum v4l2_buf_type type)
2208 {
2209 	struct zoran_fh *fh = __fh;
2210 	struct zoran *zr = fh->zr;
2211 	int i, res = 0;
2212 	unsigned long flags;
2213 
2214 	switch (fh->map_mode) {
2215 	case ZORAN_MAP_MODE_RAW:	/* raw capture */
2216 		if (fh->buffers.active == ZORAN_FREE &&
2217 		    zr->v4l_buffers.active != ZORAN_FREE) {
2218 			res = -EPERM;	/* stay off other's settings! */
2219 			return res;
2220 		}
2221 		if (zr->v4l_buffers.active == ZORAN_FREE)
2222 			return res;
2223 
2224 		spin_lock_irqsave(&zr->spinlock, flags);
2225 		/* unload capture */
2226 		if (zr->v4l_memgrab_active) {
2227 
2228 			zr36057_set_memgrab(zr, 0);
2229 		}
2230 
2231 		for (i = 0; i < fh->buffers.num_buffers; i++)
2232 			zr->v4l_buffers.buffer[i].state = BUZ_STATE_USER;
2233 		fh->buffers = zr->v4l_buffers;
2234 
2235 		zr->v4l_buffers.active = fh->buffers.active = ZORAN_FREE;
2236 
2237 		zr->v4l_grab_seq = 0;
2238 		zr->v4l_pend_head = zr->v4l_pend_tail = 0;
2239 		zr->v4l_sync_tail = 0;
2240 
2241 		spin_unlock_irqrestore(&zr->spinlock, flags);
2242 
2243 		break;
2244 
2245 	case ZORAN_MAP_MODE_JPG_REC:
2246 	case ZORAN_MAP_MODE_JPG_PLAY:
2247 		if (fh->buffers.active == ZORAN_FREE &&
2248 		    zr->jpg_buffers.active != ZORAN_FREE) {
2249 			res = -EPERM;	/* stay off other's settings! */
2250 			return res;
2251 		}
2252 		if (zr->jpg_buffers.active == ZORAN_FREE)
2253 			return res;
2254 
2255 		res = jpg_qbuf(fh, -1,
2256 			     (fh->map_mode == ZORAN_MAP_MODE_JPG_REC) ?
2257 			     BUZ_MODE_MOTION_COMPRESS :
2258 			     BUZ_MODE_MOTION_DECOMPRESS);
2259 		if (res)
2260 			return res;
2261 		break;
2262 	default:
2263 		dprintk(1, KERN_ERR
2264 			"%s: VIDIOC_STREAMOFF - invalid map mode %d\n",
2265 			ZR_DEVNAME(zr), fh->map_mode);
2266 		res = -EINVAL;
2267 		break;
2268 	}
2269 	return res;
2270 }
2271 static int zoran_g_std(struct file *file, void *__fh, v4l2_std_id *std)
2272 {
2273 	struct zoran_fh *fh = __fh;
2274 	struct zoran *zr = fh->zr;
2275 
2276 	*std = zr->norm;
2277 	return 0;
2278 }
2279 
2280 static int zoran_s_std(struct file *file, void *__fh, v4l2_std_id std)
2281 {
2282 	struct zoran_fh *fh = __fh;
2283 	struct zoran *zr = fh->zr;
2284 	int res = 0;
2285 
2286 	res = zoran_set_norm(zr, std);
2287 	if (res)
2288 		return res;
2289 
2290 	res = wait_grab_pending(zr);
2291 	return res;
2292 }
2293 
2294 static int zoran_enum_input(struct file *file, void *__fh,
2295 				 struct v4l2_input *inp)
2296 {
2297 	struct zoran_fh *fh = __fh;
2298 	struct zoran *zr = fh->zr;
2299 
2300 	if (inp->index >= zr->card.inputs)
2301 		return -EINVAL;
2302 
2303 	strncpy(inp->name, zr->card.input[inp->index].name,
2304 		sizeof(inp->name) - 1);
2305 	inp->type = V4L2_INPUT_TYPE_CAMERA;
2306 	inp->std = V4L2_STD_ALL;
2307 
2308 	/* Get status of video decoder */
2309 	decoder_call(zr, video, g_input_status, &inp->status);
2310 	return 0;
2311 }
2312 
2313 static int zoran_g_input(struct file *file, void *__fh, unsigned int *input)
2314 {
2315 	struct zoran_fh *fh = __fh;
2316 	struct zoran *zr = fh->zr;
2317 
2318 	*input = zr->input;
2319 
2320 	return 0;
2321 }
2322 
2323 static int zoran_s_input(struct file *file, void *__fh, unsigned int input)
2324 {
2325 	struct zoran_fh *fh = __fh;
2326 	struct zoran *zr = fh->zr;
2327 	int res;
2328 
2329 	res = zoran_set_input(zr, input);
2330 	if (res)
2331 		return res;
2332 
2333 	/* Make sure the changes come into effect */
2334 	res = wait_grab_pending(zr);
2335 	return res;
2336 }
2337 
2338 static int zoran_enum_output(struct file *file, void *__fh,
2339 				  struct v4l2_output *outp)
2340 {
2341 	if (outp->index != 0)
2342 		return -EINVAL;
2343 
2344 	outp->index = 0;
2345 	outp->type = V4L2_OUTPUT_TYPE_ANALOGVGAOVERLAY;
2346 	strncpy(outp->name, "Autodetect", sizeof(outp->name)-1);
2347 
2348 	return 0;
2349 }
2350 
2351 static int zoran_g_output(struct file *file, void *__fh, unsigned int *output)
2352 {
2353 	*output = 0;
2354 
2355 	return 0;
2356 }
2357 
2358 static int zoran_s_output(struct file *file, void *__fh, unsigned int output)
2359 {
2360 	if (output != 0)
2361 		return -EINVAL;
2362 
2363 	return 0;
2364 }
2365 
2366 /* cropping (sub-frame capture) */
2367 static int zoran_g_selection(struct file *file, void *__fh, struct v4l2_selection *sel)
2368 {
2369 	struct zoran_fh *fh = __fh;
2370 	struct zoran *zr = fh->zr;
2371 
2372 	if (sel->type != V4L2_BUF_TYPE_VIDEO_OUTPUT &&
2373 	    sel->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
2374 		return -EINVAL;
2375 
2376 	if (fh->map_mode == ZORAN_MAP_MODE_RAW) {
2377 		dprintk(1, KERN_ERR
2378 			"%s: VIDIOC_G_SELECTION - subcapture only supported for compressed capture\n",
2379 			ZR_DEVNAME(zr));
2380 		return -EINVAL;
2381 	}
2382 
2383 	switch (sel->target) {
2384 	case V4L2_SEL_TGT_CROP:
2385 		sel->r.top = fh->jpg_settings.img_y;
2386 		sel->r.left = fh->jpg_settings.img_x;
2387 		sel->r.width = fh->jpg_settings.img_width;
2388 		sel->r.height = fh->jpg_settings.img_height;
2389 		break;
2390 	case V4L2_SEL_TGT_CROP_DEFAULT:
2391 		sel->r.top = sel->r.left = 0;
2392 		sel->r.width = BUZ_MIN_WIDTH;
2393 		sel->r.height = BUZ_MIN_HEIGHT;
2394 		break;
2395 	case V4L2_SEL_TGT_CROP_BOUNDS:
2396 		sel->r.top = sel->r.left = 0;
2397 		sel->r.width = BUZ_MAX_WIDTH;
2398 		sel->r.height = BUZ_MAX_HEIGHT;
2399 		break;
2400 	default:
2401 		return -EINVAL;
2402 	}
2403 	return 0;
2404 }
2405 
2406 static int zoran_s_selection(struct file *file, void *__fh, struct v4l2_selection *sel)
2407 {
2408 	struct zoran_fh *fh = __fh;
2409 	struct zoran *zr = fh->zr;
2410 	struct zoran_jpg_settings settings;
2411 	int res;
2412 
2413 	if (sel->type != V4L2_BUF_TYPE_VIDEO_OUTPUT &&
2414 	    sel->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
2415 		return -EINVAL;
2416 
2417 	if (sel->target != V4L2_SEL_TGT_CROP)
2418 		return -EINVAL;
2419 
2420 	if (fh->map_mode == ZORAN_MAP_MODE_RAW) {
2421 		dprintk(1, KERN_ERR
2422 			"%s: VIDIOC_S_SELECTION - subcapture only supported for compressed capture\n",
2423 			ZR_DEVNAME(zr));
2424 		return -EINVAL;
2425 	}
2426 
2427 	settings = fh->jpg_settings;
2428 
2429 	if (fh->buffers.allocated) {
2430 		dprintk(1, KERN_ERR
2431 			"%s: VIDIOC_S_SELECTION - cannot change settings while active\n",
2432 			ZR_DEVNAME(zr));
2433 		return -EBUSY;
2434 	}
2435 
2436 	/* move into a form that we understand */
2437 	settings.img_x = sel->r.left;
2438 	settings.img_y = sel->r.top;
2439 	settings.img_width = sel->r.width;
2440 	settings.img_height = sel->r.height;
2441 
2442 	/* check validity */
2443 	res = zoran_check_jpg_settings(zr, &settings, 0);
2444 	if (res)
2445 		return res;
2446 
2447 	/* accept */
2448 	fh->jpg_settings = settings;
2449 	return res;
2450 }
2451 
2452 static int zoran_g_jpegcomp(struct file *file, void *__fh,
2453 					struct v4l2_jpegcompression *params)
2454 {
2455 	struct zoran_fh *fh = __fh;
2456 	memset(params, 0, sizeof(*params));
2457 
2458 	params->quality = fh->jpg_settings.jpg_comp.quality;
2459 	params->APPn = fh->jpg_settings.jpg_comp.APPn;
2460 	memcpy(params->APP_data,
2461 	       fh->jpg_settings.jpg_comp.APP_data,
2462 	       fh->jpg_settings.jpg_comp.APP_len);
2463 	params->APP_len = fh->jpg_settings.jpg_comp.APP_len;
2464 	memcpy(params->COM_data,
2465 	       fh->jpg_settings.jpg_comp.COM_data,
2466 	       fh->jpg_settings.jpg_comp.COM_len);
2467 	params->COM_len = fh->jpg_settings.jpg_comp.COM_len;
2468 	params->jpeg_markers =
2469 	    fh->jpg_settings.jpg_comp.jpeg_markers;
2470 
2471 	return 0;
2472 }
2473 
2474 static int zoran_s_jpegcomp(struct file *file, void *__fh,
2475 					const struct v4l2_jpegcompression *params)
2476 {
2477 	struct zoran_fh *fh = __fh;
2478 	struct zoran *zr = fh->zr;
2479 	int res = 0;
2480 	struct zoran_jpg_settings settings;
2481 
2482 	settings = fh->jpg_settings;
2483 
2484 	settings.jpg_comp = *params;
2485 
2486 	if (fh->buffers.active != ZORAN_FREE) {
2487 		dprintk(1, KERN_WARNING
2488 			"%s: VIDIOC_S_JPEGCOMP called while in playback/capture mode\n",
2489 			ZR_DEVNAME(zr));
2490 		res = -EBUSY;
2491 		return res;
2492 	}
2493 
2494 	res = zoran_check_jpg_settings(zr, &settings, 0);
2495 	if (res)
2496 		return res;
2497 	if (!fh->buffers.allocated)
2498 		fh->buffers.buffer_size =
2499 			zoran_v4l2_calc_bufsize(&fh->jpg_settings);
2500 	fh->jpg_settings.jpg_comp = settings.jpg_comp;
2501 	return res;
2502 }
2503 
2504 static unsigned int
2505 zoran_poll (struct file *file,
2506 	    poll_table  *wait)
2507 {
2508 	struct zoran_fh *fh = file->private_data;
2509 	struct zoran *zr = fh->zr;
2510 	int res = v4l2_ctrl_poll(file, wait);
2511 	int frame;
2512 	unsigned long flags;
2513 
2514 	/* we should check whether buffers are ready to be synced on
2515 	 * (w/o waits - O_NONBLOCK) here
2516 	 * if ready for read (sync), return POLLIN|POLLRDNORM,
2517 	 * if ready for write (sync), return POLLOUT|POLLWRNORM,
2518 	 * if error, return POLLERR,
2519 	 * if no buffers queued or so, return POLLNVAL
2520 	 */
2521 
2522 	switch (fh->map_mode) {
2523 	case ZORAN_MAP_MODE_RAW:
2524 		poll_wait(file, &zr->v4l_capq, wait);
2525 		frame = zr->v4l_pend[zr->v4l_sync_tail & V4L_MASK_FRAME];
2526 
2527 		spin_lock_irqsave(&zr->spinlock, flags);
2528 		dprintk(3,
2529 			KERN_DEBUG
2530 			"%s: %s() raw - active=%c, sync_tail=%lu/%c, pend_tail=%lu, pend_head=%lu\n",
2531 			ZR_DEVNAME(zr), __func__,
2532 			"FAL"[fh->buffers.active], zr->v4l_sync_tail,
2533 			"UPMD"[zr->v4l_buffers.buffer[frame].state],
2534 			zr->v4l_pend_tail, zr->v4l_pend_head);
2535 		/* Process is the one capturing? */
2536 		if (fh->buffers.active != ZORAN_FREE &&
2537 		    /* Buffer ready to DQBUF? */
2538 		    zr->v4l_buffers.buffer[frame].state == BUZ_STATE_DONE)
2539 			res |= POLLIN | POLLRDNORM;
2540 		spin_unlock_irqrestore(&zr->spinlock, flags);
2541 
2542 		break;
2543 
2544 	case ZORAN_MAP_MODE_JPG_REC:
2545 	case ZORAN_MAP_MODE_JPG_PLAY:
2546 		poll_wait(file, &zr->jpg_capq, wait);
2547 		frame = zr->jpg_pend[zr->jpg_que_tail & BUZ_MASK_FRAME];
2548 
2549 		spin_lock_irqsave(&zr->spinlock, flags);
2550 		dprintk(3,
2551 			KERN_DEBUG
2552 			"%s: %s() jpg - active=%c, que_tail=%lu/%c, que_head=%lu, dma=%lu/%lu\n",
2553 			ZR_DEVNAME(zr), __func__,
2554 			"FAL"[fh->buffers.active], zr->jpg_que_tail,
2555 			"UPMD"[zr->jpg_buffers.buffer[frame].state],
2556 			zr->jpg_que_head, zr->jpg_dma_tail, zr->jpg_dma_head);
2557 		if (fh->buffers.active != ZORAN_FREE &&
2558 		    zr->jpg_buffers.buffer[frame].state == BUZ_STATE_DONE) {
2559 			if (fh->map_mode == ZORAN_MAP_MODE_JPG_REC)
2560 				res |= POLLIN | POLLRDNORM;
2561 			else
2562 				res |= POLLOUT | POLLWRNORM;
2563 		}
2564 		spin_unlock_irqrestore(&zr->spinlock, flags);
2565 
2566 		break;
2567 
2568 	default:
2569 		dprintk(1,
2570 			KERN_ERR
2571 			"%s: %s - internal error, unknown map_mode=%d\n",
2572 			ZR_DEVNAME(zr), __func__, fh->map_mode);
2573 		res |= POLLERR;
2574 	}
2575 
2576 	return res;
2577 }
2578 
2579 
2580 /*
2581  * This maps the buffers to user space.
2582  *
2583  * Depending on the state of fh->map_mode
2584  * the V4L or the MJPEG buffers are mapped
2585  * per buffer or all together
2586  *
2587  * Note that we need to connect to some
2588  * unmap signal event to unmap the de-allocate
2589  * the buffer accordingly (zoran_vm_close())
2590  */
2591 
2592 static void
2593 zoran_vm_open (struct vm_area_struct *vma)
2594 {
2595 	struct zoran_mapping *map = vma->vm_private_data;
2596 	atomic_inc(&map->count);
2597 }
2598 
2599 static void
2600 zoran_vm_close (struct vm_area_struct *vma)
2601 {
2602 	struct zoran_mapping *map = vma->vm_private_data;
2603 	struct zoran_fh *fh = map->fh;
2604 	struct zoran *zr = fh->zr;
2605 	int i;
2606 
2607 	dprintk(3, KERN_INFO "%s: %s - munmap(%s)\n", ZR_DEVNAME(zr),
2608 		__func__, mode_name(fh->map_mode));
2609 
2610 	for (i = 0; i < fh->buffers.num_buffers; i++) {
2611 		if (fh->buffers.buffer[i].map == map)
2612 			fh->buffers.buffer[i].map = NULL;
2613 	}
2614 	kfree(map);
2615 
2616 	/* Any buffers still mapped? */
2617 	for (i = 0; i < fh->buffers.num_buffers; i++) {
2618 		if (fh->buffers.buffer[i].map) {
2619 			return;
2620 		}
2621 	}
2622 
2623 	dprintk(3, KERN_INFO "%s: %s - free %s buffers\n", ZR_DEVNAME(zr),
2624 		__func__, mode_name(fh->map_mode));
2625 
2626 	if (fh->map_mode == ZORAN_MAP_MODE_RAW) {
2627 		if (fh->buffers.active != ZORAN_FREE) {
2628 			unsigned long flags;
2629 
2630 			spin_lock_irqsave(&zr->spinlock, flags);
2631 			zr36057_set_memgrab(zr, 0);
2632 			zr->v4l_buffers.allocated = 0;
2633 			zr->v4l_buffers.active = fh->buffers.active = ZORAN_FREE;
2634 			spin_unlock_irqrestore(&zr->spinlock, flags);
2635 		}
2636 		v4l_fbuffer_free(fh);
2637 	} else {
2638 		if (fh->buffers.active != ZORAN_FREE) {
2639 			jpg_qbuf(fh, -1, zr->codec_mode);
2640 			zr->jpg_buffers.allocated = 0;
2641 			zr->jpg_buffers.active = fh->buffers.active = ZORAN_FREE;
2642 		}
2643 		jpg_fbuffer_free(fh);
2644 	}
2645 }
2646 
2647 static const struct vm_operations_struct zoran_vm_ops = {
2648 	.open = zoran_vm_open,
2649 	.close = zoran_vm_close,
2650 };
2651 
2652 static int
2653 zoran_mmap (struct file           *file,
2654 	    struct vm_area_struct *vma)
2655 {
2656 	struct zoran_fh *fh = file->private_data;
2657 	struct zoran *zr = fh->zr;
2658 	unsigned long size = (vma->vm_end - vma->vm_start);
2659 	unsigned long offset = vma->vm_pgoff << PAGE_SHIFT;
2660 	int i, j;
2661 	unsigned long page, start = vma->vm_start, todo, pos, fraglen;
2662 	int first, last;
2663 	struct zoran_mapping *map;
2664 	int res = 0;
2665 
2666 	dprintk(3,
2667 		KERN_INFO "%s: %s(%s) of 0x%08lx-0x%08lx (size=%lu)\n",
2668 		ZR_DEVNAME(zr), __func__,
2669 		mode_name(fh->map_mode), vma->vm_start, vma->vm_end, size);
2670 
2671 	if (!(vma->vm_flags & VM_SHARED) || !(vma->vm_flags & VM_READ) ||
2672 	    !(vma->vm_flags & VM_WRITE)) {
2673 		dprintk(1,
2674 			KERN_ERR
2675 			"%s: %s - no MAP_SHARED/PROT_{READ,WRITE} given\n",
2676 			ZR_DEVNAME(zr), __func__);
2677 		return -EINVAL;
2678 	}
2679 
2680 	if (!fh->buffers.allocated) {
2681 		dprintk(1,
2682 			KERN_ERR
2683 			"%s: %s(%s) - buffers not yet allocated\n",
2684 			ZR_DEVNAME(zr), __func__, mode_name(fh->map_mode));
2685 		res = -ENOMEM;
2686 		return res;
2687 	}
2688 
2689 	first = offset / fh->buffers.buffer_size;
2690 	last = first - 1 + size / fh->buffers.buffer_size;
2691 	if (offset % fh->buffers.buffer_size != 0 ||
2692 	    size % fh->buffers.buffer_size != 0 || first < 0 ||
2693 	    last < 0 || first >= fh->buffers.num_buffers ||
2694 	    last >= fh->buffers.buffer_size) {
2695 		dprintk(1,
2696 			KERN_ERR
2697 			"%s: %s(%s) - offset=%lu or size=%lu invalid for bufsize=%d and numbufs=%d\n",
2698 			ZR_DEVNAME(zr), __func__, mode_name(fh->map_mode), offset, size,
2699 			fh->buffers.buffer_size,
2700 			fh->buffers.num_buffers);
2701 		res = -EINVAL;
2702 		return res;
2703 	}
2704 
2705 	/* Check if any buffers are already mapped */
2706 	for (i = first; i <= last; i++) {
2707 		if (fh->buffers.buffer[i].map) {
2708 			dprintk(1,
2709 				KERN_ERR
2710 				"%s: %s(%s) - buffer %d already mapped\n",
2711 				ZR_DEVNAME(zr), __func__, mode_name(fh->map_mode), i);
2712 			res = -EBUSY;
2713 			return res;
2714 		}
2715 	}
2716 
2717 	/* map these buffers */
2718 	map = kmalloc(sizeof(struct zoran_mapping), GFP_KERNEL);
2719 	if (!map) {
2720 		res = -ENOMEM;
2721 		return res;
2722 	}
2723 	map->fh = fh;
2724 	atomic_set(&map->count, 1);
2725 
2726 	vma->vm_ops = &zoran_vm_ops;
2727 	vma->vm_flags |= VM_DONTEXPAND;
2728 	vma->vm_private_data = map;
2729 
2730 	if (fh->map_mode == ZORAN_MAP_MODE_RAW) {
2731 		for (i = first; i <= last; i++) {
2732 			todo = size;
2733 			if (todo > fh->buffers.buffer_size)
2734 				todo = fh->buffers.buffer_size;
2735 			page = fh->buffers.buffer[i].v4l.fbuffer_phys;
2736 			if (remap_pfn_range(vma, start, page >> PAGE_SHIFT,
2737 							todo, PAGE_SHARED)) {
2738 				dprintk(1,
2739 					KERN_ERR
2740 					"%s: %s(V4L) - remap_pfn_range failed\n",
2741 					ZR_DEVNAME(zr), __func__);
2742 				res = -EAGAIN;
2743 				return res;
2744 			}
2745 			size -= todo;
2746 			start += todo;
2747 			fh->buffers.buffer[i].map = map;
2748 			if (size == 0)
2749 				break;
2750 		}
2751 	} else {
2752 		for (i = first; i <= last; i++) {
2753 			for (j = 0;
2754 			     j < fh->buffers.buffer_size / PAGE_SIZE;
2755 			     j++) {
2756 				fraglen =
2757 				    (le32_to_cpu(fh->buffers.buffer[i].jpg.
2758 				     frag_tab[2 * j + 1]) & ~1) << 1;
2759 				todo = size;
2760 				if (todo > fraglen)
2761 					todo = fraglen;
2762 				pos =
2763 				    le32_to_cpu(fh->buffers.
2764 				    buffer[i].jpg.frag_tab[2 * j]);
2765 				/* should just be pos on i386 */
2766 				page = virt_to_phys(bus_to_virt(pos))
2767 								>> PAGE_SHIFT;
2768 				if (remap_pfn_range(vma, start, page,
2769 							todo, PAGE_SHARED)) {
2770 					dprintk(1,
2771 						KERN_ERR
2772 						"%s: %s(V4L) - remap_pfn_range failed\n",
2773 						ZR_DEVNAME(zr), __func__);
2774 					res = -EAGAIN;
2775 					return res;
2776 				}
2777 				size -= todo;
2778 				start += todo;
2779 				if (size == 0)
2780 					break;
2781 				if (le32_to_cpu(fh->buffers.buffer[i].jpg.
2782 				    frag_tab[2 * j + 1]) & 1)
2783 					break;	/* was last fragment */
2784 			}
2785 			fh->buffers.buffer[i].map = map;
2786 			if (size == 0)
2787 				break;
2788 
2789 		}
2790 	}
2791 	return res;
2792 }
2793 
2794 static const struct v4l2_ioctl_ops zoran_ioctl_ops = {
2795 	.vidioc_querycap    		    = zoran_querycap,
2796 	.vidioc_s_selection		    = zoran_s_selection,
2797 	.vidioc_g_selection		    = zoran_g_selection,
2798 	.vidioc_enum_input     		    = zoran_enum_input,
2799 	.vidioc_g_input      		    = zoran_g_input,
2800 	.vidioc_s_input      		    = zoran_s_input,
2801 	.vidioc_enum_output    		    = zoran_enum_output,
2802 	.vidioc_g_output     		    = zoran_g_output,
2803 	.vidioc_s_output     		    = zoran_s_output,
2804 	.vidioc_g_fbuf			    = zoran_g_fbuf,
2805 	.vidioc_s_fbuf			    = zoran_s_fbuf,
2806 	.vidioc_g_std 			    = zoran_g_std,
2807 	.vidioc_s_std 			    = zoran_s_std,
2808 	.vidioc_g_jpegcomp 		    = zoran_g_jpegcomp,
2809 	.vidioc_s_jpegcomp 		    = zoran_s_jpegcomp,
2810 	.vidioc_overlay			    = zoran_overlay,
2811 	.vidioc_reqbufs			    = zoran_reqbufs,
2812 	.vidioc_querybuf		    = zoran_querybuf,
2813 	.vidioc_qbuf			    = zoran_qbuf,
2814 	.vidioc_dqbuf			    = zoran_dqbuf,
2815 	.vidioc_streamon		    = zoran_streamon,
2816 	.vidioc_streamoff		    = zoran_streamoff,
2817 	.vidioc_enum_fmt_vid_cap 	    = zoran_enum_fmt_vid_cap,
2818 	.vidioc_enum_fmt_vid_out 	    = zoran_enum_fmt_vid_out,
2819 	.vidioc_enum_fmt_vid_overlay 	    = zoran_enum_fmt_vid_overlay,
2820 	.vidioc_g_fmt_vid_cap 		    = zoran_g_fmt_vid_cap,
2821 	.vidioc_g_fmt_vid_out               = zoran_g_fmt_vid_out,
2822 	.vidioc_g_fmt_vid_overlay           = zoran_g_fmt_vid_overlay,
2823 	.vidioc_s_fmt_vid_cap  		    = zoran_s_fmt_vid_cap,
2824 	.vidioc_s_fmt_vid_out               = zoran_s_fmt_vid_out,
2825 	.vidioc_s_fmt_vid_overlay           = zoran_s_fmt_vid_overlay,
2826 	.vidioc_try_fmt_vid_cap  	    = zoran_try_fmt_vid_cap,
2827 	.vidioc_try_fmt_vid_out 	    = zoran_try_fmt_vid_out,
2828 	.vidioc_try_fmt_vid_overlay 	    = zoran_try_fmt_vid_overlay,
2829 	.vidioc_subscribe_event             = v4l2_ctrl_subscribe_event,
2830 	.vidioc_unsubscribe_event           = v4l2_event_unsubscribe,
2831 };
2832 
2833 static const struct v4l2_file_operations zoran_fops = {
2834 	.owner = THIS_MODULE,
2835 	.open = zoran_open,
2836 	.release = zoran_close,
2837 	.unlocked_ioctl = video_ioctl2,
2838 	.mmap = zoran_mmap,
2839 	.poll = zoran_poll,
2840 };
2841 
2842 const struct video_device zoran_template = {
2843 	.name = ZORAN_NAME,
2844 	.fops = &zoran_fops,
2845 	.ioctl_ops = &zoran_ioctl_ops,
2846 	.release = &zoran_vdev_release,
2847 	.tvnorms = V4L2_STD_NTSC | V4L2_STD_PAL | V4L2_STD_SECAM,
2848 };
2849 
2850