mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-23 02:09:31 +07:00
drm/amd/display: Drop CONFIG_DRM_AMD_DC_DCN2_0 and DSC_SUPPORTED
[Why] DCN2 and DSC are stable enough to be build by default. So drop the flags. [How] Remove them using the unifdef tool. The following commands were executed in sequence: $ find -name '*.c' -exec unifdef -m -DCONFIG_DRM_AMD_DC_DSC_SUPPORT -DCONFIG_DRM_AMD_DC_DCN2_0 -UCONFIG_TRIM_DRM_AMD_DC_DCN2_0 '{}' ';' $ find -name '*.h' -exec unifdef -m -DCONFIG_DRM_AMD_DC_DSC_SUPPORT -DCONFIG_DRM_AMD_DC_DCN2_0 -UCONFIG_TRIM_DRM_AMD_DC_DCN2_0 '{}' ';' In addition: * Remove from kconfig, and replace any dependencies with DCN1_0. * Remove from any makefiles. * Fix and cleanup NV defninitions in dal_asic_id.h * Expand DCN1 ifdef to include DCN2 code in the following files: * clk_mgr/clk_mgr.c: dc_clk_mgr_create() * core/dc_resources.c: dc_create_resource_pool() * dce/dce_dmcu.c: dcn20_*lock_phy() * dce/dce_dmcu.c: dcn20_funcs * dce/dce_dmcu.c: dcn20_dmcu_create() * gpio/hw_factory.c: dal_hw_factory_init() * gpio/hw_translate.c: dal_hw_translate_init() Signed-off-by: Leo Li <sunpeng.li@amd.com> Signed-off-by: Bhawanpreet Lakha <Bhawanpreet.Lakha@amd.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
3a2ce8d66a
commit
1da37801a8
@ -1527,7 +1527,6 @@ static int amdgpu_device_parse_gpu_info_fw(struct amdgpu_device *adev)
|
||||
}
|
||||
|
||||
parse_soc_bounding_box:
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
/*
|
||||
* soc bounding box info is not integrated in disocovery table,
|
||||
* we always need to parse it from gpu info firmware.
|
||||
@ -1538,7 +1537,6 @@ static int amdgpu_device_parse_gpu_info_fw(struct amdgpu_device *adev)
|
||||
le32_to_cpu(hdr->header.ucode_array_offset_bytes));
|
||||
adev->dm.soc_bounding_box = &gpu_info_fw->soc_bounding_box;
|
||||
}
|
||||
#endif
|
||||
break;
|
||||
}
|
||||
default:
|
||||
@ -2602,8 +2600,6 @@ bool amdgpu_device_asic_has_dc_support(enum amd_asic_type asic_type)
|
||||
case CHIP_VEGA20:
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
case CHIP_RAVEN:
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case CHIP_NAVI10:
|
||||
case CHIP_NAVI14:
|
||||
case CHIP_NAVI12:
|
||||
|
@ -15,21 +15,11 @@ config DRM_AMD_DC
|
||||
config DRM_AMD_DC_DCN1_0
|
||||
def_bool n
|
||||
help
|
||||
RV family support for display engine
|
||||
|
||||
config DRM_AMD_DC_DCN2_0
|
||||
bool "DCN 2.0 family"
|
||||
default y
|
||||
depends on DRM_AMD_DC && X86
|
||||
depends on DRM_AMD_DC_DCN1_0
|
||||
help
|
||||
Choose this option if you want to have
|
||||
Navi support for display engine
|
||||
RV and NV family support for display engine
|
||||
|
||||
config DRM_AMD_DC_DCN2_1
|
||||
bool "DCN 2.1 family"
|
||||
depends on DRM_AMD_DC && X86
|
||||
depends on DRM_AMD_DC_DCN2_0
|
||||
help
|
||||
Choose this option if you want to have
|
||||
Renoir support for display engine
|
||||
@ -39,7 +29,6 @@ config DRM_AMD_DC_DSC_SUPPORT
|
||||
default y
|
||||
depends on DRM_AMD_DC && X86
|
||||
depends on DRM_AMD_DC_DCN1_0
|
||||
depends on DRM_AMD_DC_DCN2_0
|
||||
help
|
||||
Choose this option if you want to have
|
||||
Dynamic Stream Compression support
|
||||
|
@ -942,9 +942,7 @@ static int amdgpu_dm_init(struct amdgpu_device *adev)
|
||||
|
||||
init_data.flags.power_down_display_on_boot = true;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
init_data.soc_bounding_box = adev->dm.soc_bounding_box;
|
||||
#endif
|
||||
|
||||
/* Display Core create. */
|
||||
adev->dm.dc = dc_create(&init_data);
|
||||
@ -2755,11 +2753,9 @@ static int amdgpu_dm_initialize_drm_device(struct amdgpu_device *adev)
|
||||
break;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
case CHIP_RAVEN:
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case CHIP_NAVI12:
|
||||
case CHIP_NAVI10:
|
||||
case CHIP_NAVI14:
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
case CHIP_RENOIR:
|
||||
#endif
|
||||
@ -2915,7 +2911,6 @@ static int dm_early_init(void *handle)
|
||||
adev->mode_info.num_dig = 4;
|
||||
break;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case CHIP_NAVI10:
|
||||
case CHIP_NAVI12:
|
||||
adev->mode_info.num_crtc = 6;
|
||||
@ -2927,7 +2922,6 @@ static int dm_early_init(void *handle)
|
||||
adev->mode_info.num_hpd = 5;
|
||||
adev->mode_info.num_dig = 5;
|
||||
break;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
case CHIP_RENOIR:
|
||||
adev->mode_info.num_crtc = 4;
|
||||
@ -3227,11 +3221,9 @@ fill_plane_buffer_attributes(struct amdgpu_device *adev,
|
||||
if (adev->asic_type == CHIP_VEGA10 ||
|
||||
adev->asic_type == CHIP_VEGA12 ||
|
||||
adev->asic_type == CHIP_VEGA20 ||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
adev->asic_type == CHIP_NAVI10 ||
|
||||
adev->asic_type == CHIP_NAVI14 ||
|
||||
adev->asic_type == CHIP_NAVI12 ||
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
adev->asic_type == CHIP_RENOIR ||
|
||||
#endif
|
||||
@ -3940,10 +3932,8 @@ create_stream_for_sink(struct amdgpu_dm_connector *aconnector,
|
||||
bool scale = dm_state ? (dm_state->scaling != RMX_OFF) : false;
|
||||
int mode_refresh;
|
||||
int preferred_refresh = 0;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct dsc_dec_dpcd_caps dsc_caps;
|
||||
uint32_t link_bandwidth_kbps;
|
||||
#endif
|
||||
|
||||
struct dc_sink *sink = NULL;
|
||||
if (aconnector == NULL) {
|
||||
@ -4018,7 +4008,6 @@ create_stream_for_sink(struct amdgpu_dm_connector *aconnector,
|
||||
fill_stream_properties_from_drm_display_mode(stream,
|
||||
&mode, &aconnector->base, con_state, old_stream);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
stream->timing.flags.DSC = 0;
|
||||
|
||||
if (aconnector->dc_link && sink->sink_signal == SIGNAL_TYPE_DISPLAY_PORT) {
|
||||
@ -4037,7 +4026,6 @@ create_stream_for_sink(struct amdgpu_dm_connector *aconnector,
|
||||
&stream->timing.dsc_cfg))
|
||||
stream->timing.flags.DSC = 1;
|
||||
}
|
||||
#endif
|
||||
|
||||
update_stream_scaling_settings(&mode, dm_state, stream);
|
||||
|
||||
|
@ -287,7 +287,6 @@ struct amdgpu_display_manager {
|
||||
|
||||
const struct firmware *fw_dmcu;
|
||||
uint32_t dmcu_fw_version;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
/**
|
||||
* @soc_bounding_box:
|
||||
*
|
||||
@ -295,7 +294,6 @@ struct amdgpu_display_manager {
|
||||
* available in FW
|
||||
*/
|
||||
const struct gpu_info_soc_bounding_box_v1_0 *soc_bounding_box;
|
||||
#endif
|
||||
};
|
||||
|
||||
struct amdgpu_dm_connector {
|
||||
|
@ -511,7 +511,6 @@ bool dm_helpers_submit_i2c(
|
||||
|
||||
return result;
|
||||
}
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool dm_helpers_dp_write_dsc_enable(
|
||||
struct dc_context *ctx,
|
||||
const struct dc_stream_state *stream,
|
||||
@ -522,7 +521,6 @@ bool dm_helpers_dp_write_dsc_enable(
|
||||
|
||||
return dm_helpers_dp_write_dpcd(ctx, stream->sink->link, DP_DSC_ENABLE, &enable_dsc, 1);
|
||||
}
|
||||
#endif
|
||||
|
||||
bool dm_helpers_is_dp_sink_present(struct dc_link *link)
|
||||
{
|
||||
|
@ -995,7 +995,6 @@ void dm_pp_get_funcs(
|
||||
funcs->rv_funcs.set_hard_min_fclk_by_freq =
|
||||
pp_rv_set_hard_min_fclk_by_freq;
|
||||
break;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
case DCN_VERSION_2_0:
|
||||
funcs->ctx.ver = PP_SMU_VER_NV;
|
||||
funcs->nv_funcs.pp_smu.dm = ctx;
|
||||
@ -1018,7 +1017,6 @@ void dm_pp_get_funcs(
|
||||
funcs->nv_funcs.get_uclk_dpm_states = pp_nv_get_uclk_dpm_states;
|
||||
funcs->nv_funcs.set_pstate_handshake_support = pp_nv_set_pstate_handshake_support;
|
||||
break;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_1
|
||||
case DCN_VERSION_2_1:
|
||||
|
@ -25,18 +25,12 @@
|
||||
|
||||
DC_LIBS = basics bios calcs clk_mgr dce gpio irq virtual
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
DC_LIBS += dcn20
|
||||
endif
|
||||
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
DC_LIBS += dsc
|
||||
endif
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN1_0
|
||||
DC_LIBS += dcn20
|
||||
DC_LIBS += dsc
|
||||
DC_LIBS += dcn10 dml
|
||||
endif
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN2_1
|
||||
DC_LIBS += dcn21
|
||||
endif
|
||||
@ -59,7 +53,7 @@ include $(AMD_DC)
|
||||
DISPLAY_CORE = dc.o dc_link.o dc_resource.o dc_hw_sequencer.o dc_sink.o \
|
||||
dc_surface.o dc_link_hwss.o dc_link_dp.o dc_link_ddc.o dc_debug.o dc_stream.o
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN1_0
|
||||
DISPLAY_CORE += dc_vm_helper.o
|
||||
endif
|
||||
|
||||
|
@ -1417,10 +1417,8 @@ static enum bp_result get_integrated_info_v11(
|
||||
info->ma_channel_number = info_v11->umachannelnumber;
|
||||
info->lvds_ss_percentage =
|
||||
le16_to_cpu(info_v11->lvds_ss_percentage);
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
info->dp_ss_control =
|
||||
le16_to_cpu(info_v11->reserved1);
|
||||
#endif
|
||||
info->lvds_sspread_rate_in_10hz =
|
||||
le16_to_cpu(info_v11->lvds_ss_rate_10hz);
|
||||
info->hdmi_ss_percentage =
|
||||
|
@ -62,11 +62,9 @@ bool dal_bios_parser_init_cmd_tbl_helper2(
|
||||
return true;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case DCN_VERSION_2_0:
|
||||
*h = dal_cmd_tbl_helper_dce112_get_table2();
|
||||
return true;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
case DCN_VERSION_2_1:
|
||||
*h = dal_cmd_tbl_helper_dce112_get_table2();
|
||||
|
@ -53,13 +53,9 @@
|
||||
* remain as-is as it provides us with a guarantee from HW that it is correct.
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
/* Defaults from spreadsheet rev#247.
|
||||
* RV2 delta: dram_clock_change_latency, max_num_dpp
|
||||
*/
|
||||
#else
|
||||
/* Defaults from spreadsheet rev#247 */
|
||||
#endif
|
||||
const struct dcn_soc_bounding_box dcn10_soc_defaults = {
|
||||
/* latencies */
|
||||
.sr_exit_time = 17, /*us*/
|
||||
|
@ -72,9 +72,7 @@ CLK_MGR_DCN10 = rv1_clk_mgr.o rv1_clk_mgr_vbios_smu.o rv2_clk_mgr.o
|
||||
AMD_DAL_CLK_MGR_DCN10 = $(addprefix $(AMDDALPATH)/dc/clk_mgr/dcn10/,$(CLK_MGR_DCN10))
|
||||
|
||||
AMD_DISPLAY_FILES += $(AMD_DAL_CLK_MGR_DCN10)
|
||||
endif
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
###############################################################################
|
||||
# DCN20
|
||||
###############################################################################
|
||||
|
@ -152,13 +152,11 @@ struct clk_mgr *dc_clk_mgr_create(struct dc_context *ctx, struct pp_smu_funcs *p
|
||||
break;
|
||||
}
|
||||
break;
|
||||
#endif /* Family RV */
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case FAMILY_NV:
|
||||
dcn20_clk_mgr_construct(ctx, clk_mgr, pp_smu, dccg);
|
||||
break;
|
||||
#endif /* Family NV */
|
||||
#endif /* Family RV and NV*/
|
||||
|
||||
default:
|
||||
ASSERT(0); /* Unknown Asic */
|
||||
|
@ -60,13 +60,9 @@
|
||||
#include "dc_link_dp.h"
|
||||
#include "dc_dmub_srv.h"
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "dsc.h"
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
#include "vm_helper.h"
|
||||
#endif
|
||||
|
||||
#include "dce/dce_i2c.h"
|
||||
|
||||
@ -578,11 +574,9 @@ static void destruct(struct dc *dc)
|
||||
dc->dcn_ip = NULL;
|
||||
|
||||
#endif
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
kfree(dc->vm_helper);
|
||||
dc->vm_helper = NULL;
|
||||
|
||||
#endif
|
||||
}
|
||||
|
||||
static bool construct(struct dc *dc,
|
||||
@ -599,7 +593,6 @@ static bool construct(struct dc *dc,
|
||||
enum dce_version dc_version = DCE_VERSION_UNKNOWN;
|
||||
dc->config = init_params->flags;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
// Allocate memory for the vm_helper
|
||||
dc->vm_helper = kzalloc(sizeof(struct vm_helper), GFP_KERNEL);
|
||||
if (!dc->vm_helper) {
|
||||
@ -607,7 +600,6 @@ static bool construct(struct dc *dc,
|
||||
goto fail;
|
||||
}
|
||||
|
||||
#endif
|
||||
memcpy(&dc->bb_overrides, &init_params->bb_overrides, sizeof(dc->bb_overrides));
|
||||
|
||||
dc_dceip = kzalloc(sizeof(*dc_dceip), GFP_KERNEL);
|
||||
@ -641,9 +633,7 @@ static bool construct(struct dc *dc,
|
||||
}
|
||||
|
||||
dc->dcn_ip = dcn_ip;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
dc->soc_bounding_box = init_params->soc_bounding_box;
|
||||
#endif
|
||||
#endif
|
||||
|
||||
dc_ctx = kzalloc(sizeof(*dc_ctx), GFP_KERNEL);
|
||||
@ -745,7 +735,6 @@ static bool construct(struct dc *dc,
|
||||
return false;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
static bool disable_all_writeback_pipes_for_stream(
|
||||
const struct dc *dc,
|
||||
struct dc_stream_state *stream,
|
||||
@ -758,7 +747,6 @@ static bool disable_all_writeback_pipes_for_stream(
|
||||
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
static void disable_dangling_plane(struct dc *dc, struct dc_state *context)
|
||||
{
|
||||
@ -784,16 +772,12 @@ static void disable_dangling_plane(struct dc *dc, struct dc_state *context)
|
||||
}
|
||||
if (should_disable && old_stream) {
|
||||
dc_rem_all_planes_for_stream(dc, old_stream, dangling_context);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
disable_all_writeback_pipes_for_stream(dc, old_stream, dangling_context);
|
||||
#endif
|
||||
if (dc->hwss.apply_ctx_for_surface)
|
||||
dc->hwss.apply_ctx_for_surface(dc, old_stream, 0, dangling_context);
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (dc->hwss.program_front_end_for_ctx)
|
||||
dc->hwss.program_front_end_for_ctx(dc, dangling_context);
|
||||
#endif
|
||||
}
|
||||
|
||||
current_ctx = dc->current_state;
|
||||
@ -1183,10 +1167,8 @@ static enum dc_status dc_commit_state_no_check(struct dc *dc, struct dc_state *c
|
||||
context->stream_status[i].plane_count,
|
||||
context); /* use new pipe config in new context */
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (dc->hwss.program_front_end_for_ctx)
|
||||
dc->hwss.program_front_end_for_ctx(dc, context);
|
||||
#endif
|
||||
|
||||
/* Program hardware */
|
||||
for (i = 0; i < dc->res_pool->pipe_count; i++) {
|
||||
@ -1205,10 +1187,8 @@ static enum dc_status dc_commit_state_no_check(struct dc *dc, struct dc_state *c
|
||||
}
|
||||
|
||||
/* Program all planes within new context*/
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (dc->hwss.program_front_end_for_ctx)
|
||||
dc->hwss.program_front_end_for_ctx(dc, context);
|
||||
#endif
|
||||
for (i = 0; i < context->stream_count; i++) {
|
||||
const struct dc_link *link = context->streams[i]->link;
|
||||
|
||||
@ -1692,10 +1672,8 @@ static enum surface_update_type check_update_surfaces_for_stream(
|
||||
if (stream_update->gamut_remap)
|
||||
su_flags->bits.gamut_remap = 1;
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (stream_update->wb_update)
|
||||
su_flags->bits.wb_update = 1;
|
||||
#endif
|
||||
if (su_flags->raw != 0)
|
||||
overall_type = UPDATE_TYPE_FULL;
|
||||
|
||||
@ -1860,7 +1838,6 @@ static void copy_surface_update_to_plane(
|
||||
sizeof(struct dc_transfer_func_distributed_points));
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (srf_update->func_shaper &&
|
||||
(surface->in_shaper_func !=
|
||||
srf_update->func_shaper))
|
||||
@ -1879,7 +1856,6 @@ static void copy_surface_update_to_plane(
|
||||
memcpy(surface->blend_tf, srf_update->blend_tf,
|
||||
sizeof(*surface->blend_tf));
|
||||
|
||||
#endif
|
||||
if (srf_update->input_csc_color_matrix)
|
||||
surface->input_csc_color_matrix =
|
||||
*srf_update->input_csc_color_matrix;
|
||||
@ -1954,7 +1930,6 @@ static void copy_stream_update_to_stream(struct dc *dc,
|
||||
|
||||
if (update->dither_option)
|
||||
stream->dither_option = *update->dither_option;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/* update current stream with writeback info */
|
||||
if (update->wb_update) {
|
||||
int i;
|
||||
@ -1965,8 +1940,6 @@ static void copy_stream_update_to_stream(struct dc *dc,
|
||||
stream->writeback_info[i] =
|
||||
update->wb_update->writeback_info[i];
|
||||
}
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DSC_SUPPORT)
|
||||
if (update->dsc_config) {
|
||||
struct dc_dsc_config old_dsc_cfg = stream->timing.dsc_cfg;
|
||||
uint32_t old_dsc_enabled = stream->timing.flags.DSC;
|
||||
@ -1981,7 +1954,6 @@ static void copy_stream_update_to_stream(struct dc *dc,
|
||||
stream->timing.flags.DSC = old_dsc_enabled;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
static void commit_planes_do_stream_update(struct dc *dc,
|
||||
@ -2022,31 +1994,25 @@ static void commit_planes_do_stream_update(struct dc *dc,
|
||||
dc_stream_program_csc_matrix(dc, stream);
|
||||
|
||||
if (stream_update->dither_option) {
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct pipe_ctx *odm_pipe = pipe_ctx->next_odm_pipe;
|
||||
#endif
|
||||
resource_build_bit_depth_reduction_params(pipe_ctx->stream,
|
||||
&pipe_ctx->stream->bit_depth_params);
|
||||
pipe_ctx->stream_res.opp->funcs->opp_program_fmt(pipe_ctx->stream_res.opp,
|
||||
&stream->bit_depth_params,
|
||||
&stream->clamping);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
while (odm_pipe) {
|
||||
odm_pipe->stream_res.opp->funcs->opp_program_fmt(odm_pipe->stream_res.opp,
|
||||
&stream->bit_depth_params,
|
||||
&stream->clamping);
|
||||
odm_pipe = odm_pipe->next_odm_pipe;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DSC_SUPPORT)
|
||||
if (stream_update->dsc_config && dc->hwss.pipe_control_lock_global) {
|
||||
dc->hwss.pipe_control_lock_global(dc, pipe_ctx, true);
|
||||
dp_update_dsc_config(pipe_ctx);
|
||||
dc->hwss.pipe_control_lock_global(dc, pipe_ctx, false);
|
||||
}
|
||||
#endif
|
||||
/* Full fe update*/
|
||||
if (update_type == UPDATE_TYPE_FAST)
|
||||
continue;
|
||||
@ -2133,15 +2099,12 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
*/
|
||||
if (dc->hwss.apply_ctx_for_surface)
|
||||
dc->hwss.apply_ctx_for_surface(dc, stream, 0, context);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (dc->hwss.program_front_end_for_ctx)
|
||||
dc->hwss.program_front_end_for_ctx(dc, context);
|
||||
#endif
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (!IS_DIAG_DC(dc->ctx->dce_environment)) {
|
||||
for (i = 0; i < surface_count; i++) {
|
||||
struct dc_plane_state *plane_state = srf_updates[i].surface;
|
||||
@ -2163,7 +2126,6 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
// Update Type FULL, Surface updates
|
||||
for (j = 0; j < dc->res_pool->pipe_count; j++) {
|
||||
@ -2184,7 +2146,6 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
if (update_type == UPDATE_TYPE_FAST)
|
||||
continue;
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
ASSERT(!pipe_ctx->plane_state->triplebuffer_flips);
|
||||
|
||||
if (dc->hwss.program_triplebuffer != NULL &&
|
||||
@ -2193,7 +2154,6 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
dc->hwss.program_triplebuffer(
|
||||
dc, pipe_ctx, pipe_ctx->plane_state->triplebuffer_flips);
|
||||
}
|
||||
#endif
|
||||
stream_status =
|
||||
stream_get_status(context, pipe_ctx->stream);
|
||||
|
||||
@ -2202,10 +2162,8 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
dc, pipe_ctx->stream, stream_status->plane_count, context);
|
||||
}
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (dc->hwss.program_front_end_for_ctx && update_type != UPDATE_TYPE_FAST)
|
||||
dc->hwss.program_front_end_for_ctx(dc, context);
|
||||
#endif
|
||||
|
||||
// Update Type FAST, Surface updates
|
||||
if (update_type == UPDATE_TYPE_FAST) {
|
||||
@ -2215,7 +2173,6 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
*/
|
||||
dc->hwss.pipe_control_lock(dc, top_pipe_to_program, true);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (dc->hwss.set_flip_control_gsl)
|
||||
for (i = 0; i < surface_count; i++) {
|
||||
struct dc_plane_state *plane_state = srf_updates[i].surface;
|
||||
@ -2234,7 +2191,6 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
plane_state->flip_immediate);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
/* Perform requested Updates */
|
||||
for (i = 0; i < surface_count; i++) {
|
||||
struct dc_plane_state *plane_state = srf_updates[i].surface;
|
||||
@ -2247,7 +2203,6 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
|
||||
if (pipe_ctx->plane_state != plane_state)
|
||||
continue;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/*program triple buffer after lock based on flip type*/
|
||||
if (dc->hwss.program_triplebuffer != NULL &&
|
||||
!dc->debug.disable_tri_buf) {
|
||||
@ -2255,7 +2210,6 @@ static void commit_planes_for_stream(struct dc *dc,
|
||||
dc->hwss.program_triplebuffer(
|
||||
dc, pipe_ctx, plane_state->triplebuffer_flips);
|
||||
}
|
||||
#endif
|
||||
if (srf_updates[i].flip_addr)
|
||||
dc->hwss.update_plane_addr(dc, pipe_ctx);
|
||||
}
|
||||
@ -2421,12 +2375,10 @@ void dc_set_power_state(
|
||||
|
||||
dc->hwss.init_hw(dc);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
if (dc->hwss.init_sys_ctx != NULL &&
|
||||
dc->vm_pa_config.valid) {
|
||||
dc->hwss.init_sys_ctx(dc->hwseq, dc, &dc->vm_pa_config);
|
||||
}
|
||||
#endif
|
||||
|
||||
break;
|
||||
default:
|
||||
|
@ -1496,9 +1496,7 @@ static enum dc_status enable_link_dp(
|
||||
struct dc_link *link = stream->link;
|
||||
struct dc_link_settings link_settings = {0};
|
||||
enum dp_panel_mode panel_mode;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool fec_enable;
|
||||
#endif
|
||||
int i;
|
||||
bool apply_seamless_boot_optimization = false;
|
||||
|
||||
@ -1569,14 +1567,12 @@ static enum dc_status enable_link_dp(
|
||||
else
|
||||
status = DC_FAIL_DP_LINK_TRAINING;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (link->preferred_training_settings.fec_enable != NULL)
|
||||
fec_enable = *link->preferred_training_settings.fec_enable;
|
||||
else
|
||||
fec_enable = true;
|
||||
|
||||
dp_set_fec_enable(link, fec_enable);
|
||||
#endif
|
||||
return status;
|
||||
}
|
||||
|
||||
@ -2199,14 +2195,12 @@ static void disable_link(struct dc_link *link, enum signal_type signal)
|
||||
dp_disable_link_phy(link, signal);
|
||||
else
|
||||
dp_disable_link_phy_mst(link, signal);
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
|
||||
if (dc_is_dp_sst_signal(signal) ||
|
||||
link->mst_stream_alloc_table.stream_count == 0) {
|
||||
dp_set_fec_enable(link, false);
|
||||
dp_set_fec_ready(link, false);
|
||||
}
|
||||
#endif
|
||||
} else {
|
||||
if (signal != SIGNAL_TYPE_VIRTUAL)
|
||||
link->link_enc->funcs->disable_output(link->link_enc, signal);
|
||||
@ -3028,23 +3022,19 @@ void core_link_enable_stream(
|
||||
CONTROLLER_DP_TEST_PATTERN_VIDEOMODE,
|
||||
COLOR_DEPTH_UNDEFINED);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (pipe_ctx->stream->timing.flags.DSC) {
|
||||
if (dc_is_dp_signal(pipe_ctx->stream->signal) ||
|
||||
dc_is_virtual_signal(pipe_ctx->stream->signal))
|
||||
dp_set_dsc_enable(pipe_ctx, true);
|
||||
}
|
||||
#endif
|
||||
core_dc->hwss.enable_stream(pipe_ctx);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* Set DPS PPS SDP (AKA "info frames") */
|
||||
if (pipe_ctx->stream->timing.flags.DSC) {
|
||||
if (dc_is_dp_signal(pipe_ctx->stream->signal) ||
|
||||
dc_is_virtual_signal(pipe_ctx->stream->signal))
|
||||
dp_set_dsc_pps_sdp(pipe_ctx, true);
|
||||
}
|
||||
#endif
|
||||
|
||||
if (pipe_ctx->stream->signal == SIGNAL_TYPE_DISPLAY_PORT_MST)
|
||||
dc_link_allocate_mst_payload(pipe_ctx);
|
||||
@ -3058,14 +3048,12 @@ void core_link_enable_stream(
|
||||
update_psp_stream_config(pipe_ctx, false);
|
||||
#endif
|
||||
}
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
else { // if (IS_FPGA_MAXIMUS_DC(core_dc->ctx->dce_environment))
|
||||
if (dc_is_dp_signal(pipe_ctx->stream->signal) ||
|
||||
dc_is_virtual_signal(pipe_ctx->stream->signal))
|
||||
dp_set_dsc_enable(pipe_ctx, true);
|
||||
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void core_link_disable_stream(struct pipe_ctx *pipe_ctx)
|
||||
@ -3114,12 +3102,10 @@ void core_link_disable_stream(struct pipe_ctx *pipe_ctx)
|
||||
core_dc->hwss.disable_stream(pipe_ctx);
|
||||
|
||||
disable_link(pipe_ctx->stream->link, pipe_ctx->stream->signal);
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (pipe_ctx->stream->timing.flags.DSC) {
|
||||
if (dc_is_dp_signal(pipe_ctx->stream->signal))
|
||||
dp_set_dsc_enable(pipe_ctx, false);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void core_link_set_avmute(struct pipe_ctx *pipe_ctx, bool enable)
|
||||
@ -3187,13 +3173,11 @@ uint32_t dc_bandwidth_in_kbps_from_timing(
|
||||
uint32_t bits_per_channel = 0;
|
||||
uint32_t kbps;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (timing->flags.DSC) {
|
||||
kbps = (timing->pix_clk_100hz * timing->dsc_cfg.bits_per_pixel);
|
||||
kbps = kbps / 160 + ((kbps % 160) ? 1 : 0);
|
||||
return kbps;
|
||||
}
|
||||
#endif
|
||||
|
||||
switch (timing->display_color_depth) {
|
||||
case COLOR_DEPTH_666:
|
||||
@ -3369,7 +3353,6 @@ uint32_t dc_link_bandwidth_kbps(
|
||||
link_bw_kbps *= 8; /* 8 bits per byte*/
|
||||
link_bw_kbps *= link_setting->lane_count;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (link->dpcd_caps.fec_cap.bits.FEC_CAPABLE) {
|
||||
/* Account for FEC overhead.
|
||||
* We have to do it based on caps,
|
||||
@ -3394,7 +3377,6 @@ uint32_t dc_link_bandwidth_kbps(
|
||||
link_bw_kbps = mul_u64_u32_shr(BIT_ULL(32) * 970LL / 1000,
|
||||
link_bw_kbps, 32);
|
||||
}
|
||||
#endif
|
||||
|
||||
return link_bw_kbps;
|
||||
|
||||
|
@ -4,12 +4,8 @@
|
||||
#include "dc_link_dp.h"
|
||||
#include "dm_helpers.h"
|
||||
#include "opp.h"
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "dsc.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "resource.h"
|
||||
#endif
|
||||
|
||||
#include "inc/core_types.h"
|
||||
#include "link_hwss.h"
|
||||
@ -1365,9 +1361,7 @@ enum link_training_result dc_link_dp_perform_link_training(
|
||||
enum link_training_result status = LINK_TRAINING_SUCCESS;
|
||||
struct link_training_settings lt_settings;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool fec_enable;
|
||||
#endif
|
||||
uint8_t repeater_cnt;
|
||||
uint8_t repeater_id;
|
||||
|
||||
@ -1380,14 +1374,12 @@ enum link_training_result dc_link_dp_perform_link_training(
|
||||
/* 1. set link rate, lane count and spread. */
|
||||
dpcd_set_link_settings(link, <_settings);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (link->preferred_training_settings.fec_enable != NULL)
|
||||
fec_enable = *link->preferred_training_settings.fec_enable;
|
||||
else
|
||||
fec_enable = true;
|
||||
|
||||
dp_set_fec_ready(link, fec_enable);
|
||||
#endif
|
||||
|
||||
if (!link->is_lttpr_mode_transparent) {
|
||||
/* Configure lttpr mode */
|
||||
@ -1529,9 +1521,7 @@ enum link_training_result dc_link_dp_sync_lt_attempt(
|
||||
enum link_training_result lt_status = LINK_TRAINING_SUCCESS;
|
||||
enum dp_panel_mode panel_mode = DP_PANEL_MODE_DEFAULT;
|
||||
enum clock_source_id dp_cs_id = CLOCK_SOURCE_ID_EXTERNAL;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool fec_enable = false;
|
||||
#endif
|
||||
|
||||
initialize_training_settings(
|
||||
link,
|
||||
@ -1551,11 +1541,9 @@ enum link_training_result dc_link_dp_sync_lt_attempt(
|
||||
dp_enable_link_phy(link, link->connector_signal,
|
||||
dp_cs_id, link_settings);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* Set FEC enable */
|
||||
fec_enable = lt_overrides->fec_enable && *lt_overrides->fec_enable;
|
||||
dp_set_fec_ready(link, fec_enable);
|
||||
#endif
|
||||
|
||||
if (lt_overrides->alternate_scrambler_reset) {
|
||||
if (*lt_overrides->alternate_scrambler_reset)
|
||||
@ -1596,9 +1584,7 @@ bool dc_link_dp_sync_lt_end(struct dc_link *link, bool link_down)
|
||||
*/
|
||||
if (link_down == true) {
|
||||
dp_disable_link_phy(link, link->connector_signal);
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
dp_set_fec_ready(link, false);
|
||||
#endif
|
||||
}
|
||||
|
||||
link->sync_lt_in_progress = false;
|
||||
@ -3210,7 +3196,6 @@ static bool retrieve_link_cap(struct dc_link *link)
|
||||
dp_hw_fw_revision.ieee_fw_rev,
|
||||
sizeof(dp_hw_fw_revision.ieee_fw_rev));
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
memset(&link->dpcd_caps.dsc_caps, '\0',
|
||||
sizeof(link->dpcd_caps.dsc_caps));
|
||||
memset(&link->dpcd_caps.fec_cap, '\0', sizeof(link->dpcd_caps.fec_cap));
|
||||
@ -3232,7 +3217,6 @@ static bool retrieve_link_cap(struct dc_link *link)
|
||||
link->dpcd_caps.dsc_caps.dsc_ext_caps.raw,
|
||||
sizeof(link->dpcd_caps.dsc_caps.dsc_ext_caps.raw));
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Connectivity log: detection */
|
||||
CONN_DATA_DETECT(link, dpcd_data, sizeof(dpcd_data), "Rx Caps: ");
|
||||
@ -3361,14 +3345,12 @@ static void set_crtc_test_pattern(struct dc_link *link,
|
||||
stream->timing.display_color_depth;
|
||||
struct bit_depth_reduction_params params;
|
||||
struct output_pixel_processor *opp = pipe_ctx->stream_res.opp;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
int width = pipe_ctx->stream->timing.h_addressable +
|
||||
pipe_ctx->stream->timing.h_border_left +
|
||||
pipe_ctx->stream->timing.h_border_right;
|
||||
int height = pipe_ctx->stream->timing.v_addressable +
|
||||
pipe_ctx->stream->timing.v_border_bottom +
|
||||
pipe_ctx->stream->timing.v_border_top;
|
||||
#endif
|
||||
|
||||
memset(¶ms, 0, sizeof(params));
|
||||
|
||||
@ -3412,7 +3394,6 @@ static void set_crtc_test_pattern(struct dc_link *link,
|
||||
if (pipe_ctx->stream_res.tg->funcs->set_test_pattern)
|
||||
pipe_ctx->stream_res.tg->funcs->set_test_pattern(pipe_ctx->stream_res.tg,
|
||||
controller_test_pattern, color_depth);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
else if (opp->funcs->opp_set_disp_pattern_generator) {
|
||||
struct pipe_ctx *odm_pipe;
|
||||
int opp_cnt = 1;
|
||||
@ -3440,7 +3421,6 @@ static void set_crtc_test_pattern(struct dc_link *link,
|
||||
width,
|
||||
height);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
break;
|
||||
case DP_TEST_PATTERN_VIDEO_MODE:
|
||||
@ -3453,7 +3433,6 @@ static void set_crtc_test_pattern(struct dc_link *link,
|
||||
pipe_ctx->stream_res.tg->funcs->set_test_pattern(pipe_ctx->stream_res.tg,
|
||||
CONTROLLER_DP_TEST_PATTERN_VIDEOMODE,
|
||||
color_depth);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
else if (opp->funcs->opp_set_disp_pattern_generator) {
|
||||
struct pipe_ctx *odm_pipe;
|
||||
int opp_cnt = 1;
|
||||
@ -3480,7 +3459,6 @@ static void set_crtc_test_pattern(struct dc_link *link,
|
||||
width,
|
||||
height);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
break;
|
||||
|
||||
@ -3755,7 +3733,6 @@ enum dp_panel_mode dp_get_panel_mode(struct dc_link *link)
|
||||
return DP_PANEL_MODE_DEFAULT;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
void dp_set_fec_ready(struct dc_link *link, bool ready)
|
||||
{
|
||||
/* FEC has to be "set ready" before the link training.
|
||||
@ -3818,5 +3795,4 @@ void dp_set_fec_enable(struct dc_link *link, bool enable)
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -12,12 +12,8 @@
|
||||
#include "dc_link_ddc.h"
|
||||
#include "dm_helpers.h"
|
||||
#include "dpcd_defs.h"
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "dsc.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "resource.h"
|
||||
#endif
|
||||
|
||||
static uint8_t convert_to_count(uint8_t lttpr_repeater_count)
|
||||
{
|
||||
@ -374,7 +370,6 @@ void dp_retrain_link_dp_test(struct dc_link *link,
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#define DC_LOGGER \
|
||||
dsc->ctx->logger
|
||||
static void dsc_optc_config_log(struct display_stream_compressor *dsc,
|
||||
@ -572,5 +567,4 @@ bool dp_update_dsc_config(struct pipe_ctx *pipe_ctx)
|
||||
dp_set_dsc_pps_sdp(pipe_ctx, true);
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -49,9 +49,7 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
#include "dcn10/dcn10_resource.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "dcn20/dcn20_resource.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
#include "dcn21/dcn21_resource.h"
|
||||
#endif
|
||||
@ -111,11 +109,9 @@ enum dce_version resource_parse_asic_id(struct hw_asic_id asic_id)
|
||||
break;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case FAMILY_NV:
|
||||
dc_version = DCN_VERSION_2_0;
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
dc_version = DCE_VERSION_UNKNOWN;
|
||||
break;
|
||||
@ -167,18 +163,16 @@ struct resource_pool *dc_create_resource_pool(struct dc *dc,
|
||||
case DCN_VERSION_1_01:
|
||||
res_pool = dcn10_create_resource_pool(init_data, dc);
|
||||
break;
|
||||
#endif
|
||||
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case DCN_VERSION_2_0:
|
||||
res_pool = dcn20_create_resource_pool(init_data, dc);
|
||||
break;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
case DCN_VERSION_2_1:
|
||||
res_pool = dcn21_create_resource_pool(init_data, dc);
|
||||
break;
|
||||
#endif
|
||||
#endif
|
||||
|
||||
default:
|
||||
|
@ -108,7 +108,6 @@ static void construct(struct dc_stream_state *stream,
|
||||
/* EDID CAP translation for HDMI 2.0 */
|
||||
stream->timing.flags.LTE_340MCSC_SCRAMBLE = dc_sink_data->edid_caps.lte_340mcsc_scramble;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
memset(&stream->timing.dsc_cfg, 0, sizeof(stream->timing.dsc_cfg));
|
||||
stream->timing.dsc_cfg.num_slices_h = 0;
|
||||
stream->timing.dsc_cfg.num_slices_v = 0;
|
||||
@ -117,7 +116,6 @@ static void construct(struct dc_stream_state *stream,
|
||||
stream->timing.dsc_cfg.linebuf_depth = 9;
|
||||
stream->timing.dsc_cfg.version_minor = 2;
|
||||
stream->timing.dsc_cfg.ycbcr422_simple = 0;
|
||||
#endif
|
||||
|
||||
update_stream_signal(stream, dc_sink_data);
|
||||
|
||||
@ -367,7 +365,6 @@ bool dc_stream_set_cursor_position(
|
||||
return true;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool dc_stream_add_writeback(struct dc *dc,
|
||||
struct dc_stream_state *stream,
|
||||
struct dc_writeback_info *wb_info)
|
||||
@ -480,7 +477,6 @@ bool dc_stream_remove_writeback(struct dc *dc,
|
||||
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
uint32_t dc_stream_get_vblank_counter(const struct dc_stream_state *stream)
|
||||
{
|
||||
@ -567,7 +563,6 @@ bool dc_stream_get_scanoutpos(const struct dc_stream_state *stream,
|
||||
return ret;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool dc_stream_dmdata_status_done(struct dc *dc, struct dc_stream_state *stream)
|
||||
{
|
||||
bool status = true;
|
||||
@ -630,7 +625,6 @@ bool dc_stream_set_dynamic_metadata(struct dc *dc,
|
||||
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
void dc_stream_log(const struct dc *dc, const struct dc_stream_state *stream)
|
||||
{
|
||||
|
@ -50,7 +50,6 @@ static void construct(struct dc_context *ctx, struct dc_plane_state *plane_state
|
||||
plane_state->in_transfer_func->type = TF_TYPE_BYPASS;
|
||||
plane_state->in_transfer_func->ctx = ctx;
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
plane_state->in_shaper_func = dc_create_transfer_func();
|
||||
if (plane_state->in_shaper_func != NULL) {
|
||||
plane_state->in_shaper_func->type = TF_TYPE_BYPASS;
|
||||
@ -67,7 +66,6 @@ static void construct(struct dc_context *ctx, struct dc_plane_state *plane_state
|
||||
plane_state->blend_tf->ctx = ctx;
|
||||
}
|
||||
|
||||
#endif
|
||||
}
|
||||
|
||||
static void destruct(struct dc_plane_state *plane_state)
|
||||
@ -80,7 +78,6 @@ static void destruct(struct dc_plane_state *plane_state)
|
||||
plane_state->in_transfer_func);
|
||||
plane_state->in_transfer_func = NULL;
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (plane_state->in_shaper_func != NULL) {
|
||||
dc_transfer_func_release(
|
||||
plane_state->in_shaper_func);
|
||||
@ -97,7 +94,6 @@ static void destruct(struct dc_plane_state *plane_state)
|
||||
plane_state->blend_tf = NULL;
|
||||
}
|
||||
|
||||
#endif
|
||||
}
|
||||
|
||||
/*******************************************************************************
|
||||
@ -262,7 +258,6 @@ struct dc_transfer_func *dc_create_transfer_func(void)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
static void dc_3dlut_func_free(struct kref *kref)
|
||||
{
|
||||
struct dc_3dlut *lut = container_of(kref, struct dc_3dlut, refcount);
|
||||
@ -296,6 +291,5 @@ void dc_3dlut_func_retain(struct dc_3dlut *lut)
|
||||
{
|
||||
kref_get(&lut->refcount);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
|
@ -113,17 +113,13 @@ struct dc_caps {
|
||||
bool psp_setup_panel_mode;
|
||||
bool extended_aux_timeout_support;
|
||||
bool dmcub_support;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
bool hw_3d_lut;
|
||||
#endif
|
||||
struct dc_plane_cap planes[MAX_PLANES];
|
||||
};
|
||||
|
||||
struct dc_bug_wa {
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool no_connect_phy_config;
|
||||
bool dedcn20_305_wa;
|
||||
#endif
|
||||
bool skip_clock_update;
|
||||
};
|
||||
|
||||
@ -364,10 +360,8 @@ struct dc_debug_options {
|
||||
bool disable_dfs_bypass;
|
||||
bool disable_dpp_power_gate;
|
||||
bool disable_hubp_power_gate;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool disable_dsc_power_gate;
|
||||
int dsc_min_slice_height_override;
|
||||
#endif
|
||||
bool disable_pplib_wm_range;
|
||||
enum wm_report_mode pplib_wm_report_mode;
|
||||
unsigned int min_disp_clk_khz;
|
||||
@ -406,9 +400,7 @@ struct dc_debug_options {
|
||||
bool dmcub_emulation;
|
||||
bool dmub_command_table; /* for testing only */
|
||||
struct dc_bw_validation_profile bw_val_profile;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool disable_fec;
|
||||
#endif
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_1
|
||||
bool disable_48mhz_pwrdwn;
|
||||
#endif
|
||||
@ -417,9 +409,7 @@ struct dc_debug_options {
|
||||
*/
|
||||
unsigned int force_min_dcfclk_mhz;
|
||||
bool disable_timing_sync;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool cm_in_bypass;
|
||||
#endif
|
||||
int force_clock_mode;/*every mode change.*/
|
||||
|
||||
bool nv12_iflip_vm_wa;
|
||||
@ -432,7 +422,6 @@ struct dc_debug_data {
|
||||
uint32_t auxErrorCount;
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
struct dc_phy_addr_space_config {
|
||||
struct {
|
||||
uint64_t start_addr;
|
||||
@ -462,7 +451,6 @@ struct dc_virtual_addr_space_config {
|
||||
uint32_t page_table_block_size_in_bytes;
|
||||
uint8_t page_table_depth; // 1 = 1 level, 2 = 2 level, etc. 0 = invalid
|
||||
};
|
||||
#endif
|
||||
|
||||
struct dc_bounding_box_overrides {
|
||||
int sr_exit_time_ns;
|
||||
@ -490,9 +478,7 @@ struct dc {
|
||||
struct dc_bounding_box_overrides bb_overrides;
|
||||
struct dc_bug_wa work_arounds;
|
||||
struct dc_context *ctx;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
struct dc_phy_addr_space_config vm_pa_config;
|
||||
#endif
|
||||
|
||||
uint8_t link_count;
|
||||
struct dc_link *links[MAX_PIPES * 2];
|
||||
@ -530,10 +516,8 @@ struct dc {
|
||||
struct dc_debug_data debug_data;
|
||||
|
||||
const char *build_id;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
struct vm_helper *vm_helper;
|
||||
const struct gpu_info_soc_bounding_box_v1_0 *soc_bounding_box;
|
||||
#endif
|
||||
};
|
||||
|
||||
enum frame_buffer_mode {
|
||||
@ -570,13 +554,11 @@ struct dc_init_data {
|
||||
|
||||
struct dc_config flags;
|
||||
uint32_t log_mask;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
/**
|
||||
* gpu_info FW provided soc bounding box struct or 0 if not
|
||||
* available in FW
|
||||
*/
|
||||
const struct gpu_info_soc_bounding_box_v1_0 *soc_bounding_box;
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dc_callback_init {
|
||||
@ -591,11 +573,9 @@ struct dc *dc_create(const struct dc_init_data *init_params);
|
||||
void dc_hardware_init(struct dc *dc);
|
||||
|
||||
int dc_get_vmid_use_vector(struct dc *dc);
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
void dc_setup_vm_context(struct dc *dc, struct dc_virtual_addr_space_config *va_config, int vmid);
|
||||
/* Returns the number of vmids supported */
|
||||
int dc_setup_system_context(struct dc *dc, struct dc_phy_addr_space_config *pa_config);
|
||||
#endif
|
||||
void dc_init_callbacks(struct dc *dc,
|
||||
const struct dc_callback_init *init_params);
|
||||
void dc_deinit_callbacks(struct dc *dc);
|
||||
@ -671,7 +651,6 @@ struct dc_transfer_func {
|
||||
};
|
||||
};
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
|
||||
union dc_3dlut_state {
|
||||
struct {
|
||||
@ -695,7 +674,6 @@ struct dc_3dlut {
|
||||
union dc_3dlut_state state;
|
||||
struct dc_context *ctx;
|
||||
};
|
||||
#endif
|
||||
/*
|
||||
* This structure is filled in by dc_surface_get_status and contains
|
||||
* the last requested address and the currently active address so the called
|
||||
@ -746,9 +724,7 @@ union surface_update_flags {
|
||||
struct dc_plane_state {
|
||||
struct dc_plane_address address;
|
||||
struct dc_plane_flip_time time;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool triplebuffer_flips;
|
||||
#endif
|
||||
struct scaling_taps scaling_quality;
|
||||
struct rect src_rect;
|
||||
struct rect dst_rect;
|
||||
@ -771,11 +747,9 @@ struct dc_plane_state {
|
||||
|
||||
enum dc_color_space color_space;
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dc_3dlut *lut3d_func;
|
||||
struct dc_transfer_func *in_shaper_func;
|
||||
struct dc_transfer_func *blend_tf;
|
||||
#endif
|
||||
|
||||
enum surface_pixel_format format;
|
||||
enum dc_rotation_angle rotation;
|
||||
@ -844,11 +818,9 @@ struct dc_surface_update {
|
||||
|
||||
const struct dc_csc_transform *input_csc_color_matrix;
|
||||
const struct fixed31_32 *coeff_reduction_factor;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
const struct dc_transfer_func *func_shaper;
|
||||
const struct dc_3dlut *lut3d_func;
|
||||
const struct dc_transfer_func *blend_tf;
|
||||
#endif
|
||||
};
|
||||
|
||||
/*
|
||||
@ -869,11 +841,9 @@ void dc_transfer_func_retain(struct dc_transfer_func *dc_tf);
|
||||
void dc_transfer_func_release(struct dc_transfer_func *dc_tf);
|
||||
struct dc_transfer_func *dc_create_transfer_func(void);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dc_3dlut *dc_create_3dlut_func(void);
|
||||
void dc_3dlut_func_release(struct dc_3dlut *lut);
|
||||
void dc_3dlut_func_retain(struct dc_3dlut *lut);
|
||||
#endif
|
||||
/*
|
||||
* This structure holds a surface address. There could be multiple addresses
|
||||
* in cases such as Stereo 3D, Planar YUV, etc. Other per-flip attributes such
|
||||
@ -990,10 +960,8 @@ struct dpcd_caps {
|
||||
bool panel_mode_edp;
|
||||
bool dpcd_display_control_capable;
|
||||
bool ext_receiver_cap_field_present;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
union dpcd_fec_capability fec_cap;
|
||||
struct dpcd_dsc_capabilities dsc_caps;
|
||||
#endif
|
||||
struct dc_lttpr_caps lttpr_caps;
|
||||
|
||||
};
|
||||
@ -1016,14 +984,12 @@ struct dc_container_id {
|
||||
};
|
||||
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct dc_sink_dsc_caps {
|
||||
// 'true' if these are virtual DPCD's DSC caps (immediately upstream of sink in MST topology),
|
||||
// 'false' if they are sink's DSC caps
|
||||
bool is_virtual_dpcd_dsc;
|
||||
struct dsc_dec_dpcd_caps dsc_dec_caps;
|
||||
};
|
||||
#endif
|
||||
|
||||
/*
|
||||
* The sink structure contains EDID and other display device properties
|
||||
@ -1038,9 +1004,7 @@ struct dc_sink {
|
||||
struct stereo_3d_features features_3d[TIMING_3D_FORMAT_MAX];
|
||||
bool converter_disable_audio;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct dc_sink_dsc_caps sink_dsc_caps;
|
||||
#endif
|
||||
|
||||
/* private to DC core */
|
||||
struct dc_link *link;
|
||||
@ -1101,10 +1065,8 @@ bool dc_is_dmcu_initialized(struct dc *dc);
|
||||
|
||||
enum dc_status dc_set_clock(struct dc *dc, enum dc_clock_type clock_type, uint32_t clk_khz, uint32_t stepping);
|
||||
void dc_get_clock(struct dc *dc, enum dc_clock_type clock_type, struct dc_clock_config *clock_cfg);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DSC_SUPPORT)
|
||||
/*******************************************************************************
|
||||
* DSC Interfaces
|
||||
******************************************************************************/
|
||||
#include "dc_dsc.h"
|
||||
#endif
|
||||
#endif /* DC_INTERFACE_H_ */
|
||||
|
@ -129,9 +129,7 @@ struct dc_link_training_overrides {
|
||||
bool *alternate_scrambler_reset;
|
||||
bool *enhanced_framing;
|
||||
bool *mst_enable;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool *fec_enable;
|
||||
#endif
|
||||
};
|
||||
|
||||
union dpcd_rev {
|
||||
@ -536,7 +534,6 @@ union test_misc {
|
||||
unsigned char raw;
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* FEC capability DPCD register field bits-*/
|
||||
union dpcd_fec_capability {
|
||||
struct {
|
||||
@ -661,6 +658,5 @@ struct dpcd_dsc_capabilities {
|
||||
union dpcd_dsc_ext_capabilities dsc_ext_caps;
|
||||
};
|
||||
|
||||
#endif /* CONFIG_DRM_AMD_DC_DSC_SUPPORT */
|
||||
|
||||
#endif /* DC_DP_TYPES_H */
|
||||
|
@ -1,4 +1,3 @@
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#ifndef DC_DSC_H_
|
||||
#define DC_DSC_H_
|
||||
/*
|
||||
@ -69,4 +68,3 @@ bool dc_dsc_compute_config(
|
||||
const struct dc_crtc_timing *timing,
|
||||
struct dc_dsc_config *dsc_cfg);
|
||||
#endif
|
||||
#endif
|
||||
|
@ -167,12 +167,10 @@ enum surface_pixel_format {
|
||||
/*swaped & float*/
|
||||
SURFACE_PIXEL_FORMAT_GRPH_ABGR16161616F,
|
||||
/*grow graphics here if necessary */
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
SURFACE_PIXEL_FORMAT_GRPH_RGB111110_FIX,
|
||||
SURFACE_PIXEL_FORMAT_GRPH_BGR101111_FIX,
|
||||
SURFACE_PIXEL_FORMAT_GRPH_RGB111110_FLOAT,
|
||||
SURFACE_PIXEL_FORMAT_GRPH_BGR101111_FLOAT,
|
||||
#endif
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_BEGIN,
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_420_YCbCr =
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_BEGIN,
|
||||
@ -180,10 +178,8 @@ enum surface_pixel_format {
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_420_10bpc_YCbCr,
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_420_10bpc_YCrCb,
|
||||
SURFACE_PIXEL_FORMAT_SUBSAMPLE_END,
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_ACrYCb2101010,
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_CrYCbA1010102,
|
||||
#endif
|
||||
SURFACE_PIXEL_FORMAT_VIDEO_AYCrCb8888,
|
||||
SURFACE_PIXEL_FORMAT_INVALID
|
||||
|
||||
@ -222,12 +218,10 @@ enum tile_split_values {
|
||||
DC_ROTATED_MICRO_TILING = 0x3,
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
enum tripleBuffer_enable {
|
||||
DC_TRIPLEBUFFER_DISABLE = 0x0,
|
||||
DC_TRIPLEBUFFER_ENABLE = 0x1,
|
||||
};
|
||||
#endif
|
||||
|
||||
/* TODO: These values come from hardware spec. We need to readdress this
|
||||
* if they ever change.
|
||||
@ -427,13 +421,11 @@ struct dc_csc_transform {
|
||||
bool enable_adjustment;
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
struct dc_rgb_fixed {
|
||||
struct fixed31_32 red;
|
||||
struct fixed31_32 green;
|
||||
struct fixed31_32 blue;
|
||||
};
|
||||
#endif
|
||||
|
||||
struct dc_gamma {
|
||||
struct kref refcount;
|
||||
@ -468,10 +460,8 @@ enum dc_cursor_color_format {
|
||||
CURSOR_MODE_COLOR_1BIT_AND,
|
||||
CURSOR_MODE_COLOR_PRE_MULTIPLIED_ALPHA,
|
||||
CURSOR_MODE_COLOR_UN_PRE_MULTIPLIED_ALPHA,
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
CURSOR_MODE_COLOR_64BIT_FP_PRE_MULTIPLIED,
|
||||
CURSOR_MODE_COLOR_64BIT_FP_UN_PRE_MULTIPLIED
|
||||
#endif
|
||||
};
|
||||
|
||||
/*
|
||||
@ -626,10 +616,8 @@ enum dc_color_depth {
|
||||
COLOR_DEPTH_121212,
|
||||
COLOR_DEPTH_141414,
|
||||
COLOR_DEPTH_161616,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
COLOR_DEPTH_999,
|
||||
COLOR_DEPTH_111111,
|
||||
#endif
|
||||
COLOR_DEPTH_COUNT
|
||||
};
|
||||
|
||||
@ -690,9 +678,7 @@ struct dc_crtc_timing_flags {
|
||||
* rates less than or equal to 340Mcsc */
|
||||
uint32_t LTE_340MCSC_SCRAMBLE:1;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
uint32_t DSC : 1; /* Use DSC with this timing */
|
||||
#endif
|
||||
};
|
||||
|
||||
enum dc_timing_3d_format {
|
||||
@ -717,7 +703,6 @@ enum dc_timing_3d_format {
|
||||
TIMING_3D_FORMAT_MAX,
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct dc_dsc_config {
|
||||
uint32_t num_slices_h; /* Number of DSC slices - horizontal */
|
||||
uint32_t num_slices_v; /* Number of DSC slices - vertical */
|
||||
@ -728,7 +713,6 @@ struct dc_dsc_config {
|
||||
bool ycbcr422_simple; /* Tell DSC engine to convert YCbCr 4:2:2 to 'YCbCr 4:2:2 simple'. */
|
||||
int32_t rc_buffer_size; /* DSC RC buffer block size in bytes */
|
||||
};
|
||||
#endif
|
||||
struct dc_crtc_timing {
|
||||
uint32_t h_total;
|
||||
uint32_t h_border_left;
|
||||
@ -755,9 +739,7 @@ struct dc_crtc_timing {
|
||||
enum scanning_type scan_type;
|
||||
|
||||
struct dc_crtc_timing_flags flags;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct dc_dsc_config dsc_cfg;
|
||||
#endif
|
||||
};
|
||||
|
||||
#ifndef AMD_EDID_UTILITY
|
||||
@ -796,7 +778,6 @@ enum vram_type {
|
||||
VIDEO_MEMORY_TYPE_GDDR6 = 6,
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
enum dwb_cnv_out_bpc {
|
||||
DWB_CNV_OUT_BPC_8BPC = 0,
|
||||
DWB_CNV_OUT_BPC_10BPC = 1,
|
||||
@ -847,7 +828,6 @@ struct mcif_buf_params {
|
||||
unsigned int swlock;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
||||
#define MAX_TG_COLOR_VALUE 0x3FF
|
||||
struct tg_color {
|
||||
|
@ -29,13 +29,11 @@
|
||||
#include "dc_types.h"
|
||||
#include "grph_object_defs.h"
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
enum dc_link_fec_state {
|
||||
dc_link_fec_not_ready,
|
||||
dc_link_fec_ready,
|
||||
dc_link_fec_enabled
|
||||
};
|
||||
#endif
|
||||
struct dc_link_status {
|
||||
bool link_active;
|
||||
struct dpcd_caps *dpcd_caps;
|
||||
@ -141,9 +139,7 @@ struct dc_link {
|
||||
|
||||
struct link_trace link_trace;
|
||||
struct gpio *hpd_gpio;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
enum dc_link_fec_state fec_state;
|
||||
#endif
|
||||
};
|
||||
|
||||
const struct dc_link_status *dc_link_get_status(const struct dc_link *dc_link);
|
||||
|
@ -52,7 +52,6 @@ struct freesync_context {
|
||||
bool dummy;
|
||||
};
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
enum hubp_dmdata_mode {
|
||||
DMDATA_SW_MODE,
|
||||
DMDATA_HW_MODE
|
||||
@ -82,9 +81,7 @@ struct dc_dmdata_attributes {
|
||||
/* An unbounded array of uint32s, represents software dmdata to be loaded */
|
||||
uint32_t *dmdata_sw_data;
|
||||
};
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dc_writeback_info {
|
||||
bool wb_enabled;
|
||||
int dwb_pipe_inst;
|
||||
@ -96,7 +93,6 @@ struct dc_writeback_update {
|
||||
unsigned int num_wb_info;
|
||||
struct dc_writeback_info writeback_info[MAX_DWB_PIPES];
|
||||
};
|
||||
#endif
|
||||
|
||||
enum vertical_interrupt_ref_point {
|
||||
START_V_UPDATE = 0,
|
||||
@ -121,9 +117,7 @@ union stream_update_flags {
|
||||
uint32_t abm_level:1;
|
||||
uint32_t dpms_off:1;
|
||||
uint32_t gamut_remap:1;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
uint32_t wb_update:1;
|
||||
#endif
|
||||
} bits;
|
||||
|
||||
uint32_t raw;
|
||||
@ -204,11 +198,9 @@ struct dc_stream_state {
|
||||
|
||||
struct crtc_trigger_info triggered_crtc_reset;
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/* writeback */
|
||||
unsigned int num_wb_info;
|
||||
struct dc_writeback_info writeback_info[MAX_DWB_PIPES];
|
||||
#endif
|
||||
/* Computed state bits */
|
||||
bool mode_changed : 1;
|
||||
|
||||
@ -227,9 +219,7 @@ struct dc_stream_state {
|
||||
bool apply_seamless_boot_optimization;
|
||||
|
||||
uint32_t stream_id;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool is_dsc_enabled;
|
||||
#endif
|
||||
union stream_update_flags update_flags;
|
||||
};
|
||||
|
||||
@ -260,12 +250,8 @@ struct dc_stream_update {
|
||||
|
||||
struct dc_csc_transform *output_csc_transform;
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dc_writeback_update *wb_update;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DSC_SUPPORT)
|
||||
struct dc_dsc_config *dsc_config;
|
||||
#endif
|
||||
};
|
||||
|
||||
bool dc_is_stream_unchanged(
|
||||
@ -355,7 +341,6 @@ bool dc_add_all_planes_for_stream(
|
||||
int plane_count,
|
||||
struct dc_state *context);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool dc_stream_add_writeback(struct dc *dc,
|
||||
struct dc_stream_state *stream,
|
||||
struct dc_writeback_info *wb_info);
|
||||
@ -366,7 +351,6 @@ bool dc_stream_dmdata_status_done(struct dc *dc, struct dc_stream_state *stream)
|
||||
bool dc_stream_set_dynamic_metadata(struct dc *dc,
|
||||
struct dc_stream_state *stream,
|
||||
struct dc_dmdata_attributes *dmdata_attr);
|
||||
#endif
|
||||
|
||||
enum dc_status dc_validate_stream(struct dc *dc, struct dc_stream_state *stream);
|
||||
|
||||
|
@ -468,7 +468,6 @@ enum display_content_type {
|
||||
DISPLAY_CONTENT_TYPE_GAME = 8
|
||||
};
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/* writeback */
|
||||
struct dwb_stereo_params {
|
||||
bool stereo_enabled; /* false: normal mode, true: 3D stereo */
|
||||
@ -499,7 +498,6 @@ struct dc_dwb_params {
|
||||
enum dwb_subsample_position subsample_position;
|
||||
struct dc_transfer_func *out_transfer_func;
|
||||
};
|
||||
#endif
|
||||
|
||||
/* audio*/
|
||||
|
||||
@ -607,9 +605,7 @@ enum dc_infoframe_type {
|
||||
DC_HDMI_INFOFRAME_TYPE_AVI = 0x82,
|
||||
DC_HDMI_INFOFRAME_TYPE_SPD = 0x83,
|
||||
DC_HDMI_INFOFRAME_TYPE_AUDIO = 0x84,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
DC_DP_INFOFRAME_TYPE_PPS = 0x10,
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dc_info_packet {
|
||||
@ -788,7 +784,6 @@ struct dc_clock_config {
|
||||
#endif /*AMD_EDID_UTILITY*/
|
||||
//AMD EDID UTILITY does not need any of the above structures
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* DSC DPCD capabilities */
|
||||
union dsc_slice_caps1 {
|
||||
struct {
|
||||
@ -858,6 +853,5 @@ struct dsc_dec_dpcd_caps {
|
||||
uint32_t branch_overall_throughput_1_mps; /* In MPs */
|
||||
uint32_t branch_max_line_width;
|
||||
};
|
||||
#endif
|
||||
|
||||
#endif /* DC_TYPES_H_ */
|
||||
|
@ -67,7 +67,6 @@
|
||||
SRI(DC_ABM1_HGLS_REG_READ_PROGRESS, ABM, id), \
|
||||
NBIO_SR(BIOS_SCRATCH_2)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define ABM_DCN20_REG_LIST() \
|
||||
ABM_COMMON_REG_LIST_DCE_BASE(), \
|
||||
SR(DC_ABM1_HG_SAMPLE_RATE), \
|
||||
@ -81,7 +80,6 @@
|
||||
SR(DC_ABM1_LS_MIN_MAX_PIXEL_VALUE_THRES), \
|
||||
SR(DC_ABM1_HGLS_REG_READ_PROGRESS), \
|
||||
NBIO_SR(BIOS_SCRATCH_2)
|
||||
#endif
|
||||
|
||||
#define ABM_SF(reg_name, field_name, post_fix)\
|
||||
.field_name = reg_name ## __ ## field_name ## post_fix
|
||||
@ -163,9 +161,7 @@
|
||||
ABM_SF(ABM0_DC_ABM1_HGLS_REG_READ_PROGRESS, \
|
||||
ABM1_BL_REG_READ_MISSED_FRAME_CLEAR, mask_sh)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define ABM_MASK_SH_LIST_DCN20(mask_sh) ABM_MASK_SH_LIST_DCE110(mask_sh)
|
||||
#endif
|
||||
|
||||
#define ABM_REG_FIELD_LIST(type) \
|
||||
type ABM1_HG_NUM_OF_BINS_SEL; \
|
||||
|
@ -30,7 +30,6 @@
|
||||
#include "inc/hw/aux_engine.h"
|
||||
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
#define AUX_COMMON_REG_LIST0(id)\
|
||||
SRI(AUX_CONTROL, DP_AUX, id), \
|
||||
SRI(AUX_ARB_CONTROL, DP_AUX, id), \
|
||||
@ -39,7 +38,6 @@
|
||||
SRI(AUX_INTERRUPT_CONTROL, DP_AUX, id), \
|
||||
SRI(AUX_DPHY_RX_CONTROL1, DP_AUX, id), \
|
||||
SRI(AUX_SW_STATUS, DP_AUX, id)
|
||||
#endif
|
||||
|
||||
#define AUX_COMMON_REG_LIST(id)\
|
||||
SRI(AUX_CONTROL, DP_AUX, id), \
|
||||
|
@ -1004,7 +1004,6 @@ static bool get_pixel_clk_frequency_100hz(
|
||||
return false;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
|
||||
/* this table is use to find *1.001 and /1.001 pixel rates from non-precise pixel rate */
|
||||
struct pixel_rate_range_table_entry {
|
||||
@ -1064,7 +1063,6 @@ static const struct clock_source_funcs dcn20_clk_src_funcs = {
|
||||
.get_pix_clk_dividers = dce112_get_pix_clk_dividers,
|
||||
.get_pixel_clk_frequency_100hz = get_pixel_clk_frequency_100hz
|
||||
};
|
||||
#endif
|
||||
|
||||
/*****************************************/
|
||||
/* Constructor */
|
||||
@ -1435,7 +1433,6 @@ bool dce112_clk_src_construct(
|
||||
return true;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool dcn20_clk_src_construct(
|
||||
struct dce110_clk_src *clk_src,
|
||||
struct dc_context *ctx,
|
||||
@ -1451,4 +1448,3 @@ bool dcn20_clk_src_construct(
|
||||
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
@ -55,7 +55,6 @@
|
||||
CS_SF(PHYPLLA_PIXCLK_RESYNC_CNTL, PHYPLLA_DCCG_DEEP_COLOR_CNTL, mask_sh),\
|
||||
CS_SF(PHYPLLA_PIXCLK_RESYNC_CNTL, PHYPLLA_PIXCLK_DOUBLE_RATE_ENABLE, mask_sh)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define CS_COMMON_REG_LIST_DCN2_0(index, pllid) \
|
||||
SRI(PIXCLK_RESYNC_CNTL, PHYPLL, pllid),\
|
||||
SRII(PHASE, DP_DTO, 0),\
|
||||
@ -76,7 +75,6 @@
|
||||
SRII(PIXEL_RATE_CNTL, OTG, 3),\
|
||||
SRII(PIXEL_RATE_CNTL, OTG, 4),\
|
||||
SRII(PIXEL_RATE_CNTL, OTG, 5)
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
#define CS_COMMON_REG_LIST_DCN2_1(index, pllid) \
|
||||
@ -95,13 +93,11 @@
|
||||
SRII(PIXEL_RATE_CNTL, OTG, 3)
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define CS_COMMON_MASK_SH_LIST_DCN2_0(mask_sh)\
|
||||
CS_SF(DP_DTO0_PHASE, DP_DTO0_PHASE, mask_sh),\
|
||||
CS_SF(DP_DTO0_MODULO, DP_DTO0_MODULO, mask_sh),\
|
||||
CS_SF(PHYPLLA_PIXCLK_RESYNC_CNTL, PHYPLLA_DCCG_DEEP_COLOR_CNTL, mask_sh),\
|
||||
CS_SF(OTG0_PIXEL_RATE_CNTL, DP_DTO0_ENABLE, mask_sh)
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
|
||||
@ -201,7 +197,6 @@ bool dce112_clk_src_construct(
|
||||
const struct dce110_clk_src_shift *cs_shift,
|
||||
const struct dce110_clk_src_mask *cs_mask);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool dcn20_clk_src_construct(
|
||||
struct dce110_clk_src *clk_src,
|
||||
struct dc_context *ctx,
|
||||
@ -210,6 +205,5 @@ bool dcn20_clk_src_construct(
|
||||
const struct dce110_clk_src_regs *regs,
|
||||
const struct dce110_clk_src_shift *cs_shift,
|
||||
const struct dce110_clk_src_mask *cs_mask);
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
@ -748,9 +748,7 @@ static bool dcn10_is_dmcu_initialized(struct dmcu *dmcu)
|
||||
return true;
|
||||
}
|
||||
|
||||
#endif //(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
|
||||
static bool dcn20_lock_phy(struct dmcu *dmcu)
|
||||
{
|
||||
@ -798,7 +796,7 @@ static bool dcn20_unlock_phy(struct dmcu *dmcu)
|
||||
return true;
|
||||
}
|
||||
|
||||
#endif //(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#endif //(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
|
||||
static const struct dmcu_funcs dce_funcs = {
|
||||
.dmcu_init = dce_dmcu_init,
|
||||
@ -822,9 +820,7 @@ static const struct dmcu_funcs dcn10_funcs = {
|
||||
.get_psr_wait_loop = dcn10_get_psr_wait_loop,
|
||||
.is_dmcu_initialized = dcn10_is_dmcu_initialized
|
||||
};
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
static const struct dmcu_funcs dcn20_funcs = {
|
||||
.dmcu_init = dcn10_dmcu_init,
|
||||
.load_iram = dcn10_dmcu_load_iram,
|
||||
@ -837,7 +833,6 @@ static const struct dmcu_funcs dcn20_funcs = {
|
||||
.lock_phy = dcn20_lock_phy,
|
||||
.unlock_phy = dcn20_unlock_phy
|
||||
};
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
static const struct dmcu_funcs dcn21_funcs = {
|
||||
@ -853,6 +848,7 @@ static const struct dmcu_funcs dcn21_funcs = {
|
||||
.unlock_phy = dcn20_unlock_phy
|
||||
};
|
||||
#endif
|
||||
#endif
|
||||
|
||||
static void dce_dmcu_construct(
|
||||
struct dce_dmcu *dmcu_dce,
|
||||
@ -872,7 +868,7 @@ static void dce_dmcu_construct(
|
||||
dmcu_dce->dmcu_mask = dmcu_mask;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
static void dcn21_dmcu_construct(
|
||||
struct dce_dmcu *dmcu_dce,
|
||||
struct dc_context *ctx,
|
||||
@ -934,9 +930,7 @@ struct dmcu *dcn10_dmcu_create(
|
||||
|
||||
return &dmcu_dce->base;
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dmcu *dcn20_dmcu_create(
|
||||
struct dc_context *ctx,
|
||||
const struct dce_dmcu_registers *regs,
|
||||
@ -957,7 +951,6 @@ struct dmcu *dcn20_dmcu_create(
|
||||
|
||||
return &dmcu_dce->base;
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
struct dmcu *dcn21_dmcu_create(
|
||||
@ -981,6 +974,7 @@ struct dmcu *dcn21_dmcu_create(
|
||||
return &dmcu_dce->base;
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
void dce_dmcu_destroy(struct dmcu **dmcu)
|
||||
{
|
||||
|
@ -266,13 +266,11 @@ struct dmcu *dcn10_dmcu_create(
|
||||
const struct dce_dmcu_shift *dmcu_shift,
|
||||
const struct dce_dmcu_mask *dmcu_mask);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dmcu *dcn20_dmcu_create(
|
||||
struct dc_context *ctx,
|
||||
const struct dce_dmcu_registers *regs,
|
||||
const struct dce_dmcu_shift *dmcu_shift,
|
||||
const struct dce_dmcu_mask *dmcu_mask);
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
struct dmcu *dcn21_dmcu_create(
|
||||
|
@ -210,7 +210,6 @@
|
||||
SR(DC_IP_REQUEST_CNTL), \
|
||||
BL_REG_LIST()
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define HWSEQ_DCN2_REG_LIST()\
|
||||
HWSEQ_DCN_REG_LIST(), \
|
||||
HSWEQ_DCN_PIXEL_RATE_REG_LIST(OTG, 0), \
|
||||
@ -276,7 +275,6 @@
|
||||
SR(D6VGA_CONTROL), \
|
||||
SR(DC_IP_REQUEST_CNTL), \
|
||||
BL_REG_LIST()
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
#define HWSEQ_DCN21_REG_LIST()\
|
||||
@ -577,7 +575,6 @@ struct dce_hwseq_registers {
|
||||
HWS_SF(, VGA_TEST_CONTROL, VGA_TEST_RENDER_START, mask_sh),\
|
||||
HWSEQ_LVTMA_MASK_SH_LIST(mask_sh)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define HWSEQ_DCN2_MASK_SH_LIST(mask_sh)\
|
||||
HWSEQ_DCN_MASK_SH_LIST(mask_sh), \
|
||||
HWS_SF(, DCHUBBUB_GLOBAL_TIMER_CNTL, DCHUBBUB_GLOBAL_TIMER_REFDIV, mask_sh), \
|
||||
@ -637,7 +634,6 @@ struct dce_hwseq_registers {
|
||||
HWS_SF(, DOMAIN21_PG_STATUS, DOMAIN21_PGFSM_PWR_STATUS, mask_sh), \
|
||||
HWS_SF(, DC_IP_REQUEST_CNTL, IP_REQUEST_EN, mask_sh), \
|
||||
HWSEQ_LVTMA_MASK_SH_LIST(mask_sh)
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
#define HWSEQ_DCN21_MASK_SH_LIST(mask_sh)\
|
||||
|
@ -296,9 +296,7 @@ static bool setup_engine(
|
||||
struct dce_i2c_hw *dce_i2c_hw)
|
||||
{
|
||||
uint32_t i2c_setup_limit = I2C_SETUP_TIME_LIMIT_DCE;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
uint32_t reset_length = 0;
|
||||
#endif
|
||||
/* we have checked I2c not used by DMCU, set SW use I2C REQ to 1 to indicate SW using it*/
|
||||
REG_UPDATE(DC_I2C_ARBITRATION, DC_I2C_SW_USE_I2C_REG_REQ, 1);
|
||||
|
||||
@ -322,14 +320,12 @@ static bool setup_engine(
|
||||
REG_UPDATE_N(SETUP, 2,
|
||||
FN(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_TIME_LIMIT), i2c_setup_limit,
|
||||
FN(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_ENABLE), 1);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
} else {
|
||||
reset_length = dce_i2c_hw->send_reset_length;
|
||||
REG_UPDATE_N(SETUP, 3,
|
||||
FN(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_TIME_LIMIT), i2c_setup_limit,
|
||||
FN(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_SEND_RESET_LENGTH), reset_length,
|
||||
FN(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_ENABLE), 1);
|
||||
#endif
|
||||
}
|
||||
/* Program HW priority
|
||||
* set to High - interrupt software I2C at any time
|
||||
@ -705,7 +701,6 @@ void dcn1_i2c_hw_construct(
|
||||
dce_i2c_hw->setup_limit = I2C_SETUP_TIME_LIMIT_DCN;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
void dcn2_i2c_hw_construct(
|
||||
struct dce_i2c_hw *dce_i2c_hw,
|
||||
struct dc_context *ctx,
|
||||
@ -724,4 +719,3 @@ void dcn2_i2c_hw_construct(
|
||||
if (ctx->dc->debug.scl_reset_length10)
|
||||
dce_i2c_hw->send_reset_length = I2C_SEND_RESET_LENGTH_10;
|
||||
}
|
||||
#endif
|
||||
|
@ -177,9 +177,7 @@ struct dce_i2c_shift {
|
||||
uint8_t DC_I2C_INDEX;
|
||||
uint8_t DC_I2C_INDEX_WRITE;
|
||||
uint8_t XTAL_REF_DIV;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
uint8_t DC_I2C_DDC1_SEND_RESET_LENGTH;
|
||||
#endif
|
||||
uint8_t DC_I2C_REG_RW_CNTL_STATUS;
|
||||
};
|
||||
|
||||
@ -220,17 +218,13 @@ struct dce_i2c_mask {
|
||||
uint32_t DC_I2C_INDEX;
|
||||
uint32_t DC_I2C_INDEX_WRITE;
|
||||
uint32_t XTAL_REF_DIV;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
uint32_t DC_I2C_DDC1_SEND_RESET_LENGTH;
|
||||
#endif
|
||||
uint32_t DC_I2C_REG_RW_CNTL_STATUS;
|
||||
};
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define I2C_COMMON_MASK_SH_LIST_DCN2(mask_sh)\
|
||||
I2C_COMMON_MASK_SH_LIST_DCE110(mask_sh),\
|
||||
I2C_SF(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_SEND_RESET_LENGTH, mask_sh)
|
||||
#endif
|
||||
|
||||
struct dce_i2c_registers {
|
||||
uint32_t SETUP;
|
||||
@ -312,7 +306,6 @@ void dcn1_i2c_hw_construct(
|
||||
const struct dce_i2c_shift *shifts,
|
||||
const struct dce_i2c_mask *masks);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
void dcn2_i2c_hw_construct(
|
||||
struct dce_i2c_hw *dce_i2c_hw,
|
||||
struct dc_context *ctx,
|
||||
@ -320,7 +313,6 @@ void dcn2_i2c_hw_construct(
|
||||
const struct dce_i2c_registers *regs,
|
||||
const struct dce_i2c_shift *shifts,
|
||||
const struct dce_i2c_mask *masks);
|
||||
#endif
|
||||
|
||||
bool dce_i2c_submit_command_hw(
|
||||
struct resource_pool *pool,
|
||||
|
@ -1322,9 +1322,7 @@ static enum dc_status apply_single_controller_ctx_to_hw(
|
||||
struct dc_stream_state *stream = pipe_ctx->stream;
|
||||
struct drr_params params = {0};
|
||||
unsigned int event_triggers = 0;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct pipe_ctx *odm_pipe = pipe_ctx->next_odm_pipe;
|
||||
#endif
|
||||
|
||||
if (dc->hwss.disable_stream_gating) {
|
||||
dc->hwss.disable_stream_gating(dc, pipe_ctx);
|
||||
@ -1390,7 +1388,6 @@ static enum dc_status apply_single_controller_ctx_to_hw(
|
||||
pipe_ctx->stream_res.opp,
|
||||
&stream->bit_depth_params,
|
||||
&stream->clamping);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
while (odm_pipe) {
|
||||
odm_pipe->stream_res.opp->funcs->opp_set_dyn_expansion(
|
||||
odm_pipe->stream_res.opp,
|
||||
@ -1404,7 +1401,6 @@ static enum dc_status apply_single_controller_ctx_to_hw(
|
||||
&stream->clamping);
|
||||
odm_pipe = odm_pipe->next_odm_pipe;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (!stream->dpms_off)
|
||||
core_link_enable_stream(context, pipe_ctx);
|
||||
|
@ -290,12 +290,8 @@ void dpp1_cnv_setup (
|
||||
enum surface_pixel_format format,
|
||||
enum expansion_mode mode,
|
||||
struct dc_csc_transform input_csc_color_matrix,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
enum dc_color_space input_color_space,
|
||||
struct cnv_alpha_2bit_lut *alpha_2bit_lut)
|
||||
#else
|
||||
enum dc_color_space input_color_space)
|
||||
#endif
|
||||
{
|
||||
uint32_t pixel_format;
|
||||
uint32_t alpha_en;
|
||||
@ -542,11 +538,9 @@ static const struct dpp_funcs dcn10_dpp_funcs = {
|
||||
.set_optional_cursor_attributes = dpp1_cnv_set_optional_cursor_attributes,
|
||||
.dpp_dppclk_control = dpp1_dppclk_control,
|
||||
.dpp_set_hdr_multiplier = dpp1_set_hdr_multiplier,
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
.dpp_program_blnd_lut = NULL,
|
||||
.dpp_program_shaper_lut = NULL,
|
||||
.dpp_program_3dlut = NULL
|
||||
#endif
|
||||
};
|
||||
|
||||
static struct dpp_caps dcn10_dpp_cap = {
|
||||
|
@ -1486,12 +1486,8 @@ void dpp1_cnv_setup (
|
||||
enum surface_pixel_format format,
|
||||
enum expansion_mode mode,
|
||||
struct dc_csc_transform input_csc_color_matrix,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
enum dc_color_space input_color_space,
|
||||
struct cnv_alpha_2bit_lut *alpha_2bit_lut);
|
||||
#else
|
||||
enum dc_color_space input_color_space);
|
||||
#endif
|
||||
|
||||
void dpp1_full_bypass(struct dpp *dpp_base);
|
||||
|
||||
|
@ -736,10 +736,8 @@ void dpp1_full_bypass(struct dpp *dpp_base)
|
||||
/* COLOR_KEYER_CONTROL.COLOR_KEYER_EN = 0 this should be default */
|
||||
if (dpp->tf_mask->CM_BYPASS_EN)
|
||||
REG_SET(CM_CONTROL, 0, CM_BYPASS_EN, 1);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
else
|
||||
REG_SET(CM_CONTROL, 0, CM_BYPASS, 1);
|
||||
#endif
|
||||
|
||||
/* Setting degamma bypass for now */
|
||||
REG_SET(CM_DGAM_CONTROL, 0, CM_DGAM_LUT_MODE, 0);
|
||||
|
@ -218,14 +218,12 @@ static void dpp1_dscl_set_lb(
|
||||
INTERLEAVE_EN, lb_params->interleave_en, /* Interleave source enable */
|
||||
LB_DATA_FORMAT__ALPHA_EN, lb_params->alpha_en); /* Alpha enable */
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
else {
|
||||
/* DSCL caps: pixel data processed in float format */
|
||||
REG_SET_2(LB_DATA_FORMAT, 0,
|
||||
INTERLEAVE_EN, lb_params->interleave_en, /* Interleave source enable */
|
||||
LB_DATA_FORMAT__ALPHA_EN, lb_params->alpha_en); /* Alpha enable */
|
||||
}
|
||||
#endif
|
||||
|
||||
REG_SET_2(LB_MEMORY_CTRL, 0,
|
||||
MEMORY_CONFIG, mem_size_config,
|
||||
|
@ -109,9 +109,7 @@ const struct dwbc_funcs dcn10_dwbc_funcs = {
|
||||
.update = NULL,
|
||||
.set_stereo = NULL,
|
||||
.set_new_content = NULL,
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
.set_warmup = NULL,
|
||||
#endif
|
||||
.dwb_set_scaler = NULL,
|
||||
};
|
||||
|
||||
|
@ -306,7 +306,6 @@ void hubp1_program_pixel_format(
|
||||
REG_UPDATE(DCSURF_SURFACE_CONFIG,
|
||||
SURFACE_PIXEL_FORMAT, 12);
|
||||
break;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case SURFACE_PIXEL_FORMAT_GRPH_RGB111110_FIX:
|
||||
REG_UPDATE(DCSURF_SURFACE_CONFIG,
|
||||
SURFACE_PIXEL_FORMAT, 112);
|
||||
@ -327,7 +326,6 @@ void hubp1_program_pixel_format(
|
||||
REG_UPDATE(DCSURF_SURFACE_CONFIG,
|
||||
SURFACE_PIXEL_FORMAT, 119);
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
BREAK_TO_DEBUGGER();
|
||||
break;
|
||||
@ -1251,10 +1249,8 @@ static const struct hubp_funcs dcn10_hubp_funcs = {
|
||||
.hubp_get_underflow_status = hubp1_get_underflow_status,
|
||||
.hubp_init = hubp1_init,
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
.dmdata_set_attributes = NULL,
|
||||
.dmdata_load = NULL,
|
||||
#endif
|
||||
};
|
||||
|
||||
/*****************************************/
|
||||
|
@ -729,13 +729,11 @@ void hubp1_dcc_control(struct hubp *hubp,
|
||||
bool enable,
|
||||
enum hubp_ind_block_size independent_64b_blks);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
bool hubp1_program_surface_flip_and_addr(
|
||||
struct hubp *hubp,
|
||||
const struct dc_plane_address *address,
|
||||
bool flip_immediate);
|
||||
|
||||
#endif
|
||||
bool hubp1_is_flip_pending(struct hubp *hubp);
|
||||
|
||||
void hubp1_cursor_set_attributes(
|
||||
|
@ -49,9 +49,7 @@
|
||||
#include "clk_mgr.h"
|
||||
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "dsc.h"
|
||||
#endif
|
||||
|
||||
#define DC_LOGGER_INIT(logger)
|
||||
|
||||
@ -315,7 +313,6 @@ void dcn10_log_hw_state(struct dc *dc,
|
||||
/* Read shared OTG state registers for all DCNx */
|
||||
optc1_read_otg_state(DCN10TG_FROM_TG(tg), &s);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
/*
|
||||
* For DCN2 and greater, a register on the OPP is used to
|
||||
* determine if the CRTC is blanked instead of the OTG. So use
|
||||
@ -327,9 +324,6 @@ void dcn10_log_hw_state(struct dc *dc,
|
||||
s.blank_enabled = pool->opps[i]->funcs->dpg_is_blanked(pool->opps[i]);
|
||||
else
|
||||
s.blank_enabled = tg->funcs->is_blanked(tg);
|
||||
#else
|
||||
s.blank_enabled = tg->funcs->is_blanked(tg);
|
||||
#endif
|
||||
|
||||
//only print if OTG master is enabled
|
||||
if ((s.otg_enabled & 1) == 0)
|
||||
@ -364,7 +358,6 @@ void dcn10_log_hw_state(struct dc *dc,
|
||||
}
|
||||
DTN_INFO("\n");
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
DTN_INFO("DSC: CLOCK_EN SLICE_WIDTH Bytes_pp\n");
|
||||
for (i = 0; i < pool->res_cap->num_dsc; i++) {
|
||||
struct display_stream_compressor *dsc = pool->dscs[i];
|
||||
@ -419,7 +412,6 @@ void dcn10_log_hw_state(struct dc *dc,
|
||||
}
|
||||
}
|
||||
DTN_INFO("\n");
|
||||
#endif
|
||||
|
||||
DTN_INFO("\nCALCULATED Clocks: dcfclk_khz:%d dcfclk_deep_sleep_khz:%d dispclk_khz:%d\n"
|
||||
"dppclk_khz:%d max_supported_dppclk_khz:%d fclk_khz:%d socclk_khz:%d\n\n",
|
||||
@ -1273,11 +1265,9 @@ static void dcn10_init_hw(struct dc *dc)
|
||||
}
|
||||
|
||||
/* Power gate DSCs */
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
for (i = 0; i < res_pool->res_cap->num_dsc; i++)
|
||||
if (dc->hwss.dsc_pg_control != NULL)
|
||||
dc->hwss.dsc_pg_control(hws, res_pool->dscs[i]->inst, false);
|
||||
#endif
|
||||
|
||||
/* If taking control over from VBIOS, we may want to optimize our first
|
||||
* mode set, so we need to skip powering down pipes until we know which
|
||||
@ -2190,12 +2180,8 @@ static void update_dpp(struct dpp *dpp, struct dc_plane_state *plane_state)
|
||||
plane_state->format,
|
||||
EXPANSION_MODE_ZERO,
|
||||
plane_state->input_csc_color_matrix,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
plane_state->color_space,
|
||||
NULL);
|
||||
#else
|
||||
plane_state->color_space);
|
||||
#endif
|
||||
|
||||
//set scale and bias registers
|
||||
dcn10_build_prescale_params(&bns_params, plane_state);
|
||||
@ -2649,11 +2635,9 @@ static void dcn10_apply_ctx_for_surface(
|
||||
if (num_planes > 0)
|
||||
program_all_pipe_in_tree(dc, top_pipe_to_program, context);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/* Program secondary blending tree and writeback pipes */
|
||||
if ((stream->num_wb_info > 0) && (dc->hwss.program_all_writeback_pipes_in_tree))
|
||||
dc->hwss.program_all_writeback_pipes_in_tree(dc, stream, context);
|
||||
#endif
|
||||
if (interdependent_update)
|
||||
for (i = 0; i < dc->res_pool->pipe_count; i++) {
|
||||
struct pipe_ctx *pipe_ctx = &context->res_ctx.pipe_ctx[i];
|
||||
|
@ -53,11 +53,9 @@ static const struct ipp_funcs dcn10_ipp_funcs = {
|
||||
.ipp_destroy = dcn10_ipp_destroy
|
||||
};
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
static const struct ipp_funcs dcn20_ipp_funcs = {
|
||||
.ipp_destroy = dcn10_ipp_destroy
|
||||
};
|
||||
#endif
|
||||
|
||||
void dcn10_ipp_construct(
|
||||
struct dcn10_ipp *ippn10,
|
||||
@ -76,7 +74,6 @@ void dcn10_ipp_construct(
|
||||
ippn10->ipp_mask = ipp_mask;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
void dcn20_ipp_construct(
|
||||
struct dcn10_ipp *ippn10,
|
||||
struct dc_context *ctx,
|
||||
@ -93,4 +90,3 @@ void dcn20_ipp_construct(
|
||||
ippn10->ipp_shift = ipp_shift;
|
||||
ippn10->ipp_mask = ipp_mask;
|
||||
}
|
||||
#endif
|
||||
|
@ -49,7 +49,6 @@
|
||||
SRI(CURSOR_HOT_SPOT, CURSOR, id), \
|
||||
SRI(CURSOR_DST_OFFSET, CURSOR, id)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define IPP_REG_LIST_DCN20(id) \
|
||||
IPP_REG_LIST_DCN(id), \
|
||||
SRI(CURSOR_SETTINGS, HUBPREQ, id), \
|
||||
@ -60,7 +59,6 @@
|
||||
SRI(CURSOR_POSITION, CURSOR0_, id), \
|
||||
SRI(CURSOR_HOT_SPOT, CURSOR0_, id), \
|
||||
SRI(CURSOR_DST_OFFSET, CURSOR0_, id)
|
||||
#endif
|
||||
|
||||
#define CURSOR0_CURSOR_CONTROL__CURSOR_2X_MAGNIFY__SHIFT 0x4
|
||||
#define CURSOR0_CURSOR_CONTROL__CURSOR_2X_MAGNIFY_MASK 0x00000010L
|
||||
@ -105,7 +103,6 @@
|
||||
IPP_SF(CURSOR0_CURSOR_DST_OFFSET, CURSOR_DST_X_OFFSET, mask_sh), \
|
||||
IPP_SF(CNVC_CFG0_FORMAT_CONTROL, OUTPUT_FP, mask_sh)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define IPP_MASK_SH_LIST_DCN20(mask_sh) \
|
||||
IPP_MASK_SH_LIST_DCN(mask_sh), \
|
||||
IPP_SF(HUBPREQ0_CURSOR_SETTINGS, CURSOR0_DST_Y_OFFSET, mask_sh), \
|
||||
@ -124,7 +121,6 @@
|
||||
IPP_SF(CURSOR0_0_CURSOR_HOT_SPOT, CURSOR_HOT_SPOT_X, mask_sh), \
|
||||
IPP_SF(CURSOR0_0_CURSOR_HOT_SPOT, CURSOR_HOT_SPOT_Y, mask_sh), \
|
||||
IPP_SF(CURSOR0_0_CURSOR_DST_OFFSET, CURSOR_DST_X_OFFSET, mask_sh)
|
||||
#endif
|
||||
|
||||
#define IPP_DCN10_REG_FIELD_LIST(type) \
|
||||
type CNVC_SURFACE_PIXEL_FORMAT; \
|
||||
@ -196,13 +192,11 @@ void dcn10_ipp_construct(struct dcn10_ipp *ippn10,
|
||||
const struct dcn10_ipp_shift *ipp_shift,
|
||||
const struct dcn10_ipp_mask *ipp_mask);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
void dcn20_ipp_construct(struct dcn10_ipp *ippn10,
|
||||
struct dc_context *ctx,
|
||||
int inst,
|
||||
const struct dcn10_ipp_registers *regs,
|
||||
const struct dcn10_ipp_shift *ipp_shift,
|
||||
const struct dcn10_ipp_mask *ipp_mask);
|
||||
#endif
|
||||
|
||||
#endif /* _DCN10_IPP_H_ */
|
||||
|
@ -72,9 +72,7 @@
|
||||
struct dcn10_link_enc_aux_registers {
|
||||
uint32_t AUX_CONTROL;
|
||||
uint32_t AUX_DPHY_RX_CONTROL0;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
uint32_t AUX_DPHY_TX_CONTROL;
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dcn10_link_enc_hpd_registers {
|
||||
@ -106,7 +104,6 @@ struct dcn10_link_enc_registers {
|
||||
uint32_t DP_DPHY_HBR2_PATTERN_CONTROL;
|
||||
uint32_t DP_SEC_CNTL1;
|
||||
uint32_t TMDS_CTL_BITS;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/* DCCG */
|
||||
uint32_t CLOCK_ENABLE;
|
||||
/* DIG */
|
||||
@ -136,7 +133,6 @@ struct dcn10_link_enc_registers {
|
||||
uint32_t RAWLANE2_DIG_PCS_XF_RX_OVRD_IN_3;
|
||||
uint32_t RAWLANE3_DIG_PCS_XF_RX_OVRD_IN_2;
|
||||
uint32_t RAWLANE3_DIG_PCS_XF_RX_OVRD_IN_3;
|
||||
#endif
|
||||
};
|
||||
|
||||
#define LE_SF(reg_name, field_name, post_fix)\
|
||||
@ -242,7 +238,6 @@ struct dcn10_link_enc_registers {
|
||||
type AUX_LS_READ_EN;\
|
||||
type AUX_RX_RECEIVE_WINDOW
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
|
||||
#define DCN20_LINK_ENCODER_DPCS_REG_FIELD_LIST(type) \
|
||||
type RDPCS_PHY_DP_TX0_DATA_EN;\
|
||||
@ -423,20 +418,15 @@ struct dcn10_link_enc_registers {
|
||||
type AUX_TX_PRECHARGE_SYMBOLS; \
|
||||
type AUX_MODE_DET_CHECK_DELAY;\
|
||||
type DPCS_DBG_CBUS_DIS
|
||||
#endif
|
||||
|
||||
struct dcn10_link_enc_shift {
|
||||
DCN_LINK_ENCODER_REG_FIELD_LIST(uint8_t);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
DCN20_LINK_ENCODER_REG_FIELD_LIST(uint8_t);
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dcn10_link_enc_mask {
|
||||
DCN_LINK_ENCODER_REG_FIELD_LIST(uint32_t);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
DCN20_LINK_ENCODER_REG_FIELD_LIST(uint32_t);
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dcn10_link_encoder {
|
||||
|
@ -457,12 +457,10 @@ static const struct mpc_funcs dcn10_mpc_funcs = {
|
||||
.assert_mpcc_idle_before_connect = mpc1_assert_mpcc_idle_before_connect,
|
||||
.init_mpcc_list_from_hw = mpc1_init_mpcc_list_from_hw,
|
||||
.update_blending = mpc1_update_blending,
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
.set_denorm = NULL,
|
||||
.set_denorm_clamp = NULL,
|
||||
.set_output_csc = NULL,
|
||||
.set_output_gamma = NULL,
|
||||
#endif
|
||||
};
|
||||
|
||||
void dcn10_mpc_construct(struct dcn10_mpc *mpc10,
|
||||
|
@ -373,11 +373,9 @@ void opp1_program_oppbuf(
|
||||
*/
|
||||
REG_UPDATE(OPPBUF_CONTROL, OPPBUF_PIXEL_REPETITION, oppbuf->pixel_repetition);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/* Controls the number of padded pixels at the end of a segment */
|
||||
if (REG(OPPBUF_CONTROL1))
|
||||
REG_UPDATE(OPPBUF_CONTROL1, OPPBUF_NUM_SEGMENT_PADDED_PIXELS, oppbuf->num_segment_padded_pixels);
|
||||
#endif
|
||||
}
|
||||
|
||||
void opp1_pipe_clock_control(struct output_pixel_processor *opp, bool enable)
|
||||
@ -404,10 +402,8 @@ static const struct opp_funcs dcn10_opp_funcs = {
|
||||
.opp_program_bit_depth_reduction = opp1_program_bit_depth_reduction,
|
||||
.opp_program_stereo = opp1_program_stereo,
|
||||
.opp_pipe_clock_control = opp1_pipe_clock_control,
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
.opp_set_disp_pattern_generator = NULL,
|
||||
.dpg_is_blanked = NULL,
|
||||
#endif
|
||||
.opp_destroy = opp1_destroy
|
||||
};
|
||||
|
||||
|
@ -1502,7 +1502,6 @@ void dcn10_timing_generator_init(struct optc *optc1)
|
||||
optc1->min_v_sync_width = 1;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* "Containter" vs. "pixel" is a concept within HW blocks, mostly those closer to the back-end. It works like this:
|
||||
*
|
||||
* - In most of the formats (RGB or YCbCr 4:4:4, 4:2:2 uncompressed and DSC 4:2:2 Simple) pixel rate is the same as
|
||||
@ -1515,15 +1514,12 @@ void dcn10_timing_generator_init(struct optc *optc1)
|
||||
* to it) and has to be treated the same as 4:2:0, i.e. target containter rate has to be halved in this case as well.
|
||||
*
|
||||
*/
|
||||
#endif
|
||||
bool optc1_is_two_pixels_per_containter(const struct dc_crtc_timing *timing)
|
||||
{
|
||||
bool two_pix = timing->pixel_encoding == PIXEL_ENCODING_YCBCR420;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
two_pix = two_pix || (timing->flags.DSC && timing->pixel_encoding == PIXEL_ENCODING_YCBCR422
|
||||
&& !timing->dsc_cfg.ycbcr422_simple);
|
||||
#endif
|
||||
return two_pix;
|
||||
}
|
||||
|
||||
|
@ -165,13 +165,11 @@ struct dcn_optc_registers {
|
||||
uint32_t OTG_CRC0_WINDOWB_X_CONTROL;
|
||||
uint32_t OTG_CRC0_WINDOWB_Y_CONTROL;
|
||||
uint32_t GSL_SOURCE_SELECT;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
uint32_t DWB_SOURCE_SELECT;
|
||||
uint32_t OTG_DSC_START_POSITION;
|
||||
uint32_t OPTC_DATA_FORMAT_CONTROL;
|
||||
uint32_t OPTC_BYTES_PER_PIXEL;
|
||||
uint32_t OPTC_WIDTH_CONTROL;
|
||||
#endif
|
||||
};
|
||||
|
||||
#define TG_COMMON_MASK_SH_LIST_DCN(mask_sh)\
|
||||
@ -456,7 +454,6 @@ struct dcn_optc_registers {
|
||||
type MANUAL_FLOW_CONTROL;\
|
||||
type MANUAL_FLOW_CONTROL_SEL;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
|
||||
#define TG_REG_FIELD_LIST(type) \
|
||||
TG_REG_FIELD_LIST_DCN1_0(type)\
|
||||
@ -479,12 +476,6 @@ struct dcn_optc_registers {
|
||||
type OPTC_DWB0_SOURCE_SELECT;\
|
||||
type OPTC_DWB1_SOURCE_SELECT;
|
||||
|
||||
#else
|
||||
|
||||
#define TG_REG_FIELD_LIST(type) \
|
||||
TG_REG_FIELD_LIST_DCN1_0(type)
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
struct dcn_optc_shift {
|
||||
|
@ -163,14 +163,12 @@ struct dcn10_stream_enc_registers {
|
||||
uint32_t DP_MSA_TIMING_PARAM3;
|
||||
uint32_t DP_MSA_TIMING_PARAM4;
|
||||
uint32_t HDMI_DB_CONTROL;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
uint32_t DP_DSC_CNTL;
|
||||
uint32_t DP_DSC_BYTES_PER_PIXEL;
|
||||
uint32_t DME_CONTROL;
|
||||
uint32_t DP_SEC_METADATA_TRANSMISSION;
|
||||
uint32_t HDMI_METADATA_PACKET_CONTROL;
|
||||
uint32_t DP_SEC_FRAMING4;
|
||||
#endif
|
||||
uint32_t DIG_CLOCK_PATTERN;
|
||||
};
|
||||
|
||||
@ -466,7 +464,6 @@ struct dcn10_stream_enc_registers {
|
||||
type DIG_SOURCE_SELECT;\
|
||||
type DIG_CLOCK_PATTERN
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define SE_REG_FIELD_LIST_DCN2_0(type) \
|
||||
type DP_DSC_MODE;\
|
||||
type DP_DSC_SLICE_WIDTH;\
|
||||
@ -485,20 +482,15 @@ struct dcn10_stream_enc_registers {
|
||||
type DOLBY_VISION_EN;\
|
||||
type DP_PIXEL_COMBINE;\
|
||||
type DP_SST_SDP_SPLITTING
|
||||
#endif
|
||||
|
||||
struct dcn10_stream_encoder_shift {
|
||||
SE_REG_FIELD_LIST_DCN1_0(uint8_t);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
SE_REG_FIELD_LIST_DCN2_0(uint8_t);
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dcn10_stream_encoder_mask {
|
||||
SE_REG_FIELD_LIST_DCN1_0(uint32_t);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
SE_REG_FIELD_LIST_DCN2_0(uint32_t);
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dcn10_stream_encoder {
|
||||
|
@ -6,9 +6,7 @@ DCN20 = dcn20_resource.o dcn20_hwseq.o dcn20_dpp.o dcn20_dpp_cm.o dcn20_hubp.o \
|
||||
dcn20_stream_encoder.o dcn20_link_encoder.o dcn20_dccg.o \
|
||||
dcn20_vmid.o dcn20_dwb.o dcn20_dwb_scl.o
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
DCN20 += dcn20_dsc.o
|
||||
endif
|
||||
|
||||
ifneq ($(call cc-option, -mpreferred-stack-boundary=4),)
|
||||
cc_stack_align := -mpreferred-stack-boundary=4
|
||||
|
@ -23,7 +23,6 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "reg_helper.h"
|
||||
#include "dcn20_dsc.h"
|
||||
#include "dsc/dscc_types.h"
|
||||
@ -734,4 +733,3 @@ static void dsc_write_to_registers(struct display_stream_compressor *dsc, const
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -21,7 +21,6 @@
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#ifndef __DCN20_DSC_H__
|
||||
#define __DCN20_DSC_H__
|
||||
|
||||
@ -572,4 +571,3 @@ void dsc2_construct(struct dcn20_dsc *dsc,
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
@ -483,7 +483,6 @@ void hubp2_program_pixel_format(
|
||||
REG_UPDATE(DCSURF_SURFACE_CONFIG,
|
||||
SURFACE_PIXEL_FORMAT, 12);
|
||||
break;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case SURFACE_PIXEL_FORMAT_GRPH_RGB111110_FIX:
|
||||
REG_UPDATE(DCSURF_SURFACE_CONFIG,
|
||||
SURFACE_PIXEL_FORMAT, 112);
|
||||
@ -504,7 +503,6 @@ void hubp2_program_pixel_format(
|
||||
REG_UPDATE(DCSURF_SURFACE_CONFIG,
|
||||
SURFACE_PIXEL_FORMAT, 119);
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
BREAK_TO_DEBUGGER();
|
||||
break;
|
||||
|
@ -33,9 +33,7 @@
|
||||
#include "dcn10/dcn10_hw_sequencer.h"
|
||||
#include "dcn20_hwseq.h"
|
||||
#include "dce/dce_hwseq.h"
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "dcn20/dcn20_dsc.h"
|
||||
#endif
|
||||
#include "abm.h"
|
||||
#include "clk_mgr.h"
|
||||
#include "dmcu.h"
|
||||
@ -243,7 +241,6 @@ void dcn20_init_blank(
|
||||
dcn20_hwss_wait_for_blank_complete(opp);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
static void dcn20_dsc_pg_control(
|
||||
struct dce_hwseq *hws,
|
||||
unsigned int dsc_inst,
|
||||
@ -320,7 +317,6 @@ static void dcn20_dsc_pg_control(
|
||||
if (org_ip_request_cntl == 0)
|
||||
REG_SET(DC_IP_REQUEST_CNTL, 0, IP_REQUEST_EN, 0);
|
||||
}
|
||||
#endif
|
||||
|
||||
static void dcn20_dpp_pg_control(
|
||||
struct dce_hwseq *hws,
|
||||
@ -1696,7 +1692,6 @@ bool dcn20_dmdata_status_done(struct pipe_ctx *pipe_ctx)
|
||||
|
||||
static void dcn20_disable_stream_gating(struct dc *dc, struct pipe_ctx *pipe_ctx)
|
||||
{
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct dce_hwseq *hws = dc->hwseq;
|
||||
|
||||
if (pipe_ctx->stream_res.dsc) {
|
||||
@ -1708,12 +1703,10 @@ static void dcn20_disable_stream_gating(struct dc *dc, struct pipe_ctx *pipe_ctx
|
||||
odm_pipe = odm_pipe->next_odm_pipe;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
static void dcn20_enable_stream_gating(struct dc *dc, struct pipe_ctx *pipe_ctx)
|
||||
{
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct dce_hwseq *hws = dc->hwseq;
|
||||
|
||||
if (pipe_ctx->stream_res.dsc) {
|
||||
@ -1725,7 +1718,6 @@ static void dcn20_enable_stream_gating(struct dc *dc, struct pipe_ctx *pipe_ctx)
|
||||
odm_pipe = odm_pipe->next_odm_pipe;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void dcn20_set_dmdata_attributes(struct pipe_ctx *pipe_ctx)
|
||||
@ -1924,11 +1916,9 @@ static void dcn20_reset_back_end_for_pipe(
|
||||
}
|
||||
}
|
||||
}
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
else if (pipe_ctx->stream_res.dsc) {
|
||||
dp_set_dsc_enable(pipe_ctx, false);
|
||||
}
|
||||
#endif
|
||||
|
||||
/* by upper caller loop, parent pipe: pipe0, will be reset last.
|
||||
* back end share by all pipes and will be disable only when disable
|
||||
@ -2440,11 +2430,7 @@ void dcn20_hw_sequencer_construct(struct dc *dc)
|
||||
dc->hwss.enable_power_gating_plane = dcn20_enable_power_gating_plane;
|
||||
dc->hwss.dpp_pg_control = dcn20_dpp_pg_control;
|
||||
dc->hwss.hubp_pg_control = dcn20_hubp_pg_control;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
dc->hwss.dsc_pg_control = dcn20_dsc_pg_control;
|
||||
#else
|
||||
dc->hwss.dsc_pg_control = NULL;
|
||||
#endif
|
||||
dc->hwss.disable_vga = dcn20_disable_vga;
|
||||
|
||||
if (IS_FPGA_MAXIMUS_DC(dc->ctx->dce_environment)) {
|
||||
|
@ -168,10 +168,8 @@ static struct mpll_cfg dcn2_mpll_cfg[] = {
|
||||
void enc2_fec_set_enable(struct link_encoder *enc, bool enable)
|
||||
{
|
||||
struct dcn10_link_encoder *enc10 = TO_DCN10_LINK_ENC(enc);
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
DC_LOG_DSC("%s FEC at link encoder inst %d",
|
||||
enable ? "Enabling" : "Disabling", enc->id.enum_id);
|
||||
#endif
|
||||
REG_UPDATE(DP_DPHY_CNTL, DPHY_FEC_EN, enable);
|
||||
}
|
||||
|
||||
@ -192,7 +190,6 @@ bool enc2_fec_is_active(struct link_encoder *enc)
|
||||
return (active != 0);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* this function reads dsc related register fields to be logged later in dcn10_log_hw_state
|
||||
* into a dcn_dsc_state struct.
|
||||
*/
|
||||
@ -205,7 +202,6 @@ void link_enc2_read_state(struct link_encoder *enc, struct link_enc_state *s)
|
||||
REG_GET(DP_DPHY_CNTL, DPHY_FEC_ACTIVE_STATUS, &s->dphy_fec_active_status);
|
||||
REG_GET(DP_LINK_CNTL, DP_LINK_TRAINING_COMPLETE, &s->dp_link_training_complete);
|
||||
}
|
||||
#endif
|
||||
|
||||
static bool update_cfg_data(
|
||||
struct dcn10_link_encoder *enc10,
|
||||
@ -316,9 +312,7 @@ void enc2_hw_init(struct link_encoder *enc)
|
||||
}
|
||||
|
||||
static const struct link_encoder_funcs dcn20_link_enc_funcs = {
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.read_state = link_enc2_read_state,
|
||||
#endif
|
||||
.validate_output_with_stream =
|
||||
dcn10_link_encoder_validate_output_with_stream,
|
||||
.hw_init = enc2_hw_init,
|
||||
|
@ -158,9 +158,7 @@ void enc2_fec_set_ready(struct link_encoder *enc, bool ready);
|
||||
bool enc2_fec_is_active(struct link_encoder *enc);
|
||||
void enc2_hw_init(struct link_encoder *enc);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
void link_enc2_read_state(struct link_encoder *enc, struct link_enc_state *s);
|
||||
#endif
|
||||
|
||||
void dcn20_link_encoder_enable_dp_output(
|
||||
struct link_encoder *enc,
|
||||
|
@ -167,7 +167,6 @@ void optc2_set_gsl_source_select(
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* DSC encoder frame start controls: x = h position, line_num = # of lines from vstartup */
|
||||
void optc2_set_dsc_encoder_frame_start(struct timing_generator *optc,
|
||||
int x_position,
|
||||
@ -201,7 +200,6 @@ void optc2_set_dsc_config(struct timing_generator *optc,
|
||||
REG_UPDATE(OPTC_WIDTH_CONTROL,
|
||||
OPTC_DSC_SLICE_WIDTH, dsc_slice_width);
|
||||
}
|
||||
#endif
|
||||
|
||||
/**
|
||||
* PTI i think is already done somewhere else for 2ka
|
||||
@ -448,9 +446,7 @@ static struct timing_generator_funcs dcn20_tg_funcs = {
|
||||
.setup_global_swap_lock = NULL,
|
||||
.get_crc = optc1_get_crc,
|
||||
.configure_crc = optc1_configure_crc,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.set_dsc_config = optc2_set_dsc_config,
|
||||
#endif
|
||||
.set_dwb_source = optc2_set_dwb_source,
|
||||
.set_odm_bypass = optc2_set_odm_bypass,
|
||||
.set_odm_combine = optc2_set_odm_combine,
|
||||
|
@ -86,12 +86,10 @@ void optc2_set_gsl_source_select(struct timing_generator *optc,
|
||||
int group_idx,
|
||||
uint32_t gsl_ready_signal);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
void optc2_set_dsc_config(struct timing_generator *optc,
|
||||
enum optc_dsc_mode dsc_mode,
|
||||
uint32_t dsc_bytes_per_pixel,
|
||||
uint32_t dsc_slice_width);
|
||||
#endif
|
||||
|
||||
void optc2_set_odm_bypass(struct timing_generator *optc,
|
||||
const struct dc_crtc_timing *dc_crtc_timing);
|
||||
|
@ -45,9 +45,7 @@
|
||||
#include "dcn10/dcn10_resource.h"
|
||||
#include "dcn20_opp.h"
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "dcn20_dsc.h"
|
||||
#endif
|
||||
|
||||
#include "dcn20_link_encoder.h"
|
||||
#include "dcn20_stream_encoder.h"
|
||||
@ -95,11 +93,7 @@ struct _vcs_dpi_ip_params_st dcn2_0_ip = {
|
||||
.hostvm_max_page_table_levels = 4,
|
||||
.hostvm_cached_page_table_levels = 0,
|
||||
.pte_group_size_bytes = 2048,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.num_dsc = 6,
|
||||
#else
|
||||
.num_dsc = 0,
|
||||
#endif
|
||||
.rob_buffer_size_kbytes = 168,
|
||||
.det_buffer_size_kbytes = 164,
|
||||
.dpte_buffer_size_in_pte_reqs_luma = 84,
|
||||
@ -771,7 +765,6 @@ static int map_transmitter_id_to_phy_instance(
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#define dsc_regsDCN20(id)\
|
||||
[id] = {\
|
||||
DSC_REG_LIST_DCN20(id)\
|
||||
@ -793,7 +786,6 @@ static const struct dcn20_dsc_shift dsc_shift = {
|
||||
static const struct dcn20_dsc_mask dsc_mask = {
|
||||
DSC_REG_LIST_SH_MASK_DCN20(_MASK)
|
||||
};
|
||||
#endif
|
||||
|
||||
static const struct dccg_registers dccg_regs = {
|
||||
DCCG_REG_LIST_DCN2()
|
||||
@ -817,9 +809,7 @@ static const struct resource_caps res_cap_nv10 = {
|
||||
.num_dwb = 1,
|
||||
.num_ddc = 6,
|
||||
.num_vmid = 16,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.num_dsc = 6,
|
||||
#endif
|
||||
};
|
||||
|
||||
static const struct dc_plane_cap plane_cap = {
|
||||
@ -1213,7 +1203,6 @@ void dcn20_clock_source_destroy(struct clock_source **clk_src)
|
||||
*clk_src = NULL;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
|
||||
struct display_stream_compressor *dcn20_dsc_create(
|
||||
struct dc_context *ctx, uint32_t inst)
|
||||
@ -1236,7 +1225,6 @@ void dcn20_dsc_destroy(struct display_stream_compressor **dsc)
|
||||
*dsc = NULL;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
static void destruct(struct dcn20_resource_pool *pool)
|
||||
{
|
||||
@ -1249,12 +1237,10 @@ static void destruct(struct dcn20_resource_pool *pool)
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
for (i = 0; i < pool->base.res_cap->num_dsc; i++) {
|
||||
if (pool->base.dscs[i] != NULL)
|
||||
dcn20_dsc_destroy(&pool->base.dscs[i]);
|
||||
}
|
||||
#endif
|
||||
|
||||
if (pool->base.mpc != NULL) {
|
||||
kfree(TO_DCN20_MPC(pool->base.mpc));
|
||||
@ -1465,7 +1451,6 @@ enum dc_status dcn20_build_mapped_resource(const struct dc *dc, struct dc_state
|
||||
return status;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
|
||||
static void acquire_dsc(struct resource_context *res_ctx,
|
||||
const struct resource_pool *pool,
|
||||
@ -1499,10 +1484,8 @@ static void release_dsc(struct resource_context *res_ctx,
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
static enum dc_status add_dsc_to_stream_resource(struct dc *dc,
|
||||
struct dc_state *dc_ctx,
|
||||
struct dc_stream_state *dc_stream)
|
||||
@ -1554,7 +1537,6 @@ static enum dc_status remove_dsc_from_stream_resource(struct dc *dc,
|
||||
else
|
||||
return DC_OK;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
enum dc_status dcn20_add_stream_to_ctx(struct dc *dc, struct dc_state *new_ctx, struct dc_stream_state *dc_stream)
|
||||
@ -1566,11 +1548,9 @@ enum dc_status dcn20_add_stream_to_ctx(struct dc *dc, struct dc_state *new_ctx,
|
||||
if (result == DC_OK)
|
||||
result = resource_map_phy_clock_resources(dc, new_ctx, dc_stream);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* Get a DSC if required and available */
|
||||
if (result == DC_OK && dc_stream->timing.flags.DSC)
|
||||
result = add_dsc_to_stream_resource(dc, new_ctx, dc_stream);
|
||||
#endif
|
||||
|
||||
if (result == DC_OK)
|
||||
result = dcn20_build_mapped_resource(dc, new_ctx, dc_stream);
|
||||
@ -1583,9 +1563,7 @@ enum dc_status dcn20_remove_stream_from_ctx(struct dc *dc, struct dc_state *new_
|
||||
{
|
||||
enum dc_status result = DC_OK;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
result = remove_dsc_from_stream_resource(dc, new_ctx, dc_stream);
|
||||
#endif
|
||||
|
||||
return result;
|
||||
}
|
||||
@ -1668,9 +1646,7 @@ bool dcn20_split_stream_for_odm(
|
||||
next_odm_pipe->plane_res.xfm = pool->transforms[next_odm_pipe->pipe_idx];
|
||||
next_odm_pipe->plane_res.dpp = pool->dpps[next_odm_pipe->pipe_idx];
|
||||
next_odm_pipe->plane_res.mpcc_inst = pool->dpps[next_odm_pipe->pipe_idx]->inst;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
next_odm_pipe->stream_res.dsc = NULL;
|
||||
#endif
|
||||
if (prev_odm_pipe->next_odm_pipe && prev_odm_pipe->next_odm_pipe != next_odm_pipe) {
|
||||
next_odm_pipe->next_odm_pipe = prev_odm_pipe->next_odm_pipe;
|
||||
next_odm_pipe->next_odm_pipe->prev_odm_pipe = next_odm_pipe;
|
||||
@ -1716,14 +1692,12 @@ bool dcn20_split_stream_for_odm(
|
||||
sd->recout.x = 0;
|
||||
}
|
||||
next_odm_pipe->stream_res.opp = pool->opps[next_odm_pipe->pipe_idx];
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (next_odm_pipe->stream->timing.flags.DSC == 1) {
|
||||
acquire_dsc(res_ctx, pool, &next_odm_pipe->stream_res.dsc);
|
||||
ASSERT(next_odm_pipe->stream_res.dsc);
|
||||
if (next_odm_pipe->stream_res.dsc == NULL)
|
||||
return false;
|
||||
}
|
||||
#endif
|
||||
|
||||
return true;
|
||||
}
|
||||
@ -1747,9 +1721,7 @@ void dcn20_split_stream_for_mpc(
|
||||
secondary_pipe->plane_res.xfm = pool->transforms[secondary_pipe->pipe_idx];
|
||||
secondary_pipe->plane_res.dpp = pool->dpps[secondary_pipe->pipe_idx];
|
||||
secondary_pipe->plane_res.mpcc_inst = pool->dpps[secondary_pipe->pipe_idx]->inst;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
secondary_pipe->stream_res.dsc = NULL;
|
||||
#endif
|
||||
if (primary_pipe->bottom_pipe && primary_pipe->bottom_pipe != secondary_pipe) {
|
||||
ASSERT(!secondary_pipe->bottom_pipe);
|
||||
secondary_pipe->bottom_pipe = primary_pipe->bottom_pipe;
|
||||
@ -1833,11 +1805,9 @@ int dcn20_populate_dml_pipes_from_context(
|
||||
pipes[pipe_cnt].pipe.src.dcc = 0;
|
||||
pipes[pipe_cnt].pipe.src.vm = 0;*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
pipes[pipe_cnt].dout.dsc_enable = res_ctx->pipe_ctx[i].stream->timing.flags.DSC;
|
||||
/* todo: rotation?*/
|
||||
pipes[pipe_cnt].dout.dsc_slices = res_ctx->pipe_ctx[i].stream->timing.dsc_cfg.num_slices_h;
|
||||
#endif
|
||||
if (res_ctx->pipe_ctx[i].stream->use_dynamic_meta) {
|
||||
pipes[pipe_cnt].pipe.src.dynamic_metadata_enable = true;
|
||||
/* 1/2 vblank */
|
||||
@ -1925,14 +1895,12 @@ int dcn20_populate_dml_pipes_from_context(
|
||||
case COLOR_DEPTH_161616:
|
||||
output_bpc = 16;
|
||||
break;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
case COLOR_DEPTH_999:
|
||||
output_bpc = 9;
|
||||
break;
|
||||
case COLOR_DEPTH_111111:
|
||||
output_bpc = 11;
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
output_bpc = 8;
|
||||
break;
|
||||
@ -1960,10 +1928,8 @@ int dcn20_populate_dml_pipes_from_context(
|
||||
pipes[pipe_cnt].dout.output_bpp = output_bpc * 3;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (res_ctx->pipe_ctx[i].stream->timing.flags.DSC)
|
||||
pipes[pipe_cnt].dout.output_bpp = res_ctx->pipe_ctx[i].stream->timing.dsc_cfg.bits_per_pixel / 16.0;
|
||||
#endif
|
||||
|
||||
/* todo: default max for now, until there is logic reflecting this in dc*/
|
||||
pipes[pipe_cnt].dout.output_bpc = 12;
|
||||
@ -2185,7 +2151,6 @@ void dcn20_set_mcif_arb_params(
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool dcn20_validate_dsc(struct dc *dc, struct dc_state *new_ctx)
|
||||
{
|
||||
int i;
|
||||
@ -2219,7 +2184,6 @@ bool dcn20_validate_dsc(struct dc *dc, struct dc_state *new_ctx)
|
||||
}
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
struct pipe_ctx *dcn20_find_secondary_pipe(struct dc *dc,
|
||||
struct resource_context *res_ctx,
|
||||
@ -2322,10 +2286,8 @@ void dcn20_merge_pipes_for_validate(
|
||||
odm_pipe->bottom_pipe = NULL;
|
||||
odm_pipe->prev_odm_pipe = NULL;
|
||||
odm_pipe->next_odm_pipe = NULL;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
if (odm_pipe->stream_res.dsc)
|
||||
release_dsc(&context->res_ctx, dc->res_pool, &odm_pipe->stream_res.dsc);
|
||||
#endif
|
||||
/* Clear plane_res and stream_res */
|
||||
memset(&odm_pipe->plane_res, 0, sizeof(odm_pipe->plane_res));
|
||||
memset(&odm_pipe->stream_res, 0, sizeof(odm_pipe->stream_res));
|
||||
@ -2545,14 +2507,12 @@ bool dcn20_fast_validate_bw(
|
||||
ASSERT(0);
|
||||
}
|
||||
}
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
/* Actual dsc count per stream dsc validation*/
|
||||
if (!dcn20_validate_dsc(dc, context)) {
|
||||
context->bw_ctx.dml.vba.ValidationStatus[context->bw_ctx.dml.vba.soc.num_states] =
|
||||
DML_FAIL_DSC_VALIDATION_FAILURE;
|
||||
goto validate_fail;
|
||||
}
|
||||
#endif
|
||||
|
||||
*vlevel_out = vlevel;
|
||||
|
||||
@ -3654,7 +3614,6 @@ static bool construct(
|
||||
goto create_fail;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
for (i = 0; i < pool->base.res_cap->num_dsc; i++) {
|
||||
pool->base.dscs[i] = dcn20_dsc_create(ctx, i);
|
||||
if (pool->base.dscs[i] == NULL) {
|
||||
@ -3663,7 +3622,6 @@ static bool construct(
|
||||
goto create_fail;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
if (!dcn20_dwbc_create(ctx, &pool->base)) {
|
||||
BREAK_TO_DEBUGGER();
|
||||
|
@ -127,9 +127,7 @@ int dcn20_validate_apply_pipe_split_flags(
|
||||
struct dc_state *context,
|
||||
int vlevel,
|
||||
bool *split);
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool dcn20_validate_dsc(struct dc *dc, struct dc_state *new_ctx);
|
||||
#endif
|
||||
void dcn20_split_stream_for_mpc(
|
||||
struct resource_context *res_ctx,
|
||||
const struct resource_pool *pool,
|
||||
|
@ -205,7 +205,6 @@ static void enc2_stream_encoder_stop_hdmi_info_packets(
|
||||
HDMI_GENERIC7_LINE, 0);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
|
||||
/* Update GSP7 SDP 128 byte long */
|
||||
static void enc2_update_gsp7_128_info_packet(
|
||||
@ -360,7 +359,6 @@ static void enc2_read_state(struct stream_encoder *enc, struct enc_state *s)
|
||||
REG_GET(DP_SEC_CNTL, DP_SEC_STREAM_ENABLE, &s->sec_stream_enable);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Set Dynamic Metadata-configuration.
|
||||
* enable_dme: TRUE: enables Dynamic Metadata Enfine, FALSE: disables DME
|
||||
@ -440,10 +438,8 @@ static bool is_two_pixels_per_containter(const struct dc_crtc_timing *timing)
|
||||
{
|
||||
bool two_pix = timing->pixel_encoding == PIXEL_ENCODING_YCBCR420;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
two_pix = two_pix || (timing->flags.DSC && timing->pixel_encoding == PIXEL_ENCODING_YCBCR422
|
||||
&& !timing->dsc_cfg.ycbcr422_simple);
|
||||
#endif
|
||||
return two_pix;
|
||||
}
|
||||
|
||||
@ -587,11 +583,9 @@ static const struct stream_encoder_funcs dcn20_str_enc_funcs = {
|
||||
.dp_get_pixel_format =
|
||||
enc1_stream_encoder_dp_get_pixel_format,
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.enc_read_state = enc2_read_state,
|
||||
.dp_set_dsc_config = enc2_dp_set_dsc_config,
|
||||
.dp_set_dsc_pps_info_packet = enc2_dp_set_dsc_pps_info_packet,
|
||||
#endif
|
||||
.set_dynamic_metadata = enc2_set_dynamic_metadata,
|
||||
.hdmi_reset_stream_attribute = enc1_reset_hdmi_stream_attribute,
|
||||
};
|
||||
|
@ -323,9 +323,7 @@ void dcn21_link_encoder_disable_output(
|
||||
|
||||
|
||||
static const struct link_encoder_funcs dcn21_link_enc_funcs = {
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.read_state = link_enc2_read_state,
|
||||
#endif
|
||||
.validate_output_with_stream =
|
||||
dcn10_link_encoder_validate_output_with_stream,
|
||||
.hw_init = enc2_hw_init,
|
||||
|
@ -88,11 +88,7 @@ struct _vcs_dpi_ip_params_st dcn2_1_ip = {
|
||||
.gpuvm_max_page_table_levels = 1,
|
||||
.hostvm_max_page_table_levels = 4,
|
||||
.hostvm_cached_page_table_levels = 2,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.num_dsc = 3,
|
||||
#else
|
||||
.num_dsc = 0,
|
||||
#endif
|
||||
.rob_buffer_size_kbytes = 168,
|
||||
.det_buffer_size_kbytes = 164,
|
||||
.dpte_buffer_size_in_pte_reqs_luma = 44,
|
||||
@ -538,7 +534,6 @@ static const struct dcn20_vmid_mask vmid_masks = {
|
||||
DCN20_VMID_MASK_SH_LIST(_MASK)
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#define dsc_regsDCN20(id)\
|
||||
[id] = {\
|
||||
DSC_REG_LIST_DCN20(id)\
|
||||
@ -560,7 +555,6 @@ static const struct dcn20_dsc_shift dsc_shift = {
|
||||
static const struct dcn20_dsc_mask dsc_mask = {
|
||||
DSC_REG_LIST_SH_MASK_DCN20(_MASK)
|
||||
};
|
||||
#endif
|
||||
|
||||
#define ipp_regs(id)\
|
||||
[id] = {\
|
||||
@ -757,9 +751,7 @@ static const struct resource_caps res_cap_rn = {
|
||||
.num_dwb = 1,
|
||||
.num_ddc = 5,
|
||||
.num_vmid = 1,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.num_dsc = 3,
|
||||
#endif
|
||||
};
|
||||
|
||||
#ifdef DIAGS_BUILD
|
||||
@ -784,9 +776,7 @@ static const struct resource_caps res_cap_rn_FPGA_2pipe_dsc = {
|
||||
.num_pll = 4,
|
||||
.num_dwb = 1,
|
||||
.num_ddc = 4,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
.num_dsc = 2,
|
||||
#endif
|
||||
};
|
||||
#endif
|
||||
|
||||
@ -865,12 +855,10 @@ static void destruct(struct dcn21_resource_pool *pool)
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
for (i = 0; i < pool->base.res_cap->num_dsc; i++) {
|
||||
if (pool->base.dscs[i] != NULL)
|
||||
dcn20_dsc_destroy(&pool->base.dscs[i]);
|
||||
}
|
||||
#endif
|
||||
|
||||
if (pool->base.mpc != NULL) {
|
||||
kfree(TO_DCN20_MPC(pool->base.mpc));
|
||||
@ -1299,7 +1287,6 @@ static void read_dce_straps(
|
||||
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
|
||||
struct display_stream_compressor *dcn21_dsc_create(
|
||||
struct dc_context *ctx, uint32_t inst)
|
||||
@ -1315,7 +1302,6 @@ struct display_stream_compressor *dcn21_dsc_create(
|
||||
dsc2_construct(dsc, ctx, inst, &dsc_regs[inst], &dsc_shift, &dsc_mask);
|
||||
return &dsc->base;
|
||||
}
|
||||
#endif
|
||||
|
||||
static void update_bw_bounding_box(struct dc *dc, struct clk_bw_params *bw_params)
|
||||
{
|
||||
@ -1853,7 +1839,6 @@ static bool construct(
|
||||
goto create_fail;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
for (i = 0; i < pool->base.res_cap->num_dsc; i++) {
|
||||
pool->base.dscs[i] = dcn21_dsc_create(ctx, i);
|
||||
if (pool->base.dscs[i] == NULL) {
|
||||
@ -1862,7 +1847,6 @@ static bool construct(
|
||||
goto create_fail;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
if (!dcn20_dwbc_create(ctx, &pool->base)) {
|
||||
BREAK_TO_DEBUGGER();
|
||||
|
@ -118,13 +118,11 @@ bool dm_helpers_submit_i2c(
|
||||
const struct dc_link *link,
|
||||
struct i2c_command *cmd);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
bool dm_helpers_dp_write_dsc_enable(
|
||||
struct dc_context *ctx,
|
||||
const struct dc_stream_state *stream,
|
||||
bool enable
|
||||
);
|
||||
#endif
|
||||
bool dm_helpers_is_dp_sink_present(
|
||||
struct dc_link *link);
|
||||
|
||||
|
@ -41,9 +41,7 @@ enum pp_smu_ver {
|
||||
*/
|
||||
PP_SMU_UNSUPPORTED,
|
||||
PP_SMU_VER_RV,
|
||||
#ifndef CONFIG_TRIM_DRM_AMD_DC_DCN2_0
|
||||
PP_SMU_VER_NV,
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
PP_SMU_VER_RN,
|
||||
#endif
|
||||
@ -143,7 +141,6 @@ struct pp_smu_funcs_rv {
|
||||
void (*set_pme_wa_enable)(struct pp_smu *pp);
|
||||
};
|
||||
|
||||
#ifndef CONFIG_TRIM_DRM_AMD_DC_DCN2_0
|
||||
/* Used by pp_smu_funcs_nv.set_voltage_by_freq
|
||||
*
|
||||
*/
|
||||
@ -247,7 +244,6 @@ struct pp_smu_funcs_nv {
|
||||
enum pp_smu_status (*set_pstate_handshake_support)(struct pp_smu *pp,
|
||||
BOOLEAN pstate_handshake_supported);
|
||||
};
|
||||
#endif
|
||||
|
||||
#define PP_SMU_NUM_SOCCLK_DPM_LEVELS 8
|
||||
#define PP_SMU_NUM_DCFCLK_DPM_LEVELS 8
|
||||
@ -291,9 +287,7 @@ struct pp_smu_funcs {
|
||||
struct pp_smu ctx;
|
||||
union {
|
||||
struct pp_smu_funcs_rv rv_funcs;
|
||||
#ifndef CONFIG_TRIM_DRM_AMD_DC_DCN2_0
|
||||
struct pp_smu_funcs_nv nv_funcs;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
struct pp_smu_funcs_rn rn_funcs;
|
||||
#endif
|
||||
|
@ -38,7 +38,7 @@ endif
|
||||
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/display_mode_lib.o := $(dml_ccflags)
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN1_0
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/display_mode_vba.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn20/display_mode_vba_20.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn20/display_rq_dlg_calc_20.o := $(dml_ccflags)
|
||||
@ -56,7 +56,7 @@ CFLAGS_$(AMDDALPATH)/dc/dml/dml_common_defs.o := $(dml_ccflags)
|
||||
DML = display_mode_lib.o display_rq_dlg_helpers.o dml1_display_rq_dlg_calc.o \
|
||||
dml_common_defs.o
|
||||
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN1_0
|
||||
DML += display_mode_vba.o dcn20/display_rq_dlg_calc_20.o dcn20/display_mode_vba_20.o
|
||||
DML += dcn20/display_rq_dlg_calc_20v2.o dcn20/display_mode_vba_20v2.o
|
||||
endif
|
||||
|
@ -23,7 +23,6 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
|
||||
#include "../display_mode_lib.h"
|
||||
#include "../dml_inline_defs.h"
|
||||
@ -6126,4 +6125,3 @@ static double CalculateExtraLatency(
|
||||
return CalculateExtraLatency;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -23,7 +23,6 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
|
||||
#include "../display_mode_lib.h"
|
||||
#include "../display_mode_vba.h"
|
||||
@ -1820,4 +1819,3 @@ static void calculate_ttu_cursor(
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -135,9 +135,7 @@ enum dm_validation_status {
|
||||
DML_FAIL_DIO_SUPPORT,
|
||||
DML_FAIL_NOT_ENOUGH_DSC,
|
||||
DML_FAIL_DSC_CLK_REQUIRED,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
DML_FAIL_DSC_VALIDATION_FAILURE,
|
||||
#endif
|
||||
DML_FAIL_URGENT_LATENCY,
|
||||
DML_FAIL_REORDERING_BUFFER,
|
||||
DML_FAIL_DISPCLK_DPPCLK,
|
||||
|
@ -25,18 +25,15 @@
|
||||
|
||||
#include "display_mode_lib.h"
|
||||
#include "dc_features.h"
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "dcn20/display_mode_vba_20.h"
|
||||
#include "dcn20/display_rq_dlg_calc_20.h"
|
||||
#include "dcn20/display_mode_vba_20v2.h"
|
||||
#include "dcn20/display_rq_dlg_calc_20v2.h"
|
||||
#endif
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_1
|
||||
#include "dcn21/display_mode_vba_21.h"
|
||||
#include "dcn21/display_rq_dlg_calc_21.h"
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
const struct dml_funcs dml20_funcs = {
|
||||
.validate = dml20_ModeSupportAndSystemConfigurationFull,
|
||||
.recalculate = dml20_recalculate,
|
||||
@ -50,7 +47,6 @@ const struct dml_funcs dml20v2_funcs = {
|
||||
.rq_dlg_get_dlg_reg = dml20v2_rq_dlg_get_dlg_reg,
|
||||
.rq_dlg_get_rq_reg = dml20v2_rq_dlg_get_rq_reg
|
||||
};
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_1
|
||||
const struct dml_funcs dml21_funcs = {
|
||||
@ -70,14 +66,12 @@ void dml_init_instance(struct display_mode_lib *lib,
|
||||
lib->ip = *ip_params;
|
||||
lib->project = project;
|
||||
switch (project) {
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
case DML_PROJECT_NAVI10:
|
||||
lib->funcs = dml20_funcs;
|
||||
break;
|
||||
case DML_PROJECT_NAVI10v2:
|
||||
lib->funcs = dml20v2_funcs;
|
||||
break;
|
||||
#endif
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_1
|
||||
case DML_PROJECT_DCN21:
|
||||
lib->funcs = dml21_funcs;
|
||||
|
@ -27,17 +27,13 @@
|
||||
|
||||
|
||||
#include "dml_common_defs.h"
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
#include "display_mode_vba.h"
|
||||
#endif
|
||||
|
||||
enum dml_project {
|
||||
DML_PROJECT_UNDEFINED,
|
||||
DML_PROJECT_RAVEN1,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
DML_PROJECT_NAVI10,
|
||||
DML_PROJECT_NAVI10v2,
|
||||
#endif
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_1
|
||||
DML_PROJECT_DCN21,
|
||||
#endif
|
||||
@ -70,9 +66,7 @@ struct display_mode_lib {
|
||||
struct _vcs_dpi_ip_params_st ip;
|
||||
struct _vcs_dpi_soc_bounding_box_st soc;
|
||||
enum dml_project project;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
struct vba_vars_st vba;
|
||||
#endif
|
||||
struct dal_logger *logger;
|
||||
struct dml_funcs funcs;
|
||||
};
|
||||
|
@ -146,7 +146,6 @@ struct _vcs_dpi_ip_params_st {
|
||||
unsigned int writeback_interface_buffer_size_kbytes;
|
||||
unsigned int writeback_line_buffer_buffer_size;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
unsigned int writeback_10bpc420_supported;
|
||||
double writeback_max_hscl_ratio;
|
||||
double writeback_max_vscl_ratio;
|
||||
@ -156,7 +155,6 @@ struct _vcs_dpi_ip_params_st {
|
||||
unsigned int writeback_max_vscl_taps;
|
||||
unsigned int writeback_line_buffer_luma_buffer_size;
|
||||
unsigned int writeback_line_buffer_chroma_buffer_size;
|
||||
#endif
|
||||
|
||||
unsigned int max_page_table_levels;
|
||||
unsigned int max_num_dpp;
|
||||
|
@ -23,7 +23,6 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
|
||||
#include "display_mode_lib.h"
|
||||
#include "display_mode_vba.h"
|
||||
@ -862,4 +861,3 @@ double CalculateWriteBackDISPCLK(
|
||||
return CalculateWriteBackDISPCLK;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -23,7 +23,6 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
|
||||
#ifndef __DML2_DISPLAY_MODE_VBA_H__
|
||||
#define __DML2_DISPLAY_MODE_VBA_H__
|
||||
@ -872,4 +871,3 @@ double CalculateWriteBackDISPCLK(
|
||||
unsigned int WritebackChromaLineBufferWidth);
|
||||
|
||||
#endif /* _DML2_DISPLAY_MODE_VBA_H_ */
|
||||
#endif
|
||||
|
@ -22,7 +22,6 @@
|
||||
* Author: AMD
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
#include "dc_hw_types.h"
|
||||
#include "dsc.h"
|
||||
#include <drm/drm_dp_helper.h>
|
||||
@ -903,4 +902,3 @@ bool dc_dsc_compute_config(
|
||||
timing, dsc_min_slice_height_override, dsc_cfg);
|
||||
return is_dsc_possible;
|
||||
}
|
||||
#endif /* CONFIG_DRM_AMD_DC_DSC_SUPPORT */
|
||||
|
@ -1,4 +1,3 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
|
||||
/*
|
||||
* Copyright 2017 Advanced Micro Devices, Inc.
|
||||
@ -51,4 +50,3 @@ int dscc_compute_dsc_parameters(const struct drm_dsc_config *pps, struct dsc_par
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
@ -1,4 +1,3 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
|
||||
/*
|
||||
* Copyright 2017 Advanced Micro Devices, Inc.
|
||||
@ -703,4 +702,3 @@ const qp_table qp_table_422_8bpc_max = {
|
||||
{ 16, { 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 2, 3, 4} }
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@ -1,4 +1,3 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DSC_SUPPORT)
|
||||
|
||||
/*
|
||||
* Copyright 2017 Advanced Micro Devices, Inc.
|
||||
@ -252,4 +251,3 @@ void calc_rc_params(struct rc_params *rc, enum colour_mode cm, enum bits_per_com
|
||||
rc->rc_buf_thresh[13] = 8064;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -1,4 +1,3 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
|
||||
/*
|
||||
* Copyright 2017 Advanced Micro Devices, Inc.
|
||||
@ -82,4 +81,3 @@ void calc_rc_params(struct rc_params *rc, enum colour_mode cm, enum bits_per_com
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
@ -1,4 +1,3 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DSC_SUPPORT)
|
||||
/*
|
||||
* Copyright 2012-17 Advanced Micro Devices, Inc.
|
||||
*
|
||||
@ -144,4 +143,3 @@ int dscc_compute_dsc_parameters(const struct drm_dsc_config *pps, struct dsc_par
|
||||
return ret;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -67,12 +67,10 @@ GPIO_DCN10 = hw_translate_dcn10.o hw_factory_dcn10.o
|
||||
AMD_DAL_GPIO_DCN10 = $(addprefix $(AMDDALPATH)/dc/gpio/dcn10/,$(GPIO_DCN10))
|
||||
|
||||
AMD_DISPLAY_FILES += $(AMD_DAL_GPIO_DCN10)
|
||||
endif
|
||||
|
||||
###############################################################################
|
||||
# DCN 2
|
||||
###############################################################################
|
||||
ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
GPIO_DCN20 = hw_translate_dcn20.o hw_factory_dcn20.o
|
||||
|
||||
AMD_DAL_GPIO_DCN20 = $(addprefix $(AMDDALPATH)/dc/gpio/dcn20/,$(GPIO_DCN20))
|
||||
|
@ -22,7 +22,6 @@
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "dm_services.h"
|
||||
#include "include/gpio_types.h"
|
||||
#include "../hw_factory.h"
|
||||
@ -258,4 +257,3 @@ void dal_hw_factory_dcn20_init(struct hw_factory *factory)
|
||||
factory->funcs = &funcs;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -22,7 +22,6 @@
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#ifndef __DAL_HW_FACTORY_DCN20_H__
|
||||
#define __DAL_HW_FACTORY_DCN20_H__
|
||||
|
||||
@ -30,4 +29,3 @@
|
||||
void dal_hw_factory_dcn20_init(struct hw_factory *factory);
|
||||
|
||||
#endif /* __DAL_HW_FACTORY_DCN20_H__ */
|
||||
#endif
|
||||
|
@ -26,7 +26,6 @@
|
||||
/*
|
||||
* Pre-requisites: headers required by header of this unit
|
||||
*/
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "hw_translate_dcn20.h"
|
||||
|
||||
#include "dm_services.h"
|
||||
@ -379,4 +378,3 @@ void dal_hw_translate_dcn20_init(struct hw_translate *tr)
|
||||
tr->funcs = &funcs;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -22,7 +22,6 @@
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#ifndef __DAL_HW_TRANSLATE_DCN20_H__
|
||||
#define __DAL_HW_TRANSLATE_DCN20_H__
|
||||
|
||||
@ -32,4 +31,3 @@ struct hw_translate;
|
||||
void dal_hw_translate_dcn20_init(struct hw_translate *tr);
|
||||
|
||||
#endif /* __DAL_HW_TRANSLATE_DCN20_H__ */
|
||||
#endif
|
||||
|
@ -22,7 +22,6 @@
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "dm_services.h"
|
||||
#include "include/gpio_types.h"
|
||||
#include "../hw_factory.h"
|
||||
@ -239,4 +238,3 @@ void dal_hw_factory_dcn21_init(struct hw_factory *factory)
|
||||
factory->funcs = &funcs;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -26,7 +26,6 @@
|
||||
/*
|
||||
* Pre-requisites: headers required by header of this unit
|
||||
*/
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "hw_translate_dcn21.h"
|
||||
|
||||
#include "dm_services.h"
|
||||
@ -382,4 +381,3 @@ void dal_hw_translate_dcn21_init(struct hw_translate *tr)
|
||||
tr->funcs = &funcs;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -48,13 +48,11 @@
|
||||
DDC_GPIO_REG_LIST(cd,id),\
|
||||
.ddc_setup = REG(DC_I2C_DDC ## id ## _SETUP)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define DDC_REG_LIST_DCN2(cd, id) \
|
||||
DDC_GPIO_REG_LIST(cd, id),\
|
||||
.ddc_setup = REG(DC_I2C_DDC ## id ## _SETUP),\
|
||||
.phy_aux_cntl = REG(PHY_AUX_CNTL), \
|
||||
.dc_gpio_aux_ctrl_5 = REG(DC_GPIO_AUX_CTRL_5)
|
||||
#endif
|
||||
|
||||
#define DDC_GPIO_VGA_REG_LIST_ENTRY(type,cd)\
|
||||
.type ## _reg = REG(DC_GPIO_DDCVGA_ ## type),\
|
||||
@ -90,13 +88,11 @@
|
||||
DDC_GPIO_I2C_REG_LIST(cd),\
|
||||
.ddc_setup = 0
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define DDC_I2C_REG_LIST_DCN2(cd) \
|
||||
DDC_GPIO_I2C_REG_LIST(cd),\
|
||||
.ddc_setup = 0,\
|
||||
.phy_aux_cntl = REG(PHY_AUX_CNTL), \
|
||||
.dc_gpio_aux_ctrl_5 = REG(DC_GPIO_AUX_CTRL_5)
|
||||
#endif
|
||||
#define DDC_MASK_SH_LIST_COMMON(mask_sh) \
|
||||
SF_DDC(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_ENABLE, mask_sh),\
|
||||
SF_DDC(DC_I2C_DDC1_SETUP, DC_I2C_DDC1_EDID_DETECT_ENABLE, mask_sh),\
|
||||
@ -110,22 +106,18 @@
|
||||
SF_DDC(DC_GPIO_I2CPAD_MASK, DC_GPIO_SDA_PD_DIS, mask_sh),\
|
||||
SF_DDC(DC_GPIO_I2CPAD_MASK, DC_GPIO_SCL_PD_DIS, mask_sh)
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define DDC_MASK_SH_LIST_DCN2(mask_sh, cd) \
|
||||
{DDC_MASK_SH_LIST_COMMON(mask_sh),\
|
||||
0,\
|
||||
0,\
|
||||
(PHY_AUX_CNTL__AUX## cd ##_PAD_RXSEL## mask_sh),\
|
||||
(DC_GPIO_AUX_CTRL_5__DDC_PAD## cd ##_I2CMODE## mask_sh)}
|
||||
#endif
|
||||
|
||||
struct ddc_registers {
|
||||
struct gpio_registers gpio;
|
||||
uint32_t ddc_setup;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
uint32_t phy_aux_cntl;
|
||||
uint32_t dc_gpio_aux_ctrl_5;
|
||||
#endif
|
||||
};
|
||||
|
||||
struct ddc_sh_mask {
|
||||
@ -140,11 +132,9 @@ struct ddc_sh_mask {
|
||||
/* i2cpad_mask */
|
||||
uint32_t DC_GPIO_SDA_PD_DIS;
|
||||
uint32_t DC_GPIO_SCL_PD_DIS;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
//phy_aux_cntl
|
||||
uint32_t AUX_PAD_RXSEL;
|
||||
uint32_t DDC_PAD_I2CMODE;
|
||||
#endif
|
||||
};
|
||||
|
||||
|
||||
@ -180,7 +170,6 @@ struct ddc_sh_mask {
|
||||
{\
|
||||
DDC_I2C_REG_LIST(SCL)\
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#define ddc_data_regs_dcn2(id) \
|
||||
{\
|
||||
DDC_REG_LIST_DCN2(DATA, id)\
|
||||
@ -200,7 +189,6 @@ struct ddc_sh_mask {
|
||||
{\
|
||||
DDC_REG_LIST_DCN2(SCL)\
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#endif /* DRIVERS_GPU_DRM_AMD_DC_DEV_DC_GPIO_DDC_REGS_H_ */
|
||||
|
@ -150,7 +150,6 @@ static enum gpio_result set_config(
|
||||
AUX_PAD1_MODE, 0);
|
||||
}
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (ddc->regs->dc_gpio_aux_ctrl_5 != 0) {
|
||||
REG_UPDATE(dc_gpio_aux_ctrl_5, DDC_PAD_I2CMODE, 1);
|
||||
}
|
||||
@ -158,7 +157,6 @@ static enum gpio_result set_config(
|
||||
if (ddc->regs->phy_aux_cntl != 0) {
|
||||
REG_UPDATE(phy_aux_cntl, AUX_PAD_RXSEL, 1);
|
||||
}
|
||||
#endif
|
||||
return GPIO_RESULT_OK;
|
||||
case GPIO_DDC_CONFIG_TYPE_MODE_AUX:
|
||||
/* set the AUX pad mode */
|
||||
@ -166,12 +164,10 @@ static enum gpio_result set_config(
|
||||
REG_SET(gpio.MASK_reg, regval,
|
||||
AUX_PAD1_MODE, 1);
|
||||
}
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
if (ddc->regs->dc_gpio_aux_ctrl_5 != 0) {
|
||||
REG_UPDATE(dc_gpio_aux_ctrl_5,
|
||||
DDC_PAD_I2CMODE, 0);
|
||||
}
|
||||
#endif
|
||||
|
||||
return GPIO_RESULT_OK;
|
||||
case GPIO_DDC_CONFIG_TYPE_POLL_FOR_CONNECT:
|
||||
|
@ -48,9 +48,7 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
#include "dcn10/hw_factory_dcn10.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "dcn20/hw_factory_dcn20.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
#include "dcn21/hw_factory_dcn21.h"
|
||||
#endif
|
||||
@ -95,17 +93,15 @@ bool dal_hw_factory_init(
|
||||
case DCN_VERSION_1_01:
|
||||
dal_hw_factory_dcn10_init(factory);
|
||||
return true;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case DCN_VERSION_2_0:
|
||||
dal_hw_factory_dcn20_init(factory);
|
||||
return true;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
case DCN_VERSION_2_1:
|
||||
dal_hw_factory_dcn21_init(factory);
|
||||
return true;
|
||||
#endif
|
||||
#endif
|
||||
|
||||
default:
|
||||
|
@ -46,9 +46,7 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
#include "dcn10/hw_translate_dcn10.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "dcn20/hw_translate_dcn20.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
#include "dcn21/hw_translate_dcn21.h"
|
||||
#endif
|
||||
@ -90,17 +88,15 @@ bool dal_hw_translate_init(
|
||||
case DCN_VERSION_1_01:
|
||||
dal_hw_translate_dcn10_init(translate);
|
||||
return true;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
case DCN_VERSION_2_0:
|
||||
dal_hw_translate_dcn20_init(translate);
|
||||
return true;
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
case DCN_VERSION_2_1:
|
||||
dal_hw_translate_dcn21_init(translate);
|
||||
return true;
|
||||
#endif
|
||||
#endif
|
||||
|
||||
default:
|
||||
|
@ -43,10 +43,8 @@ enum dc_status {
|
||||
DC_FAIL_BANDWIDTH_VALIDATE = 13, /* BW and Watermark validation */
|
||||
DC_FAIL_SCALING = 14,
|
||||
DC_FAIL_DP_LINK_TRAINING = 15,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
DC_FAIL_DSC_VALIDATE = 16,
|
||||
DC_NO_DSC_RESOURCE = 17,
|
||||
#endif
|
||||
DC_FAIL_UNSUPPORTED_1 = 18,
|
||||
DC_FAIL_CLK_EXCEED_MAX = 21,
|
||||
DC_FAIL_CLK_BELOW_MIN = 22, /*THIS IS MIN PER IP*/
|
||||
|
@ -36,10 +36,8 @@
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
|
||||
#include "mpc.h"
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
#include "dwb.h"
|
||||
#include "mcif_wb.h"
|
||||
#endif
|
||||
|
||||
#define MAX_CLOCK_SOURCES 7
|
||||
|
||||
@ -135,7 +133,6 @@ struct resource_funcs {
|
||||
struct resource_context *res_ctx,
|
||||
const struct resource_pool *pool,
|
||||
struct dc_stream_state *stream);
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
void (*populate_dml_writeback_from_context)(
|
||||
struct dc *dc,
|
||||
struct resource_context *res_ctx,
|
||||
@ -146,7 +143,6 @@ struct resource_funcs {
|
||||
struct dc_state *context,
|
||||
display_e2e_pipe_params_st *pipes,
|
||||
int pipe_cnt);
|
||||
#endif
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_1)
|
||||
void (*update_bw_bounding_box)(
|
||||
struct dc *dc,
|
||||
@ -180,7 +176,6 @@ struct resource_pool {
|
||||
struct dce_i2c_sw *sw_i2cs[MAX_PIPES];
|
||||
bool i2c_hw_buffer_in_use;
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dwbc *dwbc[MAX_DWB_PIPES];
|
||||
struct mcif_wb *mcif_wb[MAX_DWB_PIPES];
|
||||
struct {
|
||||
@ -188,11 +183,8 @@ struct resource_pool {
|
||||
unsigned int gsl_1:1;
|
||||
unsigned int gsl_2:1;
|
||||
} gsl_groups;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct display_stream_compressor *dscs[MAX_PIPES];
|
||||
#endif
|
||||
|
||||
unsigned int pipe_count;
|
||||
unsigned int underlay_pipe_index;
|
||||
@ -206,9 +198,7 @@ struct resource_pool {
|
||||
unsigned int timing_generator_count;
|
||||
unsigned int mpcc_count;
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
unsigned int writeback_pipe_count;
|
||||
#endif
|
||||
/*
|
||||
* reserved clock source for DP
|
||||
*/
|
||||
@ -240,9 +230,7 @@ struct dcn_fe_bandwidth {
|
||||
|
||||
struct stream_resource {
|
||||
struct output_pixel_processor *opp;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
struct display_stream_compressor *dsc;
|
||||
#endif
|
||||
struct timing_generator *tg;
|
||||
struct stream_encoder *stream_enc;
|
||||
struct audio *audio;
|
||||
@ -251,12 +239,10 @@ struct stream_resource {
|
||||
struct encoder_info_frame encoder_info_frame;
|
||||
|
||||
struct abm *abm;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
/* There are only (num_pipes+1)/2 groups. 0 means unassigned,
|
||||
* otherwise it's using group number 'gsl_group-1'
|
||||
*/
|
||||
uint8_t gsl_group;
|
||||
#endif
|
||||
};
|
||||
|
||||
struct plane_resource {
|
||||
@ -315,10 +301,8 @@ struct pipe_ctx {
|
||||
struct _vcs_dpi_display_pipe_dest_params_st pipe_dlg_param;
|
||||
#endif
|
||||
union pipe_update_flags update_flags;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
struct dwbc *dwbc;
|
||||
struct mcif_wb *mcif_wb;
|
||||
#endif
|
||||
};
|
||||
|
||||
struct resource_context {
|
||||
@ -327,9 +311,7 @@ struct resource_context {
|
||||
bool is_audio_acquired[MAX_PIPES];
|
||||
uint8_t clock_source_ref_count[MAX_CLOCK_SOURCES];
|
||||
uint8_t dp_clock_source_ref_count;
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
bool is_dsc_acquired[MAX_PIPES];
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dce_bw_output {
|
||||
@ -349,18 +331,14 @@ struct dce_bw_output {
|
||||
int blackout_recovery_time_us;
|
||||
};
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dcn_bw_writeback {
|
||||
struct mcif_arb_params mcif_wb_arb[MAX_DWB_PIPES];
|
||||
};
|
||||
#endif
|
||||
|
||||
struct dcn_bw_output {
|
||||
struct dc_clocks clk;
|
||||
struct dcn_watermark_set watermarks;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dcn_bw_writeback bw_writeback;
|
||||
#endif
|
||||
};
|
||||
|
||||
union bw_output {
|
||||
|
@ -75,13 +75,11 @@ void dp_enable_mst_on_sink(struct dc_link *link, bool enable);
|
||||
enum dp_panel_mode dp_get_panel_mode(struct dc_link *link);
|
||||
void dp_set_panel_mode(struct dc_link *link, enum dp_panel_mode panel_mode);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DSC_SUPPORT
|
||||
void dp_set_fec_ready(struct dc_link *link, bool ready);
|
||||
void dp_set_fec_enable(struct dc_link *link, bool enable);
|
||||
bool dp_set_dsc_enable(struct pipe_ctx *pipe_ctx, bool enable);
|
||||
bool dp_set_dsc_pps_sdp(struct pipe_ctx *pipe_ctx, bool enable);
|
||||
void dp_set_dsc_on_stream(struct pipe_ctx *pipe_ctx, bool enable);
|
||||
bool dp_update_dsc_config(struct pipe_ctx *pipe_ctx);
|
||||
#endif
|
||||
|
||||
#endif /* __DC_LINK_DP_H__ */
|
||||
|
@ -96,12 +96,10 @@ enum dentist_divider_range {
|
||||
.MP1_SMN_C2PMSG_83 = mmMP1_SMN_C2PMSG_83, \
|
||||
.MP1_SMN_C2PMSG_67 = mmMP1_SMN_C2PMSG_67
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
#define CLK_REG_LIST_NV10() \
|
||||
SR(DENTIST_DISPCLK_CNTL), \
|
||||
CLK_SRI(CLK3_CLK_PLL_REQ, CLK3, 0), \
|
||||
CLK_SRI(CLK3_CLK2_DFS_CNTL, CLK3, 0)
|
||||
#endif
|
||||
|
||||
#define CLK_SF(reg_name, field_name, post_fix)\
|
||||
.field_name = reg_name ## __ ## field_name ## post_fix
|
||||
@ -120,7 +118,6 @@ enum dentist_divider_range {
|
||||
CLK_SF(MP1_SMN_C2PMSG_83, CONTENT, mask_sh),\
|
||||
CLK_SF(MP1_SMN_C2PMSG_91, CONTENT, mask_sh),
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
#define CLK_COMMON_MASK_SH_LIST_DCN20_BASE(mask_sh) \
|
||||
CLK_COMMON_MASK_SH_LIST_DCN_COMMON_BASE(mask_sh),\
|
||||
CLK_SF(DENTIST_DISPCLK_CNTL, DENTIST_DPPCLK_WDIVIDER, mask_sh),\
|
||||
@ -130,7 +127,6 @@ enum dentist_divider_range {
|
||||
CLK_COMMON_MASK_SH_LIST_DCN20_BASE(mask_sh),\
|
||||
CLK_SF(CLK3_0_CLK3_CLK_PLL_REQ, FbMult_int, mask_sh),\
|
||||
CLK_SF(CLK3_0_CLK3_CLK_PLL_REQ, FbMult_frac, mask_sh)
|
||||
#endif
|
||||
|
||||
#define CLK_REG_FIELD_LIST(type) \
|
||||
type DPREFCLK_SRC_SEL; \
|
||||
@ -143,30 +139,24 @@ enum dentist_divider_range {
|
||||
****************** Clock Manager Private Structures ***********************************
|
||||
***************************************************************************************
|
||||
*/
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
#define CLK20_REG_FIELD_LIST(type) \
|
||||
type DENTIST_DPPCLK_WDIVIDER; \
|
||||
type DENTIST_DPPCLK_CHG_DONE; \
|
||||
type FbMult_int; \
|
||||
type FbMult_frac;
|
||||
#endif
|
||||
|
||||
#define VBIOS_SMU_REG_FIELD_LIST(type) \
|
||||
type CONTENT;
|
||||
|
||||
struct clk_mgr_shift {
|
||||
CLK_REG_FIELD_LIST(uint8_t)
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
CLK20_REG_FIELD_LIST(uint8_t)
|
||||
#endif
|
||||
VBIOS_SMU_REG_FIELD_LIST(uint32_t)
|
||||
};
|
||||
|
||||
struct clk_mgr_mask {
|
||||
CLK_REG_FIELD_LIST(uint32_t)
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
CLK20_REG_FIELD_LIST(uint32_t)
|
||||
#endif
|
||||
VBIOS_SMU_REG_FIELD_LIST(uint32_t)
|
||||
};
|
||||
|
||||
@ -174,10 +164,8 @@ struct clk_mgr_registers {
|
||||
uint32_t DPREFCLK_CNTL;
|
||||
uint32_t DENTIST_DISPCLK_CNTL;
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
uint32_t CLK3_CLK2_DFS_CNTL;
|
||||
uint32_t CLK3_CLK_PLL_REQ;
|
||||
#endif
|
||||
|
||||
uint32_t MP1_SMN_C2PMSG_67;
|
||||
uint32_t MP1_SMN_C2PMSG_83;
|
||||
|
@ -52,7 +52,6 @@ struct dcn_hubbub_wm {
|
||||
struct dcn_hubbub_wm_set sets[4];
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
enum dcn_hubbub_page_table_depth {
|
||||
DCN_PAGE_TABLE_DEPTH_1_LEVEL,
|
||||
DCN_PAGE_TABLE_DEPTH_2_LEVEL,
|
||||
@ -101,13 +100,11 @@ struct hubbub_addr_config {
|
||||
} default_addrs;
|
||||
};
|
||||
|
||||
#endif
|
||||
struct hubbub_funcs {
|
||||
void (*update_dchub)(
|
||||
struct hubbub *hubbub,
|
||||
struct dchub_init_data *dh_data);
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
int (*init_dchub_sys_ctx)(
|
||||
struct hubbub *hubbub,
|
||||
struct dcn_hubbub_phys_addr_config *pa_config);
|
||||
@ -116,7 +113,6 @@ struct hubbub_funcs {
|
||||
struct dcn_hubbub_virt_addr_config *va_config,
|
||||
int vmid);
|
||||
|
||||
#endif
|
||||
bool (*get_dcc_compression_cap)(struct hubbub *hubbub,
|
||||
const struct dc_dcc_surface_param *input,
|
||||
struct dc_surface_dcc_cap *output);
|
||||
|
@ -36,14 +36,10 @@ struct dpp {
|
||||
struct dpp_caps *caps;
|
||||
struct pwl_params regamma_params;
|
||||
struct pwl_params degamma_params;
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct dpp_cursor_attributes cur_attr;
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
struct pwl_params shaper_params;
|
||||
bool cm_bypass_mode;
|
||||
#endif
|
||||
};
|
||||
|
||||
struct dpp_input_csc_matrix {
|
||||
@ -56,7 +52,6 @@ struct dpp_grph_csc_adjustment {
|
||||
enum graphics_gamut_adjust_type gamut_adjust_type;
|
||||
};
|
||||
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
struct cnv_color_keyer_params {
|
||||
int color_keyer_en;
|
||||
int color_keyer_mode;
|
||||
@ -82,7 +77,6 @@ struct cnv_alpha_2bit_lut {
|
||||
int lut2;
|
||||
int lut3;
|
||||
};
|
||||
#endif
|
||||
|
||||
struct dcn_dpp_state {
|
||||
uint32_t is_enabled;
|
||||
@ -190,12 +184,8 @@ struct dpp_funcs {
|
||||
enum surface_pixel_format format,
|
||||
enum expansion_mode mode,
|
||||
struct dc_csc_transform input_csc_color_matrix,
|
||||
#ifdef CONFIG_DRM_AMD_DC_DCN2_0
|
||||
enum dc_color_space input_color_space,
|
||||
struct cnv_alpha_2bit_lut *alpha_2bit_lut);
|
||||
#else
|
||||
enum dc_color_space input_color_space);
|
||||
#endif
|
||||
|
||||
void (*dpp_full_bypass)(struct dpp *dpp_base);
|
||||
|
||||
@ -224,7 +214,6 @@ struct dpp_funcs {
|
||||
bool dppclk_div,
|
||||
bool enable);
|
||||
|
||||
#if defined(CONFIG_DRM_AMD_DC_DCN2_0)
|
||||
bool (*dpp_program_blnd_lut)(
|
||||
struct dpp *dpp,
|
||||
const struct pwl_params *params);
|
||||
@ -237,7 +226,6 @@ struct dpp_funcs {
|
||||
void (*dpp_cnv_set_alpha_keyer)(
|
||||
struct dpp *dpp_base,
|
||||
struct cnv_color_keyer_params *color_keyer);
|
||||
#endif
|
||||
};
|
||||
|
||||
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user