Commit e994340b authored by Arun Pandey's avatar Arun Pandey Committed by Alex Deucher

drm/amd/display: Added Opp and Diags Interface for P to I

Signed-off-by: default avatarArun Pandey <Arun.Pandey@amd.com>
Reviewed-by: default avatarCharlene Liu <Charlene.Liu@amd.com>
Acked-by: default avatarHarry Wentland <harry.wentland@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 949785b5
...@@ -431,13 +431,13 @@ static enum dc_status dcn10_prog_pixclk_crtc_otg( ...@@ -431,13 +431,13 @@ static enum dc_status dcn10_prog_pixclk_crtc_otg(
struct dc *dc) struct dc *dc)
{ {
struct dc_stream_state *stream = pipe_ctx->stream; struct dc_stream_state *stream = pipe_ctx->stream;
struct mpc *mpc = dc->res_pool->mpc;
enum dc_color_space color_space; enum dc_color_space color_space;
struct tg_color black_color = {0}; struct tg_color black_color = {0};
bool enableStereo = stream->timing.timing_3d_format == TIMING_3D_FORMAT_NONE ? bool enableStereo = stream->timing.timing_3d_format == TIMING_3D_FORMAT_NONE ?
false:true; false:true;
bool rightEyePolarity = stream->timing.flags.RIGHT_EYE_3D_POLARITY; bool rightEyePolarity = stream->timing.flags.RIGHT_EYE_3D_POLARITY;
/* by upper caller loop, pipe0 is parent pipe and be called first. /* by upper caller loop, pipe0 is parent pipe and be called first.
* back end is set up by for pipe0. Other children pipe share back end * back end is set up by for pipe0. Other children pipe share back end
* with pipe 0. No program is needed. * with pipe 0. No program is needed.
......
...@@ -335,7 +335,7 @@ void mpc10_update_blend_mode( ...@@ -335,7 +335,7 @@ void mpc10_update_blend_mode(
MPCC_ALPHA_MULTIPLIED_MODE, cfg->pre_multiplied_alpha); MPCC_ALPHA_MULTIPLIED_MODE, cfg->pre_multiplied_alpha);
} }
static int mpc10_get_opp_id(struct mpc *mpc, int mpcc_id) int mpc10_get_opp_id(struct mpc *mpc, int mpcc_id)
{ {
struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc); struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
int opp_id = 0xF; int opp_id = 0xF;
......
...@@ -134,5 +134,6 @@ void mpc10_assert_idle_mpcc( ...@@ -134,5 +134,6 @@ void mpc10_assert_idle_mpcc(
void mpc10_update_blend_mode( void mpc10_update_blend_mode(
struct mpc *mpc, struct mpc *mpc,
struct mpcc_cfg *cfg); struct mpcc_cfg *cfg);
int mpc10_get_opp_id(struct mpc *mpc, int mpcc_id);
#endif #endif
...@@ -38,25 +38,6 @@ ...@@ -38,25 +38,6 @@
oppn10->base.ctx oppn10->base.ctx
enum dpg_mode {
/* RGB colour block mode */
DPG_MODE_RGB_COLOUR_BLOCK,
/* YCbCr-601 colour block mode */
DPG_MODE_YCBCR_601_COLOUR_BLOCK,
/* YCbCr-709 colour block mode */
DPG_MODE_YCBCR_709_COLOUR_BLOCK,
/* Vertical bar mode */
DPG_MODE_VERTICAL_BAR,
/* Horizontal bar mode */
DPG_MODE_HORIZONTAL_BAR,
/* Single ramp mode */
DPG_MODE_RGB_SINGLE_RAMP,
/* Dual ramp mode */
DPG_MODE_RGB_DUAL_RAMP,
/* RGB XR BIAS mode */
DPG_MODE_RGB_XR_BIAS
};
/************* FORMATTER ************/ /************* FORMATTER ************/
/** /**
...@@ -154,7 +135,7 @@ static void opp1_set_spatial_dither( ...@@ -154,7 +135,7 @@ static void opp1_set_spatial_dither(
FMT_RGB_RANDOM_ENABLE, params->flags.RGB_RANDOM); FMT_RGB_RANDOM_ENABLE, params->flags.RGB_RANDOM);
} }
static void opp1_program_bit_depth_reduction( void opp1_program_bit_depth_reduction(
struct output_pixel_processor *opp, struct output_pixel_processor *opp,
const struct bit_depth_reduction_params *params) const struct bit_depth_reduction_params *params)
{ {
...@@ -242,7 +223,7 @@ static void opp1_set_clamping( ...@@ -242,7 +223,7 @@ static void opp1_set_clamping(
} }
static void opp1_set_dyn_expansion( void opp1_set_dyn_expansion(
struct output_pixel_processor *opp, struct output_pixel_processor *opp,
enum dc_color_space color_sp, enum dc_color_space color_sp,
enum dc_color_depth color_dpth, enum dc_color_depth color_dpth,
...@@ -292,7 +273,7 @@ static void opp1_program_clamping_and_pixel_encoding( ...@@ -292,7 +273,7 @@ static void opp1_program_clamping_and_pixel_encoding(
opp1_set_pixel_encoding(oppn10, params); opp1_set_pixel_encoding(oppn10, params);
} }
static void opp1_program_fmt( void opp1_program_fmt(
struct output_pixel_processor *opp, struct output_pixel_processor *opp,
struct bit_depth_reduction_params *fmt_bit_depth, struct bit_depth_reduction_params *fmt_bit_depth,
struct clamping_and_pixel_encoding_params *clamping) struct clamping_and_pixel_encoding_params *clamping)
...@@ -315,7 +296,7 @@ static void opp1_program_fmt( ...@@ -315,7 +296,7 @@ static void opp1_program_fmt(
return; return;
} }
static void opp1_set_stereo_polarity( void opp1_set_stereo_polarity(
struct output_pixel_processor *opp, struct output_pixel_processor *opp,
bool enable, bool rightEyePolarity) bool enable, bool rightEyePolarity)
{ {
...@@ -328,7 +309,7 @@ static void opp1_set_stereo_polarity( ...@@ -328,7 +309,7 @@ static void opp1_set_stereo_polarity(
/* Constructor, Destructor */ /* Constructor, Destructor */
/*****************************************/ /*****************************************/
static void opp1_destroy(struct output_pixel_processor **opp) void opp1_destroy(struct output_pixel_processor **opp)
{ {
kfree(TO_DCN10_OPP(*opp)); kfree(TO_DCN10_OPP(*opp));
*opp = NULL; *opp = NULL;
......
...@@ -74,18 +74,6 @@ ...@@ -74,18 +74,6 @@
OPP_MASK_SH_LIST_DCN(mask_sh) OPP_MASK_SH_LIST_DCN(mask_sh)
#define OPP_DCN10_REG_FIELD_LIST(type) \ #define OPP_DCN10_REG_FIELD_LIST(type) \
type DPG_EN; \
type DPG_MODE; \
type DPG_VRES; \
type DPG_HRES; \
type DPG_ACTIVE_WIDTH; \
type DPG_ACTIVE_HEIGHT; \
type DPG_COLOUR0_R_CR; \
type DPG_COLOUR1_R_CR; \
type DPG_COLOUR0_B_CB; \
type DPG_COLOUR1_B_CB; \
type DPG_COLOUR0_G_Y; \
type DPG_COLOUR1_G_Y; \
type FMT_TRUNCATE_EN; \ type FMT_TRUNCATE_EN; \
type FMT_TRUNCATE_DEPTH; \ type FMT_TRUNCATE_DEPTH; \
type FMT_TRUNCATE_MODE; \ type FMT_TRUNCATE_MODE; \
...@@ -118,11 +106,6 @@ struct dcn10_opp_mask { ...@@ -118,11 +106,6 @@ struct dcn10_opp_mask {
}; };
struct dcn10_opp_registers { struct dcn10_opp_registers {
uint32_t DPG_CONTROL;
uint32_t DPG_DIMENSIONS;
uint32_t DPG_COLOUR_B_CB;
uint32_t DPG_COLOUR_G_Y;
uint32_t DPG_COLOUR_R_CR;
uint32_t FMT_BIT_DEPTH_CONTROL; uint32_t FMT_BIT_DEPTH_CONTROL;
uint32_t FMT_CONTROL; uint32_t FMT_CONTROL;
uint32_t FMT_DITHER_RAND_R_SEED; uint32_t FMT_DITHER_RAND_R_SEED;
...@@ -150,4 +133,25 @@ void dcn10_opp_construct(struct dcn10_opp *oppn10, ...@@ -150,4 +133,25 @@ void dcn10_opp_construct(struct dcn10_opp *oppn10,
const struct dcn10_opp_shift *opp_shift, const struct dcn10_opp_shift *opp_shift,
const struct dcn10_opp_mask *opp_mask); const struct dcn10_opp_mask *opp_mask);
void opp1_set_dyn_expansion(
struct output_pixel_processor *opp,
enum dc_color_space color_sp,
enum dc_color_depth color_dpth,
enum signal_type signal);
void opp1_program_fmt(
struct output_pixel_processor *opp,
struct bit_depth_reduction_params *fmt_bit_depth,
struct clamping_and_pixel_encoding_params *clamping);
void opp1_program_bit_depth_reduction(
struct output_pixel_processor *opp,
const struct bit_depth_reduction_params *params);
void opp1_set_stereo_polarity(
struct output_pixel_processor *opp,
bool enable, bool rightEyePolarity);
void opp1_destroy(struct output_pixel_processor **opp);
#endif #endif
...@@ -281,6 +281,21 @@ struct opp_funcs { ...@@ -281,6 +281,21 @@ struct opp_funcs {
bool enable, bool enable,
bool rightEyePolarity); bool rightEyePolarity);
void (*opp_set_test_pattern)(
struct output_pixel_processor *opp,
bool enable);
void (*opp_dpg_blank_enable)(
struct output_pixel_processor *opp,
bool enable,
const struct tg_color *color,
int width,
int height);
void (*opp_convert_pti)(
struct output_pixel_processor *opp,
bool enable,
bool polarity);
}; };
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment