drm/nouveau/disp/hda/gf119-: select HDA device entry based on bound head
authorBen Skeggs <bskeggs@redhat.com>
Wed, 6 May 2020 04:40:58 +0000 (14:40 +1000)
committerBen Skeggs <bskeggs@redhat.com>
Fri, 22 May 2020 01:13:51 +0000 (11:13 +1000)
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagf119.c

index 8a0ec7db51452a37c492b2c1804cb8c0e99d05f3..19d2d58344e4adf33d1d8db7e4ec8067b8ee83d5 100644 (file)
@@ -28,14 +28,14 @@ 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);
+       nvkm_mask(device, 0x616548 + hoff, 0x00000070, head << 4);
 }
 
 void
 gf119_hda_eld(struct nvkm_ior *ior, int head, u8 *data, u8 size)
 {
        struct nvkm_device *device = ior->disp->engine.subdev.device;
-       const u32 soff = 0x030 * ior->id;
+       const u32 soff = 0x030 * ior->id + (head * 0x04);
        int i;
 
        for (i = 0; i < size; i++)
@@ -49,6 +49,7 @@ void
 gf119_hda_hpd(struct nvkm_ior *ior, int head, bool present)
 {
        struct nvkm_device *device = ior->disp->engine.subdev.device;
+       const u32 soff = 0x030 * ior->id + (head * 0x04);
        u32 data = 0x80000000;
        u32 mask = 0x80000001;
        if (present) {
@@ -57,5 +58,5 @@ gf119_hda_hpd(struct nvkm_ior *ior, int head, bool present)
        } else {
                mask |= 0x00000002;
        }
-       nvkm_mask(device, 0x10ec10 + ior->id * 0x030, mask, data);
+       nvkm_mask(device, 0x10ec10 + soff, mask, data);
 }