} else
                return ret;
 
-       nv_wait(disp, 0x61a004 + doff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61a004 + doff) & 0x80000000))
+                       break;
+       );
        nvkm_mask(device, 0x61a004 + doff, 0xc000007f, 0x80000000 | stat);
-       nv_wait(disp, 0x61a004 + doff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61a004 + doff) & 0x80000000))
+                       break;
+       );
        return 0;
 }
 
                return ret;
 
        nvkm_mask(device, 0x61a004 + doff, 0x807f0000, 0x80150000);
-       nv_wait(disp, 0x61a004 + doff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61a004 + doff) & 0x80000000))
+                       break;
+       );
 
        nvkm_wr32(device, 0x61a00c + doff, 0x00100000 | loadval);
        mdelay(9);
        loadval = nvkm_mask(device, 0x61a00c + doff, 0xffffffff, 0x00000000);
 
        nvkm_mask(device, 0x61a004 + doff, 0x807f0000, 0x80550000);
-       nv_wait(disp, 0x61a004 + doff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61a004 + doff) & 0x80000000))
+                       break;
+       );
 
        nv_debug(disp, "DAC%d sense: 0x%08x\n", outp->or, loadval);
        if (!(loadval & 0x80000000))
 
        nvkm_wr32(device, 0x610490 + (chid * 0x0010), 0x00000013);
 
        /* wait for it to go inactive */
-       if (!nv_wait(disp, 0x610490 + (chid * 0x10), 0x80000000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610490 + (chid * 0x10)) & 0x80000000))
+                       break;
+       ) < 0) {
                nv_error(dmac, "init: 0x%08x\n",
                         nvkm_rd32(device, 0x610490 + (chid * 0x10)));
                return -EBUSY;
        /* deactivate channel */
        nvkm_mask(device, 0x610490 + (chid * 0x0010), 0x00001010, 0x00001000);
        nvkm_mask(device, 0x610490 + (chid * 0x0010), 0x00000003, 0x00000000);
-       if (!nv_wait(disp, 0x610490 + (chid * 0x10), 0x001e0000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610490 + (chid * 0x10)) & 0x001e0000))
+                       break;
+       ) < 0) {
                nv_error(dmac, "fini: 0x%08x\n",
                         nvkm_rd32(device, 0x610490 + (chid * 0x10)));
                if (suspend)
        nvkm_wr32(device, 0x610490, 0x01000013);
 
        /* wait for it to go inactive */
-       if (!nv_wait(disp, 0x610490, 0x80000000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610490) & 0x80000000))
+                       break;
+       ) < 0) {
                nv_error(mast, "init: 0x%08x\n", nvkm_rd32(device, 0x610490));
                return -EBUSY;
        }
        /* deactivate channel */
        nvkm_mask(device, 0x610490, 0x00000010, 0x00000000);
        nvkm_mask(device, 0x610490, 0x00000003, 0x00000000);
-       if (!nv_wait(disp, 0x610490, 0x001e0000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610490) & 0x001e0000))
+                       break;
+       ) < 0) {
                nv_error(mast, "fini: 0x%08x\n", nvkm_rd32(device, 0x610490));
                if (suspend)
                        return -EBUSY;
 
        /* activate channel */
        nvkm_wr32(device, 0x610490 + (chid * 0x10), 0x00000001);
-       if (!nv_wait(disp, 0x610490 + (chid * 0x10), 0x00030000, 0x00010000)) {
+       if (nvkm_msec(device, 2000,
+               u32 tmp = nvkm_rd32(device, 0x610490 + (chid * 0x10));
+               if ((tmp & 0x00030000) == 0x00010000)
+                       break;
+       ) < 0) {
                nv_error(pioc, "init: 0x%08x\n",
                         nvkm_rd32(device, 0x610490 + (chid * 0x10)));
                return -EBUSY;
        int chid = pioc->base.chid;
 
        nvkm_mask(device, 0x610490 + (chid * 0x10), 0x00000001, 0x00000000);
-       if (!nv_wait(disp, 0x610490 + (chid * 0x10), 0x00030000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610490 + (chid * 0x10)) & 0x00030000))
+                       break;
+       ) < 0) {
                nv_error(pioc, "timeout: 0x%08x\n",
                         nvkm_rd32(device, 0x610490 + (chid * 0x10)));
                if (suspend)
        if (nvkm_rd32(device, 0x6100ac) & 0x00000100) {
                nvkm_wr32(device, 0x6100ac, 0x00000100);
                nvkm_mask(device, 0x6194e8, 0x00000001, 0x00000000);
-               if (!nv_wait(disp, 0x6194e8, 0x00000002, 0x00000000)) {
-                       nv_error(disp, "timeout acquiring display\n");
+               if (nvkm_msec(device, 2000,
+                       if (!(nvkm_rd32(device, 0x6194e8) & 0x00000002))
+                               break;
+               ) < 0)
                        return -EBUSY;
-               }
        }
 
        /* point at display engine memory area (hash table, objects) */
 
        if (size && args->v0.data[0]) {
                if (outp->info.type == DCB_OUTPUT_DP) {
                        nvkm_mask(device, 0x616618 + hoff, 0x8000000c, 0x80000001);
-                       nv_wait(disp, 0x616618 + hoff, 0x80000000, 0x00000000);
+                       nvkm_msec(device, 2000,
+                               u32 tmp = nvkm_rd32(device, 0x616618 + hoff);
+                               if (!(tmp & 0x80000000))
+                                       break;
+                       );
                }
                nvkm_mask(device, 0x616548 + hoff, 0x00000070, 0x00000000);
                for (i = 0; i < size; i++)
        } else {
                if (outp->info.type == DCB_OUTPUT_DP) {
                        nvkm_mask(device, 0x616618 + hoff, 0x80000001, 0x80000000);
-                       nv_wait(disp, 0x616618 + hoff, 0x80000000, 0x00000000);
+                       nvkm_msec(device, 2000,
+                               u32 tmp = nvkm_rd32(device, 0x616618 + hoff);
+                               if (!(tmp & 0x80000000))
+                                       break;
+                       );
                }
                nvkm_mask(device, 0x10ec10 + soff, 0x80000003, 0x80000000 | !!size);
        }
 
        if (size && args->v0.data[0]) {
                if (outp->info.type == DCB_OUTPUT_DP) {
                        nvkm_mask(device, 0x61c1e0 + soff, 0x8000000d, 0x80000001);
-                       nv_wait(disp, 0x61c1e0 + soff, 0x80000000, 0x00000000);
+                       nvkm_msec(device, 2000,
+                               u32 tmp = nvkm_rd32(device, 0x61c1e0 + soff);
+                               if (!(tmp & 0x80000000))
+                                       break;
+                       );
                }
                for (i = 0; i < size; i++)
                        nvkm_wr32(device, 0x61c440 + soff, (i << 8) | args->v0.data[0]);
        } else {
                if (outp->info.type == DCB_OUTPUT_DP) {
                        nvkm_mask(device, 0x61c1e0 + soff, 0x80000001, 0x80000000);
-                       nv_wait(disp, 0x61c1e0 + soff, 0x80000000, 0x00000000);
+                       nvkm_msec(device, 2000,
+                               u32 tmp = nvkm_rd32(device, 0x61c1e0 + soff);
+                               if (!(tmp & 0x80000000))
+                                       break;
+                       );
                }
                nvkm_mask(device, 0x61c448 + soff, 0x80000003, 0x80000000 | !!size);
        }
 
        nvkm_wr32(device, 0x610200 + (chid * 0x0010), 0x00000013);
 
        /* wait for it to go inactive */
-       if (!nv_wait(disp, 0x610200 + (chid * 0x10), 0x80000000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610200 + (chid * 0x10)) & 0x80000000))
+                       break;
+       ) < 0) {
                nv_error(dmac, "init timeout, 0x%08x\n",
                         nvkm_rd32(device, 0x610200 + (chid * 0x10)));
                return -EBUSY;
        /* deactivate channel */
        nvkm_mask(device, 0x610200 + (chid * 0x0010), 0x00001010, 0x00001000);
        nvkm_mask(device, 0x610200 + (chid * 0x0010), 0x00000003, 0x00000000);
-       if (!nv_wait(disp, 0x610200 + (chid * 0x10), 0x001e0000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610200 + (chid * 0x10)) & 0x001e0000))
+                       break;
+       ) < 0) {
                nv_error(dmac, "fini timeout, 0x%08x\n",
                         nvkm_rd32(device, 0x610200 + (chid * 0x10)));
                if (suspend)
        nvkm_wr32(device, 0x610200, 0x01000013);
 
        /* wait for it to go inactive */
-       if (!nv_wait(disp, 0x610200, 0x80000000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610200) & 0x80000000))
+                       break;
+       ) < 0) {
                nv_error(mast, "init: 0x%08x\n", nvkm_rd32(device, 0x610200));
                return -EBUSY;
        }
        /* deactivate channel */
        nvkm_mask(device, 0x610200, 0x00000010, 0x00000000);
        nvkm_mask(device, 0x610200, 0x00000003, 0x00000000);
-       if (!nv_wait(disp, 0x610200, 0x001e0000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610200) & 0x001e0000))
+                       break;
+       ) < 0) {
                nv_error(mast, "fini: 0x%08x\n", nvkm_rd32(device, 0x610200));
                if (suspend)
                        return -EBUSY;
                return ret;
 
        nvkm_wr32(device, 0x610200 + (chid * 0x10), 0x00002000);
-       if (!nv_wait(disp, 0x610200 + (chid * 0x10), 0x00000000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610200 + (chid * 0x10)) & 0x00030000))
+                       break;
+       ) < 0) {
                nv_error(pioc, "timeout0: 0x%08x\n",
                         nvkm_rd32(device, 0x610200 + (chid * 0x10)));
                return -EBUSY;
        }
 
        nvkm_wr32(device, 0x610200 + (chid * 0x10), 0x00000001);
-       if (!nv_wait(disp, 0x610200 + (chid * 0x10), 0x00030000, 0x00010000)) {
+       if (nvkm_msec(device, 2000,
+               u32 tmp = nvkm_rd32(device, 0x610200 + (chid * 0x10));
+               if ((tmp & 0x00030000) == 0x00010000)
+                       break;
+       ) < 0) {
                nv_error(pioc, "timeout1: 0x%08x\n",
                         nvkm_rd32(device, 0x610200 + (chid * 0x10)));
                return -EBUSY;
        int chid = pioc->base.chid;
 
        nvkm_mask(device, 0x610200 + (chid * 0x10), 0x00000001, 0x00000000);
-       if (!nv_wait(disp, 0x610200 + (chid * 0x10), 0x00030000, 0x00000000)) {
+       if (nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x610200 + (chid * 0x10)) & 0x00030000))
+                       break;
+       ) < 0) {
                nv_error(pioc, "timeout: 0x%08x\n",
                         nvkm_rd32(device, 0x610200 + (chid * 0x10)));
                if (suspend)
        if (nvkm_rd32(device, 0x610024) & 0x00000100) {
                nvkm_wr32(device, 0x610024, 0x00000100);
                nvkm_mask(device, 0x6194e8, 0x00000001, 0x00000000);
-               if (!nv_wait(disp, 0x6194e8, 0x00000002, 0x00000000)) {
-                       nv_error(disp, "timeout acquiring display\n");
+               if (nvkm_msec(device, 2000,
+                       if (!(nvkm_rd32(device, 0x6194e8) & 0x00000002))
+                               break;
+               ) < 0)
                        return -EBUSY;
-               }
        }
 
        /* point at display engine memory area (hash table, objects) */
 
        } else
                return ret;
 
-       nv_wait(disp, 0x61e004 + soff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61e004 + soff) & 0x80000000))
+                       break;
+       );
        nvkm_mask(device, 0x61e004 + soff, 0x80000101, 0x80000000 | ctrl);
-       nv_wait(disp, 0x61e004 + soff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61e004 + soff) & 0x80000000))
+                       break;
+       );
        disp->pior.type[outp->or] = type;
        return 0;
 }
 
 
        nvkm_mask(device, 0x61c130 + loff, 0x0000000f, mask);
        nvkm_mask(device, 0x61c034 + soff, 0x80000000, 0x80000000);
-       nv_wait(disp, 0x61c034 + soff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61c034 + soff) & 0x80000000))
+                       break;
+       );
        return 0;
 }
 
 
 
        nvkm_mask(device, 0x61c130 + loff, 0x0000000f, mask);
        nvkm_mask(device, 0x61c034 + soff, 0x80000000, 0x80000000);
-       nv_wait(disp, 0x61c034 + soff, 0x80000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61c034 + soff) & 0x80000000))
+                       break;
+       );
        return 0;
 }
 
 
        } else
                return ret;
 
-       nv_wait(disp, 0x61c004 + soff, 0x80000000, 0x00000000);
+
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61c004 + soff) & 0x80000000))
+                       break;
+       );
        nvkm_mask(device, 0x61c004 + soff, 0x80000001, 0x80000000 | stat);
-       nv_wait(disp, 0x61c004 + soff, 0x80000000, 0x00000000);
-       nv_wait(disp, 0x61c030 + soff, 0x10000000, 0x00000000);
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61c004 + soff) & 0x80000000))
+                       break;
+       );
+       nvkm_msec(device, 2000,
+               if (!(nvkm_rd32(device, 0x61c030 + soff) & 0x10000000))
+                       break;
+       );
        return 0;
 }