linux-fbdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 14/17] ps3av: add quirk database for broken monitors
@ 2007-09-29  1:39 Antonino A. Daplas
  2007-10-03 21:00 ` Andrew Morton
  0 siblings, 1 reply; 4+ messages in thread
From: Antonino A. Daplas @ 2007-09-29  1:39 UTC (permalink / raw)
  To: Andrew Morton; +Cc: Geert Uytterhoeven, Linux Fbdev development list

From: Geert Uytterhoeven <Geert.Uytterhoeven@sonycom.com>

add a quirk database for broken monitors where the `best' advertised
video mode doesn't work

Signed-off-by: Geert Uytterhoeven <Geert.Uytterhoeven@sonycom.com>
Signed-off-by: Antonino Daplas <adaplas@gmail.com>
---

 drivers/ps3/ps3av.c |   41 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 41 insertions(+), 0 deletions(-)

diff --git a/drivers/ps3/ps3av.c b/drivers/ps3/ps3av.c
index fbf8dcd..cae4af9 100644
--- a/drivers/ps3/ps3av.c
+++ b/drivers/ps3/ps3av.c
@@ -721,6 +721,45 @@ static void ps3av_monitor_info_dump(cons
 	}
 }
 
+static const struct ps3av_monitor_quirk {
+	const char *monitor_name;
+	u32 clear_60, clear_50, clear_vesa;
+} ps3av_monitor_quirks[] = {
+	{
+		.monitor_name	= "DELL 2007WFP",
+		.clear_60	= PS3AV_RESBIT_1920x1080I
+	}, {
+		.monitor_name	= "L226WTQ",
+		.clear_60	= PS3AV_RESBIT_1920x1080I |
+				  PS3AV_RESBIT_1920x1080P
+	}, {
+		.monitor_name	= "SyncMaster",
+		.clear_60	= PS3AV_RESBIT_1920x1080I
+	}
+};
+
+static void ps3av_fixup_monitor_info(struct ps3av_info_monitor *info)
+{
+	unsigned int i;
+	const struct ps3av_monitor_quirk *quirk;
+
+	for (i = 0; i < ARRAY_SIZE(ps3av_monitor_quirks); i++) {
+		quirk = &ps3av_monitor_quirks[i];
+		if (!strncmp(info->monitor_name, quirk->monitor_name,
+			     sizeof(info->monitor_name))) {
+			pr_info("%s: Applying quirk for %s\n", __func__,
+				quirk->monitor_name);
+			info->res_60.res_bits &= ~quirk->clear_60;
+			info->res_60.native &= ~quirk->clear_60;
+			info->res_50.res_bits &= ~quirk->clear_50;
+			info->res_50.native &= ~quirk->clear_50;
+			info->res_vesa.res_bits &= ~quirk->clear_vesa;
+			info->res_vesa.native &= ~quirk->clear_vesa;
+			break;
+		}
+	}
+}
+
 static int ps3av_auto_videomode(struct ps3av_pkt_av_get_hw_conf *av_hw_conf,
 				int boot)
 {
@@ -739,6 +778,8 @@ static int ps3av_auto_videomode(struct p
 		ps3av_monitor_info_dump(&monitor_info);
 
 		info = &monitor_info.info;
+		ps3av_fixup_monitor_info(info);
+
 		switch (info->monitor_type) {
 		case PS3AV_MONITOR_TYPE_DVI:
 			dvi = PS3AV_MODE_DVI;


-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2005.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH 14/17] ps3av: add quirk database for broken monitors
  2007-09-29  1:39 [PATCH 14/17] ps3av: add quirk database for broken monitors Antonino A. Daplas
@ 2007-10-03 21:00 ` Andrew Morton
  2007-10-04  7:46   ` Geert Uytterhoeven
  0 siblings, 1 reply; 4+ messages in thread
From: Andrew Morton @ 2007-10-03 21:00 UTC (permalink / raw)
  To: Antonino A. Daplas; +Cc: Geert.Uytterhoeven, linux-fbdev-devel

On Sat, 29 Sep 2007 09:39:10 +0800
"Antonino A. Daplas" <adaplas@gmail.com> wrote:

> +static const struct ps3av_monitor_quirk {
> +	const char *monitor_name;
> +	u32 clear_60, clear_50, clear_vesa;
> +} ps3av_monitor_quirks[] = {
> +	{
> +		.monitor_name	= "DELL 2007WFP",
> +		.clear_60	= PS3AV_RESBIT_1920x1080I
> +	}, {
> +		.monitor_name	= "L226WTQ",
> +		.clear_60	= PS3AV_RESBIT_1920x1080I |
> +				  PS3AV_RESBIT_1920x1080P
> +	}, {
> +		.monitor_name	= "SyncMaster",
> +		.clear_60	= PS3AV_RESBIT_1920x1080I
> +	}
> +};

One assumes that the presently-unused clear_50 and clear_vesa will
be used at some time in the future...

-------------------------------------------------------------------------
This SF.net email is sponsored by: Splunk Inc.
Still grepping through log files to find problems?  Stop.
Now Search log events and configuration files using AJAX and a browser.
Download your FREE copy of Splunk now >> http://get.splunk.com/

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH 14/17] ps3av: add quirk database for broken monitors
  2007-10-03 21:00 ` Andrew Morton
@ 2007-10-04  7:46   ` Geert Uytterhoeven
  2007-10-12 14:36     ` Geert Uytterhoeven
  0 siblings, 1 reply; 4+ messages in thread
From: Geert Uytterhoeven @ 2007-10-04  7:46 UTC (permalink / raw)
  To: Andrew Morton; +Cc: linux-fbdev-devel, Antonino A. Daplas

[-- Attachment #1: Type: TEXT/PLAIN, Size: 1535 bytes --]

On Wed, 3 Oct 2007, Andrew Morton wrote:
> On Sat, 29 Sep 2007 09:39:10 +0800
> "Antonino A. Daplas" <adaplas@gmail.com> wrote:
> 
> > +static const struct ps3av_monitor_quirk {
> > +	const char *monitor_name;
> > +	u32 clear_60, clear_50, clear_vesa;
> > +} ps3av_monitor_quirks[] = {
> > +	{
> > +		.monitor_name	= "DELL 2007WFP",
> > +		.clear_60	= PS3AV_RESBIT_1920x1080I
> > +	}, {
> > +		.monitor_name	= "L226WTQ",
> > +		.clear_60	= PS3AV_RESBIT_1920x1080I |
> > +				  PS3AV_RESBIT_1920x1080P
> > +	}, {
> > +		.monitor_name	= "SyncMaster",
> > +		.clear_60	= PS3AV_RESBIT_1920x1080I
> > +	}
> > +};
> 
> One assumes that the presently-unused clear_50 and clear_vesa will
> be used at some time in the future...

So far I haven't encountered (or been reported) a monitor that needed to clear
50 Hz or VESA mode flags. I can comment out/#if 0 out/remove those parts if you
prefer.

With kind regards,
 
Geert Uytterhoeven
Software Architect

Sony Network and Software Technology Center Europe
The Corporate Village · Da Vincilaan 7-D1 · B-1935 Zaventem · Belgium
 
Phone:    +32 (0)2 700 8453	
Fax:      +32 (0)2 700 8622	
E-mail:   Geert.Uytterhoeven@sonycom.com	
Internet: http://www.sony-europe.com/
 	
Sony Network and Software Technology Center Europe	
A division of Sony Service Centre (Europe) N.V.	
Registered office: Technologielaan 7 · B-1840 Londerzeel · Belgium	
VAT BE 0413.825.160 · RPR Brussels	
Fortis Bank Zaventem · Swift GEBABEBB08A · IBAN BE39001382358619

[-- Attachment #2: Type: text/plain, Size: 314 bytes --]

-------------------------------------------------------------------------
This SF.net email is sponsored by: Splunk Inc.
Still grepping through log files to find problems?  Stop.
Now Search log events and configuration files using AJAX and a browser.
Download your FREE copy of Splunk now >> http://get.splunk.com/

[-- Attachment #3: Type: text/plain, Size: 182 bytes --]

_______________________________________________
Linux-fbdev-devel mailing list
Linux-fbdev-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-fbdev-devel

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH 14/17] ps3av: add quirk database for broken monitors
  2007-10-04  7:46   ` Geert Uytterhoeven
@ 2007-10-12 14:36     ` Geert Uytterhoeven
  0 siblings, 0 replies; 4+ messages in thread
From: Geert Uytterhoeven @ 2007-10-12 14:36 UTC (permalink / raw)
  To: Andrew Morton
  Cc: Geert Uytterhoeven, Linux Frame Buffer Device Development,
	Antonino A. Daplas

[-- Attachment #1: Type: TEXT/PLAIN, Size: 3611 bytes --]

	Hi Andrew,

On Thu, 4 Oct 2007, Geert Uytterhoeven wrote:
> On Wed, 3 Oct 2007, Andrew Morton wrote:
> > On Sat, 29 Sep 2007 09:39:10 +0800
> > "Antonino A. Daplas" <adaplas@gmail.com> wrote:
> > 
> > > +static const struct ps3av_monitor_quirk {
> > > +	const char *monitor_name;
> > > +	u32 clear_60, clear_50, clear_vesa;
> > > +} ps3av_monitor_quirks[] = {
> > > +	{
> > > +		.monitor_name	= "DELL 2007WFP",
> > > +		.clear_60	= PS3AV_RESBIT_1920x1080I
> > > +	}, {
> > > +		.monitor_name	= "L226WTQ",
> > > +		.clear_60	= PS3AV_RESBIT_1920x1080I |
> > > +				  PS3AV_RESBIT_1920x1080P
> > > +	}, {
> > > +		.monitor_name	= "SyncMaster",
> > > +		.clear_60	= PS3AV_RESBIT_1920x1080I
> > > +	}
> > > +};
> > 
> > One assumes that the presently-unused clear_50 and clear_vesa will
> > be used at some time in the future...
> 
> So far I haven't encountered (or been reported) a monitor that needed to clear
> 50 Hz or VESA mode flags. I can comment out/#if 0 out/remove those parts if you
> prefer.

I removed those fields. Here's an updated patch:

Subject: ps3av: add quirk database for broken monitors

ps3av: add a quirk database for broken monitors where the `best' advertised
video mode doesn't work

Signed-off-by: Geert Uytterhoeven <Geert.Uytterhoeven@sonycom.com>
---
Removed the `clear_50' and `clear_vesa' fields of struct ps3av_monitor_quirk,
as they're currently unused

 drivers/ps3/ps3av.c |   37 +++++++++++++++++++++++++++++++++++++
 1 files changed, 37 insertions(+)

--- a/drivers/ps3/ps3av.c
+++ b/drivers/ps3/ps3av.c
@@ -721,6 +721,41 @@ static void ps3av_monitor_info_dump(cons
 	}
 }
 
+static const struct ps3av_monitor_quirk {
+	const char *monitor_name;
+	u32 clear_60;
+} ps3av_monitor_quirks[] = {
+	{
+		.monitor_name	= "DELL 2007WFP",
+		.clear_60	= PS3AV_RESBIT_1920x1080I
+	}, {
+		.monitor_name	= "L226WTQ",
+		.clear_60	= PS3AV_RESBIT_1920x1080I |
+				  PS3AV_RESBIT_1920x1080P
+	}, {
+		.monitor_name	= "SyncMaster",
+		.clear_60	= PS3AV_RESBIT_1920x1080I
+	}
+};
+
+static void ps3av_fixup_monitor_info(struct ps3av_info_monitor *info)
+{
+	unsigned int i;
+	const struct ps3av_monitor_quirk *quirk;
+
+	for (i = 0; i < ARRAY_SIZE(ps3av_monitor_quirks); i++) {
+		quirk = &ps3av_monitor_quirks[i];
+		if (!strncmp(info->monitor_name, quirk->monitor_name,
+			     sizeof(info->monitor_name))) {
+			pr_info("%s: Applying quirk for %s\n", __func__,
+				quirk->monitor_name);
+			info->res_60.res_bits &= ~quirk->clear_60;
+			info->res_60.native &= ~quirk->clear_60;
+			break;
+		}
+	}
+}
+
 static int ps3av_auto_videomode(struct ps3av_pkt_av_get_hw_conf *av_hw_conf,
 				int boot)
 {
@@ -739,6 +774,8 @@ static int ps3av_auto_videomode(struct p
 		ps3av_monitor_info_dump(&monitor_info);
 
 		info = &monitor_info.info;
+		ps3av_fixup_monitor_info(info);
+
 		switch (info->monitor_type) {
 		case PS3AV_MONITOR_TYPE_DVI:
 			dvi = PS3AV_MODE_DVI;

With kind regards,
 
Geert Uytterhoeven
Software Architect

Sony Network and Software Technology Center Europe
The Corporate Village · Da Vincilaan 7-D1 · B-1935 Zaventem · Belgium
 
Phone:    +32 (0)2 700 8453	
Fax:      +32 (0)2 700 8622	
E-mail:   Geert.Uytterhoeven@sonycom.com	
Internet: http://www.sony-europe.com/
 	
Sony Network and Software Technology Center Europe	
A division of Sony Service Centre (Europe) N.V.	
Registered office: Technologielaan 7 · B-1840 Londerzeel · Belgium	
VAT BE 0413.825.160 · RPR Brussels	
Fortis Bank Zaventem · Swift GEBABEBB08A · IBAN BE39001382358619

[-- Attachment #2: Type: text/plain, Size: 314 bytes --]

-------------------------------------------------------------------------
This SF.net email is sponsored by: Splunk Inc.
Still grepping through log files to find problems?  Stop.
Now Search log events and configuration files using AJAX and a browser.
Download your FREE copy of Splunk now >> http://get.splunk.com/

[-- Attachment #3: Type: text/plain, Size: 182 bytes --]

_______________________________________________
Linux-fbdev-devel mailing list
Linux-fbdev-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-fbdev-devel

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2007-10-12 14:36 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-09-29  1:39 [PATCH 14/17] ps3av: add quirk database for broken monitors Antonino A. Daplas
2007-10-03 21:00 ` Andrew Morton
2007-10-04  7:46   ` Geert Uytterhoeven
2007-10-12 14:36     ` Geert Uytterhoeven

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).