videobuf-core.c 25.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 * generic helper functions for handling video4linux capture buffers
 *
 * (c) 2007 Mauro Carvalho Chehab, <mchehab@infradead.org>
 *
 * Highly based on video-buf written originally by:
 * (c) 2001,02 Gerd Knorr <kraxel@bytesex.org>
 * (c) 2006 Mauro Carvalho Chehab, <mchehab@infradead.org>
 * (c) 2006 Ted Walther and John Sokol
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2
 */

#include <linux/init.h>
#include <linux/module.h>
#include <linux/moduleparam.h>
19
#include <linux/mm.h>
20
#include <linux/sched.h>
21 22 23 24 25 26
#include <linux/slab.h>
#include <linux/interrupt.h>

#include <media/videobuf-core.h>

#define MAGIC_BUFFER 0x20070728
27 28 29 30 31 32 33 34 35
#define MAGIC_CHECK(is, should)						\
	do {								\
		if (unlikely((is) != (should))) {			\
			printk(KERN_ERR					\
				"magic mismatch: %x (expected %x)\n",	\
					is, should);			\
			BUG();						\
		}							\
	} while (0)
36

37
static int debug;
38 39 40 41 42 43
module_param(debug, int, 0644);

MODULE_DESCRIPTION("helper module to manage video4linux buffers");
MODULE_AUTHOR("Mauro Carvalho Chehab <mchehab@infradead.org>");
MODULE_LICENSE("GPL");

44 45 46 47 48
#define dprintk(level, fmt, arg...)					\
	do {								\
		if (debug >= level)					\
			printk(KERN_DEBUG "vbuf: " fmt, ## arg);	\
	} while (0)
49 50 51 52

/* --------------------------------------------------------------------- */

#define CALL(q, f, arg...)						\
53
	((q->int_ops->f) ? q->int_ops->f(arg) : 0)
54

55
struct videobuf_buffer *videobuf_alloc(struct videobuf_queue *q)
56 57 58
{
	struct videobuf_buffer *vb;

59
	BUG_ON(q->msize < sizeof(*vb));
60 61 62 63 64 65 66 67 68

	if (!q->int_ops || !q->int_ops->alloc) {
		printk(KERN_ERR "No specific ops defined!\n");
		BUG();
	}

	vb = q->int_ops->alloc(q->msize);
	if (NULL != vb) {
		init_waitqueue_head(&vb->done);
69
		vb->magic = MAGIC_BUFFER;
70 71 72 73
	}

	return vb;
}
74
EXPORT_SYMBOL_GPL(videobuf_alloc);
75

76 77
#define WAITON_CONDITION (vb->state != VIDEOBUF_ACTIVE &&\
				vb->state != VIDEOBUF_QUEUED)
78 79
int videobuf_waiton(struct videobuf_buffer *vb, int non_blocking, int intr)
{
80
	MAGIC_CHECK(vb->magic, MAGIC_BUFFER);
81 82 83 84 85 86

	if (non_blocking) {
		if (WAITON_CONDITION)
			return 0;
		else
			return -EAGAIN;
87
	}
88 89 90 91 92 93 94

	if (intr)
		return wait_event_interruptible(vb->done, WAITON_CONDITION);
	else
		wait_event(vb->done, WAITON_CONDITION);

	return 0;
95
}
96
EXPORT_SYMBOL_GPL(videobuf_waiton);
97

98
int videobuf_iolock(struct videobuf_queue *q, struct videobuf_buffer *vb,
99 100
		    struct v4l2_framebuffer *fbuf)
{
101 102
	MAGIC_CHECK(vb->magic, MAGIC_BUFFER);
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
103

104
	return CALL(q, iolock, q, vb, fbuf);
105
}
106
EXPORT_SYMBOL_GPL(videobuf_iolock);
107

108 109
void *videobuf_queue_to_vaddr(struct videobuf_queue *q,
			      struct videobuf_buffer *buf)
110
{
111 112
	if (q->int_ops->vaddr)
		return q->int_ops->vaddr(buf);
113
	return NULL;
114
}
115
EXPORT_SYMBOL_GPL(videobuf_queue_to_vaddr);
116

117 118 119
/* --------------------------------------------------------------------- */


120
void videobuf_queue_core_init(struct videobuf_queue *q,
121
			 const struct videobuf_queue_ops *ops,
122
			 struct device *dev,
123 124 125 126
			 spinlock_t *irqlock,
			 enum v4l2_buf_type type,
			 enum v4l2_field field,
			 unsigned int msize,
127 128
			 void *priv,
			 struct videobuf_qtype_ops *int_ops)
129
{
130
	BUG_ON(!q);
131
	memset(q, 0, sizeof(*q));
132 133 134 135 136 137
	q->irqlock   = irqlock;
	q->dev       = dev;
	q->type      = type;
	q->field     = field;
	q->msize     = msize;
	q->ops       = ops;
138
	q->priv_data = priv;
139
	q->int_ops   = int_ops;
140 141

	/* All buffer operations are mandatory */
142 143 144 145
	BUG_ON(!q->ops->buf_setup);
	BUG_ON(!q->ops->buf_prepare);
	BUG_ON(!q->ops->buf_queue);
	BUG_ON(!q->ops->buf_release);
146

147 148 149
	/* Lock is mandatory for queue_cancel to work */
	BUG_ON(!irqlock);

150
	/* Having implementations for abstract methods are mandatory */
151
	BUG_ON(!q->int_ops);
152

153
	mutex_init(&q->vb_lock);
154
	init_waitqueue_head(&q->wait);
155 156
	INIT_LIST_HEAD(&q->stream);
}
157
EXPORT_SYMBOL_GPL(videobuf_queue_core_init);
158

159
/* Locking: Only usage in bttv unsafe find way to remove */
160 161 162 163
int videobuf_queue_is_busy(struct videobuf_queue *q)
{
	int i;

164
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
165 166

	if (q->streaming) {
167
		dprintk(1, "busy: streaming active\n");
168 169 170
		return 1;
	}
	if (q->reading) {
171
		dprintk(1, "busy: pending read #1\n");
172 173 174
		return 1;
	}
	if (q->read_buf) {
175
		dprintk(1, "busy: pending read #2\n");
176 177 178 179 180
		return 1;
	}
	for (i = 0; i < VIDEO_MAX_FRAME; i++) {
		if (NULL == q->bufs[i])
			continue;
181
		if (q->bufs[i]->map) {
182
			dprintk(1, "busy: buffer #%d mapped\n", i);
183 184
			return 1;
		}
185
		if (q->bufs[i]->state == VIDEOBUF_QUEUED) {
186
			dprintk(1, "busy: buffer #%d queued\n", i);
187 188
			return 1;
		}
189
		if (q->bufs[i]->state == VIDEOBUF_ACTIVE) {
190
			dprintk(1, "busy: buffer #%d avtive\n", i);
191 192 193 194 195
			return 1;
		}
	}
	return 0;
}
196
EXPORT_SYMBOL_GPL(videobuf_queue_is_busy);
197

198
/* Locking: Caller holds q->vb_lock */
199 200
void videobuf_queue_cancel(struct videobuf_queue *q)
{
201
	unsigned long flags = 0;
202 203
	int i;

204 205 206 207
	q->streaming = 0;
	q->reading  = 0;
	wake_up_interruptible_sync(&q->wait);

208
	/* remove queued buffers from list */
209
	spin_lock_irqsave(q->irqlock, flags);
210 211 212
	for (i = 0; i < VIDEO_MAX_FRAME; i++) {
		if (NULL == q->bufs[i])
			continue;
213
		if (q->bufs[i]->state == VIDEOBUF_QUEUED) {
214
			list_del(&q->bufs[i]->queue);
215
			q->bufs[i]->state = VIDEOBUF_ERROR;
216
			wake_up_all(&q->bufs[i]->done);
217 218
		}
	}
219
	spin_unlock_irqrestore(q->irqlock, flags);
220 221 222 223 224

	/* free all buffers + clear queue */
	for (i = 0; i < VIDEO_MAX_FRAME; i++) {
		if (NULL == q->bufs[i])
			continue;
225
		q->ops->buf_release(q, q->bufs[i]);
226 227 228
	}
	INIT_LIST_HEAD(&q->stream);
}
229
EXPORT_SYMBOL_GPL(videobuf_queue_cancel);
230 231 232

/* --------------------------------------------------------------------- */

233
/* Locking: Caller holds q->vb_lock */
234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250
enum v4l2_field videobuf_next_field(struct videobuf_queue *q)
{
	enum v4l2_field field = q->field;

	BUG_ON(V4L2_FIELD_ANY == field);

	if (V4L2_FIELD_ALTERNATE == field) {
		if (V4L2_FIELD_TOP == q->last) {
			field   = V4L2_FIELD_BOTTOM;
			q->last = V4L2_FIELD_BOTTOM;
		} else {
			field   = V4L2_FIELD_TOP;
			q->last = V4L2_FIELD_TOP;
		}
	}
	return field;
}
251
EXPORT_SYMBOL_GPL(videobuf_next_field);
252

253
/* Locking: Caller holds q->vb_lock */
254 255 256
static void videobuf_status(struct videobuf_queue *q, struct v4l2_buffer *b,
			    struct videobuf_buffer *vb, enum v4l2_buf_type type)
{
257 258
	MAGIC_CHECK(vb->magic, MAGIC_BUFFER);
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278

	b->index    = vb->i;
	b->type     = type;

	b->memory   = vb->memory;
	switch (b->memory) {
	case V4L2_MEMORY_MMAP:
		b->m.offset  = vb->boff;
		b->length    = vb->bsize;
		break;
	case V4L2_MEMORY_USERPTR:
		b->m.userptr = vb->baddr;
		b->length    = vb->bsize;
		break;
	case V4L2_MEMORY_OVERLAY:
		b->m.offset  = vb->boff;
		break;
	}

	b->flags    = 0;
279
	if (vb->map)
280 281 282
		b->flags |= V4L2_BUF_FLAG_MAPPED;

	switch (vb->state) {
283 284 285
	case VIDEOBUF_PREPARED:
	case VIDEOBUF_QUEUED:
	case VIDEOBUF_ACTIVE:
286 287
		b->flags |= V4L2_BUF_FLAG_QUEUED;
		break;
288 289
	case VIDEOBUF_DONE:
	case VIDEOBUF_ERROR:
290 291
		b->flags |= V4L2_BUF_FLAG_DONE;
		break;
292 293
	case VIDEOBUF_NEEDS_INIT:
	case VIDEOBUF_IDLE:
294 295 296 297 298 299 300 301 302 303 304 305 306 307 308
		/* nothing */
		break;
	}

	if (vb->input != UNSET) {
		b->flags |= V4L2_BUF_FLAG_INPUT;
		b->input  = vb->input;
	}

	b->field     = vb->field;
	b->timestamp = vb->ts;
	b->bytesused = vb->size;
	b->sequence  = vb->field_count >> 1;
}

309
/* Locking: Caller holds q->vb_lock */
310 311 312 313 314 315 316
static int __videobuf_mmap_free(struct videobuf_queue *q)
{
	int i;

	if (!q)
		return 0;

317
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
318

319 320 321
	for (i = 0; i < VIDEO_MAX_FRAME; i++)
		if (q->bufs[i] && q->bufs[i]->map)
			return -EBUSY;
322

323 324 325
	for (i = 0; i < VIDEO_MAX_FRAME; i++) {
		if (NULL == q->bufs[i])
			continue;
326
		q->ops->buf_release(q, q->bufs[i]);
327 328 329 330
		kfree(q->bufs[i]);
		q->bufs[i] = NULL;
	}

331
	return 0;
332 333 334 335 336
}

int videobuf_mmap_free(struct videobuf_queue *q)
{
	int ret;
337
	mutex_lock(&q->vb_lock);
338
	ret = __videobuf_mmap_free(q);
339
	mutex_unlock(&q->vb_lock);
340 341
	return ret;
}
342
EXPORT_SYMBOL_GPL(videobuf_mmap_free);
343

344
/* Locking: Caller holds q->vb_lock */
345
int __videobuf_mmap_setup(struct videobuf_queue *q,
346 347 348 349 350 351
			unsigned int bcount, unsigned int bsize,
			enum v4l2_memory memory)
{
	unsigned int i;
	int err;

352
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
353 354 355 356 357 358 359 360 361

	err = __videobuf_mmap_free(q);
	if (0 != err)
		return err;

	/* Allocate and initialize buffers */
	for (i = 0; i < bcount; i++) {
		q->bufs[i] = videobuf_alloc(q);

362
		if (NULL == q->bufs[i])
363 364 365 366 367 368 369 370
			break;

		q->bufs[i]->i      = i;
		q->bufs[i]->input  = UNSET;
		q->bufs[i]->memory = memory;
		q->bufs[i]->bsize  = bsize;
		switch (memory) {
		case V4L2_MEMORY_MMAP:
371
			q->bufs[i]->boff = PAGE_ALIGN(bsize) * i;
372 373 374 375 376 377 378 379 380 381 382
			break;
		case V4L2_MEMORY_USERPTR:
		case V4L2_MEMORY_OVERLAY:
			/* nothing */
			break;
		}
	}

	if (!i)
		return -ENOMEM;

383
	dprintk(1, "mmap setup: %d buffers, %d bytes each\n", i, bsize);
384 385 386

	return i;
}
387
EXPORT_SYMBOL_GPL(__videobuf_mmap_setup);
388 389 390 391 392 393

int videobuf_mmap_setup(struct videobuf_queue *q,
			unsigned int bcount, unsigned int bsize,
			enum v4l2_memory memory)
{
	int ret;
394
	mutex_lock(&q->vb_lock);
395
	ret = __videobuf_mmap_setup(q, bcount, bsize, memory);
396
	mutex_unlock(&q->vb_lock);
397 398
	return ret;
}
399
EXPORT_SYMBOL_GPL(videobuf_mmap_setup);
400

401 402 403
int videobuf_reqbufs(struct videobuf_queue *q,
		 struct v4l2_requestbuffers *req)
{
404
	unsigned int size, count;
405 406 407
	int retval;

	if (req->count < 1) {
408
		dprintk(1, "reqbufs: count invalid (%d)\n", req->count);
409 410
		return -EINVAL;
	}
411

412 413 414
	if (req->memory != V4L2_MEMORY_MMAP     &&
	    req->memory != V4L2_MEMORY_USERPTR  &&
	    req->memory != V4L2_MEMORY_OVERLAY) {
415
		dprintk(1, "reqbufs: memory type invalid\n");
416 417 418
		return -EINVAL;
	}

419
	mutex_lock(&q->vb_lock);
420
	if (req->type != q->type) {
421
		dprintk(1, "reqbufs: queue type invalid\n");
422 423 424 425
		retval = -EINVAL;
		goto done;
	}

426
	if (q->streaming) {
427
		dprintk(1, "reqbufs: streaming already exists\n");
428 429
		retval = -EBUSY;
		goto done;
430 431
	}
	if (!list_empty(&q->stream)) {
432
		dprintk(1, "reqbufs: stream running\n");
433 434
		retval = -EBUSY;
		goto done;
435 436 437 438 439 440
	}

	count = req->count;
	if (count > VIDEO_MAX_FRAME)
		count = VIDEO_MAX_FRAME;
	size = 0;
441
	q->ops->buf_setup(q, &count, &size);
442 443
	dprintk(1, "reqbufs: bufs=%d, size=0x%x [%u pages total]\n",
		count, size,
444
		(unsigned int)((count * PAGE_ALIGN(size)) >> PAGE_SHIFT));
445

446
	retval = __videobuf_mmap_setup(q, count, size, req->memory);
447
	if (retval < 0) {
448
		dprintk(1, "reqbufs: mmap setup returned %d\n", retval);
449 450 451
		goto done;
	}

452
	req->count = retval;
453
	retval = 0;
454 455

 done:
456
	mutex_unlock(&q->vb_lock);
457 458
	return retval;
}
459
EXPORT_SYMBOL_GPL(videobuf_reqbufs);
460 461 462

int videobuf_querybuf(struct videobuf_queue *q, struct v4l2_buffer *b)
{
463 464
	int ret = -EINVAL;

465
	mutex_lock(&q->vb_lock);
466
	if (unlikely(b->type != q->type)) {
467
		dprintk(1, "querybuf: Wrong type.\n");
468
		goto done;
469
	}
470
	if (unlikely(b->index >= VIDEO_MAX_FRAME)) {
471
		dprintk(1, "querybuf: index out of range.\n");
472
		goto done;
473 474
	}
	if (unlikely(NULL == q->bufs[b->index])) {
475
		dprintk(1, "querybuf: buffer is null.\n");
476
		goto done;
477
	}
478

479
	videobuf_status(q, b, q->bufs[b->index], q->type);
480 481 482

	ret = 0;
done:
483
	mutex_unlock(&q->vb_lock);
484
	return ret;
485
}
486
EXPORT_SYMBOL_GPL(videobuf_querybuf);
487

488
int videobuf_qbuf(struct videobuf_queue *q, struct v4l2_buffer *b)
489 490 491
{
	struct videobuf_buffer *buf;
	enum v4l2_field field;
492
	unsigned long flags = 0;
493 494
	int retval;

495
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
496

497 498 499
	if (b->memory == V4L2_MEMORY_MMAP)
		down_read(&current->mm->mmap_sem);

500
	mutex_lock(&q->vb_lock);
501 502
	retval = -EBUSY;
	if (q->reading) {
503
		dprintk(1, "qbuf: Reading running...\n");
504 505 506 507
		goto done;
	}
	retval = -EINVAL;
	if (b->type != q->type) {
508
		dprintk(1, "qbuf: Wrong type.\n");
509 510
		goto done;
	}
511
	if (b->index >= VIDEO_MAX_FRAME) {
512
		dprintk(1, "qbuf: index out of range.\n");
513 514 515 516
		goto done;
	}
	buf = q->bufs[b->index];
	if (NULL == buf) {
517
		dprintk(1, "qbuf: buffer is null.\n");
518 519
		goto done;
	}
520
	MAGIC_CHECK(buf->magic, MAGIC_BUFFER);
521
	if (buf->memory != b->memory) {
522
		dprintk(1, "qbuf: memory type is wrong.\n");
523 524
		goto done;
	}
525
	if (buf->state != VIDEOBUF_NEEDS_INIT && buf->state != VIDEOBUF_IDLE) {
526
		dprintk(1, "qbuf: buffer is already queued or active.\n");
527 528 529 530 531
		goto done;
	}

	if (b->flags & V4L2_BUF_FLAG_INPUT) {
		if (b->input >= q->inputs) {
532
			dprintk(1, "qbuf: wrong input.\n");
533 534 535 536 537 538 539 540 541 542
			goto done;
		}
		buf->input = b->input;
	} else {
		buf->input = UNSET;
	}

	switch (b->memory) {
	case V4L2_MEMORY_MMAP:
		if (0 == buf->baddr) {
543 544
			dprintk(1, "qbuf: mmap requested "
				   "but buffer addr is zero!\n");
545 546 547 548 549
			goto done;
		}
		break;
	case V4L2_MEMORY_USERPTR:
		if (b->length < buf->bsize) {
550
			dprintk(1, "qbuf: buffer length is not enough\n");
551 552
			goto done;
		}
553 554 555
		if (VIDEOBUF_NEEDS_INIT != buf->state &&
		    buf->baddr != b->m.userptr)
			q->ops->buf_release(q, buf);
556 557 558 559 560 561
		buf->baddr = b->m.userptr;
		break;
	case V4L2_MEMORY_OVERLAY:
		buf->boff = b->m.offset;
		break;
	default:
562
		dprintk(1, "qbuf: wrong memory type\n");
563 564 565
		goto done;
	}

566
	dprintk(1, "qbuf: requesting next field\n");
567
	field = videobuf_next_field(q);
568
	retval = q->ops->buf_prepare(q, buf, field);
569
	if (0 != retval) {
570
		dprintk(1, "qbuf: buffer_prepare returned %d\n", retval);
571 572 573
		goto done;
	}

574
	list_add_tail(&buf->stream, &q->stream);
575
	if (q->streaming) {
576
		spin_lock_irqsave(q->irqlock, flags);
577
		q->ops->buf_queue(q, buf);
578
		spin_unlock_irqrestore(q->irqlock, flags);
579
	}
580
	dprintk(1, "qbuf: succeeded\n");
581
	retval = 0;
582
	wake_up_interruptible_sync(&q->wait);
583

584
done:
585
	mutex_unlock(&q->vb_lock);
586 587 588 589

	if (b->memory == V4L2_MEMORY_MMAP)
		up_read(&current->mm->mmap_sem);

590 591
	return retval;
}
592
EXPORT_SYMBOL_GPL(videobuf_qbuf);
593 594 595

/* Locking: Caller holds q->vb_lock */
static int stream_next_buffer_check_queue(struct videobuf_queue *q, int noblock)
596 597 598
{
	int retval;

599 600 601 602
checks:
	if (!q->streaming) {
		dprintk(1, "next_buffer: Not streaming\n");
		retval = -EINVAL;
603 604
		goto done;
	}
605

606
	if (list_empty(&q->stream)) {
607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628
		if (noblock) {
			retval = -EAGAIN;
			dprintk(2, "next_buffer: no buffers to dequeue\n");
			goto done;
		} else {
			dprintk(2, "next_buffer: waiting on buffer\n");

			/* Drop lock to avoid deadlock with qbuf */
			mutex_unlock(&q->vb_lock);

			/* Checking list_empty and streaming is safe without
			 * locks because we goto checks to validate while
			 * holding locks before proceeding */
			retval = wait_event_interruptible(q->wait,
				!list_empty(&q->stream) || !q->streaming);
			mutex_lock(&q->vb_lock);

			if (retval)
				goto done;

			goto checks;
		}
629
	}
630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647

	retval = 0;

done:
	return retval;
}

/* Locking: Caller holds q->vb_lock */
static int stream_next_buffer(struct videobuf_queue *q,
			struct videobuf_buffer **vb, int nonblocking)
{
	int retval;
	struct videobuf_buffer *buf = NULL;

	retval = stream_next_buffer_check_queue(q, nonblocking);
	if (retval)
		goto done;

648 649
	buf = list_entry(q->stream.next, struct videobuf_buffer, stream);
	retval = videobuf_waiton(buf, nonblocking, 1);
650 651 652 653 654 655 656 657 658
	if (retval < 0)
		goto done;

	*vb = buf;
done:
	return retval;
}

int videobuf_dqbuf(struct videobuf_queue *q,
659
		   struct v4l2_buffer *b, int nonblocking)
660 661 662 663 664 665
{
	struct videobuf_buffer *buf = NULL;
	int retval;

	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);

666
	mutex_lock(&q->vb_lock);
667 668

	retval = stream_next_buffer(q, &buf, nonblocking);
669
	if (retval < 0) {
670
		dprintk(1, "dqbuf: next_buffer error: %i\n", retval);
671 672
		goto done;
	}
673

674
	switch (buf->state) {
675
	case VIDEOBUF_ERROR:
676
		dprintk(1, "dqbuf: state is error\n");
677
		retval = -EIO;
678
		CALL(q, sync, q, buf);
679
		buf->state = VIDEOBUF_IDLE;
680
		break;
681
	case VIDEOBUF_DONE:
682 683
		dprintk(1, "dqbuf: state is done\n");
		CALL(q, sync, q, buf);
684
		buf->state = VIDEOBUF_IDLE;
685 686
		break;
	default:
687
		dprintk(1, "dqbuf: state invalid\n");
688 689 690 691
		retval = -EINVAL;
		goto done;
	}
	list_del(&buf->stream);
692 693
	memset(b, 0, sizeof(*b));
	videobuf_status(q, b, buf, q->type);
694
done:
695
	mutex_unlock(&q->vb_lock);
696 697
	return retval;
}
698
EXPORT_SYMBOL_GPL(videobuf_dqbuf);
699 700 701 702

int videobuf_streamon(struct videobuf_queue *q)
{
	struct videobuf_buffer *buf;
703
	unsigned long flags = 0;
704 705
	int retval;

706
	mutex_lock(&q->vb_lock);
707 708 709 710 711 712 713
	retval = -EBUSY;
	if (q->reading)
		goto done;
	retval = 0;
	if (q->streaming)
		goto done;
	q->streaming = 1;
714
	spin_lock_irqsave(q->irqlock, flags);
715
	list_for_each_entry(buf, &q->stream, stream)
716
		if (buf->state == VIDEOBUF_PREPARED)
717
			q->ops->buf_queue(q, buf);
718
	spin_unlock_irqrestore(q->irqlock, flags);
719

720
	wake_up_interruptible_sync(&q->wait);
721
done:
722
	mutex_unlock(&q->vb_lock);
723 724
	return retval;
}
725
EXPORT_SYMBOL_GPL(videobuf_streamon);
726

727
/* Locking: Caller holds q->vb_lock */
728
static int __videobuf_streamoff(struct videobuf_queue *q)
729 730
{
	if (!q->streaming)
731 732
		return -EINVAL;

733 734
	videobuf_queue_cancel(q);

735 736 737 738 739 740 741
	return 0;
}

int videobuf_streamoff(struct videobuf_queue *q)
{
	int retval;

742
	mutex_lock(&q->vb_lock);
743
	retval = __videobuf_streamoff(q);
744
	mutex_unlock(&q->vb_lock);
745

746 747
	return retval;
}
748
EXPORT_SYMBOL_GPL(videobuf_streamoff);
749

750
/* Locking: Caller holds q->vb_lock */
751 752 753 754 755
static ssize_t videobuf_read_zerocopy(struct videobuf_queue *q,
				      char __user *data,
				      size_t count, loff_t *ppos)
{
	enum v4l2_field field;
756
	unsigned long flags = 0;
757 758
	int retval;

759
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
760 761 762 763 764 765 766 767 768 769 770

	/* setup stuff */
	q->read_buf = videobuf_alloc(q);
	if (NULL == q->read_buf)
		return -ENOMEM;

	q->read_buf->memory = V4L2_MEMORY_USERPTR;
	q->read_buf->baddr  = (unsigned long)data;
	q->read_buf->bsize  = count;

	field = videobuf_next_field(q);
771
	retval = q->ops->buf_prepare(q, q->read_buf, field);
772 773 774 775
	if (0 != retval)
		goto done;

	/* start capture & wait */
776
	spin_lock_irqsave(q->irqlock, flags);
777
	q->ops->buf_queue(q, q->read_buf);
778
	spin_unlock_irqrestore(q->irqlock, flags);
779
	retval = videobuf_waiton(q->read_buf, 0, 0);
780
	if (0 == retval) {
781
		CALL(q, sync, q, q->read_buf);
782
		if (VIDEOBUF_ERROR == q->read_buf->state)
783 784 785 786 787
			retval = -EIO;
		else
			retval = q->read_buf->size;
	}

788
done:
789
	/* cleanup */
790
	q->ops->buf_release(q, q->read_buf);
791 792 793 794 795
	kfree(q->read_buf);
	q->read_buf = NULL;
	return retval;
}

796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838
static int __videobuf_copy_to_user(struct videobuf_queue *q,
				   struct videobuf_buffer *buf,
				   char __user *data, size_t count,
				   int nonblocking)
{
	void *vaddr = CALL(q, vaddr, buf);

	/* copy to userspace */
	if (count > buf->size - q->read_off)
		count = buf->size - q->read_off;

	if (copy_to_user(data, vaddr + q->read_off, count))
		return -EFAULT;

	return count;
}

static int __videobuf_copy_stream(struct videobuf_queue *q,
				  struct videobuf_buffer *buf,
				  char __user *data, size_t count, size_t pos,
				  int vbihack, int nonblocking)
{
	unsigned int *fc = CALL(q, vaddr, buf);

	if (vbihack) {
		/* dirty, undocumented hack -- pass the frame counter
			* within the last four bytes of each vbi data block.
			* We need that one to maintain backward compatibility
			* to all vbi decoding software out there ... */
		fc += (buf->size >> 2) - 1;
		*fc = buf->field_count >> 1;
		dprintk(1, "vbihack: %d\n", *fc);
	}

	/* copy stuff using the common method */
	count = __videobuf_copy_to_user(q, buf, data, count, nonblocking);

	if ((count == -EFAULT) && (pos == 0))
		return -EFAULT;

	return count;
}

839 840 841 842 843
ssize_t videobuf_read_one(struct videobuf_queue *q,
			  char __user *data, size_t count, loff_t *ppos,
			  int nonblocking)
{
	enum v4l2_field field;
844
	unsigned long flags = 0;
845
	unsigned size = 0, nbufs = 1;
846 847
	int retval;

848
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
849

850
	mutex_lock(&q->vb_lock);
851

852
	q->ops->buf_setup(q, &nbufs, &size);
853 854 855 856

	if (NULL == q->read_buf  &&
	    count >= size        &&
	    !nonblocking) {
857
		retval = videobuf_read_zerocopy(q, data, count, ppos);
858 859 860 861 862 863 864 865 866 867 868
		if (retval >= 0  ||  retval == -EIO)
			/* ok, all done */
			goto done;
		/* fallback to kernel bounce buffer on failures */
	}

	if (NULL == q->read_buf) {
		/* need to capture a new frame */
		retval = -ENOMEM;
		q->read_buf = videobuf_alloc(q);

869
		dprintk(1, "video alloc=0x%p\n", q->read_buf);
870 871 872 873 874
		if (NULL == q->read_buf)
			goto done;
		q->read_buf->memory = V4L2_MEMORY_USERPTR;
		q->read_buf->bsize = count; /* preferred size */
		field = videobuf_next_field(q);
875
		retval = q->ops->buf_prepare(q, q->read_buf, field);
876 877

		if (0 != retval) {
878
			kfree(q->read_buf);
879 880 881 882
			q->read_buf = NULL;
			goto done;
		}

883
		spin_lock_irqsave(q->irqlock, flags);
884
		q->ops->buf_queue(q, q->read_buf);
885 886
		spin_unlock_irqrestore(q->irqlock, flags);

887 888 889 890 891 892 893 894
		q->read_off = 0;
	}

	/* wait until capture is done */
	retval = videobuf_waiton(q->read_buf, nonblocking, 1);
	if (0 != retval)
		goto done;

895
	CALL(q, sync, q, q->read_buf);
896

897
	if (VIDEOBUF_ERROR == q->read_buf->state) {
898
		/* catch I/O errors */
899
		q->ops->buf_release(q, q->read_buf);
900 901 902 903 904 905 906
		kfree(q->read_buf);
		q->read_buf = NULL;
		retval = -EIO;
		goto done;
	}

	/* Copy to userspace */
907
	retval = __videobuf_copy_to_user(q, q->read_buf, data, count, nonblocking);
908
	if (retval < 0)
909 910 911 912 913
		goto done;

	q->read_off += retval;
	if (q->read_off == q->read_buf->size) {
		/* all data copied, cleanup */
914
		q->ops->buf_release(q, q->read_buf);
915 916 917 918
		kfree(q->read_buf);
		q->read_buf = NULL;
	}

919
done:
920
	mutex_unlock(&q->vb_lock);
921 922
	return retval;
}
923
EXPORT_SYMBOL_GPL(videobuf_read_one);
924

925
/* Locking: Caller holds q->vb_lock */
926
static int __videobuf_read_start(struct videobuf_queue *q)
927 928
{
	enum v4l2_field field;
929
	unsigned long flags = 0;
930
	unsigned int count = 0, size = 0;
931 932
	int err, i;

933
	q->ops->buf_setup(q, &count, &size);
934 935 936 937 938 939
	if (count < 2)
		count = 2;
	if (count > VIDEO_MAX_FRAME)
		count = VIDEO_MAX_FRAME;
	size = PAGE_ALIGN(size);

940
	err = __videobuf_mmap_setup(q, count, size, V4L2_MEMORY_USERPTR);
941
	if (err < 0)
942 943
		return err;

944 945
	count = err;

946 947
	for (i = 0; i < count; i++) {
		field = videobuf_next_field(q);
948
		err = q->ops->buf_prepare(q, q->bufs[i], field);
949 950 951 952
		if (err)
			return err;
		list_add_tail(&q->bufs[i]->stream, &q->stream);
	}
953
	spin_lock_irqsave(q->irqlock, flags);
954
	for (i = 0; i < count; i++)
955
		q->ops->buf_queue(q, q->bufs[i]);
956
	spin_unlock_irqrestore(q->irqlock, flags);
957 958 959 960
	q->reading = 1;
	return 0;
}

961
static void __videobuf_read_stop(struct videobuf_queue *q)
962 963 964 965
{
	int i;

	videobuf_queue_cancel(q);
966
	__videobuf_mmap_free(q);
967 968 969 970 971 972 973 974
	INIT_LIST_HEAD(&q->stream);
	for (i = 0; i < VIDEO_MAX_FRAME; i++) {
		if (NULL == q->bufs[i])
			continue;
		kfree(q->bufs[i]);
		q->bufs[i] = NULL;
	}
	q->read_buf = NULL;
975 976
}

977 978 979 980
int videobuf_read_start(struct videobuf_queue *q)
{
	int rc;

981
	mutex_lock(&q->vb_lock);
982
	rc = __videobuf_read_start(q);
983
	mutex_unlock(&q->vb_lock);
984 985 986

	return rc;
}
987
EXPORT_SYMBOL_GPL(videobuf_read_start);
988

989 990
void videobuf_read_stop(struct videobuf_queue *q)
{
991
	mutex_lock(&q->vb_lock);
992
	__videobuf_read_stop(q);
993
	mutex_unlock(&q->vb_lock);
994
}
995
EXPORT_SYMBOL_GPL(videobuf_read_stop);
996 997 998

void videobuf_stop(struct videobuf_queue *q)
{
999
	mutex_lock(&q->vb_lock);
1000 1001 1002 1003 1004 1005 1006

	if (q->streaming)
		__videobuf_streamoff(q);

	if (q->reading)
		__videobuf_read_stop(q);

1007
	mutex_unlock(&q->vb_lock);
1008
}
1009
EXPORT_SYMBOL_GPL(videobuf_stop);
1010

1011 1012 1013 1014 1015
ssize_t videobuf_read_stream(struct videobuf_queue *q,
			     char __user *data, size_t count, loff_t *ppos,
			     int vbihack, int nonblocking)
{
	int rc, retval;
1016
	unsigned long flags = 0;
1017

1018
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
1019

1020
	dprintk(2, "%s\n", __func__);
1021
	mutex_lock(&q->vb_lock);
1022 1023 1024 1025
	retval = -EBUSY;
	if (q->streaming)
		goto done;
	if (!q->reading) {
1026
		retval = __videobuf_read_start(q);
1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047
		if (retval < 0)
			goto done;
	}

	retval = 0;
	while (count > 0) {
		/* get / wait for data */
		if (NULL == q->read_buf) {
			q->read_buf = list_entry(q->stream.next,
						 struct videobuf_buffer,
						 stream);
			list_del(&q->read_buf->stream);
			q->read_off = 0;
		}
		rc = videobuf_waiton(q->read_buf, nonblocking, 1);
		if (rc < 0) {
			if (0 == retval)
				retval = rc;
			break;
		}

1048
		if (q->read_buf->state == VIDEOBUF_DONE) {
1049
			rc = __videobuf_copy_stream(q, q->read_buf, data + retval, count,
1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068
					retval, vbihack, nonblocking);
			if (rc < 0) {
				retval = rc;
				break;
			}
			retval      += rc;
			count       -= rc;
			q->read_off += rc;
		} else {
			/* some error */
			q->read_off = q->read_buf->size;
			if (0 == retval)
				retval = -EIO;
		}

		/* requeue buffer when done with copying */
		if (q->read_off == q->read_buf->size) {
			list_add_tail(&q->read_buf->stream,
				      &q->stream);
1069
			spin_lock_irqsave(q->irqlock, flags);
1070
			q->ops->buf_queue(q, q->read_buf);
1071
			spin_unlock_irqrestore(q->irqlock, flags);
1072 1073 1074 1075 1076 1077
			q->read_buf = NULL;
		}
		if (retval < 0)
			break;
	}

1078
done:
1079
	mutex_unlock(&q->vb_lock);
1080 1081
	return retval;
}
1082
EXPORT_SYMBOL_GPL(videobuf_read_stream);
1083 1084 1085 1086 1087 1088 1089 1090

unsigned int videobuf_poll_stream(struct file *file,
				  struct videobuf_queue *q,
				  poll_table *wait)
{
	struct videobuf_buffer *buf = NULL;
	unsigned int rc = 0;

1091
	mutex_lock(&q->vb_lock);
1092 1093 1094 1095 1096 1097
	if (q->streaming) {
		if (!list_empty(&q->stream))
			buf = list_entry(q->stream.next,
					 struct videobuf_buffer, stream);
	} else {
		if (!q->reading)
1098
			__videobuf_read_start(q);
1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114
		if (!q->reading) {
			rc = POLLERR;
		} else if (NULL == q->read_buf) {
			q->read_buf = list_entry(q->stream.next,
						 struct videobuf_buffer,
						 stream);
			list_del(&q->read_buf->stream);
			q->read_off = 0;
		}
		buf = q->read_buf;
	}
	if (!buf)
		rc = POLLERR;

	if (0 == rc) {
		poll_wait(file, &buf->done, wait);
1115 1116
		if (buf->state == VIDEOBUF_DONE ||
		    buf->state == VIDEOBUF_ERROR)
1117 1118
			rc = POLLIN|POLLRDNORM;
	}
1119
	mutex_unlock(&q->vb_lock);
1120 1121
	return rc;
}
1122
EXPORT_SYMBOL_GPL(videobuf_poll_stream);
1123

1124
int videobuf_mmap_mapper(struct videobuf_queue *q, struct vm_area_struct *vma)
1125 1126 1127
{
	int retval;

1128
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
1129

1130
	mutex_lock(&q->vb_lock);
1131
	retval = CALL(q, mmap_mapper, q, vma);
1132
	mutex_unlock(&q->vb_lock);
1133 1134 1135

	return retval;
}
1136
EXPORT_SYMBOL_GPL(videobuf_mmap_mapper);
1137 1138 1139 1140 1141 1142

#ifdef CONFIG_VIDEO_V4L1_COMPAT
int videobuf_cgmbuf(struct videobuf_queue *q,
		    struct video_mbuf *mbuf, int count)
{
	struct v4l2_requestbuffers req;
1143
	int rc, i;
1144

1145
	MAGIC_CHECK(q->int_ops->magic, MAGIC_QTYPE_OPS);
1146

1147
	memset(&req, 0, sizeof(req));
1148 1149 1150
	req.type   = q->type;
	req.count  = count;
	req.memory = V4L2_MEMORY_MMAP;
1151
	rc = videobuf_reqbufs(q, &req);
1152 1153 1154 1155 1156 1157 1158
	if (rc < 0)
		return rc;

	mbuf->frames = req.count;
	mbuf->size   = 0;
	for (i = 0; i < mbuf->frames; i++) {
		mbuf->offsets[i]  = q->bufs[i]->boff;
1159
		mbuf->size       += PAGE_ALIGN(q->bufs[i]->bsize);
1160 1161 1162 1163
	}

	return 0;
}
1164
EXPORT_SYMBOL_GPL(videobuf_cgmbuf);
1165 1166
#endif