changeset 8477:b5dce4fa1c48

support for exotic norms
author henry
date Mon, 16 Dec 2002 17:05:49 +0000
parents 650dda2e4bbb
children 7988573021e8
files libmpdemux/tv.c libmpdemux/tv.h libmpdemux/tvi_v4l.c
diffstat 3 files changed, 43 insertions(+), 5 deletions(-) [+]
line wrap: on
line diff
--- a/libmpdemux/tv.c	Mon Dec 16 10:43:07 2002 +0000
+++ b/libmpdemux/tv.c	Mon Dec 16 17:05:49 2002 +0000
@@ -159,6 +159,18 @@
 	tvh->norm = TV_NORM_NTSC;
     else if (!strcasecmp(tv_param_norm, "secam"))
 	tvh->norm = TV_NORM_SECAM;
+    else if (!strcasecmp(tv_param_norm, "palnc"))
+	tvh->norm = TV_NORM_PALNC;
+    else if (!strcasecmp(tv_param_norm, "palm"))
+	tvh->norm = TV_NORM_PALM;
+    else if (!strcasecmp(tv_param_norm, "paln"))
+	tvh->norm = TV_NORM_PALN;
+    else if (!strcasecmp(tv_param_norm, "ntscjp"))
+	tvh->norm = TV_NORM_NTSCJP;
+    else {
+	mp_msg(MSGT_TV, MSGL_V, "Bogus norm parameter, setting PAL.\n");
+	tvh->norm = TV_NORM_PAL;
+    }
 
     mp_msg(MSGT_TV, MSGL_V, "Selected norm: %s\n", tv_param_norm);
     funcs->control(tvh->priv, TVI_CONTROL_TUN_SET_NORM, &tvh->norm);
--- a/libmpdemux/tv.h	Mon Dec 16 10:43:07 2002 +0000
+++ b/libmpdemux/tv.h	Mon Dec 16 17:05:49 2002 +0000
@@ -154,6 +154,10 @@
 #define TV_NORM_PAL		1
 #define TV_NORM_NTSC		2
 #define TV_NORM_SECAM		3
+#define TV_NORM_PALNC		4
+#define TV_NORM_PALM		5
+#define TV_NORM_PALN		6
+#define TV_NORM_NTSCJP		7
 
 #endif /* USE_TV */
 
--- a/libmpdemux/tvi_v4l.c	Mon Dec 16 10:43:07 2002 +0000
+++ b/libmpdemux/tvi_v4l.c	Mon Dec 16 17:05:49 2002 +0000
@@ -980,15 +980,21 @@
 	{
 	    int req_mode = (int)*(void **)arg;
 
-	    if ((req_mode != TV_NORM_PAL) && (req_mode != TV_NORM_NTSC) && (req_mode != TV_NORM_SECAM)) {
+	    if ((req_mode != TV_NORM_PAL) && (req_mode != TV_NORM_NTSC) && (req_mode != TV_NORM_SECAM)
+		&& (req_mode != TV_NORM_PALNC) && (req_mode != TV_NORM_PALM) && (req_mode != TV_NORM_PALN)
+		&& (req_mode != TV_NORM_NTSCJP)) {
 		mp_msg(MSGT_TV, MSGL_ERR, "Unknown norm!\n");
 		return(TVI_CONTROL_FALSE);
 	    }
 
 	    if (priv->channels[priv->act_channel].flags & VIDEO_VC_TUNER) {
 		control(priv, TVI_CONTROL_TUN_GET_TUNER, 0);
-		if (((req_mode == TV_NORM_PAL) && !(priv->tuner.flags & VIDEO_TUNER_PAL)) ||
-		    ((req_mode == TV_NORM_NTSC) && !(priv->tuner.flags & VIDEO_TUNER_NTSC)) ||
+		if (((req_mode == TV_NORM_PAL
+		      || req_mode == TV_NORM_PALNC
+		      || req_mode == TV_NORM_PALN) && !(priv->tuner.flags & VIDEO_TUNER_PAL)) ||
+		    ((req_mode == TV_NORM_NTSC
+		      || req_mode == TV_NORM_NTSCJP
+		      || req_mode == TV_NORM_PALM) && !(priv->tuner.flags & VIDEO_TUNER_NTSC)) ||
 		    ((req_mode == TV_NORM_SECAM) && !(priv->tuner.flags & VIDEO_TUNER_SECAM)))
 		{
 		    mp_msg(MSGT_TV, MSGL_ERR, "Tuner isn't capable to set norm!\n");
@@ -997,9 +1003,13 @@
 
 		switch(req_mode) {
 		case TV_NORM_PAL:
+		case TV_NORM_PALNC:
+		case TV_NORM_PALN:
 		    priv->tuner.mode = VIDEO_MODE_PAL;
 		    break;
 		case TV_NORM_NTSC:
+		case TV_NORM_NTSCJP:
+		case TV_NORM_PALM:
 		    priv->tuner.mode = VIDEO_MODE_NTSC;
 		    break;
 		case TV_NORM_SECAM:
@@ -1023,6 +1033,18 @@
 	    case TV_NORM_SECAM:
 		priv->channels[priv->act_channel].norm = VIDEO_MODE_SECAM;
 		break;
+	    case TV_NORM_PALNC:
+		priv->channels[priv->act_channel].norm = 3;
+		break;
+	    case TV_NORM_PALM:
+		priv->channels[priv->act_channel].norm = 4;
+		break;
+	    case TV_NORM_PALN:
+		priv->channels[priv->act_channel].norm = 5;
+		break;
+	    case TV_NORM_NTSCJP:
+		priv->channels[priv->act_channel].norm = 6;
+		break;
 	    }
 	    if (ioctl(priv->video_fd, VIDIOCSCHAN, &priv->channels[priv->act_channel]) == -1)
 	    {
@@ -1035,11 +1057,11 @@
 		return(TVI_CONTROL_FALSE);
 	    }
 
-	    if(req_mode == TV_NORM_PAL || req_mode == TV_NORM_SECAM) {
+	    if(req_mode == TV_NORM_PAL || req_mode == TV_NORM_SECAM || req_mode == TV_NORM_PALN || req_mode == TV_NORM_PALNC) {
 		priv->fps = PAL_FPS;
             }
 
-	    if(req_mode == TV_NORM_NTSC) {
+	    if(req_mode == TV_NORM_NTSC || req_mode == TV_NORM_NTSCJP || req_mode == TV_NORM_PALM) {
 		priv->fps = NTSC_FPS;
             }