Commit ef30f441 authored by Wenjing Liu's avatar Wenjing Liu Committed by Alex Deucher

drm/amd/display: define link res and make it accessible to all link interfaces

[why]
There will be a series of re-arch changes in Link Resource Management.
They are more and more muxable link resource objects and the resource is
insufficient for a one to one allocation to all links created.
Therefore a link resource sharing logic is required to determine which
link should use certain link resource.

This commit is the first one in this series that starts by defining a
link resource struct, this struct will be available to all interfaces
that need to perform link programming sequence.

In later commits, we will granduately decouple link resource objects out
of dc link. So instead of access a link resource from dc link. Current
link's resource can be accessible through pipe_ctx->link_res during
commit, or by calling  dc_link_get_cur_link_res function with current
link passed in after commit.
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Reviewed-by: default avatarJun Lei <Jun.Lei@amd.com>
Acked-by: default avatarRodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: default avatarWenjing Liu <wenjing.liu@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 19afe66d
...@@ -986,7 +986,7 @@ static bool dc_link_detect_helper(struct dc_link *link, ...@@ -986,7 +986,7 @@ static bool dc_link_detect_helper(struct dc_link *link,
* empty which leads to allocate_mst_payload() has "0" * empty which leads to allocate_mst_payload() has "0"
* pbn_per_slot value leading to exception on dc_fixpt_div() * pbn_per_slot value leading to exception on dc_fixpt_div()
*/ */
dp_verify_mst_link_cap(link); dp_verify_mst_link_cap(link, NULL);
/* /*
* This call will initiate MST topology discovery. Which * This call will initiate MST topology discovery. Which
...@@ -1150,6 +1150,7 @@ static bool dc_link_detect_helper(struct dc_link *link, ...@@ -1150,6 +1150,7 @@ static bool dc_link_detect_helper(struct dc_link *link,
// verify link cap for SST non-seamless boot // verify link cap for SST non-seamless boot
if (!perform_dp_seamless_boot) if (!perform_dp_seamless_boot)
dp_verify_link_cap_with_retries(link, dp_verify_link_cap_with_retries(link,
NULL,
&link->reported_link_cap, &link->reported_link_cap,
LINK_TRAINING_MAX_VERIFY_RETRY); LINK_TRAINING_MAX_VERIFY_RETRY);
} else { } else {
...@@ -2503,7 +2504,8 @@ static void write_i2c_redriver_setting( ...@@ -2503,7 +2504,8 @@ static void write_i2c_redriver_setting(
DC_LOG_DEBUG("Set redriver failed"); DC_LOG_DEBUG("Set redriver failed");
} }
static void disable_link(struct dc_link *link, enum signal_type signal) static void disable_link(struct dc_link *link, const struct link_resource *link_res,
enum signal_type signal)
{ {
/* /*
* TODO: implement call for dp_set_hw_test_pattern * TODO: implement call for dp_set_hw_test_pattern
...@@ -2522,20 +2524,20 @@ static void disable_link(struct dc_link *link, enum signal_type signal) ...@@ -2522,20 +2524,20 @@ static void disable_link(struct dc_link *link, enum signal_type signal)
struct dc_link_settings link_settings = link->cur_link_settings; struct dc_link_settings link_settings = link->cur_link_settings;
#endif #endif
if (dc_is_dp_sst_signal(signal)) if (dc_is_dp_sst_signal(signal))
dp_disable_link_phy(link, signal); dp_disable_link_phy(link, link_res, signal);
else else
dp_disable_link_phy_mst(link, signal); dp_disable_link_phy_mst(link, link_res, signal);
if (dc_is_dp_sst_signal(signal) || if (dc_is_dp_sst_signal(signal) ||
link->mst_stream_alloc_table.stream_count == 0) { link->mst_stream_alloc_table.stream_count == 0) {
#if defined(CONFIG_DRM_AMD_DC_DCN) #if defined(CONFIG_DRM_AMD_DC_DCN)
if (dp_get_link_encoding_format(&link_settings) == DP_8b_10b_ENCODING) { if (dp_get_link_encoding_format(&link_settings) == DP_8b_10b_ENCODING) {
dp_set_fec_enable(link, false); dp_set_fec_enable(link, false);
dp_set_fec_ready(link, false); dp_set_fec_ready(link, link_res, false);
} }
#else #else
dp_set_fec_enable(link, false); dp_set_fec_enable(link, false);
dp_set_fec_ready(link, false); dp_set_fec_ready(link, link_res, false);
#endif #endif
} }
} else { } else {
...@@ -2646,7 +2648,7 @@ static enum dc_status enable_link( ...@@ -2646,7 +2648,7 @@ static enum dc_status enable_link(
* new link settings. * new link settings.
*/ */
if (link->link_status.link_active) { if (link->link_status.link_active) {
disable_link(link, pipe_ctx->stream->signal); disable_link(link, &pipe_ctx->link_res, pipe_ctx->stream->signal);
} }
switch (pipe_ctx->stream->signal) { switch (pipe_ctx->stream->signal) {
...@@ -4109,7 +4111,7 @@ static void fpga_dp_hpo_enable_link_and_stream(struct dc_state *state, struct pi ...@@ -4109,7 +4111,7 @@ static void fpga_dp_hpo_enable_link_and_stream(struct dc_state *state, struct pi
stream->link->cur_link_settings = link_settings; stream->link->cur_link_settings = link_settings;
/* Enable clock, Configure lane count, and Enable Link Encoder*/ /* Enable clock, Configure lane count, and Enable Link Encoder*/
enable_dp_hpo_output(stream->link, &stream->link->cur_link_settings); enable_dp_hpo_output(stream->link, &pipe_ctx->link_res, &stream->link->cur_link_settings);
#ifdef DIAGS_BUILD #ifdef DIAGS_BUILD
/* Workaround for FPGA HPO capture DP link data: /* Workaround for FPGA HPO capture DP link data:
...@@ -4353,7 +4355,8 @@ void core_link_enable_stream( ...@@ -4353,7 +4355,8 @@ void core_link_enable_stream(
if (status != DC_FAIL_DP_LINK_TRAINING || if (status != DC_FAIL_DP_LINK_TRAINING ||
pipe_ctx->stream->signal == SIGNAL_TYPE_DISPLAY_PORT_MST) { pipe_ctx->stream->signal == SIGNAL_TYPE_DISPLAY_PORT_MST) {
if (false == stream->link->link_status.link_active) if (false == stream->link->link_status.link_active)
disable_link(stream->link, pipe_ctx->stream->signal); disable_link(stream->link, &pipe_ctx->link_res,
pipe_ctx->stream->signal);
BREAK_TO_DEBUGGER(); BREAK_TO_DEBUGGER();
return; return;
} }
...@@ -4502,14 +4505,14 @@ void core_link_disable_stream(struct pipe_ctx *pipe_ctx) ...@@ -4502,14 +4505,14 @@ void core_link_disable_stream(struct pipe_ctx *pipe_ctx)
* state machine. * state machine.
* In DP2 or MST mode, our encoder will stay video active * In DP2 or MST mode, our encoder will stay video active
*/ */
disable_link(pipe_ctx->stream->link, pipe_ctx->stream->signal); disable_link(pipe_ctx->stream->link, &pipe_ctx->link_res, pipe_ctx->stream->signal);
dc->hwss.disable_stream(pipe_ctx); dc->hwss.disable_stream(pipe_ctx);
} else { } else {
dc->hwss.disable_stream(pipe_ctx); dc->hwss.disable_stream(pipe_ctx);
disable_link(pipe_ctx->stream->link, pipe_ctx->stream->signal); disable_link(pipe_ctx->stream->link, &pipe_ctx->link_res, pipe_ctx->stream->signal);
} }
#else #else
disable_link(pipe_ctx->stream->link, pipe_ctx->stream->signal); disable_link(pipe_ctx->stream->link, &pipe_ctx->link_res, pipe_ctx->stream->signal);
dc->hwss.disable_stream(pipe_ctx); dc->hwss.disable_stream(pipe_ctx);
#endif #endif
...@@ -4592,16 +4595,22 @@ void dc_link_set_drive_settings(struct dc *dc, ...@@ -4592,16 +4595,22 @@ void dc_link_set_drive_settings(struct dc *dc,
{ {
int i; int i;
struct pipe_ctx *pipe = NULL;
const struct link_resource *link_res;
for (i = 0; i < dc->link_count; i++) { link_res = dc_link_get_cur_link_res(link);
if (dc->links[i] == link)
break;
}
if (i >= dc->link_count) for (i = 0; i < MAX_PIPES; i++) {
pipe = &dc->current_state->res_ctx.pipe_ctx[i];
if (pipe->stream && pipe->stream->link) {
if (pipe->stream->link == link)
break;
}
}
if (pipe && link_res)
dc_link_dp_set_drive_settings(pipe->stream->link, link_res, lt_settings);
else
ASSERT_CRITICAL(false); ASSERT_CRITICAL(false);
dc_link_dp_set_drive_settings(dc->links[i], lt_settings);
} }
void dc_link_set_preferred_link_settings(struct dc *dc, void dc_link_set_preferred_link_settings(struct dc *dc,
...@@ -4793,6 +4802,9 @@ void dc_link_overwrite_extended_receiver_cap( ...@@ -4793,6 +4802,9 @@ void dc_link_overwrite_extended_receiver_cap(
bool dc_link_is_fec_supported(const struct dc_link *link) bool dc_link_is_fec_supported(const struct dc_link *link)
{ {
/* TODO - use asic cap instead of link_enc->features
* we no longer know which link enc to use for this link before commit
*/
struct link_encoder *link_enc = NULL; struct link_encoder *link_enc = NULL;
/* Links supporting dynamically assigned link encoder will be assigned next /* Links supporting dynamically assigned link encoder will be assigned next
...@@ -4887,3 +4899,22 @@ uint32_t dc_bandwidth_in_kbps_from_timing( ...@@ -4887,3 +4899,22 @@ uint32_t dc_bandwidth_in_kbps_from_timing(
return kbps; return kbps;
} }
const struct link_resource *dc_link_get_cur_link_res(const struct dc_link *link)
{
int i;
struct pipe_ctx *pipe = NULL;
const struct link_resource *link_res = NULL;
for (i = 0; i < MAX_PIPES; i++) {
pipe = &link->dc->current_state->res_ctx.pipe_ctx[i];
if (pipe->stream && pipe->stream->link && pipe->top_pipe == NULL) {
if (pipe->stream->link == link) {
link_res = &pipe->link_res;
break;
}
}
}
return link_res;
}
...@@ -77,7 +77,9 @@ enum dc_status dpcd_get_tunneling_device_data(struct dc_link *link) ...@@ -77,7 +77,9 @@ enum dc_status dpcd_get_tunneling_device_data(struct dc_link *link)
* @param[in] link_setting Lane count, link rate and downspread control. * @param[in] link_setting Lane count, link rate and downspread control.
* @param[out] lt_settings Link settings and drive settings (voltage swing and pre-emphasis). * @param[out] lt_settings Link settings and drive settings (voltage swing and pre-emphasis).
*/ */
static enum link_training_result dpia_configure_link(struct dc_link *link, static enum link_training_result dpia_configure_link(
struct dc_link *link,
const struct link_resource *link_res,
const struct dc_link_settings *link_setting, const struct dc_link_settings *link_setting,
struct link_training_settings *lt_settings) struct link_training_settings *lt_settings)
{ {
...@@ -111,7 +113,7 @@ static enum link_training_result dpia_configure_link(struct dc_link *link, ...@@ -111,7 +113,7 @@ static enum link_training_result dpia_configure_link(struct dc_link *link,
fec_enable = *link->preferred_training_settings.fec_enable; fec_enable = *link->preferred_training_settings.fec_enable;
else else
fec_enable = true; fec_enable = true;
status = dp_set_fec_ready(link, fec_enable); status = dp_set_fec_ready(link, link_res, fec_enable);
if (status != DC_OK && link->is_hpd_pending) if (status != DC_OK && link->is_hpd_pending)
return LINK_TRAINING_ABORT; return LINK_TRAINING_ABORT;
...@@ -252,7 +254,9 @@ static enum dc_status dpcd_set_lt_pattern(struct dc_link *link, ...@@ -252,7 +254,9 @@ static enum dc_status dpcd_set_lt_pattern(struct dc_link *link,
* @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis). * @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis).
* @param hop The Hop in display path. DPRX = 0. * @param hop The Hop in display path. DPRX = 0.
*/ */
static enum link_training_result dpia_training_cr_non_transparent(struct dc_link *link, static enum link_training_result dpia_training_cr_non_transparent(
struct dc_link *link,
const struct link_resource *link_res,
struct link_training_settings *lt_settings, struct link_training_settings *lt_settings,
uint32_t hop) uint32_t hop)
{ {
...@@ -411,7 +415,9 @@ static enum link_training_result dpia_training_cr_non_transparent(struct dc_link ...@@ -411,7 +415,9 @@ static enum link_training_result dpia_training_cr_non_transparent(struct dc_link
* @param link DPIA link being trained. * @param link DPIA link being trained.
* @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis). * @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis).
*/ */
static enum link_training_result dpia_training_cr_transparent(struct dc_link *link, static enum link_training_result dpia_training_cr_transparent(
struct dc_link *link,
const struct link_resource *link_res,
struct link_training_settings *lt_settings) struct link_training_settings *lt_settings)
{ {
enum link_training_result result = LINK_TRAINING_CR_FAIL_LANE0; enum link_training_result result = LINK_TRAINING_CR_FAIL_LANE0;
...@@ -511,16 +517,18 @@ static enum link_training_result dpia_training_cr_transparent(struct dc_link *li ...@@ -511,16 +517,18 @@ static enum link_training_result dpia_training_cr_transparent(struct dc_link *li
* @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis). * @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis).
* @param hop The Hop in display path. DPRX = 0. * @param hop The Hop in display path. DPRX = 0.
*/ */
static enum link_training_result dpia_training_cr_phase(struct dc_link *link, static enum link_training_result dpia_training_cr_phase(
struct dc_link *link,
const struct link_resource *link_res,
struct link_training_settings *lt_settings, struct link_training_settings *lt_settings,
uint32_t hop) uint32_t hop)
{ {
enum link_training_result result = LINK_TRAINING_CR_FAIL_LANE0; enum link_training_result result = LINK_TRAINING_CR_FAIL_LANE0;
if (link->lttpr_mode == LTTPR_MODE_NON_TRANSPARENT) if (link->lttpr_mode == LTTPR_MODE_NON_TRANSPARENT)
result = dpia_training_cr_non_transparent(link, lt_settings, hop); result = dpia_training_cr_non_transparent(link, link_res, lt_settings, hop);
else else
result = dpia_training_cr_transparent(link, lt_settings); result = dpia_training_cr_transparent(link, link_res, lt_settings);
return result; return result;
} }
...@@ -561,7 +569,9 @@ static uint32_t dpia_get_eq_aux_rd_interval(const struct dc_link *link, ...@@ -561,7 +569,9 @@ static uint32_t dpia_get_eq_aux_rd_interval(const struct dc_link *link,
* @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis). * @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis).
* @param hop The Hop in display path. DPRX = 0. * @param hop The Hop in display path. DPRX = 0.
*/ */
static enum link_training_result dpia_training_eq_non_transparent(struct dc_link *link, static enum link_training_result dpia_training_eq_non_transparent(
struct dc_link *link,
const struct link_resource *link_res,
struct link_training_settings *lt_settings, struct link_training_settings *lt_settings,
uint32_t hop) uint32_t hop)
{ {
...@@ -700,7 +710,9 @@ static enum link_training_result dpia_training_eq_non_transparent(struct dc_link ...@@ -700,7 +710,9 @@ static enum link_training_result dpia_training_eq_non_transparent(struct dc_link
* @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis). * @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis).
* @param hop The Hop in display path. DPRX = 0. * @param hop The Hop in display path. DPRX = 0.
*/ */
static enum link_training_result dpia_training_eq_transparent(struct dc_link *link, static enum link_training_result dpia_training_eq_transparent(
struct dc_link *link,
const struct link_resource *link_res,
struct link_training_settings *lt_settings) struct link_training_settings *lt_settings)
{ {
enum link_training_result result = LINK_TRAINING_EQ_FAIL_EQ; enum link_training_result result = LINK_TRAINING_EQ_FAIL_EQ;
...@@ -779,16 +791,18 @@ static enum link_training_result dpia_training_eq_transparent(struct dc_link *li ...@@ -779,16 +791,18 @@ static enum link_training_result dpia_training_eq_transparent(struct dc_link *li
* @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis). * @param lt_settings link_setting and drive settings (voltage swing and pre-emphasis).
* @param hop The Hop in display path. DPRX = 0. * @param hop The Hop in display path. DPRX = 0.
*/ */
static enum link_training_result dpia_training_eq_phase(struct dc_link *link, static enum link_training_result dpia_training_eq_phase(
struct dc_link *link,
const struct link_resource *link_res,
struct link_training_settings *lt_settings, struct link_training_settings *lt_settings,
uint32_t hop) uint32_t hop)
{ {
enum link_training_result result; enum link_training_result result;
if (link->lttpr_mode == LTTPR_MODE_NON_TRANSPARENT) if (link->lttpr_mode == LTTPR_MODE_NON_TRANSPARENT)
result = dpia_training_eq_non_transparent(link, lt_settings, hop); result = dpia_training_eq_non_transparent(link, link_res, lt_settings, hop);
else else
result = dpia_training_eq_transparent(link, lt_settings); result = dpia_training_eq_transparent(link, link_res, lt_settings);
return result; return result;
} }
...@@ -908,7 +922,9 @@ static void dpia_training_abort(struct dc_link *link, uint32_t hop) ...@@ -908,7 +922,9 @@ static void dpia_training_abort(struct dc_link *link, uint32_t hop)
core_link_send_set_config(link, DPIA_SET_CFG_SET_LINK, data); core_link_send_set_config(link, DPIA_SET_CFG_SET_LINK, data);
} }
enum link_training_result dc_link_dpia_perform_link_training(struct dc_link *link, enum link_training_result dc_link_dpia_perform_link_training(
struct dc_link *link,
const struct link_resource *link_res,
const struct dc_link_settings *link_setting, const struct dc_link_settings *link_setting,
bool skip_video_pattern) bool skip_video_pattern)
{ {
...@@ -918,7 +934,7 @@ enum link_training_result dc_link_dpia_perform_link_training(struct dc_link *lin ...@@ -918,7 +934,7 @@ enum link_training_result dc_link_dpia_perform_link_training(struct dc_link *lin
int8_t repeater_id; /* Current hop. */ int8_t repeater_id; /* Current hop. */
/* Configure link as prescribed in link_setting and set LTTPR mode. */ /* Configure link as prescribed in link_setting and set LTTPR mode. */
result = dpia_configure_link(link, link_setting, &lt_settings); result = dpia_configure_link(link, link_res, link_setting, &lt_settings);
if (result != LINK_TRAINING_SUCCESS) if (result != LINK_TRAINING_SUCCESS)
return result; return result;
...@@ -930,12 +946,12 @@ enum link_training_result dc_link_dpia_perform_link_training(struct dc_link *lin ...@@ -930,12 +946,12 @@ enum link_training_result dc_link_dpia_perform_link_training(struct dc_link *lin
*/ */
for (repeater_id = repeater_cnt; repeater_id >= 0; repeater_id--) { for (repeater_id = repeater_cnt; repeater_id >= 0; repeater_id--) {
/* Clock recovery. */ /* Clock recovery. */
result = dpia_training_cr_phase(link, &lt_settings, repeater_id); result = dpia_training_cr_phase(link, link_res, &lt_settings, repeater_id);
if (result != LINK_TRAINING_SUCCESS) if (result != LINK_TRAINING_SUCCESS)
break; break;
/* Equalization. */ /* Equalization. */
result = dpia_training_eq_phase(link, &lt_settings, repeater_id); result = dpia_training_eq_phase(link, link_res, &lt_settings, repeater_id);
if (result != LINK_TRAINING_SUCCESS) if (result != LINK_TRAINING_SUCCESS)
break; break;
......
...@@ -71,6 +71,7 @@ void dp_source_sequence_trace(struct dc_link *link, uint8_t dp_test_mode) ...@@ -71,6 +71,7 @@ void dp_source_sequence_trace(struct dc_link *link, uint8_t dp_test_mode)
void dp_enable_link_phy( void dp_enable_link_phy(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
enum signal_type signal, enum signal_type signal,
enum clock_source_id clock_source, enum clock_source_id clock_source,
const struct dc_link_settings *link_settings) const struct dc_link_settings *link_settings)
...@@ -135,7 +136,7 @@ void dp_enable_link_phy( ...@@ -135,7 +136,7 @@ void dp_enable_link_phy(
#if defined(CONFIG_DRM_AMD_DC_DCN) #if defined(CONFIG_DRM_AMD_DC_DCN)
if (dp_get_link_encoding_format(link_settings) == DP_128b_132b_ENCODING) { if (dp_get_link_encoding_format(link_settings) == DP_128b_132b_ENCODING) {
enable_dp_hpo_output(link, link_settings); enable_dp_hpo_output(link, link_res, link_settings);
} else if (dp_get_link_encoding_format(link_settings) == DP_8b_10b_ENCODING) { } else if (dp_get_link_encoding_format(link_settings) == DP_8b_10b_ENCODING) {
if (dc_is_dp_sst_signal(signal)) { if (dc_is_dp_sst_signal(signal)) {
link_enc->funcs->enable_dp_output( link_enc->funcs->enable_dp_output(
...@@ -236,7 +237,8 @@ bool edp_receiver_ready_T7(struct dc_link *link) ...@@ -236,7 +237,8 @@ bool edp_receiver_ready_T7(struct dc_link *link)
return result; return result;
} }
void dp_disable_link_phy(struct dc_link *link, enum signal_type signal) void dp_disable_link_phy(struct dc_link *link, const struct link_resource *link_res,
enum signal_type signal)
{ {
struct dc *dc = link->ctx->dc; struct dc *dc = link->ctx->dc;
struct dmcu *dmcu = dc->res_pool->dmcu; struct dmcu *dmcu = dc->res_pool->dmcu;
...@@ -260,7 +262,7 @@ void dp_disable_link_phy(struct dc_link *link, enum signal_type signal) ...@@ -260,7 +262,7 @@ void dp_disable_link_phy(struct dc_link *link, enum signal_type signal)
link->dc->hwss.edp_backlight_control(link, false); link->dc->hwss.edp_backlight_control(link, false);
#if defined(CONFIG_DRM_AMD_DC_DCN) #if defined(CONFIG_DRM_AMD_DC_DCN)
if (dp_get_link_encoding_format(&link->cur_link_settings) == DP_128b_132b_ENCODING) if (dp_get_link_encoding_format(&link->cur_link_settings) == DP_128b_132b_ENCODING)
disable_dp_hpo_output(link, signal); disable_dp_hpo_output(link, link_res, signal);
else else
link_enc->funcs->disable_output(link_enc, signal); link_enc->funcs->disable_output(link_enc, signal);
#else #else
...@@ -274,7 +276,7 @@ void dp_disable_link_phy(struct dc_link *link, enum signal_type signal) ...@@ -274,7 +276,7 @@ void dp_disable_link_phy(struct dc_link *link, enum signal_type signal)
#if defined(CONFIG_DRM_AMD_DC_DCN) #if defined(CONFIG_DRM_AMD_DC_DCN)
if (dp_get_link_encoding_format(&link->cur_link_settings) == DP_128b_132b_ENCODING && if (dp_get_link_encoding_format(&link->cur_link_settings) == DP_128b_132b_ENCODING &&
hpo_link_enc) hpo_link_enc)
disable_dp_hpo_output(link, signal); disable_dp_hpo_output(link, link_res, signal);
else else
link_enc->funcs->disable_output(link_enc, signal); link_enc->funcs->disable_output(link_enc, signal);
#else #else
...@@ -294,13 +296,14 @@ void dp_disable_link_phy(struct dc_link *link, enum signal_type signal) ...@@ -294,13 +296,14 @@ void dp_disable_link_phy(struct dc_link *link, enum signal_type signal)
dc->clk_mgr->funcs->notify_link_rate_change(dc->clk_mgr, link); dc->clk_mgr->funcs->notify_link_rate_change(dc->clk_mgr, link);
} }
void dp_disable_link_phy_mst(struct dc_link *link, enum signal_type signal) void dp_disable_link_phy_mst(struct dc_link *link, const struct link_resource *link_res,
enum signal_type signal)
{ {
/* MST disable link only when no stream use the link */ /* MST disable link only when no stream use the link */
if (link->mst_stream_alloc_table.stream_count > 0) if (link->mst_stream_alloc_table.stream_count > 0)
return; return;
dp_disable_link_phy(link, signal); dp_disable_link_phy(link, link_res, signal);
/* set the sink to SST mode after disabling the link */ /* set the sink to SST mode after disabling the link */
dp_enable_mst_on_sink(link, false); dp_enable_mst_on_sink(link, false);
...@@ -308,6 +311,7 @@ void dp_disable_link_phy_mst(struct dc_link *link, enum signal_type signal) ...@@ -308,6 +311,7 @@ void dp_disable_link_phy_mst(struct dc_link *link, enum signal_type signal)
bool dp_set_hw_training_pattern( bool dp_set_hw_training_pattern(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
enum dc_dp_training_pattern pattern, enum dc_dp_training_pattern pattern,
uint32_t offset) uint32_t offset)
{ {
...@@ -338,7 +342,7 @@ bool dp_set_hw_training_pattern( ...@@ -338,7 +342,7 @@ bool dp_set_hw_training_pattern(
break; break;
} }
dp_set_hw_test_pattern(link, test_pattern, NULL, 0); dp_set_hw_test_pattern(link, link_res, test_pattern, NULL, 0);
return true; return true;
} }
...@@ -349,6 +353,7 @@ bool dp_set_hw_training_pattern( ...@@ -349,6 +353,7 @@ bool dp_set_hw_training_pattern(
#endif #endif
void dp_set_hw_lane_settings( void dp_set_hw_lane_settings(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
const struct link_training_settings *link_settings, const struct link_training_settings *link_settings,
uint32_t offset) uint32_t offset)
{ {
...@@ -379,6 +384,7 @@ void dp_set_hw_lane_settings( ...@@ -379,6 +384,7 @@ void dp_set_hw_lane_settings(
void dp_set_hw_test_pattern( void dp_set_hw_test_pattern(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
enum dp_test_pattern test_pattern, enum dp_test_pattern test_pattern,
uint8_t *custom_pattern, uint8_t *custom_pattern,
uint32_t custom_pattern_size) uint32_t custom_pattern_size)
...@@ -446,7 +452,7 @@ void dp_retrain_link_dp_test(struct dc_link *link, ...@@ -446,7 +452,7 @@ void dp_retrain_link_dp_test(struct dc_link *link,
pipes[i].stream_res.stream_enc); pipes[i].stream_res.stream_enc);
/* disable any test pattern that might be active */ /* disable any test pattern that might be active */
dp_set_hw_test_pattern(link, dp_set_hw_test_pattern(link, &pipes[i].link_res,
DP_TEST_PATTERN_VIDEO_MODE, NULL, 0); DP_TEST_PATTERN_VIDEO_MODE, NULL, 0);
dp_receiver_power_ctrl(link, false); dp_receiver_power_ctrl(link, false);
...@@ -763,7 +769,9 @@ static enum phyd32clk_clock_source get_phyd32clk_src(struct dc_link *link) ...@@ -763,7 +769,9 @@ static enum phyd32clk_clock_source get_phyd32clk_src(struct dc_link *link)
} }
} }
void enable_dp_hpo_output(struct dc_link *link, const struct dc_link_settings *link_settings) void enable_dp_hpo_output(struct dc_link *link,
const struct link_resource *link_res,
const struct dc_link_settings *link_settings)
{ {
const struct dc *dc = link->dc; const struct dc *dc = link->dc;
enum phyd32clk_clock_source phyd32clk; enum phyd32clk_clock_source phyd32clk;
...@@ -814,7 +822,9 @@ void enable_dp_hpo_output(struct dc_link *link, const struct dc_link_settings *l ...@@ -814,7 +822,9 @@ void enable_dp_hpo_output(struct dc_link *link, const struct dc_link_settings *l
} }
} }
void disable_dp_hpo_output(struct dc_link *link, enum signal_type signal) void disable_dp_hpo_output(struct dc_link *link,
const struct link_resource *link_res,
enum signal_type signal)
{ {
const struct dc *dc = link->dc; const struct dc *dc = link->dc;
......
...@@ -30,6 +30,8 @@ ...@@ -30,6 +30,8 @@
#include "dc_types.h" #include "dc_types.h"
#include "grph_object_defs.h" #include "grph_object_defs.h"
struct link_resource;
enum dc_link_fec_state { enum dc_link_fec_state {
dc_link_fec_not_ready, dc_link_fec_not_ready,
dc_link_fec_ready, dc_link_fec_ready,
...@@ -359,14 +361,17 @@ void dc_link_remove_remote_sink( ...@@ -359,14 +361,17 @@ void dc_link_remove_remote_sink(
void dc_link_dp_set_drive_settings( void dc_link_dp_set_drive_settings(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
struct link_training_settings *lt_settings); struct link_training_settings *lt_settings);
bool dc_link_dp_perform_link_training_skip_aux( bool dc_link_dp_perform_link_training_skip_aux(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
const struct dc_link_settings *link_setting); const struct dc_link_settings *link_setting);
enum link_training_result dc_link_dp_perform_link_training( enum link_training_result dc_link_dp_perform_link_training(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
const struct dc_link_settings *link_settings, const struct dc_link_settings *link_settings,
bool skip_video_pattern); bool skip_video_pattern);
...@@ -374,6 +379,7 @@ bool dc_link_dp_sync_lt_begin(struct dc_link *link); ...@@ -374,6 +379,7 @@ bool dc_link_dp_sync_lt_begin(struct dc_link *link);
enum link_training_result dc_link_dp_sync_lt_attempt( enum link_training_result dc_link_dp_sync_lt_attempt(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
struct dc_link_settings *link_setting, struct dc_link_settings *link_setting,
struct dc_link_training_overrides *lt_settings); struct dc_link_training_overrides *lt_settings);
...@@ -454,4 +460,6 @@ bool dc_link_should_enable_fec(const struct dc_link *link); ...@@ -454,4 +460,6 @@ bool dc_link_should_enable_fec(const struct dc_link *link);
uint32_t dc_link_bw_kbps_from_raw_frl_link_rate_data(uint8_t bw); uint32_t dc_link_bw_kbps_from_raw_frl_link_rate_data(uint8_t bw);
enum dp_link_encoding dc_link_dp_mst_decide_link_encoding_format(const struct dc_link *link); enum dp_link_encoding dc_link_dp_mst_decide_link_encoding_format(const struct dc_link *link);
#endif #endif
const struct link_resource *dc_link_get_cur_link_res(const struct dc_link *link);
#endif /* DC_LINK_H_ */ #endif /* DC_LINK_H_ */
...@@ -334,6 +334,11 @@ struct plane_resource { ...@@ -334,6 +334,11 @@ struct plane_resource {
struct dcn_fe_bandwidth bw; struct dcn_fe_bandwidth bw;
}; };
/* all mappable hardware resources used to enable a link */
struct link_resource {
void *dummy;
};
union pipe_update_flags { union pipe_update_flags {
struct { struct {
uint32_t enable : 1; uint32_t enable : 1;
...@@ -361,6 +366,7 @@ struct pipe_ctx { ...@@ -361,6 +366,7 @@ struct pipe_ctx {
struct plane_resource plane_res; struct plane_resource plane_res;
struct stream_resource stream_res; struct stream_resource stream_res;
struct link_resource link_res;
struct clock_source *clock_source; struct clock_source *clock_source;
......
...@@ -56,16 +56,19 @@ enum { ...@@ -56,16 +56,19 @@ enum {
bool dp_verify_link_cap( bool dp_verify_link_cap(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
struct dc_link_settings *known_limit_link_setting, struct dc_link_settings *known_limit_link_setting,
int *fail_count); int *fail_count);
bool dp_verify_link_cap_with_retries( bool dp_verify_link_cap_with_retries(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
struct dc_link_settings *known_limit_link_setting, struct dc_link_settings *known_limit_link_setting,
int attempts); int attempts);
bool dp_verify_mst_link_cap( bool dp_verify_mst_link_cap(
struct dc_link *link); struct dc_link *link,
const struct link_resource *link_res);
bool dp_validate_mode_timing( bool dp_validate_mode_timing(
struct dc_link *link, struct dc_link *link,
...@@ -168,7 +171,7 @@ uint8_t dc_dp_initialize_scrambling_data_symbols( ...@@ -168,7 +171,7 @@ uint8_t dc_dp_initialize_scrambling_data_symbols(
struct dc_link *link, struct dc_link *link,
enum dc_dp_training_pattern pattern); enum dc_dp_training_pattern pattern);
enum dc_status dp_set_fec_ready(struct dc_link *link, bool ready); enum dc_status dp_set_fec_ready(struct dc_link *link, const struct link_resource *link_res, bool ready);
void dp_set_fec_enable(struct dc_link *link, bool enable); void dp_set_fec_enable(struct dc_link *link, bool enable);
struct link_encoder *dp_get_link_enc(struct dc_link *link); struct link_encoder *dp_get_link_enc(struct dc_link *link);
bool dp_set_dsc_enable(struct pipe_ctx *pipe_ctx, bool enable); bool dp_set_dsc_enable(struct pipe_ctx *pipe_ctx, bool enable);
...@@ -211,8 +214,12 @@ bool dpcd_poll_for_allocation_change_trigger(struct dc_link *link); ...@@ -211,8 +214,12 @@ bool dpcd_poll_for_allocation_change_trigger(struct dc_link *link);
struct fixed31_32 calculate_sst_avg_time_slots_per_mtp( struct fixed31_32 calculate_sst_avg_time_slots_per_mtp(
const struct dc_stream_state *stream, const struct dc_stream_state *stream,
const struct dc_link *link); const struct dc_link *link);
void enable_dp_hpo_output(struct dc_link *link, const struct dc_link_settings *link_settings); void enable_dp_hpo_output(struct dc_link *link,
void disable_dp_hpo_output(struct dc_link *link, enum signal_type signal); const struct link_resource *link_res,
const struct dc_link_settings *link_settings);
void disable_dp_hpo_output(struct dc_link *link,
const struct link_resource *link_res,
enum signal_type signal);
void setup_dp_hpo_stream(struct pipe_ctx *pipe_ctx, bool enable); void setup_dp_hpo_stream(struct pipe_ctx *pipe_ctx, bool enable);
bool is_dp_128b_132b_signal(struct pipe_ctx *pipe_ctx); bool is_dp_128b_132b_signal(struct pipe_ctx *pipe_ctx);
void reset_dp_hpo_stream_encoders_for_link(struct dc_link *link); void reset_dp_hpo_stream_encoders_for_link(struct dc_link *link);
......
...@@ -91,8 +91,9 @@ enum dc_status dpcd_get_tunneling_device_data(struct dc_link *link); ...@@ -91,8 +91,9 @@ enum dc_status dpcd_get_tunneling_device_data(struct dc_link *link);
* DPIA equivalent of dc_link_dp_perfrorm_link_training. * DPIA equivalent of dc_link_dp_perfrorm_link_training.
* Aborts link training upon detection of sink unplug. * Aborts link training upon detection of sink unplug.
*/ */
enum link_training_result enum link_training_result dc_link_dpia_perform_link_training(
dc_link_dpia_perform_link_training(struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
const struct dc_link_settings *link_setting, const struct dc_link_settings *link_setting,
bool skip_video_pattern); bool skip_video_pattern);
......
...@@ -32,6 +32,7 @@ struct gpio *get_hpd_gpio(struct dc_bios *dcb, ...@@ -32,6 +32,7 @@ struct gpio *get_hpd_gpio(struct dc_bios *dcb,
void dp_enable_link_phy( void dp_enable_link_phy(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
enum signal_type signal, enum signal_type signal,
enum clock_source_id clock_source, enum clock_source_id clock_source,
const struct dc_link_settings *link_settings); const struct dc_link_settings *link_settings);
...@@ -42,22 +43,27 @@ void edp_add_delay_for_T9(struct dc_link *link); ...@@ -42,22 +43,27 @@ void edp_add_delay_for_T9(struct dc_link *link);
bool edp_receiver_ready_T9(struct dc_link *link); bool edp_receiver_ready_T9(struct dc_link *link);
bool edp_receiver_ready_T7(struct dc_link *link); bool edp_receiver_ready_T7(struct dc_link *link);
void dp_disable_link_phy(struct dc_link *link, enum signal_type signal); void dp_disable_link_phy(struct dc_link *link, const struct link_resource *link_res,
enum signal_type signal);
void dp_disable_link_phy_mst(struct dc_link *link, enum signal_type signal); void dp_disable_link_phy_mst(struct dc_link *link, const struct link_resource *link_res,
enum signal_type signal);
bool dp_set_hw_training_pattern( bool dp_set_hw_training_pattern(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
enum dc_dp_training_pattern pattern, enum dc_dp_training_pattern pattern,
uint32_t offset); uint32_t offset);
void dp_set_hw_lane_settings( void dp_set_hw_lane_settings(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
const struct link_training_settings *link_settings, const struct link_training_settings *link_settings,
uint32_t offset); uint32_t offset);
void dp_set_hw_test_pattern( void dp_set_hw_test_pattern(
struct dc_link *link, struct dc_link *link,
const struct link_resource *link_res,
enum dp_test_pattern test_pattern, enum dp_test_pattern test_pattern,
uint8_t *custom_pattern, uint8_t *custom_pattern,
uint32_t custom_pattern_size); uint32_t custom_pattern_size);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment