2014-11-03 21:27:40 +01:00
/*
* Copyright ( c ) 2014 Philippe De Muyter < phdm @ macqel . be >
* Copyright ( c ) 2014 William Manley < will @ williammanley . net >
* Copyright ( c ) 2011 Peter Zotov < whitequark @ whitequark . org >
2017-05-22 19:14:52 +02:00
* Copyright ( c ) 2014 - 2017 The strace developers .
2014-11-03 21:27:40 +01:00
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
* 2. Redistributions in binary form must reproduce the above copyright
* notice , this list of conditions and the following disclaimer in the
* documentation and / or other materials provided with the distribution .
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission .
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ` ` AS IS ' ' AND ANY EXPRESS OR
* IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED .
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT , INDIRECT ,
* INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT
* NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*/
# include "defs.h"
2016-05-03 22:30:41 +00:00
# include DEF_MPERS_TYPE(struct_v4l2_buffer)
2017-04-14 02:39:03 +03:00
# include DEF_MPERS_TYPE(struct_v4l2_clip)
2016-05-03 22:30:41 +00:00
# include DEF_MPERS_TYPE(struct_v4l2_create_buffers)
# include DEF_MPERS_TYPE(struct_v4l2_ext_control)
# include DEF_MPERS_TYPE(struct_v4l2_ext_controls)
# include DEF_MPERS_TYPE(struct_v4l2_format)
# include DEF_MPERS_TYPE(struct_v4l2_framebuffer)
# include DEF_MPERS_TYPE(struct_v4l2_input)
# include DEF_MPERS_TYPE(struct_v4l2_standard)
2014-11-03 21:27:40 +01:00
# include <stdint.h>
2016-05-13 20:15:12 +00:00
# include <linux/ioctl.h>
2015-02-22 02:13:04 +00:00
# include <linux/types.h>
2014-11-03 21:27:40 +01:00
# include <linux/videodev2.h>
2016-05-01 17:25:24 +00:00
2016-05-03 22:30:41 +00:00
typedef struct v4l2_buffer struct_v4l2_buffer ;
2017-04-14 02:39:03 +03:00
typedef struct v4l2_clip struct_v4l2_clip ;
2016-05-03 22:30:41 +00:00
typedef struct v4l2_create_buffers struct_v4l2_create_buffers ;
typedef struct v4l2_ext_control struct_v4l2_ext_control ;
typedef struct v4l2_ext_controls struct_v4l2_ext_controls ;
typedef struct v4l2_format struct_v4l2_format ;
typedef struct v4l2_framebuffer struct_v4l2_framebuffer ;
typedef struct v4l2_input struct_v4l2_input ;
typedef struct v4l2_standard struct_v4l2_standard ;
# include MPERS_DEFS
2017-07-11 00:20:54 +00:00
# include "print_fields.h"
2014-11-03 21:27:40 +01:00
/* some historical constants */
# ifndef V4L2_CID_HCENTER
# define V4L2_CID_HCENTER (V4L2_CID_BASE+22)
# endif
# ifndef V4L2_CID_VCENTER
# define V4L2_CID_VCENTER (V4L2_CID_BASE+23)
# endif
# ifndef V4L2_CID_BAND_STOP_FILTER
# define V4L2_CID_BAND_STOP_FILTER (V4L2_CID_BASE+33)
# endif
# define FMT_FRACT "%u / %u"
# define ARGS_FRACT(x) ((x).numerator), ((x).denominator)
2016-05-01 17:25:24 +00:00
# define FMT_RECT "{left=%d, top=%d, width=%u, height=%u}"
2014-11-03 21:27:40 +01:00
# define ARGS_RECT(x) (x).left, (x).top, (x).width, (x).height
2016-05-01 17:25:24 +00:00
static void
print_pixelformat ( uint32_t fourcc )
2014-11-03 21:27:40 +01:00
{
2016-05-01 17:25:24 +00:00
const union {
2015-01-25 00:27:00 +00:00
uint32_t pixelformat ;
unsigned char cc [ sizeof ( uint32_t ) ] ;
2016-05-13 03:51:43 +00:00
} u = {
# if WORDS_BIGENDIAN
. cc = {
( unsigned char ) ( fourcc > > 24 ) ,
( unsigned char ) ( fourcc > > 16 ) ,
( unsigned char ) ( fourcc > > 8 ) ,
( unsigned char ) fourcc
}
# else
. pixelformat = fourcc
# endif
} ;
2015-01-25 00:27:00 +00:00
unsigned int i ;
tprints ( " v4l2_fourcc( " ) ;
for ( i = 0 ; i < sizeof ( u . cc ) ; + + i ) {
2016-05-01 17:25:24 +00:00
unsigned char c = u . cc [ i ] ;
2015-01-25 00:27:00 +00:00
if ( i )
tprints ( " , " ) ;
2016-05-01 17:25:24 +00:00
if ( c = = ' \' ' | | c = = ' \\ ' ) {
char sym [ ] = {
' \' ' ,
' \\ ' ,
c ,
' \' ' ,
' \0 '
} ;
tprints ( sym ) ;
} else if ( c > = ' ' & & c < = 0x7e ) {
2015-01-25 00:27:00 +00:00
char sym [ ] = {
' \' ' ,
2016-05-01 17:25:24 +00:00
c ,
' \' ' ,
' \0 '
2015-01-25 00:27:00 +00:00
} ;
tprints ( sym ) ;
} else {
char hex [ ] = {
' \' ' ,
' \\ ' ,
' x ' ,
" 0123456789abcdef " [ c > > 4 ] ,
" 0123456789abcdef " [ c & 0xf ] ,
' \' ' ,
' \0 '
} ;
tprints ( hex ) ;
}
}
tprints ( " ) " ) ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
# include "xlat/v4l2_device_capabilities_flags.h"
static int
2016-12-26 10:26:03 +00:00
print_v4l2_capability ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
struct v4l2_capability caps ;
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & caps ) )
return 1 ;
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " { " , caps , driver ) ;
PRINT_FIELD_CSTRING ( " , " , caps , card ) ;
PRINT_FIELD_CSTRING ( " , " , caps , bus_info ) ;
2016-05-01 17:25:24 +00:00
tprintf ( " , version=%u.%u.%u, capabilities= " ,
( caps . version > > 16 ) & 0xFF ,
( caps . version > > 8 ) & 0xFF ,
caps . version & 0xFF ) ;
printflags ( v4l2_device_capabilities_flags , caps . capabilities ,
" V4L2_CAP_??? " ) ;
# ifdef V4L2_CAP_DEVICE_CAPS
tprints ( " , device_caps= " ) ;
printflags ( v4l2_device_capabilities_flags , caps . device_caps ,
" V4L2_CAP_??? " ) ;
# endif
tprints ( " } " ) ;
return 1 ;
}
# include "xlat/v4l2_buf_types.h"
# include "xlat/v4l2_format_description_flags.h"
static int
2016-12-26 10:26:03 +00:00
print_v4l2_fmtdesc ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
struct v4l2_fmtdesc f ;
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & f ) )
return RVAL_DECODED | 1 ;
tprintf ( " {index=%u, type= " , f . index ) ;
printxval ( v4l2_buf_types , f . type , " V4L2_BUF_TYPE_??? " ) ;
return 0 ;
}
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & f ) ) {
tprints ( " , flags= " ) ;
printflags ( v4l2_format_description_flags , f . flags ,
" V4L2_FMT_FLAG_??? " ) ;
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " , " , f , description ) ;
2016-05-01 17:25:24 +00:00
tprints ( " , pixelformat= " ) ;
print_pixelformat ( f . pixelformat ) ;
}
tprints ( " } " ) ;
return 1 ;
}
# include "xlat/v4l2_fields.h"
# include "xlat/v4l2_colorspaces.h"
2017-04-14 02:39:03 +03:00
# include "xlat/v4l2_vbi_flags.h"
# include "xlat/v4l2_sliced_flags.h"
2016-05-01 17:25:24 +00:00
2017-04-14 02:39:03 +03:00
static bool
2017-06-17 22:23:09 +00:00
print_v4l2_clip ( struct tcb * tcp , void * elem_buf , size_t elem_size , void * data )
2017-04-14 02:39:03 +03:00
{
const struct_v4l2_clip * p = elem_buf ;
tprintf ( FMT_RECT , ARGS_RECT ( p - > c ) ) ;
return true ;
}
static bool
print_v4l2_format_fmt ( struct tcb * const tcp , const char * prefix ,
const struct_v4l2_format * f )
2014-11-03 21:27:40 +01:00
{
2017-04-14 02:39:03 +03:00
bool ret = true ;
2014-11-03 21:27:40 +01:00
switch ( f - > type ) {
case V4L2_BUF_TYPE_VIDEO_CAPTURE :
2016-05-01 17:25:24 +00:00
case V4L2_BUF_TYPE_VIDEO_OUTPUT :
tprints ( prefix ) ;
tprintf ( " fmt.pix={width=%u, height=%u, pixelformat= " ,
f - > fmt . pix . width , f - > fmt . pix . height ) ;
print_pixelformat ( f - > fmt . pix . pixelformat ) ;
2014-11-03 21:27:40 +01:00
tprints ( " , field= " ) ;
2016-05-01 17:25:24 +00:00
printxval ( v4l2_fields , f - > fmt . pix . field , " V4L2_FIELD_??? " ) ;
2014-11-03 21:27:40 +01:00
tprintf ( " , bytesperline=%u, sizeimage=%u, colorspace= " ,
2016-05-01 17:25:24 +00:00
f - > fmt . pix . bytesperline , f - > fmt . pix . sizeimage ) ;
printxval ( v4l2_colorspaces , f - > fmt . pix . colorspace ,
2014-11-03 21:27:40 +01:00
" V4L2_COLORSPACE_??? " ) ;
tprints ( " } " ) ;
break ;
# if HAVE_DECL_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE
case V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE :
case V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE : {
unsigned int i , max ;
2016-05-01 17:25:24 +00:00
tprints ( prefix ) ;
tprintf ( " fmt.pix_mp={width=%u, height=%u, pixelformat= " ,
f - > fmt . pix_mp . width , f - > fmt . pix_mp . height ) ;
print_pixelformat ( f - > fmt . pix_mp . pixelformat ) ;
2014-11-03 21:27:40 +01:00
tprints ( " , field= " ) ;
2016-05-01 17:25:24 +00:00
printxval ( v4l2_fields , f - > fmt . pix_mp . field , " V4L2_FIELD_??? " ) ;
2014-11-03 21:27:40 +01:00
tprints ( " , colorspace= " ) ;
2016-05-01 17:25:24 +00:00
printxval ( v4l2_colorspaces , f - > fmt . pix_mp . colorspace ,
2014-11-03 21:27:40 +01:00
" V4L2_COLORSPACE_??? " ) ;
2016-05-01 17:25:24 +00:00
tprints ( " , plane_fmt=[ " ) ;
max = f - > fmt . pix_mp . num_planes ;
2014-11-03 21:27:40 +01:00
if ( max > VIDEO_MAX_PLANES )
max = VIDEO_MAX_PLANES ;
for ( i = 0 ; i < max ; i + + ) {
if ( i > 0 )
tprints ( " , " ) ;
tprintf ( " {sizeimage=%u, bytesperline=%u} " ,
2016-05-01 17:25:24 +00:00
f - > fmt . pix_mp . plane_fmt [ i ] . sizeimage ,
f - > fmt . pix_mp . plane_fmt [ i ] . bytesperline ) ;
2014-11-03 21:27:40 +01:00
}
2017-04-14 02:39:03 +03:00
tprintf ( " ], num_planes=%u} " ,
( unsigned ) f - > fmt . pix_mp . num_planes ) ;
2014-11-03 21:27:40 +01:00
break ;
}
# endif
2017-04-14 02:39:03 +03:00
/* OUTPUT_OVERLAY since Linux v2.6.22-rc1~1118^2~179 */
2015-01-09 04:53:19 +00:00
# if HAVE_DECL_V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY
2014-11-03 21:27:40 +01:00
case V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY :
2015-01-09 04:53:19 +00:00
# endif
2017-04-14 02:39:03 +03:00
case V4L2_BUF_TYPE_VIDEO_OVERLAY : {
struct_v4l2_clip clip ;
2016-05-01 17:25:24 +00:00
tprints ( prefix ) ;
2017-04-14 02:39:03 +03:00
tprintf ( " fmt.win={left=%d, top=%d, width=%u, height=%u, field= " ,
ARGS_RECT ( f - > fmt . win . w ) ) ;
printxval ( v4l2_fields , f - > fmt . win . field , " V4L2_FIELD_??? " ) ;
tprintf ( " , chromakey=%#x, clips= " , f - > fmt . win . chromakey ) ;
ret = print_array ( tcp , ptr_to_kulong ( f - > fmt . win . clips ) ,
f - > fmt . win . clipcount , & clip , sizeof ( clip ) ,
umoven_or_printaddr , print_v4l2_clip , 0 ) ;
tprintf ( " , clipcount=%u, bitmap= " , f - > fmt . win . clipcount ) ;
printaddr ( ptr_to_kulong ( f - > fmt . win . bitmap ) ) ;
2017-06-13 21:00:04 +00:00
# ifdef HAVE_STRUCT_V4L2_WINDOW_GLOBAL_ALPHA
2017-04-14 02:39:03 +03:00
tprintf ( " , global_alpha=%#x " , f - > fmt . win . global_alpha ) ;
# endif
tprints ( " } " ) ;
2014-11-03 21:27:40 +01:00
break ;
2017-04-14 02:39:03 +03:00
}
2014-11-03 21:27:40 +01:00
case V4L2_BUF_TYPE_VBI_CAPTURE :
case V4L2_BUF_TYPE_VBI_OUTPUT :
2016-05-01 17:25:24 +00:00
tprints ( prefix ) ;
2017-04-14 02:39:03 +03:00
tprintf ( " fmt.vbi={sampling_rate=%u, offset=%u, "
" samples_per_line=%u, sample_format= " ,
f - > fmt . vbi . sampling_rate , f - > fmt . vbi . offset ,
f - > fmt . vbi . samples_per_line ) ;
print_pixelformat ( f - > fmt . vbi . sample_format ) ;
tprintf ( " , start=[%u, %u], count=[%u, %u], " ,
f - > fmt . vbi . start [ 0 ] , f - > fmt . vbi . start [ 1 ] ,
f - > fmt . vbi . count [ 0 ] , f - > fmt . vbi . count [ 1 ] ) ;
tprints ( " flags= " ) ;
printxval ( v4l2_vbi_flags , f - > fmt . vbi . flags , " V4L2_VBI_??? " ) ;
tprints ( " } " ) ;
2014-11-03 21:27:40 +01:00
break ;
2017-04-14 02:39:03 +03:00
/* both since Linux v2.6.14-rc2~64 */
# if HAVE_DECL_V4L2_BUF_TYPE_SLICED_VBI_CAPTURE
2014-11-03 21:27:40 +01:00
case V4L2_BUF_TYPE_SLICED_VBI_CAPTURE :
2017-04-14 02:39:03 +03:00
case V4L2_BUF_TYPE_SLICED_VBI_OUTPUT : {
unsigned int i , j ;
2016-05-01 17:25:24 +00:00
tprints ( prefix ) ;
2017-04-14 02:39:03 +03:00
tprints ( " fmt.sliced={service_set= " ) ;
printxval ( v4l2_sliced_flags , f - > fmt . sliced . service_set ,
" V4L2_SLICED_??? " ) ;
tprintf ( " , io_size=%u, service_lines=[ " ,
f - > fmt . sliced . io_size ) ;
for ( i = 0 ; i < ARRAY_SIZE ( f - > fmt . sliced . service_lines ) ; i + + ) {
if ( i > 0 )
tprints ( " , " ) ;
tprints ( " [ " ) ;
for ( j = 0 ;
j < ARRAY_SIZE ( f - > fmt . sliced . service_lines [ 0 ] ) ;
j + + ) {
if ( j > 0 )
tprints ( " , " ) ;
tprintf ( " %#x " ,
f - > fmt . sliced . service_lines [ i ] [ j ] ) ;
}
tprints ( " ] " ) ;
}
tprints ( " ]} " ) ;
2014-11-03 21:27:40 +01:00
break ;
2017-04-14 02:39:03 +03:00
}
# endif
/* since Linux v4.4-rc1~118^2~14 */
# if HAVE_DECL_V4L2_BUF_TYPE_SDR_OUTPUT
case V4L2_BUF_TYPE_SDR_OUTPUT :
# endif
/* since Linux v3.15-rc1~85^2~213 */
2016-05-01 17:25:24 +00:00
# if HAVE_DECL_V4L2_BUF_TYPE_SDR_CAPTURE
case V4L2_BUF_TYPE_SDR_CAPTURE :
tprints ( prefix ) ;
2017-04-14 02:39:03 +03:00
tprints ( " fmt.sdr={pixelformat= " ) ;
print_pixelformat ( f - > fmt . sdr . pixelformat ) ;
2017-06-13 21:00:04 +00:00
# ifdef HAVE_STRUCT_V4L2_SDR_FORMAT_BUFFERSIZE
2017-04-14 02:39:03 +03:00
tprintf ( " , buffersize=%u " ,
f - > fmt . sdr . buffersize ) ;
2016-05-01 17:25:24 +00:00
# endif
2017-04-14 02:39:03 +03:00
tprints ( " } " ) ;
break ;
2016-05-01 17:25:24 +00:00
# endif
2014-11-03 21:27:40 +01:00
}
2017-04-14 02:39:03 +03:00
return ret ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
static int
2016-12-26 10:26:03 +00:00
print_v4l2_format ( struct tcb * const tcp , const kernel_ulong_t arg ,
v4l2: change type of ioctl 3rd argument from long to kernel_ureg_t
* v4l2.c (print_v4l2_capability, print_v4l2_fmtdesc, print_v4l2_format,
print_v4l2_requestbuffers, print_v4l2_buffer, print_v4l2_framebuffer,
print_v4l2_buf_type, print_v4l2_streamparm, print_v4l2_standard,
print_v4l2_input, print_v4l2_control, print_v4l2_queryctrl,
print_v4l2_cropcap, print_v4l2_crop, print_v4l2_ext_controls,
print_v4l2_frmsizeenum, print_v4l2_frmivalenum,
print_v4l2_create_buffers, v4l2_ioctl): Change arg type from long
to kernel_ureg_t.
2016-12-21 01:22:18 +00:00
const bool is_get )
2014-11-03 21:27:40 +01:00
{
2016-05-03 22:30:41 +00:00
struct_v4l2_format f ;
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & f ) )
return RVAL_DECODED | 1 ;
tprints ( " {type= " ) ;
printxval ( v4l2_buf_types , f . type , " V4L2_BUF_TYPE_??? " ) ;
if ( is_get )
return 0 ;
2017-04-14 02:39:03 +03:00
if ( ! print_v4l2_format_fmt ( tcp , " , " , & f ) ) {
tprints ( " } " ) ;
return RVAL_DECODED | 1 ;
}
2016-05-01 17:25:24 +00:00
} else {
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & f ) ) {
const char * delim = is_get ? " , " : " => " ;
2017-04-14 02:39:03 +03:00
print_v4l2_format_fmt ( tcp , delim , & f ) ;
2016-05-01 17:25:24 +00:00
}
tprints ( " } " ) ;
}
return 1 ;
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
# include "xlat/v4l2_memories.h"
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
static int
2016-12-26 10:26:03 +00:00
print_v4l2_requestbuffers ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
struct v4l2_requestbuffers reqbufs ;
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & reqbufs ) )
return RVAL_DECODED | 1 ;
tprintf ( " {count=%u, type= " , reqbufs . count ) ;
printxval ( v4l2_buf_types , reqbufs . type , " V4L2_BUF_TYPE_??? " ) ;
tprints ( " , memory= " ) ;
printxval ( v4l2_memories , reqbufs . memory , " V4L2_MEMORY_??? " ) ;
2014-11-03 21:27:40 +01:00
tprints ( " } " ) ;
2016-05-01 17:25:24 +00:00
return 0 ;
} else {
static char outstr [ sizeof ( " {count=} " ) + sizeof ( int ) * 3 ] ;
if ( syserror ( tcp ) | | umove ( tcp , arg , & reqbufs ) < 0 )
return 1 ;
sprintf ( outstr , " {count=%u} " , reqbufs . count ) ;
tcp - > auxstr = outstr ;
return 1 + RVAL_STR ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
# include "xlat/v4l2_buf_flags.h"
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
static int
v4l2: change type of ioctl 3rd argument from long to kernel_ureg_t
* v4l2.c (print_v4l2_capability, print_v4l2_fmtdesc, print_v4l2_format,
print_v4l2_requestbuffers, print_v4l2_buffer, print_v4l2_framebuffer,
print_v4l2_buf_type, print_v4l2_streamparm, print_v4l2_standard,
print_v4l2_input, print_v4l2_control, print_v4l2_queryctrl,
print_v4l2_cropcap, print_v4l2_crop, print_v4l2_ext_controls,
print_v4l2_frmsizeenum, print_v4l2_frmivalenum,
print_v4l2_create_buffers, v4l2_ioctl): Change arg type from long
to kernel_ureg_t.
2016-12-21 01:22:18 +00:00
print_v4l2_buffer ( struct tcb * const tcp , const unsigned int code ,
2016-12-26 10:26:03 +00:00
const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
2016-05-03 22:30:41 +00:00
struct_v4l2_buffer b ;
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & b ) )
return RVAL_DECODED | 1 ;
tprints ( " {type= " ) ;
printxval ( v4l2_buf_types , b . type , " V4L2_BUF_TYPE_??? " ) ;
if ( code ! = VIDIOC_DQBUF )
tprintf ( " , index=%u " , b . index ) ;
} else {
if ( ! syserror ( tcp ) & & umove ( tcp , arg , & b ) = = 0 ) {
if ( code = = VIDIOC_DQBUF )
tprintf ( " , index=%u " , b . index ) ;
tprints ( " , memory= " ) ;
printxval ( v4l2_memories , b . memory , " V4L2_MEMORY_??? " ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( b . memory = = V4L2_MEMORY_MMAP ) {
tprintf ( " , m.offset=%#x " , b . m . offset ) ;
} else if ( b . memory = = V4L2_MEMORY_USERPTR ) {
2016-06-11 01:28:21 +00:00
tprints ( " , m.userptr= " ) ;
2016-12-25 02:14:49 +00:00
printaddr ( b . m . userptr ) ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
tprintf ( " , length=%u, bytesused=%u, flags= " ,
b . length , b . bytesused ) ;
printflags ( v4l2_buf_flags , b . flags , " V4L2_BUF_FLAG_??? " ) ;
2016-11-28 04:07:37 +00:00
if ( code = = VIDIOC_DQBUF ) {
tprints ( " , timestamp = " ) ;
MPERS_FUNC_NAME ( print_struct_timeval ) ( & b . timestamp ) ;
}
2016-05-01 17:25:24 +00:00
tprints ( " , ... " ) ;
2014-11-03 21:27:40 +01:00
}
tprints ( " } " ) ;
}
2016-05-01 17:25:24 +00:00
return 1 ;
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
static int
2016-12-26 10:26:03 +00:00
print_v4l2_framebuffer ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
2016-05-03 22:30:41 +00:00
struct_v4l2_framebuffer b ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
tprints ( " , " ) ;
if ( ! umove_or_printaddr ( tcp , arg , & b ) ) {
2016-06-11 01:28:21 +00:00
tprintf ( " {capability=%#x, flags=%#x, base= " ,
b . capability , b . flags ) ;
2016-12-26 01:37:21 +00:00
printaddr ( ptr_to_kulong ( b . base ) ) ;
2016-06-11 01:28:21 +00:00
tprints ( " } " ) ;
2016-05-01 17:25:24 +00:00
}
return RVAL_DECODED | 1 ;
}
static int
2016-12-26 10:26:03 +00:00
print_v4l2_buf_type ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
int type ;
tprints ( " , " ) ;
if ( ! umove_or_printaddr ( tcp , arg , & type ) ) {
tprints ( " [ " ) ;
printxval ( v4l2_buf_types , type , " V4L2_BUF_TYPE_??? " ) ;
tprints ( " ] " ) ;
}
return RVAL_DECODED | 1 ;
}
# include "xlat/v4l2_streaming_capabilities.h"
# include "xlat/v4l2_capture_modes.h"
static int
2016-12-26 10:26:03 +00:00
print_v4l2_streamparm ( struct tcb * const tcp , const kernel_ulong_t arg ,
v4l2: change type of ioctl 3rd argument from long to kernel_ureg_t
* v4l2.c (print_v4l2_capability, print_v4l2_fmtdesc, print_v4l2_format,
print_v4l2_requestbuffers, print_v4l2_buffer, print_v4l2_framebuffer,
print_v4l2_buf_type, print_v4l2_streamparm, print_v4l2_standard,
print_v4l2_input, print_v4l2_control, print_v4l2_queryctrl,
print_v4l2_cropcap, print_v4l2_crop, print_v4l2_ext_controls,
print_v4l2_frmsizeenum, print_v4l2_frmivalenum,
print_v4l2_create_buffers, v4l2_ioctl): Change arg type from long
to kernel_ureg_t.
2016-12-21 01:22:18 +00:00
const bool is_get )
2016-05-01 17:25:24 +00:00
{
struct v4l2_streamparm s ;
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & s ) )
return RVAL_DECODED | 1 ;
tprints ( " {type= " ) ;
printxval ( v4l2_buf_types , s . type , " V4L2_BUF_TYPE_??? " ) ;
switch ( s . type ) {
case V4L2_BUF_TYPE_VIDEO_CAPTURE :
case V4L2_BUF_TYPE_VIDEO_OUTPUT :
if ( is_get )
return 0 ;
tprints ( " , " ) ;
break ;
default :
tprints ( " } " ) ;
return RVAL_DECODED | 1 ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
} else {
if ( syserror ( tcp ) | | umove ( tcp , arg , & s ) < 0 ) {
2014-11-03 21:27:40 +01:00
tprints ( " } " ) ;
2016-05-01 17:25:24 +00:00
return 1 ;
}
tprints ( is_get ? " , " : " => " ) ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
if ( s . type = = V4L2_BUF_TYPE_VIDEO_CAPTURE ) {
tprints ( " parm.capture={capability= " ) ;
printflags ( v4l2_streaming_capabilities ,
s . parm . capture . capability , " V4L2_CAP_??? " ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
tprints ( " , capturemode= " ) ;
printflags ( v4l2_capture_modes ,
s . parm . capture . capturemode , " V4L2_MODE_??? " ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
tprintf ( " , timeperframe= " FMT_FRACT ,
ARGS_FRACT ( s . parm . capture . timeperframe ) ) ;
tprintf ( " , extendedmode=%u, readbuffers=%u} " ,
s . parm . capture . extendedmode ,
s . parm . capture . readbuffers ) ;
} else {
tprints ( " parm.output={capability= " ) ;
printflags ( v4l2_streaming_capabilities ,
s . parm . output . capability , " V4L2_CAP_??? " ) ;
tprintf ( " , outputmode=%u " , s . parm . output . outputmode ) ;
tprintf ( " , timeperframe= " FMT_FRACT ,
ARGS_FRACT ( s . parm . output . timeperframe ) ) ;
tprintf ( " , extendedmode=%u, writebuffers=%u} " ,
s . parm . output . extendedmode ,
s . parm . output . writebuffers ) ;
}
if ( exiting ( tcp ) )
tprints ( " } " ) ;
return 1 ;
}
static int
2016-12-26 10:26:03 +00:00
print_v4l2_standard ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
2016-05-03 22:30:41 +00:00
struct_v4l2_standard s ;
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & s ) )
return RVAL_DECODED | 1 ;
tprintf ( " {index=%u " , s . index ) ;
} else {
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & s ) ) {
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " , " , s , name ) ;
2016-05-01 17:25:24 +00:00
tprintf ( " , frameperiod= " FMT_FRACT ,
ARGS_FRACT ( s . frameperiod ) ) ;
tprintf ( " , framelines=%d " , s . framelines ) ;
2014-11-03 21:27:40 +01:00
}
tprints ( " } " ) ;
}
2016-05-01 17:25:24 +00:00
return 1 ;
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
# include "xlat/v4l2_input_types.h"
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
static int
2016-12-26 10:26:03 +00:00
print_v4l2_input ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
2016-05-03 22:30:41 +00:00
struct_v4l2_input i ;
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & i ) )
return RVAL_DECODED | 1 ;
tprintf ( " {index=%u " , i . index ) ;
} else {
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & i ) ) {
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " , " , i , name ) ;
2016-05-01 17:25:24 +00:00
tprints ( " , type= " ) ;
printxval ( v4l2_input_types , i . type ,
" V4L2_INPUT_TYPE_??? " ) ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
tprints ( " } " ) ;
}
return 1 ;
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
# include "xlat/v4l2_control_ids.h"
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
static int
2016-12-26 10:26:03 +00:00
print_v4l2_control ( struct tcb * const tcp , const kernel_ulong_t arg ,
v4l2: change type of ioctl 3rd argument from long to kernel_ureg_t
* v4l2.c (print_v4l2_capability, print_v4l2_fmtdesc, print_v4l2_format,
print_v4l2_requestbuffers, print_v4l2_buffer, print_v4l2_framebuffer,
print_v4l2_buf_type, print_v4l2_streamparm, print_v4l2_standard,
print_v4l2_input, print_v4l2_control, print_v4l2_queryctrl,
print_v4l2_cropcap, print_v4l2_crop, print_v4l2_ext_controls,
print_v4l2_frmsizeenum, print_v4l2_frmivalenum,
print_v4l2_create_buffers, v4l2_ioctl): Change arg type from long
to kernel_ureg_t.
2016-12-21 01:22:18 +00:00
const bool is_get )
2016-05-01 17:25:24 +00:00
{
struct v4l2_control c ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & c ) )
return RVAL_DECODED | 1 ;
tprints ( " {id= " ) ;
printxval ( v4l2_control_ids , c . id , " V4L2_CID_??? " ) ;
if ( ! is_get )
tprintf ( " , value=%d " , c . value ) ;
return 0 ;
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & c ) ) {
tprints ( is_get ? " , " : " => " ) ;
tprintf ( " value=%d " , c . value ) ;
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
tprints ( " } " ) ;
return 1 ;
}
v4l2: Add decoding for VIDIOC_G/S_TUNER's arg
* v4l2.c: Include "xlat/v4l2_tuner_types.h", "xlat/v4l2_tuner_capabilities.h",
"xlat/v4l2_tuner_rxsubchanses.h", and "xlat/v4l2_tuner_audmodes.h".
(print_v4l2_tuner): New function. Add decoding for VIDIOC_G/S_TUNER's arg.
(v4l2_ioctl): Add new cases for decoding VIDIOC_G/S_TUNER's arg.
* xlat/v4l2_tuner_types.in: Add V4L2_TUNER_RADIO and
V4L2_TUNER_ANALOG_TV introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_DIGITAL_TV introduced by linux kernel
commit v2.6.11-rc4~55^2~20.
Add V4L2_TUNER_ADC and V4L2_TUNER_RF introduced by linux kernel commit
v3.15-rc1~85^2~215.
Add V4L2_TUNER_SDR introduced by linux kernel commit v4.4-rc1~118^2~17
(as the replacement of V4L2_TUNER_ADC).
* xlat/v4l2_tuner_capabilities.in: Add V4L2_TUNER_CAP_LOW,
V4L2_TUNER_CAP_NORM, V4L2_TUNER_CAP_STEREO, V4L2_TUNER_CAP_LANG2,
V4L2_TUNER_CAP_SAP, and V4L2_TUNER_CAP_LANG1 introduced by linux kernel
commit 2.5.46~39^2~23^2~4.
Add V4L2_TUNER_CAP_HWSEEK_BOUNDED and V4L2_TUNER_CAP_HWSEEK_WRAP
introduced by linux kernel commit v3.6-rc1~28^2~306.
Add V4L2_TUNER_CAP_RDS introduced by linux commit v2.6.32-rc1~679^2~189.
Add V4L2_TUNER_CAP_RDS_BLOCK_IO and V4L2_TUNER_CAP_RDS_CONTROLS
introduced by linux kernel commit v2.6.37-rc1~64^2~110.
Add V4L2_TUNER_CAP_FREQ_BANDS introduced by linux kernel commit
v3.6-rc1~28^2~46.
Add V4L2_TUNER_CAP_HWSEEK_PROG_LIM introduced by linux kernel commit
v3.6-rc1~28^2~40.
Add V4L2_TUNER_CAP_1HZ introduced by linux kernel commit
v3.15-rc1~85^2~214.
* xlat/v4l2_tuner_audmodes.in: Add V4L2_TUNER_MODE_MONO,
V4L2_TUNER_MODE_STEREO, V4L2_TUNER_MODE_LANG2, V4L2_TUNER_MODE_SAP, and
V4L2_TUNER_MODE_LANG1 introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_MODE_LANG1_LANG2 introduced by linux kernel commit
v2.6.17-rc1~739^2~9.
* xlat/v4l2_tuner_rxsubchanses.in: Add V4L2_TUNER_SUB_MONO,
V4L2_TUNER_SUB_STEREO, V4L2_TUNER_SUB_LANG2, V4L2_TUNER_SUB_SAP, and
V4L2_TUNER_SUB_LANG1 introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_SUB_RDS introduced by linux kernel commit
v2.6.32-rc1~679^2~189.
Signed-off-by: Edgar Kaziahmedov <edos@linux.com>
2017-04-23 04:53:47 +03:00
# include "xlat/v4l2_tuner_types.h"
# include "xlat/v4l2_tuner_capabilities.h"
# include "xlat/v4l2_tuner_rxsubchanses.h"
# include "xlat/v4l2_tuner_audmodes.h"
static int
print_v4l2_tuner ( struct tcb * const tcp , const kernel_ulong_t arg ,
const bool is_get )
{
struct v4l2_tuner c ;
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & c ) )
return RVAL_DECODED | 1 ;
tprintf ( " {index=%u " , c . index ) ;
if ( is_get )
return 0 ;
tprints ( " , " ) ;
} else {
if ( syserror ( tcp ) | | umove ( tcp , arg , & c ) < 0 ) {
tprints ( " } " ) ;
return 1 ;
}
tprints ( is_get ? " , " : " => " ) ;
}
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " " , c , name ) ;
v4l2: Add decoding for VIDIOC_G/S_TUNER's arg
* v4l2.c: Include "xlat/v4l2_tuner_types.h", "xlat/v4l2_tuner_capabilities.h",
"xlat/v4l2_tuner_rxsubchanses.h", and "xlat/v4l2_tuner_audmodes.h".
(print_v4l2_tuner): New function. Add decoding for VIDIOC_G/S_TUNER's arg.
(v4l2_ioctl): Add new cases for decoding VIDIOC_G/S_TUNER's arg.
* xlat/v4l2_tuner_types.in: Add V4L2_TUNER_RADIO and
V4L2_TUNER_ANALOG_TV introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_DIGITAL_TV introduced by linux kernel
commit v2.6.11-rc4~55^2~20.
Add V4L2_TUNER_ADC and V4L2_TUNER_RF introduced by linux kernel commit
v3.15-rc1~85^2~215.
Add V4L2_TUNER_SDR introduced by linux kernel commit v4.4-rc1~118^2~17
(as the replacement of V4L2_TUNER_ADC).
* xlat/v4l2_tuner_capabilities.in: Add V4L2_TUNER_CAP_LOW,
V4L2_TUNER_CAP_NORM, V4L2_TUNER_CAP_STEREO, V4L2_TUNER_CAP_LANG2,
V4L2_TUNER_CAP_SAP, and V4L2_TUNER_CAP_LANG1 introduced by linux kernel
commit 2.5.46~39^2~23^2~4.
Add V4L2_TUNER_CAP_HWSEEK_BOUNDED and V4L2_TUNER_CAP_HWSEEK_WRAP
introduced by linux kernel commit v3.6-rc1~28^2~306.
Add V4L2_TUNER_CAP_RDS introduced by linux commit v2.6.32-rc1~679^2~189.
Add V4L2_TUNER_CAP_RDS_BLOCK_IO and V4L2_TUNER_CAP_RDS_CONTROLS
introduced by linux kernel commit v2.6.37-rc1~64^2~110.
Add V4L2_TUNER_CAP_FREQ_BANDS introduced by linux kernel commit
v3.6-rc1~28^2~46.
Add V4L2_TUNER_CAP_HWSEEK_PROG_LIM introduced by linux kernel commit
v3.6-rc1~28^2~40.
Add V4L2_TUNER_CAP_1HZ introduced by linux kernel commit
v3.15-rc1~85^2~214.
* xlat/v4l2_tuner_audmodes.in: Add V4L2_TUNER_MODE_MONO,
V4L2_TUNER_MODE_STEREO, V4L2_TUNER_MODE_LANG2, V4L2_TUNER_MODE_SAP, and
V4L2_TUNER_MODE_LANG1 introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_MODE_LANG1_LANG2 introduced by linux kernel commit
v2.6.17-rc1~739^2~9.
* xlat/v4l2_tuner_rxsubchanses.in: Add V4L2_TUNER_SUB_MONO,
V4L2_TUNER_SUB_STEREO, V4L2_TUNER_SUB_LANG2, V4L2_TUNER_SUB_SAP, and
V4L2_TUNER_SUB_LANG1 introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_SUB_RDS introduced by linux kernel commit
v2.6.32-rc1~679^2~189.
Signed-off-by: Edgar Kaziahmedov <edos@linux.com>
2017-04-23 04:53:47 +03:00
tprints ( " , type= " ) ;
printxval ( v4l2_tuner_types , c . type , " V4L2_TUNER_TYPE_??? " ) ;
tprints ( " , capability= " ) ;
printxval ( v4l2_tuner_capabilities , c . capability ,
" V4L2_TUNER_CAP_??? " ) ;
tprintf ( " , rangelow=%u, rangehigh=%u, rxsubchans= " ,
c . rangelow , c . rangehigh ) ;
printxval ( v4l2_tuner_rxsubchanses , c . rxsubchans ,
" V4L2_TUNER_SUB_??? " ) ;
tprints ( " , audmode= " ) ;
printxval ( v4l2_tuner_audmodes , c . audmode ,
" V4L2_TUNER_MODE_??? " ) ;
tprintf ( " , signal=%d, afc=%d " , c . signal , c . afc ) ;
if ( exiting ( tcp ) )
tprints ( " } " ) ;
return 1 ;
}
2016-05-01 17:25:24 +00:00
# include "xlat/v4l2_control_types.h"
# include "xlat/v4l2_control_flags.h"
static int
2016-12-26 10:26:03 +00:00
print_v4l2_queryctrl ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
struct v4l2_queryctrl c ;
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & c ) )
return RVAL_DECODED | 1 ;
tprints ( " {id= " ) ;
} else {
if ( syserror ( tcp ) | | umove ( tcp , arg , & c ) < 0 ) {
2014-11-03 21:27:40 +01:00
tprints ( " } " ) ;
2016-05-01 17:25:24 +00:00
return 1 ;
}
2016-07-15 16:08:19 +00:00
if ( get_tcb_priv_ulong ( tcp ) )
2016-05-01 17:25:24 +00:00
tprints ( " => " ) ;
2014-11-03 21:27:40 +01:00
}
2016-07-15 16:08:19 +00:00
if ( entering ( tcp ) | | get_tcb_priv_ulong ( tcp ) ) {
2015-02-22 02:13:04 +00:00
# ifdef V4L2_CTRL_FLAG_NEXT_CTRL
2016-07-15 16:08:19 +00:00
const unsigned long next = c . id & V4L2_CTRL_FLAG_NEXT_CTRL ;
set_tcb_priv_ulong ( tcp , next ) ;
if ( next ) {
2016-05-01 17:25:24 +00:00
tprints ( " V4L2_CTRL_FLAG_NEXT_CTRL| " ) ;
c . id & = ~ V4L2_CTRL_FLAG_NEXT_CTRL ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
# endif
printxval ( v4l2_control_ids , c . id , " V4L2_CID_??? " ) ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
if ( exiting ( tcp ) ) {
tprints ( " , type= " ) ;
printxval ( v4l2_control_types , c . type , " V4L2_CTRL_TYPE_??? " ) ;
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " , " , c , name ) ;
2016-05-01 17:25:24 +00:00
tprintf ( " , minimum=%d, maximum=%d, step=%d "
" , default_value=%d, flags= " ,
c . minimum , c . maximum , c . step , c . default_value ) ;
printflags ( v4l2_control_flags , c . flags , " V4L2_CTRL_FLAG_??? " ) ;
tprints ( " } " ) ;
}
return 1 ;
}
static int
2016-12-26 10:26:03 +00:00
print_v4l2_cropcap ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
struct v4l2_cropcap c ;
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & c ) )
return RVAL_DECODED | 1 ;
tprints ( " {type= " ) ;
printxval ( v4l2_buf_types , c . type , " V4L2_BUF_TYPE_??? " ) ;
return 0 ;
}
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & c ) ) {
tprintf ( " , bounds= " FMT_RECT
" , defrect= " FMT_RECT
" , pixelaspect= " FMT_FRACT ,
ARGS_RECT ( c . bounds ) ,
ARGS_RECT ( c . defrect ) ,
ARGS_FRACT ( c . pixelaspect ) ) ;
}
tprints ( " } " ) ;
return 1 ;
}
static int
2016-12-26 10:26:03 +00:00
print_v4l2_crop ( struct tcb * const tcp , const kernel_ulong_t arg ,
v4l2: change type of ioctl 3rd argument from long to kernel_ureg_t
* v4l2.c (print_v4l2_capability, print_v4l2_fmtdesc, print_v4l2_format,
print_v4l2_requestbuffers, print_v4l2_buffer, print_v4l2_framebuffer,
print_v4l2_buf_type, print_v4l2_streamparm, print_v4l2_standard,
print_v4l2_input, print_v4l2_control, print_v4l2_queryctrl,
print_v4l2_cropcap, print_v4l2_crop, print_v4l2_ext_controls,
print_v4l2_frmsizeenum, print_v4l2_frmivalenum,
print_v4l2_create_buffers, v4l2_ioctl): Change arg type from long
to kernel_ureg_t.
2016-12-21 01:22:18 +00:00
const bool is_get )
2016-05-01 17:25:24 +00:00
{
struct v4l2_crop c ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & c ) )
return RVAL_DECODED | 1 ;
tprints ( " {type= " ) ;
printxval ( v4l2_buf_types , c . type , " V4L2_BUF_TYPE_??? " ) ;
if ( is_get )
2014-11-03 21:27:40 +01:00
return 0 ;
2016-05-01 17:25:24 +00:00
tprintf ( " , c= " FMT_RECT , ARGS_RECT ( c . c ) ) ;
} else {
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & c ) )
tprintf ( " , c= " FMT_RECT , ARGS_RECT ( c . c ) ) ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
tprints ( " } " ) ;
return RVAL_DECODED | 1 ;
}
2015-02-22 02:13:04 +00:00
# ifdef VIDIOC_S_EXT_CTRLS
2016-05-07 23:15:36 +00:00
static bool
print_v4l2_ext_control ( struct tcb * tcp , void * elem_buf , size_t elem_size , void * data )
2016-05-01 17:25:24 +00:00
{
2016-05-07 23:15:36 +00:00
const struct_v4l2_ext_control * p = elem_buf ;
2016-05-01 17:25:24 +00:00
2016-05-07 23:15:36 +00:00
tprints ( " {id= " ) ;
printxval ( v4l2_control_ids , p - > id , " V4L2_CID_??? " ) ;
2015-02-22 02:13:04 +00:00
# if HAVE_DECL_V4L2_CTRL_TYPE_STRING
2016-05-07 23:15:36 +00:00
tprintf ( " , size=%u " , p - > size ) ;
if ( p - > size > 0 ) {
tprints ( " , string= " ) ;
2016-12-26 01:37:21 +00:00
printstrn ( tcp , ptr_to_kulong ( p - > string ) , p - > size ) ;
2016-05-07 23:15:36 +00:00
} else
2015-02-22 02:13:04 +00:00
# endif
2016-12-19 16:19:40 +00:00
tprintf ( " , value=%d, value64=% " PRId64 , p - > value , ( int64_t ) p - > value64 ) ;
2016-05-07 23:15:36 +00:00
tprints ( " } " ) ;
return true ;
2016-05-01 17:25:24 +00:00
}
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
# include "xlat/v4l2_control_classes.h"
static int
2016-12-26 10:26:03 +00:00
print_v4l2_ext_controls ( struct tcb * const tcp , const kernel_ulong_t arg ,
v4l2: change type of ioctl 3rd argument from long to kernel_ureg_t
* v4l2.c (print_v4l2_capability, print_v4l2_fmtdesc, print_v4l2_format,
print_v4l2_requestbuffers, print_v4l2_buffer, print_v4l2_framebuffer,
print_v4l2_buf_type, print_v4l2_streamparm, print_v4l2_standard,
print_v4l2_input, print_v4l2_control, print_v4l2_queryctrl,
print_v4l2_cropcap, print_v4l2_crop, print_v4l2_ext_controls,
print_v4l2_frmsizeenum, print_v4l2_frmivalenum,
print_v4l2_create_buffers, v4l2_ioctl): Change arg type from long
to kernel_ureg_t.
2016-12-21 01:22:18 +00:00
const bool is_get )
2016-05-01 17:25:24 +00:00
{
2016-05-03 22:30:41 +00:00
struct_v4l2_ext_controls c ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & c ) )
return RVAL_DECODED | 1 ;
tprints ( " {ctrl_class= " ) ;
printxval ( v4l2_control_classes , c . ctrl_class ,
" V4L2_CTRL_CLASS_??? " ) ;
tprintf ( " , count=%u " , c . count ) ;
if ( ! c . count ) {
tprints ( " } " ) ;
return RVAL_DECODED | 1 ;
}
if ( is_get )
2014-11-03 21:27:40 +01:00
return 0 ;
2016-05-01 17:25:24 +00:00
tprints ( " , " ) ;
} else {
if ( umove ( tcp , arg , & c ) < 0 ) {
2014-11-03 21:27:40 +01:00
tprints ( " } " ) ;
2016-05-01 17:25:24 +00:00
return 1 ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
tprints ( is_get ? " , " : " => " ) ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
tprints ( " controls= " ) ;
2016-05-07 23:15:36 +00:00
struct_v4l2_ext_control ctrl ;
2016-12-26 01:37:21 +00:00
bool fail = ! print_array ( tcp , ptr_to_kulong ( c . controls ) , c . count ,
2016-05-07 23:15:36 +00:00
& ctrl , sizeof ( ctrl ) ,
umoven_or_printaddr_ignore_syserror ,
print_v4l2_ext_control , 0 ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( exiting ( tcp ) & & syserror ( tcp ) )
tprintf ( " , error_idx=%u " , c . error_idx ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( exiting ( tcp ) | | fail ) {
2014-11-03 21:27:40 +01:00
tprints ( " } " ) ;
2016-05-01 17:25:24 +00:00
return RVAL_DECODED | 1 ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
return 1 ;
}
# endif /* VIDIOC_S_EXT_CTRLS */
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
# ifdef VIDIOC_ENUM_FRAMESIZES
# include "xlat / v4l2_framesize_types.h"
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
static int
2016-12-26 10:26:03 +00:00
print_v4l2_frmsizeenum ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
struct v4l2_frmsizeenum s ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & s ) )
return RVAL_DECODED | 1 ;
tprintf ( " {index=%u, pixel_format= " , s . index ) ;
print_pixelformat ( s . pixel_format ) ;
return 0 ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & s ) ) {
tprints ( " , type= " ) ;
printxval ( v4l2_framesize_types , s . type , " V4L2_FRMSIZE_TYPE_??? " ) ;
switch ( s . type ) {
case V4L2_FRMSIZE_TYPE_DISCRETE :
tprintf ( " , discrete={width=%u, height=%u} " ,
s . discrete . width , s . discrete . height ) ;
break ;
case V4L2_FRMSIZE_TYPE_STEPWISE :
tprintf ( " , stepwise={min_width=%u, max_width=%u, "
" step_width=%u, min_height=%u, max_height=%u, "
" step_height=%u} " ,
s . stepwise . min_width , s . stepwise . max_width ,
s . stepwise . step_width , s . stepwise . min_height ,
s . stepwise . max_height , s . stepwise . step_height ) ;
break ;
}
}
tprints ( " } " ) ;
return 1 ;
}
# endif /* VIDIOC_ENUM_FRAMESIZES */
2015-01-09 04:53:19 +00:00
# ifdef VIDIOC_ENUM_FRAMEINTERVALS
2016-05-01 17:25:24 +00:00
# include "xlat / v4l2_frameinterval_types.h"
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
static int
2016-12-26 10:26:03 +00:00
print_v4l2_frmivalenum ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
struct v4l2_frmivalenum f ;
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & f ) )
return RVAL_DECODED | 1 ;
tprintf ( " {index=%u, pixel_format= " , f . index ) ;
2014-11-03 21:27:40 +01:00
print_pixelformat ( f . pixel_format ) ;
tprintf ( " , width=%u, height=%u " , f . width , f . height ) ;
2016-05-01 17:25:24 +00:00
return 0 ;
}
if ( ! syserror ( tcp ) & & ! umove ( tcp , arg , & f ) ) {
tprints ( " , type= " ) ;
printxval ( v4l2_frameinterval_types , f . type ,
" V4L2_FRMIVAL_TYPE_??? " ) ;
switch ( f . type ) {
case V4L2_FRMIVAL_TYPE_DISCRETE :
tprintf ( " , discrete= " FMT_FRACT ,
ARGS_FRACT ( f . discrete ) ) ;
break ;
case V4L2_FRMIVAL_TYPE_STEPWISE :
case V4L2_FRMSIZE_TYPE_CONTINUOUS :
tprintf ( " , stepwise={min= " FMT_FRACT " , max= "
FMT_FRACT " , step= " FMT_FRACT " } " ,
ARGS_FRACT ( f . stepwise . min ) ,
ARGS_FRACT ( f . stepwise . max ) ,
ARGS_FRACT ( f . stepwise . step ) ) ;
break ;
2014-11-03 21:27:40 +01:00
}
}
2016-05-01 17:25:24 +00:00
tprints ( " } " ) ;
return 1 ;
}
2015-01-09 04:53:19 +00:00
# endif /* VIDIOC_ENUM_FRAMEINTERVALS */
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
# ifdef VIDIOC_CREATE_BUFS
static int
2016-12-26 10:26:03 +00:00
print_v4l2_create_buffers ( struct tcb * const tcp , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
2016-05-03 22:30:41 +00:00
struct_v4l2_create_buffers b ;
2016-05-01 17:25:24 +00:00
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & b ) )
return RVAL_DECODED | 1 ;
tprintf ( " {count=%u, memory= " , b . count ) ;
printxval ( v4l2_memories , b . memory , " V4L2_MEMORY_??? " ) ;
tprints ( " , format={type= " ) ;
printxval ( v4l2_buf_types , b . format . type ,
" V4L2_BUF_TYPE_??? " ) ;
2017-04-14 02:39:03 +03:00
print_v4l2_format_fmt ( tcp , " , " ,
2016-05-03 22:30:41 +00:00
( struct_v4l2_format * ) & b . format ) ;
2016-05-01 17:25:24 +00:00
tprints ( " }} " ) ;
return 0 ;
} else {
static const char fmt [ ] = " {index=%u, count=%u} " ;
static char outstr [ sizeof ( fmt ) + sizeof ( int ) * 6 ] ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
if ( syserror ( tcp ) | | umove ( tcp , arg , & b ) < 0 )
return 1 ;
sprintf ( outstr , fmt , b . index , b . count ) ;
tcp - > auxstr = outstr ;
return 1 + RVAL_STR ;
2014-11-03 21:27:40 +01:00
}
2016-05-01 17:25:24 +00:00
}
# endif /* VIDIOC_CREATE_BUFS */
2014-11-03 21:27:40 +01:00
v4l2: change type of ioctl 3rd argument from long to kernel_ureg_t
* v4l2.c (print_v4l2_capability, print_v4l2_fmtdesc, print_v4l2_format,
print_v4l2_requestbuffers, print_v4l2_buffer, print_v4l2_framebuffer,
print_v4l2_buf_type, print_v4l2_streamparm, print_v4l2_standard,
print_v4l2_input, print_v4l2_control, print_v4l2_queryctrl,
print_v4l2_cropcap, print_v4l2_crop, print_v4l2_ext_controls,
print_v4l2_frmsizeenum, print_v4l2_frmivalenum,
print_v4l2_create_buffers, v4l2_ioctl): Change arg type from long
to kernel_ureg_t.
2016-12-21 01:22:18 +00:00
MPERS_PRINTER_DECL ( int , v4l2_ioctl , struct tcb * const tcp ,
2016-12-26 10:26:03 +00:00
const unsigned int code , const kernel_ulong_t arg )
2016-05-01 17:25:24 +00:00
{
if ( ! verbose ( tcp ) )
return RVAL_DECODED ;
2015-05-20 17:50:21 +02:00
2016-05-01 17:25:24 +00:00
switch ( code ) {
case VIDIOC_QUERYCAP : /* R */
return print_v4l2_capability ( tcp , arg ) ;
2015-05-20 17:50:21 +02:00
2016-05-01 17:25:24 +00:00
case VIDIOC_ENUM_FMT : /* RW */
return print_v4l2_fmtdesc ( tcp , arg ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_G_FMT : /* RW */
case VIDIOC_S_FMT : /* RW */
case VIDIOC_TRY_FMT : /* RW */
return print_v4l2_format ( tcp , arg , code = = VIDIOC_G_FMT ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_REQBUFS : /* RW */
return print_v4l2_requestbuffers ( tcp , arg ) ;
2015-04-18 15:06:43 +02:00
2016-05-01 17:25:24 +00:00
case VIDIOC_QUERYBUF : /* RW */
case VIDIOC_QBUF : /* RW */
case VIDIOC_DQBUF : /* RW */
return print_v4l2_buffer ( tcp , code , arg ) ;
case VIDIOC_G_FBUF : /* R */
if ( entering ( tcp ) )
2015-04-18 15:06:43 +02:00
return 0 ;
2016-05-01 17:25:24 +00:00
/* fall through */
case VIDIOC_S_FBUF : /* W */
return print_v4l2_framebuffer ( tcp , arg ) ;
2015-04-18 15:06:43 +02:00
2016-05-01 17:25:24 +00:00
case VIDIOC_STREAMON : /* W */
case VIDIOC_STREAMOFF : /* W */
return print_v4l2_buf_type ( tcp , arg ) ;
2015-04-18 15:06:43 +02:00
2016-05-01 17:25:24 +00:00
case VIDIOC_G_PARM : /* RW */
case VIDIOC_S_PARM : /* RW */
return print_v4l2_streamparm ( tcp , arg , code = = VIDIOC_G_PARM ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_G_STD : /* R */
if ( entering ( tcp ) )
2014-11-03 21:27:40 +01:00
return 0 ;
2016-05-01 17:25:24 +00:00
/* fall through */
case VIDIOC_S_STD : /* W */
tprints ( " , " ) ;
printnum_int64 ( tcp , arg , " %# " PRIx64 ) ;
return RVAL_DECODED | 1 ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_ENUMSTD : /* RW */
return print_v4l2_standard ( tcp , arg ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_ENUMINPUT : /* RW */
return print_v4l2_input ( tcp , arg ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_G_CTRL : /* RW */
case VIDIOC_S_CTRL : /* RW */
return print_v4l2_control ( tcp , arg , code = = VIDIOC_G_CTRL ) ;
2014-11-03 21:27:40 +01:00
v4l2: Add decoding for VIDIOC_G/S_TUNER's arg
* v4l2.c: Include "xlat/v4l2_tuner_types.h", "xlat/v4l2_tuner_capabilities.h",
"xlat/v4l2_tuner_rxsubchanses.h", and "xlat/v4l2_tuner_audmodes.h".
(print_v4l2_tuner): New function. Add decoding for VIDIOC_G/S_TUNER's arg.
(v4l2_ioctl): Add new cases for decoding VIDIOC_G/S_TUNER's arg.
* xlat/v4l2_tuner_types.in: Add V4L2_TUNER_RADIO and
V4L2_TUNER_ANALOG_TV introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_DIGITAL_TV introduced by linux kernel
commit v2.6.11-rc4~55^2~20.
Add V4L2_TUNER_ADC and V4L2_TUNER_RF introduced by linux kernel commit
v3.15-rc1~85^2~215.
Add V4L2_TUNER_SDR introduced by linux kernel commit v4.4-rc1~118^2~17
(as the replacement of V4L2_TUNER_ADC).
* xlat/v4l2_tuner_capabilities.in: Add V4L2_TUNER_CAP_LOW,
V4L2_TUNER_CAP_NORM, V4L2_TUNER_CAP_STEREO, V4L2_TUNER_CAP_LANG2,
V4L2_TUNER_CAP_SAP, and V4L2_TUNER_CAP_LANG1 introduced by linux kernel
commit 2.5.46~39^2~23^2~4.
Add V4L2_TUNER_CAP_HWSEEK_BOUNDED and V4L2_TUNER_CAP_HWSEEK_WRAP
introduced by linux kernel commit v3.6-rc1~28^2~306.
Add V4L2_TUNER_CAP_RDS introduced by linux commit v2.6.32-rc1~679^2~189.
Add V4L2_TUNER_CAP_RDS_BLOCK_IO and V4L2_TUNER_CAP_RDS_CONTROLS
introduced by linux kernel commit v2.6.37-rc1~64^2~110.
Add V4L2_TUNER_CAP_FREQ_BANDS introduced by linux kernel commit
v3.6-rc1~28^2~46.
Add V4L2_TUNER_CAP_HWSEEK_PROG_LIM introduced by linux kernel commit
v3.6-rc1~28^2~40.
Add V4L2_TUNER_CAP_1HZ introduced by linux kernel commit
v3.15-rc1~85^2~214.
* xlat/v4l2_tuner_audmodes.in: Add V4L2_TUNER_MODE_MONO,
V4L2_TUNER_MODE_STEREO, V4L2_TUNER_MODE_LANG2, V4L2_TUNER_MODE_SAP, and
V4L2_TUNER_MODE_LANG1 introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_MODE_LANG1_LANG2 introduced by linux kernel commit
v2.6.17-rc1~739^2~9.
* xlat/v4l2_tuner_rxsubchanses.in: Add V4L2_TUNER_SUB_MONO,
V4L2_TUNER_SUB_STEREO, V4L2_TUNER_SUB_LANG2, V4L2_TUNER_SUB_SAP, and
V4L2_TUNER_SUB_LANG1 introduced by linux kernel commit
2.5.46~39^2~23^2~4.
Add V4L2_TUNER_SUB_RDS introduced by linux kernel commit
v2.6.32-rc1~679^2~189.
Signed-off-by: Edgar Kaziahmedov <edos@linux.com>
2017-04-23 04:53:47 +03:00
case VIDIOC_G_TUNER : /* RW */
case VIDIOC_S_TUNER : /* RW */
return print_v4l2_tuner ( tcp , arg , code = = VIDIOC_G_TUNER ) ;
2016-05-01 17:25:24 +00:00
case VIDIOC_QUERYCTRL : /* RW */
return print_v4l2_queryctrl ( tcp , arg ) ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_G_INPUT : /* R */
if ( entering ( tcp ) )
2014-11-03 21:27:40 +01:00
return 0 ;
2016-05-01 17:25:24 +00:00
/* fall through */
case VIDIOC_S_INPUT : /* RW */
tprints ( " , " ) ;
printnum_int ( tcp , arg , " %u " ) ;
return RVAL_DECODED | 1 ;
2014-11-03 21:27:40 +01:00
2016-05-01 17:25:24 +00:00
case VIDIOC_CROPCAP : /* RW */
return print_v4l2_cropcap ( tcp , arg ) ;
case VIDIOC_G_CROP : /* RW */
case VIDIOC_S_CROP : /* W */
return print_v4l2_crop ( tcp , arg , code = = VIDIOC_G_CROP ) ;
# ifdef VIDIOC_S_EXT_CTRLS
case VIDIOC_S_EXT_CTRLS : /* RW */
case VIDIOC_TRY_EXT_CTRLS : /* RW */
case VIDIOC_G_EXT_CTRLS : /* RW */
return print_v4l2_ext_controls ( tcp , arg ,
code = = VIDIOC_G_EXT_CTRLS ) ;
# endif /* VIDIOC_S_EXT_CTRLS */
# ifdef VIDIOC_ENUM_FRAMESIZES
case VIDIOC_ENUM_FRAMESIZES : /* RW */
return print_v4l2_frmsizeenum ( tcp , arg ) ;
# endif /* VIDIOC_ENUM_FRAMESIZES */
# ifdef VIDIOC_ENUM_FRAMEINTERVALS
case VIDIOC_ENUM_FRAMEINTERVALS : /* RW */
return print_v4l2_frmivalenum ( tcp , arg ) ;
# endif /* VIDIOC_ENUM_FRAMEINTERVALS */
# ifdef VIDIOC_CREATE_BUFS
case VIDIOC_CREATE_BUFS : /* RW */
return print_v4l2_create_buffers ( tcp , arg ) ;
# endif /* VIDIOC_CREATE_BUFS */
default :
return RVAL_DECODED ;
2014-11-03 21:27:40 +01:00
}
}