diff options
Diffstat (limited to 'drivers/video/tridentfb.c')
-rw-r--r-- | drivers/video/tridentfb.c | 144 |
1 files changed, 61 insertions, 83 deletions
diff --git a/drivers/video/tridentfb.c b/drivers/video/tridentfb.c index d6796448c5ac..381e5853df6f 100644 --- a/drivers/video/tridentfb.c +++ b/drivers/video/tridentfb.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/pci.h> | 22 | #include <linux/pci.h> |
23 | 23 | ||
24 | #include <linux/delay.h> | 24 | #include <linux/delay.h> |
25 | #include <video/vga.h> | ||
25 | #include <video/trident.h> | 26 | #include <video/trident.h> |
26 | 27 | ||
27 | #define VERSION "0.7.9-NEWAPI" | 28 | #define VERSION "0.7.9-NEWAPI" |
@@ -149,8 +150,6 @@ static int iscyber(int id) | |||
149 | } | 150 | } |
150 | } | 151 | } |
151 | 152 | ||
152 | #define CRT 0x3D0 /* CRTC registers offset for color display */ | ||
153 | |||
154 | static inline void t_outb(struct tridentfb_par *p, u8 val, u16 reg) | 153 | static inline void t_outb(struct tridentfb_par *p, u8 val, u16 reg) |
155 | { | 154 | { |
156 | fb_writeb(val, p->io_virt + reg); | 155 | fb_writeb(val, p->io_virt + reg); |
@@ -525,60 +524,41 @@ static void tridentfb_copyarea(struct fb_info *info, | |||
525 | 524 | ||
526 | static inline unsigned char read3X4(struct tridentfb_par *par, int reg) | 525 | static inline unsigned char read3X4(struct tridentfb_par *par, int reg) |
527 | { | 526 | { |
528 | writeb(reg, par->io_virt + CRT + 4); | 527 | return vga_mm_rcrt(par->io_virt, reg); |
529 | return readb(par->io_virt + CRT + 5); | ||
530 | } | 528 | } |
531 | 529 | ||
532 | static inline void write3X4(struct tridentfb_par *par, int reg, | 530 | static inline void write3X4(struct tridentfb_par *par, int reg, |
533 | unsigned char val) | 531 | unsigned char val) |
534 | { | 532 | { |
535 | writeb(reg, par->io_virt + CRT + 4); | 533 | vga_mm_wcrt(par->io_virt, reg, val); |
536 | writeb(val, par->io_virt + CRT + 5); | ||
537 | } | ||
538 | |||
539 | static inline unsigned char read3C4(struct tridentfb_par *par, int reg) | ||
540 | { | ||
541 | t_outb(par, reg, 0x3C4); | ||
542 | return t_inb(par, 0x3C5); | ||
543 | } | ||
544 | |||
545 | static inline void write3C4(struct tridentfb_par *par, int reg, | ||
546 | unsigned char val) | ||
547 | { | ||
548 | t_outb(par, reg, 0x3C4); | ||
549 | t_outb(par, val, 0x3C5); | ||
550 | } | 534 | } |
551 | 535 | ||
552 | static inline unsigned char read3CE(struct tridentfb_par *par, int reg) | 536 | static inline unsigned char read3CE(struct tridentfb_par *par, |
537 | unsigned char reg) | ||
553 | { | 538 | { |
554 | t_outb(par, reg, 0x3CE); | 539 | return vga_mm_rgfx(par->io_virt, reg); |
555 | return t_inb(par, 0x3CF); | ||
556 | } | 540 | } |
557 | 541 | ||
558 | static inline void writeAttr(struct tridentfb_par *par, int reg, | 542 | static inline void writeAttr(struct tridentfb_par *par, int reg, |
559 | unsigned char val) | 543 | unsigned char val) |
560 | { | 544 | { |
561 | fb_readb(par->io_virt + CRT + 0x0A); /* flip-flop to index */ | 545 | fb_readb(par->io_virt + VGA_IS1_RC); /* flip-flop to index */ |
562 | t_outb(par, reg, 0x3C0); | 546 | vga_mm_wattr(par->io_virt, reg, val); |
563 | t_outb(par, val, 0x3C0); | ||
564 | } | 547 | } |
565 | 548 | ||
566 | static inline void write3CE(struct tridentfb_par *par, int reg, | 549 | static inline void write3CE(struct tridentfb_par *par, int reg, |
567 | unsigned char val) | 550 | unsigned char val) |
568 | { | 551 | { |
569 | t_outb(par, reg, 0x3CE); | 552 | vga_mm_wgfx(par->io_virt, reg, val); |
570 | t_outb(par, val, 0x3CF); | ||
571 | } | 553 | } |
572 | 554 | ||
573 | static void enable_mmio(void) | 555 | static void enable_mmio(void) |
574 | { | 556 | { |
575 | /* Goto New Mode */ | 557 | /* Goto New Mode */ |
576 | outb(0x0B, 0x3C4); | 558 | vga_io_rseq(0x0B); |
577 | inb(0x3C5); | ||
578 | 559 | ||
579 | /* Unprotect registers */ | 560 | /* Unprotect registers */ |
580 | outb(NewMode1, 0x3C4); | 561 | vga_io_wseq(NewMode1, 0x80); |
581 | outb(0x80, 0x3C5); | ||
582 | 562 | ||
583 | /* Enable MMIO */ | 563 | /* Enable MMIO */ |
584 | outb(PCIReg, 0x3D4); | 564 | outb(PCIReg, 0x3D4); |
@@ -588,12 +568,10 @@ static void enable_mmio(void) | |||
588 | static void disable_mmio(struct tridentfb_par *par) | 568 | static void disable_mmio(struct tridentfb_par *par) |
589 | { | 569 | { |
590 | /* Goto New Mode */ | 570 | /* Goto New Mode */ |
591 | t_outb(par, 0x0B, 0x3C4); | 571 | vga_mm_rseq(par->io_virt, 0x0B); |
592 | t_inb(par, 0x3C5); | ||
593 | 572 | ||
594 | /* Unprotect registers */ | 573 | /* Unprotect registers */ |
595 | t_outb(par, NewMode1, 0x3C4); | 574 | vga_mm_wseq(par->io_virt, NewMode1, 0x80); |
596 | t_outb(par, 0x80, 0x3C5); | ||
597 | 575 | ||
598 | /* Disable MMIO */ | 576 | /* Disable MMIO */ |
599 | t_outb(par, PCIReg, 0x3D4); | 577 | t_outb(par, PCIReg, 0x3D4); |
@@ -602,7 +580,8 @@ static void disable_mmio(struct tridentfb_par *par) | |||
602 | 580 | ||
603 | static void crtc_unlock(struct tridentfb_par *par) | 581 | static void crtc_unlock(struct tridentfb_par *par) |
604 | { | 582 | { |
605 | write3X4(par, CRTVSyncEnd, read3X4(par, CRTVSyncEnd) & 0x7F); | 583 | write3X4(par, VGA_CRTC_V_SYNC_END, |
584 | read3X4(par, VGA_CRTC_V_SYNC_END) & 0x7F); | ||
606 | } | 585 | } |
607 | 586 | ||
608 | /* Return flat panel's maximum x resolution */ | 587 | /* Return flat panel's maximum x resolution */ |
@@ -641,7 +620,7 @@ static int __devinit get_nativex(struct tridentfb_par *par) | |||
641 | /* Set pitch */ | 620 | /* Set pitch */ |
642 | static void set_lwidth(struct tridentfb_par *par, int width) | 621 | static void set_lwidth(struct tridentfb_par *par, int width) |
643 | { | 622 | { |
644 | write3X4(par, Offset, width & 0xFF); | 623 | write3X4(par, VGA_CRTC_OFFSET, width & 0xFF); |
645 | write3X4(par, AddColReg, | 624 | write3X4(par, AddColReg, |
646 | (read3X4(par, AddColReg) & 0xCF) | ((width & 0x300) >> 4)); | 625 | (read3X4(par, AddColReg) & 0xCF) | ((width & 0x300) >> 4)); |
647 | } | 626 | } |
@@ -668,8 +647,8 @@ static void screen_center(struct tridentfb_par *par) | |||
668 | static void set_screen_start(struct tridentfb_par *par, int base) | 647 | static void set_screen_start(struct tridentfb_par *par, int base) |
669 | { | 648 | { |
670 | u8 tmp; | 649 | u8 tmp; |
671 | write3X4(par, StartAddrLow, base & 0xFF); | 650 | write3X4(par, VGA_CRTC_START_LO, base & 0xFF); |
672 | write3X4(par, StartAddrHigh, (base & 0xFF00) >> 8); | 651 | write3X4(par, VGA_CRTC_START_HI, (base & 0xFF00) >> 8); |
673 | tmp = read3X4(par, CRTCModuleTest) & 0xDF; | 652 | tmp = read3X4(par, CRTCModuleTest) & 0xDF; |
674 | write3X4(par, CRTCModuleTest, tmp | ((base & 0x10000) >> 11)); | 653 | write3X4(par, CRTCModuleTest, tmp | ((base & 0x10000) >> 11)); |
675 | tmp = read3X4(par, CRTHiOrd) & 0xF8; | 654 | tmp = read3X4(par, CRTHiOrd) & 0xF8; |
@@ -698,8 +677,8 @@ static void set_vclk(struct tridentfb_par *par, unsigned long freq) | |||
698 | break; | 677 | break; |
699 | } | 678 | } |
700 | if (is3Dchip(par->chip_id)) { | 679 | if (is3Dchip(par->chip_id)) { |
701 | write3C4(par, ClockHigh, hi); | 680 | vga_mm_wseq(par->io_virt, ClockHigh, hi); |
702 | write3C4(par, ClockLow, lo); | 681 | vga_mm_wseq(par->io_virt, ClockLow, lo); |
703 | } else { | 682 | } else { |
704 | outb(lo, 0x43C8); | 683 | outb(lo, 0x43C8); |
705 | outb(hi, 0x43C9); | 684 | outb(hi, 0x43C9); |
@@ -782,7 +761,7 @@ static unsigned int __devinit get_memsize(struct tridentfb_par *par) | |||
782 | break; | 761 | break; |
783 | case 0x0E: /* XP */ | 762 | case 0x0E: /* XP */ |
784 | 763 | ||
785 | tmp2 = read3C4(par, 0xC1); | 764 | tmp2 = vga_mm_rseq(par->io_virt, 0xC1); |
786 | switch (tmp2) { | 765 | switch (tmp2) { |
787 | case 0x00: | 766 | case 0x00: |
788 | k = 20 * Mb; | 767 | k = 20 * Mb; |
@@ -931,7 +910,7 @@ static int tridentfb_set_par(struct fb_info *info) | |||
931 | * than requested resolution decide whether | 910 | * than requested resolution decide whether |
932 | * we stretch or center | 911 | * we stretch or center |
933 | */ | 912 | */ |
934 | t_outb(par, 0xEB, 0x3C2); | 913 | t_outb(par, 0xEB, VGA_MIS_W); |
935 | 914 | ||
936 | shadowmode_on(par); | 915 | shadowmode_on(par); |
937 | 916 | ||
@@ -941,26 +920,26 @@ static int tridentfb_set_par(struct fb_info *info) | |||
941 | screen_stretch(par); | 920 | screen_stretch(par); |
942 | 921 | ||
943 | } else { | 922 | } else { |
944 | t_outb(par, 0x2B, 0x3C2); | 923 | t_outb(par, 0x2B, VGA_MIS_W); |
945 | write3CE(par, CyberControl, 8); | 924 | write3CE(par, CyberControl, 8); |
946 | } | 925 | } |
947 | 926 | ||
948 | /* vertical timing values */ | 927 | /* vertical timing values */ |
949 | write3X4(par, CRTVTotal, vtotal & 0xFF); | 928 | write3X4(par, VGA_CRTC_V_TOTAL, vtotal & 0xFF); |
950 | write3X4(par, CRTVDispEnd, vdispend & 0xFF); | 929 | write3X4(par, VGA_CRTC_V_DISP_END, vdispend & 0xFF); |
951 | write3X4(par, CRTVSyncStart, vsyncstart & 0xFF); | 930 | write3X4(par, VGA_CRTC_V_SYNC_START, vsyncstart & 0xFF); |
952 | write3X4(par, CRTVSyncEnd, (vsyncend & 0x0F)); | 931 | write3X4(par, VGA_CRTC_V_SYNC_END, (vsyncend & 0x0F)); |
953 | write3X4(par, CRTVBlankStart, vblankstart & 0xFF); | 932 | write3X4(par, VGA_CRTC_V_BLANK_START, vblankstart & 0xFF); |
954 | write3X4(par, CRTVBlankEnd, 0 /* p->vblankend & 0xFF */); | 933 | write3X4(par, VGA_CRTC_V_BLANK_END, 0 /* p->vblankend & 0xFF */); |
955 | 934 | ||
956 | /* horizontal timing values */ | 935 | /* horizontal timing values */ |
957 | write3X4(par, CRTHTotal, htotal & 0xFF); | 936 | write3X4(par, VGA_CRTC_H_TOTAL, htotal & 0xFF); |
958 | write3X4(par, CRTHDispEnd, hdispend & 0xFF); | 937 | write3X4(par, VGA_CRTC_H_DISP, hdispend & 0xFF); |
959 | write3X4(par, CRTHSyncStart, hsyncstart & 0xFF); | 938 | write3X4(par, VGA_CRTC_H_SYNC_START, hsyncstart & 0xFF); |
960 | write3X4(par, CRTHSyncEnd, | 939 | write3X4(par, VGA_CRTC_H_SYNC_END, |
961 | (hsyncend & 0x1F) | ((hblankend & 0x20) << 2)); | 940 | (hsyncend & 0x1F) | ((hblankend & 0x20) << 2)); |
962 | write3X4(par, CRTHBlankStart, hblankstart & 0xFF); | 941 | write3X4(par, VGA_CRTC_H_BLANK_START, hblankstart & 0xFF); |
963 | write3X4(par, CRTHBlankEnd, 0 /* (p->hblankend & 0x1F) */); | 942 | write3X4(par, VGA_CRTC_H_BLANK_END, 0 /* (p->hblankend & 0x1F) */); |
964 | 943 | ||
965 | /* higher bits of vertical timing values */ | 944 | /* higher bits of vertical timing values */ |
966 | tmp = 0x10; | 945 | tmp = 0x10; |
@@ -972,7 +951,7 @@ static int tridentfb_set_par(struct fb_info *info) | |||
972 | if (vtotal & 0x200) tmp |= 0x20; | 951 | if (vtotal & 0x200) tmp |= 0x20; |
973 | if (vdispend & 0x200) tmp |= 0x40; | 952 | if (vdispend & 0x200) tmp |= 0x40; |
974 | if (vsyncstart & 0x200) tmp |= 0x80; | 953 | if (vsyncstart & 0x200) tmp |= 0x80; |
975 | write3X4(par, CRTOverflow, tmp); | 954 | write3X4(par, VGA_CRTC_OVERFLOW, tmp); |
976 | 955 | ||
977 | tmp = read3X4(par, CRTHiOrd) | 0x08; /* line compare bit 10 */ | 956 | tmp = read3X4(par, CRTHiOrd) | 0x08; /* line compare bit 10 */ |
978 | if (vtotal & 0x400) tmp |= 0x80; | 957 | if (vtotal & 0x400) tmp |= 0x80; |
@@ -989,11 +968,11 @@ static int tridentfb_set_par(struct fb_info *info) | |||
989 | tmp = 0x40; | 968 | tmp = 0x40; |
990 | if (vblankstart & 0x200) tmp |= 0x20; | 969 | if (vblankstart & 0x200) tmp |= 0x20; |
991 | //FIXME if (info->var.vmode & FB_VMODE_DOUBLE) tmp |= 0x80; /* double scan for 200 line modes */ | 970 | //FIXME if (info->var.vmode & FB_VMODE_DOUBLE) tmp |= 0x80; /* double scan for 200 line modes */ |
992 | write3X4(par, CRTMaxScanLine, tmp); | 971 | write3X4(par, VGA_CRTC_MAX_SCAN, tmp); |
993 | 972 | ||
994 | write3X4(par, CRTLineCompare, 0xFF); | 973 | write3X4(par, VGA_CRTC_LINE_COMPARE, 0xFF); |
995 | write3X4(par, CRTPRowScan, 0); | 974 | write3X4(par, VGA_CRTC_PRESET_ROW, 0); |
996 | write3X4(par, CRTModeControl, 0xC3); | 975 | write3X4(par, VGA_CRTC_MODE, 0xC3); |
997 | 976 | ||
998 | write3X4(par, LinearAddReg, 0x20); /* enable linear addressing */ | 977 | write3X4(par, LinearAddReg, 0x20); /* enable linear addressing */ |
999 | 978 | ||
@@ -1041,12 +1020,12 @@ static int tridentfb_set_par(struct fb_info *info) | |||
1041 | vclk *= 2; | 1020 | vclk *= 2; |
1042 | set_vclk(par, vclk); | 1021 | set_vclk(par, vclk); |
1043 | 1022 | ||
1044 | write3C4(par, 0, 3); | 1023 | vga_mm_wseq(par->io_virt, 0, 3); |
1045 | write3C4(par, 1, 1); /* set char clock 8 dots wide */ | 1024 | vga_mm_wseq(par->io_virt, 1, 1); /* set char clock 8 dots wide */ |
1046 | /* enable 4 maps because needed in chain4 mode */ | 1025 | /* enable 4 maps because needed in chain4 mode */ |
1047 | write3C4(par, 2, 0x0F); | 1026 | vga_mm_wseq(par->io_virt, 2, 0x0F); |
1048 | write3C4(par, 3, 0); | 1027 | vga_mm_wseq(par->io_virt, 3, 0); |
1049 | write3C4(par, 4, 0x0E); /* memory mode enable bitmaps ?? */ | 1028 | vga_mm_wseq(par->io_virt, 4, 0x0E); /* memory mode enable bitmaps ?? */ |
1050 | 1029 | ||
1051 | /* divide clock by 2 if 32bpp chain4 mode display and CPU path */ | 1030 | /* divide clock by 2 if 32bpp chain4 mode display and CPU path */ |
1052 | write3CE(par, MiscExtFunc, (bpp == 32) ? 0x1A : 0x12); | 1031 | write3CE(par, MiscExtFunc, (bpp == 32) ? 0x1A : 0x12); |
@@ -1056,7 +1035,7 @@ static int tridentfb_set_par(struct fb_info *info) | |||
1056 | 1035 | ||
1057 | if (par->chip_id == CYBERBLADEXPAi1) { | 1036 | if (par->chip_id == CYBERBLADEXPAi1) { |
1058 | /* This fixes snow-effect in 32 bpp */ | 1037 | /* This fixes snow-effect in 32 bpp */ |
1059 | write3X4(par, CRTHSyncStart, 0x84); | 1038 | write3X4(par, VGA_CRTC_H_SYNC_START, 0x84); |
1060 | } | 1039 | } |
1061 | 1040 | ||
1062 | /* graphics mode and support 256 color modes */ | 1041 | /* graphics mode and support 256 color modes */ |
@@ -1067,8 +1046,8 @@ static int tridentfb_set_par(struct fb_info *info) | |||
1067 | /* colors */ | 1046 | /* colors */ |
1068 | for (tmp = 0; tmp < 0x10; tmp++) | 1047 | for (tmp = 0; tmp < 0x10; tmp++) |
1069 | writeAttr(par, tmp, tmp); | 1048 | writeAttr(par, tmp, tmp); |
1070 | fb_readb(par->io_virt + CRT + 0x0A); /* flip-flop to index */ | 1049 | fb_readb(par->io_virt + VGA_IS1_RC); /* flip-flop to index */ |
1071 | t_outb(par, 0x20, 0x3C0); /* enable attr */ | 1050 | t_outb(par, 0x20, VGA_ATT_W); /* enable attr */ |
1072 | 1051 | ||
1073 | switch (bpp) { | 1052 | switch (bpp) { |
1074 | case 8: | 1053 | case 8: |
@@ -1086,13 +1065,13 @@ static int tridentfb_set_par(struct fb_info *info) | |||
1086 | break; | 1065 | break; |
1087 | } | 1066 | } |
1088 | 1067 | ||
1089 | t_inb(par, 0x3C8); | 1068 | t_inb(par, VGA_PEL_IW); |
1090 | t_inb(par, 0x3C6); | 1069 | t_inb(par, VGA_PEL_MSK); |
1091 | t_inb(par, 0x3C6); | 1070 | t_inb(par, VGA_PEL_MSK); |
1092 | t_inb(par, 0x3C6); | 1071 | t_inb(par, VGA_PEL_MSK); |
1093 | t_inb(par, 0x3C6); | 1072 | t_inb(par, VGA_PEL_MSK); |
1094 | t_outb(par, tmp, 0x3C6); | 1073 | t_outb(par, tmp, VGA_PEL_MSK); |
1095 | t_inb(par, 0x3C8); | 1074 | t_inb(par, VGA_PEL_IW); |
1096 | 1075 | ||
1097 | if (par->flatpanel) | 1076 | if (par->flatpanel) |
1098 | set_number_of_lines(par, info->var.yres); | 1077 | set_number_of_lines(par, info->var.yres); |
@@ -1116,12 +1095,12 @@ static int tridentfb_setcolreg(unsigned regno, unsigned red, unsigned green, | |||
1116 | return 1; | 1095 | return 1; |
1117 | 1096 | ||
1118 | if (bpp == 8) { | 1097 | if (bpp == 8) { |
1119 | t_outb(par, 0xFF, 0x3C6); | 1098 | t_outb(par, 0xFF, VGA_PEL_MSK); |
1120 | t_outb(par, regno, 0x3C8); | 1099 | t_outb(par, regno, VGA_PEL_IW); |
1121 | 1100 | ||
1122 | t_outb(par, red >> 10, 0x3C9); | 1101 | t_outb(par, red >> 10, VGA_PEL_D); |
1123 | t_outb(par, green >> 10, 0x3C9); | 1102 | t_outb(par, green >> 10, VGA_PEL_D); |
1124 | t_outb(par, blue >> 10, 0x3C9); | 1103 | t_outb(par, blue >> 10, VGA_PEL_D); |
1125 | 1104 | ||
1126 | } else if (regno < 16) { | 1105 | } else if (regno < 16) { |
1127 | if (bpp == 16) { /* RGB 565 */ | 1106 | if (bpp == 16) { /* RGB 565 */ |
@@ -1232,8 +1211,7 @@ static int __devinit trident_pci_probe(struct pci_dev *dev, | |||
1232 | /* If PCI id is 0x9660 then further detect chip type */ | 1211 | /* If PCI id is 0x9660 then further detect chip type */ |
1233 | 1212 | ||
1234 | if (chip_id == TGUI9660) { | 1213 | if (chip_id == TGUI9660) { |
1235 | outb(RevisionID, 0x3C4); | 1214 | revision = vga_io_rseq(RevisionID); |
1236 | revision = inb(0x3C5); | ||
1237 | 1215 | ||
1238 | switch (revision) { | 1216 | switch (revision) { |
1239 | case 0x22: | 1217 | case 0x22: |