more AGP stuff
git-svn-id: file:///srv/svn/repos/haiku/trunk/current@8018 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
c8079ef9c9
commit
ca0e044be6
@ -990,6 +990,7 @@ static status_t nv_general_bios_to_powergraphics()
|
|||||||
{
|
{
|
||||||
uint32 agp_ident, agp_stat, agp_cmd;
|
uint32 agp_ident, agp_stat, agp_cmd;
|
||||||
bool agp_1x, agp_2x, agp_4x, agp3_4x, agp3_8x;
|
bool agp_1x, agp_2x, agp_4x, agp3_4x, agp3_8x;
|
||||||
|
uint8 agp_speed;
|
||||||
|
|
||||||
LOG(2, ("INIT: Skipping card coldstart!\n"));
|
LOG(2, ("INIT: Skipping card coldstart!\n"));
|
||||||
|
|
||||||
@ -1138,42 +1139,38 @@ static status_t nv_general_bios_to_powergraphics()
|
|||||||
|
|
||||||
/* ... list them... */
|
/* ... list them... */
|
||||||
agp_1x = agp_2x = agp_4x = agp3_4x = agp3_8x = false;
|
agp_1x = agp_2x = agp_4x = agp3_4x = agp3_8x = false;
|
||||||
/* try to select AGP 2.0 setup */
|
|
||||||
CFGW(AGPSTAT, (CFGR(AGPSTAT) & 0xfffffff7));
|
|
||||||
agp_stat = CFGR(AGPSTAT);
|
agp_stat = CFGR(AGPSTAT);
|
||||||
|
/* the mainboard and graphicscard determine AGP version used on power-up/reset */
|
||||||
if (!(agp_stat & 0x00000008))
|
if (!(agp_stat & 0x00000008))
|
||||||
{
|
{
|
||||||
/* AGP 2.0 scheme applies */
|
/* AGP 2.0 scheme applies */
|
||||||
if (agp_stat & 0x00000001)
|
if (agp_stat & 0x00000001)
|
||||||
{
|
{
|
||||||
LOG(4,("INIT: AGP 2.0 1x mode is supported\n"));
|
LOG(4,("INIT: AGP 2.0 1x mode is available\n"));
|
||||||
agp_1x = true;
|
agp_1x = true;
|
||||||
}
|
}
|
||||||
if (agp_stat & 0x00000002)
|
if (agp_stat & 0x00000002)
|
||||||
{
|
{
|
||||||
LOG(4,("INIT: AGP 2.0 2x mode is supported\n"));
|
LOG(4,("INIT: AGP 2.0 2x mode is available\n"));
|
||||||
agp_2x = true;
|
agp_2x = true;
|
||||||
}
|
}
|
||||||
if (agp_stat & 0x00000004)
|
if (agp_stat & 0x00000004)
|
||||||
{
|
{
|
||||||
LOG(4,("INIT: AGP 2.0 4x mode is supported\n"));
|
LOG(4,("INIT: AGP 2.0 4x mode is available\n"));
|
||||||
agp_4x = true;
|
agp_4x = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* try to select AGP 3.0 setup */
|
else
|
||||||
CFGW(AGPSTAT, (CFGR(AGPSTAT) | 0x00000008));
|
|
||||||
agp_stat = CFGR(AGPSTAT);
|
|
||||||
if (agp_stat & 0x00000008)
|
|
||||||
{
|
{
|
||||||
/* AGP 3.0 scheme applies */
|
/* AGP 3.0 scheme applies */
|
||||||
if (agp_stat & 0x00000001)
|
if (agp_stat & 0x00000001)
|
||||||
{
|
{
|
||||||
LOG(4,("INIT: AGP 3.0 4x mode is supported\n"));
|
LOG(4,("INIT: AGP 3.0 4x mode is available\n"));
|
||||||
agp3_4x = true;
|
agp3_4x = true;
|
||||||
}
|
}
|
||||||
if (agp_stat & 0x00000002)
|
if (agp_stat & 0x00000002)
|
||||||
{
|
{
|
||||||
LOG(4,("INIT: AGP 3.0 8x mode is supported\n"));
|
LOG(4,("INIT: AGP 3.0 8x mode is available\n"));
|
||||||
agp3_8x = true;
|
agp3_8x = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1189,57 +1186,58 @@ static status_t nv_general_bios_to_powergraphics()
|
|||||||
LOG(4,("INIT: enabling AGP\n"));
|
LOG(4,("INIT: enabling AGP\n"));
|
||||||
|
|
||||||
/* select highest AGP mode */
|
/* select highest AGP mode */
|
||||||
//fixme: from nv.settings !?! for now: testing 2x
|
//fixme: from nv.settings !?! for now: testing 4x
|
||||||
switch (2)
|
agp_speed = 4;
|
||||||
|
if (!(agp_stat & 0x00000008))
|
||||||
{
|
{
|
||||||
case 8:
|
/* AGP 2.0 scheme applies */
|
||||||
if (agp3_8x)
|
switch (agp_speed)
|
||||||
{
|
{
|
||||||
LOG(4,("INIT: using AGP 3.0 8x mode\n"));
|
case 4:
|
||||||
/* select AGP 3.0 */
|
if (agp_4x)
|
||||||
agp_stat |= 0x00000008;
|
{
|
||||||
/* select 8x mode */
|
LOG(4,("INIT: using AGP 2.0 4x mode\n"));
|
||||||
agp_cmd = 0x00000002;
|
/* select 4x mode */
|
||||||
|
agp_cmd = 0x00000004;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 2:
|
||||||
|
if (agp_2x)
|
||||||
|
{
|
||||||
|
LOG(4,("INIT: using AGP 2.0 2x mode\n"));
|
||||||
|
/* select 2x mode */
|
||||||
|
agp_cmd = 0x00000002;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 1:
|
||||||
|
default:
|
||||||
|
LOG(4,("INIT: using AGP 2.0 1x mode\n"));
|
||||||
|
/* select 1x mode */
|
||||||
|
agp_cmd = 0x00000001;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 4:
|
}
|
||||||
if (agp3_4x)
|
else
|
||||||
|
{
|
||||||
|
/* AGP 3.0 scheme applies */
|
||||||
|
switch (agp_speed)
|
||||||
{
|
{
|
||||||
|
case 8:
|
||||||
|
if (agp3_8x)
|
||||||
|
{
|
||||||
|
LOG(4,("INIT: using AGP 3.0 8x mode\n"));
|
||||||
|
/* select 8x mode */
|
||||||
|
agp_cmd = 0x00000002;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 4:
|
||||||
|
default:
|
||||||
LOG(4,("INIT: using AGP 3.0 4x mode\n"));
|
LOG(4,("INIT: using AGP 3.0 4x mode\n"));
|
||||||
/* select AGP 3.0 */
|
|
||||||
agp_stat |= 0x00000008;
|
|
||||||
/* select 4x mode */
|
/* select 4x mode */
|
||||||
agp_cmd = 0x00000001;
|
agp_cmd = 0x00000001;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (agp_4x)
|
|
||||||
{
|
|
||||||
LOG(4,("INIT: using AGP 2.0 4x mode\n"));
|
|
||||||
/* select AGP 2.0 */
|
|
||||||
agp_stat &= 0xfffffff7;
|
|
||||||
/* select 4x mode */
|
|
||||||
agp_cmd = 0x00000004;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 2:
|
|
||||||
if (agp_2x)
|
|
||||||
{
|
|
||||||
LOG(4,("INIT: using AGP 2.0 2x mode\n"));
|
|
||||||
/* select AGP 2.0 */
|
|
||||||
agp_stat &= 0xfffffff7;
|
|
||||||
/* select 2x mode */
|
|
||||||
agp_cmd = 0x00000002;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 1:
|
|
||||||
LOG(4,("INIT: using AGP 2.0 1x mode\n"));
|
|
||||||
/* select AGP 2.0 */
|
|
||||||
agp_stat &= 0xfffffff7;
|
|
||||||
/* select 1x mode */
|
|
||||||
agp_cmd = 0x00000001;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
CFGW(AGPSTAT, agp_stat);
|
|
||||||
|
|
||||||
/* activate sideband adressing if supported */
|
/* activate sideband adressing if supported */
|
||||||
if (agp_stat & 0x00000200) agp_cmd |= 0x00000200;
|
if (agp_stat & 0x00000200) agp_cmd |= 0x00000200;
|
||||||
|
Loading…
Reference in New Issue
Block a user