1V4L2-COMPLIANCE(1)               User Commands              V4L2-COMPLIANCE(1)
2
3
4

NAME

6       v4l2-compliance - An application to test video4linux drivers
7

SYNOPSIS

9       v4l2-compliance  [-h]  [-d  <dev>] [-r <dev>] [-V <dev>] [-S <dev>] [-e
10       <dev>]        [-s        <count>]         [-f]         [-a]         [-c
11       color=<color>,skip=<skip>,perc=<perc>] [-n] [-T] [-v] [-w]
12

DESCRIPTION

14       The  v4l2-compliance  tool  is used to test video4linux devices, either
15       video, vbi, radio or swradio, both input and  output.  It  attempts  to
16       test  almost all aspects of a V4L2 device and it covers almost all V4L2
17       ioctls. It has very good support for video capture and output, VBI cap‐
18       ture and output and (software) radio tuning and transmitting.
19
20       The support for memory-to-memory devices is limited at the moment.
21
22       If  you  have  questions  about  v4l2-compliance then mail those to the
23       linux-media@vger.kernel.org mailinglist.
24
25       When testing a driver always compile the utility from the latest source
26       code  from  the  git  repository  (http://git.linuxtv.org/cgit.cgi/v4l-
27       utils.git/). The version supplied by linux distributions is almost cer‐
28       tainly too old.
29
30       In  addition,  if  a test fails then it will output the source and line
31       where the failure occurred, so you often need access to the source code
32       to see what that test is all about.
33
34       Note  that  v4l2-compliance  not  only tests for compliance against the
35       V4L2 API, but also whether the driver is using all the  correct  frame‐
36       works.  These  frameworks  often  automatically provide ioctls that are
37       strictly speaking optional, but that come for free  if  you  use  those
38       frameworks.  By  requiring  their  presence the v4l2-compliance utility
39       will enforce their use.
40
41       If you want to submit a new V4L2 driver, then that driver must pass the
42       v4l2-compliance tests without fails. The best method of using this tool
43       to test your driver is to first test without any streaming options  and
44       fix any failures from the first reported failure to the last. Sometimes
45       earlier failures can generate later failures, so just start fixing them
46       in order and test again after each fix.
47
48       Next  test  your  driver  with  the -s option to do the basic streaming
49       tests. This requires that there is a valid input or output.
50
51       Whenever you run v4l2-compliance it will save the current driver  state
52       and restore it after all tests are done (including when you press Ctrl-
53       C). All the streaming tests are performed using  the  saved  configura‐
54       tion. This makes it possible to prepare for the streaming tests by con‐
55       figuring the device before calling v4l2-compliance.
56
57       Finally you should test your driver using the -f and -c options to ver‐
58       ify  that  all video pixel formats are correctly supported. You need to
59       perform all three streaming tests for all inputs and outputs.  You  can
60       use  the  -a option to automate that if that is possible for your hard‐
61       ware.
62
63       If your driver passes all tests, then your can be confident  that  your
64       driver is in very good shape!
65

OPTIONS

67       -d, --device <dev>
68              Use device <dev> as the video device. If <dev> is a number, then
69              /dev/video<dev> is used.
70
71       -V, --vbi-device <dev>
72              Use device <dev> as the vbi device. If <dev> is a  number,  then
73              /dev/vbi<dev> is used.
74
75       -r, --radio-device <dev>
76              Use device <dev> as the radio device. If <dev> is a number, then
77              /dev/radio<dev> is used.
78
79       -S, --sdr-device <dev>
80              Use device <dev> as the SDR device. If <dev> is a  number,  then
81              /dev/swradio<dev> is used.
82
83       -t, --touch-device <dev>
84              Use device <dev> as the touch device. If <dev> is a number, then
85              /dev/v4l-touch<dev> is used.
86
87       -u, --subdev-device <dev>
88              Use device <dev> as the v4l-subdevX device. If <dev> is  a  num‐
89              ber, then /dev/v4l-subdev<dev> is used.
90
91       -m, --media-device <dev>
92              Use  device  <dev>  as the media controller device. Besides this
93              device it also tests all interfaces it finds.  If  <dev>  starts
94              with a digit, then /dev/media<dev> is used.
95
96       -M, --media-device-only <dev>
97              Use  device <dev> as the media controller device. Only test this
98              device, don't walk over all the  interfaces.   If  <dev>  starts
99              with a digit, then /dev/media<dev> is used.
100
101       -e, --exp-buf-device <dev>
102              Use  device  <dev> as the video device used to export DMABUFfers
103              for doing DMABUF streaming tests. If <dev>  is  a  number,  then
104              /dev/video<dev>  is  used. If this option is not specified, then
105              the DMABUF streaming tests will be skipped.
106
107       -s, --streaming <count>
108              Enable the streaming tests. Set <count> to the number of  frames
109              to  stream (default 60).  This requires that before v4l2-compli‐
110              ance is called the device has been configured with a valid input
111              (or  output)  and  frequency  (when the device has a tuner). For
112              DMABUF testing --expbuf-device needs to be set as well.
113
114              The configuration of the driver at the time v4l2-compliance  was
115              called will be used for the streaming tests.
116
117       -f, --stream-all-formats
118              Test  whether  all  available  formats  can  be  streamed.  This
119              attempts to stream using MMAP mode or read/write  (if  V4L2_MEM‐
120              ORY_MMAP  is  not  available) for one second for all formats, at
121              all sizes, at all intervals and with all field values. In  addi‐
122              tion,  if  the driver supports scaling, cropping or composing it
123              will test that as well in various combinations.  If  the  driver
124              supports  a  lot  of combinations then this test can take a long
125              time.
126
127              The configuration of the driver at the time v4l2-compliance  was
128              called will be used for the streaming tests.
129
130       -c, --stream-all-color color=red|green|blue,skip=<skip>,perc=<perc>
131              For  all  supported,  non-compressed  formats  stream <skip + 1>
132              frames. For the last frame go  over  all  pixels  and  calculate
133              which  of  the  R,  G  and B color components of a pixel has the
134              highest value and count that as a red, green or blue pixel.  The
135              test  succeeds  if  at  least  perc percent of the frame has the
136              given color.  This requires that a valid and predominantly  red,
137              green  or  blue video signal is present on the input(s). If skip
138              is not specified, then just capture the first frame. A  non-zero
139              skip  value is useful if it takes a few frames for the device to
140              calibrate. If perc is not specified, then this defaults to 90%.
141
142              Most signal generators are able to generate pure  red,  blue  or
143              green  video.  For cameras you can print a completely red, green
144              or blue picture and hold it before the camera.
145
146              The goal of this test is to determine if all pixel formats  will
147              interpret  the  red, green and blue colors correctly and that no
148              color components are swapped.
149
150              The configuration of the driver at the time v4l2-compliance  was
151              called will be used for the streaming tests.
152
153       -a, --stream-all-io
154              Do  the  -s, -c and -f streaming tests for all inputs or outputs
155              instead of just the current input or output. This requires  that
156              a  valid  video signal is present on all inputs or that all out‐
157              puts are hooked up.
158
159       -E, --exit-on-fail
160              Exit this application when the first failure occurs  instead  of
161              continuing with a possible inconsistent state.
162
163       -n, --no-warnings
164              Turn  off  warning  messages. They are still counted in the sum‐
165              mary, but you won't see them.
166
167       -T, --trace
168              Trace all called ioctls.
169
170       -v, --verbose
171              Turn on verbose reporting.
172
173       -w, --wrapper
174              Use the libv4l2 wrapper library for all  V4L2  device  accesses.
175              Note  that  doing this will cause some tests to fail because the
176              libv4l2 library isn't fully V4L2 compliant. By default v4l2-com‐
177              pliance   will  bypass  libv4l2  and  access  the  V4L2  devices
178              directly.
179
180       -W, --exit-on-warn
181              Exit this application when the first warning occurs  instead  of
182              continuing.
183
184       -h, --help
185              Prints the help message.
186

EXIT STATUS

188       On success, it returns 0. Otherwise, it will return the error code.
189

BUGS

191       This  is  a work in progress, and every so often it turns out that some
192       tests done by v4l2-compliance are too strict or  plain  wrong.  If  you
193       suspect  that  might  be  the case, then report such bugs to the linux-
194       media@vger.kernel.org mailinglist.
195
196
197
198v4l-utils 1.16.3                  March 2015                V4L2-COMPLIANCE(1)
Impressum