aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/video/arkfb.c60
1 files changed, 34 insertions, 26 deletions
diff --git a/drivers/video/arkfb.c b/drivers/video/arkfb.c
index aded91b42c76..53c66e8dcb0b 100644
--- a/drivers/video/arkfb.c
+++ b/drivers/video/arkfb.c
@@ -473,32 +473,40 @@ static unsigned short dac_regs[4] = {0x3c8, 0x3c9, 0x3c6, 0x3c7};
473 473
474static void ark_dac_read_regs(void *data, u8 *code, int count) 474static void ark_dac_read_regs(void *data, u8 *code, int count)
475{ 475{
476 u8 regval = vga_rseq(NULL, 0x1C); 476 struct fb_info *info = data;
477 struct arkfb_info *par;
478 u8 regval;
477 479
480 par = info->par;
481 regval = vga_rseq(par->state.vgabase, 0x1C);
478 while (count != 0) 482 while (count != 0)
479 { 483 {
480 vga_wseq(NULL, 0x1C, regval | (code[0] & 4 ? 0x80 : 0)); 484 vga_wseq(par->state.vgabase, 0x1C, regval | (code[0] & 4 ? 0x80 : 0));
481 code[1] = vga_r(NULL, dac_regs[code[0] & 3]); 485 code[1] = vga_r(par->state.vgabase, dac_regs[code[0] & 3]);
482 count--; 486 count--;
483 code += 2; 487 code += 2;
484 } 488 }
485 489
486 vga_wseq(NULL, 0x1C, regval); 490 vga_wseq(par->state.vgabase, 0x1C, regval);
487} 491}
488 492
489static void ark_dac_write_regs(void *data, u8 *code, int count) 493static void ark_dac_write_regs(void *data, u8 *code, int count)
490{ 494{
491 u8 regval = vga_rseq(NULL, 0x1C); 495 struct fb_info *info = data;
496 struct arkfb_info *par;
497 u8 regval;
492 498
499 par = info->par;
500 regval = vga_rseq(par->state.vgabase, 0x1C);
493 while (count != 0) 501 while (count != 0)
494 { 502 {
495 vga_wseq(NULL, 0x1C, regval | (code[0] & 4 ? 0x80 : 0)); 503 vga_wseq(par->state.vgabase, 0x1C, regval | (code[0] & 4 ? 0x80 : 0));
496 vga_w(NULL, dac_regs[code[0] & 3], code[1]); 504 vga_w(par->state.vgabase, dac_regs[code[0] & 3], code[1]);
497 count--; 505 count--;
498 code += 2; 506 code += 2;
499 } 507 }
500 508
501 vga_wseq(NULL, 0x1C, regval); 509 vga_wseq(par->state.vgabase, 0x1C, regval);
502} 510}
503 511
504 512
@@ -514,8 +522,8 @@ static void ark_set_pixclock(struct fb_info *info, u32 pixclock)
514 } 522 }
515 523
516 /* Set VGA misc register */ 524 /* Set VGA misc register */
517 regval = vga_r(NULL, VGA_MIS_R); 525 regval = vga_r(par->state.vgabase, VGA_MIS_R);
518 vga_w(NULL, VGA_MIS_W, regval | VGA_MIS_ENB_PLL_LOAD); 526 vga_w(par->state.vgabase, VGA_MIS_W, regval | VGA_MIS_ENB_PLL_LOAD);
519} 527}
520 528
521 529
@@ -671,15 +679,15 @@ static int arkfb_set_par(struct fb_info *info)
671 svga_wseq_mask(par->state.vgabase, 0x10, 0x1F, 0x1F); /* enable linear framebuffer and full memory access */ 679 svga_wseq_mask(par->state.vgabase, 0x10, 0x1F, 0x1F); /* enable linear framebuffer and full memory access */
672 svga_wseq_mask(par->state.vgabase, 0x12, 0x03, 0x03); /* 4 MB linear framebuffer size */ 680 svga_wseq_mask(par->state.vgabase, 0x12, 0x03, 0x03); /* 4 MB linear framebuffer size */
673 681
674 vga_wseq(NULL, 0x13, info->fix.smem_start >> 16); 682 vga_wseq(par->state.vgabase, 0x13, info->fix.smem_start >> 16);
675 vga_wseq(NULL, 0x14, info->fix.smem_start >> 24); 683 vga_wseq(par->state.vgabase, 0x14, info->fix.smem_start >> 24);
676 vga_wseq(NULL, 0x15, 0); 684 vga_wseq(par->state.vgabase, 0x15, 0);
677 vga_wseq(NULL, 0x16, 0); 685 vga_wseq(par->state.vgabase, 0x16, 0);
678 686
679 /* Set the FIFO threshold register */ 687 /* Set the FIFO threshold register */
680 /* It is fascinating way to store 5-bit value in 8-bit register */ 688 /* It is fascinating way to store 5-bit value in 8-bit register */
681 regval = 0x10 | ((threshold & 0x0E) >> 1) | (threshold & 0x01) << 7 | (threshold & 0x10) << 1; 689 regval = 0x10 | ((threshold & 0x0E) >> 1) | (threshold & 0x01) << 7 | (threshold & 0x10) << 1;
682 vga_wseq(NULL, 0x18, regval); 690 vga_wseq(par->state.vgabase, 0x18, regval);
683 691
684 /* Set the offset register */ 692 /* Set the offset register */
685 pr_debug("fb%d: offset register : %d\n", info->node, offset_value); 693 pr_debug("fb%d: offset register : %d\n", info->node, offset_value);
@@ -708,30 +716,30 @@ static int arkfb_set_par(struct fb_info *info)
708 pr_debug("fb%d: text mode\n", info->node); 716 pr_debug("fb%d: text mode\n", info->node);
709 svga_set_textmode_vga_regs(par->state.vgabase); 717 svga_set_textmode_vga_regs(par->state.vgabase);
710 718
711 vga_wseq(NULL, 0x11, 0x10); /* basic VGA mode */ 719 vga_wseq(par->state.vgabase, 0x11, 0x10); /* basic VGA mode */
712 svga_wcrt_mask(par->state.vgabase, 0x46, 0x00, 0x04); /* 8bit pixel path */ 720 svga_wcrt_mask(par->state.vgabase, 0x46, 0x00, 0x04); /* 8bit pixel path */
713 dac_set_mode(par->dac, DAC_PSEUDO8_8); 721 dac_set_mode(par->dac, DAC_PSEUDO8_8);
714 722
715 break; 723 break;
716 case 1: 724 case 1:
717 pr_debug("fb%d: 4 bit pseudocolor\n", info->node); 725 pr_debug("fb%d: 4 bit pseudocolor\n", info->node);
718 vga_wgfx(NULL, VGA_GFX_MODE, 0x40); 726 vga_wgfx(par->state.vgabase, VGA_GFX_MODE, 0x40);
719 727
720 vga_wseq(NULL, 0x11, 0x10); /* basic VGA mode */ 728 vga_wseq(par->state.vgabase, 0x11, 0x10); /* basic VGA mode */
721 svga_wcrt_mask(par->state.vgabase, 0x46, 0x00, 0x04); /* 8bit pixel path */ 729 svga_wcrt_mask(par->state.vgabase, 0x46, 0x00, 0x04); /* 8bit pixel path */
722 dac_set_mode(par->dac, DAC_PSEUDO8_8); 730 dac_set_mode(par->dac, DAC_PSEUDO8_8);
723 break; 731 break;
724 case 2: 732 case 2:
725 pr_debug("fb%d: 4 bit pseudocolor, planar\n", info->node); 733 pr_debug("fb%d: 4 bit pseudocolor, planar\n", info->node);
726 734
727 vga_wseq(NULL, 0x11, 0x10); /* basic VGA mode */ 735 vga_wseq(par->state.vgabase, 0x11, 0x10); /* basic VGA mode */
728 svga_wcrt_mask(par->state.vgabase, 0x46, 0x00, 0x04); /* 8bit pixel path */ 736 svga_wcrt_mask(par->state.vgabase, 0x46, 0x00, 0x04); /* 8bit pixel path */
729 dac_set_mode(par->dac, DAC_PSEUDO8_8); 737 dac_set_mode(par->dac, DAC_PSEUDO8_8);
730 break; 738 break;
731 case 3: 739 case 3:
732 pr_debug("fb%d: 8 bit pseudocolor\n", info->node); 740 pr_debug("fb%d: 8 bit pseudocolor\n", info->node);
733 741
734 vga_wseq(NULL, 0x11, 0x16); /* 8bpp accel mode */ 742 vga_wseq(par->state.vgabase, 0x11, 0x16); /* 8bpp accel mode */
735 743
736 if (info->var.pixclock > 20000) { 744 if (info->var.pixclock > 20000) {
737 pr_debug("fb%d: not using multiplex\n", info->node); 745 pr_debug("fb%d: not using multiplex\n", info->node);
@@ -747,21 +755,21 @@ static int arkfb_set_par(struct fb_info *info)
747 case 4: 755 case 4:
748 pr_debug("fb%d: 5/5/5 truecolor\n", info->node); 756 pr_debug("fb%d: 5/5/5 truecolor\n", info->node);
749 757
750 vga_wseq(NULL, 0x11, 0x1A); /* 16bpp accel mode */ 758 vga_wseq(par->state.vgabase, 0x11, 0x1A); /* 16bpp accel mode */
751 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */ 759 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */
752 dac_set_mode(par->dac, DAC_RGB1555_16); 760 dac_set_mode(par->dac, DAC_RGB1555_16);
753 break; 761 break;
754 case 5: 762 case 5:
755 pr_debug("fb%d: 5/6/5 truecolor\n", info->node); 763 pr_debug("fb%d: 5/6/5 truecolor\n", info->node);
756 764
757 vga_wseq(NULL, 0x11, 0x1A); /* 16bpp accel mode */ 765 vga_wseq(par->state.vgabase, 0x11, 0x1A); /* 16bpp accel mode */
758 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */ 766 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */
759 dac_set_mode(par->dac, DAC_RGB0565_16); 767 dac_set_mode(par->dac, DAC_RGB0565_16);
760 break; 768 break;
761 case 6: 769 case 6:
762 pr_debug("fb%d: 8/8/8 truecolor\n", info->node); 770 pr_debug("fb%d: 8/8/8 truecolor\n", info->node);
763 771
764 vga_wseq(NULL, 0x11, 0x16); /* 8bpp accel mode ??? */ 772 vga_wseq(par->state.vgabase, 0x11, 0x16); /* 8bpp accel mode ??? */
765 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */ 773 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */
766 dac_set_mode(par->dac, DAC_RGB0888_16); 774 dac_set_mode(par->dac, DAC_RGB0888_16);
767 hmul = 3; 775 hmul = 3;
@@ -770,7 +778,7 @@ static int arkfb_set_par(struct fb_info *info)
770 case 7: 778 case 7:
771 pr_debug("fb%d: 8/8/8/8 truecolor\n", info->node); 779 pr_debug("fb%d: 8/8/8/8 truecolor\n", info->node);
772 780
773 vga_wseq(NULL, 0x11, 0x1E); /* 32bpp accel mode */ 781 vga_wseq(par->state.vgabase, 0x11, 0x1E); /* 32bpp accel mode */
774 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */ 782 svga_wcrt_mask(par->state.vgabase, 0x46, 0x04, 0x04); /* 16bit pixel path */
775 dac_set_mode(par->dac, DAC_RGB8888_16); 783 dac_set_mode(par->dac, DAC_RGB8888_16);
776 hmul = 2; 784 hmul = 2;
@@ -789,7 +797,7 @@ static int arkfb_set_par(struct fb_info *info)
789 /* Set interlaced mode start/end register */ 797 /* Set interlaced mode start/end register */
790 value = info->var.xres + info->var.left_margin + info->var.right_margin + info->var.hsync_len; 798 value = info->var.xres + info->var.left_margin + info->var.right_margin + info->var.hsync_len;
791 value = ((value * hmul / hdiv) / 8) - 5; 799 value = ((value * hmul / hdiv) / 8) - 5;
792 vga_wcrt(NULL, 0x42, (value + 1) / 2); 800 vga_wcrt(par->state.vgabase, 0x42, (value + 1) / 2);
793 801
794 memset_io(info->screen_base, 0x00, screen_size); 802 memset_io(info->screen_base, 0x00, screen_size);
795 /* Device and screen back on */ 803 /* Device and screen back on */
@@ -996,7 +1004,7 @@ static int __devinit ark_pci_probe(struct pci_dev *dev, const struct pci_device_
996 } 1004 }
997 1005
998 /* FIXME get memsize */ 1006 /* FIXME get memsize */
999 regval = vga_rseq(NULL, 0x10); 1007 regval = vga_rseq(par->state.vgabase, 0x10);
1000 info->screen_size = (1 << (regval >> 6)) << 20; 1008 info->screen_size = (1 << (regval >> 6)) << 20;
1001 info->fix.smem_len = info->screen_size; 1009 info->fix.smem_len = info->screen_size;
1002 1010