Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1936651imm; Thu, 12 Jul 2018 10:12:17 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdePViSBluANXTTOe4a5/Zv6WSe+L5+cojJKk0w5RoHVlYsryz9ICIxwelxyLn+Y288dzW6 X-Received: by 2002:a63:d401:: with SMTP id a1-v6mr2850950pgh.414.1531415536997; Thu, 12 Jul 2018 10:12:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531415536; cv=none; d=google.com; s=arc-20160816; b=uQHswoA1Cy767Bk/RifGUnfYEta3nswAzdmxbSwyLsTXvE4ARPlob/yW/aWeB97Jue r6Q3Ul8/M26Ns3Ps6nvyz59OBcAqPN+ryOJJYdLlvkOqiRhkFckzjNN8kUaYKKKKZka8 tdVfZa2Yin7fAOU6aboQAS/Zw8IUAJuary6O1VtSX3WfqaHe85qBC/WUnkL72/FsktSu sjOXBRaL1BFQr3I070EBUEUP0XDIVgszXI1gLoznasDeWMdPH5AfF7BqAIBmQ7Yw9Zrs YKD8ALHD0wUhqiF/j3Bl8DFSHzXmi7HbW8FzuNy8DV2FZwP27FWGVhPioWwpsfr2Tnru m8kw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=bON7v2b1XK2CdjtdhfkfgLPvYlpmxI4VlI7eFMs1UIo=; b=KKuk6Ivu2hpG/79qe4qLVzwkhT0qGgSrNB4396nbz8o6KQuD4hXpYtUgtTkIb3RbPk 1iom84nmcbGX0VUPeMpc98DdoNQp+V7iznTQXr0IembM6kby2PE0/7q2dFoJsqNyPqXE PmKPRGPpKgkP+OmRtWejJ5u65MGnmsJf2aQE4CHqJBqh/CLQPXhIpDgXRHpc411FC32m IHm4OtMgokNiDYk7U/e66+qrAccofU/2jb7+LWQLaqLHT51ujMcCoXQ6BQTAVJCNV6dr z8M3uU53oa87uJJD4rC2BW8e4E7DYc8EmZykFWGd+wQelMDQcEFRHHwEG7K4FqI9emKn /DPg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y10-v6si9208729pgf.312.2018.07.12.10.12.01; Thu, 12 Jul 2018 10:12:16 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732607AbeGLRVf (ORCPT + 99 others); Thu, 12 Jul 2018 13:21:35 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:41758 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727092AbeGLRVe (ORCPT ); Thu, 12 Jul 2018 13:21:34 -0400 Received: from smtp.corp.redhat.com (int-mx06.intmail.prod.int.rdu2.redhat.com [10.11.54.6]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 162A1701E6; Thu, 12 Jul 2018 17:11:08 +0000 (UTC) Received: from whitewolf.lyude.net.com (ovpn-120-214.rdu2.redhat.com [10.10.120.214]) by smtp.corp.redhat.com (Postfix) with ESMTP id 8E6272142F20; Thu, 12 Jul 2018 17:11:07 +0000 (UTC) From: Lyude Paul To: nouveau@lists.freedesktop.org Cc: Ben Skeggs , David Airlie , Daniel Vetter , Maarten Lankhorst , =?UTF-8?q?Ville=20Syrj=C3=A4l=C3=A4?= , Archit Taneja , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/2] drm/nouveau: Expose nv50 MST structures in disp.h Date: Thu, 12 Jul 2018 13:10:46 -0400 Message-Id: <20180712171056.26359-2-lyude@redhat.com> In-Reply-To: <20180712171056.26359-1-lyude@redhat.com> References: <20180712171056.26359-1-lyude@redhat.com> X-Scanned-By: MIMEDefang 2.78 on 10.11.54.6 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Thu, 12 Jul 2018 17:11:08 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.2]); Thu, 12 Jul 2018 17:11:08 +0000 (UTC) for IP:'10.11.54.6' DOMAIN:'int-mx06.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'lyude@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We're about to need this so that we can hook up dp_mst_info into debugfs so we can walk the encoder list and find each mst mgr. Signed-off-by: Lyude Paul --- drivers/gpu/drm/nouveau/dispnv50/disp.c | 34 ------------------------ drivers/gpu/drm/nouveau/dispnv50/disp.h | 35 +++++++++++++++++++++++++ 2 files changed, 35 insertions(+), 34 deletions(-) diff --git a/drivers/gpu/drm/nouveau/dispnv50/disp.c b/drivers/gpu/drm/nouveau/dispnv50/disp.c index d9da69c83ae7..f76fe5f260a4 100644 --- a/drivers/gpu/drm/nouveau/dispnv50/disp.c +++ b/drivers/gpu/drm/nouveau/dispnv50/disp.c @@ -568,40 +568,6 @@ nv50_hdmi_enable(struct drm_encoder *encoder, struct drm_display_mode *mode) /****************************************************************************** * MST *****************************************************************************/ -#define nv50_mstm(p) container_of((p), struct nv50_mstm, mgr) -#define nv50_mstc(p) container_of((p), struct nv50_mstc, connector) -#define nv50_msto(p) container_of((p), struct nv50_msto, encoder) - -struct nv50_mstm { - struct nouveau_encoder *outp; - - struct drm_dp_mst_topology_mgr mgr; - struct nv50_msto *msto[4]; - - bool modified; - bool disabled; - int links; -}; - -struct nv50_mstc { - struct nv50_mstm *mstm; - struct drm_dp_mst_port *port; - struct drm_connector connector; - - struct drm_display_mode *native; - struct edid *edid; - - int pbn; -}; - -struct nv50_msto { - struct drm_encoder encoder; - - struct nv50_head *head; - struct nv50_mstc *mstc; - bool disabled; -}; - static struct drm_dp_payload * nv50_msto_payload(struct nv50_msto *msto) { diff --git a/drivers/gpu/drm/nouveau/dispnv50/disp.h b/drivers/gpu/drm/nouveau/dispnv50/disp.h index e48c5eb35b49..5ba7093f3c74 100644 --- a/drivers/gpu/drm/nouveau/dispnv50/disp.h +++ b/drivers/gpu/drm/nouveau/dispnv50/disp.h @@ -3,6 +3,7 @@ #include #include "nouveau_display.h" +#include "nouveau_encoder.h" struct nv50_disp { struct nvif_disp *disp; @@ -65,6 +66,40 @@ struct nv50_dmac { struct mutex lock; }; +#define nv50_mstm(p) container_of((p), struct nv50_mstm, mgr) +#define nv50_mstc(p) container_of((p), struct nv50_mstc, connector) +#define nv50_msto(p) container_of((p), struct nv50_msto, encoder) + +struct nv50_mstm { + struct nouveau_encoder *outp; + + struct drm_dp_mst_topology_mgr mgr; + struct nv50_msto *msto[4]; + + bool modified; + bool disabled; + int links; +}; + +struct nv50_mstc { + struct nv50_mstm *mstm; + struct drm_dp_mst_port *port; + struct drm_connector connector; + + struct drm_display_mode *native; + struct edid *edid; + + int pbn; +}; + +struct nv50_msto { + struct drm_encoder encoder; + + struct nv50_head *head; + struct nv50_mstc *mstc; + bool disabled; +}; + int nv50_dmac_create(struct nvif_device *device, struct nvif_object *disp, const s32 *oclass, u8 head, void *data, u32 size, u64 syncbuf, struct nv50_dmac *dmac); -- 2.17.1