Lines Matching full:m2
37 } dot, vco, n, m, m1, m2, p, p1; member
50 .m2 = { .min = 6, .max = 16 },
63 .m2 = { .min = 6, .max = 16 },
76 .m2 = { .min = 6, .max = 16 },
89 .m2 = { .min = 3, .max = 7 },
102 .m2 = { .min = 3, .max = 7 },
116 .m2 = { .min = 5, .max = 11 },
131 .m2 = { .min = 5, .max = 11 },
144 .m2 = { .min = 5, .max = 11 },
158 .m2 = { .min = 5, .max = 11 },
172 /* Pineview only has one combined m divider, which we treat as m2. */
174 .m2 = { .min = 0, .max = 254 },
187 .m2 = { .min = 0, .max = 254 },
196 * We calculate clock using (register_value + 2) for N/M1/M2, so here
205 .m2 = { .min = 5, .max = 9 },
218 .m2 = { .min = 5, .max = 9 },
231 .m2 = { .min = 5, .max = 9 },
245 .m2 = { .min = 5, .max = 9 },
258 .m2 = { .min = 5, .max = 9 },
276 .m2 = { .min = 11, .max = 156 },
292 .m2 = { .min = 24 << 22, .max = 175 << 22 },
302 /* FIXME: find real m2 limits */
303 .m2 = { .min = 2 << 22, .max = 255 << 22 },
319 clock->m = clock->m2 + 2; in pnv_calc_dpll_params()
332 return 5 * (dpll->m1 + 2) + (dpll->m2 + 2); in i9xx_dpll_compute_m()
350 clock->m = clock->m1 * clock->m2; in vlv_calc_dpll_params()
363 clock->m = clock->m1 * clock->m2; in chv_calc_dpll_params()
441 clock.m2 = (fp & FP_M2_PINEVIEW_DIV_MASK) >> FP_M2_DIV_SHIFT; in i9xx_crtc_clock_get()
444 clock.m2 = (fp & FP_M2_DIV_MASK) >> FP_M2_DIV_SHIFT; in i9xx_crtc_clock_get()
534 clock.m2 = REG_FIELD_GET(DPIO_M2_DIV_MASK, tmp); in vlv_crtc_clock_get()
566 clock.m2 = REG_FIELD_GET(DPIO_CHV_M2_DIV_MASK, pll_dw0) << 22; in chv_crtc_clock_get()
568 clock.m2 |= REG_FIELD_GET(DPIO_CHV_M2_FRAC_DIV_MASK, pll_dw2); in chv_crtc_clock_get()
588 if (clock->m2 < limit->m2.min || limit->m2.max < clock->m2) in intel_pll_is_valid()
596 if (clock->m1 <= clock->m2) in intel_pll_is_valid()
669 for (clock.m2 = limit->m2.min; in i9xx_find_best_dpll()
670 clock.m2 <= limit->m2.max; clock.m2++) { in i9xx_find_best_dpll()
671 if (clock.m2 >= clock.m1) in i9xx_find_best_dpll()
727 for (clock.m2 = limit->m2.min; in pnv_find_best_dpll()
728 clock.m2 <= limit->m2.max; clock.m2++) { in pnv_find_best_dpll()
787 /* based on hardware requirement, prefer larger m1,m2 */ in g4x_find_best_dpll()
790 for (clock.m2 = limit->m2.max; in g4x_find_best_dpll()
791 clock.m2 >= limit->m2.min; clock.m2--) { in g4x_find_best_dpll()
883 /* based on hardware requirement, prefer bigger m1,m2 values */ in vlv_find_best_dpll()
887 clock.m2 = DIV_ROUND_CLOSEST(target * clock.p * clock.n, in vlv_find_best_dpll()
929 u64 m2; in chv_find_best_dpll() local
951 m2 = DIV_ROUND_CLOSEST_ULL(mul_u32_u32(target, clock.p * clock.n) << 22, in chv_find_best_dpll()
954 if (m2 > INT_MAX/clock.m1) in chv_find_best_dpll()
957 clock.m2 = m2; in chv_find_best_dpll()
990 return dpll->n << 16 | dpll->m1 << 8 | dpll->m2; in i9xx_dpll_compute_fp()
995 return (1 << dpll->n) << 16 | dpll->m2; in pnv_dpll_compute_fp()
1948 DPIO_M2_DIV(clock->m2) | in vlv_prepare_pll()
2055 m2_frac = clock->m2 & 0x3fffff; in chv_prepare_pll()
2066 /* Feedback post-divider - m2 */ in chv_prepare_pll()
2068 DPIO_CHV_M2_DIV(clock->m2 >> 22)); in chv_prepare_pll()
2075 /* M2 fraction division */ in chv_prepare_pll()
2079 /* M2 fraction division enable */ in chv_prepare_pll()