[From nobody Tue Aug 15 08:44:27 2006
Return-Path: &lt;akpm@osdl.org&gt;
X-Flags: 1001
Delivered-To: GMX delivery to t.schorpp@gmx.de
Received: (qmail invoked by alias); 09 Sep 2005 22:55:42 -0000
Received: from smtp.osdl.org (EHLO smtp.osdl.org) [65.172.181.4]
	by mx0.gmx.net (mx058) with SMTP; 10 Sep 2005 00:55:42 +0200
Received: from shell0.pdx.osdl.net (fw.osdl.org [65.172.181.6])
	by smtp.osdl.org (8.12.8/8.12.8) with ESMTP id j89MtdBo020655
	(version=TLSv1/SSLv3 cipher=EDH-RSA-DES-CBC3-SHA bits=168 verify=NO);
	Fri, 9 Sep 2005 15:55:40 -0700
Received: from localhost.localdomain (shell0.pdx.osdl.net [10.9.0.31])
	by shell0.pdx.osdl.net (8.13.1/8.11.6) with ESMTP id j89Mtdaj015167;
	Fri, 9 Sep 2005 15:55:39 -0700
Message-Id: &lt;200509092255.j89Mtdaj015167@shell0.pdx.osdl.net&gt;
Subject: dvb-av7110-siemens-dvb-c-analog-video-input-support.patch removed
	from -mm tree
To: t.schorpp@gmx.de, js@linuxtv.org, mm-commits@vger.kernel.org
From: akpm@osdl.org
Date: Fri, 09 Sep 2005 15:55:15 -0700
X-Spam-Status: No, hits=2.567 required=5 tests=DOMAIN_BODY,NO_REAL_NAME
X-Spam-Level: **
X-Spam-Checker-Version: SpamAssassin 2.63-osdl_revision__1.45__
X-MIMEDefang-Filter: osdl$Revision: 1.115 $
X-Scanned-By: MIMEDefang 2.36
X-GMX-Antivirus: -1 (not scanned, may not use virus scanner)
X-GMX-Antispam: 0 (Mail was not recognized as spam)
X-GMX-UID: uHdQY2hFeSEkSMXwbnUhaXN1IGRvbwDB


The patch titled

     dvb: av7110: Siemens DVB-C analog video input support

has been removed from the -mm tree.  Its filename is

     dvb-av7110-siemens-dvb-c-analog-video-input-support.patch

This patch was probably dropped from -mm because
it has already been merged into a subsystem tree
or into Linus's tree


Patches currently in -mm which might be from t.schorpp@gmx.de are




From: thomas schorpp &lt;t.schorpp@gmx.de&gt;

Add support for analog video inputs (CVBS and Y/C) of the
analog module for the Siemens DVB-C card.

Signed-off-by: thomas schorpp &lt;t.schorpp@gmx.de&gt;
Signed-off-by: Johannes Stezenbach &lt;js@linuxtv.org&gt;
Signed-off-by: Andrew Morton &lt;akpm@osdl.org&gt;
---

 drivers/media/dvb/ttpci/av7110_v4l.c |   74 +++++++++++++++++++++++++----------
 1 files changed, 54 insertions(+), 20 deletions(-)

diff -puN drivers/media/dvb/ttpci/av7110_v4l.c~dvb-av7110-siemens-dvb-c-analog-video-input-support drivers/media/dvb/ttpci/av7110_v4l.c
--- devel/drivers/media/dvb/ttpci/av7110_v4l.c~dvb-av7110-siemens-dvb-c-analog-video-input-support	2005-09-09 12:33:08.000000000 -0700
+++ devel-akpm/drivers/media/dvb/ttpci/av7110_v4l.c	2005-09-09 12:33:08.000000000 -0700
@@ -70,7 +70,7 @@ static int msp_readreg(struct av7110 *av
 	return 0;
 }
 
-static struct v4l2_input inputs[2] = {
+static struct v4l2_input inputs[4] = {
 	{
 		.index		= 0,
 		.name		= &quot;DVB&quot;,
@@ -87,6 +87,22 @@ static struct v4l2_input inputs[2] = {
 		.tuner		= 0,
 		.std		= V4L2_STD_PAL_BG|V4L2_STD_NTSC_M,
 		.status		= 0,
+	}, {
+		.index		= 2,
+		.name		= &quot;Video&quot;,
+		.type		= V4L2_INPUT_TYPE_CAMERA,
+		.audioset	= 0,
+		.tuner		= 0,
+		.std		= V4L2_STD_PAL_BG|V4L2_STD_NTSC_M,
+		.status		= 0,
+	}, {
+		.index		= 3,
+		.name		= &quot;Y/C&quot;,
+		.type		= V4L2_INPUT_TYPE_CAMERA,
+		.audioset	= 0,
+		.tuner		= 0,
+		.std		= V4L2_STD_PAL_BG|V4L2_STD_NTSC_M,
+		.status		= 0,
 	}
 };
 
@@ -212,24 +228,44 @@ static int av7110_dvb_c_switch(struct sa
 	}
 
 	if (0 != av7110-&gt;current_input) {
+		dprintk(1, &quot;switching to analog TV:\n&quot;);
 		adswitch = 1;
 		source = SAA7146_HPS_SOURCE_PORT_B;
 		sync = SAA7146_HPS_SYNC_PORT_B;
 		memcpy(standard, analog_standard, sizeof(struct saa7146_standard) * 2);
-		dprintk(1, &quot;switching to analog TV\n&quot;);
-		msp_writereg(av7110, MSP_WR_DSP, 0x0008, 0x0000); // loudspeaker source
-		msp_writereg(av7110, MSP_WR_DSP, 0x0009, 0x0000); // headphone source
-		msp_writereg(av7110, MSP_WR_DSP, 0x000a, 0x0000); // SCART 1 source
-		msp_writereg(av7110, MSP_WR_DSP, 0x000e, 0x3000); // FM matrix, mono
-		msp_writereg(av7110, MSP_WR_DSP, 0x0000, 0x4f00); // loudspeaker + headphone
-		msp_writereg(av7110, MSP_WR_DSP, 0x0007, 0x4f00); // SCART 1 volume
 
-		if (av7110-&gt;analog_tuner_flags &amp; ANALOG_TUNER_VES1820) {
-			if (ves1820_writereg(dev, 0x09, 0x0f, 0x60))
-				dprintk(1, &quot;setting band in demodulator failed.\n&quot;);
-		} else if (av7110-&gt;analog_tuner_flags &amp; ANALOG_TUNER_STV0297) {
-			saa7146_setgpio(dev, 1, SAA7146_GPIO_OUTHI); // TDA9198 pin9(STD)
-			saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTHI); // TDA9198 pin30(VIF)
+		switch (av7110-&gt;current_input) {
+		case 1:
+			dprintk(1, &quot;switching SAA7113 to Analog Tuner Input.\n&quot;);
+			msp_writereg(av7110, MSP_WR_DSP, 0x0008, 0x0000); // loudspeaker source
+			msp_writereg(av7110, MSP_WR_DSP, 0x0009, 0x0000); // headphone source
+			msp_writereg(av7110, MSP_WR_DSP, 0x000a, 0x0000); // SCART 1 source
+			msp_writereg(av7110, MSP_WR_DSP, 0x000e, 0x3000); // FM matrix, mono
+			msp_writereg(av7110, MSP_WR_DSP, 0x0000, 0x4f00); // loudspeaker + headphone
+			msp_writereg(av7110, MSP_WR_DSP, 0x0007, 0x4f00); // SCART 1 volume
+
+			if (av7110-&gt;analog_tuner_flags &amp; ANALOG_TUNER_VES1820) {
+				if (ves1820_writereg(dev, 0x09, 0x0f, 0x60))
+					dprintk(1, &quot;setting band in demodulator failed.\n&quot;);
+			} else if (av7110-&gt;analog_tuner_flags &amp; ANALOG_TUNER_STV0297) {
+				saa7146_setgpio(dev, 1, SAA7146_GPIO_OUTHI); // TDA9198 pin9(STD)
+				saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTHI); // TDA9198 pin30(VIF)
+			}
+			if (i2c_writereg(av7110, 0x48, 0x02, 0xd0) != 1)
+				dprintk(1, &quot;saa7113 write failed @ card %d&quot;, av7110-&gt;dvb_adapter.num);
+			break;
+		case 2:
+			dprintk(1, &quot;switching SAA7113 to Video AV CVBS Input.\n&quot;);
+			if (i2c_writereg(av7110, 0x48, 0x02, 0xd2) != 1)
+				dprintk(1, &quot;saa7113 write failed @ card %d&quot;, av7110-&gt;dvb_adapter.num);
+			break;
+		case 3:
+			dprintk(1, &quot;switching SAA7113 to Video AV Y/C Input.\n&quot;);
+			if (i2c_writereg(av7110, 0x48, 0x02, 0xd9) != 1)
+				dprintk(1, &quot;saa7113 write failed @ card %d&quot;, av7110-&gt;dvb_adapter.num);
+			break;
+		default:
+			dprintk(1, &quot;switching SAA7113 to Input: AV7110: SAA7113: invalid input.\n&quot;);
 		}
 	} else {
 		adswitch = 0;
@@ -300,7 +336,6 @@ static int av7110_ioctl(struct saa7146_f
 		// FIXME: standard / stereo detection is still broken
 		msp_readreg(av7110, MSP_RD_DEM, 0x007e, &amp;stereo_det);
 		dprintk(1, &quot;VIDIOC_G_TUNER: msp3400 TV standard detection: 0x%04x\n&quot;, stereo_det);
-
 		msp_readreg(av7110, MSP_RD_DSP, 0x0018, &amp;stereo_det);
 		dprintk(1, &quot;VIDIOC_G_TUNER: msp3400 stereo detection: 0x%04x\n&quot;, stereo_det);
 		stereo = (s8)(stereo_det &gt;&gt; 8);
@@ -310,7 +345,7 @@ static int av7110_ioctl(struct saa7146_f
 			t-&gt;audmode = V4L2_TUNER_MODE_STEREO;
 		}
 		else if (stereo &lt; -0x10) {
-			/* bilingual*/
+			/* bilingual */
 			t-&gt;rxsubchans = V4L2_TUNER_SUB_LANG1 | V4L2_TUNER_SUB_LANG2;
 			t-&gt;audmode = V4L2_TUNER_MODE_LANG1;
 		}
@@ -344,7 +379,7 @@ static int av7110_ioctl(struct saa7146_f
 			fm_matrix = 0x3000; // mono
 			src = 0x0010;
 			break;
-		default: /* case V4L2_TUNER_MODE_MONO: {*/
+		default: /* case V4L2_TUNER_MODE_MONO: */
 			dprintk(2, &quot;VIDIOC_S_TUNER: TDA9840_SET_MONO\n&quot;);
 			fm_matrix = 0x3000; // mono
 			src = 0x0030;
@@ -406,7 +441,7 @@ static int av7110_ioctl(struct saa7146_f
 		dprintk(2, &quot;VIDIOC_ENUMINPUT: %d\n&quot;, i-&gt;index);
 
 		if (av7110-&gt;analog_tuner_flags) {
-			if (i-&gt;index &lt; 0 || i-&gt;index &gt;= 2)
+			if (i-&gt;index &lt; 0 || i-&gt;index &gt;= 4)
 				return -EINVAL;
 		} else {
 			if (i-&gt;index != 0)
@@ -433,10 +468,9 @@ static int av7110_ioctl(struct saa7146_f
 		if (!av7110-&gt;analog_tuner_flags)
 			return 0;
 
-		if (input &lt; 0 || input &gt;= 2)
+		if (input &lt; 0 || input &gt;= 4)
 			return -EINVAL;
 
-		/* FIXME: switch inputs here */
 		av7110-&gt;current_input = input;
 		return av7110_dvb_c_switch(fh);
 	}
_


]