diff options
Diffstat (limited to 'drivers/video/intelfb/intelfbhw.c')
-rw-r--r-- | drivers/video/intelfb/intelfbhw.c | 66 |
1 files changed, 31 insertions, 35 deletions
diff --git a/drivers/video/intelfb/intelfbhw.c b/drivers/video/intelfb/intelfbhw.c index 92bdde8f9b23..2537880b2420 100644 --- a/drivers/video/intelfb/intelfbhw.c +++ b/drivers/video/intelfb/intelfbhw.c | |||
@@ -566,7 +566,7 @@ static int calc_vclock3(int index, int m, int n, int p) | |||
566 | return 0; | 566 | return 0; |
567 | return PLL_REFCLK * m / n / p; | 567 | return PLL_REFCLK * m / n / p; |
568 | } | 568 | } |
569 | 569 | ||
570 | static int calc_vclock(int index, int m1, int m2, int n, int p1, int p2) | 570 | static int calc_vclock(int index, int m1, int m2, int n, int p1, int p2) |
571 | { | 571 | { |
572 | switch(index) | 572 | switch(index) |
@@ -578,7 +578,7 @@ static int calc_vclock(int index, int m1, int m2, int n, int p1, int p2) | |||
578 | ((p1)) * (p2 ? 10 : 5))); | 578 | ((p1)) * (p2 ? 10 : 5))); |
579 | case PLLS_I8xx: | 579 | case PLLS_I8xx: |
580 | default: | 580 | default: |
581 | return ((PLL_REFCLK * (5 * (m1 + 2) + (m2 + 2)) / (n + 2) / | 581 | return ((PLL_REFCLK * (5 * (m1 + 2) + (m2 + 2)) / (n + 2) / |
582 | ((p1+2) * (1 << (p2 + 1))))); | 582 | ((p1+2) * (1 << (p2 + 1))))); |
583 | } | 583 | } |
584 | } | 584 | } |
@@ -608,7 +608,7 @@ intelfbhw_print_hw_state(struct intelfb_info *dinfo, struct intelfb_hwstate *hw) | |||
608 | p2 = (hw->vga_pd >> VGAPD_0_P2_SHIFT) & DPLL_P2_MASK; | 608 | p2 = (hw->vga_pd >> VGAPD_0_P2_SHIFT) & DPLL_P2_MASK; |
609 | printk(" VGA0: (m1, m2, n, p1, p2) = (%d, %d, %d, %d, %d)\n", | 609 | printk(" VGA0: (m1, m2, n, p1, p2) = (%d, %d, %d, %d, %d)\n", |
610 | m1, m2, n, p1, p2); | 610 | m1, m2, n, p1, p2); |
611 | printk(" VGA0: clock is %d\n", | 611 | printk(" VGA0: clock is %d\n", |
612 | calc_vclock(index, m1, m2, n, p1, p2)); | 612 | calc_vclock(index, m1, m2, n, p1, p2)); |
613 | 613 | ||
614 | n = (hw->vga1_divisor >> FP_N_DIVISOR_SHIFT) & FP_DIVISOR_MASK; | 614 | n = (hw->vga1_divisor >> FP_N_DIVISOR_SHIFT) & FP_DIVISOR_MASK; |
@@ -740,7 +740,7 @@ intelfbhw_print_hw_state(struct intelfb_info *dinfo, struct intelfb_hwstate *hw) | |||
740 | for (i = 0; i < 8; i++) | 740 | for (i = 0; i < 8; i++) |
741 | printk(" FENCE%d 0x%08x\n", i, | 741 | printk(" FENCE%d 0x%08x\n", i, |
742 | hw->fence[i]); | 742 | hw->fence[i]); |
743 | 743 | ||
744 | printk(" INSTPM 0x%08x\n", hw->instpm); | 744 | printk(" INSTPM 0x%08x\n", hw->instpm); |
745 | printk(" MEM_MODE 0x%08x\n", hw->mem_mode); | 745 | printk(" MEM_MODE 0x%08x\n", hw->mem_mode); |
746 | printk(" FW_BLC_0 0x%08x\n", hw->fw_blc_0); | 746 | printk(" FW_BLC_0 0x%08x\n", hw->fw_blc_0); |
@@ -750,7 +750,7 @@ intelfbhw_print_hw_state(struct intelfb_info *dinfo, struct intelfb_hwstate *hw) | |||
750 | #endif | 750 | #endif |
751 | } | 751 | } |
752 | 752 | ||
753 | 753 | ||
754 | 754 | ||
755 | /* Split the M parameter into M1 and M2. */ | 755 | /* Split the M parameter into M1 and M2. */ |
756 | static int | 756 | static int |
@@ -759,18 +759,15 @@ splitm(int index, unsigned int m, unsigned int *retm1, unsigned int *retm2) | |||
759 | int m1, m2; | 759 | int m1, m2; |
760 | int testm; | 760 | int testm; |
761 | /* no point optimising too much - brute force m */ | 761 | /* no point optimising too much - brute force m */ |
762 | for (m1 = plls[index].min_m1; m1 < plls[index].max_m1+1; m1++) | 762 | for (m1 = plls[index].min_m1; m1 < plls[index].max_m1+1; m1++) { |
763 | { | 763 | for (m2 = plls[index].min_m2; m2 < plls[index].max_m2+1; m2++) { |
764 | for (m2 = plls[index].min_m2; m2 < plls[index].max_m2+1; m2++) | 764 | testm = ( 5 * ( m1 + 2 )) + (m2 + 2); |
765 | { | 765 | if (testm == m) { |
766 | testm = ( 5 * ( m1 + 2 )) + (m2 + 2); | 766 | *retm1 = (unsigned int)m1; |
767 | if (testm == m) | 767 | *retm2 = (unsigned int)m2; |
768 | { | 768 | return 0; |
769 | *retm1 = (unsigned int)m1; | 769 | } |
770 | *retm2 = (unsigned int)m2; | 770 | } |
771 | return 0; | ||
772 | } | ||
773 | } | ||
774 | } | 771 | } |
775 | return 1; | 772 | return 1; |
776 | } | 773 | } |
@@ -781,8 +778,7 @@ splitp(int index, unsigned int p, unsigned int *retp1, unsigned int *retp2) | |||
781 | { | 778 | { |
782 | int p1, p2; | 779 | int p1, p2; |
783 | 780 | ||
784 | if (index == PLLS_I9xx) | 781 | if (index == PLLS_I9xx) { |
785 | { | ||
786 | switch (p) { | 782 | switch (p) { |
787 | case 10: | 783 | case 10: |
788 | p1 = 2; | 784 | p1 = 2; |
@@ -803,8 +799,7 @@ splitp(int index, unsigned int p, unsigned int *retp1, unsigned int *retp2) | |||
803 | return 0; | 799 | return 0; |
804 | } | 800 | } |
805 | 801 | ||
806 | if (index == PLLS_I8xx) | 802 | if (index == PLLS_I8xx) { |
807 | { | ||
808 | if (p % 4 == 0) | 803 | if (p % 4 == 0) |
809 | p2 = 1; | 804 | p2 = 1; |
810 | else | 805 | else |
@@ -814,7 +809,9 @@ splitp(int index, unsigned int p, unsigned int *retp1, unsigned int *retp2) | |||
814 | p2 = 0; | 809 | p2 = 0; |
815 | p1 = (p / (1 << (p2 + 1))) - 2; | 810 | p1 = (p / (1 << (p2 + 1))) - 2; |
816 | } | 811 | } |
817 | if (p1 < plls[index].min_p1 || p1 > plls[index].max_p1 || (p1 + 2) * (1 << (p2 + 1)) != p) { | 812 | if (p1 < plls[index].min_p1 || |
813 | p1 > plls[index].max_p1 || | ||
814 | (p1 + 2) * (1 << (p2 + 1)) != p) { | ||
818 | return 1; | 815 | return 1; |
819 | } else { | 816 | } else { |
820 | *retp1 = (unsigned int)p1; | 817 | *retp1 = (unsigned int)p1; |
@@ -858,14 +855,13 @@ calc_pll_params(int index, int clock, u32 *retm1, u32 *retm2, u32 *retn, u32 *re | |||
858 | if (p_max > plls[index].max_p) | 855 | if (p_max > plls[index].max_p) |
859 | p_max = plls[index].max_p; | 856 | p_max = plls[index].max_p; |
860 | 857 | ||
861 | if (clock < PLL_REFCLK && index==PLLS_I9xx) | 858 | if (clock < PLL_REFCLK && index == PLLS_I9xx) { |
862 | { | 859 | p_min = 10; |
863 | p_min = 10; | 860 | p_max = 20; |
864 | p_max = 20; | 861 | /* this makes 640x480 work it really shouldn't |
865 | /* this makes 640x480 work it really shouldn't | 862 | - SOMEONE WITHOUT DOCS WOZ HERE */ |
866 | - SOMEONE WITHOUT DOCS WOZ HERE */ | 863 | if (clock < 30000) |
867 | if (clock < 30000) | 864 | clock *= 4; |
868 | clock *= 4; | ||
869 | } | 865 | } |
870 | 866 | ||
871 | DBG_MSG("p range is %d-%d (%d)\n", p_min, p_max, p_inc); | 867 | DBG_MSG("p range is %d-%d (%d)\n", p_min, p_max, p_inc); |
@@ -925,7 +921,7 @@ calc_pll_params(int index, int clock, u32 *retm1, u32 *retm2, u32 *retn, u32 *re | |||
925 | DBG_MSG("m, n, p: %d (%d,%d), %d (%d), %d (%d,%d), " | 921 | DBG_MSG("m, n, p: %d (%d,%d), %d (%d), %d (%d,%d), " |
926 | "f: %d (%d), VCO: %d\n", | 922 | "f: %d (%d), VCO: %d\n", |
927 | m, m1, m2, n, n1, p, p1, p2, | 923 | m, m1, m2, n, n1, p, p1, p2, |
928 | calc_vclock3(index, m, n, p), | 924 | calc_vclock3(index, m, n, p), |
929 | calc_vclock(index, m1, m2, n1, p1, p2), | 925 | calc_vclock(index, m1, m2, n1, p1, p2), |
930 | calc_vclock3(index, m, n, p) * p); | 926 | calc_vclock3(index, m, n, p) * p); |
931 | *retm1 = m1; | 927 | *retm1 = m1; |
@@ -1030,7 +1026,8 @@ intelfbhw_mode_to_hw(struct intelfb_info *dinfo, struct intelfb_hwstate *hw, | |||
1030 | /* Desired clock in kHz */ | 1026 | /* Desired clock in kHz */ |
1031 | clock_target = 1000000000 / var->pixclock; | 1027 | clock_target = 1000000000 / var->pixclock; |
1032 | 1028 | ||
1033 | if (calc_pll_params(dinfo->pll_index, clock_target, &m1, &m2, &n, &p1, &p2, &clock)) { | 1029 | if (calc_pll_params(dinfo->pll_index, clock_target, &m1, &m2, |
1030 | &n, &p1, &p2, &clock)) { | ||
1034 | WRN_MSG("calc_pll_params failed\n"); | 1031 | WRN_MSG("calc_pll_params failed\n"); |
1035 | return 1; | 1032 | return 1; |
1036 | } | 1033 | } |
@@ -1263,14 +1260,13 @@ intelfbhw_program_mode(struct intelfb_info *dinfo, | |||
1263 | OUTREG(pipe_conf_reg, tmp); | 1260 | OUTREG(pipe_conf_reg, tmp); |
1264 | 1261 | ||
1265 | count = 0; | 1262 | count = 0; |
1266 | do{ | 1263 | do { |
1267 | tmp_val[count%3] = INREG(0x70000); | 1264 | tmp_val[count%3] = INREG(0x70000); |
1268 | if ((tmp_val[0] == tmp_val[1]) && (tmp_val[1]==tmp_val[2])) | 1265 | if ((tmp_val[0] == tmp_val[1]) && (tmp_val[1]==tmp_val[2])) |
1269 | break; | 1266 | break; |
1270 | count++; | 1267 | count++; |
1271 | udelay(1); | 1268 | udelay(1); |
1272 | if (count % 200 == 0) | 1269 | if (count % 200 == 0) { |
1273 | { | ||
1274 | tmp = INREG(pipe_conf_reg); | 1270 | tmp = INREG(pipe_conf_reg); |
1275 | tmp &= ~PIPECONF_ENABLE; | 1271 | tmp &= ~PIPECONF_ENABLE; |
1276 | OUTREG(pipe_conf_reg, tmp); | 1272 | OUTREG(pipe_conf_reg, tmp); |