]> git.proxmox.com Git - mirror_ubuntu-disco-kernel.git/commitdiff
drm/nouveau/ibus: switch to device pri macros
authorBen Skeggs <bskeggs@redhat.com>
Thu, 20 Aug 2015 04:54:09 +0000 (14:54 +1000)
committerBen Skeggs <bskeggs@redhat.com>
Fri, 28 Aug 2015 02:40:15 +0000 (12:40 +1000)
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
drivers/gpu/drm/nouveau/nvkm/subdev/ibus/gf100.c
drivers/gpu/drm/nouveau/nvkm/subdev/ibus/gk104.c
drivers/gpu/drm/nouveau/nvkm/subdev/ibus/gk20a.c

index d4c175dfc797efce8e9dc526d4796b5e62120160..5f7652942b2af099d044aa751383c928750e989e 100644 (file)
 static void
 gf100_ibus_intr_hub(struct nvkm_ibus *ibus, int i)
 {
-       u32 addr = nv_rd32(ibus, 0x122120 + (i * 0x0400));
-       u32 data = nv_rd32(ibus, 0x122124 + (i * 0x0400));
-       u32 stat = nv_rd32(ibus, 0x122128 + (i * 0x0400));
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 addr = nvkm_rd32(device, 0x122120 + (i * 0x0400));
+       u32 data = nvkm_rd32(device, 0x122124 + (i * 0x0400));
+       u32 stat = nvkm_rd32(device, 0x122128 + (i * 0x0400));
        nv_error(ibus, "HUB%d: 0x%06x 0x%08x (0x%08x)\n", i, addr, data, stat);
-       nv_mask(ibus, 0x122128 + (i * 0x0400), 0x00000200, 0x00000000);
+       nvkm_mask(device, 0x122128 + (i * 0x0400), 0x00000200, 0x00000000);
 }
 
 static void
 gf100_ibus_intr_rop(struct nvkm_ibus *ibus, int i)
 {
-       u32 addr = nv_rd32(ibus, 0x124120 + (i * 0x0400));
-       u32 data = nv_rd32(ibus, 0x124124 + (i * 0x0400));
-       u32 stat = nv_rd32(ibus, 0x124128 + (i * 0x0400));
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 addr = nvkm_rd32(device, 0x124120 + (i * 0x0400));
+       u32 data = nvkm_rd32(device, 0x124124 + (i * 0x0400));
+       u32 stat = nvkm_rd32(device, 0x124128 + (i * 0x0400));
        nv_error(ibus, "ROP%d: 0x%06x 0x%08x (0x%08x)\n", i, addr, data, stat);
-       nv_mask(ibus, 0x124128 + (i * 0x0400), 0x00000200, 0x00000000);
+       nvkm_mask(device, 0x124128 + (i * 0x0400), 0x00000200, 0x00000000);
 }
 
 static void
 gf100_ibus_intr_gpc(struct nvkm_ibus *ibus, int i)
 {
-       u32 addr = nv_rd32(ibus, 0x128120 + (i * 0x0400));
-       u32 data = nv_rd32(ibus, 0x128124 + (i * 0x0400));
-       u32 stat = nv_rd32(ibus, 0x128128 + (i * 0x0400));
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 addr = nvkm_rd32(device, 0x128120 + (i * 0x0400));
+       u32 data = nvkm_rd32(device, 0x128124 + (i * 0x0400));
+       u32 stat = nvkm_rd32(device, 0x128128 + (i * 0x0400));
        nv_error(ibus, "GPC%d: 0x%06x 0x%08x (0x%08x)\n", i, addr, data, stat);
-       nv_mask(ibus, 0x128128 + (i * 0x0400), 0x00000200, 0x00000000);
+       nvkm_mask(device, 0x128128 + (i * 0x0400), 0x00000200, 0x00000000);
 }
 
 static void
 gf100_ibus_intr(struct nvkm_subdev *subdev)
 {
        struct nvkm_ibus *ibus = (void *)subdev;
-       u32 intr0 = nv_rd32(ibus, 0x121c58);
-       u32 intr1 = nv_rd32(ibus, 0x121c5c);
-       u32 hubnr = nv_rd32(ibus, 0x121c70);
-       u32 ropnr = nv_rd32(ibus, 0x121c74);
-       u32 gpcnr = nv_rd32(ibus, 0x121c78);
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 intr0 = nvkm_rd32(device, 0x121c58);
+       u32 intr1 = nvkm_rd32(device, 0x121c5c);
+       u32 hubnr = nvkm_rd32(device, 0x121c70);
+       u32 ropnr = nvkm_rd32(device, 0x121c74);
+       u32 gpcnr = nvkm_rd32(device, 0x121c78);
        u32 i;
 
        for (i = 0; (intr0 & 0x0000ff00) && i < hubnr; i++) {
index 4107d9d25a04aad507dcf7c0227239c9ca848c89..53dd1ba389d74ee665d086f238917a6d8f0dd5d4 100644 (file)
 static void
 gk104_ibus_intr_hub(struct nvkm_ibus *ibus, int i)
 {
-       u32 addr = nv_rd32(ibus, 0x122120 + (i * 0x0800));
-       u32 data = nv_rd32(ibus, 0x122124 + (i * 0x0800));
-       u32 stat = nv_rd32(ibus, 0x122128 + (i * 0x0800));
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 addr = nvkm_rd32(device, 0x122120 + (i * 0x0800));
+       u32 data = nvkm_rd32(device, 0x122124 + (i * 0x0800));
+       u32 stat = nvkm_rd32(device, 0x122128 + (i * 0x0800));
        nv_error(ibus, "HUB%d: 0x%06x 0x%08x (0x%08x)\n", i, addr, data, stat);
-       nv_mask(ibus, 0x122128 + (i * 0x0800), 0x00000200, 0x00000000);
+       nvkm_mask(device, 0x122128 + (i * 0x0800), 0x00000200, 0x00000000);
 }
 
 static void
 gk104_ibus_intr_rop(struct nvkm_ibus *ibus, int i)
 {
-       u32 addr = nv_rd32(ibus, 0x124120 + (i * 0x0800));
-       u32 data = nv_rd32(ibus, 0x124124 + (i * 0x0800));
-       u32 stat = nv_rd32(ibus, 0x124128 + (i * 0x0800));
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 addr = nvkm_rd32(device, 0x124120 + (i * 0x0800));
+       u32 data = nvkm_rd32(device, 0x124124 + (i * 0x0800));
+       u32 stat = nvkm_rd32(device, 0x124128 + (i * 0x0800));
        nv_error(ibus, "ROP%d: 0x%06x 0x%08x (0x%08x)\n", i, addr, data, stat);
-       nv_mask(ibus, 0x124128 + (i * 0x0800), 0x00000200, 0x00000000);
+       nvkm_mask(device, 0x124128 + (i * 0x0800), 0x00000200, 0x00000000);
 }
 
 static void
 gk104_ibus_intr_gpc(struct nvkm_ibus *ibus, int i)
 {
-       u32 addr = nv_rd32(ibus, 0x128120 + (i * 0x0800));
-       u32 data = nv_rd32(ibus, 0x128124 + (i * 0x0800));
-       u32 stat = nv_rd32(ibus, 0x128128 + (i * 0x0800));
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 addr = nvkm_rd32(device, 0x128120 + (i * 0x0800));
+       u32 data = nvkm_rd32(device, 0x128124 + (i * 0x0800));
+       u32 stat = nvkm_rd32(device, 0x128128 + (i * 0x0800));
        nv_error(ibus, "GPC%d: 0x%06x 0x%08x (0x%08x)\n", i, addr, data, stat);
-       nv_mask(ibus, 0x128128 + (i * 0x0800), 0x00000200, 0x00000000);
+       nvkm_mask(device, 0x128128 + (i * 0x0800), 0x00000200, 0x00000000);
 }
 
 static void
 gk104_ibus_intr(struct nvkm_subdev *subdev)
 {
        struct nvkm_ibus *ibus = (void *)subdev;
-       u32 intr0 = nv_rd32(ibus, 0x120058);
-       u32 intr1 = nv_rd32(ibus, 0x12005c);
-       u32 hubnr = nv_rd32(ibus, 0x120070);
-       u32 ropnr = nv_rd32(ibus, 0x120074);
-       u32 gpcnr = nv_rd32(ibus, 0x120078);
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 intr0 = nvkm_rd32(device, 0x120058);
+       u32 intr1 = nvkm_rd32(device, 0x12005c);
+       u32 hubnr = nvkm_rd32(device, 0x120070);
+       u32 ropnr = nvkm_rd32(device, 0x120074);
+       u32 gpcnr = nvkm_rd32(device, 0x120078);
        u32 i;
 
        for (i = 0; (intr0 & 0x0000ff00) && i < hubnr; i++) {
@@ -93,15 +97,16 @@ static int
 gk104_ibus_init(struct nvkm_object *object)
 {
        struct nvkm_ibus *ibus = (void *)object;
+       struct nvkm_device *device = ibus->subdev.device;
        int ret = nvkm_ibus_init(ibus);
        if (ret == 0) {
-               nv_mask(ibus, 0x122318, 0x0003ffff, 0x00001000);
-               nv_mask(ibus, 0x12231c, 0x0003ffff, 0x00000200);
-               nv_mask(ibus, 0x122310, 0x0003ffff, 0x00000800);
-               nv_mask(ibus, 0x122348, 0x0003ffff, 0x00000100);
-               nv_mask(ibus, 0x1223b0, 0x0003ffff, 0x00000fff);
-               nv_mask(ibus, 0x122348, 0x0003ffff, 0x00000200);
-               nv_mask(ibus, 0x122358, 0x0003ffff, 0x00002880);
+               nvkm_mask(device, 0x122318, 0x0003ffff, 0x00001000);
+               nvkm_mask(device, 0x12231c, 0x0003ffff, 0x00000200);
+               nvkm_mask(device, 0x122310, 0x0003ffff, 0x00000800);
+               nvkm_mask(device, 0x122348, 0x0003ffff, 0x00000100);
+               nvkm_mask(device, 0x1223b0, 0x0003ffff, 0x00000fff);
+               nvkm_mask(device, 0x122348, 0x0003ffff, 0x00000200);
+               nvkm_mask(device, 0x122358, 0x0003ffff, 0x00002880);
        }
        return ret;
 }
index 7bdedc53e1b4482a17b991ef14bbd28c10e4e2a2..1b676aaecc88994de47b41510330fb449b620cc8 100644 (file)
 static void
 gk20a_ibus_init_ibus_ring(struct nvkm_ibus *ibus)
 {
-       nv_mask(ibus, 0x137250, 0x3f, 0);
+       struct nvkm_device *device = ibus->subdev.device;
+       nvkm_mask(device, 0x137250, 0x3f, 0);
 
-       nv_mask(ibus, 0x000200, 0x20, 0);
+       nvkm_mask(device, 0x000200, 0x20, 0);
        usleep_range(20, 30);
-       nv_mask(ibus, 0x000200, 0x20, 0x20);
+       nvkm_mask(device, 0x000200, 0x20, 0x20);
 
-       nv_wr32(ibus, 0x12004c, 0x4);
-       nv_wr32(ibus, 0x122204, 0x2);
-       nv_rd32(ibus, 0x122204);
+       nvkm_wr32(device, 0x12004c, 0x4);
+       nvkm_wr32(device, 0x122204, 0x2);
+       nvkm_rd32(device, 0x122204);
 
        /*
         * Bug: increase clock timeout to avoid operation failure at high
         * gpcclk rate.
         */
-       nv_wr32(ibus, 0x122354, 0x800);
-       nv_wr32(ibus, 0x128328, 0x800);
-       nv_wr32(ibus, 0x124320, 0x800);
+       nvkm_wr32(device, 0x122354, 0x800);
+       nvkm_wr32(device, 0x128328, 0x800);
+       nvkm_wr32(device, 0x124320, 0x800);
 }
 
 static void
 gk20a_ibus_intr(struct nvkm_subdev *subdev)
 {
        struct nvkm_ibus *ibus = (void *)subdev;
-       u32 status0 = nv_rd32(ibus, 0x120058);
+       struct nvkm_device *device = ibus->subdev.device;
+       u32 status0 = nvkm_rd32(device, 0x120058);
 
        if (status0 & 0x7) {
                nv_debug(ibus, "resetting ibus ring\n");
@@ -56,7 +58,7 @@ gk20a_ibus_intr(struct nvkm_subdev *subdev)
        }
 
        /* Acknowledge interrupt */
-       nv_mask(ibus, 0x12004c, 0x2, 0x2);
+       nvkm_mask(device, 0x12004c, 0x2, 0x2);
 
        if (!nv_wait(subdev, 0x12004c, 0x3f, 0x00))
                nv_warn(ibus, "timeout waiting for ringmaster ack\n");