mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-03 23:58:05 +00:00
drm/dp_mst: Convert drm_dp_mst_topology.c to drm_err()/drm_dbg*()
And finally, convert all of the code in drm_dp_mst_topology.c over to using drm_err() and drm_dbg*(). Note that this refactor would have been a lot more complicated to have tried writing a coccinelle script for, so this whole thing was done by hand. v2: * Fix line-wrapping in drm_dp_mst_atomic_check_mstb_bw_limit() Signed-off-by: Lyude Paul <lyude@redhat.com> Cc: Robert Foss <robert.foss@linaro.org> Reviewed-by: Robert Foss <robert.foss@linaro.org> Link: https://patchwork.freedesktop.org/patch/msgid/20210423184309.207645-18-lyude@redhat.com Reviewed-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
parent
a4d00750cd
commit
3a08f53dcf
1 changed files with 187 additions and 181 deletions
|
@ -286,7 +286,8 @@ static void drm_dp_encode_sideband_msg_hdr(struct drm_dp_sideband_msg_hdr *hdr,
|
||||||
*len = idx;
|
*len = idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool drm_dp_decode_sideband_msg_hdr(struct drm_dp_sideband_msg_hdr *hdr,
|
static bool drm_dp_decode_sideband_msg_hdr(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
struct drm_dp_sideband_msg_hdr *hdr,
|
||||||
u8 *buf, int buflen, u8 *hdrlen)
|
u8 *buf, int buflen, u8 *hdrlen)
|
||||||
{
|
{
|
||||||
u8 crc4;
|
u8 crc4;
|
||||||
|
@ -303,7 +304,7 @@ static bool drm_dp_decode_sideband_msg_hdr(struct drm_dp_sideband_msg_hdr *hdr,
|
||||||
crc4 = drm_dp_msg_header_crc4(buf, (len * 2) - 1);
|
crc4 = drm_dp_msg_header_crc4(buf, (len * 2) - 1);
|
||||||
|
|
||||||
if ((crc4 & 0xf) != (buf[len - 1] & 0xf)) {
|
if ((crc4 & 0xf) != (buf[len - 1] & 0xf)) {
|
||||||
DRM_DEBUG_KMS("crc4 mismatch 0x%x 0x%x\n", crc4, buf[len - 1]);
|
drm_dbg_kms(mgr->dev, "crc4 mismatch 0x%x 0x%x\n", crc4, buf[len - 1]);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -789,7 +790,8 @@ static bool drm_dp_sideband_append_payload(struct drm_dp_sideband_msg_rx *msg,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool drm_dp_sideband_parse_link_address(struct drm_dp_sideband_msg_rx *raw,
|
static bool drm_dp_sideband_parse_link_address(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
struct drm_dp_sideband_msg_rx *raw,
|
||||||
struct drm_dp_sideband_msg_reply_body *repmsg)
|
struct drm_dp_sideband_msg_reply_body *repmsg)
|
||||||
{
|
{
|
||||||
int idx = 1;
|
int idx = 1;
|
||||||
|
@ -1014,7 +1016,8 @@ drm_dp_sideband_parse_query_stream_enc_status(
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool drm_dp_sideband_parse_reply(struct drm_dp_sideband_msg_rx *raw,
|
static bool drm_dp_sideband_parse_reply(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
struct drm_dp_sideband_msg_rx *raw,
|
||||||
struct drm_dp_sideband_msg_reply_body *msg)
|
struct drm_dp_sideband_msg_reply_body *msg)
|
||||||
{
|
{
|
||||||
memset(msg, 0, sizeof(*msg));
|
memset(msg, 0, sizeof(*msg));
|
||||||
|
@ -1030,7 +1033,7 @@ static bool drm_dp_sideband_parse_reply(struct drm_dp_sideband_msg_rx *raw,
|
||||||
|
|
||||||
switch (msg->req_type) {
|
switch (msg->req_type) {
|
||||||
case DP_LINK_ADDRESS:
|
case DP_LINK_ADDRESS:
|
||||||
return drm_dp_sideband_parse_link_address(raw, msg);
|
return drm_dp_sideband_parse_link_address(mgr, raw, msg);
|
||||||
case DP_QUERY_PAYLOAD:
|
case DP_QUERY_PAYLOAD:
|
||||||
return drm_dp_sideband_parse_query_payload_ack(raw, msg);
|
return drm_dp_sideband_parse_query_payload_ack(raw, msg);
|
||||||
case DP_REMOTE_DPCD_READ:
|
case DP_REMOTE_DPCD_READ:
|
||||||
|
@ -1053,14 +1056,16 @@ static bool drm_dp_sideband_parse_reply(struct drm_dp_sideband_msg_rx *raw,
|
||||||
case DP_QUERY_STREAM_ENC_STATUS:
|
case DP_QUERY_STREAM_ENC_STATUS:
|
||||||
return drm_dp_sideband_parse_query_stream_enc_status(raw, msg);
|
return drm_dp_sideband_parse_query_stream_enc_status(raw, msg);
|
||||||
default:
|
default:
|
||||||
DRM_ERROR("Got unknown reply 0x%02x (%s)\n", msg->req_type,
|
drm_err(mgr->dev, "Got unknown reply 0x%02x (%s)\n",
|
||||||
drm_dp_mst_req_type_str(msg->req_type));
|
msg->req_type, drm_dp_mst_req_type_str(msg->req_type));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool drm_dp_sideband_parse_connection_status_notify(struct drm_dp_sideband_msg_rx *raw,
|
static bool
|
||||||
struct drm_dp_sideband_msg_req_body *msg)
|
drm_dp_sideband_parse_connection_status_notify(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
struct drm_dp_sideband_msg_rx *raw,
|
||||||
|
struct drm_dp_sideband_msg_req_body *msg)
|
||||||
{
|
{
|
||||||
int idx = 1;
|
int idx = 1;
|
||||||
|
|
||||||
|
@ -1082,12 +1087,14 @@ static bool drm_dp_sideband_parse_connection_status_notify(struct drm_dp_sideban
|
||||||
idx++;
|
idx++;
|
||||||
return true;
|
return true;
|
||||||
fail_len:
|
fail_len:
|
||||||
DRM_DEBUG_KMS("connection status reply parse length fail %d %d\n", idx, raw->curlen);
|
drm_dbg_kms(mgr->dev, "connection status reply parse length fail %d %d\n",
|
||||||
|
idx, raw->curlen);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool drm_dp_sideband_parse_resource_status_notify(struct drm_dp_sideband_msg_rx *raw,
|
static bool drm_dp_sideband_parse_resource_status_notify(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
struct drm_dp_sideband_msg_req_body *msg)
|
struct drm_dp_sideband_msg_rx *raw,
|
||||||
|
struct drm_dp_sideband_msg_req_body *msg)
|
||||||
{
|
{
|
||||||
int idx = 1;
|
int idx = 1;
|
||||||
|
|
||||||
|
@ -1105,11 +1112,12 @@ static bool drm_dp_sideband_parse_resource_status_notify(struct drm_dp_sideband_
|
||||||
idx++;
|
idx++;
|
||||||
return true;
|
return true;
|
||||||
fail_len:
|
fail_len:
|
||||||
DRM_DEBUG_KMS("resource status reply parse length fail %d %d\n", idx, raw->curlen);
|
drm_dbg_kms(mgr->dev, "resource status reply parse length fail %d %d\n", idx, raw->curlen);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool drm_dp_sideband_parse_req(struct drm_dp_sideband_msg_rx *raw,
|
static bool drm_dp_sideband_parse_req(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
struct drm_dp_sideband_msg_rx *raw,
|
||||||
struct drm_dp_sideband_msg_req_body *msg)
|
struct drm_dp_sideband_msg_req_body *msg)
|
||||||
{
|
{
|
||||||
memset(msg, 0, sizeof(*msg));
|
memset(msg, 0, sizeof(*msg));
|
||||||
|
@ -1117,12 +1125,12 @@ static bool drm_dp_sideband_parse_req(struct drm_dp_sideband_msg_rx *raw,
|
||||||
|
|
||||||
switch (msg->req_type) {
|
switch (msg->req_type) {
|
||||||
case DP_CONNECTION_STATUS_NOTIFY:
|
case DP_CONNECTION_STATUS_NOTIFY:
|
||||||
return drm_dp_sideband_parse_connection_status_notify(raw, msg);
|
return drm_dp_sideband_parse_connection_status_notify(mgr, raw, msg);
|
||||||
case DP_RESOURCE_STATUS_NOTIFY:
|
case DP_RESOURCE_STATUS_NOTIFY:
|
||||||
return drm_dp_sideband_parse_resource_status_notify(raw, msg);
|
return drm_dp_sideband_parse_resource_status_notify(mgr, raw, msg);
|
||||||
default:
|
default:
|
||||||
DRM_ERROR("Got unknown request 0x%02x (%s)\n", msg->req_type,
|
drm_err(mgr->dev, "Got unknown request 0x%02x (%s)\n",
|
||||||
drm_dp_mst_req_type_str(msg->req_type));
|
msg->req_type, drm_dp_mst_req_type_str(msg->req_type));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1232,14 +1240,14 @@ static int drm_dp_mst_assign_payload_id(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
ret = find_first_zero_bit(&mgr->payload_mask, mgr->max_payloads + 1);
|
ret = find_first_zero_bit(&mgr->payload_mask, mgr->max_payloads + 1);
|
||||||
if (ret > mgr->max_payloads) {
|
if (ret > mgr->max_payloads) {
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
DRM_DEBUG_KMS("out of payload ids %d\n", ret);
|
drm_dbg_kms(mgr->dev, "out of payload ids %d\n", ret);
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
vcpi_ret = find_first_zero_bit(&mgr->vcpi_mask, mgr->max_payloads + 1);
|
vcpi_ret = find_first_zero_bit(&mgr->vcpi_mask, mgr->max_payloads + 1);
|
||||||
if (vcpi_ret > mgr->max_payloads) {
|
if (vcpi_ret > mgr->max_payloads) {
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
DRM_DEBUG_KMS("out of vcpi ids %d\n", ret);
|
drm_dbg_kms(mgr->dev, "out of vcpi ids %d\n", ret);
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1261,7 +1269,7 @@ static void drm_dp_mst_put_payload_id(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
return;
|
return;
|
||||||
|
|
||||||
mutex_lock(&mgr->payload_lock);
|
mutex_lock(&mgr->payload_lock);
|
||||||
DRM_DEBUG_KMS("putting payload %d\n", vcpi);
|
drm_dbg_kms(mgr->dev, "putting payload %d\n", vcpi);
|
||||||
clear_bit(vcpi - 1, &mgr->vcpi_mask);
|
clear_bit(vcpi - 1, &mgr->vcpi_mask);
|
||||||
|
|
||||||
for (i = 0; i < mgr->max_payloads; i++) {
|
for (i = 0; i < mgr->max_payloads; i++) {
|
||||||
|
@ -1331,7 +1339,8 @@ static int drm_dp_mst_wait_tx_reply(struct drm_dp_mst_branch *mstb,
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
DRM_DEBUG_KMS("timedout msg send %p %d %d\n", txmsg, txmsg->state, txmsg->seqno);
|
drm_dbg_kms(mgr->dev, "timedout msg send %p %d %d\n",
|
||||||
|
txmsg, txmsg->state, txmsg->seqno);
|
||||||
|
|
||||||
/* dump some state */
|
/* dump some state */
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
|
@ -1485,7 +1494,7 @@ static void
|
||||||
drm_dp_mst_get_mstb_malloc(struct drm_dp_mst_branch *mstb)
|
drm_dp_mst_get_mstb_malloc(struct drm_dp_mst_branch *mstb)
|
||||||
{
|
{
|
||||||
kref_get(&mstb->malloc_kref);
|
kref_get(&mstb->malloc_kref);
|
||||||
DRM_DEBUG("mstb %p (%d)\n", mstb, kref_read(&mstb->malloc_kref));
|
drm_dbg(mstb->mgr->dev, "mstb %p (%d)\n", mstb, kref_read(&mstb->malloc_kref));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1502,7 +1511,7 @@ drm_dp_mst_get_mstb_malloc(struct drm_dp_mst_branch *mstb)
|
||||||
static void
|
static void
|
||||||
drm_dp_mst_put_mstb_malloc(struct drm_dp_mst_branch *mstb)
|
drm_dp_mst_put_mstb_malloc(struct drm_dp_mst_branch *mstb)
|
||||||
{
|
{
|
||||||
DRM_DEBUG("mstb %p (%d)\n", mstb, kref_read(&mstb->malloc_kref) - 1);
|
drm_dbg(mstb->mgr->dev, "mstb %p (%d)\n", mstb, kref_read(&mstb->malloc_kref) - 1);
|
||||||
kref_put(&mstb->malloc_kref, drm_dp_free_mst_branch_device);
|
kref_put(&mstb->malloc_kref, drm_dp_free_mst_branch_device);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1536,7 +1545,7 @@ void
|
||||||
drm_dp_mst_get_port_malloc(struct drm_dp_mst_port *port)
|
drm_dp_mst_get_port_malloc(struct drm_dp_mst_port *port)
|
||||||
{
|
{
|
||||||
kref_get(&port->malloc_kref);
|
kref_get(&port->malloc_kref);
|
||||||
DRM_DEBUG("port %p (%d)\n", port, kref_read(&port->malloc_kref));
|
drm_dbg(port->mgr->dev, "port %p (%d)\n", port, kref_read(&port->malloc_kref));
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_dp_mst_get_port_malloc);
|
EXPORT_SYMBOL(drm_dp_mst_get_port_malloc);
|
||||||
|
|
||||||
|
@ -1553,7 +1562,7 @@ EXPORT_SYMBOL(drm_dp_mst_get_port_malloc);
|
||||||
void
|
void
|
||||||
drm_dp_mst_put_port_malloc(struct drm_dp_mst_port *port)
|
drm_dp_mst_put_port_malloc(struct drm_dp_mst_port *port)
|
||||||
{
|
{
|
||||||
DRM_DEBUG("port %p (%d)\n", port, kref_read(&port->malloc_kref) - 1);
|
drm_dbg(port->mgr->dev, "port %p (%d)\n", port, kref_read(&port->malloc_kref) - 1);
|
||||||
kref_put(&port->malloc_kref, drm_dp_free_mst_port);
|
kref_put(&port->malloc_kref, drm_dp_free_mst_port);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_dp_mst_put_port_malloc);
|
EXPORT_SYMBOL(drm_dp_mst_put_port_malloc);
|
||||||
|
@ -1778,8 +1787,7 @@ drm_dp_mst_topology_try_get_mstb(struct drm_dp_mst_branch *mstb)
|
||||||
topology_ref_history_lock(mstb->mgr);
|
topology_ref_history_lock(mstb->mgr);
|
||||||
ret = kref_get_unless_zero(&mstb->topology_kref);
|
ret = kref_get_unless_zero(&mstb->topology_kref);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DRM_DEBUG("mstb %p (%d)\n",
|
drm_dbg(mstb->mgr->dev, "mstb %p (%d)\n", mstb, kref_read(&mstb->topology_kref));
|
||||||
mstb, kref_read(&mstb->topology_kref));
|
|
||||||
save_mstb_topology_ref(mstb, DRM_DP_MST_TOPOLOGY_REF_GET);
|
save_mstb_topology_ref(mstb, DRM_DP_MST_TOPOLOGY_REF_GET);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1809,7 +1817,7 @@ static void drm_dp_mst_topology_get_mstb(struct drm_dp_mst_branch *mstb)
|
||||||
save_mstb_topology_ref(mstb, DRM_DP_MST_TOPOLOGY_REF_GET);
|
save_mstb_topology_ref(mstb, DRM_DP_MST_TOPOLOGY_REF_GET);
|
||||||
WARN_ON(kref_read(&mstb->topology_kref) == 0);
|
WARN_ON(kref_read(&mstb->topology_kref) == 0);
|
||||||
kref_get(&mstb->topology_kref);
|
kref_get(&mstb->topology_kref);
|
||||||
DRM_DEBUG("mstb %p (%d)\n", mstb, kref_read(&mstb->topology_kref));
|
drm_dbg(mstb->mgr->dev, "mstb %p (%d)\n", mstb, kref_read(&mstb->topology_kref));
|
||||||
|
|
||||||
topology_ref_history_unlock(mstb->mgr);
|
topology_ref_history_unlock(mstb->mgr);
|
||||||
}
|
}
|
||||||
|
@ -1831,8 +1839,7 @@ drm_dp_mst_topology_put_mstb(struct drm_dp_mst_branch *mstb)
|
||||||
{
|
{
|
||||||
topology_ref_history_lock(mstb->mgr);
|
topology_ref_history_lock(mstb->mgr);
|
||||||
|
|
||||||
DRM_DEBUG("mstb %p (%d)\n",
|
drm_dbg(mstb->mgr->dev, "mstb %p (%d)\n", mstb, kref_read(&mstb->topology_kref) - 1);
|
||||||
mstb, kref_read(&mstb->topology_kref) - 1);
|
|
||||||
save_mstb_topology_ref(mstb, DRM_DP_MST_TOPOLOGY_REF_PUT);
|
save_mstb_topology_ref(mstb, DRM_DP_MST_TOPOLOGY_REF_PUT);
|
||||||
|
|
||||||
topology_ref_history_unlock(mstb->mgr);
|
topology_ref_history_unlock(mstb->mgr);
|
||||||
|
@ -1895,8 +1902,7 @@ drm_dp_mst_topology_try_get_port(struct drm_dp_mst_port *port)
|
||||||
topology_ref_history_lock(port->mgr);
|
topology_ref_history_lock(port->mgr);
|
||||||
ret = kref_get_unless_zero(&port->topology_kref);
|
ret = kref_get_unless_zero(&port->topology_kref);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DRM_DEBUG("port %p (%d)\n",
|
drm_dbg(port->mgr->dev, "port %p (%d)\n", port, kref_read(&port->topology_kref));
|
||||||
port, kref_read(&port->topology_kref));
|
|
||||||
save_port_topology_ref(port, DRM_DP_MST_TOPOLOGY_REF_GET);
|
save_port_topology_ref(port, DRM_DP_MST_TOPOLOGY_REF_GET);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1923,7 +1929,7 @@ static void drm_dp_mst_topology_get_port(struct drm_dp_mst_port *port)
|
||||||
|
|
||||||
WARN_ON(kref_read(&port->topology_kref) == 0);
|
WARN_ON(kref_read(&port->topology_kref) == 0);
|
||||||
kref_get(&port->topology_kref);
|
kref_get(&port->topology_kref);
|
||||||
DRM_DEBUG("port %p (%d)\n", port, kref_read(&port->topology_kref));
|
drm_dbg(port->mgr->dev, "port %p (%d)\n", port, kref_read(&port->topology_kref));
|
||||||
save_port_topology_ref(port, DRM_DP_MST_TOPOLOGY_REF_GET);
|
save_port_topology_ref(port, DRM_DP_MST_TOPOLOGY_REF_GET);
|
||||||
|
|
||||||
topology_ref_history_unlock(port->mgr);
|
topology_ref_history_unlock(port->mgr);
|
||||||
|
@ -1944,8 +1950,7 @@ static void drm_dp_mst_topology_put_port(struct drm_dp_mst_port *port)
|
||||||
{
|
{
|
||||||
topology_ref_history_lock(port->mgr);
|
topology_ref_history_lock(port->mgr);
|
||||||
|
|
||||||
DRM_DEBUG("port %p (%d)\n",
|
drm_dbg(port->mgr->dev, "port %p (%d)\n", port, kref_read(&port->topology_kref) - 1);
|
||||||
port, kref_read(&port->topology_kref) - 1);
|
|
||||||
save_port_topology_ref(port, DRM_DP_MST_TOPOLOGY_REF_PUT);
|
save_port_topology_ref(port, DRM_DP_MST_TOPOLOGY_REF_PUT);
|
||||||
|
|
||||||
topology_ref_history_unlock(port->mgr);
|
topology_ref_history_unlock(port->mgr);
|
||||||
|
@ -2130,8 +2135,7 @@ drm_dp_port_set_pdt(struct drm_dp_mst_port *port, u8 new_pdt,
|
||||||
mstb = drm_dp_add_mst_branch_device(lct, rad);
|
mstb = drm_dp_add_mst_branch_device(lct, rad);
|
||||||
if (!mstb) {
|
if (!mstb) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
DRM_ERROR("Failed to create MSTB for port %p",
|
drm_err(mgr->dev, "Failed to create MSTB for port %p", port);
|
||||||
port);
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2261,8 +2265,8 @@ static void build_mst_prop_path(const struct drm_dp_mst_branch *mstb,
|
||||||
int drm_dp_mst_connector_late_register(struct drm_connector *connector,
|
int drm_dp_mst_connector_late_register(struct drm_connector *connector,
|
||||||
struct drm_dp_mst_port *port)
|
struct drm_dp_mst_port *port)
|
||||||
{
|
{
|
||||||
DRM_DEBUG_KMS("registering %s remote bus for %s\n",
|
drm_dbg_kms(port->mgr->dev, "registering %s remote bus for %s\n",
|
||||||
port->aux.name, connector->kdev->kobj.name);
|
port->aux.name, connector->kdev->kobj.name);
|
||||||
|
|
||||||
port->aux.dev = connector->kdev;
|
port->aux.dev = connector->kdev;
|
||||||
return drm_dp_aux_register_devnode(&port->aux);
|
return drm_dp_aux_register_devnode(&port->aux);
|
||||||
|
@ -2281,8 +2285,8 @@ EXPORT_SYMBOL(drm_dp_mst_connector_late_register);
|
||||||
void drm_dp_mst_connector_early_unregister(struct drm_connector *connector,
|
void drm_dp_mst_connector_early_unregister(struct drm_connector *connector,
|
||||||
struct drm_dp_mst_port *port)
|
struct drm_dp_mst_port *port)
|
||||||
{
|
{
|
||||||
DRM_DEBUG_KMS("unregistering %s remote bus for %s\n",
|
drm_dbg_kms(port->mgr->dev, "unregistering %s remote bus for %s\n",
|
||||||
port->aux.name, connector->kdev->kobj.name);
|
port->aux.name, connector->kdev->kobj.name);
|
||||||
drm_dp_aux_unregister_devnode(&port->aux);
|
drm_dp_aux_unregister_devnode(&port->aux);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_dp_mst_connector_early_unregister);
|
EXPORT_SYMBOL(drm_dp_mst_connector_early_unregister);
|
||||||
|
@ -2312,7 +2316,7 @@ drm_dp_mst_port_add_connector(struct drm_dp_mst_branch *mstb,
|
||||||
return;
|
return;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
DRM_ERROR("Failed to create connector for port %p: %d\n", port, ret);
|
drm_err(mgr->dev, "Failed to create connector for port %p: %d\n", port, ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -2452,8 +2456,7 @@ drm_dp_mst_handle_link_address_port(struct drm_dp_mst_branch *mstb,
|
||||||
if (ret == 1) {
|
if (ret == 1) {
|
||||||
send_link_addr = true;
|
send_link_addr = true;
|
||||||
} else if (ret < 0) {
|
} else if (ret < 0) {
|
||||||
DRM_ERROR("Failed to change PDT on port %p: %d\n",
|
drm_err(dev, "Failed to change PDT on port %p: %d\n", port, ret);
|
||||||
port, ret);
|
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2548,8 +2551,7 @@ drm_dp_mst_handle_conn_stat(struct drm_dp_mst_branch *mstb,
|
||||||
if (ret == 1) {
|
if (ret == 1) {
|
||||||
dowork = true;
|
dowork = true;
|
||||||
} else if (ret < 0) {
|
} else if (ret < 0) {
|
||||||
DRM_ERROR("Failed to change PDT for port %p: %d\n",
|
drm_err(mgr->dev, "Failed to change PDT for port %p: %d\n", port, ret);
|
||||||
port, ret);
|
|
||||||
dowork = false;
|
dowork = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2608,7 +2610,9 @@ static struct drm_dp_mst_branch *drm_dp_get_mst_branch_device(struct drm_dp_mst_
|
||||||
if (port->port_num == port_num) {
|
if (port->port_num == port_num) {
|
||||||
mstb = port->mstb;
|
mstb = port->mstb;
|
||||||
if (!mstb) {
|
if (!mstb) {
|
||||||
DRM_ERROR("failed to lookup MSTB with lct %d, rad %02x\n", lct, rad[0]);
|
drm_err(mgr->dev,
|
||||||
|
"failed to lookup MSTB with lct %d, rad %02x\n",
|
||||||
|
lct, rad[0]);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2744,7 +2748,7 @@ static void drm_dp_mst_link_probe_work(struct work_struct *work)
|
||||||
* things work again.
|
* things work again.
|
||||||
*/
|
*/
|
||||||
if (clear_payload_id_table) {
|
if (clear_payload_id_table) {
|
||||||
DRM_DEBUG_KMS("Clearing payload ID table\n");
|
drm_dbg_kms(dev, "Clearing payload ID table\n");
|
||||||
drm_dp_send_clear_payload_id_table(mgr, mstb);
|
drm_dp_send_clear_payload_id_table(mgr, mstb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2806,7 +2810,7 @@ static int drm_dp_send_sideband_msg(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
retries++;
|
retries++;
|
||||||
goto retry;
|
goto retry;
|
||||||
}
|
}
|
||||||
DRM_DEBUG_KMS("failed to dpcd write %d %d\n", tosend, ret);
|
drm_dbg_kms(mgr->dev, "failed to dpcd write %d %d\n", tosend, ret);
|
||||||
|
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
@ -2919,7 +2923,7 @@ static void process_single_down_tx_qlock(struct drm_dp_mst_topology_mgr *mgr)
|
||||||
struct drm_dp_sideband_msg_tx, next);
|
struct drm_dp_sideband_msg_tx, next);
|
||||||
ret = process_single_tx_qlock(mgr, txmsg, false);
|
ret = process_single_tx_qlock(mgr, txmsg, false);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
DRM_DEBUG_KMS("failed to send msg in q %d\n", ret);
|
drm_dbg_kms(mgr->dev, "failed to send msg in q %d\n", ret);
|
||||||
list_del(&txmsg->next);
|
list_del(&txmsg->next);
|
||||||
txmsg->state = DRM_DP_SIDEBAND_TX_TIMEOUT;
|
txmsg->state = DRM_DP_SIDEBAND_TX_TIMEOUT;
|
||||||
wake_up_all(&mgr->tx_waitq);
|
wake_up_all(&mgr->tx_waitq);
|
||||||
|
@ -2944,24 +2948,26 @@ static void drm_dp_queue_down_tx(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
drm_dp_dump_link_address(struct drm_dp_link_address_ack_reply *reply)
|
drm_dp_dump_link_address(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
struct drm_dp_link_address_ack_reply *reply)
|
||||||
{
|
{
|
||||||
struct drm_dp_link_addr_reply_port *port_reply;
|
struct drm_dp_link_addr_reply_port *port_reply;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < reply->nports; i++) {
|
for (i = 0; i < reply->nports; i++) {
|
||||||
port_reply = &reply->ports[i];
|
port_reply = &reply->ports[i];
|
||||||
DRM_DEBUG_KMS("port %d: input %d, pdt: %d, pn: %d, dpcd_rev: %02x, mcs: %d, ddps: %d, ldps %d, sdp %d/%d\n",
|
drm_dbg_kms(mgr->dev,
|
||||||
i,
|
"port %d: input %d, pdt: %d, pn: %d, dpcd_rev: %02x, mcs: %d, ddps: %d, ldps %d, sdp %d/%d\n",
|
||||||
port_reply->input_port,
|
i,
|
||||||
port_reply->peer_device_type,
|
port_reply->input_port,
|
||||||
port_reply->port_number,
|
port_reply->peer_device_type,
|
||||||
port_reply->dpcd_revision,
|
port_reply->port_number,
|
||||||
port_reply->mcs,
|
port_reply->dpcd_revision,
|
||||||
port_reply->ddps,
|
port_reply->mcs,
|
||||||
port_reply->legacy_device_plug_status,
|
port_reply->ddps,
|
||||||
port_reply->num_sdp_streams,
|
port_reply->legacy_device_plug_status,
|
||||||
port_reply->num_sdp_stream_sinks);
|
port_reply->num_sdp_streams,
|
||||||
|
port_reply->num_sdp_stream_sinks);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2987,26 +2993,25 @@ static int drm_dp_send_link_address(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
/* FIXME: Actually do some real error handling here */
|
/* FIXME: Actually do some real error handling here */
|
||||||
ret = drm_dp_mst_wait_tx_reply(mstb, txmsg);
|
ret = drm_dp_mst_wait_tx_reply(mstb, txmsg);
|
||||||
if (ret <= 0) {
|
if (ret <= 0) {
|
||||||
DRM_ERROR("Sending link address failed with %d\n", ret);
|
drm_err(mgr->dev, "Sending link address failed with %d\n", ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
if (txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK) {
|
if (txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK) {
|
||||||
DRM_ERROR("link address NAK received\n");
|
drm_err(mgr->dev, "link address NAK received\n");
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
reply = &txmsg->reply.u.link_addr;
|
reply = &txmsg->reply.u.link_addr;
|
||||||
DRM_DEBUG_KMS("link address reply: %d\n", reply->nports);
|
drm_dbg_kms(mgr->dev, "link address reply: %d\n", reply->nports);
|
||||||
drm_dp_dump_link_address(reply);
|
drm_dp_dump_link_address(mgr, reply);
|
||||||
|
|
||||||
ret = drm_dp_check_mstb_guid(mstb, reply->guid);
|
ret = drm_dp_check_mstb_guid(mstb, reply->guid);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
char buf[64];
|
char buf[64];
|
||||||
|
|
||||||
drm_dp_mst_rad_to_str(mstb->rad, mstb->lct, buf, sizeof(buf));
|
drm_dp_mst_rad_to_str(mstb->rad, mstb->lct, buf, sizeof(buf));
|
||||||
DRM_ERROR("GUID check on %s failed: %d\n",
|
drm_err(mgr->dev, "GUID check on %s failed: %d\n", buf, ret);
|
||||||
buf, ret);
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3030,8 +3035,8 @@ static int drm_dp_send_link_address(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
if (port_mask & BIT(port->port_num))
|
if (port_mask & BIT(port->port_num))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
DRM_DEBUG_KMS("port %d was not in link address, removing\n",
|
drm_dbg_kms(mgr->dev, "port %d was not in link address, removing\n",
|
||||||
port->port_num);
|
port->port_num);
|
||||||
list_del(&port->next);
|
list_del(&port->next);
|
||||||
drm_dp_mst_topology_put_port(port);
|
drm_dp_mst_topology_put_port(port);
|
||||||
changed = true;
|
changed = true;
|
||||||
|
@ -3063,7 +3068,7 @@ drm_dp_send_clear_payload_id_table(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
|
||||||
ret = drm_dp_mst_wait_tx_reply(mstb, txmsg);
|
ret = drm_dp_mst_wait_tx_reply(mstb, txmsg);
|
||||||
if (ret > 0 && txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK)
|
if (ret > 0 && txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK)
|
||||||
DRM_DEBUG_KMS("clear payload table id nak received\n");
|
drm_dbg_kms(mgr->dev, "clear payload table id nak received\n");
|
||||||
|
|
||||||
kfree(txmsg);
|
kfree(txmsg);
|
||||||
}
|
}
|
||||||
|
@ -3092,15 +3097,15 @@ drm_dp_send_enum_path_resources(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
path_res = &txmsg->reply.u.path_resources;
|
path_res = &txmsg->reply.u.path_resources;
|
||||||
|
|
||||||
if (txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK) {
|
if (txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK) {
|
||||||
DRM_DEBUG_KMS("enum path resources nak received\n");
|
drm_dbg_kms(mgr->dev, "enum path resources nak received\n");
|
||||||
} else {
|
} else {
|
||||||
if (port->port_num != path_res->port_number)
|
if (port->port_num != path_res->port_number)
|
||||||
DRM_ERROR("got incorrect port in response\n");
|
DRM_ERROR("got incorrect port in response\n");
|
||||||
|
|
||||||
DRM_DEBUG_KMS("enum path resources %d: %d %d\n",
|
drm_dbg_kms(mgr->dev, "enum path resources %d: %d %d\n",
|
||||||
path_res->port_number,
|
path_res->port_number,
|
||||||
path_res->full_payload_bw_number,
|
path_res->full_payload_bw_number,
|
||||||
path_res->avail_payload_bw_number);
|
path_res->avail_payload_bw_number);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If something changed, make sure we send a
|
* If something changed, make sure we send a
|
||||||
|
@ -3346,7 +3351,7 @@ static int drm_dp_destroy_payload_step1(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
int id,
|
int id,
|
||||||
struct drm_dp_payload *payload)
|
struct drm_dp_payload *payload)
|
||||||
{
|
{
|
||||||
DRM_DEBUG_KMS("\n");
|
drm_dbg_kms(mgr->dev, "\n");
|
||||||
/* it's okay for these to fail */
|
/* it's okay for these to fail */
|
||||||
if (port) {
|
if (port) {
|
||||||
drm_dp_payload_send_msg(mgr, port, id, 0);
|
drm_dp_payload_send_msg(mgr, port, id, 0);
|
||||||
|
@ -3452,7 +3457,7 @@ int drm_dp_update_payload_part1(struct drm_dp_mst_topology_mgr *mgr)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
DRM_DEBUG_KMS("removing payload %d\n", i);
|
drm_dbg_kms(mgr->dev, "removing payload %d\n", i);
|
||||||
for (j = i; j < mgr->max_payloads - 1; j++) {
|
for (j = i; j < mgr->max_payloads - 1; j++) {
|
||||||
mgr->payloads[j] = mgr->payloads[j + 1];
|
mgr->payloads[j] = mgr->payloads[j + 1];
|
||||||
mgr->proposed_vcpis[j] = mgr->proposed_vcpis[j + 1];
|
mgr->proposed_vcpis[j] = mgr->proposed_vcpis[j + 1];
|
||||||
|
@ -3499,7 +3504,7 @@ int drm_dp_update_payload_part2(struct drm_dp_mst_topology_mgr *mgr)
|
||||||
|
|
||||||
port = container_of(mgr->proposed_vcpis[i], struct drm_dp_mst_port, vcpi);
|
port = container_of(mgr->proposed_vcpis[i], struct drm_dp_mst_port, vcpi);
|
||||||
|
|
||||||
DRM_DEBUG_KMS("payload %d %d\n", i, mgr->payloads[i].payload_state);
|
drm_dbg_kms(mgr->dev, "payload %d %d\n", i, mgr->payloads[i].payload_state);
|
||||||
if (mgr->payloads[i].payload_state == DP_PAYLOAD_LOCAL) {
|
if (mgr->payloads[i].payload_state == DP_PAYLOAD_LOCAL) {
|
||||||
ret = drm_dp_create_payload_step2(mgr, port, mgr->proposed_vcpis[i]->vcpi, &mgr->payloads[i]);
|
ret = drm_dp_create_payload_step2(mgr, port, mgr->proposed_vcpis[i]->vcpi, &mgr->payloads[i]);
|
||||||
} else if (mgr->payloads[i].payload_state == DP_PAYLOAD_DELETE_LOCAL) {
|
} else if (mgr->payloads[i].payload_state == DP_PAYLOAD_DELETE_LOCAL) {
|
||||||
|
@ -3544,8 +3549,8 @@ static int drm_dp_send_dpcd_read(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
|
||||||
/* DPCD read should never be NACKed */
|
/* DPCD read should never be NACKed */
|
||||||
if (txmsg->reply.reply_type == 1) {
|
if (txmsg->reply.reply_type == 1) {
|
||||||
DRM_ERROR("mstb %p port %d: DPCD read on addr 0x%x for %d bytes NAKed\n",
|
drm_err(mgr->dev, "mstb %p port %d: DPCD read on addr 0x%x for %d bytes NAKed\n",
|
||||||
mstb, port->port_num, offset, size);
|
mstb, port->port_num, offset, size);
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
goto fail_free;
|
goto fail_free;
|
||||||
}
|
}
|
||||||
|
@ -3651,8 +3656,8 @@ int drm_dp_get_vc_payload_bw(const struct drm_dp_mst_topology_mgr *mgr,
|
||||||
int link_rate, int link_lane_count)
|
int link_rate, int link_lane_count)
|
||||||
{
|
{
|
||||||
if (link_rate == 0 || link_lane_count == 0)
|
if (link_rate == 0 || link_lane_count == 0)
|
||||||
DRM_DEBUG_KMS("invalid link rate/lane count: (%d / %d)\n",
|
drm_dbg_kms(mgr->dev, "invalid link rate/lane count: (%d / %d)\n",
|
||||||
link_rate, link_lane_count);
|
link_rate, link_lane_count);
|
||||||
|
|
||||||
/* See DP v2.0 2.6.4.2, VCPayload_Bandwidth_for_OneTimeSlotPer_MTP_Allocation */
|
/* See DP v2.0 2.6.4.2, VCPayload_Bandwidth_for_OneTimeSlotPer_MTP_Allocation */
|
||||||
return link_rate * link_lane_count / 54000;
|
return link_rate * link_lane_count / 54000;
|
||||||
|
@ -3709,7 +3714,7 @@ int drm_dp_mst_topology_mgr_set_mst(struct drm_dp_mst_topology_mgr *mgr, bool ms
|
||||||
/* get dpcd info */
|
/* get dpcd info */
|
||||||
ret = drm_dp_dpcd_read(mgr->aux, DP_DPCD_REV, mgr->dpcd, DP_RECEIVER_CAP_SIZE);
|
ret = drm_dp_dpcd_read(mgr->aux, DP_DPCD_REV, mgr->dpcd, DP_RECEIVER_CAP_SIZE);
|
||||||
if (ret != DP_RECEIVER_CAP_SIZE) {
|
if (ret != DP_RECEIVER_CAP_SIZE) {
|
||||||
DRM_DEBUG_KMS("failed to read DPCD\n");
|
drm_dbg_kms(mgr->dev, "failed to read DPCD\n");
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3844,7 +3849,7 @@ int drm_dp_mst_topology_mgr_resume(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
ret = drm_dp_dpcd_read(mgr->aux, DP_DPCD_REV, mgr->dpcd,
|
ret = drm_dp_dpcd_read(mgr->aux, DP_DPCD_REV, mgr->dpcd,
|
||||||
DP_RECEIVER_CAP_SIZE);
|
DP_RECEIVER_CAP_SIZE);
|
||||||
if (ret != DP_RECEIVER_CAP_SIZE) {
|
if (ret != DP_RECEIVER_CAP_SIZE) {
|
||||||
DRM_DEBUG_KMS("dpcd read failed - undocked during suspend?\n");
|
drm_dbg_kms(mgr->dev, "dpcd read failed - undocked during suspend?\n");
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3853,20 +3858,20 @@ int drm_dp_mst_topology_mgr_resume(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
DP_UP_REQ_EN |
|
DP_UP_REQ_EN |
|
||||||
DP_UPSTREAM_IS_SRC);
|
DP_UPSTREAM_IS_SRC);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
DRM_DEBUG_KMS("mst write failed - undocked during suspend?\n");
|
drm_dbg_kms(mgr->dev, "mst write failed - undocked during suspend?\n");
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Some hubs forget their guids after they resume */
|
/* Some hubs forget their guids after they resume */
|
||||||
ret = drm_dp_dpcd_read(mgr->aux, DP_GUID, guid, 16);
|
ret = drm_dp_dpcd_read(mgr->aux, DP_GUID, guid, 16);
|
||||||
if (ret != 16) {
|
if (ret != 16) {
|
||||||
DRM_DEBUG_KMS("dpcd read failed - undocked during suspend?\n");
|
drm_dbg_kms(mgr->dev, "dpcd read failed - undocked during suspend?\n");
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = drm_dp_check_mstb_guid(mgr->mst_primary, guid);
|
ret = drm_dp_check_mstb_guid(mgr->mst_primary, guid);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DRM_DEBUG_KMS("check mstb failed - undocked during suspend?\n");
|
drm_dbg_kms(mgr->dev, "check mstb failed - undocked during suspend?\n");
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3879,7 +3884,8 @@ int drm_dp_mst_topology_mgr_resume(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
mutex_unlock(&mgr->lock);
|
mutex_unlock(&mgr->lock);
|
||||||
|
|
||||||
if (sync) {
|
if (sync) {
|
||||||
DRM_DEBUG_KMS("Waiting for link probe work to finish re-syncing topology...\n");
|
drm_dbg_kms(mgr->dev,
|
||||||
|
"Waiting for link probe work to finish re-syncing topology...\n");
|
||||||
flush_work(&mgr->work);
|
flush_work(&mgr->work);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3912,15 +3918,15 @@ drm_dp_get_one_sb_msg(struct drm_dp_mst_topology_mgr *mgr, bool up,
|
||||||
len = min(mgr->max_dpcd_transaction_bytes, 16);
|
len = min(mgr->max_dpcd_transaction_bytes, 16);
|
||||||
ret = drm_dp_dpcd_read(mgr->aux, basereg, replyblock, len);
|
ret = drm_dp_dpcd_read(mgr->aux, basereg, replyblock, len);
|
||||||
if (ret != len) {
|
if (ret != len) {
|
||||||
DRM_DEBUG_KMS("failed to read DPCD down rep %d %d\n", len, ret);
|
drm_dbg_kms(mgr->dev, "failed to read DPCD down rep %d %d\n", len, ret);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = drm_dp_decode_sideband_msg_hdr(&hdr, replyblock, len, &hdrlen);
|
ret = drm_dp_decode_sideband_msg_hdr(mgr, &hdr, replyblock, len, &hdrlen);
|
||||||
if (ret == false) {
|
if (ret == false) {
|
||||||
print_hex_dump(KERN_DEBUG, "failed hdr", DUMP_PREFIX_NONE, 16,
|
print_hex_dump(KERN_DEBUG, "failed hdr", DUMP_PREFIX_NONE, 16,
|
||||||
1, replyblock, len, false);
|
1, replyblock, len, false);
|
||||||
DRM_DEBUG_KMS("ERROR: failed header\n");
|
drm_dbg_kms(mgr->dev, "ERROR: failed header\n");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3928,22 +3934,20 @@ drm_dp_get_one_sb_msg(struct drm_dp_mst_topology_mgr *mgr, bool up,
|
||||||
/* Caller is responsible for giving back this reference */
|
/* Caller is responsible for giving back this reference */
|
||||||
*mstb = drm_dp_get_mst_branch_device(mgr, hdr.lct, hdr.rad);
|
*mstb = drm_dp_get_mst_branch_device(mgr, hdr.lct, hdr.rad);
|
||||||
if (!*mstb) {
|
if (!*mstb) {
|
||||||
DRM_DEBUG_KMS("Got MST reply from unknown device %d\n",
|
drm_dbg_kms(mgr->dev, "Got MST reply from unknown device %d\n", hdr.lct);
|
||||||
hdr.lct);
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!drm_dp_sideband_msg_set_header(msg, &hdr, hdrlen)) {
|
if (!drm_dp_sideband_msg_set_header(msg, &hdr, hdrlen)) {
|
||||||
DRM_DEBUG_KMS("sideband msg set header failed %d\n",
|
drm_dbg_kms(mgr->dev, "sideband msg set header failed %d\n", replyblock[0]);
|
||||||
replyblock[0]);
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
replylen = min(msg->curchunk_len, (u8)(len - hdrlen));
|
replylen = min(msg->curchunk_len, (u8)(len - hdrlen));
|
||||||
ret = drm_dp_sideband_append_payload(msg, replyblock + hdrlen, replylen);
|
ret = drm_dp_sideband_append_payload(msg, replyblock + hdrlen, replylen);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
DRM_DEBUG_KMS("sideband msg build failed %d\n", replyblock[0]);
|
drm_dbg_kms(mgr->dev, "sideband msg build failed %d\n", replyblock[0]);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3954,14 +3958,14 @@ drm_dp_get_one_sb_msg(struct drm_dp_mst_topology_mgr *mgr, bool up,
|
||||||
ret = drm_dp_dpcd_read(mgr->aux, basereg + curreply,
|
ret = drm_dp_dpcd_read(mgr->aux, basereg + curreply,
|
||||||
replyblock, len);
|
replyblock, len);
|
||||||
if (ret != len) {
|
if (ret != len) {
|
||||||
DRM_DEBUG_KMS("failed to read a chunk (len %d, ret %d)\n",
|
drm_dbg_kms(mgr->dev, "failed to read a chunk (len %d, ret %d)\n",
|
||||||
len, ret);
|
len, ret);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = drm_dp_sideband_append_payload(msg, replyblock, len);
|
ret = drm_dp_sideband_append_payload(msg, replyblock, len);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
DRM_DEBUG_KMS("failed to build sideband msg\n");
|
drm_dbg_kms(mgr->dev, "failed to build sideband msg\n");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3995,21 +3999,21 @@ static int drm_dp_mst_handle_down_rep(struct drm_dp_mst_topology_mgr *mgr)
|
||||||
struct drm_dp_sideband_msg_hdr *hdr;
|
struct drm_dp_sideband_msg_hdr *hdr;
|
||||||
|
|
||||||
hdr = &msg->initial_hdr;
|
hdr = &msg->initial_hdr;
|
||||||
DRM_DEBUG_KMS("Got MST reply with no msg %p %d %d %02x %02x\n",
|
drm_dbg_kms(mgr->dev, "Got MST reply with no msg %p %d %d %02x %02x\n",
|
||||||
mstb, hdr->seqno, hdr->lct, hdr->rad[0],
|
mstb, hdr->seqno, hdr->lct, hdr->rad[0], msg->msg[0]);
|
||||||
msg->msg[0]);
|
|
||||||
goto out_clear_reply;
|
goto out_clear_reply;
|
||||||
}
|
}
|
||||||
|
|
||||||
drm_dp_sideband_parse_reply(msg, &txmsg->reply);
|
drm_dp_sideband_parse_reply(mgr, msg, &txmsg->reply);
|
||||||
|
|
||||||
if (txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK) {
|
if (txmsg->reply.reply_type == DP_SIDEBAND_REPLY_NAK) {
|
||||||
DRM_DEBUG_KMS("Got NAK reply: req 0x%02x (%s), reason 0x%02x (%s), nak data 0x%02x\n",
|
drm_dbg_kms(mgr->dev,
|
||||||
txmsg->reply.req_type,
|
"Got NAK reply: req 0x%02x (%s), reason 0x%02x (%s), nak data 0x%02x\n",
|
||||||
drm_dp_mst_req_type_str(txmsg->reply.req_type),
|
txmsg->reply.req_type,
|
||||||
txmsg->reply.u.nak.reason,
|
drm_dp_mst_req_type_str(txmsg->reply.req_type),
|
||||||
drm_dp_mst_nak_reason_str(txmsg->reply.u.nak.reason),
|
txmsg->reply.u.nak.reason,
|
||||||
txmsg->reply.u.nak.nak_data);
|
drm_dp_mst_nak_reason_str(txmsg->reply.u.nak.reason),
|
||||||
|
txmsg->reply.u.nak.nak_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
memset(msg, 0, sizeof(struct drm_dp_sideband_msg_rx));
|
memset(msg, 0, sizeof(struct drm_dp_sideband_msg_rx));
|
||||||
|
@ -4057,8 +4061,7 @@ drm_dp_mst_process_up_req(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mstb) {
|
if (!mstb) {
|
||||||
DRM_DEBUG_KMS("Got MST reply from unknown device %d\n",
|
drm_dbg_kms(mgr->dev, "Got MST reply from unknown device %d\n", hdr->lct);
|
||||||
hdr->lct);
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4118,12 +4121,12 @@ static int drm_dp_mst_handle_up_req(struct drm_dp_mst_topology_mgr *mgr)
|
||||||
|
|
||||||
INIT_LIST_HEAD(&up_req->next);
|
INIT_LIST_HEAD(&up_req->next);
|
||||||
|
|
||||||
drm_dp_sideband_parse_req(&mgr->up_req_recv, &up_req->msg);
|
drm_dp_sideband_parse_req(mgr, &mgr->up_req_recv, &up_req->msg);
|
||||||
|
|
||||||
if (up_req->msg.req_type != DP_CONNECTION_STATUS_NOTIFY &&
|
if (up_req->msg.req_type != DP_CONNECTION_STATUS_NOTIFY &&
|
||||||
up_req->msg.req_type != DP_RESOURCE_STATUS_NOTIFY) {
|
up_req->msg.req_type != DP_RESOURCE_STATUS_NOTIFY) {
|
||||||
DRM_DEBUG_KMS("Received unknown up req type, ignoring: %x\n",
|
drm_dbg_kms(mgr->dev, "Received unknown up req type, ignoring: %x\n",
|
||||||
up_req->msg.req_type);
|
up_req->msg.req_type);
|
||||||
kfree(up_req);
|
kfree(up_req);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -4135,20 +4138,20 @@ static int drm_dp_mst_handle_up_req(struct drm_dp_mst_topology_mgr *mgr)
|
||||||
const struct drm_dp_connection_status_notify *conn_stat =
|
const struct drm_dp_connection_status_notify *conn_stat =
|
||||||
&up_req->msg.u.conn_stat;
|
&up_req->msg.u.conn_stat;
|
||||||
|
|
||||||
DRM_DEBUG_KMS("Got CSN: pn: %d ldps:%d ddps: %d mcs: %d ip: %d pdt: %d\n",
|
drm_dbg_kms(mgr->dev, "Got CSN: pn: %d ldps:%d ddps: %d mcs: %d ip: %d pdt: %d\n",
|
||||||
conn_stat->port_number,
|
conn_stat->port_number,
|
||||||
conn_stat->legacy_device_plug_status,
|
conn_stat->legacy_device_plug_status,
|
||||||
conn_stat->displayport_device_plug_status,
|
conn_stat->displayport_device_plug_status,
|
||||||
conn_stat->message_capability_status,
|
conn_stat->message_capability_status,
|
||||||
conn_stat->input_port,
|
conn_stat->input_port,
|
||||||
conn_stat->peer_device_type);
|
conn_stat->peer_device_type);
|
||||||
} else if (up_req->msg.req_type == DP_RESOURCE_STATUS_NOTIFY) {
|
} else if (up_req->msg.req_type == DP_RESOURCE_STATUS_NOTIFY) {
|
||||||
const struct drm_dp_resource_status_notify *res_stat =
|
const struct drm_dp_resource_status_notify *res_stat =
|
||||||
&up_req->msg.u.resource_stat;
|
&up_req->msg.u.resource_stat;
|
||||||
|
|
||||||
DRM_DEBUG_KMS("Got RSN: pn: %d avail_pbn %d\n",
|
drm_dbg_kms(mgr->dev, "Got RSN: pn: %d avail_pbn %d\n",
|
||||||
res_stat->port_number,
|
res_stat->port_number,
|
||||||
res_stat->available_pbn);
|
res_stat->available_pbn);
|
||||||
}
|
}
|
||||||
|
|
||||||
up_req->hdr = mgr->up_req_recv.initial_hdr;
|
up_req->hdr = mgr->up_req_recv.initial_hdr;
|
||||||
|
@ -4388,8 +4391,9 @@ int drm_dp_atomic_find_vcpi_slots(struct drm_atomic_state *state,
|
||||||
* which is an error
|
* which is an error
|
||||||
*/
|
*/
|
||||||
if (WARN_ON(!prev_slots)) {
|
if (WARN_ON(!prev_slots)) {
|
||||||
DRM_ERROR("cannot allocate and release VCPI on [MST PORT:%p] in the same state\n",
|
drm_err(mgr->dev,
|
||||||
port);
|
"cannot allocate and release VCPI on [MST PORT:%p] in the same state\n",
|
||||||
|
port);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4406,12 +4410,12 @@ int drm_dp_atomic_find_vcpi_slots(struct drm_atomic_state *state,
|
||||||
|
|
||||||
req_slots = DIV_ROUND_UP(pbn, pbn_div);
|
req_slots = DIV_ROUND_UP(pbn, pbn_div);
|
||||||
|
|
||||||
DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] [MST PORT:%p] VCPI %d -> %d\n",
|
drm_dbg_atomic(mgr->dev, "[CONNECTOR:%d:%s] [MST PORT:%p] VCPI %d -> %d\n",
|
||||||
port->connector->base.id, port->connector->name,
|
port->connector->base.id, port->connector->name,
|
||||||
port, prev_slots, req_slots);
|
port, prev_slots, req_slots);
|
||||||
DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] [MST PORT:%p] PBN %d -> %d\n",
|
drm_dbg_atomic(mgr->dev, "[CONNECTOR:%d:%s] [MST PORT:%p] PBN %d -> %d\n",
|
||||||
port->connector->base.id, port->connector->name,
|
port->connector->base.id, port->connector->name,
|
||||||
port, prev_bw, pbn);
|
port, prev_bw, pbn);
|
||||||
|
|
||||||
/* Add the new allocation to the state */
|
/* Add the new allocation to the state */
|
||||||
if (!vcpi) {
|
if (!vcpi) {
|
||||||
|
@ -4475,12 +4479,12 @@ int drm_dp_atomic_release_vcpi_slots(struct drm_atomic_state *state,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (WARN_ON(!found)) {
|
if (WARN_ON(!found)) {
|
||||||
DRM_ERROR("no VCPI for [MST PORT:%p] found in mst state %p\n",
|
drm_err(mgr->dev, "no VCPI for [MST PORT:%p] found in mst state %p\n",
|
||||||
port, &topology_state->base);
|
port, &topology_state->base);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
DRM_DEBUG_ATOMIC("[MST PORT:%p] VCPI %d -> 0\n", port, pos->vcpi);
|
drm_dbg_atomic(mgr->dev, "[MST PORT:%p] VCPI %d -> 0\n", port, pos->vcpi);
|
||||||
if (pos->vcpi) {
|
if (pos->vcpi) {
|
||||||
drm_dp_mst_put_port_malloc(port);
|
drm_dp_mst_put_port_malloc(port);
|
||||||
pos->vcpi = 0;
|
pos->vcpi = 0;
|
||||||
|
@ -4511,8 +4515,9 @@ bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (port->vcpi.vcpi > 0) {
|
if (port->vcpi.vcpi > 0) {
|
||||||
DRM_DEBUG_KMS("payload: vcpi %d already allocated for pbn %d - requested pbn %d\n",
|
drm_dbg_kms(mgr->dev,
|
||||||
port->vcpi.vcpi, port->vcpi.pbn, pbn);
|
"payload: vcpi %d already allocated for pbn %d - requested pbn %d\n",
|
||||||
|
port->vcpi.vcpi, port->vcpi.pbn, pbn);
|
||||||
if (pbn == port->vcpi.pbn) {
|
if (pbn == port->vcpi.pbn) {
|
||||||
drm_dp_mst_topology_put_port(port);
|
drm_dp_mst_topology_put_port(port);
|
||||||
return true;
|
return true;
|
||||||
|
@ -4521,13 +4526,12 @@ bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
|
||||||
ret = drm_dp_init_vcpi(mgr, &port->vcpi, pbn, slots);
|
ret = drm_dp_init_vcpi(mgr, &port->vcpi, pbn, slots);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DRM_DEBUG_KMS("failed to init vcpi slots=%d max=63 ret=%d\n",
|
drm_dbg_kms(mgr->dev, "failed to init vcpi slots=%d max=63 ret=%d\n",
|
||||||
DIV_ROUND_UP(pbn, mgr->pbn_div), ret);
|
DIV_ROUND_UP(pbn, mgr->pbn_div), ret);
|
||||||
drm_dp_mst_topology_put_port(port);
|
drm_dp_mst_topology_put_port(port);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
DRM_DEBUG_KMS("initing vcpi for pbn=%d slots=%d\n",
|
drm_dbg_kms(mgr->dev, "initing vcpi for pbn=%d slots=%d\n", pbn, port->vcpi.num_slots);
|
||||||
pbn, port->vcpi.num_slots);
|
|
||||||
|
|
||||||
/* Keep port allocated until its payload has been removed */
|
/* Keep port allocated until its payload has been removed */
|
||||||
drm_dp_mst_get_port_malloc(port);
|
drm_dp_mst_get_port_malloc(port);
|
||||||
|
@ -4609,14 +4613,14 @@ static int drm_dp_dpcd_write_payload(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
|
|
||||||
ret = drm_dp_dpcd_write(mgr->aux, DP_PAYLOAD_ALLOCATE_SET, payload_alloc, 3);
|
ret = drm_dp_dpcd_write(mgr->aux, DP_PAYLOAD_ALLOCATE_SET, payload_alloc, 3);
|
||||||
if (ret != 3) {
|
if (ret != 3) {
|
||||||
DRM_DEBUG_KMS("failed to write payload allocation %d\n", ret);
|
drm_dbg_kms(mgr->dev, "failed to write payload allocation %d\n", ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
retry:
|
retry:
|
||||||
ret = drm_dp_dpcd_readb(mgr->aux, DP_PAYLOAD_TABLE_UPDATE_STATUS, &status);
|
ret = drm_dp_dpcd_readb(mgr->aux, DP_PAYLOAD_TABLE_UPDATE_STATUS, &status);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
DRM_DEBUG_KMS("failed to read payload table status %d\n", ret);
|
drm_dbg_kms(mgr->dev, "failed to read payload table status %d\n", ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4626,7 +4630,8 @@ static int drm_dp_dpcd_write_payload(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
usleep_range(10000, 20000);
|
usleep_range(10000, 20000);
|
||||||
goto retry;
|
goto retry;
|
||||||
}
|
}
|
||||||
DRM_DEBUG_KMS("status not set after read payload table status %d\n", status);
|
drm_dbg_kms(mgr->dev, "status not set after read payload table status %d\n",
|
||||||
|
status);
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
@ -4673,16 +4678,15 @@ int drm_dp_check_act_status(struct drm_dp_mst_topology_mgr *mgr)
|
||||||
status & DP_PAYLOAD_ACT_HANDLED || status < 0,
|
status & DP_PAYLOAD_ACT_HANDLED || status < 0,
|
||||||
200, timeout_ms * USEC_PER_MSEC);
|
200, timeout_ms * USEC_PER_MSEC);
|
||||||
if (ret < 0 && status >= 0) {
|
if (ret < 0 && status >= 0) {
|
||||||
DRM_ERROR("Failed to get ACT after %dms, last status: %02x\n",
|
drm_err(mgr->dev, "Failed to get ACT after %dms, last status: %02x\n",
|
||||||
timeout_ms, status);
|
timeout_ms, status);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
} else if (status < 0) {
|
} else if (status < 0) {
|
||||||
/*
|
/*
|
||||||
* Failure here isn't unexpected - the hub may have
|
* Failure here isn't unexpected - the hub may have
|
||||||
* just been unplugged
|
* just been unplugged
|
||||||
*/
|
*/
|
||||||
DRM_DEBUG_KMS("Failed to read payload table status: %d\n",
|
drm_dbg_kms(mgr->dev, "Failed to read payload table status: %d\n", status);
|
||||||
status);
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5122,12 +5126,11 @@ drm_dp_mst_atomic_check_mstb_bw_limit(struct drm_dp_mst_branch *mstb,
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (mstb->port_parent)
|
if (mstb->port_parent)
|
||||||
DRM_DEBUG_ATOMIC("[MSTB:%p] [MST PORT:%p] Checking bandwidth limits on [MSTB:%p]\n",
|
drm_dbg_atomic(mstb->mgr->dev,
|
||||||
mstb->port_parent->parent, mstb->port_parent,
|
"[MSTB:%p] [MST PORT:%p] Checking bandwidth limits on [MSTB:%p]\n",
|
||||||
mstb);
|
mstb->port_parent->parent, mstb->port_parent, mstb);
|
||||||
else
|
else
|
||||||
DRM_DEBUG_ATOMIC("[MSTB:%p] Checking bandwidth limits\n",
|
drm_dbg_atomic(mstb->mgr->dev, "[MSTB:%p] Checking bandwidth limits\n", mstb);
|
||||||
mstb);
|
|
||||||
|
|
||||||
list_for_each_entry(port, &mstb->ports, next) {
|
list_for_each_entry(port, &mstb->ports, next) {
|
||||||
ret = drm_dp_mst_atomic_check_port_bw_limit(port, state);
|
ret = drm_dp_mst_atomic_check_port_bw_limit(port, state);
|
||||||
|
@ -5185,14 +5188,14 @@ drm_dp_mst_atomic_check_port_bw_limit(struct drm_dp_mst_port *port,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pbn_used > port->full_pbn) {
|
if (pbn_used > port->full_pbn) {
|
||||||
DRM_DEBUG_ATOMIC("[MSTB:%p] [MST PORT:%p] required PBN of %d exceeds port limit of %d\n",
|
drm_dbg_atomic(port->mgr->dev,
|
||||||
port->parent, port, pbn_used,
|
"[MSTB:%p] [MST PORT:%p] required PBN of %d exceeds port limit of %d\n",
|
||||||
port->full_pbn);
|
port->parent, port, pbn_used, port->full_pbn);
|
||||||
return -ENOSPC;
|
return -ENOSPC;
|
||||||
}
|
}
|
||||||
|
|
||||||
DRM_DEBUG_ATOMIC("[MSTB:%p] [MST PORT:%p] uses %d out of %d PBN\n",
|
drm_dbg_atomic(port->mgr->dev, "[MSTB:%p] [MST PORT:%p] uses %d out of %d PBN\n",
|
||||||
port->parent, port, pbn_used, port->full_pbn);
|
port->parent, port, pbn_used, port->full_pbn);
|
||||||
|
|
||||||
return pbn_used;
|
return pbn_used;
|
||||||
}
|
}
|
||||||
|
@ -5207,31 +5210,31 @@ drm_dp_mst_atomic_check_vcpi_alloc_limit(struct drm_dp_mst_topology_mgr *mgr,
|
||||||
list_for_each_entry(vcpi, &mst_state->vcpis, next) {
|
list_for_each_entry(vcpi, &mst_state->vcpis, next) {
|
||||||
/* Releasing VCPI is always OK-even if the port is gone */
|
/* Releasing VCPI is always OK-even if the port is gone */
|
||||||
if (!vcpi->vcpi) {
|
if (!vcpi->vcpi) {
|
||||||
DRM_DEBUG_ATOMIC("[MST PORT:%p] releases all VCPI slots\n",
|
drm_dbg_atomic(mgr->dev, "[MST PORT:%p] releases all VCPI slots\n",
|
||||||
vcpi->port);
|
vcpi->port);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
DRM_DEBUG_ATOMIC("[MST PORT:%p] requires %d vcpi slots\n",
|
drm_dbg_atomic(mgr->dev, "[MST PORT:%p] requires %d vcpi slots\n",
|
||||||
vcpi->port, vcpi->vcpi);
|
vcpi->port, vcpi->vcpi);
|
||||||
|
|
||||||
avail_slots -= vcpi->vcpi;
|
avail_slots -= vcpi->vcpi;
|
||||||
if (avail_slots < 0) {
|
if (avail_slots < 0) {
|
||||||
DRM_DEBUG_ATOMIC("[MST PORT:%p] not enough VCPI slots in mst state %p (avail=%d)\n",
|
drm_dbg_atomic(mgr->dev,
|
||||||
vcpi->port, mst_state,
|
"[MST PORT:%p] not enough VCPI slots in mst state %p (avail=%d)\n",
|
||||||
avail_slots + vcpi->vcpi);
|
vcpi->port, mst_state, avail_slots + vcpi->vcpi);
|
||||||
return -ENOSPC;
|
return -ENOSPC;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (++payload_count > mgr->max_payloads) {
|
if (++payload_count > mgr->max_payloads) {
|
||||||
DRM_DEBUG_ATOMIC("[MST MGR:%p] state %p has too many payloads (max=%d)\n",
|
drm_dbg_atomic(mgr->dev,
|
||||||
mgr, mst_state, mgr->max_payloads);
|
"[MST MGR:%p] state %p has too many payloads (max=%d)\n",
|
||||||
|
mgr, mst_state, mgr->max_payloads);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
DRM_DEBUG_ATOMIC("[MST MGR:%p] mst state %p VCPI avail=%d used=%d\n",
|
drm_dbg_atomic(mgr->dev, "[MST MGR:%p] mst state %p VCPI avail=%d used=%d\n",
|
||||||
mgr, mst_state, avail_slots,
|
mgr, mst_state, avail_slots, 63 - avail_slots);
|
||||||
63 - avail_slots);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -5288,8 +5291,8 @@ int drm_dp_mst_add_affected_dsc_crtcs(struct drm_atomic_state *state, struct drm
|
||||||
if (IS_ERR(crtc_state))
|
if (IS_ERR(crtc_state))
|
||||||
return PTR_ERR(crtc_state);
|
return PTR_ERR(crtc_state);
|
||||||
|
|
||||||
DRM_DEBUG_ATOMIC("[MST MGR:%p] Setting mode_changed flag on CRTC %p\n",
|
drm_dbg_atomic(mgr->dev, "[MST MGR:%p] Setting mode_changed flag on CRTC %p\n",
|
||||||
mgr, crtc);
|
mgr, crtc);
|
||||||
|
|
||||||
crtc_state->mode_changed = true;
|
crtc_state->mode_changed = true;
|
||||||
}
|
}
|
||||||
|
@ -5334,21 +5337,24 @@ int drm_dp_mst_atomic_enable_dsc(struct drm_atomic_state *state,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!found) {
|
if (!found) {
|
||||||
DRM_DEBUG_ATOMIC("[MST PORT:%p] Couldn't find VCPI allocation in mst state %p\n",
|
drm_dbg_atomic(state->dev,
|
||||||
port, mst_state);
|
"[MST PORT:%p] Couldn't find VCPI allocation in mst state %p\n",
|
||||||
|
port, mst_state);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pos->dsc_enabled == enable) {
|
if (pos->dsc_enabled == enable) {
|
||||||
DRM_DEBUG_ATOMIC("[MST PORT:%p] DSC flag is already set to %d, returning %d VCPI slots\n",
|
drm_dbg_atomic(state->dev,
|
||||||
port, enable, pos->vcpi);
|
"[MST PORT:%p] DSC flag is already set to %d, returning %d VCPI slots\n",
|
||||||
|
port, enable, pos->vcpi);
|
||||||
vcpi = pos->vcpi;
|
vcpi = pos->vcpi;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (enable) {
|
if (enable) {
|
||||||
vcpi = drm_dp_atomic_find_vcpi_slots(state, port->mgr, port, pbn, pbn_div);
|
vcpi = drm_dp_atomic_find_vcpi_slots(state, port->mgr, port, pbn, pbn_div);
|
||||||
DRM_DEBUG_ATOMIC("[MST PORT:%p] Enabling DSC flag, reallocating %d VCPI slots on the port\n",
|
drm_dbg_atomic(state->dev,
|
||||||
port, vcpi);
|
"[MST PORT:%p] Enabling DSC flag, reallocating %d VCPI slots on the port\n",
|
||||||
|
port, vcpi);
|
||||||
if (vcpi < 0)
|
if (vcpi < 0)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -5695,7 +5701,7 @@ static int drm_dp_mst_i2c_xfer(struct i2c_adapter *adapter,
|
||||||
} else if (remote_i2c_write_ok(msgs, num)) {
|
} else if (remote_i2c_write_ok(msgs, num)) {
|
||||||
ret = drm_dp_mst_i2c_write(mstb, port, msgs, num);
|
ret = drm_dp_mst_i2c_write(mstb, port, msgs, num);
|
||||||
} else {
|
} else {
|
||||||
DRM_DEBUG_KMS("Unsupported I2C transaction for MST device\n");
|
drm_dbg_kms(mgr->dev, "Unsupported I2C transaction for MST device\n");
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue