aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/video/tridentfb.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/video/tridentfb.c')
-rw-r--r--drivers/video/tridentfb.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/drivers/video/tridentfb.c b/drivers/video/tridentfb.c
index b6065effc5e0..da4b464cbdba 100644
--- a/drivers/video/tridentfb.c
+++ b/drivers/video/tridentfb.c
@@ -558,13 +558,15 @@ static inline void write3CE(struct tridentfb_par *par, int reg,
558 vga_mm_wgfx(par->io_virt, reg, val); 558 vga_mm_wgfx(par->io_virt, reg, val);
559} 559}
560 560
561static void enable_mmio(void) 561static void enable_mmio(struct tridentfb_par *par)
562{ 562{
563 /* Goto New Mode */ 563 /* Goto New Mode */
564 vga_io_rseq(0x0B); 564 vga_io_rseq(0x0B);
565 565
566 /* Unprotect registers */ 566 /* Unprotect registers */
567 vga_io_wseq(NewMode1, 0x80); 567 vga_io_wseq(NewMode1, 0x80);
568 if (!is_oldprotect(par->chip_id))
569 vga_io_wseq(Protection, 0x92);
568 570
569 /* Enable MMIO */ 571 /* Enable MMIO */
570 outb(PCIReg, 0x3D4); 572 outb(PCIReg, 0x3D4);
@@ -578,6 +580,8 @@ static void disable_mmio(struct tridentfb_par *par)
578 580
579 /* Unprotect registers */ 581 /* Unprotect registers */
580 vga_mm_wseq(par->io_virt, NewMode1, 0x80); 582 vga_mm_wseq(par->io_virt, NewMode1, 0x80);
583 if (!is_oldprotect(par->chip_id))
584 vga_mm_wseq(par->io_virt, Protection, 0x92);
581 585
582 /* Disable MMIO */ 586 /* Disable MMIO */
583 t_outb(par, PCIReg, 0x3D4); 587 t_outb(par, PCIReg, 0x3D4);
@@ -995,6 +999,7 @@ static int tridentfb_set_par(struct fb_info *info)
995 vblankend /= 2; 999 vblankend /= 2;
996 } 1000 }
997 1001
1002 enable_mmio(par);
998 crtc_unlock(par); 1003 crtc_unlock(par);
999 write3CE(par, CyberControl, 8); 1004 write3CE(par, CyberControl, 8);
1000 tmp = 0xEB; 1005 tmp = 0xEB;
@@ -1116,7 +1121,7 @@ static int tridentfb_set_par(struct fb_info *info)
1116 if (!is_xp(par->chip_id)) 1121 if (!is_xp(par->chip_id))
1117 write3X4(par, Performance, read3X4(par, Performance) | 0x10); 1122 write3X4(par, Performance, read3X4(par, Performance) | 0x10);
1118 /* MMIO & PCI read and write burst enable */ 1123 /* MMIO & PCI read and write burst enable */
1119 if (par->chip_id != TGUI9440) 1124 if (par->chip_id != TGUI9440 && par->chip_id != IMAGE975)
1120 write3X4(par, PCIReg, read3X4(par, PCIReg) | 0x06); 1125 write3X4(par, PCIReg, read3X4(par, PCIReg) | 0x06);
1121 1126
1122 vga_mm_wseq(par->io_virt, 0, 3); 1127 vga_mm_wseq(par->io_virt, 0, 3);
@@ -1403,7 +1408,7 @@ static int __devinit trident_pci_probe(struct pci_dev *dev,
1403 goto out_unmap1; 1408 goto out_unmap1;
1404 } 1409 }
1405 1410
1406 enable_mmio(); 1411 enable_mmio(default_par);
1407 1412
1408 /* setup framebuffer memory */ 1413 /* setup framebuffer memory */
1409 tridentfb_fix.smem_start = pci_resource_start(dev, 0); 1414 tridentfb_fix.smem_start = pci_resource_start(dev, 0);