.. | .. |
---|
23 | 23 | * |
---|
24 | 24 | */ |
---|
25 | 25 | |
---|
| 26 | +#include <linux/slab.h> |
---|
| 27 | + |
---|
26 | 28 | #include "dm_services.h" |
---|
27 | 29 | #include "dcn10_opp.h" |
---|
28 | 30 | #include "reg_helper.h" |
---|
.. | .. |
---|
166 | 168 | REG_UPDATE(FMT_CONTROL, FMT_PIXEL_ENCODING, 0); |
---|
167 | 169 | break; |
---|
168 | 170 | case PIXEL_ENCODING_YCBCR422: |
---|
169 | | - REG_UPDATE(FMT_CONTROL, FMT_PIXEL_ENCODING, 1); |
---|
| 171 | + REG_UPDATE_3(FMT_CONTROL, |
---|
| 172 | + FMT_PIXEL_ENCODING, 1, |
---|
| 173 | + FMT_SUBSAMPLING_MODE, 2, |
---|
| 174 | + FMT_CBCR_BIT_REDUCTION_BYPASS, 0); |
---|
170 | 175 | break; |
---|
171 | 176 | case PIXEL_ENCODING_YCBCR420: |
---|
172 | 177 | REG_UPDATE(FMT_CONTROL, FMT_PIXEL_ENCODING, 2); |
---|
.. | .. |
---|
234 | 239 | REG_UPDATE_2(FMT_DYNAMIC_EXP_CNTL, |
---|
235 | 240 | FMT_DYNAMIC_EXP_EN, 0, |
---|
236 | 241 | FMT_DYNAMIC_EXP_MODE, 0); |
---|
| 242 | + |
---|
| 243 | + if (opp->dyn_expansion == DYN_EXPANSION_DISABLE) |
---|
| 244 | + return; |
---|
237 | 245 | |
---|
238 | 246 | /*00 - 10-bit -> 12-bit dynamic expansion*/ |
---|
239 | 247 | /*01 - 8-bit -> 12-bit dynamic expansion*/ |
---|
.. | .. |
---|
365 | 373 | */ |
---|
366 | 374 | REG_UPDATE(OPPBUF_CONTROL, OPPBUF_PIXEL_REPETITION, oppbuf->pixel_repetition); |
---|
367 | 375 | |
---|
| 376 | + /* Controls the number of padded pixels at the end of a segment */ |
---|
| 377 | + if (REG(OPPBUF_CONTROL1)) |
---|
| 378 | + REG_UPDATE(OPPBUF_CONTROL1, OPPBUF_NUM_SEGMENT_PADDED_PIXELS, oppbuf->num_segment_padded_pixels); |
---|
368 | 379 | } |
---|
369 | 380 | |
---|
370 | 381 | void opp1_pipe_clock_control(struct output_pixel_processor *opp, bool enable) |
---|
.. | .. |
---|
391 | 402 | .opp_program_bit_depth_reduction = opp1_program_bit_depth_reduction, |
---|
392 | 403 | .opp_program_stereo = opp1_program_stereo, |
---|
393 | 404 | .opp_pipe_clock_control = opp1_pipe_clock_control, |
---|
| 405 | + .opp_set_disp_pattern_generator = NULL, |
---|
| 406 | + .dpg_is_blanked = NULL, |
---|
394 | 407 | .opp_destroy = opp1_destroy |
---|
395 | 408 | }; |
---|
396 | 409 | |
---|