Commit cb3ec8cb authored by Ben Skeggs's avatar Ben Skeggs Committed by Lyude Paul

drm/nouveau/disp: move outp init/fini paths to chipset code

- pre-nv5x doesn't use any of this
- preparation for GSP-RM
Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
Reviewed-by: default avatarLyude Paul <lyude@redhat.com>
Acked-by: default avatarDanilo Krummrich <me@dakr.org>
Signed-off-by: default avatarLyude Paul <lyude@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230919220442.202488-38-lyude@redhat.com
parent 62b0eef2
...@@ -102,18 +102,14 @@ static int ...@@ -102,18 +102,14 @@ static int
nvkm_disp_fini(struct nvkm_engine *engine, bool suspend) nvkm_disp_fini(struct nvkm_engine *engine, bool suspend)
{ {
struct nvkm_disp *disp = nvkm_disp(engine); struct nvkm_disp *disp = nvkm_disp(engine);
struct nvkm_conn *conn;
struct nvkm_outp *outp; struct nvkm_outp *outp;
if (disp->func->fini) if (disp->func->fini)
disp->func->fini(disp); disp->func->fini(disp);
list_for_each_entry(outp, &disp->outps, head) { list_for_each_entry(outp, &disp->outps, head) {
nvkm_outp_fini(outp); if (outp->func->fini)
} outp->func->fini(outp);
list_for_each_entry(conn, &disp->conns, head) {
nvkm_conn_fini(conn);
} }
return 0; return 0;
...@@ -123,16 +119,12 @@ static int ...@@ -123,16 +119,12 @@ static int
nvkm_disp_init(struct nvkm_engine *engine) nvkm_disp_init(struct nvkm_engine *engine)
{ {
struct nvkm_disp *disp = nvkm_disp(engine); struct nvkm_disp *disp = nvkm_disp(engine);
struct nvkm_conn *conn;
struct nvkm_outp *outp; struct nvkm_outp *outp;
struct nvkm_ior *ior; struct nvkm_ior *ior;
list_for_each_entry(conn, &disp->conns, head) {
nvkm_conn_init(conn);
}
list_for_each_entry(outp, &disp->outps, head) { list_for_each_entry(outp, &disp->outps, head) {
nvkm_outp_init(outp); if (outp->func->init)
outp->func->init(outp);
} }
if (disp->func->init) { if (disp->func->init) {
...@@ -156,9 +148,7 @@ nvkm_disp_oneinit(struct nvkm_engine *engine) ...@@ -156,9 +148,7 @@ nvkm_disp_oneinit(struct nvkm_engine *engine)
{ {
struct nvkm_disp *disp = nvkm_disp(engine); struct nvkm_disp *disp = nvkm_disp(engine);
struct nvkm_subdev *subdev = &disp->engine.subdev; struct nvkm_subdev *subdev = &disp->engine.subdev;
struct nvkm_outp *outp;
struct nvkm_head *head; struct nvkm_head *head;
struct nvkm_ior *ior;
int ret, i; int ret, i;
if (disp->func->oneinit) { if (disp->func->oneinit) {
...@@ -167,19 +157,6 @@ nvkm_disp_oneinit(struct nvkm_engine *engine) ...@@ -167,19 +157,6 @@ nvkm_disp_oneinit(struct nvkm_engine *engine)
return ret; return ret;
} }
/* Enforce identity-mapped SOR assignment for panels, which have
* certain bits (ie. backlight controls) wired to a specific SOR.
*/
list_for_each_entry(outp, &disp->outps, head) {
if (outp->conn->info.type == DCB_CONNECTOR_LVDS ||
outp->conn->info.type == DCB_CONNECTOR_eDP) {
ior = nvkm_ior_find(disp, SOR, ffs(outp->info.or) - 1);
if (!WARN_ON(!ior))
ior->identity = true;
outp->identity = true;
}
}
i = 0; i = 0;
list_for_each_entry(head, &disp->heads, head) list_for_each_entry(head, &disp->heads, head)
i = max(i, head->id + 1); i = max(i, head->id + 1);
......
...@@ -29,16 +29,6 @@ ...@@ -29,16 +29,6 @@
#include <nvif/event.h> #include <nvif/event.h>
void
nvkm_conn_fini(struct nvkm_conn *conn)
{
}
void
nvkm_conn_init(struct nvkm_conn *conn)
{
}
void void
nvkm_conn_del(struct nvkm_conn **pconn) nvkm_conn_del(struct nvkm_conn **pconn)
{ {
......
...@@ -19,8 +19,6 @@ struct nvkm_conn { ...@@ -19,8 +19,6 @@ struct nvkm_conn {
int nvkm_conn_new(struct nvkm_disp *, int index, struct nvbios_connE *, int nvkm_conn_new(struct nvkm_disp *, int index, struct nvbios_connE *,
struct nvkm_conn **); struct nvkm_conn **);
void nvkm_conn_del(struct nvkm_conn **); void nvkm_conn_del(struct nvkm_conn **);
void nvkm_conn_init(struct nvkm_conn *);
void nvkm_conn_fini(struct nvkm_conn *);
#define CONN_MSG(c,l,f,a...) do { \ #define CONN_MSG(c,l,f,a...) do { \
struct nvkm_conn *_conn = (c); \ struct nvkm_conn *_conn = (c); \
......
...@@ -603,6 +603,7 @@ nvkm_dp_fini(struct nvkm_outp *outp) ...@@ -603,6 +603,7 @@ nvkm_dp_fini(struct nvkm_outp *outp)
static void static void
nvkm_dp_init(struct nvkm_outp *outp) nvkm_dp_init(struct nvkm_outp *outp)
{ {
nvkm_outp_init(outp);
nvkm_dp_enable(outp, outp->dp.enabled); nvkm_dp_enable(outp, outp->dp.enabled);
} }
......
...@@ -1586,6 +1586,7 @@ nv50_disp_oneinit(struct nvkm_disp *disp) ...@@ -1586,6 +1586,7 @@ nv50_disp_oneinit(struct nvkm_disp *disp)
struct nvkm_bios *bios = device->bios; struct nvkm_bios *bios = device->bios;
struct nvkm_outp *outp, *outt, *pair; struct nvkm_outp *outp, *outt, *pair;
struct nvkm_conn *conn; struct nvkm_conn *conn;
struct nvkm_ior *ior;
int ret, i; int ret, i;
u8 ver, hdr; u8 ver, hdr;
u32 data; u32 data;
...@@ -1747,6 +1748,19 @@ nv50_disp_oneinit(struct nvkm_disp *disp) ...@@ -1747,6 +1748,19 @@ nv50_disp_oneinit(struct nvkm_disp *disp)
list_add_tail(&outp->conn->head, &disp->conns); list_add_tail(&outp->conn->head, &disp->conns);
} }
/* Enforce identity-mapped SOR assignment for panels, which have
* certain bits (ie. backlight controls) wired to a specific SOR.
*/
list_for_each_entry(outp, &disp->outps, head) {
if (outp->conn->info.type == DCB_CONNECTOR_LVDS ||
outp->conn->info.type == DCB_CONNECTOR_eDP) {
ior = nvkm_ior_find(disp, SOR, ffs(outp->info.or) - 1);
if (!WARN_ON(!ior))
ior->identity = true;
outp->identity = true;
}
}
return 0; return 0;
} }
......
...@@ -287,13 +287,6 @@ nvkm_outp_acquire(struct nvkm_outp *outp, bool hda) ...@@ -287,13 +287,6 @@ nvkm_outp_acquire(struct nvkm_outp *outp, bool hda)
return 0; return 0;
} }
void
nvkm_outp_fini(struct nvkm_outp *outp)
{
if (outp->func->fini)
outp->func->fini(outp);
}
struct nvkm_ior * struct nvkm_ior *
nvkm_outp_inherit(struct nvkm_outp *outp) nvkm_outp_inherit(struct nvkm_outp *outp)
{ {
...@@ -332,8 +325,8 @@ nvkm_outp_inherit(struct nvkm_outp *outp) ...@@ -332,8 +325,8 @@ nvkm_outp_inherit(struct nvkm_outp *outp)
return ior; return ior;
} }
static void void
nvkm_outp_init_route(struct nvkm_outp *outp) nvkm_outp_init(struct nvkm_outp *outp)
{ {
enum nvkm_ior_proto proto; enum nvkm_ior_proto proto;
enum nvkm_ior_type type; enum nvkm_ior_type type;
...@@ -365,14 +358,6 @@ nvkm_outp_init_route(struct nvkm_outp *outp) ...@@ -365,14 +358,6 @@ nvkm_outp_init_route(struct nvkm_outp *outp)
ior->arm.outp = outp; ior->arm.outp = outp;
} }
void
nvkm_outp_init(struct nvkm_outp *outp)
{
nvkm_outp_init_route(outp);
if (outp->func->init)
outp->func->init(outp);
}
void void
nvkm_outp_del(struct nvkm_outp **poutp) nvkm_outp_del(struct nvkm_outp **poutp)
{ {
...@@ -420,6 +405,7 @@ nvkm_outp_new_(const struct nvkm_outp_func *func, struct nvkm_disp *disp, ...@@ -420,6 +405,7 @@ nvkm_outp_new_(const struct nvkm_outp_func *func, struct nvkm_disp *disp,
static const struct nvkm_outp_func static const struct nvkm_outp_func
nvkm_outp = { nvkm_outp = {
.init = nvkm_outp_init,
.detect = nvkm_outp_detect, .detect = nvkm_outp_detect,
.inherit = nvkm_outp_inherit, .inherit = nvkm_outp_inherit,
.acquire = nvkm_outp_acquire, .acquire = nvkm_outp_acquire,
......
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