lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Wed, 21 Apr 2010 16:01:46 +0800
From:	Zhenyu Wang <zhenyuw@...ux.intel.com>
To:	Eric Anholt <eric@...olt.net>
Cc:	Takashi Iwai <tiwai@...e.de>, David Airlie <airlied@...ux.ie>,
	dri-devel@...ts.sourceforge.net, linux-kernel@...r.kernel.org,
	Jesse Barnes <jbarnes@...tuousgeek.org>
Subject: Re: [PATCH] i915: Skip wrong TV outputs on HP laptop

On 2010.04.20 10:13:20 -0700, Eric Anholt wrote:
> On Tue, 20 Apr 2010 14:50:54 +0200, Takashi Iwai <tiwai@...e.de> wrote:
> > A new HP laptop with GM45 seems detecting wrongly TV outputs
> > occasionally.  Most of time it detects the TV output as disconnected,
> > but spontaneously it detects NTSC 480i although the laptop has no TV
> > output at all.
> > 
> > A simple (but ad hoc) fix is to add a DMI check as below.
> > 
> > Signed-off-by: Takashi Iwai <tiwai@...e.de>
> 
> Does this laptop have no TV connector on the laptop or the dock for it?

Maybe old TV quirks in UMS driver will also be helpful in case that
current BIOS check still fail. 

This is from old UMS driver, but use pci subsys ids instead of dmi info
at that time.

From 60bc20124faee4db406b856e139959f8c082830d Mon Sep 17 00:00:00 2001
From: Zhenyu Wang <zhenyuw@...ux.intel.com>
Date: Wed, 21 Apr 2010 15:53:51 +0800
Subject: [PATCH] drm/i915: TV quirks for laptop with no TV connector

This picks up TV connector quirks in original UMS driver,
to disable TV encoder on laptop with no physical TV port.

Signed-off-by: Zhenyu Wang <zhenyuw@...ux.intel.com>
---
 drivers/gpu/drm/i915/intel_tv.c |   69 +++++++++++++++++++++++++++++++++++++++
 1 files changed, 69 insertions(+), 0 deletions(-)

diff --git a/drivers/gpu/drm/i915/intel_tv.c b/drivers/gpu/drm/i915/intel_tv.c
index 081cb90..a96a14f 100644
--- a/drivers/gpu/drm/i915/intel_tv.c
+++ b/drivers/gpu/drm/i915/intel_tv.c
@@ -1612,6 +1612,71 @@ static int tv_is_present_in_vbt(struct drm_device *dev)
 	return ret;
 }
 
+struct intel_tv_quirk {
+	int pci_device;
+	int subsys_vendor;
+	int subsys_device;
+};
+
+struct intel_tv_quirk intel_tv_quirk_list[] = {
+	/* Clevo M720R has no tv output */
+	{ 0x2a02, 0x1558, 0x0721 },
+	/* Dell Latitude X1 */
+	{ 0x2592, 0x1028, 0x01a3 },
+	/* Dell Latitude X1 / D630 (LP: #197740) */
+	{ 0x2592, 0x1028, 0x01f9 },
+	/* Dell XPS 1330 */
+	{ 0x2a02, 0x1028, 0x0209 },
+	/* Dell Inspiron 1535 */
+	{ 0x2a02, 0x1028, 0x0254 },
+	/* Dell Inspiron 1735 */
+	{ 0x2a02, 0x1028, 0x0256 },
+	/* Dell Inspiron 1318 */
+	{ 0x2a02, 0x1028, 0x0286 },
+	/* Dell Vostro A840 (LP: #235155) */
+	{ 0x2a02, 0x1028, 0x0298 },
+	/* Lenovo 3000 v200 */
+	{ 0x2a02, 0x17aa, 0x3c18 },
+	/* Panasonic Toughbook CF-Y4 has no TV output */
+	{ 0x2592, 0x10f7, 0x8338 },
+	/* Panasonic Toughbook CF-Y7 has no TV output */
+	{ 0x2a02, 0x10f7, 0x8338 },
+	/* Toshiba Satellite U300 has no TV output */
+	{ 0x2a02, 0x1179, 0xff50 },
+	/* Samsung Q35 has no TV output */
+	{ 0x27a2, 0x144d, 0xc504 },
+	/* Samsung Q45 has no TV output */
+	{ 0x2a02, 0x144d, 0xc510 },
+	/* HP Compaq nx6110 has no TV output */
+	{ 0x2592, 0x103c, 0x099c },
+	/* HP Compaq nx6310 has no TV output */
+	{ 0x27a2, 0x103c, 0x30aa },
+	/* HP Compaq 6730s has no TV output */
+	{ 0x2a42, 0x103c, 0x30e8 },
+	/* Ordi Enduro UW31 (See LP: #152416) */
+	{ 0x27a2, 0x1584, 0x9900 },
+	/* Littlebit Sepia X35 (rebranded Asus Z37E) (See LP: #201257) */
+	{ 0x2a02, 0x1043, 0x8265 },
+	/* end mark */
+	{ 0, 0, 0 }
+};
+
+static bool
+intel_tv_check(struct drm_device *dev)
+{
+	struct pci_dev *pdev = dev->pdev;
+	struct intel_tv_quirk *q = intel_tv_quirk_list;
+
+	while (q && q->pci_device) {
+		if (q->pci_device == dev->pci_device &&
+		    q->subsys_vendor == pdev->subsystem_vendor &&
+		    q->subsys_device == pdev->subsystem_device)
+			return true;
+		++q;
+	}
+	return false;
+}
+
 void
 intel_tv_init(struct drm_device *dev)
 {
@@ -1635,6 +1700,10 @@ intel_tv_init(struct drm_device *dev)
 	if (!dev_priv->int_tv_support)
 		return;
 
+	/* No real TV output quirks */
+	if (intel_tv_check(dev))
+		return;
+
 	/*
 	 * Sanity check the TV output by checking to see if the
 	 * DAC register holds a value
-- 
1.6.3.3


-- 
Open Source Technology Center, Intel ltd.

$gpg --keyserver wwwkeys.pgp.net --recv-keys 4D781827

Download attachment "signature.asc" of type "application/pgp-signature" (199 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ