1 /*****************************************************************************
3 *****************************************************************************
4 * Copyright (C) 2001, 2002 VideoLAN
7 * Authors: Eric Petit <titer@videolan.org>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
22 *****************************************************************************/
24 /*****************************************************************************
26 *****************************************************************************/
28 #include <vlc/input.h>
31 #include <sys/types.h>
36 #include <linux/types.h>
37 #include <sys/ioctl.h>
38 #include "videodev2.h"
40 /* ivtv specific ioctls */
41 #define IVTV_IOC_G_CODEC 0xFFEE7703
42 #define IVTV_IOC_S_CODEC 0xFFEE7704
45 /* for use with IVTV_IOC_G_CODEC and IVTV_IOC_S_CODEC */
47 struct ivtv_ioctl_codec {
49 uint32_t audio_bitmask;
51 uint32_t bitrate_mode;
53 uint32_t bitrate_peak;
56 uint32_t dnr_temporal;
59 uint32_t framespergop;
65 /*****************************************************************************
67 *****************************************************************************/
68 static int Open ( vlc_object_t * );
69 static void Close ( vlc_object_t * );
71 static int Read ( access_t *, uint8_t *, int );
72 static int Control ( access_t *, int, va_list );
74 /*****************************************************************************
76 *****************************************************************************/
78 #define DEVICE_TEXT N_( "Device" )
79 #define DEVICE_LONGTEXT N_( "PVR video device" )
81 #define NORM_TEXT N_( "Norm" )
82 #define NORM_LONGTEXT N_( "Defines the norm of the stream (Automatic, SECAM, PAL, or NTSC)" )
83 static int i_norm_list[] = { V4L2_STD_UNKNOWN, V4L2_STD_SECAM, V4L2_STD_PAL,
85 static char *psz_norm_list_text[] = { N_("Automatic"), N_("SECAM"),
86 N_("PAL"), N_("NSTC") };
88 #define WIDTH_TEXT N_( "Width" )
89 #define WIDTH_LONGTEXT N_( "Width of the stream to capture (-1 for " \
91 #define HEIGHT_TEXT N_( "Height" )
92 #define HEIGHT_LONGTEXT N_( "Height of the stream to capture (-1 for " \
94 #define FREQUENCY_TEXT N_( "Frequency" )
95 #define FREQUENCY_LONGTEXT N_( "Frequency to capture (in kHz), if applicable" )
96 #define FRAMERATE_TEXT N_( "Framerate" )
97 #define FRAMERATE_LONGTEXT N_( "Framerate to capture, if applicable (-1 for " \
99 #define KEYINT_TEXT N_( "Key interval" )
100 #define KEYINT_LONGTEXT N_( "Interval between keyframes, in FIXME (-1 for " \
102 #define BFRAMES_TEXT N_( "B Frames" )
103 #define BFRAMES_LONGTEXT N_("If this option is set, B-Frames will be used." \
104 "Use this option to set the number of B-Frames")
105 #define BITRATE_TEXT N_( "Bitrate" )
106 #define BITRATE_LONGTEXT N_( "Bitrate to use (-1 for default)" )
107 #define BITRATE_PEAK_TEXT N_( "Bitrate peak" )
108 #define BITRATE_PEAK_LONGTEXT N_( "Peak bitrate in VBR mode" )
109 #define BITRATE_MODE_TEXT N_( "Bitrate mode (vbr or cbr)" )
110 #define BITRATE_MODE_LONGTEXT N_( "Bitrate mode to use" )
111 #define BITMASK_TEXT N_( "Audio bitmask" )
112 #define BITMASK_LONGTEXT N_("FIXME FIXME FIXME FIXME" )
113 #define CHAN_TEXT N_( "Channel" )
114 #define CHAN_LONGTEXT N_( "Channel of the card to use (Usually, 0 = tuner, " \
115 "1 = composite, 2 = svideo )" )
117 static int i_bitrates[] = { 0, 1 };
118 static char *psz_bitrates_list_text[] = { N_("vbr"), N_("cbr") };
121 set_shortname( _("PVR") );
122 set_description( _("MPEG Encoding cards input (with ivtv drivers)") );
123 set_capability( "access2", 0 );
124 add_shortcut( "pvr" );
126 add_string( "pvr-device", "/dev/video0", NULL, DEVICE_TEXT,
127 DEVICE_LONGTEXT, VLC_FALSE );
129 add_integer( "pvr-norm", V4L2_STD_UNKNOWN , NULL, NORM_TEXT,
130 NORM_LONGTEXT, VLC_FALSE );
131 change_integer_list( i_norm_list, psz_norm_list_text, 0 );
133 add_integer( "pvr-width", -1, NULL, WIDTH_TEXT, WIDTH_LONGTEXT, VLC_TRUE );
134 add_integer( "pvr-height", -1, NULL, WIDTH_TEXT, WIDTH_LONGTEXT,
136 add_integer( "pvr-frequency", -1, NULL, FREQUENCY_TEXT, FREQUENCY_LONGTEXT,
138 add_integer( "pvr-framerate", -1, NULL, FRAMERATE_TEXT, FRAMERATE_LONGTEXT,
140 add_integer( "pvr-keyint", -1, NULL, KEYINT_TEXT, KEYINT_LONGTEXT,
142 add_integer( "pvr-bframes", -1, NULL, FRAMERATE_TEXT, FRAMERATE_LONGTEXT,
144 add_integer( "pvr-bitrate", -1, NULL, BITRATE_TEXT, BITRATE_LONGTEXT,
146 add_integer( "pvr-bitrate-peak", -1, NULL, BITRATE_PEAK_TEXT,
147 BITRATE_PEAK_LONGTEXT, VLC_TRUE );
148 add_integer( "pvr-bitrate-mode", -1, NULL, BITRATE_MODE_TEXT,
149 BITRATE_MODE_LONGTEXT, VLC_TRUE );
150 change_integer_list( i_bitrates, psz_bitrates_list_text, 0 );
151 add_integer( "pvr-audio-bitmask", -1, NULL, BITMASK_TEXT,
152 BITMASK_LONGTEXT, VLC_TRUE );
153 add_integer( "pvr-channel", -1, NULL, CHAN_TEXT,
154 CHAN_LONGTEXT, VLC_TRUE );
156 set_callbacks( Open, Close );
160 /*****************************************************************************
161 * Private access data
162 *****************************************************************************/
165 /* file descriptor */
168 int64_t i_tell; /** Number of read bytes */
186 /*****************************************************************************
187 * Open: open the device
188 *****************************************************************************/
189 static int Open( vlc_object_t * p_this )
191 access_t *p_access = (access_t*) p_this;
192 access_sys_t * p_sys;
193 char * psz_tofree, * psz_parser, * psz_device;
197 struct v4l2_format vfmt;
198 struct v4l2_frequency vf;
199 struct ivtv_ioctl_codec codec;
201 //psz_device = calloc( strlen( "/dev/videox" ) + 1, 1 );
203 p_access->pf_read = Read;
204 p_access->pf_block = NULL;
205 p_access->pf_seek = NULL;
206 p_access->pf_control = Control;
208 /* create private access data */
209 p_sys = calloc( sizeof( access_sys_t ), 1 );
210 p_access->p_sys = p_sys;
212 /* defaults values */
213 var_Create( p_access, "pvr-device", VLC_VAR_STRING | VLC_VAR_DOINHERIT );
214 var_Get( p_access, "pvr-device" , &val);
215 psz_device = val.psz_string;
217 var_Create( p_access, "pvr-norm", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
218 var_Get( p_access, "pvr-norm" , &val);
219 p_sys->i_standard = val.i_int;
221 var_Create( p_access, "pvr-width", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
222 var_Get( p_access, "pvr-width" , &val);
223 p_sys->i_width = val.i_int;
225 var_Create( p_access, "pvr-height", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
226 var_Get( p_access, "pvr-height" , &val);
227 p_sys->i_height = val.i_int;
229 var_Create( p_access, "pvr-frequency", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
230 var_Get( p_access, "pvr-frequency" , &val);
231 p_sys->i_frequency = val.i_int;
233 var_Create( p_access, "pvr-framerate", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
234 var_Get( p_access, "pvr-framerate" , &val);
235 p_sys->i_framerate = val.i_int;
237 var_Create( p_access, "pvr-keyint", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
238 var_Get( p_access, "pvr-keyint" , &val);
239 p_sys->i_keyint = val.i_int;
241 var_Create( p_access, "pvr-bframes", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
242 var_Get( p_access, "pvr-bframes" , &val);
243 p_sys->i_bframes = val.b_bool;
245 var_Create( p_access, "pvr-bitrate", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
246 var_Get( p_access, "pvr-bitrate" , &val);
247 p_sys->i_bitrate = val.i_int;
249 var_Create( p_access, "pvr-bitrate-peak", VLC_VAR_INTEGER |
251 var_Get( p_access, "pvr-bitrate-peak" , &val);
252 p_sys->i_bitrate_peak = val.i_int;
254 var_Create( p_access, "pvr-bitrate-mode", VLC_VAR_INTEGER |
256 var_Get( p_access, "pvr-bitrate-mode" , &val);
257 p_sys->i_bitrate_mode = val.i_int;
259 var_Create( p_access, "pvr-audio-bitmask", VLC_VAR_INTEGER |
261 var_Get( p_access, "pvr-audio-bitmask" , &val);
262 p_sys->i_audio_bitmask = val.i_int;
263 var_Create( p_access, "pvr-channel", VLC_VAR_INTEGER |
265 var_Get( p_access, "pvr-channel" , &val);
266 p_sys->i_input = val.i_int;
271 /* parse command line options */
272 psz_tofree = strdup( p_access->psz_path );
273 psz_parser = psz_tofree;
279 if ( !strncmp( psz_parser, "norm=", strlen( "norm=" ) ) )
281 char *psz_parser_init;
282 psz_parser += strlen( "norm=" );
283 psz_parser_init = psz_parser;
284 while ( *psz_parser != ':' && *psz_parser != ','
285 && *psz_parser != '\0' )
290 if ( !strncmp( psz_parser_init, "secam" ,
291 psz_parser - psz_parser_init ) )
293 p_sys->i_standard = V4L2_STD_SECAM;
295 else if ( !strncmp( psz_parser_init, "pal" ,
296 psz_parser - psz_parser_init ) )
298 p_sys->i_standard = V4L2_STD_PAL;
300 else if ( !strncmp( psz_parser_init, "ntsc" ,
301 psz_parser - psz_parser_init ) )
303 p_sys->i_standard = V4L2_STD_NTSC;
307 p_sys->i_standard = strtol( psz_parser_init ,
311 else if( !strncmp( psz_parser, "channel=",
312 strlen( "channel=" ) ) )
315 strtol( psz_parser + strlen( "channel=" ),
318 else if( !strncmp( psz_parser, "device=", strlen( "device=" ) ) )
320 psz_device = calloc( strlen( "/dev/videox" ) + 1, 1 );
321 sprintf( psz_device, "/dev/video%ld",
322 strtol( psz_parser + strlen( "device=" ),
325 else if( !strncmp( psz_parser, "frequency=",
326 strlen( "frequency=" ) ) )
329 strtol( psz_parser + strlen( "frequency=" ),
332 else if( !strncmp( psz_parser, "framerate=",
333 strlen( "framerate=" ) ) )
336 strtol( psz_parser + strlen( "framerate=" ),
339 else if( !strncmp( psz_parser, "keyint=",
340 strlen( "keyint=" ) ) )
343 strtol( psz_parser + strlen( "keyint=" ),
346 else if( !strncmp( psz_parser, "bframes=",
347 strlen( "bframes=" ) ) )
350 strtol( psz_parser + strlen( "bframes=" ),
354 else if( !strncmp( psz_parser, "width=",
355 strlen( "width=" ) ) )
358 strtol( psz_parser + strlen( "width=" ),
361 else if( !strncmp( psz_parser, "height=",
362 strlen( "height=" ) ) )
365 strtol( psz_parser + strlen( "height=" ),
368 else if( !strncmp( psz_parser, "audio=",
369 strlen( "audio=" ) ) )
371 p_sys->i_audio_bitmask =
372 strtol( psz_parser + strlen( "audio=" ),
375 else if( !strncmp( psz_parser, "bitrate=",
376 strlen( "bitrate=" ) ) )
379 strtol( psz_parser + strlen( "bitrate=" ),
382 else if( !strncmp( psz_parser, "maxbitrate=",
383 strlen( "maxbitrate=" ) ) )
385 p_sys->i_bitrate_peak =
386 strtol( psz_parser + strlen( "maxbitrate=" ),
389 else if( !strncmp( psz_parser, "bitratemode=",
390 strlen( "bitratemode=" ) ) )
392 char *psz_parser_init;
393 psz_parser += strlen( "bitratemode=" );
394 psz_parser_init = psz_parser;
395 while ( *psz_parser != ':' && *psz_parser != ','
396 && *psz_parser != '\0' )
401 if ( !strncmp( psz_parser_init, "vbr" ,
402 psz_parser - psz_parser_init ) )
404 p_sys->i_bitrate_mode = 0;
406 else if ( !strncmp( psz_parser_init, "cbr" ,
407 psz_parser - psz_parser_init ) )
409 p_sys->i_bitrate_mode = 1;
412 else if( !strncmp( psz_parser, "size=",
413 strlen( "size=" ) ) )
416 strtol( psz_parser + strlen( "size=" ),
419 strtol( psz_parser + 1 ,
424 char *psz_parser_init;
425 psz_parser_init = psz_parser;
426 while ( *psz_parser != ':' && *psz_parser != ',' && *psz_parser != '\0' )
430 psz_device = calloc( psz_parser - psz_parser_init + 1, 1 );
431 strncpy( psz_device, psz_parser_init,
432 psz_parser - psz_parser_init );
441 //give a default value to psz_device if none has bee specified
445 psz_device = calloc( strlen( "/dev/videox" ) + 1, 1 );
446 strcpy( psz_device, "/dev/video0" );
451 /* open the device */
452 if( ( p_sys->i_fd = open( psz_device, O_RDWR ) ) < 0 )
454 msg_Err( p_access, "cannot open device (%s)", strerror( errno ) );
459 msg_Dbg( p_access, "using video device: %s",psz_device);
465 if ( p_sys->i_input != -1 )
467 if ( ioctl( p_sys->i_fd, VIDIOC_S_INPUT, &p_sys->i_input ) < 0 )
469 msg_Warn( p_access, "VIDIOC_S_INPUT failed" );
473 msg_Dbg( p_access, "input set to:%d", p_sys->i_input);
477 /* set the video standard */
478 if ( p_sys->i_standard != V4L2_STD_UNKNOWN )
480 if ( ioctl( p_sys->i_fd, VIDIOC_S_STD, &p_sys->i_standard ) < 0 )
482 msg_Warn( p_access, "VIDIOC_S_STD failed" );
486 msg_Dbg( p_access, "video standard set to:%x", p_sys->i_standard);
490 /* set the picture size */
491 if ( p_sys->i_width != -1 || p_sys->i_height != -1 )
493 if ( ioctl( p_sys->i_fd, VIDIOC_G_FMT, &vfmt ) < 0 )
495 msg_Warn( p_access, "VIDIOC_G_FMT failed" );
499 if ( p_sys->i_width != -1 )
501 vfmt.fmt.pix.width = p_sys->i_width;
504 if ( p_sys->i_height != -1 )
506 vfmt.fmt.pix.height = p_sys->i_height;
509 if ( ioctl( p_sys->i_fd, VIDIOC_S_FMT, &vfmt ) < 0 )
511 msg_Warn( p_access, "VIDIOC_S_FMT failed" );
515 msg_Dbg( p_access, "picture size set to:%dx%d",
516 vfmt.fmt.pix.width, vfmt.fmt.pix.height );
521 /* set the frequency */
522 if ( p_sys->i_frequency != -1 )
524 vf.tuner = 0; /* TODO: let the user choose the tuner */
525 if ( ioctl( p_sys->i_fd, VIDIOC_G_FREQUENCY, &vf ) < 0 )
527 msg_Warn( p_access, "VIDIOC_G_FREQUENCY failed (%s)",
532 vf.frequency = p_sys->i_frequency * 16 / 1000;
533 if( ioctl( p_sys->i_fd, VIDIOC_S_FREQUENCY, &vf ) < 0 )
535 msg_Warn( p_access, "VIDIOC_S_FREQUENCY failed (%s)",
540 msg_Dbg( p_access, "Tuner frequency set to:%d",
546 /* codec parameters */
547 if ( p_sys->i_framerate != -1
548 || p_sys->i_bitrate_mode != -1
549 || p_sys->i_bitrate_peak != -1
550 || p_sys->i_keyint != -1
551 || p_sys->i_bframes != -1
552 || p_sys->i_bitrate != -1
553 || p_sys->i_audio_bitmask != -1 )
555 if ( ioctl( p_sys->i_fd, IVTV_IOC_G_CODEC, &codec ) < 0 )
557 msg_Warn( p_access, "IVTV_IOC_G_CODEC failed" );
561 if ( p_sys->i_framerate != -1 )
563 switch ( p_sys->i_framerate )
574 msg_Warn( p_access, "invalid framerate, reverting to 25" );
580 if ( p_sys->i_bitrate != -1 )
582 codec.bitrate = p_sys->i_bitrate;
585 if ( p_sys->i_bitrate_peak != -1 )
587 codec.bitrate_peak = p_sys->i_bitrate_peak;
590 if ( p_sys->i_bitrate_mode != -1 )
592 codec.bitrate_mode = p_sys->i_bitrate_mode;
595 if ( p_sys->i_audio_bitmask != -1 )
597 codec.audio_bitmask = p_sys->i_audio_bitmask;
599 if ( p_sys->i_keyint != -1 )
601 codec.framespergop = p_sys->i_keyint;
604 if ( p_sys->i_bframes != -1 )
606 codec.bframes = p_sys->i_bframes;
608 if( ioctl( p_sys->i_fd, IVTV_IOC_S_CODEC, &codec ) < 0 )
610 msg_Warn( p_access, "IVTV_IOC_S_CODEC failed" );
614 msg_Dbg( p_access, "Setting codec parameters to: framerate: %d, bitrate: %d/%d/%d",
615 codec.framerate, codec.bitrate, codec.bitrate_peak, codec.bitrate_mode );
620 /* do a quick read */
624 if ( read( p_sys->i_fd, psz_tmp, 1 ) )
626 msg_Dbg(p_input, "Could read byte from device");
630 msg_Warn(p_input, "Could not read byte from device");
637 /*****************************************************************************
638 * Close: close the device
639 *****************************************************************************/
640 static void Close( vlc_object_t * p_this )
642 access_t *p_access = (access_t*) p_this;
643 access_sys_t * p_sys = p_access->p_sys;
645 close( p_sys->i_fd );
649 /*****************************************************************************
651 *****************************************************************************/
652 static int Read( access_t * p_access, uint8_t * p_buffer,
655 access_sys_t * p_sys = p_access->p_sys;
659 struct timeval timeout;
663 FD_SET( p_sys->i_fd, &fds );
665 timeout.tv_usec = 500000;
670 while( !( i_ret = select( p_sys->i_fd + 1, &fds,
671 NULL, NULL, &timeout ) ) )
674 FD_SET( p_sys->i_fd, &fds );
676 timeout.tv_usec = 500000;
678 if( p_access->b_die || p_access->b_error )
684 msg_Err( p_access, "select error (%s)", strerror( errno ) );
688 i_ret = read( p_sys->i_fd, p_buffer, i_len );
691 p_sys->b_eof = VLC_TRUE;
693 else if ( i_ret > 0 )
695 p_sys->i_tell += i_ret;
701 /*****************************************************************************
703 *****************************************************************************/
704 static int Control( access_t *p_access, int i_query, va_list args )
706 access_sys_t *p_sys = p_access->p_sys;
714 case ACCESS_CAN_SEEK:
715 case ACCESS_CAN_FASTSEEK:
716 pb_bool = (vlc_bool_t*)va_arg( args, vlc_bool_t* );
717 *pb_bool = VLC_FALSE;
719 case ACCESS_CAN_PAUSE:
720 pb_bool = (vlc_bool_t*)va_arg( args, vlc_bool_t* );
721 *pb_bool = VLC_FALSE;
723 case ACCESS_CAN_CONTROL_PACE:
724 pb_bool = (vlc_bool_t*)va_arg( args, vlc_bool_t* );
725 *pb_bool = VLC_FALSE;
730 pi_int = (int*)va_arg( args, int * );
733 case ACCESS_GET_SIZE:
734 pi_64 = (int64_t*)va_arg( args, int64_t * );
738 pi_64 = (int64_t*)va_arg( args, int64_t * );
739 *pi_64 = p_sys->i_tell;
742 pb_bool = (vlc_bool_t*)va_arg( args, vlc_bool_t* );
743 *pb_bool = p_sys->b_eof;
745 case ACCESS_GET_PTS_DELAY:
746 pi_64 = (int64_t*)va_arg( args, int64_t * );
751 case ACCESS_SET_PAUSE_STATE:
756 msg_Err( p_access, "unimplemented query in control" );