drm/nouveau/disp/hda/gf119-: add HAL for programming device entry in SF
authorBen Skeggs <bskeggs@redhat.com>
Wed, 6 May 2020 04:40:56 +0000 (14:40 +1000)
committerBen Skeggs <bskeggs@redhat.com>
Fri, 22 May 2020 01:13:51 +0000 (11:13 +1000)
Register has moved on GV100.

Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagf119.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/ior.h
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgf119.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgk104.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgm107.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgm200.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgv100.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sortu102.c

index 1080ba6..8a0ec7d 100644 (file)
 #include "ior.h"
 
 void
+gf119_hda_device_entry(struct nvkm_ior *ior, int head)
+{
+       struct nvkm_device *device = ior->disp->engine.subdev.device;
+       const u32 hoff = 0x800 * head;
+       nvkm_mask(device, 0x616548 + hoff, 0x00000070, 0x00000000);
+}
+
+void
 gf119_hda_eld(struct nvkm_ior *ior, int head, u8 *data, u8 size)
 {
        struct nvkm_device *device = ior->disp->engine.subdev.device;
@@ -41,11 +49,10 @@ void
 gf119_hda_hpd(struct nvkm_ior *ior, int head, bool present)
 {
        struct nvkm_device *device = ior->disp->engine.subdev.device;
-       const u32 hoff = 0x800 * head;
        u32 data = 0x80000000;
        u32 mask = 0x80000001;
        if (present) {
-               nvkm_mask(device, 0x616548 + hoff, 0x00000070, 0x00000000);
+               ior->func->hda.device_entry(ior, head);
                data |= 0x00000001;
        } else {
                mask |= 0x00000002;
index c60acf7..eb1155e 100644 (file)
@@ -88,6 +88,7 @@ struct nvkm_ior_func {
        struct {
                void (*hpd)(struct nvkm_ior *, int head, bool present);
                void (*eld)(struct nvkm_ior *, int head, u8 *data, u8 size);
+               void (*device_entry)(struct nvkm_ior *, int head);
        } hda;
 };
 
@@ -162,6 +163,7 @@ void gt215_hda_eld(struct nvkm_ior *, int, u8 *, u8);
 
 void gf119_hda_hpd(struct nvkm_ior *, int, bool);
 void gf119_hda_eld(struct nvkm_ior *, int, u8 *, u8);
+void gf119_hda_device_entry(struct nvkm_ior *, int);
 
 #define IOR_MSG(i,l,f,a...) do {                                               \
        struct nvkm_ior *_ior = (i);                                           \
index 456a5a1..3b3643f 100644 (file)
@@ -177,6 +177,7 @@ gf119_sor = {
        .hda = {
                .hpd = gf119_hda_hpd,
                .eld = gf119_hda_eld,
+               .device_entry = gf119_hda_device_entry,
        },
 };
 
index b94090e..0c09256 100644 (file)
@@ -43,6 +43,7 @@ gk104_sor = {
        .hda = {
                .hpd = gf119_hda_hpd,
                .eld = gf119_hda_eld,
+               .device_entry = gf119_hda_device_entry,
        },
 };
 
index e6965de..38045c9 100644 (file)
@@ -57,6 +57,7 @@ gm107_sor = {
        .hda = {
                .hpd = gf119_hda_hpd,
                .eld = gf119_hda_eld,
+               .device_entry = gf119_hda_device_entry,
        },
 };
 
index 384f826..cf2075d 100644 (file)
@@ -115,6 +115,7 @@ gm200_sor = {
        .hda = {
                .hpd = gf119_hda_hpd,
                .eld = gf119_hda_eld,
+               .device_entry = gf119_hda_device_entry,
        },
 };
 
index b0597ff..565cfbc 100644 (file)
@@ -103,6 +103,7 @@ gv100_sor = {
        .hda = {
                .hpd = gf119_hda_hpd,
                .eld = gf119_hda_eld,
+               .device_entry = gf119_hda_device_entry,
        },
 };
 
index 4d5f379..b16ecea 100644 (file)
@@ -88,6 +88,7 @@ tu102_sor = {
        .hda = {
                .hpd = gf119_hda_hpd,
                .eld = gf119_hda_eld,
+               .device_entry = gf119_hda_device_entry,
        },
 };