diff options
-rw-r--r-- | DOCS/man/en/mplayer.1 | 2 | ||||
-rw-r--r-- | help/help_mp-en.h | 1 | ||||
-rw-r--r-- | stream/stream_tv.c | 2 | ||||
-rw-r--r-- | stream/tv.c | 26 |
4 files changed, 21 insertions, 10 deletions
diff --git a/DOCS/man/en/mplayer.1 b/DOCS/man/en/mplayer.1 index 3defb7d568..f6f893132d 100644 --- a/DOCS/man/en/mplayer.1 +++ b/DOCS/man/en/mplayer.1 @@ -1759,7 +1759,7 @@ In most cases automute=100 will be enough. Default is 0 (automute disabled). .IPs driver=<value> See \-tv driver=help for a list of compiled-in TV input drivers. -available: dummy, v4l, v4l2, bsdbt848 +available: dummy, v4l, v4l2, bsdbt848 (default: autodetect) .IPs device=<value> Specify TV device (default: /dev/\:video0). .I NOTE: diff --git a/help/help_mp-en.h b/help/help_mp-en.h index 3f3494e144..5f89d9c582 100644 --- a/help/help_mp-en.h +++ b/help/help_mp-en.h @@ -2081,6 +2081,7 @@ static char help_text[]= #define MSGTR_TV_AvailableDrivers "Available drivers:\n" #define MSGTR_TV_DriverInfo "Selected driver: %s\n name: %s\n author: %s\n comment: %s\n" #define MSGTR_TV_NoSuchDriver "No such driver: %s\n" +#define MSGTR_TV_DriverAutoDetectionFailed "TV driver autodetection failed.\n" #define MSGTR_TV_UnknownColorOption "Unknown color option (%d) specified!\n" #define MSGTR_TV_CurrentFrequency "Current frequency: %lu (%.3f)\n" #define MSGTR_TV_NoTeletext "No teletext" diff --git a/stream/stream_tv.c b/stream/stream_tv.c index 6d8967c069..4b3af7be7c 100644 --- a/stream/stream_tv.c +++ b/stream/stream_tv.c @@ -40,7 +40,7 @@ tv_param_t stream_tv_defaults = { -1, //normid #endif NULL, //device - "dummy", //driver + NULL, //driver -1, //width -1, //height 0, //input, used in v4l and bttv diff --git a/stream/tv.c b/stream/tv.c index 58a05ba8f8..d6c380c5f9 100644 --- a/stream/tv.c +++ b/stream/tv.c @@ -52,17 +52,18 @@ extern tvi_info_t tvi_info_v4l2; extern tvi_info_t tvi_info_bsdbt848; #endif +/** List of drivers in autodetection order */ static const tvi_info_t* tvi_driver_list[]={ - &tvi_info_dummy, -#ifdef HAVE_TV_V4L1 - &tvi_info_v4l, -#endif #ifdef HAVE_TV_V4L2 &tvi_info_v4l2, #endif +#ifdef HAVE_TV_V4L1 + &tvi_info_v4l, +#endif #ifdef HAVE_TV_BSDBT848 &tvi_info_bsdbt848, #endif + &tvi_info_dummy, NULL }; @@ -560,7 +561,7 @@ static tvi_handle_t *tv_begin(tv_param_t* tv_param) { int i; tvi_handle_t* h; - if(!strcmp(tv_param->driver,"help")){ + if(tv_param->driver && !strcmp(tv_param->driver,"help")){ mp_msg(MSGT_TV,MSGL_INFO,MSGTR_TV_AvailableDrivers); for(i=0;tvi_driver_list[i];i++){ mp_msg(MSGT_TV,MSGL_INFO," %s\t%s",tvi_driver_list[i]->short_name,tvi_driver_list[i]->name); @@ -572,20 +573,29 @@ static tvi_handle_t *tv_begin(tv_param_t* tv_param) } for(i=0;tvi_driver_list[i];i++){ - if (!strcmp(tvi_driver_list[i]->short_name, tv_param->driver)){ + if (!tv_param->driver || !strcmp(tvi_driver_list[i]->short_name, tv_param->driver)){ h=tvi_driver_list[i]->tvi_init(tv_param); - if(!h) return NULL; + //Requested driver initialization failed + if (!h && tv_param->driver) + return NULL; + //Driver initialization failed during autodetection process. + if (!h) + continue; h->tv_param=tv_param; mp_msg(MSGT_TV, MSGL_INFO, MSGTR_TV_DriverInfo, tvi_driver_list[i]->short_name, tvi_driver_list[i]->name, tvi_driver_list[i]->author, tvi_driver_list[i]->comment?tvi_driver_list[i]->comment:""); + tv_param->driver=strdup(tvi_driver_list[i]->short_name); return h; } } - mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_NoSuchDriver, tv_param->driver); + if(tv_param->driver) + mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_NoSuchDriver, tv_param->driver); + else + mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_DriverAutoDetectionFailed); return(NULL); } |