added panel DPMS, updated detection code again (next iteration)
git-svn-id: file:///srv/svn/repos/haiku/trunk/current@7186 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
ead04ffa5e
commit
4709c2c813
@ -1,6 +1,6 @@
|
|||||||
/* CTRC functionality */
|
/* CTRC functionality */
|
||||||
/* Author:
|
/* Author:
|
||||||
Rudolf Cornelissen 11/2002-3/2004
|
Rudolf Cornelissen 11/2002-4/2004
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define MODULE_BIT 0x00040000
|
#define MODULE_BIT 0x00040000
|
||||||
@ -267,7 +267,8 @@ status_t nv_crtc_set_timing(display_mode target)
|
|||||||
uint32 iscale_x, iscale_y;
|
uint32 iscale_x, iscale_y;
|
||||||
|
|
||||||
/* powerup both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
/* powerup both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
||||||
DACW(FP_DEBUG0, (DACR(FP_DEBUG0) & 0xcfffffff));
|
//fixme: remove once DPMS confirmed OK!
|
||||||
|
// DACW(FP_DEBUG0, (DACR(FP_DEBUG0) & 0xcfffffff));
|
||||||
|
|
||||||
/* calculate inverse scaling factors used by hardware in 20.12 format */
|
/* calculate inverse scaling factors used by hardware in 20.12 format */
|
||||||
iscale_x = (((1 << 12) * target.timing.h_display) / si->ps.panel1_width);
|
iscale_x = (((1 << 12) * target.timing.h_display) / si->ps.panel1_width);
|
||||||
@ -286,8 +287,8 @@ status_t nv_crtc_set_timing(display_mode target)
|
|||||||
DACW(FP_VVALID_S, 0);
|
DACW(FP_VVALID_S, 0);
|
||||||
DACW(FP_VVALID_E, (si->ps.panel1_height - 1));
|
DACW(FP_VVALID_E, (si->ps.panel1_height - 1));
|
||||||
|
|
||||||
/* nVidia cards support upscaling except on NV11 */
|
/* nVidia cards support upscaling except on ??? */
|
||||||
//fixme? logfiles tell me this is nonsense...
|
/* NV11 cards can upscale after all! */
|
||||||
if (0)//si->ps.card_type == NV11)
|
if (0)//si->ps.card_type == NV11)
|
||||||
{
|
{
|
||||||
/* disable last fetched line limiting */
|
/* disable last fetched line limiting */
|
||||||
@ -442,12 +443,18 @@ status_t nv_crtc_dpms(bool display, bool h, bool v)
|
|||||||
/* end synchronous reset if display should be enabled */
|
/* end synchronous reset if display should be enabled */
|
||||||
SEQW(RESET, 0x03);
|
SEQW(RESET, 0x03);
|
||||||
|
|
||||||
|
/* powerup both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
||||||
|
if (si->ps.tmds1_active) DACW(FP_DEBUG0, (DACR(FP_DEBUG0) & 0xcfffffff));
|
||||||
|
|
||||||
LOG(4,("display on, "));
|
LOG(4,("display on, "));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
SEQW(CLKMODE, (temp | 0x20));
|
SEQW(CLKMODE, (temp | 0x20));
|
||||||
|
|
||||||
|
/* powerdown both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
||||||
|
if (si->ps.tmds1_active) DACW(FP_DEBUG0, (DACR(FP_DEBUG0) | 0x30000000));
|
||||||
|
|
||||||
LOG(4,("display off, "));
|
LOG(4,("display off, "));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/* second CTRC functionality for GeForce cards */
|
/* second CTRC functionality for GeForce cards */
|
||||||
/* Author:
|
/* Author:
|
||||||
Rudolf Cornelissen 11/2002-3/2004
|
Rudolf Cornelissen 11/2002-4/2004
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define MODULE_BIT 0x00020000
|
#define MODULE_BIT 0x00020000
|
||||||
@ -250,7 +250,8 @@ status_t nv_crtc2_set_timing(display_mode target)
|
|||||||
uint32 iscale_x, iscale_y;
|
uint32 iscale_x, iscale_y;
|
||||||
|
|
||||||
/* powerup both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
/* powerup both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
||||||
DAC2W(FP_DEBUG0, (DAC2R(FP_DEBUG0) & 0xcfffffff));
|
//fixme: remove once DPMS confirmed OK!
|
||||||
|
// DAC2W(FP_DEBUG0, (DAC2R(FP_DEBUG0) & 0xcfffffff));
|
||||||
|
|
||||||
/* calculate inverse scaling factors used by hardware in 20.12 format */
|
/* calculate inverse scaling factors used by hardware in 20.12 format */
|
||||||
iscale_x = (((1 << 12) * target.timing.h_display) / si->ps.panel2_width);
|
iscale_x = (((1 << 12) * target.timing.h_display) / si->ps.panel2_width);
|
||||||
@ -269,8 +270,8 @@ status_t nv_crtc2_set_timing(display_mode target)
|
|||||||
DAC2W(FP_VVALID_S, 0);
|
DAC2W(FP_VVALID_S, 0);
|
||||||
DAC2W(FP_VVALID_E, (si->ps.panel2_height - 1));
|
DAC2W(FP_VVALID_E, (si->ps.panel2_height - 1));
|
||||||
|
|
||||||
/* nVidia cards support upscaling except on NV11 */
|
/* nVidia cards support upscaling except on ??? */
|
||||||
//fixme? logfiles tell me this is nonsense...
|
/* NV11 cards can upscale after all! */
|
||||||
if (0)//si->ps.card_type == NV11)
|
if (0)//si->ps.card_type == NV11)
|
||||||
{
|
{
|
||||||
/* disable last fetched line limiting */
|
/* disable last fetched line limiting */
|
||||||
@ -425,12 +426,18 @@ status_t nv_crtc2_dpms(bool display, bool h, bool v)
|
|||||||
/* end synchronous reset if display should be enabled */
|
/* end synchronous reset if display should be enabled */
|
||||||
SEQW(RESET, 0x03);
|
SEQW(RESET, 0x03);
|
||||||
|
|
||||||
|
/* powerup both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
||||||
|
if (si->ps.tmds2_active) DAC2W(FP_DEBUG0, (DAC2R(FP_DEBUG0) & 0xcfffffff));
|
||||||
|
|
||||||
LOG(4,("display on, "));
|
LOG(4,("display on, "));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
SEQW(CLKMODE, (temp | 0x20));
|
SEQW(CLKMODE, (temp | 0x20));
|
||||||
|
|
||||||
|
/* powerdown both LVDS (laptop panellink) and TMDS (DVI panellink) transmitters */
|
||||||
|
if (si->ps.tmds2_active) DAC2W(FP_DEBUG0, (DAC2R(FP_DEBUG0) | 0x30000000));
|
||||||
|
|
||||||
LOG(4,("display off, "));
|
LOG(4,("display off, "));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/* Authors:
|
/* Authors:
|
||||||
Mark Watson 12/1999,
|
Mark Watson 12/1999,
|
||||||
Apsed,
|
Apsed,
|
||||||
Rudolf Cornelissen 10/2002-3/2004
|
Rudolf Cornelissen 10/2002-4/2004
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define MODULE_BIT 0x00008000
|
#define MODULE_BIT 0x00008000
|
||||||
@ -80,7 +80,7 @@ status_t nv_general_powerup()
|
|||||||
{
|
{
|
||||||
status_t status;
|
status_t status;
|
||||||
|
|
||||||
LOG(1,("POWERUP: nVidia (open)BeOS Accelerant 0.10-9 running.\n"));
|
LOG(1,("POWERUP: nVidia (open)BeOS Accelerant 0.10-10 running.\n"));
|
||||||
|
|
||||||
/* preset no laptop */
|
/* preset no laptop */
|
||||||
si->ps.laptop = false;
|
si->ps.laptop = false;
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/* Read initialisation information from card */
|
/* Read initialisation information from card */
|
||||||
/* some bits are hacks, where PINS is not known */
|
/* some bits are hacks, where PINS is not known */
|
||||||
/* Author:
|
/* Author:
|
||||||
Rudolf Cornelissen 7/2003-3/2004
|
Rudolf Cornelissen 7/2003-4/2004
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define MODULE_BIT 0x00002000
|
#define MODULE_BIT 0x00002000
|
||||||
@ -250,7 +250,7 @@ void fake_pins(void)
|
|||||||
static void detect_panels()
|
static void detect_panels()
|
||||||
{
|
{
|
||||||
/* detect if the BIOS enabled LCD's (internal panels or DVI) or TVout */
|
/* detect if the BIOS enabled LCD's (internal panels or DVI) or TVout */
|
||||||
{
|
|
||||||
/* both external TMDS transmitters (used for LCD/DVI) and external TVencoders
|
/* both external TMDS transmitters (used for LCD/DVI) and external TVencoders
|
||||||
* can use the CRTC's in slaved mode. */
|
* can use the CRTC's in slaved mode. */
|
||||||
/* Note:
|
/* Note:
|
||||||
@ -313,16 +313,17 @@ static void detect_panels()
|
|||||||
* are used!
|
* are used!
|
||||||
* Currently we'd loose the panel setup while not being able to restore it. */
|
* Currently we'd loose the panel setup while not being able to restore it. */
|
||||||
|
|
||||||
/* Note:
|
/* note: (facts)
|
||||||
* NV11 and NV17 cards can't distinquish between head 1 and head 2 except for
|
* -> NV11 and NV17 laptops have LVDS panels, programmed in both sets registers;
|
||||||
* connected laptop panels via the FP_TG_CTRL register (the DAC and DAC2
|
* -> NV34 laptops have TMDS panels, programmed in only one set of registers;
|
||||||
* flatpanel registers access the same single set on those cards!);
|
* -> NV11, NV25 and NV34 DVI cards, so external panels (TMDS) are programmed
|
||||||
* furthermore assuming that no DVI exist on non-laptop cards upto and
|
* in only one set of registers;
|
||||||
* including NV17 (for now). */
|
* -> a register-set's FP_TG_CTRL register, bit 31 tells you if a LVDS panel is
|
||||||
//fixme: how about NV18?
|
* connected to the primary head (0), or to the secondary head (1);
|
||||||
if (((si->ps.card_type <= NV17) && si->ps.laptop &&
|
* -> for LVDS panels both registersets are programmed identically by the card's
|
||||||
(!(DACR(FP_TG_CTRL) & 0x80000000))) || (si->ps.card_type > NV17))
|
* BIOSes;
|
||||||
{
|
* -> the programmed set of registers tells you where a TMDS (DVI) panel is
|
||||||
|
* connected. */
|
||||||
if (slaved_for_dev1 && !tvout1)
|
if (slaved_for_dev1 && !tvout1)
|
||||||
{
|
{
|
||||||
uint16 width = ((DACR(FP_HDISPEND) & 0x0000ffff) + 1);
|
uint16 width = ((DACR(FP_HDISPEND) & 0x0000ffff) + 1);
|
||||||
@ -335,12 +336,7 @@ static void detect_panels()
|
|||||||
si->ps.panel1_height = height;
|
si->ps.panel1_height = height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
//fixme: how about NV18?
|
|
||||||
if (((si->ps.card_type <= NV17) && si->ps.laptop &&
|
|
||||||
(DAC2R(FP_TG_CTRL) & 0x80000000)) || (si->ps.card_type > NV17))
|
|
||||||
{
|
|
||||||
if (si->ps.secondary_head && slaved_for_dev2 && !tvout2)
|
if (si->ps.secondary_head && slaved_for_dev2 && !tvout2)
|
||||||
{
|
{
|
||||||
uint16 width = ((DAC2R(FP_HDISPEND) & 0x0000ffff) + 1);
|
uint16 width = ((DAC2R(FP_HDISPEND) & 0x0000ffff) + 1);
|
||||||
@ -353,12 +349,7 @@ static void detect_panels()
|
|||||||
si->ps.panel2_height = height;
|
si->ps.panel2_height = height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
//fixme: how about NV18?
|
|
||||||
if (((si->ps.card_type <= NV17) && si->ps.laptop &&
|
|
||||||
(!(DACR(FP_TG_CTRL) & 0x80000000))) || (si->ps.card_type > NV17))
|
|
||||||
{
|
|
||||||
if (!si->ps.slaved_tmds1 && !tvout1)
|
if (!si->ps.slaved_tmds1 && !tvout1)
|
||||||
{
|
{
|
||||||
uint16 width = ((DACR(FP_HDISPEND) & 0x0000ffff) + 1);
|
uint16 width = ((DACR(FP_HDISPEND) & 0x0000ffff) + 1);
|
||||||
@ -371,12 +362,7 @@ static void detect_panels()
|
|||||||
si->ps.panel1_height = height;
|
si->ps.panel1_height = height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
//fixme: how about NV18?
|
|
||||||
if (((si->ps.card_type <= NV17) && si->ps.laptop &&
|
|
||||||
(DAC2R(FP_TG_CTRL) & 0x80000000)) || (si->ps.card_type > NV17))
|
|
||||||
{
|
|
||||||
if (si->ps.secondary_head && !si->ps.slaved_tmds2 && !tvout2)
|
if (si->ps.secondary_head && !si->ps.slaved_tmds2 && !tvout2)
|
||||||
{
|
{
|
||||||
uint16 width = ((DAC2R(FP_HDISPEND) & 0x0000ffff) + 1);
|
uint16 width = ((DAC2R(FP_HDISPEND) & 0x0000ffff) + 1);
|
||||||
@ -389,6 +375,32 @@ static void detect_panels()
|
|||||||
si->ps.panel2_height = height;
|
si->ps.panel2_height = height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//fixme...:
|
||||||
|
//we are assuming that no DVI is used as external monitor on laptops;
|
||||||
|
//otherwise we probably get into trouble here if the checked specs match.
|
||||||
|
if (si->ps.laptop && si->ps.tmds1_active && si->ps.tmds2_active &&
|
||||||
|
(DACR(FP_TG_CTRL) == DAC2R(FP_TG_CTRL)) &&
|
||||||
|
(si->ps.panel1_width == si->ps.panel2_width) &&
|
||||||
|
(si->ps.panel1_height == si->ps.panel2_height))
|
||||||
|
{
|
||||||
|
if (DACR(FP_TG_CTRL) & 0x80000000)
|
||||||
|
{
|
||||||
|
/* LVDS panel is on CRTC2, so clear false primary detection */
|
||||||
|
si->ps.slaved_tmds1 = false;
|
||||||
|
si->ps.master_tmds1 = false;
|
||||||
|
si->ps.tmds1_active = false;
|
||||||
|
si->ps.panel1_width = 0;
|
||||||
|
si->ps.panel1_height = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* LVDS panel is on CRTC1, so clear false secondary detection */
|
||||||
|
si->ps.slaved_tmds2 = false;
|
||||||
|
si->ps.master_tmds2 = false;
|
||||||
|
si->ps.tmds2_active = false;
|
||||||
|
si->ps.panel2_width = 0;
|
||||||
|
si->ps.panel2_height = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -400,57 +412,57 @@ static void detect_panels()
|
|||||||
|
|
||||||
/* dump some panel configuration registers... */
|
/* dump some panel configuration registers... */
|
||||||
LOG(2,("INFO: Dumping flatpanel registers:\n"));
|
LOG(2,("INFO: Dumping flatpanel registers:\n"));
|
||||||
LOG(2,("DAC1: FP_HDISPEND: $%08x = (dec) %d\n", DACR(FP_HDISPEND),DACR(FP_HDISPEND)));
|
LOG(2,("DAC1: FP_HDISPEND: %d\n", DACR(FP_HDISPEND)));
|
||||||
LOG(2,("DAC1: FP_HTOTAL: $%08x = (dec) %d\n", DACR(FP_HTOTAL),DACR(FP_HTOTAL)));
|
LOG(2,("DAC1: FP_HTOTAL: %d\n", DACR(FP_HTOTAL)));
|
||||||
LOG(2,("DAC1: FP_HCRTC: $%08x = (dec) %d\n", DACR(FP_HCRTC),DACR(FP_HCRTC)));
|
LOG(2,("DAC1: FP_HCRTC: %d\n", DACR(FP_HCRTC)));
|
||||||
LOG(2,("DAC1: FP_HSYNC_S: $%08x = (dec) %d\n", DACR(FP_HSYNC_S),DACR(FP_HSYNC_S)));
|
LOG(2,("DAC1: FP_HSYNC_S: %d\n", DACR(FP_HSYNC_S)));
|
||||||
LOG(2,("DAC1: FP_HSYNC_E: $%08x = (dec) %d\n", DACR(FP_HSYNC_E),DACR(FP_HSYNC_E)));
|
LOG(2,("DAC1: FP_HSYNC_E: %d\n", DACR(FP_HSYNC_E)));
|
||||||
LOG(2,("DAC1: FP_HVALID_S: $%08x = (dec) %d\n", DACR(FP_HVALID_S),DACR(FP_HVALID_S)));
|
LOG(2,("DAC1: FP_HVALID_S: %d\n", DACR(FP_HVALID_S)));
|
||||||
LOG(2,("DAC1: FP_HVALID_E: $%08x = (dec) %d\n", DACR(FP_HVALID_E),DACR(FP_HVALID_E)));
|
LOG(2,("DAC1: FP_HVALID_E: %d\n", DACR(FP_HVALID_E)));
|
||||||
|
|
||||||
LOG(2,("DAC1: FP_VDISPEND: $%08x = (dec) %d\n", DACR(FP_VDISPEND),DACR(FP_VDISPEND)));
|
LOG(2,("DAC1: FP_VDISPEND: %d\n", DACR(FP_VDISPEND)));
|
||||||
LOG(2,("DAC1: FP_VTOTAL: $%08x = (dec) %d\n", DACR(FP_VTOTAL),DACR(FP_VTOTAL)));
|
LOG(2,("DAC1: FP_VTOTAL: %d\n", DACR(FP_VTOTAL)));
|
||||||
LOG(2,("DAC1: FP_VCRTC: $%08x = (dec) %d\n", DACR(FP_VCRTC),DACR(FP_VCRTC)));
|
LOG(2,("DAC1: FP_VCRTC: %d\n", DACR(FP_VCRTC)));
|
||||||
LOG(2,("DAC1: FP_VSYNC_S: $%08x = (dec) %d\n", DACR(FP_VSYNC_S),DACR(FP_VSYNC_S)));
|
LOG(2,("DAC1: FP_VSYNC_S: %d\n", DACR(FP_VSYNC_S)));
|
||||||
LOG(2,("DAC1: FP_VSYNC_E: $%08x = (dec) %d\n", DACR(FP_VSYNC_E),DACR(FP_VSYNC_E)));
|
LOG(2,("DAC1: FP_VSYNC_E: %d\n", DACR(FP_VSYNC_E)));
|
||||||
LOG(2,("DAC1: FP_VVALID_S: $%08x = (dec) %d\n", DACR(FP_VVALID_S),DACR(FP_VVALID_S)));
|
LOG(2,("DAC1: FP_VVALID_S: %d\n", DACR(FP_VVALID_S)));
|
||||||
LOG(2,("DAC1: FP_VVALID_E: $%08x = (dec) %d\n", DACR(FP_VVALID_E),DACR(FP_VVALID_E)));
|
LOG(2,("DAC1: FP_VVALID_E: %d\n", DACR(FP_VVALID_E)));
|
||||||
|
|
||||||
LOG(2,("DAC1: FP_CHKSUM: $%08x = (dec) %d\n", DACR(FP_CHKSUM),DACR(FP_CHKSUM)));
|
LOG(2,("DAC1: FP_CHKSUM: $%08x = (dec) %d\n", DACR(FP_CHKSUM),DACR(FP_CHKSUM)));
|
||||||
LOG(2,("DAC1: FP_TST_CTRL: $%08x = (dec) %d\n", DACR(FP_TST_CTRL),DACR(FP_TST_CTRL)));
|
LOG(2,("DAC1: FP_TST_CTRL: $%08x\n", DACR(FP_TST_CTRL)));
|
||||||
LOG(2,("DAC1: FP_TG_CTRL: $%08x = (dec) %d\n", DACR(FP_TG_CTRL),DACR(FP_TG_CTRL)));
|
LOG(2,("DAC1: FP_TG_CTRL: $%08x\n", DACR(FP_TG_CTRL)));
|
||||||
LOG(2,("DAC1: FP_DEBUG0: $%08x = (dec) %d\n", DACR(FP_DEBUG0),DACR(FP_DEBUG0)));
|
LOG(2,("DAC1: FP_DEBUG0: $%08x\n", DACR(FP_DEBUG0)));
|
||||||
LOG(2,("DAC1: FP_DEBUG1: $%08x = (dec) %d\n", DACR(FP_DEBUG1),DACR(FP_DEBUG1)));
|
LOG(2,("DAC1: FP_DEBUG1: $%08x\n", DACR(FP_DEBUG1)));
|
||||||
LOG(2,("DAC1: FP_DEBUG2: $%08x = (dec) %d\n", DACR(FP_DEBUG2),DACR(FP_DEBUG2)));
|
LOG(2,("DAC1: FP_DEBUG2: $%08x\n", DACR(FP_DEBUG2)));
|
||||||
LOG(2,("DAC1: FP_DEBUG3: $%08x = (dec) %d\n", DACR(FP_DEBUG3),DACR(FP_DEBUG3)));
|
LOG(2,("DAC1: FP_DEBUG3: $%08x\n", DACR(FP_DEBUG3)));
|
||||||
|
|
||||||
LOG(2,("DAC1: FUNCSEL: $%08x\n", NV_REG32(NV32_FUNCSEL)));
|
LOG(2,("DAC1: FUNCSEL: $%08x\n", NV_REG32(NV32_FUNCSEL)));
|
||||||
|
|
||||||
if(si->ps.secondary_head)
|
if(si->ps.secondary_head)
|
||||||
{
|
{
|
||||||
LOG(2,("DAC2: FP_HDISPEND: $%08x = (dec) %d\n", DAC2R(FP_HDISPEND),DAC2R(FP_HDISPEND)));
|
LOG(2,("DAC2: FP_HDISPEND: %d\n", DAC2R(FP_HDISPEND)));
|
||||||
LOG(2,("DAC2: FP_HTOTAL: $%08x = (dec) %d\n", DAC2R(FP_HTOTAL),DAC2R(FP_HTOTAL)));
|
LOG(2,("DAC2: FP_HTOTAL: %d\n", DAC2R(FP_HTOTAL)));
|
||||||
LOG(2,("DAC2: FP_HCRTC: $%08x = (dec) %d\n", DAC2R(FP_HCRTC),DAC2R(FP_HCRTC)));
|
LOG(2,("DAC2: FP_HCRTC: %d\n", DAC2R(FP_HCRTC)));
|
||||||
LOG(2,("DAC2: FP_HSYNC_S: $%08x = (dec) %d\n", DAC2R(FP_HSYNC_S),DAC2R(FP_HSYNC_S)));
|
LOG(2,("DAC2: FP_HSYNC_S: %d\n", DAC2R(FP_HSYNC_S)));
|
||||||
LOG(2,("DAC2: FP_HSYNC_E: $%08x = (dec) %d\n", DAC2R(FP_HSYNC_E),DAC2R(FP_HSYNC_E)));
|
LOG(2,("DAC2: FP_HSYNC_E: %d\n", DAC2R(FP_HSYNC_E)));
|
||||||
LOG(2,("DAC2: FP_HVALID_S: $%08x = (dec) %d\n", DAC2R(FP_HVALID_S),DAC2R(FP_HVALID_S)));
|
LOG(2,("DAC2: FP_HVALID_S:%d\n", DAC2R(FP_HVALID_S)));
|
||||||
LOG(2,("DAC2: FP_HVALID_E: $%08x = (dec) %d\n", DAC2R(FP_HVALID_E),DAC2R(FP_HVALID_E)));
|
LOG(2,("DAC2: FP_HVALID_E: %d\n", DAC2R(FP_HVALID_E)));
|
||||||
|
|
||||||
LOG(2,("DAC2: FP_VDISPEND: $%08x = (dec) %d\n", DAC2R(FP_VDISPEND),DAC2R(FP_VDISPEND)));
|
LOG(2,("DAC2: FP_VDISPEND: %d\n", DAC2R(FP_VDISPEND)));
|
||||||
LOG(2,("DAC2: FP_VTOTAL: $%08x = (dec) %d\n", DAC2R(FP_VTOTAL),DAC2R(FP_VTOTAL)));
|
LOG(2,("DAC2: FP_VTOTAL: %d\n", DAC2R(FP_VTOTAL)));
|
||||||
LOG(2,("DAC2: FP_VCRTC: $%08x = (dec) %d\n", DAC2R(FP_VCRTC),DAC2R(FP_VCRTC)));
|
LOG(2,("DAC2: FP_VCRTC: %d\n", DAC2R(FP_VCRTC)));
|
||||||
LOG(2,("DAC2: FP_VSYNC_S: $%08x = (dec) %d\n", DAC2R(FP_VSYNC_S),DAC2R(FP_VSYNC_S)));
|
LOG(2,("DAC2: FP_VSYNC_S: %d\n", DAC2R(FP_VSYNC_S)));
|
||||||
LOG(2,("DAC2: FP_VSYNC_E: $%08x = (dec) %d\n", DAC2R(FP_VSYNC_E),DAC2R(FP_VSYNC_E)));
|
LOG(2,("DAC2: FP_VSYNC_E: %d\n", DAC2R(FP_VSYNC_E)));
|
||||||
LOG(2,("DAC2: FP_VVALID_S: $%08x = (dec) %d\n", DAC2R(FP_VVALID_S),DAC2R(FP_VVALID_S)));
|
LOG(2,("DAC2: FP_VVALID_S: %d\n", DAC2R(FP_VVALID_S)));
|
||||||
LOG(2,("DAC2: FP_VVALID_E: $%08x = (dec) %d\n", DAC2R(FP_VVALID_E),DAC2R(FP_VVALID_E)));
|
LOG(2,("DAC2: FP_VVALID_E: %d\n", DAC2R(FP_VVALID_E)));
|
||||||
|
|
||||||
LOG(2,("DAC2: FP_CHKSUM: $%08x = (dec) %d\n", DAC2R(FP_CHKSUM),DAC2R(FP_CHKSUM)));
|
LOG(2,("DAC2: FP_CHKSUM: $%08x = (dec) %d\n", DAC2R(FP_CHKSUM),DAC2R(FP_CHKSUM)));
|
||||||
LOG(2,("DAC2: FP_TST_CTRL: $%08x = (dec) %d\n", DAC2R(FP_TST_CTRL),DAC2R(FP_TST_CTRL)));
|
LOG(2,("DAC2: FP_TST_CTRL: $%08x\n", DAC2R(FP_TST_CTRL)));
|
||||||
LOG(2,("DAC2: FP_TG_CTRL: $%08x = (dec) %d\n", DAC2R(FP_TG_CTRL),DAC2R(FP_TG_CTRL)));
|
LOG(2,("DAC2: FP_TG_CTRL: $%08x\n", DAC2R(FP_TG_CTRL)));
|
||||||
LOG(2,("DAC2: FP_DEBUG0: $%08x = (dec) %d\n", DAC2R(FP_DEBUG0),DAC2R(FP_DEBUG0)));
|
LOG(2,("DAC2: FP_DEBUG0: $%08x\n", DAC2R(FP_DEBUG0)));
|
||||||
LOG(2,("DAC2: FP_DEBUG1: $%08x = (dec) %d\n", DAC2R(FP_DEBUG1),DAC2R(FP_DEBUG1)));
|
LOG(2,("DAC2: FP_DEBUG1: $%08x\n", DAC2R(FP_DEBUG1)));
|
||||||
LOG(2,("DAC2: FP_DEBUG2: $%08x = (dec) %d\n", DAC2R(FP_DEBUG2),DAC2R(FP_DEBUG2)));
|
LOG(2,("DAC2: FP_DEBUG2: $%08x\n", DAC2R(FP_DEBUG2)));
|
||||||
LOG(2,("DAC2: FP_DEBUG3: $%08x = (dec) %d\n", DAC2R(FP_DEBUG3),DAC2R(FP_DEBUG3)));
|
LOG(2,("DAC2: FP_DEBUG3: $%08x\n", DAC2R(FP_DEBUG3)));
|
||||||
|
|
||||||
LOG(2,("DAC2: FUNCSEL: $%08x\n", NV_REG32(NV32_2FUNCSEL)));
|
LOG(2,("DAC2: FUNCSEL: $%08x\n", NV_REG32(NV32_2FUNCSEL)));
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p><h2>Changes done for each driverversion:</h2></p>
|
<p><h2>Changes done for each driverversion:</h2></p>
|
||||||
<p><h1>head (0.10-9), (Rudolf)</h1></p>
|
<p><h1>head (0.10-10), (Rudolf)</h1></p>
|
||||||
<ul>
|
<ul>
|
||||||
<li>Implemented laptop internal flatpanel presence and native resolution detection;
|
<li>Implemented laptop internal flatpanel presence and native resolution detection;
|
||||||
<li>Implemented external DVI flatpanel(s) presence and native resolution detection;
|
<li>Implemented external DVI flatpanel(s) presence and native resolution detection;
|
||||||
@ -15,7 +15,9 @@
|
|||||||
<li>Added flatpanel LVDS and TMDS transmitters powerup if a panel is detected;
|
<li>Added flatpanel LVDS and TMDS transmitters powerup if a panel is detected;
|
||||||
<li>Updated NV11 and NV17 panel detection code: head should be identified correctly now;
|
<li>Updated NV11 and NV17 panel detection code: head should be identified correctly now;
|
||||||
<li>Fixed acceleration engine management regarding sync_to_token: no more updating glitches should occur now;
|
<li>Fixed acceleration engine management regarding sync_to_token: no more updating glitches should occur now;
|
||||||
<li>Added recognition for GeForce4 MX 4000, GeForceFX 5700LE and GeForceFX 5700VE cards; also modified a few others to be more correct.
|
<li>Added recognition for GeForce4 MX 4000, GeForceFX 5700LE and GeForceFX 5700VE cards; also modified a few others to be more correct;
|
||||||
|
<li>Updated panel detection code once more: pre NV18 DVI panels should be working again now;
|
||||||
|
<li>Added flatpanel DPMS support for both heads via powerup/powerdown of LVDS and TMDS transmitters.
|
||||||
</ul>
|
</ul>
|
||||||
NOTE:<br>
|
NOTE:<br>
|
||||||
dualhead switch mode is not yet operational for flatpanels...
|
dualhead switch mode is not yet operational for flatpanels...
|
||||||
|
Loading…
Reference in New Issue
Block a user