Success! (was Re: External Monitor under Pismo)

Michel Dänzer michdaen at iiic.ethz.ch
Tue May 1 09:03:10 EST 2001


(Adding CC: to linuxppc-dev to reach more potentially interested people)

"Jason E. Stewart" wrote:

> I'm writing this email to you off my ViewSonic21 running at measly
> 1280x1024 but it's much better than the 1024x768 I got using
> 'mirror'.
>
> I rebuilt r128_driver.c with the CRTOnly code commented in, added:
>
> Option "CRTOnly"
>
> to my XF86Config, and took out:
>
> Option "ProgramFPRegs" "No"
>
> (that last one caused me quite some grief till I read the code and
> realized it wasn't running the CRTOnly check unless registers were
> on....)
>
> And it works!!!!

Great!


> I'm happy to provide my recompiled r128_drv.o to pismo folks. Perhaps
> Michel can put it on his WWW site?

I am reluctant to do that. I'd prefer to get a solution into XFree86.

Someone please try the attached patch against current CVS. It turns Option
"UseBIOSDisplay" (which probably doesn't work for us - no BIOS here...) into
Option "Display" which accepts modes "CRT", "FP", "Mirror" and "BIOS".


Reports, comments and suggestions most welcome.


--
Earthling Michel Dänzer (MrCooper)    \   Debian GNU/Linux (powerpc) developer
CS student, Free Software enthusiast   \        XFree86 and DRI project member
-------------- next part --------------
Index: r128_driver.c
===================================================================
RCS file: /cvs/xc/programs/Xserver/hw/xfree86/drivers/ati/r128_driver.c,v
retrieving revision 1.26
diff -u -3 -r1.26 r128_driver.c
--- r128_driver.c	2001/04/10 16:07:59	1.26
+++ r128_driver.c	2001/04/30 15:38:46
@@ -140,7 +140,7 @@
   /* FIXME: Disable CRTOnly until it is tested */
   OPTION_CRT,
 #endif
-  OPTION_BIOS_DISPLAY,
+  OPTION_DISPLAY,
   OPTION_PANEL_WIDTH,
   OPTION_PANEL_HEIGHT,
   OPTION_PROG_FP_REGS,
@@ -165,7 +165,7 @@
   { OPTION_BUFFER_SIZE,  "BufferSize",       OPTV_INTEGER, {0}, FALSE },
   { OPTION_USE_CCE_2D,   "UseCCEfor2D",      OPTV_BOOLEAN, {0}, FALSE },
 #endif
-  { OPTION_BIOS_DISPLAY, "UseBIOSDisplay",   OPTV_BOOLEAN, {0}, FALSE },
+  { OPTION_DISPLAY,      "Display",          OPTV_STRING,  {0}, FALSE },
   { OPTION_PANEL_WIDTH,  "PanelWidth",       OPTV_INTEGER, {0}, FALSE },
   { OPTION_PANEL_HEIGHT, "PanelHeight",      OPTV_INTEGER, {0}, FALSE },
   { OPTION_PROG_FP_REGS, "ProgramFPRegs",    OPTV_BOOLEAN, {0}, FALSE },
@@ -920,10 +920,24 @@
        setting.  BIOS_5_SCRATCH holds the display device on flat panel
        systems only. */
     if (info->HasPanelRegs) {
-	if (xf86ReturnOptValBool(R128Options, OPTION_BIOS_DISPLAY, FALSE))
-	    info->BIOSDisplay = INREG8(R128_BIOS_5_SCRATCH);
+        char *display = xf86GetOptValString(R128Options, OPTION_DISPLAY);
+
+	if (!strcmp(display, "BIOS"))
+	  info->BIOSDisplay = INREG8(R128_BIOS_5_SCRATCH);
+	else if (!strcmp(display, "Mirror"))
+	  info->BIOSDisplay = R128_BIOS_DISPLAY_FP_CRT;
+	else if (!strcmp(display, "CRT"))
+	  info->BIOSDisplay = R128_BIOS_DISPLAY_CRT;
+	else if (!strcmp(display, "FP"))
+	  info->BIOSDisplay = R128_BIOS_DISPLAY_FP;
 	else
-	    info->BIOSDisplay = R128_BIOS_DISPLAY_FP;
+	{
+	  xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
+		     "Unsupported mode \"%s\" specified for Option \"Display\".\n", display);
+	  xf86DrvMsg(pScrn->scrnIndex, X_INFO,
+		     "Supported modes are: \"BIOS\", \"Mirror\", \"CRT\" and \"FP\"\n");
+	  return FALSE;
+	}
     } else {
 	info->BIOSDisplay     = R128_BIOS_DISPLAY_CRT;
     }
@@ -1949,7 +1963,7 @@
 #endif
 			     )) return FALSE;

-				/* DPMS setup */
+				/* DPMS setup - FIXME: also for mirror mode? - Michel */
     if (!info->HasPanelRegs || info->BIOSDisplay == R128_BIOS_DISPLAY_CRT)
 	xf86DPMSInit(pScreen, R128DisplayPowerManagementSet, 0);



More information about the Linuxppc-dev mailing list