Commit 9f8213f9 authored by Petr Vandrovec's avatar Petr Vandrovec

Initialize Matrox G100 and G400 hardware with values read from BIOS instead of

with failsafe settings discovered in the past.
Fixes corrupted screen display on some G100.
parent 76a21cfa
...@@ -873,8 +873,7 @@ static int MGAG100_preinit(WPMINFO2) { ...@@ -873,8 +873,7 @@ static int MGAG100_preinit(WPMINFO2) {
hw->MXoptionReg |= 0x1080; hw->MXoptionReg |= 0x1080;
pci_write_config_dword(ACCESS_FBINFO(pcidev), PCI_OPTION_REG, hw->MXoptionReg); pci_write_config_dword(ACCESS_FBINFO(pcidev), PCI_OPTION_REG, hw->MXoptionReg);
mga_outl(M_CTLWTST, 0x00000300); mga_outl(M_CTLWTST, ACCESS_FBINFO(values).reg.mctlwtst);
/* mga_outl(M_CTLWTST, 0x03258A31); */
udelay(100); udelay(100);
mga_outb(0x1C05, 0x00); mga_outb(0x1C05, 0x00);
mga_outb(0x1C05, 0x80); mga_outb(0x1C05, 0x80);
...@@ -925,17 +924,18 @@ static int MGAG100_preinit(WPMINFO2) { ...@@ -925,17 +924,18 @@ static int MGAG100_preinit(WPMINFO2) {
pci_write_config_dword(ACCESS_FBINFO(pcidev), PCI_OPTION2_REG, reg50); pci_write_config_dword(ACCESS_FBINFO(pcidev), PCI_OPTION2_REG, reg50);
if (ACCESS_FBINFO(devflags.memtype) == -1) if (ACCESS_FBINFO(devflags.memtype) == -1)
ACCESS_FBINFO(devflags.memtype) = 0; hw->MXoptionReg |= ACCESS_FBINFO(values).reg.opt & 0x1C00;
hw->MXoptionReg |= (ACCESS_FBINFO(devflags.memtype) & 7) << 10; else
hw->MXoptionReg |= (ACCESS_FBINFO(devflags.memtype) & 7) << 10;
if (ACCESS_FBINFO(devflags.sgram)) if (ACCESS_FBINFO(devflags.sgram))
hw->MXoptionReg |= 0x4000; hw->MXoptionReg |= 0x4000;
mga_outl(M_CTLWTST, 0x042450A1); mga_outl(M_CTLWTST, ACCESS_FBINFO(values).reg.mctlwtst);
mga_outl(M_MEMRDBK, 0x00000108); mga_outl(M_MEMRDBK, ACCESS_FBINFO(values).reg.memrdbk);
udelay(200); udelay(200);
mga_outl(M_MACCESS, 0x00000000); mga_outl(M_MACCESS, 0x00000000);
mga_outl(M_MACCESS, 0x00008000); mga_outl(M_MACCESS, 0x00008000);
udelay(100); udelay(100);
mga_outl(M_MEMRDBK, 0x00000108); mga_outl(M_MEMRDBK, ACCESS_FBINFO(values).reg.memrdbk);
hw->MXoptionReg |= 0x00040020; hw->MXoptionReg |= 0x00040020;
} }
pci_write_config_dword(ACCESS_FBINFO(pcidev), PCI_OPTION_REG, hw->MXoptionReg); pci_write_config_dword(ACCESS_FBINFO(pcidev), PCI_OPTION_REG, hw->MXoptionReg);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment