Lines Matching refs:wm
1996 static u32 evergreen_dram_bandwidth(struct evergreen_wm_params *wm) in evergreen_dram_bandwidth() argument
2004 yclk.full = dfixed_const(wm->yclk); in evergreen_dram_bandwidth()
2006 dram_channels.full = dfixed_const(wm->dram_channels * 4); in evergreen_dram_bandwidth()
2016 static u32 evergreen_dram_bandwidth_for_display(struct evergreen_wm_params *wm) in evergreen_dram_bandwidth_for_display() argument
2024 yclk.full = dfixed_const(wm->yclk); in evergreen_dram_bandwidth_for_display()
2026 dram_channels.full = dfixed_const(wm->dram_channels * 4); in evergreen_dram_bandwidth_for_display()
2036 static u32 evergreen_data_return_bandwidth(struct evergreen_wm_params *wm) in evergreen_data_return_bandwidth() argument
2044 sclk.full = dfixed_const(wm->sclk); in evergreen_data_return_bandwidth()
2056 static u32 evergreen_dmif_request_bandwidth(struct evergreen_wm_params *wm) in evergreen_dmif_request_bandwidth() argument
2064 disp_clk.full = dfixed_const(wm->disp_clk); in evergreen_dmif_request_bandwidth()
2076 static u32 evergreen_available_bandwidth(struct evergreen_wm_params *wm) in evergreen_available_bandwidth() argument
2079 u32 dram_bandwidth = evergreen_dram_bandwidth(wm); in evergreen_available_bandwidth()
2080 u32 data_return_bandwidth = evergreen_data_return_bandwidth(wm); in evergreen_available_bandwidth()
2081 u32 dmif_req_bandwidth = evergreen_dmif_request_bandwidth(wm); in evergreen_available_bandwidth()
2086 static u32 evergreen_average_bandwidth(struct evergreen_wm_params *wm) in evergreen_average_bandwidth() argument
2099 line_time.full = dfixed_const(wm->active_time + wm->blank_time); in evergreen_average_bandwidth()
2101 bpp.full = dfixed_const(wm->bytes_per_pixel); in evergreen_average_bandwidth()
2102 src_width.full = dfixed_const(wm->src_width); in evergreen_average_bandwidth()
2104 bandwidth.full = dfixed_mul(bandwidth, wm->vsc); in evergreen_average_bandwidth()
2110 static u32 evergreen_latency_watermark(struct evergreen_wm_params *wm) in evergreen_latency_watermark() argument
2114 u32 available_bandwidth = evergreen_available_bandwidth(wm); in evergreen_latency_watermark()
2117 u32 dc_latency = 40000000 / wm->disp_clk; /* dc pipe latency */ in evergreen_latency_watermark()
2118 u32 other_heads_data_return_time = ((wm->num_heads + 1) * worst_chunk_return_time) + in evergreen_latency_watermark()
2119 (wm->num_heads * cursor_line_pair_return_time); in evergreen_latency_watermark()
2124 if (wm->num_heads == 0) in evergreen_latency_watermark()
2129 if ((wm->vsc.full > a.full) || in evergreen_latency_watermark()
2130 ((wm->vsc.full > b.full) && (wm->vtaps >= 3)) || in evergreen_latency_watermark()
2131 (wm->vtaps >= 5) || in evergreen_latency_watermark()
2132 ((wm->vsc.full >= a.full) && wm->interlaced)) in evergreen_latency_watermark()
2138 b.full = dfixed_const(wm->num_heads); in evergreen_latency_watermark()
2142 c.full = dfixed_const(wm->disp_clk); in evergreen_latency_watermark()
2144 c.full = dfixed_const(wm->bytes_per_pixel); in evergreen_latency_watermark()
2149 a.full = dfixed_const(max_src_lines_per_dst_line * wm->src_width * wm->bytes_per_pixel); in evergreen_latency_watermark()
2156 if (line_fill_time < wm->active_time) in evergreen_latency_watermark()
2159 return latency + (line_fill_time - wm->active_time); in evergreen_latency_watermark()
2163 …atic bool evergreen_average_bandwidth_vs_dram_bandwidth_for_display(struct evergreen_wm_params *wm) in evergreen_average_bandwidth_vs_dram_bandwidth_for_display() argument
2165 if (evergreen_average_bandwidth(wm) <= in evergreen_average_bandwidth_vs_dram_bandwidth_for_display()
2166 (evergreen_dram_bandwidth_for_display(wm) / wm->num_heads)) in evergreen_average_bandwidth_vs_dram_bandwidth_for_display()
2172 static bool evergreen_average_bandwidth_vs_available_bandwidth(struct evergreen_wm_params *wm) in evergreen_average_bandwidth_vs_available_bandwidth() argument
2174 if (evergreen_average_bandwidth(wm) <= in evergreen_average_bandwidth_vs_available_bandwidth()
2175 (evergreen_available_bandwidth(wm) / wm->num_heads)) in evergreen_average_bandwidth_vs_available_bandwidth()
2181 static bool evergreen_check_latency_hiding(struct evergreen_wm_params *wm) in evergreen_check_latency_hiding() argument
2183 u32 lb_partitions = wm->lb_size / wm->src_width; in evergreen_check_latency_hiding()
2184 u32 line_time = wm->active_time + wm->blank_time; in evergreen_check_latency_hiding()
2190 if (wm->vsc.full > a.full) in evergreen_check_latency_hiding()
2193 if (lb_partitions <= (wm->vtaps + 1)) in evergreen_check_latency_hiding()
2199 latency_hiding = (latency_tolerant_lines * line_time + wm->blank_time); in evergreen_check_latency_hiding()
2201 if (evergreen_latency_watermark(wm) <= latency_hiding) in evergreen_check_latency_hiding()