summaryrefslogtreecommitdiff
path: root/v4l2-apps/test/capture_example.c
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@infradead.org>2008-07-11 13:42:25 -0300
committerMauro Carvalho Chehab <mchehab@infradead.org>2008-07-11 13:42:25 -0300
commit754f080bdf7412769906262dfad451a6f90f2077 (patch)
tree87e18e95a553b04c8836df604bf99edb5eaaa274 /v4l2-apps/test/capture_example.c
parentb884d16928248c316903c9b1f1483a3586228f65 (diff)
downloadmediapointer-dvb-s2-754f080bdf7412769906262dfad451a6f90f2077.tar.gz
mediapointer-dvb-s2-754f080bdf7412769906262dfad451a6f90f2077.tar.bz2
Adds the possibility of writing captured stream into a file
From: Mauro Carvalho Chehab <mchehab@infradead.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'v4l2-apps/test/capture_example.c')
-rw-r--r--v4l2-apps/test/capture_example.c26
1 files changed, 19 insertions, 7 deletions
diff --git a/v4l2-apps/test/capture_example.c b/v4l2-apps/test/capture_example.c
index fda252b61..bbb0c4e57 100644
--- a/v4l2-apps/test/capture_example.c
+++ b/v4l2-apps/test/capture_example.c
@@ -45,6 +45,7 @@ static io_method io = IO_METHOD_MMAP;
static int fd = -1;
struct buffer * buffers = NULL;
static unsigned int n_buffers = 0;
+static int out_buf = 0;
static void
errno_exit (const char * s)
@@ -69,9 +70,14 @@ xioctl (int fd,
}
static void
-process_image (const void * p)
+process_image (const void * p,
+ int size)
{
- fputc ('.', stdout);
+ if (!out_buf)
+ fputc ('.', stdout);
+ else
+ fwrite (p, size, 1, stdout);
+
fflush (stdout);
}
@@ -98,7 +104,7 @@ read_frame (void)
}
}
- process_image (buffers[0].start);
+ process_image (buffers[0].start, buffers[0].length);
break;
@@ -125,7 +131,7 @@ read_frame (void)
assert (buf.index < n_buffers);
- process_image (buffers[buf.index].start);
+ process_image (buffers[buf.index].start, buffers[buf.index].length);
if (-1 == xioctl (fd, VIDIOC_QBUF, &buf))
errno_exit ("VIDIOC_QBUF");
@@ -160,7 +166,7 @@ read_frame (void)
assert (i < n_buffers);
- process_image ((void *) buf.m.userptr);
+ process_image ((void *) buf.m.userptr, buf.length);
if (-1 == xioctl (fd, VIDIOC_QBUF, &buf))
errno_exit ("VIDIOC_QBUF");
@@ -176,7 +182,7 @@ mainloop (void)
{
unsigned int count;
- count = 100;
+ count = 1000;
while (count-- > 0) {
for (;;) {
@@ -589,11 +595,12 @@ usage (FILE * fp,
"-m | --mmap Use memory mapped buffers\n"
"-r | --read Use read() calls\n"
"-u | --userp Use application allocated buffers\n"
+ "-o | --output Outputs stream to stdout\n"
"",
argv[0]);
}
-static const char short_options [] = "d:hmru";
+static const char short_options [] = "d:hmruo";
static const struct option
long_options [] = {
@@ -602,6 +609,7 @@ long_options [] = {
{ "mmap", no_argument, NULL, 'm' },
{ "read", no_argument, NULL, 'r' },
{ "userp", no_argument, NULL, 'u' },
+ { "output", no_argument, NULL, 'o' },
{ 0, 0, 0, 0 }
};
@@ -646,6 +654,10 @@ main (int argc,
io = IO_METHOD_USERPTR;
break;
+ case 'o':
+ out_buf++;
+ break;
+
default:
usage (stderr, argc, argv);
exit (EXIT_FAILURE);