mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00
drm/amd/display: Rename DCN opp specific function prefixes to oppn10
Also update relevant registers. Signed-off-by: Dmytro Laktyushkin <Dmytro.Laktyushkin@amd.com> Reviewed-by: Charlene Liu <Charlene.Liu@amd.com> Acked-by: Harry Wentland <Harry.Wentland@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
db3bc05034
commit
13066f9f64
3 changed files with 185 additions and 183 deletions
|
@ -37,7 +37,7 @@
|
|||
#define CTX \
|
||||
oppn10->base.ctx
|
||||
|
||||
static void opp_set_regamma_mode(
|
||||
static void oppn10_set_regamma_mode(
|
||||
struct output_pixel_processor *opp,
|
||||
enum opp_regamma mode)
|
||||
{
|
||||
|
@ -167,7 +167,7 @@ static void set_spatial_dither(
|
|||
FMT_RGB_RANDOM_ENABLE, params->flags.RGB_RANDOM);
|
||||
}
|
||||
|
||||
static void opp_program_bit_depth_reduction(
|
||||
static void oppn10_program_bit_depth_reduction(
|
||||
struct output_pixel_processor *opp,
|
||||
const struct bit_depth_reduction_params *params)
|
||||
{
|
||||
|
@ -255,7 +255,7 @@ static void opp_set_clamping(
|
|||
|
||||
}
|
||||
|
||||
static void opp_set_dyn_expansion(
|
||||
static void oppn10_set_dyn_expansion(
|
||||
struct output_pixel_processor *opp,
|
||||
enum dc_color_space color_sp,
|
||||
enum dc_color_depth color_dpth,
|
||||
|
@ -304,7 +304,7 @@ static void opp_program_clamping_and_pixel_encoding(
|
|||
set_pixel_encoding(oppn10, params);
|
||||
}
|
||||
|
||||
static void opp_program_fmt(
|
||||
static void oppn10_program_fmt(
|
||||
struct output_pixel_processor *opp,
|
||||
struct bit_depth_reduction_params *fmt_bit_depth,
|
||||
struct clamping_and_pixel_encoding_params *clamping)
|
||||
|
@ -316,7 +316,7 @@ static void opp_program_fmt(
|
|||
|
||||
/* dithering is affected by <CrtcSourceSelect>, hence should be
|
||||
* programmed afterwards */
|
||||
opp_program_bit_depth_reduction(
|
||||
oppn10_program_bit_depth_reduction(
|
||||
opp,
|
||||
fmt_bit_depth);
|
||||
|
||||
|
@ -327,7 +327,7 @@ static void opp_program_fmt(
|
|||
return;
|
||||
}
|
||||
|
||||
static void opp_set_output_csc_default(
|
||||
static void oppn10_set_output_csc_default(
|
||||
struct output_pixel_processor *opp,
|
||||
const struct default_adjustment *default_adjust)
|
||||
{
|
||||
|
@ -703,7 +703,7 @@ static void opp_configure_regamma_lut(
|
|||
REG_SET(CM_RGAM_LUT_INDEX, 0, CM_RGAM_LUT_INDEX, 0);
|
||||
}
|
||||
|
||||
static void opp_power_on_regamma_lut(
|
||||
static void oppn10_power_on_regamma_lut(
|
||||
struct output_pixel_processor *opp,
|
||||
bool power_on)
|
||||
{
|
||||
|
@ -713,142 +713,8 @@ static void opp_power_on_regamma_lut(
|
|||
|
||||
}
|
||||
|
||||
void opp_set_output_csc_adjustment(
|
||||
struct output_pixel_processor *opp,
|
||||
const struct out_csc_color_matrix *tbl_entry)
|
||||
{
|
||||
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
//enum csc_color_mode config = CSC_COLOR_MODE_GRAPHICS_OUTPUT_CSC;
|
||||
|
||||
|
||||
uint32_t ocsc_mode = 4;
|
||||
|
||||
/**
|
||||
*if (tbl_entry != NULL) {
|
||||
* switch (tbl_entry->color_space) {
|
||||
* case COLOR_SPACE_SRGB:
|
||||
* case COLOR_SPACE_2020_RGB_FULLRANGE:
|
||||
* ocsc_mode = 0;
|
||||
* break;
|
||||
* case COLOR_SPACE_SRGB_LIMITED:
|
||||
* case COLOR_SPACE_2020_RGB_LIMITEDRANGE:
|
||||
* ocsc_mode = 1;
|
||||
* break;
|
||||
* case COLOR_SPACE_YCBCR601:
|
||||
* case COLOR_SPACE_YCBCR601_LIMITED:
|
||||
* ocsc_mode = 2;
|
||||
* break;
|
||||
* case COLOR_SPACE_YCBCR709:
|
||||
* case COLOR_SPACE_YCBCR709_LIMITED:
|
||||
* case COLOR_SPACE_2020_YCBCR:
|
||||
* ocsc_mode = 3;
|
||||
* break;
|
||||
* case COLOR_SPACE_UNKNOWN:
|
||||
* default:
|
||||
* break;
|
||||
* }
|
||||
*}
|
||||
*/
|
||||
|
||||
REG_SET(CM_OCSC_CONTROL, 0, CM_OCSC_MODE, ocsc_mode);
|
||||
program_color_matrix(oppn10, tbl_entry);
|
||||
}
|
||||
|
||||
static void opp_program_regamma_lut(
|
||||
struct output_pixel_processor *opp,
|
||||
const struct pwl_result_data *rgb,
|
||||
uint32_t num)
|
||||
{
|
||||
uint32_t i;
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
for (i = 0 ; i < num; i++) {
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0, CM_RGAM_LUT_DATA, rgb[i].red_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0, CM_RGAM_LUT_DATA, rgb[i].green_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0, CM_RGAM_LUT_DATA, rgb[i].blue_reg);
|
||||
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0,
|
||||
CM_RGAM_LUT_DATA, rgb[i].delta_red_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0,
|
||||
CM_RGAM_LUT_DATA, rgb[i].delta_green_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0,
|
||||
CM_RGAM_LUT_DATA, rgb[i].delta_blue_reg);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
static bool opp_set_regamma_pwl(
|
||||
struct output_pixel_processor *opp, const struct pwl_params *params)
|
||||
{
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
|
||||
opp_power_on_regamma_lut(opp, true);
|
||||
opp_configure_regamma_lut(opp, oppn10->is_write_to_ram_a_safe);
|
||||
|
||||
if (oppn10->is_write_to_ram_a_safe)
|
||||
opp_program_regamma_luta_settings(opp, params);
|
||||
else
|
||||
opp_program_regamma_lutb_settings(opp, params);
|
||||
|
||||
opp_program_regamma_lut(
|
||||
opp, params->rgb_resulted, params->hw_points_num);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static void opp_set_stereo_polarity(
|
||||
struct output_pixel_processor *opp,
|
||||
bool enable, bool rightEyePolarity)
|
||||
{
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
|
||||
REG_UPDATE(FMT_CONTROL, FMT_STEREOSYNC_OVERRIDE, enable);
|
||||
}
|
||||
|
||||
/*****************************************/
|
||||
/* Constructor, Destructor */
|
||||
/*****************************************/
|
||||
|
||||
static void dcn10_opp_destroy(struct output_pixel_processor **opp)
|
||||
{
|
||||
dm_free(TO_DCN10_OPP(*opp));
|
||||
*opp = NULL;
|
||||
}
|
||||
|
||||
static struct opp_funcs dcn10_opp_funcs = {
|
||||
.opp_power_on_regamma_lut = opp_power_on_regamma_lut,
|
||||
.opp_set_csc_adjustment = opp_set_output_csc_adjustment,
|
||||
.opp_set_csc_default = opp_set_output_csc_default,
|
||||
.opp_set_dyn_expansion = opp_set_dyn_expansion,
|
||||
.opp_program_regamma_pwl = opp_set_regamma_pwl,
|
||||
.opp_set_regamma_mode = opp_set_regamma_mode,
|
||||
.opp_program_fmt = opp_program_fmt,
|
||||
.opp_program_bit_depth_reduction = opp_program_bit_depth_reduction,
|
||||
.opp_set_stereo_polarity = opp_set_stereo_polarity,
|
||||
.opp_destroy = dcn10_opp_destroy
|
||||
};
|
||||
|
||||
void dcn10_opp_construct(struct dcn10_opp *oppn10,
|
||||
struct dc_context *ctx,
|
||||
uint32_t inst,
|
||||
const struct dcn10_opp_registers *regs,
|
||||
const struct dcn10_opp_shift *opp_shift,
|
||||
const struct dcn10_opp_mask *opp_mask)
|
||||
{
|
||||
oppn10->base.ctx = ctx;
|
||||
oppn10->base.inst = inst;
|
||||
oppn10->base.funcs = &dcn10_opp_funcs;
|
||||
|
||||
oppn10->regs = regs;
|
||||
oppn10->opp_shift = opp_shift;
|
||||
oppn10->opp_mask = opp_mask;
|
||||
}
|
||||
|
||||
|
||||
void program_color_matrix(struct dcn10_opp *oppn10,
|
||||
static void oppn10_program_color_matrix(struct dcn10_opp *oppn10,
|
||||
const struct out_csc_color_matrix *tbl_entry)
|
||||
{
|
||||
uint32_t mode;
|
||||
|
@ -917,3 +783,136 @@ void program_color_matrix(struct dcn10_opp *oppn10,
|
|||
CM_COMB_C34, tbl_entry->regval[11]);
|
||||
}
|
||||
}
|
||||
|
||||
void oppn10_set_output_csc_adjustment(
|
||||
struct output_pixel_processor *opp,
|
||||
const struct out_csc_color_matrix *tbl_entry)
|
||||
{
|
||||
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
//enum csc_color_mode config = CSC_COLOR_MODE_GRAPHICS_OUTPUT_CSC;
|
||||
|
||||
|
||||
uint32_t ocsc_mode = 4;
|
||||
|
||||
/**
|
||||
*if (tbl_entry != NULL) {
|
||||
* switch (tbl_entry->color_space) {
|
||||
* case COLOR_SPACE_SRGB:
|
||||
* case COLOR_SPACE_2020_RGB_FULLRANGE:
|
||||
* ocsc_mode = 0;
|
||||
* break;
|
||||
* case COLOR_SPACE_SRGB_LIMITED:
|
||||
* case COLOR_SPACE_2020_RGB_LIMITEDRANGE:
|
||||
* ocsc_mode = 1;
|
||||
* break;
|
||||
* case COLOR_SPACE_YCBCR601:
|
||||
* case COLOR_SPACE_YCBCR601_LIMITED:
|
||||
* ocsc_mode = 2;
|
||||
* break;
|
||||
* case COLOR_SPACE_YCBCR709:
|
||||
* case COLOR_SPACE_YCBCR709_LIMITED:
|
||||
* case COLOR_SPACE_2020_YCBCR:
|
||||
* ocsc_mode = 3;
|
||||
* break;
|
||||
* case COLOR_SPACE_UNKNOWN:
|
||||
* default:
|
||||
* break;
|
||||
* }
|
||||
*}
|
||||
*/
|
||||
|
||||
REG_SET(CM_OCSC_CONTROL, 0, CM_OCSC_MODE, ocsc_mode);
|
||||
oppn10_program_color_matrix(oppn10, tbl_entry);
|
||||
}
|
||||
|
||||
static void opp_program_regamma_lut(
|
||||
struct output_pixel_processor *opp,
|
||||
const struct pwl_result_data *rgb,
|
||||
uint32_t num)
|
||||
{
|
||||
uint32_t i;
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
for (i = 0 ; i < num; i++) {
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0, CM_RGAM_LUT_DATA, rgb[i].red_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0, CM_RGAM_LUT_DATA, rgb[i].green_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0, CM_RGAM_LUT_DATA, rgb[i].blue_reg);
|
||||
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0,
|
||||
CM_RGAM_LUT_DATA, rgb[i].delta_red_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0,
|
||||
CM_RGAM_LUT_DATA, rgb[i].delta_green_reg);
|
||||
REG_SET(CM_RGAM_LUT_DATA, 0,
|
||||
CM_RGAM_LUT_DATA, rgb[i].delta_blue_reg);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
static bool oppn10_set_regamma_pwl(
|
||||
struct output_pixel_processor *opp, const struct pwl_params *params)
|
||||
{
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
|
||||
oppn10_power_on_regamma_lut(opp, true);
|
||||
opp_configure_regamma_lut(opp, oppn10->is_write_to_ram_a_safe);
|
||||
|
||||
if (oppn10->is_write_to_ram_a_safe)
|
||||
opp_program_regamma_luta_settings(opp, params);
|
||||
else
|
||||
opp_program_regamma_lutb_settings(opp, params);
|
||||
|
||||
opp_program_regamma_lut(
|
||||
opp, params->rgb_resulted, params->hw_points_num);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static void oppn10_set_stereo_polarity(
|
||||
struct output_pixel_processor *opp,
|
||||
bool enable, bool rightEyePolarity)
|
||||
{
|
||||
struct dcn10_opp *oppn10 = TO_DCN10_OPP(opp);
|
||||
|
||||
REG_UPDATE(FMT_CONTROL, FMT_STEREOSYNC_OVERRIDE, enable);
|
||||
}
|
||||
|
||||
/*****************************************/
|
||||
/* Constructor, Destructor */
|
||||
/*****************************************/
|
||||
|
||||
static void dcn10_opp_destroy(struct output_pixel_processor **opp)
|
||||
{
|
||||
dm_free(TO_DCN10_OPP(*opp));
|
||||
*opp = NULL;
|
||||
}
|
||||
|
||||
static struct opp_funcs dcn10_opp_funcs = {
|
||||
.opp_power_on_regamma_lut = oppn10_power_on_regamma_lut,
|
||||
.opp_set_csc_adjustment = oppn10_set_output_csc_adjustment,
|
||||
.opp_set_csc_default = oppn10_set_output_csc_default,
|
||||
.opp_set_dyn_expansion = oppn10_set_dyn_expansion,
|
||||
.opp_program_regamma_pwl = oppn10_set_regamma_pwl,
|
||||
.opp_set_regamma_mode = oppn10_set_regamma_mode,
|
||||
.opp_program_fmt = oppn10_program_fmt,
|
||||
.opp_program_bit_depth_reduction = oppn10_program_bit_depth_reduction,
|
||||
.opp_set_stereo_polarity = oppn10_set_stereo_polarity,
|
||||
.opp_destroy = dcn10_opp_destroy
|
||||
};
|
||||
|
||||
void dcn10_opp_construct(struct dcn10_opp *oppn10,
|
||||
struct dc_context *ctx,
|
||||
uint32_t inst,
|
||||
const struct dcn10_opp_registers *regs,
|
||||
const struct dcn10_opp_shift *opp_shift,
|
||||
const struct dcn10_opp_mask *opp_mask)
|
||||
{
|
||||
oppn10->base.ctx = ctx;
|
||||
oppn10->base.inst = inst;
|
||||
oppn10->base.funcs = &dcn10_opp_funcs;
|
||||
|
||||
oppn10->regs = regs;
|
||||
oppn10->opp_shift = opp_shift;
|
||||
oppn10->opp_mask = opp_mask;
|
||||
}
|
||||
|
||||
|
|
|
@ -33,7 +33,19 @@
|
|||
#define OPP_SF(reg_name, field_name, post_fix)\
|
||||
.field_name = reg_name ## __ ## field_name ## post_fix
|
||||
|
||||
#define OPP_DCN10_REG_LIST(id) \
|
||||
#define OPP_REG_LIST_DCN(id) \
|
||||
SRI(OBUF_CONTROL, DSCL, id), \
|
||||
SRI(FMT_BIT_DEPTH_CONTROL, FMT, id), \
|
||||
SRI(FMT_CONTROL, FMT, id), \
|
||||
SRI(FMT_DITHER_RAND_R_SEED, FMT, id), \
|
||||
SRI(FMT_DITHER_RAND_G_SEED, FMT, id), \
|
||||
SRI(FMT_DITHER_RAND_B_SEED, FMT, id), \
|
||||
SRI(FMT_CLAMP_CNTL, FMT, id), \
|
||||
SRI(FMT_DYNAMIC_EXP_CNTL, FMT, id), \
|
||||
SRI(FMT_MAP420_MEMORY_CONTROL, FMT, id)
|
||||
|
||||
#define OPP_REG_LIST_DCN10(id) \
|
||||
OPP_REG_LIST_DCN(id), \
|
||||
SRI(CM_OCSC_C11_C12, CM, id), \
|
||||
SRI(CM_OCSC_C13_C14, CM, id), \
|
||||
SRI(CM_OCSC_C21_C22, CM, id), \
|
||||
|
@ -48,15 +60,6 @@
|
|||
SRI(CM_COMB_C33_C34, CM, id), \
|
||||
SRI(CM_RGAM_LUT_WRITE_EN_MASK, CM, id), \
|
||||
SRI(CM_RGAM_CONTROL, CM, id), \
|
||||
SRI(OBUF_CONTROL, DSCL, id), \
|
||||
SRI(FMT_BIT_DEPTH_CONTROL, FMT, id), \
|
||||
SRI(FMT_CONTROL, FMT, id), \
|
||||
SRI(FMT_DITHER_RAND_R_SEED, FMT, id), \
|
||||
SRI(FMT_DITHER_RAND_G_SEED, FMT, id), \
|
||||
SRI(FMT_DITHER_RAND_B_SEED, FMT, id), \
|
||||
SRI(FMT_CLAMP_CNTL, FMT, id), \
|
||||
SRI(FMT_DYNAMIC_EXP_CNTL, FMT, id), \
|
||||
SRI(FMT_MAP420_MEMORY_CONTROL, FMT, id), \
|
||||
SRI(CM_OCSC_CONTROL, CM, id), \
|
||||
SRI(CM_RGAM_RAMB_START_CNTL_B, CM, id), \
|
||||
SRI(CM_RGAM_RAMB_START_CNTL_G, CM, id), \
|
||||
|
@ -120,7 +123,34 @@
|
|||
SRI(CM_MEM_PWR_CTRL, CM, id), \
|
||||
SRI(CM_RGAM_LUT_DATA, CM, id)
|
||||
|
||||
#define OPP_DCN10_MASK_SH_LIST(mask_sh) \
|
||||
|
||||
#define OPP_MASK_SH_LIST_DCN(mask_sh) \
|
||||
OPP_SF(DSCL0_OBUF_CONTROL, OBUF_BYPASS, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TRUNCATE_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TRUNCATE_DEPTH, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TRUNCATE_MODE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_SPATIAL_DITHER_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_SPATIAL_DITHER_MODE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_SPATIAL_DITHER_DEPTH, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TEMPORAL_DITHER_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_HIGHPASS_RANDOM_ENABLE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_FRAME_RANDOM_ENABLE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_RGB_RANDOM_ENABLE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CONTROL, FMT_SPATIAL_DITHER_FRAME_COUNTER_MAX, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CONTROL, FMT_SPATIAL_DITHER_FRAME_COUNTER_BIT_SWAP, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DITHER_RAND_R_SEED, FMT_RAND_R_SEED, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DITHER_RAND_G_SEED, FMT_RAND_G_SEED, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DITHER_RAND_B_SEED, FMT_RAND_B_SEED, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CONTROL, FMT_PIXEL_ENCODING, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CLAMP_CNTL, FMT_CLAMP_DATA_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CLAMP_CNTL, FMT_CLAMP_COLOR_FORMAT, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DYNAMIC_EXP_CNTL, FMT_DYNAMIC_EXP_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DYNAMIC_EXP_CNTL, FMT_DYNAMIC_EXP_MODE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_MAP420_MEMORY_CONTROL, FMT_MAP420MEM_PWR_FORCE, mask_sh)
|
||||
|
||||
#define OPP_MASK_SH_LIST_DCN10(mask_sh) \
|
||||
OPP_MASK_SH_LIST_DCN(mask_sh), \
|
||||
OPP_SF(DSCL0_OBUF_CONTROL, OBUF_H_2X_UPSCALE_EN, mask_sh), \
|
||||
OPP_SF(CM0_CM_OCSC_C11_C12, CM_OCSC_C11, mask_sh), \
|
||||
OPP_SF(CM0_CM_OCSC_C11_C12, CM_OCSC_C12, mask_sh), \
|
||||
OPP_SF(CM0_CM_OCSC_C13_C14, CM_OCSC_C13, mask_sh), \
|
||||
|
@ -146,29 +176,6 @@
|
|||
OPP_SF(CM0_CM_COMB_C33_C34, CM_COMB_C33, mask_sh), \
|
||||
OPP_SF(CM0_CM_COMB_C33_C34, CM_COMB_C34, mask_sh), \
|
||||
OPP_SF(CM0_CM_RGAM_CONTROL, CM_RGAM_LUT_MODE, mask_sh), \
|
||||
OPP_SF(DSCL0_OBUF_CONTROL, OBUF_BYPASS, mask_sh), \
|
||||
OPP_SF(DSCL0_OBUF_CONTROL, OBUF_H_2X_UPSCALE_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TRUNCATE_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TRUNCATE_DEPTH, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TRUNCATE_MODE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_SPATIAL_DITHER_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_SPATIAL_DITHER_MODE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_SPATIAL_DITHER_DEPTH, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_TEMPORAL_DITHER_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_HIGHPASS_RANDOM_ENABLE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_FRAME_RANDOM_ENABLE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_BIT_DEPTH_CONTROL, FMT_RGB_RANDOM_ENABLE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CONTROL, FMT_SPATIAL_DITHER_FRAME_COUNTER_MAX, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CONTROL, FMT_SPATIAL_DITHER_FRAME_COUNTER_BIT_SWAP, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DITHER_RAND_R_SEED, FMT_RAND_R_SEED, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DITHER_RAND_G_SEED, FMT_RAND_G_SEED, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DITHER_RAND_B_SEED, FMT_RAND_B_SEED, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CONTROL, FMT_PIXEL_ENCODING, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CLAMP_CNTL, FMT_CLAMP_DATA_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_CLAMP_CNTL, FMT_CLAMP_COLOR_FORMAT, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DYNAMIC_EXP_CNTL, FMT_DYNAMIC_EXP_EN, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_DYNAMIC_EXP_CNTL, FMT_DYNAMIC_EXP_MODE, mask_sh), \
|
||||
OPP_SF(FMT0_FMT_MAP420_MEMORY_CONTROL, FMT_MAP420MEM_PWR_FORCE, mask_sh), \
|
||||
OPP_SF(CM0_CM_OCSC_CONTROL, CM_OCSC_MODE, mask_sh), \
|
||||
OPP_SF(CM0_CM_RGAM_RAMB_START_CNTL_B, CM_RGAM_RAMB_EXP_REGION_START_B, mask_sh), \
|
||||
OPP_SF(CM0_CM_RGAM_RAMB_START_CNTL_B, CM_RGAM_RAMB_EXP_REGION_START_SEGMENT_B, mask_sh), \
|
||||
|
@ -691,8 +698,4 @@ void dcn10_opp_construct(struct dcn10_opp *oppn10,
|
|||
const struct dcn10_opp_shift *opp_shift,
|
||||
const struct dcn10_opp_mask *opp_mask);
|
||||
|
||||
void program_color_matrix(
|
||||
struct dcn10_opp *oppn10,
|
||||
const struct out_csc_color_matrix *tbl_entry);
|
||||
|
||||
#endif
|
||||
|
|
|
@ -286,7 +286,7 @@ static const struct dcn10_ipp_mask ipp_mask = {
|
|||
|
||||
#define opp_regs(id)\
|
||||
[id] = {\
|
||||
OPP_DCN10_REG_LIST(id),\
|
||||
OPP_REG_LIST_DCN10(id),\
|
||||
}
|
||||
|
||||
static const struct dcn10_opp_registers opp_regs[] = {
|
||||
|
@ -297,11 +297,11 @@ static const struct dcn10_opp_registers opp_regs[] = {
|
|||
};
|
||||
|
||||
static const struct dcn10_opp_shift opp_shift = {
|
||||
OPP_DCN10_MASK_SH_LIST(__SHIFT)
|
||||
OPP_MASK_SH_LIST_DCN10(__SHIFT)
|
||||
};
|
||||
|
||||
static const struct dcn10_opp_mask opp_mask = {
|
||||
OPP_DCN10_MASK_SH_LIST(_MASK),
|
||||
OPP_MASK_SH_LIST_DCN10(_MASK),
|
||||
};
|
||||
|
||||
#define tf_regs(id)\
|
||||
|
|
Loading…
Add table
Reference in a new issue