Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

drm/nvc0: implement pgraph engine hooks

Signed-off-by: Ben Skeggs <bskeggs@redhat.com>

+3631 -3
+1 -1
drivers/gpu/drm/nouveau/Makefile
··· 18 18 nv04_fifo.o nv10_fifo.o nv40_fifo.o nv50_fifo.o nvc0_fifo.o \ 19 19 nv04_graph.o nv10_graph.o nv20_graph.o \ 20 20 nv40_graph.o nv50_graph.o nvc0_graph.o \ 21 - nv40_grctx.o nv50_grctx.o \ 21 + nv40_grctx.o nv50_grctx.o nvc0_grctx.o \ 22 22 nv84_crypt.o \ 23 23 nv04_instmem.o nv50_instmem.o nvc0_instmem.o \ 24 24 nv50_evo.o nv50_crtc.o nv50_dac.o nv50_sor.o \
+1 -1
drivers/gpu/drm/nouveau/nouveau_bo.c
··· 839 839 } 840 840 841 841 /* Software copy if the card isn't up and running yet. */ 842 - if (!dev_priv->channel) { 842 + if (!dev_priv->channel || dev_priv->card_type == NV_C0) { 843 843 ret = ttm_bo_move_memcpy(bo, evict, no_wait_reserve, no_wait_gpu, new_mem); 844 844 goto out; 845 845 }
+1
drivers/gpu/drm/nouveau/nouveau_drv.h
··· 365 365 bool accel_blocked; 366 366 bool registered; 367 367 int grctx_size; 368 + void *priv; 368 369 369 370 /* NV2x/NV3x context table (0x400780) */ 370 371 struct nouveau_gpuobj *ctx_table;
+708 -1
drivers/gpu/drm/nouveau/nvc0_graph.c
··· 22 22 * Authors: Ben Skeggs 23 23 */ 24 24 25 + #include <linux/firmware.h> 26 + 25 27 #include "drmP.h" 26 28 27 29 #include "nouveau_drv.h" 30 + #include "nouveau_mm.h" 31 + #include "nvc0_graph.h" 32 + 33 + static void nvc0_graph_isr(struct drm_device *); 34 + static int nvc0_graph_unload_context_to(struct drm_device *dev, u64 chan); 28 35 29 36 void 30 37 nvc0_graph_fifo_access(struct drm_device *dev, bool enabled) ··· 44 37 return NULL; 45 38 } 46 39 40 + static int 41 + nvc0_graph_construct_context(struct nouveau_channel *chan) 42 + { 43 + struct drm_nouveau_private *dev_priv = chan->dev->dev_private; 44 + struct nvc0_graph_priv *priv = dev_priv->engine.graph.priv; 45 + struct nvc0_graph_chan *grch = chan->pgraph_ctx; 46 + struct drm_device *dev = chan->dev; 47 + int ret, i; 48 + u32 *ctx; 49 + 50 + ctx = kmalloc(priv->grctx_size, GFP_KERNEL); 51 + if (!ctx) 52 + return -ENOMEM; 53 + 54 + nvc0_graph_load_context(chan); 55 + 56 + nv_wo32(grch->grctx, 0x1c, 1); 57 + nv_wo32(grch->grctx, 0x20, 0); 58 + nv_wo32(grch->grctx, 0x28, 0); 59 + nv_wo32(grch->grctx, 0x2c, 0); 60 + dev_priv->engine.instmem.flush(dev); 61 + 62 + ret = nvc0_grctx_generate(chan); 63 + if (ret) { 64 + kfree(ctx); 65 + return ret; 66 + } 67 + 68 + ret = nvc0_graph_unload_context_to(dev, chan->ramin->vinst); 69 + if (ret) { 70 + kfree(ctx); 71 + return ret; 72 + } 73 + 74 + for (i = 0; i < priv->grctx_size; i += 4) 75 + ctx[i / 4] = nv_ro32(grch->grctx, i); 76 + 77 + priv->grctx_vals = ctx; 78 + return 0; 79 + } 80 + 81 + static int 82 + nvc0_graph_create_context_mmio_list(struct nouveau_channel *chan) 83 + { 84 + struct drm_nouveau_private *dev_priv = chan->dev->dev_private; 85 + struct nvc0_graph_priv *priv = dev_priv->engine.graph.priv; 86 + struct nvc0_graph_chan *grch = chan->pgraph_ctx; 87 + struct drm_device *dev = chan->dev; 88 + int i = 0, gpc, tp, ret; 89 + u32 magic; 90 + 91 + ret = nouveau_gpuobj_new(dev, NULL, 0x2000, 256, NVOBJ_FLAG_VM, 92 + &grch->unk408004); 93 + if (ret) 94 + return ret; 95 + 96 + ret = nouveau_gpuobj_new(dev, NULL, 0x8000, 256, NVOBJ_FLAG_VM, 97 + &grch->unk40800c); 98 + if (ret) 99 + return ret; 100 + 101 + ret = nouveau_gpuobj_new(dev, NULL, 384 * 1024, 4096, NVOBJ_FLAG_VM, 102 + &grch->unk418810); 103 + if (ret) 104 + return ret; 105 + 106 + ret = nouveau_gpuobj_new(dev, NULL, 0x1000, 0, NVOBJ_FLAG_VM, 107 + &grch->mmio); 108 + if (ret) 109 + return ret; 110 + 111 + 112 + nv_wo32(grch->mmio, i++ * 4, 0x00408004); 113 + nv_wo32(grch->mmio, i++ * 4, grch->unk408004->vinst >> 8); 114 + nv_wo32(grch->mmio, i++ * 4, 0x00408008); 115 + nv_wo32(grch->mmio, i++ * 4, 0x80000018); 116 + 117 + nv_wo32(grch->mmio, i++ * 4, 0x0040800c); 118 + nv_wo32(grch->mmio, i++ * 4, grch->unk40800c->vinst >> 8); 119 + nv_wo32(grch->mmio, i++ * 4, 0x00408010); 120 + nv_wo32(grch->mmio, i++ * 4, 0x80000000); 121 + 122 + nv_wo32(grch->mmio, i++ * 4, 0x00418810); 123 + nv_wo32(grch->mmio, i++ * 4, 0x80000000 | grch->unk418810->vinst >> 12); 124 + nv_wo32(grch->mmio, i++ * 4, 0x00419848); 125 + nv_wo32(grch->mmio, i++ * 4, 0x10000000 | grch->unk418810->vinst >> 12); 126 + 127 + nv_wo32(grch->mmio, i++ * 4, 0x00419004); 128 + nv_wo32(grch->mmio, i++ * 4, grch->unk40800c->vinst >> 8); 129 + nv_wo32(grch->mmio, i++ * 4, 0x00419008); 130 + nv_wo32(grch->mmio, i++ * 4, 0x00000000); 131 + 132 + nv_wo32(grch->mmio, i++ * 4, 0x00418808); 133 + nv_wo32(grch->mmio, i++ * 4, grch->unk408004->vinst >> 8); 134 + nv_wo32(grch->mmio, i++ * 4, 0x0041880c); 135 + nv_wo32(grch->mmio, i++ * 4, 0x80000018); 136 + 137 + magic = 0x02180000; 138 + nv_wo32(grch->mmio, i++ * 4, 0x00405830); 139 + nv_wo32(grch->mmio, i++ * 4, magic); 140 + for (gpc = 0; gpc < priv->gpc_nr; gpc++) { 141 + for (tp = 0; tp < priv->tp_nr[gpc]; tp++, magic += 0x02fc) { 142 + u32 reg = 0x504520 + (gpc * 0x8000) + (tp * 0x0800); 143 + nv_wo32(grch->mmio, i++ * 4, reg); 144 + nv_wo32(grch->mmio, i++ * 4, magic); 145 + } 146 + } 147 + 148 + grch->mmio_nr = i / 2; 149 + return 0; 150 + } 151 + 47 152 int 48 153 nvc0_graph_create_context(struct nouveau_channel *chan) 49 154 { 155 + struct drm_nouveau_private *dev_priv = chan->dev->dev_private; 156 + struct nouveau_instmem_engine *pinstmem = &dev_priv->engine.instmem; 157 + struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; 158 + struct nvc0_graph_priv *priv = pgraph->priv; 159 + struct nvc0_graph_chan *grch; 160 + struct drm_device *dev = chan->dev; 161 + struct nouveau_gpuobj *grctx; 162 + int ret, i; 163 + 164 + chan->pgraph_ctx = kzalloc(sizeof(*grch), GFP_KERNEL); 165 + if (!chan->pgraph_ctx) 166 + return -ENOMEM; 167 + grch = chan->pgraph_ctx; 168 + 169 + ret = nouveau_gpuobj_new(dev, NULL, priv->grctx_size, 256, 170 + NVOBJ_FLAG_VM | NVOBJ_FLAG_ZERO_ALLOC, 171 + &grch->grctx); 172 + if (ret) 173 + goto error; 174 + chan->ramin_grctx = grch->grctx; 175 + grctx = grch->grctx; 176 + 177 + ret = nvc0_graph_create_context_mmio_list(chan); 178 + if (ret) 179 + goto error; 180 + 181 + nv_wo32(chan->ramin, 0x0210, lower_32_bits(grctx->vinst) | 4); 182 + nv_wo32(chan->ramin, 0x0214, upper_32_bits(grctx->vinst)); 183 + pinstmem->flush(dev); 184 + 185 + if (!priv->grctx_vals) { 186 + ret = nvc0_graph_construct_context(chan); 187 + if (ret) 188 + goto error; 189 + } 190 + 191 + for (i = 0; i < priv->grctx_size; i += 4) 192 + nv_wo32(grctx, i, priv->grctx_vals[i / 4]); 193 + 194 + nv_wo32(grctx, 0xf4, 0); 195 + nv_wo32(grctx, 0xf8, 0); 196 + nv_wo32(grctx, 0x10, grch->mmio_nr); 197 + nv_wo32(grctx, 0x14, lower_32_bits(grch->mmio->vinst)); 198 + nv_wo32(grctx, 0x18, upper_32_bits(grch->mmio->vinst)); 199 + nv_wo32(grctx, 0x1c, 1); 200 + nv_wo32(grctx, 0x20, 0); 201 + nv_wo32(grctx, 0x28, 0); 202 + nv_wo32(grctx, 0x2c, 0); 203 + pinstmem->flush(dev); 50 204 return 0; 205 + 206 + error: 207 + pgraph->destroy_context(chan); 208 + return ret; 51 209 } 52 210 53 211 void 54 212 nvc0_graph_destroy_context(struct nouveau_channel *chan) 55 213 { 214 + struct nvc0_graph_chan *grch; 215 + 216 + grch = chan->pgraph_ctx; 217 + chan->pgraph_ctx = NULL; 218 + if (!grch) 219 + return; 220 + 221 + nouveau_gpuobj_ref(NULL, &grch->mmio); 222 + nouveau_gpuobj_ref(NULL, &grch->unk418810); 223 + nouveau_gpuobj_ref(NULL, &grch->unk40800c); 224 + nouveau_gpuobj_ref(NULL, &grch->unk408004); 225 + nouveau_gpuobj_ref(NULL, &grch->grctx); 226 + chan->ramin_grctx = NULL; 56 227 } 57 228 58 229 int 59 230 nvc0_graph_load_context(struct nouveau_channel *chan) 60 231 { 232 + struct drm_device *dev = chan->dev; 233 + 234 + nv_wr32(dev, 0x409840, 0x00000030); 235 + nv_wr32(dev, 0x409500, 0x80000000 | chan->ramin->vinst >> 12); 236 + nv_wr32(dev, 0x409504, 0x00000003); 237 + if (!nv_wait(dev, 0x409800, 0x00000010, 0x00000010)) 238 + NV_ERROR(dev, "PGRAPH: load_ctx timeout\n"); 239 + 240 + printk(KERN_ERR "load_ctx 0x%08x\n", nv_rd32(dev, 0x409b00)); 241 + return 0; 242 + } 243 + 244 + static int 245 + nvc0_graph_unload_context_to(struct drm_device *dev, u64 chan) 246 + { 247 + nv_wr32(dev, 0x409840, 0x00000003); 248 + nv_wr32(dev, 0x409500, 0x80000000 | chan >> 12); 249 + nv_wr32(dev, 0x409504, 0x00000009); 250 + if (!nv_wait(dev, 0x409800, 0x00000001, 0x00000000)) { 251 + NV_ERROR(dev, "PGRAPH: unload_ctx timeout\n"); 252 + return -EBUSY; 253 + } 254 + 61 255 return 0; 62 256 } 63 257 64 258 int 65 259 nvc0_graph_unload_context(struct drm_device *dev) 66 260 { 67 - return 0; 261 + u64 inst = (u64)(nv_rd32(dev, 0x409b00) & 0x0fffffff) << 12; 262 + return nvc0_graph_unload_context_to(dev, inst); 263 + } 264 + 265 + static void 266 + nvc0_graph_destroy(struct drm_device *dev) 267 + { 268 + struct drm_nouveau_private *dev_priv = dev->dev_private; 269 + struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; 270 + struct nvc0_graph_priv *priv; 271 + 272 + priv = pgraph->priv; 273 + if (!priv) 274 + return; 275 + 276 + nouveau_irq_unregister(dev, 12); 277 + 278 + nouveau_gpuobj_ref(NULL, &priv->unk4188b8); 279 + nouveau_gpuobj_ref(NULL, &priv->unk4188b4); 280 + 281 + if (priv->grctx_vals) 282 + kfree(priv->grctx_vals); 283 + kfree(priv); 68 284 } 69 285 70 286 void 71 287 nvc0_graph_takedown(struct drm_device *dev) 72 288 { 289 + nvc0_graph_destroy(dev); 290 + } 291 + 292 + static int 293 + nvc0_graph_create(struct drm_device *dev) 294 + { 295 + struct drm_nouveau_private *dev_priv = dev->dev_private; 296 + struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; 297 + struct nvc0_graph_priv *priv; 298 + int ret, gpc, i; 299 + 300 + priv = kzalloc(sizeof(*priv), GFP_KERNEL); 301 + if (!priv) 302 + return -ENOMEM; 303 + pgraph->priv = priv; 304 + 305 + ret = nouveau_gpuobj_new(dev, NULL, 0x1000, 256, 0, &priv->unk4188b4); 306 + if (ret) 307 + goto error; 308 + 309 + ret = nouveau_gpuobj_new(dev, NULL, 0x1000, 256, 0, &priv->unk4188b8); 310 + if (ret) 311 + goto error; 312 + 313 + for (i = 0; i < 0x1000; i += 4) { 314 + nv_wo32(priv->unk4188b4, i, 0x00000010); 315 + nv_wo32(priv->unk4188b8, i, 0x00000010); 316 + } 317 + 318 + priv->gpc_nr = nv_rd32(dev, 0x409604) & 0x0000001f; 319 + priv->rop_nr = (nv_rd32(dev, 0x409604) & 0x001f0000) >> 16; 320 + for (gpc = 0; gpc < priv->gpc_nr; gpc++) { 321 + priv->tp_nr[gpc] = nv_rd32(dev, GPC_UNIT(gpc, 0x2608)); 322 + priv->tp_total += priv->tp_nr[gpc]; 323 + } 324 + 325 + /*XXX: these need figuring out... */ 326 + switch (dev_priv->chipset) { 327 + case 0xc0: 328 + if (priv->tp_total == 11) { /* 465, 3/4/4/0, 4 */ 329 + priv->magic_not_rop_nr = 0x07; 330 + priv->magic419bd0 = 0x0a360000; 331 + priv->magic419be4 = 0x04c33a54; 332 + /* filled values up to tp_total, the rest 0 */ 333 + priv->magicgpc980[0] = 0x22111000; 334 + priv->magicgpc980[1] = 0x00000233; 335 + priv->magicgpc980[2] = 0x00000000; 336 + priv->magicgpc980[3] = 0x00000000; 337 + priv->magicgpc918 = 0x000ba2e9; 338 + } else 339 + if (priv->tp_total == 14) { /* 470, 3/3/4/4, 5 */ 340 + priv->magic_not_rop_nr = 0x05; 341 + priv->magic419bd0 = 0x043c0000; 342 + priv->magic419be4 = 0x09041208; 343 + priv->magicgpc980[0] = 0x11110000; 344 + priv->magicgpc980[1] = 0x00233222; 345 + priv->magicgpc980[2] = 0x00000000; 346 + priv->magicgpc980[3] = 0x00000000; 347 + priv->magicgpc918 = 0x00092493; 348 + } else 349 + if (priv->tp_total == 15) { /* 480, 3/4/4/4, 6 */ 350 + priv->magic_not_rop_nr = 0x06; 351 + priv->magic419bd0 = 0x023e0000; 352 + priv->magic419be4 = 0x10414104; 353 + priv->magicgpc980[0] = 0x11110000; 354 + priv->magicgpc980[1] = 0x03332222; 355 + priv->magicgpc980[2] = 0x00000000; 356 + priv->magicgpc980[3] = 0x00000000; 357 + priv->magicgpc918 = 0x00088889; 358 + } 359 + break; 360 + case 0xc3: /* 450, 4/0/0/0, 2 */ 361 + priv->magic_not_rop_nr = 0x03; 362 + priv->magic419bd0 = 0x00500000; 363 + priv->magic419be4 = 0x00000000; 364 + priv->magicgpc980[0] = 0x00003210; 365 + priv->magicgpc980[1] = 0x00000000; 366 + priv->magicgpc980[2] = 0x00000000; 367 + priv->magicgpc980[3] = 0x00000000; 368 + priv->magicgpc918 = 0x00200000; 369 + break; 370 + case 0xc4: /* 460, 3/4/0/0, 4 */ 371 + priv->magic_not_rop_nr = 0x01; 372 + priv->magic419bd0 = 0x045c0000; 373 + priv->magic419be4 = 0x09041208; 374 + priv->magicgpc980[0] = 0x02321100; 375 + priv->magicgpc980[1] = 0x00000000; 376 + priv->magicgpc980[2] = 0x00000000; 377 + priv->magicgpc980[3] = 0x00000000; 378 + priv->magicgpc918 = 0x00124925; 379 + break; 380 + } 381 + 382 + if (!priv->magic419bd0) { 383 + NV_ERROR(dev, "PGRAPH: unknown config: %d/%d/%d/%d, %d\n", 384 + priv->tp_nr[0], priv->tp_nr[1], priv->tp_nr[2], 385 + priv->tp_nr[3], priv->rop_nr); 386 + /* use 0xc3's values... */ 387 + priv->magic_not_rop_nr = 0x03; 388 + priv->magic419bd0 = 0x00500000; 389 + priv->magic419be4 = 0x00000000; 390 + priv->magicgpc980[0] = 0x00003210; 391 + priv->magicgpc980[1] = 0x00000000; 392 + priv->magicgpc980[2] = 0x00000000; 393 + priv->magicgpc980[3] = 0x00000000; 394 + priv->magicgpc918 = 0x00200000; 395 + } 396 + 397 + nouveau_irq_register(dev, 12, nvc0_graph_isr); 398 + NVOBJ_CLASS(dev, 0x902d, GR); /* 2D */ 399 + NVOBJ_CLASS(dev, 0x9039, GR); /* M2MF */ 400 + NVOBJ_CLASS(dev, 0x9097, GR); /* 3D */ 401 + NVOBJ_CLASS(dev, 0x90c0, GR); /* COMPUTE */ 402 + return 0; 403 + 404 + error: 405 + nvc0_graph_destroy(dev); 406 + return ret; 407 + } 408 + 409 + static void 410 + nvc0_graph_init_obj418880(struct drm_device *dev) 411 + { 412 + struct drm_nouveau_private *dev_priv = dev->dev_private; 413 + struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; 414 + struct nvc0_graph_priv *priv = pgraph->priv; 415 + int i; 416 + 417 + nv_wr32(dev, GPC_BCAST(0x0880), 0x00000000); 418 + nv_wr32(dev, GPC_BCAST(0x08a4), 0x00000000); 419 + for (i = 0; i < 4; i++) 420 + nv_wr32(dev, GPC_BCAST(0x0888) + (i * 4), 0x00000000); 421 + nv_wr32(dev, GPC_BCAST(0x08b4), priv->unk4188b4->vinst >> 8); 422 + nv_wr32(dev, GPC_BCAST(0x08b8), priv->unk4188b8->vinst >> 8); 423 + } 424 + 425 + static void 426 + nvc0_graph_init_regs(struct drm_device *dev) 427 + { 428 + nv_wr32(dev, 0x400080, 0x003083c2); 429 + nv_wr32(dev, 0x400088, 0x00006fe7); 430 + nv_wr32(dev, 0x40008c, 0x00000000); 431 + nv_wr32(dev, 0x400090, 0x00000030); 432 + nv_wr32(dev, 0x40013c, 0x013901f7); 433 + nv_wr32(dev, 0x400140, 0x00000100); 434 + nv_wr32(dev, 0x400144, 0x00000000); 435 + nv_wr32(dev, 0x400148, 0x00000110); 436 + nv_wr32(dev, 0x400138, 0x00000000); 437 + nv_wr32(dev, 0x400130, 0x00000000); 438 + nv_wr32(dev, 0x400134, 0x00000000); 439 + nv_wr32(dev, 0x400124, 0x00000002); 440 + } 441 + 442 + static void 443 + nvc0_graph_init_gpc_0(struct drm_device *dev) 444 + { 445 + struct drm_nouveau_private *dev_priv = dev->dev_private; 446 + struct nvc0_graph_priv *priv = dev_priv->engine.graph.priv; 447 + int gpc; 448 + 449 + // TP ROP UNKVAL(magic_not_rop_nr) 450 + // 450: 4/0/0/0 2 3 451 + // 460: 3/4/0/0 4 1 452 + // 465: 3/4/4/0 4 7 453 + // 470: 3/3/4/4 5 5 454 + // 480: 3/4/4/4 6 6 455 + 456 + // magicgpc918 457 + // 450: 00200000 00000000001000000000000000000000 458 + // 460: 00124925 00000000000100100100100100100101 459 + // 465: 000ba2e9 00000000000010111010001011101001 460 + // 470: 00092493 00000000000010010010010010010011 461 + // 480: 00088889 00000000000010001000100010001001 462 + 463 + /* filled values up to tp_total, remainder 0 */ 464 + // 450: 00003210 00000000 00000000 00000000 465 + // 460: 02321100 00000000 00000000 00000000 466 + // 465: 22111000 00000233 00000000 00000000 467 + // 470: 11110000 00233222 00000000 00000000 468 + // 480: 11110000 03332222 00000000 00000000 469 + 470 + nv_wr32(dev, GPC_BCAST(0x0980), priv->magicgpc980[0]); 471 + nv_wr32(dev, GPC_BCAST(0x0984), priv->magicgpc980[1]); 472 + nv_wr32(dev, GPC_BCAST(0x0988), priv->magicgpc980[2]); 473 + nv_wr32(dev, GPC_BCAST(0x098c), priv->magicgpc980[3]); 474 + 475 + for (gpc = 0; gpc < priv->gpc_nr; gpc++) { 476 + nv_wr32(dev, GPC_UNIT(gpc, 0x0914), priv->magic_not_rop_nr << 8 | 477 + priv->tp_nr[gpc]); 478 + nv_wr32(dev, GPC_UNIT(gpc, 0x0910), 0x00040000 | priv->tp_total); 479 + nv_wr32(dev, GPC_UNIT(gpc, 0x0918), priv->magicgpc918); 480 + } 481 + 482 + nv_wr32(dev, GPC_BCAST(0x1bd4), priv->magicgpc918); 483 + nv_wr32(dev, GPC_BCAST(0x08ac), priv->rop_nr); 484 + } 485 + 486 + static void 487 + nvc0_graph_init_units(struct drm_device *dev) 488 + { 489 + nv_wr32(dev, 0x409c24, 0x000f0000); 490 + nv_wr32(dev, 0x404000, 0xc0000000); /* DISPATCH */ 491 + nv_wr32(dev, 0x404600, 0xc0000000); /* M2MF */ 492 + nv_wr32(dev, 0x408030, 0xc0000000); 493 + nv_wr32(dev, 0x40601c, 0xc0000000); 494 + nv_wr32(dev, 0x404490, 0xc0000000); /* MACRO */ 495 + nv_wr32(dev, 0x406018, 0xc0000000); 496 + nv_wr32(dev, 0x405840, 0xc0000000); 497 + nv_wr32(dev, 0x405844, 0x00ffffff); 498 + nv_mask(dev, 0x419cc0, 0x00000008, 0x00000008); 499 + nv_mask(dev, 0x419eb4, 0x00001000, 0x00001000); 500 + } 501 + 502 + static void 503 + nvc0_graph_init_gpc_1(struct drm_device *dev) 504 + { 505 + struct drm_nouveau_private *dev_priv = dev->dev_private; 506 + struct nvc0_graph_priv *priv = dev_priv->engine.graph.priv; 507 + int gpc, tp; 508 + 509 + for (gpc = 0; gpc < priv->gpc_nr; gpc++) { 510 + nv_wr32(dev, GPC_UNIT(gpc, 0x0420), 0xc0000000); 511 + nv_wr32(dev, GPC_UNIT(gpc, 0x0900), 0xc0000000); 512 + nv_wr32(dev, GPC_UNIT(gpc, 0x1028), 0xc0000000); 513 + nv_wr32(dev, GPC_UNIT(gpc, 0x0824), 0xc0000000); 514 + for (tp = 0; tp < priv->tp_nr[gpc]; tp++) { 515 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x508), 0xffffffff); 516 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x50c), 0xffffffff); 517 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x224), 0xc0000000); 518 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x48c), 0xc0000000); 519 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x084), 0xc0000000); 520 + nv_wr32(dev, TP_UNIT(gpc, tp, 0xe44), 0x001ffffe); 521 + nv_wr32(dev, TP_UNIT(gpc, tp, 0xe4c), 0x0000000f); 522 + } 523 + nv_wr32(dev, GPC_UNIT(gpc, 0x2c90), 0xffffffff); 524 + nv_wr32(dev, GPC_UNIT(gpc, 0x2c94), 0xffffffff); 525 + } 526 + } 527 + 528 + static void 529 + nvc0_graph_init_rop(struct drm_device *dev) 530 + { 531 + struct drm_nouveau_private *dev_priv = dev->dev_private; 532 + struct nvc0_graph_priv *priv = dev_priv->engine.graph.priv; 533 + int rop; 534 + 535 + for (rop = 0; rop < priv->rop_nr; rop++) { 536 + nv_wr32(dev, ROP_UNIT(rop, 0x144), 0xc0000000); 537 + nv_wr32(dev, ROP_UNIT(rop, 0x070), 0xc0000000); 538 + nv_wr32(dev, ROP_UNIT(rop, 0x204), 0xffffffff); 539 + nv_wr32(dev, ROP_UNIT(rop, 0x208), 0xffffffff); 540 + } 541 + } 542 + 543 + static int 544 + nvc0_fuc_load_fw(struct drm_device *dev, u32 fuc_base, 545 + const char *code_fw, const char *data_fw) 546 + { 547 + const struct firmware *fw; 548 + char name[32]; 549 + int ret, i; 550 + 551 + snprintf(name, sizeof(name), "nouveau/%s", data_fw); 552 + ret = request_firmware(&fw, name, &dev->pdev->dev); 553 + if (ret) { 554 + NV_ERROR(dev, "failed to load %s\n", data_fw); 555 + return ret; 556 + } 557 + 558 + nv_wr32(dev, fuc_base + 0x01c0, 0x01000000); 559 + for (i = 0; i < fw->size / 4; i++) 560 + nv_wr32(dev, fuc_base + 0x01c4, ((u32 *)fw->data)[i]); 561 + release_firmware(fw); 562 + 563 + snprintf(name, sizeof(name), "nouveau/%s", code_fw); 564 + ret = request_firmware(&fw, name, &dev->pdev->dev); 565 + if (ret) { 566 + NV_ERROR(dev, "failed to load %s\n", code_fw); 567 + return ret; 568 + } 569 + 570 + nv_wr32(dev, fuc_base + 0x0180, 0x01000000); 571 + for (i = 0; i < fw->size / 4; i++) { 572 + if ((i & 0x3f) == 0) 573 + nv_wr32(dev, fuc_base + 0x0188, i >> 6); 574 + nv_wr32(dev, fuc_base + 0x0184, ((u32 *)fw->data)[i]); 575 + } 576 + release_firmware(fw); 577 + 578 + return 0; 579 + } 580 + 581 + static int 582 + nvc0_graph_init_ctxctl(struct drm_device *dev) 583 + { 584 + struct drm_nouveau_private *dev_priv = dev->dev_private; 585 + struct nvc0_graph_priv *priv = dev_priv->engine.graph.priv; 586 + u32 r000260; 587 + int ret; 588 + 589 + /* load fuc microcode */ 590 + r000260 = nv_mask(dev, 0x000260, 0x00000001, 0x00000000); 591 + ret = nvc0_fuc_load_fw(dev, 0x409000, "fuc409c", "fuc409d"); 592 + if (ret == 0) 593 + nvc0_fuc_load_fw(dev, 0x41a000, "fuc41ac", "fuc41ad"); 594 + nv_wr32(dev, 0x000260, r000260); 595 + 596 + if (ret) 597 + return ret; 598 + 599 + /* start both of them running */ 600 + nv_wr32(dev, 0x409840, 0xffffffff); 601 + nv_wr32(dev, 0x41a10c, 0x00000000); 602 + nv_wr32(dev, 0x40910c, 0x00000000); 603 + nv_wr32(dev, 0x41a100, 0x00000002); 604 + nv_wr32(dev, 0x409100, 0x00000002); 605 + if (!nv_wait(dev, 0x409800, 0x00000001, 0x00000001)) 606 + NV_INFO(dev, "0x409800 wait failed\n"); 607 + 608 + nv_wr32(dev, 0x409840, 0xffffffff); 609 + nv_wr32(dev, 0x409500, 0x7fffffff); 610 + nv_wr32(dev, 0x409504, 0x00000021); 611 + 612 + nv_wr32(dev, 0x409840, 0xffffffff); 613 + nv_wr32(dev, 0x409500, 0x00000000); 614 + nv_wr32(dev, 0x409504, 0x00000010); 615 + if (!nv_wait_ne(dev, 0x409800, 0xffffffff, 0x00000000)) { 616 + NV_ERROR(dev, "fuc09 req 0x10 timeout\n"); 617 + return -EBUSY; 618 + } 619 + priv->grctx_size = nv_rd32(dev, 0x409800); 620 + 621 + nv_wr32(dev, 0x409840, 0xffffffff); 622 + nv_wr32(dev, 0x409500, 0x00000000); 623 + nv_wr32(dev, 0x409504, 0x00000016); 624 + if (!nv_wait_ne(dev, 0x409800, 0xffffffff, 0x00000000)) { 625 + NV_ERROR(dev, "fuc09 req 0x16 timeout\n"); 626 + return -EBUSY; 627 + } 628 + 629 + nv_wr32(dev, 0x409840, 0xffffffff); 630 + nv_wr32(dev, 0x409500, 0x00000000); 631 + nv_wr32(dev, 0x409504, 0x00000025); 632 + if (!nv_wait_ne(dev, 0x409800, 0xffffffff, 0x00000000)) { 633 + NV_ERROR(dev, "fuc09 req 0x25 timeout\n"); 634 + return -EBUSY; 635 + } 636 + 637 + return 0; 73 638 } 74 639 75 640 int 76 641 nvc0_graph_init(struct drm_device *dev) 77 642 { 78 643 struct drm_nouveau_private *dev_priv = dev->dev_private; 644 + struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; 645 + struct nvc0_graph_priv *priv; 646 + int ret; 647 + 79 648 dev_priv->engine.graph.accel_blocked = true; 649 + 650 + switch (dev_priv->chipset) { 651 + case 0xc0: 652 + case 0xc3: 653 + case 0xc4: 654 + break; 655 + default: 656 + NV_ERROR(dev, "PGRAPH: unsupported chipset, please report!\n"); 657 + if (nouveau_noaccel != 0) 658 + return 0; 659 + break; 660 + } 661 + 662 + nv_mask(dev, 0x000200, 0x18001000, 0x00000000); 663 + nv_mask(dev, 0x000200, 0x18001000, 0x18001000); 664 + 665 + if (!pgraph->priv) { 666 + ret = nvc0_graph_create(dev); 667 + if (ret) 668 + return ret; 669 + } 670 + priv = pgraph->priv; 671 + 672 + nvc0_graph_init_obj418880(dev); 673 + nvc0_graph_init_regs(dev); 674 + //nvc0_graph_init_unitplemented_magics(dev); 675 + nvc0_graph_init_gpc_0(dev); 676 + //nvc0_graph_init_unitplemented_c242(dev); 677 + 678 + nv_wr32(dev, 0x400500, 0x00010001); 679 + nv_wr32(dev, 0x400100, 0xffffffff); 680 + nv_wr32(dev, 0x40013c, 0xffffffff); 681 + 682 + nvc0_graph_init_units(dev); 683 + nvc0_graph_init_gpc_1(dev); 684 + nvc0_graph_init_rop(dev); 685 + 686 + nv_wr32(dev, 0x400108, 0xffffffff); 687 + nv_wr32(dev, 0x400138, 0xffffffff); 688 + nv_wr32(dev, 0x400118, 0xffffffff); 689 + nv_wr32(dev, 0x400130, 0xffffffff); 690 + nv_wr32(dev, 0x40011c, 0xffffffff); 691 + nv_wr32(dev, 0x400134, 0xffffffff); 692 + nv_wr32(dev, 0x400054, 0x34ce3464); 693 + 694 + ret = nvc0_graph_init_ctxctl(dev); 695 + if (ret) 696 + return ret; 697 + 698 + dev_priv->engine.graph.accel_blocked = false; 80 699 return 0; 81 700 } 82 701 702 + static struct nouveau_enum nvc0_graph_data_error[] = { 703 + { 5, "INVALID_ENUM" }, 704 + {} 705 + }; 706 + 707 + static int 708 + nvc0_graph_isr_chid(struct drm_device *dev, u64 inst) 709 + { 710 + struct drm_nouveau_private *dev_priv = dev->dev_private; 711 + struct nouveau_channel *chan; 712 + unsigned long flags; 713 + int i; 714 + 715 + spin_lock_irqsave(&dev_priv->channels.lock, flags); 716 + for (i = 0; i < dev_priv->engine.fifo.channels; i++) { 717 + chan = dev_priv->channels.ptr[i]; 718 + if (!chan || !chan->ramin) 719 + continue; 720 + 721 + if (inst == chan->ramin->vinst) 722 + break; 723 + } 724 + spin_unlock_irqrestore(&dev_priv->channels.lock, flags); 725 + return i; 726 + } 727 + 728 + static void 729 + nvc0_graph_isr(struct drm_device *dev) 730 + { 731 + u64 inst = (u64)(nv_rd32(dev, 0x409b00) & 0x0fffffff) << 12; 732 + u32 chid = nvc0_graph_isr_chid(dev, inst); 733 + u32 stat = nv_rd32(dev, 0x400100); 734 + u32 addr = nv_rd32(dev, 0x400704); 735 + u32 mthd = (addr & 0x00003ffc); 736 + u32 subc = (addr & 0x00070000) >> 16; 737 + u32 data = nv_rd32(dev, 0x400708); 738 + u32 code = nv_rd32(dev, 0x400110); 739 + u32 class = nv_rd32(dev, 0x404200 + (subc * 4)); 740 + 741 + if (stat & 0x00000010) { 742 + NV_INFO(dev, "PGRAPH: ILLEGAL_MTHD ch %d [0x%010llx] subc %d " 743 + "class 0x%04x mthd 0x%04x data 0x%08x\n", 744 + chid, inst, subc, class, mthd, data); 745 + nv_wr32(dev, 0x400100, 0x00000010); 746 + stat &= ~0x00000010; 747 + } 748 + 749 + if (stat & 0x00100000) { 750 + NV_INFO(dev, "PGRAPH: DATA_ERROR ["); 751 + nouveau_enum_print(nvc0_graph_data_error, code); 752 + printk("] ch %d [0x%010llx] subc %d class 0x%04x " 753 + "mthd 0x%04x data 0x%08x\n", 754 + chid, inst, subc, class, mthd, data); 755 + nv_wr32(dev, 0x400100, 0x00100000); 756 + stat &= ~0x00100000; 757 + } 758 + 759 + if (stat & 0x00080000) { 760 + u32 ustat = nv_rd32(dev, 0x409c18); 761 + 762 + NV_INFO(dev, "PGRAPH: CTXCTRL ustat 0x%08x\n", ustat); 763 + 764 + nv_wr32(dev, 0x409c20, ustat); 765 + nv_wr32(dev, 0x400100, 0x00080000); 766 + stat &= ~0x00080000; 767 + } 768 + 769 + if (stat) { 770 + NV_INFO(dev, "PGRAPH: unknown stat 0x%08x\n", stat); 771 + nv_wr32(dev, 0x400100, stat); 772 + } 773 + 774 + nv_wr32(dev, 0x400500, 0x00010001); 775 + }
+66
drivers/gpu/drm/nouveau/nvc0_graph.h
··· 1 + /* 2 + * Copyright 2010 Red Hat Inc. 3 + * 4 + * Permission is hereby granted, free of charge, to any person obtaining a 5 + * copy of this software and associated documentation files (the "Software"), 6 + * to deal in the Software without restriction, including without limitation 7 + * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 + * and/or sell copies of the Software, and to permit persons to whom the 9 + * Software is furnished to do so, subject to the following conditions: 10 + * 11 + * The above copyright notice and this permission notice shall be included in 12 + * all copies or substantial portions of the Software. 13 + * 14 + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15 + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 17 + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 18 + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 19 + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 20 + * OTHER DEALINGS IN THE SOFTWARE. 21 + * 22 + * Authors: Ben Skeggs 23 + */ 24 + 25 + #ifndef __NVC0_GRAPH_H__ 26 + #define __NVC0_GRAPH_H__ 27 + 28 + #define GPC_MAX 4 29 + #define TP_MAX 32 30 + 31 + #define ROP_BCAST(r) (0x408800 + (r)) 32 + #define ROP_UNIT(u,r) (0x410000 + (u) * 0x400 + (r)) 33 + #define GPC_BCAST(r) (0x418000 + (r)) 34 + #define GPC_UNIT(t,r) (0x500000 + (t) * 0x8000 + (r)) 35 + #define TP_UNIT(t,m,r) (0x504000 + (t) * 0x8000 + (m) * 0x800 + (r)) 36 + 37 + struct nvc0_graph_priv { 38 + u8 gpc_nr; 39 + u8 rop_nr; 40 + u8 tp_nr[GPC_MAX]; 41 + u8 tp_total; 42 + 43 + u32 grctx_size; 44 + u32 *grctx_vals; 45 + struct nouveau_gpuobj *unk4188b4; 46 + struct nouveau_gpuobj *unk4188b8; 47 + 48 + u8 magic_not_rop_nr; 49 + u32 magic419bd0; 50 + u32 magic419be4; 51 + u32 magicgpc980[4]; 52 + u32 magicgpc918; 53 + }; 54 + 55 + struct nvc0_graph_chan { 56 + struct nouveau_gpuobj *grctx; 57 + struct nouveau_gpuobj *unk408004; // 0x418810 too 58 + struct nouveau_gpuobj *unk40800c; // 0x419004 too 59 + struct nouveau_gpuobj *unk418810; // 0x419848 too 60 + struct nouveau_gpuobj *mmio; 61 + int mmio_nr; 62 + }; 63 + 64 + int nvc0_grctx_generate(struct nouveau_channel *); 65 + 66 + #endif
+2854
drivers/gpu/drm/nouveau/nvc0_grctx.c
··· 1 + /* 2 + * Copyright 2010 Red Hat Inc. 3 + * 4 + * Permission is hereby granted, free of charge, to any person obtaining a 5 + * copy of this software and associated documentation files (the "Software"), 6 + * to deal in the Software without restriction, including without limitation 7 + * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 + * and/or sell copies of the Software, and to permit persons to whom the 9 + * Software is furnished to do so, subject to the following conditions: 10 + * 11 + * The above copyright notice and this permission notice shall be included in 12 + * all copies or substantial portions of the Software. 13 + * 14 + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15 + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 17 + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 18 + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 19 + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 20 + * OTHER DEALINGS IN THE SOFTWARE. 21 + * 22 + * Authors: Ben Skeggs 23 + */ 24 + 25 + #include "drmP.h" 26 + #include "nouveau_drv.h" 27 + #include "nouveau_mm.h" 28 + #include "nvc0_graph.h" 29 + 30 + static void 31 + nv_icmd(struct drm_device *dev, u32 icmd, u32 data) 32 + { 33 + nv_wr32(dev, 0x400204, data); 34 + nv_wr32(dev, 0x400200, icmd); 35 + while (nv_rd32(dev, 0x400700) & 2) {} 36 + } 37 + 38 + static void 39 + nv_mthd(struct drm_device *dev, u32 class, u32 mthd, u32 data) 40 + { 41 + nv_wr32(dev, 0x40448c, data); 42 + nv_wr32(dev, 0x404488, 0x80000000 | (mthd << 14) | class); 43 + } 44 + 45 + static void 46 + nvc0_grctx_generate_9097(struct drm_device *dev) 47 + { 48 + nv_mthd(dev, 0x9097, 0x0800, 0x00000000); 49 + nv_mthd(dev, 0x9097, 0x0840, 0x00000000); 50 + nv_mthd(dev, 0x9097, 0x0880, 0x00000000); 51 + nv_mthd(dev, 0x9097, 0x08c0, 0x00000000); 52 + nv_mthd(dev, 0x9097, 0x0900, 0x00000000); 53 + nv_mthd(dev, 0x9097, 0x0940, 0x00000000); 54 + nv_mthd(dev, 0x9097, 0x0980, 0x00000000); 55 + nv_mthd(dev, 0x9097, 0x09c0, 0x00000000); 56 + nv_mthd(dev, 0x9097, 0x0804, 0x00000000); 57 + nv_mthd(dev, 0x9097, 0x0844, 0x00000000); 58 + nv_mthd(dev, 0x9097, 0x0884, 0x00000000); 59 + nv_mthd(dev, 0x9097, 0x08c4, 0x00000000); 60 + nv_mthd(dev, 0x9097, 0x0904, 0x00000000); 61 + nv_mthd(dev, 0x9097, 0x0944, 0x00000000); 62 + nv_mthd(dev, 0x9097, 0x0984, 0x00000000); 63 + nv_mthd(dev, 0x9097, 0x09c4, 0x00000000); 64 + nv_mthd(dev, 0x9097, 0x0808, 0x00000400); 65 + nv_mthd(dev, 0x9097, 0x0848, 0x00000400); 66 + nv_mthd(dev, 0x9097, 0x0888, 0x00000400); 67 + nv_mthd(dev, 0x9097, 0x08c8, 0x00000400); 68 + nv_mthd(dev, 0x9097, 0x0908, 0x00000400); 69 + nv_mthd(dev, 0x9097, 0x0948, 0x00000400); 70 + nv_mthd(dev, 0x9097, 0x0988, 0x00000400); 71 + nv_mthd(dev, 0x9097, 0x09c8, 0x00000400); 72 + nv_mthd(dev, 0x9097, 0x080c, 0x00000300); 73 + nv_mthd(dev, 0x9097, 0x084c, 0x00000300); 74 + nv_mthd(dev, 0x9097, 0x088c, 0x00000300); 75 + nv_mthd(dev, 0x9097, 0x08cc, 0x00000300); 76 + nv_mthd(dev, 0x9097, 0x090c, 0x00000300); 77 + nv_mthd(dev, 0x9097, 0x094c, 0x00000300); 78 + nv_mthd(dev, 0x9097, 0x098c, 0x00000300); 79 + nv_mthd(dev, 0x9097, 0x09cc, 0x00000300); 80 + nv_mthd(dev, 0x9097, 0x0810, 0x000000cf); 81 + nv_mthd(dev, 0x9097, 0x0850, 0x00000000); 82 + nv_mthd(dev, 0x9097, 0x0890, 0x00000000); 83 + nv_mthd(dev, 0x9097, 0x08d0, 0x00000000); 84 + nv_mthd(dev, 0x9097, 0x0910, 0x00000000); 85 + nv_mthd(dev, 0x9097, 0x0950, 0x00000000); 86 + nv_mthd(dev, 0x9097, 0x0990, 0x00000000); 87 + nv_mthd(dev, 0x9097, 0x09d0, 0x00000000); 88 + nv_mthd(dev, 0x9097, 0x0814, 0x00000040); 89 + nv_mthd(dev, 0x9097, 0x0854, 0x00000040); 90 + nv_mthd(dev, 0x9097, 0x0894, 0x00000040); 91 + nv_mthd(dev, 0x9097, 0x08d4, 0x00000040); 92 + nv_mthd(dev, 0x9097, 0x0914, 0x00000040); 93 + nv_mthd(dev, 0x9097, 0x0954, 0x00000040); 94 + nv_mthd(dev, 0x9097, 0x0994, 0x00000040); 95 + nv_mthd(dev, 0x9097, 0x09d4, 0x00000040); 96 + nv_mthd(dev, 0x9097, 0x0818, 0x00000001); 97 + nv_mthd(dev, 0x9097, 0x0858, 0x00000001); 98 + nv_mthd(dev, 0x9097, 0x0898, 0x00000001); 99 + nv_mthd(dev, 0x9097, 0x08d8, 0x00000001); 100 + nv_mthd(dev, 0x9097, 0x0918, 0x00000001); 101 + nv_mthd(dev, 0x9097, 0x0958, 0x00000001); 102 + nv_mthd(dev, 0x9097, 0x0998, 0x00000001); 103 + nv_mthd(dev, 0x9097, 0x09d8, 0x00000001); 104 + nv_mthd(dev, 0x9097, 0x081c, 0x00000000); 105 + nv_mthd(dev, 0x9097, 0x085c, 0x00000000); 106 + nv_mthd(dev, 0x9097, 0x089c, 0x00000000); 107 + nv_mthd(dev, 0x9097, 0x08dc, 0x00000000); 108 + nv_mthd(dev, 0x9097, 0x091c, 0x00000000); 109 + nv_mthd(dev, 0x9097, 0x095c, 0x00000000); 110 + nv_mthd(dev, 0x9097, 0x099c, 0x00000000); 111 + nv_mthd(dev, 0x9097, 0x09dc, 0x00000000); 112 + nv_mthd(dev, 0x9097, 0x0820, 0x00000000); 113 + nv_mthd(dev, 0x9097, 0x0860, 0x00000000); 114 + nv_mthd(dev, 0x9097, 0x08a0, 0x00000000); 115 + nv_mthd(dev, 0x9097, 0x08e0, 0x00000000); 116 + nv_mthd(dev, 0x9097, 0x0920, 0x00000000); 117 + nv_mthd(dev, 0x9097, 0x0960, 0x00000000); 118 + nv_mthd(dev, 0x9097, 0x09a0, 0x00000000); 119 + nv_mthd(dev, 0x9097, 0x09e0, 0x00000000); 120 + nv_mthd(dev, 0x9097, 0x2700, 0x00000000); 121 + nv_mthd(dev, 0x9097, 0x2720, 0x00000000); 122 + nv_mthd(dev, 0x9097, 0x2740, 0x00000000); 123 + nv_mthd(dev, 0x9097, 0x2760, 0x00000000); 124 + nv_mthd(dev, 0x9097, 0x2780, 0x00000000); 125 + nv_mthd(dev, 0x9097, 0x27a0, 0x00000000); 126 + nv_mthd(dev, 0x9097, 0x27c0, 0x00000000); 127 + nv_mthd(dev, 0x9097, 0x27e0, 0x00000000); 128 + nv_mthd(dev, 0x9097, 0x2704, 0x00000000); 129 + nv_mthd(dev, 0x9097, 0x2724, 0x00000000); 130 + nv_mthd(dev, 0x9097, 0x2744, 0x00000000); 131 + nv_mthd(dev, 0x9097, 0x2764, 0x00000000); 132 + nv_mthd(dev, 0x9097, 0x2784, 0x00000000); 133 + nv_mthd(dev, 0x9097, 0x27a4, 0x00000000); 134 + nv_mthd(dev, 0x9097, 0x27c4, 0x00000000); 135 + nv_mthd(dev, 0x9097, 0x27e4, 0x00000000); 136 + nv_mthd(dev, 0x9097, 0x2708, 0x00000000); 137 + nv_mthd(dev, 0x9097, 0x2728, 0x00000000); 138 + nv_mthd(dev, 0x9097, 0x2748, 0x00000000); 139 + nv_mthd(dev, 0x9097, 0x2768, 0x00000000); 140 + nv_mthd(dev, 0x9097, 0x2788, 0x00000000); 141 + nv_mthd(dev, 0x9097, 0x27a8, 0x00000000); 142 + nv_mthd(dev, 0x9097, 0x27c8, 0x00000000); 143 + nv_mthd(dev, 0x9097, 0x27e8, 0x00000000); 144 + nv_mthd(dev, 0x9097, 0x270c, 0x00000000); 145 + nv_mthd(dev, 0x9097, 0x272c, 0x00000000); 146 + nv_mthd(dev, 0x9097, 0x274c, 0x00000000); 147 + nv_mthd(dev, 0x9097, 0x276c, 0x00000000); 148 + nv_mthd(dev, 0x9097, 0x278c, 0x00000000); 149 + nv_mthd(dev, 0x9097, 0x27ac, 0x00000000); 150 + nv_mthd(dev, 0x9097, 0x27cc, 0x00000000); 151 + nv_mthd(dev, 0x9097, 0x27ec, 0x00000000); 152 + nv_mthd(dev, 0x9097, 0x2710, 0x00014000); 153 + nv_mthd(dev, 0x9097, 0x2730, 0x00014000); 154 + nv_mthd(dev, 0x9097, 0x2750, 0x00014000); 155 + nv_mthd(dev, 0x9097, 0x2770, 0x00014000); 156 + nv_mthd(dev, 0x9097, 0x2790, 0x00014000); 157 + nv_mthd(dev, 0x9097, 0x27b0, 0x00014000); 158 + nv_mthd(dev, 0x9097, 0x27d0, 0x00014000); 159 + nv_mthd(dev, 0x9097, 0x27f0, 0x00014000); 160 + nv_mthd(dev, 0x9097, 0x2714, 0x00000040); 161 + nv_mthd(dev, 0x9097, 0x2734, 0x00000040); 162 + nv_mthd(dev, 0x9097, 0x2754, 0x00000040); 163 + nv_mthd(dev, 0x9097, 0x2774, 0x00000040); 164 + nv_mthd(dev, 0x9097, 0x2794, 0x00000040); 165 + nv_mthd(dev, 0x9097, 0x27b4, 0x00000040); 166 + nv_mthd(dev, 0x9097, 0x27d4, 0x00000040); 167 + nv_mthd(dev, 0x9097, 0x27f4, 0x00000040); 168 + nv_mthd(dev, 0x9097, 0x1c00, 0x00000000); 169 + nv_mthd(dev, 0x9097, 0x1c10, 0x00000000); 170 + nv_mthd(dev, 0x9097, 0x1c20, 0x00000000); 171 + nv_mthd(dev, 0x9097, 0x1c30, 0x00000000); 172 + nv_mthd(dev, 0x9097, 0x1c40, 0x00000000); 173 + nv_mthd(dev, 0x9097, 0x1c50, 0x00000000); 174 + nv_mthd(dev, 0x9097, 0x1c60, 0x00000000); 175 + nv_mthd(dev, 0x9097, 0x1c70, 0x00000000); 176 + nv_mthd(dev, 0x9097, 0x1c80, 0x00000000); 177 + nv_mthd(dev, 0x9097, 0x1c90, 0x00000000); 178 + nv_mthd(dev, 0x9097, 0x1ca0, 0x00000000); 179 + nv_mthd(dev, 0x9097, 0x1cb0, 0x00000000); 180 + nv_mthd(dev, 0x9097, 0x1cc0, 0x00000000); 181 + nv_mthd(dev, 0x9097, 0x1cd0, 0x00000000); 182 + nv_mthd(dev, 0x9097, 0x1ce0, 0x00000000); 183 + nv_mthd(dev, 0x9097, 0x1cf0, 0x00000000); 184 + nv_mthd(dev, 0x9097, 0x1c04, 0x00000000); 185 + nv_mthd(dev, 0x9097, 0x1c14, 0x00000000); 186 + nv_mthd(dev, 0x9097, 0x1c24, 0x00000000); 187 + nv_mthd(dev, 0x9097, 0x1c34, 0x00000000); 188 + nv_mthd(dev, 0x9097, 0x1c44, 0x00000000); 189 + nv_mthd(dev, 0x9097, 0x1c54, 0x00000000); 190 + nv_mthd(dev, 0x9097, 0x1c64, 0x00000000); 191 + nv_mthd(dev, 0x9097, 0x1c74, 0x00000000); 192 + nv_mthd(dev, 0x9097, 0x1c84, 0x00000000); 193 + nv_mthd(dev, 0x9097, 0x1c94, 0x00000000); 194 + nv_mthd(dev, 0x9097, 0x1ca4, 0x00000000); 195 + nv_mthd(dev, 0x9097, 0x1cb4, 0x00000000); 196 + nv_mthd(dev, 0x9097, 0x1cc4, 0x00000000); 197 + nv_mthd(dev, 0x9097, 0x1cd4, 0x00000000); 198 + nv_mthd(dev, 0x9097, 0x1ce4, 0x00000000); 199 + nv_mthd(dev, 0x9097, 0x1cf4, 0x00000000); 200 + nv_mthd(dev, 0x9097, 0x1c08, 0x00000000); 201 + nv_mthd(dev, 0x9097, 0x1c18, 0x00000000); 202 + nv_mthd(dev, 0x9097, 0x1c28, 0x00000000); 203 + nv_mthd(dev, 0x9097, 0x1c38, 0x00000000); 204 + nv_mthd(dev, 0x9097, 0x1c48, 0x00000000); 205 + nv_mthd(dev, 0x9097, 0x1c58, 0x00000000); 206 + nv_mthd(dev, 0x9097, 0x1c68, 0x00000000); 207 + nv_mthd(dev, 0x9097, 0x1c78, 0x00000000); 208 + nv_mthd(dev, 0x9097, 0x1c88, 0x00000000); 209 + nv_mthd(dev, 0x9097, 0x1c98, 0x00000000); 210 + nv_mthd(dev, 0x9097, 0x1ca8, 0x00000000); 211 + nv_mthd(dev, 0x9097, 0x1cb8, 0x00000000); 212 + nv_mthd(dev, 0x9097, 0x1cc8, 0x00000000); 213 + nv_mthd(dev, 0x9097, 0x1cd8, 0x00000000); 214 + nv_mthd(dev, 0x9097, 0x1ce8, 0x00000000); 215 + nv_mthd(dev, 0x9097, 0x1cf8, 0x00000000); 216 + nv_mthd(dev, 0x9097, 0x1c0c, 0x00000000); 217 + nv_mthd(dev, 0x9097, 0x1c1c, 0x00000000); 218 + nv_mthd(dev, 0x9097, 0x1c2c, 0x00000000); 219 + nv_mthd(dev, 0x9097, 0x1c3c, 0x00000000); 220 + nv_mthd(dev, 0x9097, 0x1c4c, 0x00000000); 221 + nv_mthd(dev, 0x9097, 0x1c5c, 0x00000000); 222 + nv_mthd(dev, 0x9097, 0x1c6c, 0x00000000); 223 + nv_mthd(dev, 0x9097, 0x1c7c, 0x00000000); 224 + nv_mthd(dev, 0x9097, 0x1c8c, 0x00000000); 225 + nv_mthd(dev, 0x9097, 0x1c9c, 0x00000000); 226 + nv_mthd(dev, 0x9097, 0x1cac, 0x00000000); 227 + nv_mthd(dev, 0x9097, 0x1cbc, 0x00000000); 228 + nv_mthd(dev, 0x9097, 0x1ccc, 0x00000000); 229 + nv_mthd(dev, 0x9097, 0x1cdc, 0x00000000); 230 + nv_mthd(dev, 0x9097, 0x1cec, 0x00000000); 231 + nv_mthd(dev, 0x9097, 0x1cfc, 0x00000000); 232 + nv_mthd(dev, 0x9097, 0x1d00, 0x00000000); 233 + nv_mthd(dev, 0x9097, 0x1d10, 0x00000000); 234 + nv_mthd(dev, 0x9097, 0x1d20, 0x00000000); 235 + nv_mthd(dev, 0x9097, 0x1d30, 0x00000000); 236 + nv_mthd(dev, 0x9097, 0x1d40, 0x00000000); 237 + nv_mthd(dev, 0x9097, 0x1d50, 0x00000000); 238 + nv_mthd(dev, 0x9097, 0x1d60, 0x00000000); 239 + nv_mthd(dev, 0x9097, 0x1d70, 0x00000000); 240 + nv_mthd(dev, 0x9097, 0x1d80, 0x00000000); 241 + nv_mthd(dev, 0x9097, 0x1d90, 0x00000000); 242 + nv_mthd(dev, 0x9097, 0x1da0, 0x00000000); 243 + nv_mthd(dev, 0x9097, 0x1db0, 0x00000000); 244 + nv_mthd(dev, 0x9097, 0x1dc0, 0x00000000); 245 + nv_mthd(dev, 0x9097, 0x1dd0, 0x00000000); 246 + nv_mthd(dev, 0x9097, 0x1de0, 0x00000000); 247 + nv_mthd(dev, 0x9097, 0x1df0, 0x00000000); 248 + nv_mthd(dev, 0x9097, 0x1d04, 0x00000000); 249 + nv_mthd(dev, 0x9097, 0x1d14, 0x00000000); 250 + nv_mthd(dev, 0x9097, 0x1d24, 0x00000000); 251 + nv_mthd(dev, 0x9097, 0x1d34, 0x00000000); 252 + nv_mthd(dev, 0x9097, 0x1d44, 0x00000000); 253 + nv_mthd(dev, 0x9097, 0x1d54, 0x00000000); 254 + nv_mthd(dev, 0x9097, 0x1d64, 0x00000000); 255 + nv_mthd(dev, 0x9097, 0x1d74, 0x00000000); 256 + nv_mthd(dev, 0x9097, 0x1d84, 0x00000000); 257 + nv_mthd(dev, 0x9097, 0x1d94, 0x00000000); 258 + nv_mthd(dev, 0x9097, 0x1da4, 0x00000000); 259 + nv_mthd(dev, 0x9097, 0x1db4, 0x00000000); 260 + nv_mthd(dev, 0x9097, 0x1dc4, 0x00000000); 261 + nv_mthd(dev, 0x9097, 0x1dd4, 0x00000000); 262 + nv_mthd(dev, 0x9097, 0x1de4, 0x00000000); 263 + nv_mthd(dev, 0x9097, 0x1df4, 0x00000000); 264 + nv_mthd(dev, 0x9097, 0x1d08, 0x00000000); 265 + nv_mthd(dev, 0x9097, 0x1d18, 0x00000000); 266 + nv_mthd(dev, 0x9097, 0x1d28, 0x00000000); 267 + nv_mthd(dev, 0x9097, 0x1d38, 0x00000000); 268 + nv_mthd(dev, 0x9097, 0x1d48, 0x00000000); 269 + nv_mthd(dev, 0x9097, 0x1d58, 0x00000000); 270 + nv_mthd(dev, 0x9097, 0x1d68, 0x00000000); 271 + nv_mthd(dev, 0x9097, 0x1d78, 0x00000000); 272 + nv_mthd(dev, 0x9097, 0x1d88, 0x00000000); 273 + nv_mthd(dev, 0x9097, 0x1d98, 0x00000000); 274 + nv_mthd(dev, 0x9097, 0x1da8, 0x00000000); 275 + nv_mthd(dev, 0x9097, 0x1db8, 0x00000000); 276 + nv_mthd(dev, 0x9097, 0x1dc8, 0x00000000); 277 + nv_mthd(dev, 0x9097, 0x1dd8, 0x00000000); 278 + nv_mthd(dev, 0x9097, 0x1de8, 0x00000000); 279 + nv_mthd(dev, 0x9097, 0x1df8, 0x00000000); 280 + nv_mthd(dev, 0x9097, 0x1d0c, 0x00000000); 281 + nv_mthd(dev, 0x9097, 0x1d1c, 0x00000000); 282 + nv_mthd(dev, 0x9097, 0x1d2c, 0x00000000); 283 + nv_mthd(dev, 0x9097, 0x1d3c, 0x00000000); 284 + nv_mthd(dev, 0x9097, 0x1d4c, 0x00000000); 285 + nv_mthd(dev, 0x9097, 0x1d5c, 0x00000000); 286 + nv_mthd(dev, 0x9097, 0x1d6c, 0x00000000); 287 + nv_mthd(dev, 0x9097, 0x1d7c, 0x00000000); 288 + nv_mthd(dev, 0x9097, 0x1d8c, 0x00000000); 289 + nv_mthd(dev, 0x9097, 0x1d9c, 0x00000000); 290 + nv_mthd(dev, 0x9097, 0x1dac, 0x00000000); 291 + nv_mthd(dev, 0x9097, 0x1dbc, 0x00000000); 292 + nv_mthd(dev, 0x9097, 0x1dcc, 0x00000000); 293 + nv_mthd(dev, 0x9097, 0x1ddc, 0x00000000); 294 + nv_mthd(dev, 0x9097, 0x1dec, 0x00000000); 295 + nv_mthd(dev, 0x9097, 0x1dfc, 0x00000000); 296 + nv_mthd(dev, 0x9097, 0x1f00, 0x00000000); 297 + nv_mthd(dev, 0x9097, 0x1f08, 0x00000000); 298 + nv_mthd(dev, 0x9097, 0x1f10, 0x00000000); 299 + nv_mthd(dev, 0x9097, 0x1f18, 0x00000000); 300 + nv_mthd(dev, 0x9097, 0x1f20, 0x00000000); 301 + nv_mthd(dev, 0x9097, 0x1f28, 0x00000000); 302 + nv_mthd(dev, 0x9097, 0x1f30, 0x00000000); 303 + nv_mthd(dev, 0x9097, 0x1f38, 0x00000000); 304 + nv_mthd(dev, 0x9097, 0x1f40, 0x00000000); 305 + nv_mthd(dev, 0x9097, 0x1f48, 0x00000000); 306 + nv_mthd(dev, 0x9097, 0x1f50, 0x00000000); 307 + nv_mthd(dev, 0x9097, 0x1f58, 0x00000000); 308 + nv_mthd(dev, 0x9097, 0x1f60, 0x00000000); 309 + nv_mthd(dev, 0x9097, 0x1f68, 0x00000000); 310 + nv_mthd(dev, 0x9097, 0x1f70, 0x00000000); 311 + nv_mthd(dev, 0x9097, 0x1f78, 0x00000000); 312 + nv_mthd(dev, 0x9097, 0x1f04, 0x00000000); 313 + nv_mthd(dev, 0x9097, 0x1f0c, 0x00000000); 314 + nv_mthd(dev, 0x9097, 0x1f14, 0x00000000); 315 + nv_mthd(dev, 0x9097, 0x1f1c, 0x00000000); 316 + nv_mthd(dev, 0x9097, 0x1f24, 0x00000000); 317 + nv_mthd(dev, 0x9097, 0x1f2c, 0x00000000); 318 + nv_mthd(dev, 0x9097, 0x1f34, 0x00000000); 319 + nv_mthd(dev, 0x9097, 0x1f3c, 0x00000000); 320 + nv_mthd(dev, 0x9097, 0x1f44, 0x00000000); 321 + nv_mthd(dev, 0x9097, 0x1f4c, 0x00000000); 322 + nv_mthd(dev, 0x9097, 0x1f54, 0x00000000); 323 + nv_mthd(dev, 0x9097, 0x1f5c, 0x00000000); 324 + nv_mthd(dev, 0x9097, 0x1f64, 0x00000000); 325 + nv_mthd(dev, 0x9097, 0x1f6c, 0x00000000); 326 + nv_mthd(dev, 0x9097, 0x1f74, 0x00000000); 327 + nv_mthd(dev, 0x9097, 0x1f7c, 0x00000000); 328 + nv_mthd(dev, 0x9097, 0x1f80, 0x00000000); 329 + nv_mthd(dev, 0x9097, 0x1f88, 0x00000000); 330 + nv_mthd(dev, 0x9097, 0x1f90, 0x00000000); 331 + nv_mthd(dev, 0x9097, 0x1f98, 0x00000000); 332 + nv_mthd(dev, 0x9097, 0x1fa0, 0x00000000); 333 + nv_mthd(dev, 0x9097, 0x1fa8, 0x00000000); 334 + nv_mthd(dev, 0x9097, 0x1fb0, 0x00000000); 335 + nv_mthd(dev, 0x9097, 0x1fb8, 0x00000000); 336 + nv_mthd(dev, 0x9097, 0x1fc0, 0x00000000); 337 + nv_mthd(dev, 0x9097, 0x1fc8, 0x00000000); 338 + nv_mthd(dev, 0x9097, 0x1fd0, 0x00000000); 339 + nv_mthd(dev, 0x9097, 0x1fd8, 0x00000000); 340 + nv_mthd(dev, 0x9097, 0x1fe0, 0x00000000); 341 + nv_mthd(dev, 0x9097, 0x1fe8, 0x00000000); 342 + nv_mthd(dev, 0x9097, 0x1ff0, 0x00000000); 343 + nv_mthd(dev, 0x9097, 0x1ff8, 0x00000000); 344 + nv_mthd(dev, 0x9097, 0x1f84, 0x00000000); 345 + nv_mthd(dev, 0x9097, 0x1f8c, 0x00000000); 346 + nv_mthd(dev, 0x9097, 0x1f94, 0x00000000); 347 + nv_mthd(dev, 0x9097, 0x1f9c, 0x00000000); 348 + nv_mthd(dev, 0x9097, 0x1fa4, 0x00000000); 349 + nv_mthd(dev, 0x9097, 0x1fac, 0x00000000); 350 + nv_mthd(dev, 0x9097, 0x1fb4, 0x00000000); 351 + nv_mthd(dev, 0x9097, 0x1fbc, 0x00000000); 352 + nv_mthd(dev, 0x9097, 0x1fc4, 0x00000000); 353 + nv_mthd(dev, 0x9097, 0x1fcc, 0x00000000); 354 + nv_mthd(dev, 0x9097, 0x1fd4, 0x00000000); 355 + nv_mthd(dev, 0x9097, 0x1fdc, 0x00000000); 356 + nv_mthd(dev, 0x9097, 0x1fe4, 0x00000000); 357 + nv_mthd(dev, 0x9097, 0x1fec, 0x00000000); 358 + nv_mthd(dev, 0x9097, 0x1ff4, 0x00000000); 359 + nv_mthd(dev, 0x9097, 0x1ffc, 0x00000000); 360 + nv_mthd(dev, 0x9097, 0x2200, 0x00000022); 361 + nv_mthd(dev, 0x9097, 0x2210, 0x00000022); 362 + nv_mthd(dev, 0x9097, 0x2220, 0x00000022); 363 + nv_mthd(dev, 0x9097, 0x2230, 0x00000022); 364 + nv_mthd(dev, 0x9097, 0x2240, 0x00000022); 365 + nv_mthd(dev, 0x9097, 0x2000, 0x00000000); 366 + nv_mthd(dev, 0x9097, 0x2040, 0x00000011); 367 + nv_mthd(dev, 0x9097, 0x2080, 0x00000020); 368 + nv_mthd(dev, 0x9097, 0x20c0, 0x00000030); 369 + nv_mthd(dev, 0x9097, 0x2100, 0x00000040); 370 + nv_mthd(dev, 0x9097, 0x2140, 0x00000051); 371 + nv_mthd(dev, 0x9097, 0x200c, 0x00000001); 372 + nv_mthd(dev, 0x9097, 0x204c, 0x00000001); 373 + nv_mthd(dev, 0x9097, 0x208c, 0x00000001); 374 + nv_mthd(dev, 0x9097, 0x20cc, 0x00000001); 375 + nv_mthd(dev, 0x9097, 0x210c, 0x00000001); 376 + nv_mthd(dev, 0x9097, 0x214c, 0x00000001); 377 + nv_mthd(dev, 0x9097, 0x2010, 0x00000000); 378 + nv_mthd(dev, 0x9097, 0x2050, 0x00000000); 379 + nv_mthd(dev, 0x9097, 0x2090, 0x00000001); 380 + nv_mthd(dev, 0x9097, 0x20d0, 0x00000002); 381 + nv_mthd(dev, 0x9097, 0x2110, 0x00000003); 382 + nv_mthd(dev, 0x9097, 0x2150, 0x00000004); 383 + nv_mthd(dev, 0x9097, 0x0380, 0x00000000); 384 + nv_mthd(dev, 0x9097, 0x03a0, 0x00000000); 385 + nv_mthd(dev, 0x9097, 0x03c0, 0x00000000); 386 + nv_mthd(dev, 0x9097, 0x03e0, 0x00000000); 387 + nv_mthd(dev, 0x9097, 0x0384, 0x00000000); 388 + nv_mthd(dev, 0x9097, 0x03a4, 0x00000000); 389 + nv_mthd(dev, 0x9097, 0x03c4, 0x00000000); 390 + nv_mthd(dev, 0x9097, 0x03e4, 0x00000000); 391 + nv_mthd(dev, 0x9097, 0x0388, 0x00000000); 392 + nv_mthd(dev, 0x9097, 0x03a8, 0x00000000); 393 + nv_mthd(dev, 0x9097, 0x03c8, 0x00000000); 394 + nv_mthd(dev, 0x9097, 0x03e8, 0x00000000); 395 + nv_mthd(dev, 0x9097, 0x038c, 0x00000000); 396 + nv_mthd(dev, 0x9097, 0x03ac, 0x00000000); 397 + nv_mthd(dev, 0x9097, 0x03cc, 0x00000000); 398 + nv_mthd(dev, 0x9097, 0x03ec, 0x00000000); 399 + nv_mthd(dev, 0x9097, 0x0700, 0x00000000); 400 + nv_mthd(dev, 0x9097, 0x0710, 0x00000000); 401 + nv_mthd(dev, 0x9097, 0x0720, 0x00000000); 402 + nv_mthd(dev, 0x9097, 0x0730, 0x00000000); 403 + nv_mthd(dev, 0x9097, 0x0704, 0x00000000); 404 + nv_mthd(dev, 0x9097, 0x0714, 0x00000000); 405 + nv_mthd(dev, 0x9097, 0x0724, 0x00000000); 406 + nv_mthd(dev, 0x9097, 0x0734, 0x00000000); 407 + nv_mthd(dev, 0x9097, 0x0708, 0x00000000); 408 + nv_mthd(dev, 0x9097, 0x0718, 0x00000000); 409 + nv_mthd(dev, 0x9097, 0x0728, 0x00000000); 410 + nv_mthd(dev, 0x9097, 0x0738, 0x00000000); 411 + nv_mthd(dev, 0x9097, 0x2800, 0x00000000); 412 + nv_mthd(dev, 0x9097, 0x2804, 0x00000000); 413 + nv_mthd(dev, 0x9097, 0x2808, 0x00000000); 414 + nv_mthd(dev, 0x9097, 0x280c, 0x00000000); 415 + nv_mthd(dev, 0x9097, 0x2810, 0x00000000); 416 + nv_mthd(dev, 0x9097, 0x2814, 0x00000000); 417 + nv_mthd(dev, 0x9097, 0x2818, 0x00000000); 418 + nv_mthd(dev, 0x9097, 0x281c, 0x00000000); 419 + nv_mthd(dev, 0x9097, 0x2820, 0x00000000); 420 + nv_mthd(dev, 0x9097, 0x2824, 0x00000000); 421 + nv_mthd(dev, 0x9097, 0x2828, 0x00000000); 422 + nv_mthd(dev, 0x9097, 0x282c, 0x00000000); 423 + nv_mthd(dev, 0x9097, 0x2830, 0x00000000); 424 + nv_mthd(dev, 0x9097, 0x2834, 0x00000000); 425 + nv_mthd(dev, 0x9097, 0x2838, 0x00000000); 426 + nv_mthd(dev, 0x9097, 0x283c, 0x00000000); 427 + nv_mthd(dev, 0x9097, 0x2840, 0x00000000); 428 + nv_mthd(dev, 0x9097, 0x2844, 0x00000000); 429 + nv_mthd(dev, 0x9097, 0x2848, 0x00000000); 430 + nv_mthd(dev, 0x9097, 0x284c, 0x00000000); 431 + nv_mthd(dev, 0x9097, 0x2850, 0x00000000); 432 + nv_mthd(dev, 0x9097, 0x2854, 0x00000000); 433 + nv_mthd(dev, 0x9097, 0x2858, 0x00000000); 434 + nv_mthd(dev, 0x9097, 0x285c, 0x00000000); 435 + nv_mthd(dev, 0x9097, 0x2860, 0x00000000); 436 + nv_mthd(dev, 0x9097, 0x2864, 0x00000000); 437 + nv_mthd(dev, 0x9097, 0x2868, 0x00000000); 438 + nv_mthd(dev, 0x9097, 0x286c, 0x00000000); 439 + nv_mthd(dev, 0x9097, 0x2870, 0x00000000); 440 + nv_mthd(dev, 0x9097, 0x2874, 0x00000000); 441 + nv_mthd(dev, 0x9097, 0x2878, 0x00000000); 442 + nv_mthd(dev, 0x9097, 0x287c, 0x00000000); 443 + nv_mthd(dev, 0x9097, 0x2880, 0x00000000); 444 + nv_mthd(dev, 0x9097, 0x2884, 0x00000000); 445 + nv_mthd(dev, 0x9097, 0x2888, 0x00000000); 446 + nv_mthd(dev, 0x9097, 0x288c, 0x00000000); 447 + nv_mthd(dev, 0x9097, 0x2890, 0x00000000); 448 + nv_mthd(dev, 0x9097, 0x2894, 0x00000000); 449 + nv_mthd(dev, 0x9097, 0x2898, 0x00000000); 450 + nv_mthd(dev, 0x9097, 0x289c, 0x00000000); 451 + nv_mthd(dev, 0x9097, 0x28a0, 0x00000000); 452 + nv_mthd(dev, 0x9097, 0x28a4, 0x00000000); 453 + nv_mthd(dev, 0x9097, 0x28a8, 0x00000000); 454 + nv_mthd(dev, 0x9097, 0x28ac, 0x00000000); 455 + nv_mthd(dev, 0x9097, 0x28b0, 0x00000000); 456 + nv_mthd(dev, 0x9097, 0x28b4, 0x00000000); 457 + nv_mthd(dev, 0x9097, 0x28b8, 0x00000000); 458 + nv_mthd(dev, 0x9097, 0x28bc, 0x00000000); 459 + nv_mthd(dev, 0x9097, 0x28c0, 0x00000000); 460 + nv_mthd(dev, 0x9097, 0x28c4, 0x00000000); 461 + nv_mthd(dev, 0x9097, 0x28c8, 0x00000000); 462 + nv_mthd(dev, 0x9097, 0x28cc, 0x00000000); 463 + nv_mthd(dev, 0x9097, 0x28d0, 0x00000000); 464 + nv_mthd(dev, 0x9097, 0x28d4, 0x00000000); 465 + nv_mthd(dev, 0x9097, 0x28d8, 0x00000000); 466 + nv_mthd(dev, 0x9097, 0x28dc, 0x00000000); 467 + nv_mthd(dev, 0x9097, 0x28e0, 0x00000000); 468 + nv_mthd(dev, 0x9097, 0x28e4, 0x00000000); 469 + nv_mthd(dev, 0x9097, 0x28e8, 0x00000000); 470 + nv_mthd(dev, 0x9097, 0x28ec, 0x00000000); 471 + nv_mthd(dev, 0x9097, 0x28f0, 0x00000000); 472 + nv_mthd(dev, 0x9097, 0x28f4, 0x00000000); 473 + nv_mthd(dev, 0x9097, 0x28f8, 0x00000000); 474 + nv_mthd(dev, 0x9097, 0x28fc, 0x00000000); 475 + nv_mthd(dev, 0x9097, 0x2900, 0x00000000); 476 + nv_mthd(dev, 0x9097, 0x2904, 0x00000000); 477 + nv_mthd(dev, 0x9097, 0x2908, 0x00000000); 478 + nv_mthd(dev, 0x9097, 0x290c, 0x00000000); 479 + nv_mthd(dev, 0x9097, 0x2910, 0x00000000); 480 + nv_mthd(dev, 0x9097, 0x2914, 0x00000000); 481 + nv_mthd(dev, 0x9097, 0x2918, 0x00000000); 482 + nv_mthd(dev, 0x9097, 0x291c, 0x00000000); 483 + nv_mthd(dev, 0x9097, 0x2920, 0x00000000); 484 + nv_mthd(dev, 0x9097, 0x2924, 0x00000000); 485 + nv_mthd(dev, 0x9097, 0x2928, 0x00000000); 486 + nv_mthd(dev, 0x9097, 0x292c, 0x00000000); 487 + nv_mthd(dev, 0x9097, 0x2930, 0x00000000); 488 + nv_mthd(dev, 0x9097, 0x2934, 0x00000000); 489 + nv_mthd(dev, 0x9097, 0x2938, 0x00000000); 490 + nv_mthd(dev, 0x9097, 0x293c, 0x00000000); 491 + nv_mthd(dev, 0x9097, 0x2940, 0x00000000); 492 + nv_mthd(dev, 0x9097, 0x2944, 0x00000000); 493 + nv_mthd(dev, 0x9097, 0x2948, 0x00000000); 494 + nv_mthd(dev, 0x9097, 0x294c, 0x00000000); 495 + nv_mthd(dev, 0x9097, 0x2950, 0x00000000); 496 + nv_mthd(dev, 0x9097, 0x2954, 0x00000000); 497 + nv_mthd(dev, 0x9097, 0x2958, 0x00000000); 498 + nv_mthd(dev, 0x9097, 0x295c, 0x00000000); 499 + nv_mthd(dev, 0x9097, 0x2960, 0x00000000); 500 + nv_mthd(dev, 0x9097, 0x2964, 0x00000000); 501 + nv_mthd(dev, 0x9097, 0x2968, 0x00000000); 502 + nv_mthd(dev, 0x9097, 0x296c, 0x00000000); 503 + nv_mthd(dev, 0x9097, 0x2970, 0x00000000); 504 + nv_mthd(dev, 0x9097, 0x2974, 0x00000000); 505 + nv_mthd(dev, 0x9097, 0x2978, 0x00000000); 506 + nv_mthd(dev, 0x9097, 0x297c, 0x00000000); 507 + nv_mthd(dev, 0x9097, 0x2980, 0x00000000); 508 + nv_mthd(dev, 0x9097, 0x2984, 0x00000000); 509 + nv_mthd(dev, 0x9097, 0x2988, 0x00000000); 510 + nv_mthd(dev, 0x9097, 0x298c, 0x00000000); 511 + nv_mthd(dev, 0x9097, 0x2990, 0x00000000); 512 + nv_mthd(dev, 0x9097, 0x2994, 0x00000000); 513 + nv_mthd(dev, 0x9097, 0x2998, 0x00000000); 514 + nv_mthd(dev, 0x9097, 0x299c, 0x00000000); 515 + nv_mthd(dev, 0x9097, 0x29a0, 0x00000000); 516 + nv_mthd(dev, 0x9097, 0x29a4, 0x00000000); 517 + nv_mthd(dev, 0x9097, 0x29a8, 0x00000000); 518 + nv_mthd(dev, 0x9097, 0x29ac, 0x00000000); 519 + nv_mthd(dev, 0x9097, 0x29b0, 0x00000000); 520 + nv_mthd(dev, 0x9097, 0x29b4, 0x00000000); 521 + nv_mthd(dev, 0x9097, 0x29b8, 0x00000000); 522 + nv_mthd(dev, 0x9097, 0x29bc, 0x00000000); 523 + nv_mthd(dev, 0x9097, 0x29c0, 0x00000000); 524 + nv_mthd(dev, 0x9097, 0x29c4, 0x00000000); 525 + nv_mthd(dev, 0x9097, 0x29c8, 0x00000000); 526 + nv_mthd(dev, 0x9097, 0x29cc, 0x00000000); 527 + nv_mthd(dev, 0x9097, 0x29d0, 0x00000000); 528 + nv_mthd(dev, 0x9097, 0x29d4, 0x00000000); 529 + nv_mthd(dev, 0x9097, 0x29d8, 0x00000000); 530 + nv_mthd(dev, 0x9097, 0x29dc, 0x00000000); 531 + nv_mthd(dev, 0x9097, 0x29e0, 0x00000000); 532 + nv_mthd(dev, 0x9097, 0x29e4, 0x00000000); 533 + nv_mthd(dev, 0x9097, 0x29e8, 0x00000000); 534 + nv_mthd(dev, 0x9097, 0x29ec, 0x00000000); 535 + nv_mthd(dev, 0x9097, 0x29f0, 0x00000000); 536 + nv_mthd(dev, 0x9097, 0x29f4, 0x00000000); 537 + nv_mthd(dev, 0x9097, 0x29f8, 0x00000000); 538 + nv_mthd(dev, 0x9097, 0x29fc, 0x00000000); 539 + nv_mthd(dev, 0x9097, 0x0a00, 0x00000000); 540 + nv_mthd(dev, 0x9097, 0x0a20, 0x00000000); 541 + nv_mthd(dev, 0x9097, 0x0a40, 0x00000000); 542 + nv_mthd(dev, 0x9097, 0x0a60, 0x00000000); 543 + nv_mthd(dev, 0x9097, 0x0a80, 0x00000000); 544 + nv_mthd(dev, 0x9097, 0x0aa0, 0x00000000); 545 + nv_mthd(dev, 0x9097, 0x0ac0, 0x00000000); 546 + nv_mthd(dev, 0x9097, 0x0ae0, 0x00000000); 547 + nv_mthd(dev, 0x9097, 0x0b00, 0x00000000); 548 + nv_mthd(dev, 0x9097, 0x0b20, 0x00000000); 549 + nv_mthd(dev, 0x9097, 0x0b40, 0x00000000); 550 + nv_mthd(dev, 0x9097, 0x0b60, 0x00000000); 551 + nv_mthd(dev, 0x9097, 0x0b80, 0x00000000); 552 + nv_mthd(dev, 0x9097, 0x0ba0, 0x00000000); 553 + nv_mthd(dev, 0x9097, 0x0bc0, 0x00000000); 554 + nv_mthd(dev, 0x9097, 0x0be0, 0x00000000); 555 + nv_mthd(dev, 0x9097, 0x0a04, 0x00000000); 556 + nv_mthd(dev, 0x9097, 0x0a24, 0x00000000); 557 + nv_mthd(dev, 0x9097, 0x0a44, 0x00000000); 558 + nv_mthd(dev, 0x9097, 0x0a64, 0x00000000); 559 + nv_mthd(dev, 0x9097, 0x0a84, 0x00000000); 560 + nv_mthd(dev, 0x9097, 0x0aa4, 0x00000000); 561 + nv_mthd(dev, 0x9097, 0x0ac4, 0x00000000); 562 + nv_mthd(dev, 0x9097, 0x0ae4, 0x00000000); 563 + nv_mthd(dev, 0x9097, 0x0b04, 0x00000000); 564 + nv_mthd(dev, 0x9097, 0x0b24, 0x00000000); 565 + nv_mthd(dev, 0x9097, 0x0b44, 0x00000000); 566 + nv_mthd(dev, 0x9097, 0x0b64, 0x00000000); 567 + nv_mthd(dev, 0x9097, 0x0b84, 0x00000000); 568 + nv_mthd(dev, 0x9097, 0x0ba4, 0x00000000); 569 + nv_mthd(dev, 0x9097, 0x0bc4, 0x00000000); 570 + nv_mthd(dev, 0x9097, 0x0be4, 0x00000000); 571 + nv_mthd(dev, 0x9097, 0x0a08, 0x00000000); 572 + nv_mthd(dev, 0x9097, 0x0a28, 0x00000000); 573 + nv_mthd(dev, 0x9097, 0x0a48, 0x00000000); 574 + nv_mthd(dev, 0x9097, 0x0a68, 0x00000000); 575 + nv_mthd(dev, 0x9097, 0x0a88, 0x00000000); 576 + nv_mthd(dev, 0x9097, 0x0aa8, 0x00000000); 577 + nv_mthd(dev, 0x9097, 0x0ac8, 0x00000000); 578 + nv_mthd(dev, 0x9097, 0x0ae8, 0x00000000); 579 + nv_mthd(dev, 0x9097, 0x0b08, 0x00000000); 580 + nv_mthd(dev, 0x9097, 0x0b28, 0x00000000); 581 + nv_mthd(dev, 0x9097, 0x0b48, 0x00000000); 582 + nv_mthd(dev, 0x9097, 0x0b68, 0x00000000); 583 + nv_mthd(dev, 0x9097, 0x0b88, 0x00000000); 584 + nv_mthd(dev, 0x9097, 0x0ba8, 0x00000000); 585 + nv_mthd(dev, 0x9097, 0x0bc8, 0x00000000); 586 + nv_mthd(dev, 0x9097, 0x0be8, 0x00000000); 587 + nv_mthd(dev, 0x9097, 0x0a0c, 0x00000000); 588 + nv_mthd(dev, 0x9097, 0x0a2c, 0x00000000); 589 + nv_mthd(dev, 0x9097, 0x0a4c, 0x00000000); 590 + nv_mthd(dev, 0x9097, 0x0a6c, 0x00000000); 591 + nv_mthd(dev, 0x9097, 0x0a8c, 0x00000000); 592 + nv_mthd(dev, 0x9097, 0x0aac, 0x00000000); 593 + nv_mthd(dev, 0x9097, 0x0acc, 0x00000000); 594 + nv_mthd(dev, 0x9097, 0x0aec, 0x00000000); 595 + nv_mthd(dev, 0x9097, 0x0b0c, 0x00000000); 596 + nv_mthd(dev, 0x9097, 0x0b2c, 0x00000000); 597 + nv_mthd(dev, 0x9097, 0x0b4c, 0x00000000); 598 + nv_mthd(dev, 0x9097, 0x0b6c, 0x00000000); 599 + nv_mthd(dev, 0x9097, 0x0b8c, 0x00000000); 600 + nv_mthd(dev, 0x9097, 0x0bac, 0x00000000); 601 + nv_mthd(dev, 0x9097, 0x0bcc, 0x00000000); 602 + nv_mthd(dev, 0x9097, 0x0bec, 0x00000000); 603 + nv_mthd(dev, 0x9097, 0x0a10, 0x00000000); 604 + nv_mthd(dev, 0x9097, 0x0a30, 0x00000000); 605 + nv_mthd(dev, 0x9097, 0x0a50, 0x00000000); 606 + nv_mthd(dev, 0x9097, 0x0a70, 0x00000000); 607 + nv_mthd(dev, 0x9097, 0x0a90, 0x00000000); 608 + nv_mthd(dev, 0x9097, 0x0ab0, 0x00000000); 609 + nv_mthd(dev, 0x9097, 0x0ad0, 0x00000000); 610 + nv_mthd(dev, 0x9097, 0x0af0, 0x00000000); 611 + nv_mthd(dev, 0x9097, 0x0b10, 0x00000000); 612 + nv_mthd(dev, 0x9097, 0x0b30, 0x00000000); 613 + nv_mthd(dev, 0x9097, 0x0b50, 0x00000000); 614 + nv_mthd(dev, 0x9097, 0x0b70, 0x00000000); 615 + nv_mthd(dev, 0x9097, 0x0b90, 0x00000000); 616 + nv_mthd(dev, 0x9097, 0x0bb0, 0x00000000); 617 + nv_mthd(dev, 0x9097, 0x0bd0, 0x00000000); 618 + nv_mthd(dev, 0x9097, 0x0bf0, 0x00000000); 619 + nv_mthd(dev, 0x9097, 0x0a14, 0x00000000); 620 + nv_mthd(dev, 0x9097, 0x0a34, 0x00000000); 621 + nv_mthd(dev, 0x9097, 0x0a54, 0x00000000); 622 + nv_mthd(dev, 0x9097, 0x0a74, 0x00000000); 623 + nv_mthd(dev, 0x9097, 0x0a94, 0x00000000); 624 + nv_mthd(dev, 0x9097, 0x0ab4, 0x00000000); 625 + nv_mthd(dev, 0x9097, 0x0ad4, 0x00000000); 626 + nv_mthd(dev, 0x9097, 0x0af4, 0x00000000); 627 + nv_mthd(dev, 0x9097, 0x0b14, 0x00000000); 628 + nv_mthd(dev, 0x9097, 0x0b34, 0x00000000); 629 + nv_mthd(dev, 0x9097, 0x0b54, 0x00000000); 630 + nv_mthd(dev, 0x9097, 0x0b74, 0x00000000); 631 + nv_mthd(dev, 0x9097, 0x0b94, 0x00000000); 632 + nv_mthd(dev, 0x9097, 0x0bb4, 0x00000000); 633 + nv_mthd(dev, 0x9097, 0x0bd4, 0x00000000); 634 + nv_mthd(dev, 0x9097, 0x0bf4, 0x00000000); 635 + nv_mthd(dev, 0x9097, 0x0c00, 0x00000000); 636 + nv_mthd(dev, 0x9097, 0x0c10, 0x00000000); 637 + nv_mthd(dev, 0x9097, 0x0c20, 0x00000000); 638 + nv_mthd(dev, 0x9097, 0x0c30, 0x00000000); 639 + nv_mthd(dev, 0x9097, 0x0c40, 0x00000000); 640 + nv_mthd(dev, 0x9097, 0x0c50, 0x00000000); 641 + nv_mthd(dev, 0x9097, 0x0c60, 0x00000000); 642 + nv_mthd(dev, 0x9097, 0x0c70, 0x00000000); 643 + nv_mthd(dev, 0x9097, 0x0c80, 0x00000000); 644 + nv_mthd(dev, 0x9097, 0x0c90, 0x00000000); 645 + nv_mthd(dev, 0x9097, 0x0ca0, 0x00000000); 646 + nv_mthd(dev, 0x9097, 0x0cb0, 0x00000000); 647 + nv_mthd(dev, 0x9097, 0x0cc0, 0x00000000); 648 + nv_mthd(dev, 0x9097, 0x0cd0, 0x00000000); 649 + nv_mthd(dev, 0x9097, 0x0ce0, 0x00000000); 650 + nv_mthd(dev, 0x9097, 0x0cf0, 0x00000000); 651 + nv_mthd(dev, 0x9097, 0x0c04, 0x00000000); 652 + nv_mthd(dev, 0x9097, 0x0c14, 0x00000000); 653 + nv_mthd(dev, 0x9097, 0x0c24, 0x00000000); 654 + nv_mthd(dev, 0x9097, 0x0c34, 0x00000000); 655 + nv_mthd(dev, 0x9097, 0x0c44, 0x00000000); 656 + nv_mthd(dev, 0x9097, 0x0c54, 0x00000000); 657 + nv_mthd(dev, 0x9097, 0x0c64, 0x00000000); 658 + nv_mthd(dev, 0x9097, 0x0c74, 0x00000000); 659 + nv_mthd(dev, 0x9097, 0x0c84, 0x00000000); 660 + nv_mthd(dev, 0x9097, 0x0c94, 0x00000000); 661 + nv_mthd(dev, 0x9097, 0x0ca4, 0x00000000); 662 + nv_mthd(dev, 0x9097, 0x0cb4, 0x00000000); 663 + nv_mthd(dev, 0x9097, 0x0cc4, 0x00000000); 664 + nv_mthd(dev, 0x9097, 0x0cd4, 0x00000000); 665 + nv_mthd(dev, 0x9097, 0x0ce4, 0x00000000); 666 + nv_mthd(dev, 0x9097, 0x0cf4, 0x00000000); 667 + nv_mthd(dev, 0x9097, 0x0c08, 0x00000000); 668 + nv_mthd(dev, 0x9097, 0x0c18, 0x00000000); 669 + nv_mthd(dev, 0x9097, 0x0c28, 0x00000000); 670 + nv_mthd(dev, 0x9097, 0x0c38, 0x00000000); 671 + nv_mthd(dev, 0x9097, 0x0c48, 0x00000000); 672 + nv_mthd(dev, 0x9097, 0x0c58, 0x00000000); 673 + nv_mthd(dev, 0x9097, 0x0c68, 0x00000000); 674 + nv_mthd(dev, 0x9097, 0x0c78, 0x00000000); 675 + nv_mthd(dev, 0x9097, 0x0c88, 0x00000000); 676 + nv_mthd(dev, 0x9097, 0x0c98, 0x00000000); 677 + nv_mthd(dev, 0x9097, 0x0ca8, 0x00000000); 678 + nv_mthd(dev, 0x9097, 0x0cb8, 0x00000000); 679 + nv_mthd(dev, 0x9097, 0x0cc8, 0x00000000); 680 + nv_mthd(dev, 0x9097, 0x0cd8, 0x00000000); 681 + nv_mthd(dev, 0x9097, 0x0ce8, 0x00000000); 682 + nv_mthd(dev, 0x9097, 0x0cf8, 0x00000000); 683 + nv_mthd(dev, 0x9097, 0x0c0c, 0x3f800000); 684 + nv_mthd(dev, 0x9097, 0x0c1c, 0x3f800000); 685 + nv_mthd(dev, 0x9097, 0x0c2c, 0x3f800000); 686 + nv_mthd(dev, 0x9097, 0x0c3c, 0x3f800000); 687 + nv_mthd(dev, 0x9097, 0x0c4c, 0x3f800000); 688 + nv_mthd(dev, 0x9097, 0x0c5c, 0x3f800000); 689 + nv_mthd(dev, 0x9097, 0x0c6c, 0x3f800000); 690 + nv_mthd(dev, 0x9097, 0x0c7c, 0x3f800000); 691 + nv_mthd(dev, 0x9097, 0x0c8c, 0x3f800000); 692 + nv_mthd(dev, 0x9097, 0x0c9c, 0x3f800000); 693 + nv_mthd(dev, 0x9097, 0x0cac, 0x3f800000); 694 + nv_mthd(dev, 0x9097, 0x0cbc, 0x3f800000); 695 + nv_mthd(dev, 0x9097, 0x0ccc, 0x3f800000); 696 + nv_mthd(dev, 0x9097, 0x0cdc, 0x3f800000); 697 + nv_mthd(dev, 0x9097, 0x0cec, 0x3f800000); 698 + nv_mthd(dev, 0x9097, 0x0cfc, 0x3f800000); 699 + nv_mthd(dev, 0x9097, 0x0d00, 0xffff0000); 700 + nv_mthd(dev, 0x9097, 0x0d08, 0xffff0000); 701 + nv_mthd(dev, 0x9097, 0x0d10, 0xffff0000); 702 + nv_mthd(dev, 0x9097, 0x0d18, 0xffff0000); 703 + nv_mthd(dev, 0x9097, 0x0d20, 0xffff0000); 704 + nv_mthd(dev, 0x9097, 0x0d28, 0xffff0000); 705 + nv_mthd(dev, 0x9097, 0x0d30, 0xffff0000); 706 + nv_mthd(dev, 0x9097, 0x0d38, 0xffff0000); 707 + nv_mthd(dev, 0x9097, 0x0d04, 0xffff0000); 708 + nv_mthd(dev, 0x9097, 0x0d0c, 0xffff0000); 709 + nv_mthd(dev, 0x9097, 0x0d14, 0xffff0000); 710 + nv_mthd(dev, 0x9097, 0x0d1c, 0xffff0000); 711 + nv_mthd(dev, 0x9097, 0x0d24, 0xffff0000); 712 + nv_mthd(dev, 0x9097, 0x0d2c, 0xffff0000); 713 + nv_mthd(dev, 0x9097, 0x0d34, 0xffff0000); 714 + nv_mthd(dev, 0x9097, 0x0d3c, 0xffff0000); 715 + nv_mthd(dev, 0x9097, 0x0e00, 0x00000000); 716 + nv_mthd(dev, 0x9097, 0x0e10, 0x00000000); 717 + nv_mthd(dev, 0x9097, 0x0e20, 0x00000000); 718 + nv_mthd(dev, 0x9097, 0x0e30, 0x00000000); 719 + nv_mthd(dev, 0x9097, 0x0e40, 0x00000000); 720 + nv_mthd(dev, 0x9097, 0x0e50, 0x00000000); 721 + nv_mthd(dev, 0x9097, 0x0e60, 0x00000000); 722 + nv_mthd(dev, 0x9097, 0x0e70, 0x00000000); 723 + nv_mthd(dev, 0x9097, 0x0e80, 0x00000000); 724 + nv_mthd(dev, 0x9097, 0x0e90, 0x00000000); 725 + nv_mthd(dev, 0x9097, 0x0ea0, 0x00000000); 726 + nv_mthd(dev, 0x9097, 0x0eb0, 0x00000000); 727 + nv_mthd(dev, 0x9097, 0x0ec0, 0x00000000); 728 + nv_mthd(dev, 0x9097, 0x0ed0, 0x00000000); 729 + nv_mthd(dev, 0x9097, 0x0ee0, 0x00000000); 730 + nv_mthd(dev, 0x9097, 0x0ef0, 0x00000000); 731 + nv_mthd(dev, 0x9097, 0x0e04, 0xffff0000); 732 + nv_mthd(dev, 0x9097, 0x0e14, 0xffff0000); 733 + nv_mthd(dev, 0x9097, 0x0e24, 0xffff0000); 734 + nv_mthd(dev, 0x9097, 0x0e34, 0xffff0000); 735 + nv_mthd(dev, 0x9097, 0x0e44, 0xffff0000); 736 + nv_mthd(dev, 0x9097, 0x0e54, 0xffff0000); 737 + nv_mthd(dev, 0x9097, 0x0e64, 0xffff0000); 738 + nv_mthd(dev, 0x9097, 0x0e74, 0xffff0000); 739 + nv_mthd(dev, 0x9097, 0x0e84, 0xffff0000); 740 + nv_mthd(dev, 0x9097, 0x0e94, 0xffff0000); 741 + nv_mthd(dev, 0x9097, 0x0ea4, 0xffff0000); 742 + nv_mthd(dev, 0x9097, 0x0eb4, 0xffff0000); 743 + nv_mthd(dev, 0x9097, 0x0ec4, 0xffff0000); 744 + nv_mthd(dev, 0x9097, 0x0ed4, 0xffff0000); 745 + nv_mthd(dev, 0x9097, 0x0ee4, 0xffff0000); 746 + nv_mthd(dev, 0x9097, 0x0ef4, 0xffff0000); 747 + nv_mthd(dev, 0x9097, 0x0e08, 0xffff0000); 748 + nv_mthd(dev, 0x9097, 0x0e18, 0xffff0000); 749 + nv_mthd(dev, 0x9097, 0x0e28, 0xffff0000); 750 + nv_mthd(dev, 0x9097, 0x0e38, 0xffff0000); 751 + nv_mthd(dev, 0x9097, 0x0e48, 0xffff0000); 752 + nv_mthd(dev, 0x9097, 0x0e58, 0xffff0000); 753 + nv_mthd(dev, 0x9097, 0x0e68, 0xffff0000); 754 + nv_mthd(dev, 0x9097, 0x0e78, 0xffff0000); 755 + nv_mthd(dev, 0x9097, 0x0e88, 0xffff0000); 756 + nv_mthd(dev, 0x9097, 0x0e98, 0xffff0000); 757 + nv_mthd(dev, 0x9097, 0x0ea8, 0xffff0000); 758 + nv_mthd(dev, 0x9097, 0x0eb8, 0xffff0000); 759 + nv_mthd(dev, 0x9097, 0x0ec8, 0xffff0000); 760 + nv_mthd(dev, 0x9097, 0x0ed8, 0xffff0000); 761 + nv_mthd(dev, 0x9097, 0x0ee8, 0xffff0000); 762 + nv_mthd(dev, 0x9097, 0x0ef8, 0xffff0000); 763 + nv_mthd(dev, 0x9097, 0x0d40, 0x00000000); 764 + nv_mthd(dev, 0x9097, 0x0d48, 0x00000000); 765 + nv_mthd(dev, 0x9097, 0x0d50, 0x00000000); 766 + nv_mthd(dev, 0x9097, 0x0d58, 0x00000000); 767 + nv_mthd(dev, 0x9097, 0x0d44, 0x00000000); 768 + nv_mthd(dev, 0x9097, 0x0d4c, 0x00000000); 769 + nv_mthd(dev, 0x9097, 0x0d54, 0x00000000); 770 + nv_mthd(dev, 0x9097, 0x0d5c, 0x00000000); 771 + nv_mthd(dev, 0x9097, 0x1e00, 0x00000001); 772 + nv_mthd(dev, 0x9097, 0x1e20, 0x00000001); 773 + nv_mthd(dev, 0x9097, 0x1e40, 0x00000001); 774 + nv_mthd(dev, 0x9097, 0x1e60, 0x00000001); 775 + nv_mthd(dev, 0x9097, 0x1e80, 0x00000001); 776 + nv_mthd(dev, 0x9097, 0x1ea0, 0x00000001); 777 + nv_mthd(dev, 0x9097, 0x1ec0, 0x00000001); 778 + nv_mthd(dev, 0x9097, 0x1ee0, 0x00000001); 779 + nv_mthd(dev, 0x9097, 0x1e04, 0x00000001); 780 + nv_mthd(dev, 0x9097, 0x1e24, 0x00000001); 781 + nv_mthd(dev, 0x9097, 0x1e44, 0x00000001); 782 + nv_mthd(dev, 0x9097, 0x1e64, 0x00000001); 783 + nv_mthd(dev, 0x9097, 0x1e84, 0x00000001); 784 + nv_mthd(dev, 0x9097, 0x1ea4, 0x00000001); 785 + nv_mthd(dev, 0x9097, 0x1ec4, 0x00000001); 786 + nv_mthd(dev, 0x9097, 0x1ee4, 0x00000001); 787 + nv_mthd(dev, 0x9097, 0x1e08, 0x00000002); 788 + nv_mthd(dev, 0x9097, 0x1e28, 0x00000002); 789 + nv_mthd(dev, 0x9097, 0x1e48, 0x00000002); 790 + nv_mthd(dev, 0x9097, 0x1e68, 0x00000002); 791 + nv_mthd(dev, 0x9097, 0x1e88, 0x00000002); 792 + nv_mthd(dev, 0x9097, 0x1ea8, 0x00000002); 793 + nv_mthd(dev, 0x9097, 0x1ec8, 0x00000002); 794 + nv_mthd(dev, 0x9097, 0x1ee8, 0x00000002); 795 + nv_mthd(dev, 0x9097, 0x1e0c, 0x00000001); 796 + nv_mthd(dev, 0x9097, 0x1e2c, 0x00000001); 797 + nv_mthd(dev, 0x9097, 0x1e4c, 0x00000001); 798 + nv_mthd(dev, 0x9097, 0x1e6c, 0x00000001); 799 + nv_mthd(dev, 0x9097, 0x1e8c, 0x00000001); 800 + nv_mthd(dev, 0x9097, 0x1eac, 0x00000001); 801 + nv_mthd(dev, 0x9097, 0x1ecc, 0x00000001); 802 + nv_mthd(dev, 0x9097, 0x1eec, 0x00000001); 803 + nv_mthd(dev, 0x9097, 0x1e10, 0x00000001); 804 + nv_mthd(dev, 0x9097, 0x1e30, 0x00000001); 805 + nv_mthd(dev, 0x9097, 0x1e50, 0x00000001); 806 + nv_mthd(dev, 0x9097, 0x1e70, 0x00000001); 807 + nv_mthd(dev, 0x9097, 0x1e90, 0x00000001); 808 + nv_mthd(dev, 0x9097, 0x1eb0, 0x00000001); 809 + nv_mthd(dev, 0x9097, 0x1ed0, 0x00000001); 810 + nv_mthd(dev, 0x9097, 0x1ef0, 0x00000001); 811 + nv_mthd(dev, 0x9097, 0x1e14, 0x00000002); 812 + nv_mthd(dev, 0x9097, 0x1e34, 0x00000002); 813 + nv_mthd(dev, 0x9097, 0x1e54, 0x00000002); 814 + nv_mthd(dev, 0x9097, 0x1e74, 0x00000002); 815 + nv_mthd(dev, 0x9097, 0x1e94, 0x00000002); 816 + nv_mthd(dev, 0x9097, 0x1eb4, 0x00000002); 817 + nv_mthd(dev, 0x9097, 0x1ed4, 0x00000002); 818 + nv_mthd(dev, 0x9097, 0x1ef4, 0x00000002); 819 + nv_mthd(dev, 0x9097, 0x1e18, 0x00000001); 820 + nv_mthd(dev, 0x9097, 0x1e38, 0x00000001); 821 + nv_mthd(dev, 0x9097, 0x1e58, 0x00000001); 822 + nv_mthd(dev, 0x9097, 0x1e78, 0x00000001); 823 + nv_mthd(dev, 0x9097, 0x1e98, 0x00000001); 824 + nv_mthd(dev, 0x9097, 0x1eb8, 0x00000001); 825 + nv_mthd(dev, 0x9097, 0x1ed8, 0x00000001); 826 + nv_mthd(dev, 0x9097, 0x1ef8, 0x00000001); 827 + nv_mthd(dev, 0x9097, 0x3400, 0x00000000); 828 + nv_mthd(dev, 0x9097, 0x3404, 0x00000000); 829 + nv_mthd(dev, 0x9097, 0x3408, 0x00000000); 830 + nv_mthd(dev, 0x9097, 0x340c, 0x00000000); 831 + nv_mthd(dev, 0x9097, 0x3410, 0x00000000); 832 + nv_mthd(dev, 0x9097, 0x3414, 0x00000000); 833 + nv_mthd(dev, 0x9097, 0x3418, 0x00000000); 834 + nv_mthd(dev, 0x9097, 0x341c, 0x00000000); 835 + nv_mthd(dev, 0x9097, 0x3420, 0x00000000); 836 + nv_mthd(dev, 0x9097, 0x3424, 0x00000000); 837 + nv_mthd(dev, 0x9097, 0x3428, 0x00000000); 838 + nv_mthd(dev, 0x9097, 0x342c, 0x00000000); 839 + nv_mthd(dev, 0x9097, 0x3430, 0x00000000); 840 + nv_mthd(dev, 0x9097, 0x3434, 0x00000000); 841 + nv_mthd(dev, 0x9097, 0x3438, 0x00000000); 842 + nv_mthd(dev, 0x9097, 0x343c, 0x00000000); 843 + nv_mthd(dev, 0x9097, 0x3440, 0x00000000); 844 + nv_mthd(dev, 0x9097, 0x3444, 0x00000000); 845 + nv_mthd(dev, 0x9097, 0x3448, 0x00000000); 846 + nv_mthd(dev, 0x9097, 0x344c, 0x00000000); 847 + nv_mthd(dev, 0x9097, 0x3450, 0x00000000); 848 + nv_mthd(dev, 0x9097, 0x3454, 0x00000000); 849 + nv_mthd(dev, 0x9097, 0x3458, 0x00000000); 850 + nv_mthd(dev, 0x9097, 0x345c, 0x00000000); 851 + nv_mthd(dev, 0x9097, 0x3460, 0x00000000); 852 + nv_mthd(dev, 0x9097, 0x3464, 0x00000000); 853 + nv_mthd(dev, 0x9097, 0x3468, 0x00000000); 854 + nv_mthd(dev, 0x9097, 0x346c, 0x00000000); 855 + nv_mthd(dev, 0x9097, 0x3470, 0x00000000); 856 + nv_mthd(dev, 0x9097, 0x3474, 0x00000000); 857 + nv_mthd(dev, 0x9097, 0x3478, 0x00000000); 858 + nv_mthd(dev, 0x9097, 0x347c, 0x00000000); 859 + nv_mthd(dev, 0x9097, 0x3480, 0x00000000); 860 + nv_mthd(dev, 0x9097, 0x3484, 0x00000000); 861 + nv_mthd(dev, 0x9097, 0x3488, 0x00000000); 862 + nv_mthd(dev, 0x9097, 0x348c, 0x00000000); 863 + nv_mthd(dev, 0x9097, 0x3490, 0x00000000); 864 + nv_mthd(dev, 0x9097, 0x3494, 0x00000000); 865 + nv_mthd(dev, 0x9097, 0x3498, 0x00000000); 866 + nv_mthd(dev, 0x9097, 0x349c, 0x00000000); 867 + nv_mthd(dev, 0x9097, 0x34a0, 0x00000000); 868 + nv_mthd(dev, 0x9097, 0x34a4, 0x00000000); 869 + nv_mthd(dev, 0x9097, 0x34a8, 0x00000000); 870 + nv_mthd(dev, 0x9097, 0x34ac, 0x00000000); 871 + nv_mthd(dev, 0x9097, 0x34b0, 0x00000000); 872 + nv_mthd(dev, 0x9097, 0x34b4, 0x00000000); 873 + nv_mthd(dev, 0x9097, 0x34b8, 0x00000000); 874 + nv_mthd(dev, 0x9097, 0x34bc, 0x00000000); 875 + nv_mthd(dev, 0x9097, 0x34c0, 0x00000000); 876 + nv_mthd(dev, 0x9097, 0x34c4, 0x00000000); 877 + nv_mthd(dev, 0x9097, 0x34c8, 0x00000000); 878 + nv_mthd(dev, 0x9097, 0x34cc, 0x00000000); 879 + nv_mthd(dev, 0x9097, 0x34d0, 0x00000000); 880 + nv_mthd(dev, 0x9097, 0x34d4, 0x00000000); 881 + nv_mthd(dev, 0x9097, 0x34d8, 0x00000000); 882 + nv_mthd(dev, 0x9097, 0x34dc, 0x00000000); 883 + nv_mthd(dev, 0x9097, 0x34e0, 0x00000000); 884 + nv_mthd(dev, 0x9097, 0x34e4, 0x00000000); 885 + nv_mthd(dev, 0x9097, 0x34e8, 0x00000000); 886 + nv_mthd(dev, 0x9097, 0x34ec, 0x00000000); 887 + nv_mthd(dev, 0x9097, 0x34f0, 0x00000000); 888 + nv_mthd(dev, 0x9097, 0x34f4, 0x00000000); 889 + nv_mthd(dev, 0x9097, 0x34f8, 0x00000000); 890 + nv_mthd(dev, 0x9097, 0x34fc, 0x00000000); 891 + nv_mthd(dev, 0x9097, 0x3500, 0x00000000); 892 + nv_mthd(dev, 0x9097, 0x3504, 0x00000000); 893 + nv_mthd(dev, 0x9097, 0x3508, 0x00000000); 894 + nv_mthd(dev, 0x9097, 0x350c, 0x00000000); 895 + nv_mthd(dev, 0x9097, 0x3510, 0x00000000); 896 + nv_mthd(dev, 0x9097, 0x3514, 0x00000000); 897 + nv_mthd(dev, 0x9097, 0x3518, 0x00000000); 898 + nv_mthd(dev, 0x9097, 0x351c, 0x00000000); 899 + nv_mthd(dev, 0x9097, 0x3520, 0x00000000); 900 + nv_mthd(dev, 0x9097, 0x3524, 0x00000000); 901 + nv_mthd(dev, 0x9097, 0x3528, 0x00000000); 902 + nv_mthd(dev, 0x9097, 0x352c, 0x00000000); 903 + nv_mthd(dev, 0x9097, 0x3530, 0x00000000); 904 + nv_mthd(dev, 0x9097, 0x3534, 0x00000000); 905 + nv_mthd(dev, 0x9097, 0x3538, 0x00000000); 906 + nv_mthd(dev, 0x9097, 0x353c, 0x00000000); 907 + nv_mthd(dev, 0x9097, 0x3540, 0x00000000); 908 + nv_mthd(dev, 0x9097, 0x3544, 0x00000000); 909 + nv_mthd(dev, 0x9097, 0x3548, 0x00000000); 910 + nv_mthd(dev, 0x9097, 0x354c, 0x00000000); 911 + nv_mthd(dev, 0x9097, 0x3550, 0x00000000); 912 + nv_mthd(dev, 0x9097, 0x3554, 0x00000000); 913 + nv_mthd(dev, 0x9097, 0x3558, 0x00000000); 914 + nv_mthd(dev, 0x9097, 0x355c, 0x00000000); 915 + nv_mthd(dev, 0x9097, 0x3560, 0x00000000); 916 + nv_mthd(dev, 0x9097, 0x3564, 0x00000000); 917 + nv_mthd(dev, 0x9097, 0x3568, 0x00000000); 918 + nv_mthd(dev, 0x9097, 0x356c, 0x00000000); 919 + nv_mthd(dev, 0x9097, 0x3570, 0x00000000); 920 + nv_mthd(dev, 0x9097, 0x3574, 0x00000000); 921 + nv_mthd(dev, 0x9097, 0x3578, 0x00000000); 922 + nv_mthd(dev, 0x9097, 0x357c, 0x00000000); 923 + nv_mthd(dev, 0x9097, 0x3580, 0x00000000); 924 + nv_mthd(dev, 0x9097, 0x3584, 0x00000000); 925 + nv_mthd(dev, 0x9097, 0x3588, 0x00000000); 926 + nv_mthd(dev, 0x9097, 0x358c, 0x00000000); 927 + nv_mthd(dev, 0x9097, 0x3590, 0x00000000); 928 + nv_mthd(dev, 0x9097, 0x3594, 0x00000000); 929 + nv_mthd(dev, 0x9097, 0x3598, 0x00000000); 930 + nv_mthd(dev, 0x9097, 0x359c, 0x00000000); 931 + nv_mthd(dev, 0x9097, 0x35a0, 0x00000000); 932 + nv_mthd(dev, 0x9097, 0x35a4, 0x00000000); 933 + nv_mthd(dev, 0x9097, 0x35a8, 0x00000000); 934 + nv_mthd(dev, 0x9097, 0x35ac, 0x00000000); 935 + nv_mthd(dev, 0x9097, 0x35b0, 0x00000000); 936 + nv_mthd(dev, 0x9097, 0x35b4, 0x00000000); 937 + nv_mthd(dev, 0x9097, 0x35b8, 0x00000000); 938 + nv_mthd(dev, 0x9097, 0x35bc, 0x00000000); 939 + nv_mthd(dev, 0x9097, 0x35c0, 0x00000000); 940 + nv_mthd(dev, 0x9097, 0x35c4, 0x00000000); 941 + nv_mthd(dev, 0x9097, 0x35c8, 0x00000000); 942 + nv_mthd(dev, 0x9097, 0x35cc, 0x00000000); 943 + nv_mthd(dev, 0x9097, 0x35d0, 0x00000000); 944 + nv_mthd(dev, 0x9097, 0x35d4, 0x00000000); 945 + nv_mthd(dev, 0x9097, 0x35d8, 0x00000000); 946 + nv_mthd(dev, 0x9097, 0x35dc, 0x00000000); 947 + nv_mthd(dev, 0x9097, 0x35e0, 0x00000000); 948 + nv_mthd(dev, 0x9097, 0x35e4, 0x00000000); 949 + nv_mthd(dev, 0x9097, 0x35e8, 0x00000000); 950 + nv_mthd(dev, 0x9097, 0x35ec, 0x00000000); 951 + nv_mthd(dev, 0x9097, 0x35f0, 0x00000000); 952 + nv_mthd(dev, 0x9097, 0x35f4, 0x00000000); 953 + nv_mthd(dev, 0x9097, 0x35f8, 0x00000000); 954 + nv_mthd(dev, 0x9097, 0x35fc, 0x00000000); 955 + nv_mthd(dev, 0x9097, 0x030c, 0x00000001); 956 + nv_mthd(dev, 0x9097, 0x1944, 0x00000000); 957 + nv_mthd(dev, 0x9097, 0x1514, 0x00000000); 958 + nv_mthd(dev, 0x9097, 0x0d68, 0x0000ffff); 959 + nv_mthd(dev, 0x9097, 0x121c, 0x0fac6881); 960 + nv_mthd(dev, 0x9097, 0x0fac, 0x00000001); 961 + nv_mthd(dev, 0x9097, 0x1538, 0x00000001); 962 + nv_mthd(dev, 0x9097, 0x0fe0, 0x00000000); 963 + nv_mthd(dev, 0x9097, 0x0fe4, 0x00000000); 964 + nv_mthd(dev, 0x9097, 0x0fe8, 0x00000014); 965 + nv_mthd(dev, 0x9097, 0x0fec, 0x00000040); 966 + nv_mthd(dev, 0x9097, 0x0ff0, 0x00000000); 967 + nv_mthd(dev, 0x9097, 0x179c, 0x00000000); 968 + nv_mthd(dev, 0x9097, 0x1228, 0x00000400); 969 + nv_mthd(dev, 0x9097, 0x122c, 0x00000300); 970 + nv_mthd(dev, 0x9097, 0x1230, 0x00010001); 971 + nv_mthd(dev, 0x9097, 0x07f8, 0x00000000); 972 + nv_mthd(dev, 0x9097, 0x15b4, 0x00000001); 973 + nv_mthd(dev, 0x9097, 0x15cc, 0x00000000); 974 + nv_mthd(dev, 0x9097, 0x1534, 0x00000000); 975 + nv_mthd(dev, 0x9097, 0x0fb0, 0x00000000); 976 + nv_mthd(dev, 0x9097, 0x15d0, 0x00000000); 977 + nv_mthd(dev, 0x9097, 0x153c, 0x00000000); 978 + nv_mthd(dev, 0x9097, 0x16b4, 0x00000003); 979 + nv_mthd(dev, 0x9097, 0x0fbc, 0x0000ffff); 980 + nv_mthd(dev, 0x9097, 0x0fc0, 0x0000ffff); 981 + nv_mthd(dev, 0x9097, 0x0fc4, 0x0000ffff); 982 + nv_mthd(dev, 0x9097, 0x0fc8, 0x0000ffff); 983 + nv_mthd(dev, 0x9097, 0x0df8, 0x00000000); 984 + nv_mthd(dev, 0x9097, 0x0dfc, 0x00000000); 985 + nv_mthd(dev, 0x9097, 0x1948, 0x00000000); 986 + nv_mthd(dev, 0x9097, 0x1970, 0x00000001); 987 + nv_mthd(dev, 0x9097, 0x161c, 0x000009f0); 988 + nv_mthd(dev, 0x9097, 0x0dcc, 0x00000010); 989 + nv_mthd(dev, 0x9097, 0x163c, 0x00000000); 990 + nv_mthd(dev, 0x9097, 0x15e4, 0x00000000); 991 + nv_mthd(dev, 0x9097, 0x1160, 0x25e00040); 992 + nv_mthd(dev, 0x9097, 0x1164, 0x25e00040); 993 + nv_mthd(dev, 0x9097, 0x1168, 0x25e00040); 994 + nv_mthd(dev, 0x9097, 0x116c, 0x25e00040); 995 + nv_mthd(dev, 0x9097, 0x1170, 0x25e00040); 996 + nv_mthd(dev, 0x9097, 0x1174, 0x25e00040); 997 + nv_mthd(dev, 0x9097, 0x1178, 0x25e00040); 998 + nv_mthd(dev, 0x9097, 0x117c, 0x25e00040); 999 + nv_mthd(dev, 0x9097, 0x1180, 0x25e00040); 1000 + nv_mthd(dev, 0x9097, 0x1184, 0x25e00040); 1001 + nv_mthd(dev, 0x9097, 0x1188, 0x25e00040); 1002 + nv_mthd(dev, 0x9097, 0x118c, 0x25e00040); 1003 + nv_mthd(dev, 0x9097, 0x1190, 0x25e00040); 1004 + nv_mthd(dev, 0x9097, 0x1194, 0x25e00040); 1005 + nv_mthd(dev, 0x9097, 0x1198, 0x25e00040); 1006 + nv_mthd(dev, 0x9097, 0x119c, 0x25e00040); 1007 + nv_mthd(dev, 0x9097, 0x11a0, 0x25e00040); 1008 + nv_mthd(dev, 0x9097, 0x11a4, 0x25e00040); 1009 + nv_mthd(dev, 0x9097, 0x11a8, 0x25e00040); 1010 + nv_mthd(dev, 0x9097, 0x11ac, 0x25e00040); 1011 + nv_mthd(dev, 0x9097, 0x11b0, 0x25e00040); 1012 + nv_mthd(dev, 0x9097, 0x11b4, 0x25e00040); 1013 + nv_mthd(dev, 0x9097, 0x11b8, 0x25e00040); 1014 + nv_mthd(dev, 0x9097, 0x11bc, 0x25e00040); 1015 + nv_mthd(dev, 0x9097, 0x11c0, 0x25e00040); 1016 + nv_mthd(dev, 0x9097, 0x11c4, 0x25e00040); 1017 + nv_mthd(dev, 0x9097, 0x11c8, 0x25e00040); 1018 + nv_mthd(dev, 0x9097, 0x11cc, 0x25e00040); 1019 + nv_mthd(dev, 0x9097, 0x11d0, 0x25e00040); 1020 + nv_mthd(dev, 0x9097, 0x11d4, 0x25e00040); 1021 + nv_mthd(dev, 0x9097, 0x11d8, 0x25e00040); 1022 + nv_mthd(dev, 0x9097, 0x11dc, 0x25e00040); 1023 + nv_mthd(dev, 0x9097, 0x1880, 0x00000000); 1024 + nv_mthd(dev, 0x9097, 0x1884, 0x00000000); 1025 + nv_mthd(dev, 0x9097, 0x1888, 0x00000000); 1026 + nv_mthd(dev, 0x9097, 0x188c, 0x00000000); 1027 + nv_mthd(dev, 0x9097, 0x1890, 0x00000000); 1028 + nv_mthd(dev, 0x9097, 0x1894, 0x00000000); 1029 + nv_mthd(dev, 0x9097, 0x1898, 0x00000000); 1030 + nv_mthd(dev, 0x9097, 0x189c, 0x00000000); 1031 + nv_mthd(dev, 0x9097, 0x18a0, 0x00000000); 1032 + nv_mthd(dev, 0x9097, 0x18a4, 0x00000000); 1033 + nv_mthd(dev, 0x9097, 0x18a8, 0x00000000); 1034 + nv_mthd(dev, 0x9097, 0x18ac, 0x00000000); 1035 + nv_mthd(dev, 0x9097, 0x18b0, 0x00000000); 1036 + nv_mthd(dev, 0x9097, 0x18b4, 0x00000000); 1037 + nv_mthd(dev, 0x9097, 0x18b8, 0x00000000); 1038 + nv_mthd(dev, 0x9097, 0x18bc, 0x00000000); 1039 + nv_mthd(dev, 0x9097, 0x18c0, 0x00000000); 1040 + nv_mthd(dev, 0x9097, 0x18c4, 0x00000000); 1041 + nv_mthd(dev, 0x9097, 0x18c8, 0x00000000); 1042 + nv_mthd(dev, 0x9097, 0x18cc, 0x00000000); 1043 + nv_mthd(dev, 0x9097, 0x18d0, 0x00000000); 1044 + nv_mthd(dev, 0x9097, 0x18d4, 0x00000000); 1045 + nv_mthd(dev, 0x9097, 0x18d8, 0x00000000); 1046 + nv_mthd(dev, 0x9097, 0x18dc, 0x00000000); 1047 + nv_mthd(dev, 0x9097, 0x18e0, 0x00000000); 1048 + nv_mthd(dev, 0x9097, 0x18e4, 0x00000000); 1049 + nv_mthd(dev, 0x9097, 0x18e8, 0x00000000); 1050 + nv_mthd(dev, 0x9097, 0x18ec, 0x00000000); 1051 + nv_mthd(dev, 0x9097, 0x18f0, 0x00000000); 1052 + nv_mthd(dev, 0x9097, 0x18f4, 0x00000000); 1053 + nv_mthd(dev, 0x9097, 0x18f8, 0x00000000); 1054 + nv_mthd(dev, 0x9097, 0x18fc, 0x00000000); 1055 + nv_mthd(dev, 0x9097, 0x0f84, 0x00000000); 1056 + nv_mthd(dev, 0x9097, 0x0f88, 0x00000000); 1057 + nv_mthd(dev, 0x9097, 0x17c8, 0x00000000); 1058 + nv_mthd(dev, 0x9097, 0x17cc, 0x00000000); 1059 + nv_mthd(dev, 0x9097, 0x17d0, 0x000000ff); 1060 + nv_mthd(dev, 0x9097, 0x17d4, 0xffffffff); 1061 + nv_mthd(dev, 0x9097, 0x17d8, 0x00000002); 1062 + nv_mthd(dev, 0x9097, 0x17dc, 0x00000000); 1063 + nv_mthd(dev, 0x9097, 0x15f4, 0x00000000); 1064 + nv_mthd(dev, 0x9097, 0x15f8, 0x00000000); 1065 + nv_mthd(dev, 0x9097, 0x1434, 0x00000000); 1066 + nv_mthd(dev, 0x9097, 0x1438, 0x00000000); 1067 + nv_mthd(dev, 0x9097, 0x0d74, 0x00000000); 1068 + nv_mthd(dev, 0x9097, 0x0dec, 0x00000001); 1069 + nv_mthd(dev, 0x9097, 0x13a4, 0x00000000); 1070 + nv_mthd(dev, 0x9097, 0x1318, 0x00000001); 1071 + nv_mthd(dev, 0x9097, 0x1644, 0x00000000); 1072 + nv_mthd(dev, 0x9097, 0x0748, 0x00000000); 1073 + nv_mthd(dev, 0x9097, 0x0de8, 0x00000000); 1074 + nv_mthd(dev, 0x9097, 0x1648, 0x00000000); 1075 + nv_mthd(dev, 0x9097, 0x12a4, 0x00000000); 1076 + nv_mthd(dev, 0x9097, 0x1120, 0x00000000); 1077 + nv_mthd(dev, 0x9097, 0x1124, 0x00000000); 1078 + nv_mthd(dev, 0x9097, 0x1128, 0x00000000); 1079 + nv_mthd(dev, 0x9097, 0x112c, 0x00000000); 1080 + nv_mthd(dev, 0x9097, 0x1118, 0x00000000); 1081 + nv_mthd(dev, 0x9097, 0x164c, 0x00000000); 1082 + nv_mthd(dev, 0x9097, 0x1658, 0x00000000); 1083 + nv_mthd(dev, 0x9097, 0x1910, 0x00000290); 1084 + nv_mthd(dev, 0x9097, 0x1518, 0x00000000); 1085 + nv_mthd(dev, 0x9097, 0x165c, 0x00000001); 1086 + nv_mthd(dev, 0x9097, 0x1520, 0x00000000); 1087 + nv_mthd(dev, 0x9097, 0x1604, 0x00000000); 1088 + nv_mthd(dev, 0x9097, 0x1570, 0x00000000); 1089 + nv_mthd(dev, 0x9097, 0x13b0, 0x3f800000); 1090 + nv_mthd(dev, 0x9097, 0x13b4, 0x3f800000); 1091 + nv_mthd(dev, 0x9097, 0x020c, 0x00000000); 1092 + nv_mthd(dev, 0x9097, 0x1670, 0x30201000); 1093 + nv_mthd(dev, 0x9097, 0x1674, 0x70605040); 1094 + nv_mthd(dev, 0x9097, 0x1678, 0xb8a89888); 1095 + nv_mthd(dev, 0x9097, 0x167c, 0xf8e8d8c8); 1096 + nv_mthd(dev, 0x9097, 0x166c, 0x00000000); 1097 + nv_mthd(dev, 0x9097, 0x1680, 0x00ffff00); 1098 + nv_mthd(dev, 0x9097, 0x12d0, 0x00000003); 1099 + nv_mthd(dev, 0x9097, 0x12d4, 0x00000002); 1100 + nv_mthd(dev, 0x9097, 0x1684, 0x00000000); 1101 + nv_mthd(dev, 0x9097, 0x1688, 0x00000000); 1102 + nv_mthd(dev, 0x9097, 0x0dac, 0x00001b02); 1103 + nv_mthd(dev, 0x9097, 0x0db0, 0x00001b02); 1104 + nv_mthd(dev, 0x9097, 0x0db4, 0x00000000); 1105 + nv_mthd(dev, 0x9097, 0x168c, 0x00000000); 1106 + nv_mthd(dev, 0x9097, 0x15bc, 0x00000000); 1107 + nv_mthd(dev, 0x9097, 0x156c, 0x00000000); 1108 + nv_mthd(dev, 0x9097, 0x187c, 0x00000000); 1109 + nv_mthd(dev, 0x9097, 0x1110, 0x00000001); 1110 + nv_mthd(dev, 0x9097, 0x0dc0, 0x00000000); 1111 + nv_mthd(dev, 0x9097, 0x0dc4, 0x00000000); 1112 + nv_mthd(dev, 0x9097, 0x0dc8, 0x00000000); 1113 + nv_mthd(dev, 0x9097, 0x1234, 0x00000000); 1114 + nv_mthd(dev, 0x9097, 0x1690, 0x00000000); 1115 + nv_mthd(dev, 0x9097, 0x12ac, 0x00000001); 1116 + nv_mthd(dev, 0x9097, 0x02c4, 0x00000000); 1117 + nv_mthd(dev, 0x9097, 0x0790, 0x00000000); 1118 + nv_mthd(dev, 0x9097, 0x0794, 0x00000000); 1119 + nv_mthd(dev, 0x9097, 0x0798, 0x00000000); 1120 + nv_mthd(dev, 0x9097, 0x079c, 0x00000000); 1121 + nv_mthd(dev, 0x9097, 0x07a0, 0x00000000); 1122 + nv_mthd(dev, 0x9097, 0x077c, 0x00000000); 1123 + nv_mthd(dev, 0x9097, 0x1000, 0x00000010); 1124 + nv_mthd(dev, 0x9097, 0x10fc, 0x00000000); 1125 + nv_mthd(dev, 0x9097, 0x1290, 0x00000000); 1126 + nv_mthd(dev, 0x9097, 0x0218, 0x00000010); 1127 + nv_mthd(dev, 0x9097, 0x12d8, 0x00000000); 1128 + nv_mthd(dev, 0x9097, 0x12dc, 0x00000010); 1129 + nv_mthd(dev, 0x9097, 0x0d94, 0x00000001); 1130 + nv_mthd(dev, 0x9097, 0x155c, 0x00000000); 1131 + nv_mthd(dev, 0x9097, 0x1560, 0x00000000); 1132 + nv_mthd(dev, 0x9097, 0x1564, 0x00001fff); 1133 + nv_mthd(dev, 0x9097, 0x1574, 0x00000000); 1134 + nv_mthd(dev, 0x9097, 0x1578, 0x00000000); 1135 + nv_mthd(dev, 0x9097, 0x157c, 0x003fffff); 1136 + nv_mthd(dev, 0x9097, 0x1354, 0x00000000); 1137 + nv_mthd(dev, 0x9097, 0x1664, 0x00000000); 1138 + nv_mthd(dev, 0x9097, 0x1610, 0x00000012); 1139 + nv_mthd(dev, 0x9097, 0x1608, 0x00000000); 1140 + nv_mthd(dev, 0x9097, 0x160c, 0x00000000); 1141 + nv_mthd(dev, 0x9097, 0x162c, 0x00000003); 1142 + nv_mthd(dev, 0x9097, 0x0210, 0x00000000); 1143 + nv_mthd(dev, 0x9097, 0x0320, 0x00000000); 1144 + nv_mthd(dev, 0x9097, 0x0324, 0x3f800000); 1145 + nv_mthd(dev, 0x9097, 0x0328, 0x3f800000); 1146 + nv_mthd(dev, 0x9097, 0x032c, 0x3f800000); 1147 + nv_mthd(dev, 0x9097, 0x0330, 0x3f800000); 1148 + nv_mthd(dev, 0x9097, 0x0334, 0x3f800000); 1149 + nv_mthd(dev, 0x9097, 0x0338, 0x3f800000); 1150 + nv_mthd(dev, 0x9097, 0x0750, 0x00000000); 1151 + nv_mthd(dev, 0x9097, 0x0760, 0x39291909); 1152 + nv_mthd(dev, 0x9097, 0x0764, 0x79695949); 1153 + nv_mthd(dev, 0x9097, 0x0768, 0xb9a99989); 1154 + nv_mthd(dev, 0x9097, 0x076c, 0xf9e9d9c9); 1155 + nv_mthd(dev, 0x9097, 0x0770, 0x30201000); 1156 + nv_mthd(dev, 0x9097, 0x0774, 0x70605040); 1157 + nv_mthd(dev, 0x9097, 0x0778, 0x00009080); 1158 + nv_mthd(dev, 0x9097, 0x0780, 0x39291909); 1159 + nv_mthd(dev, 0x9097, 0x0784, 0x79695949); 1160 + nv_mthd(dev, 0x9097, 0x0788, 0xb9a99989); 1161 + nv_mthd(dev, 0x9097, 0x078c, 0xf9e9d9c9); 1162 + nv_mthd(dev, 0x9097, 0x07d0, 0x30201000); 1163 + nv_mthd(dev, 0x9097, 0x07d4, 0x70605040); 1164 + nv_mthd(dev, 0x9097, 0x07d8, 0x00009080); 1165 + nv_mthd(dev, 0x9097, 0x037c, 0x00000001); 1166 + nv_mthd(dev, 0x9097, 0x0740, 0x00000000); 1167 + nv_mthd(dev, 0x9097, 0x0744, 0x00000000); 1168 + nv_mthd(dev, 0x9097, 0x2600, 0x00000000); 1169 + nv_mthd(dev, 0x9097, 0x1918, 0x00000000); 1170 + nv_mthd(dev, 0x9097, 0x191c, 0x00000900); 1171 + nv_mthd(dev, 0x9097, 0x1920, 0x00000405); 1172 + nv_mthd(dev, 0x9097, 0x1308, 0x00000001); 1173 + nv_mthd(dev, 0x9097, 0x1924, 0x00000000); 1174 + nv_mthd(dev, 0x9097, 0x13ac, 0x00000000); 1175 + nv_mthd(dev, 0x9097, 0x192c, 0x00000001); 1176 + nv_mthd(dev, 0x9097, 0x193c, 0x00002c1c); 1177 + nv_mthd(dev, 0x9097, 0x0d7c, 0x00000000); 1178 + nv_mthd(dev, 0x9097, 0x0f8c, 0x00000000); 1179 + nv_mthd(dev, 0x9097, 0x02c0, 0x00000001); 1180 + nv_mthd(dev, 0x9097, 0x1510, 0x00000000); 1181 + nv_mthd(dev, 0x9097, 0x1940, 0x00000000); 1182 + nv_mthd(dev, 0x9097, 0x0ff4, 0x00000000); 1183 + nv_mthd(dev, 0x9097, 0x0ff8, 0x00000000); 1184 + nv_mthd(dev, 0x9097, 0x194c, 0x00000000); 1185 + nv_mthd(dev, 0x9097, 0x1950, 0x00000000); 1186 + nv_mthd(dev, 0x9097, 0x1968, 0x00000000); 1187 + nv_mthd(dev, 0x9097, 0x1590, 0x0000003f); 1188 + nv_mthd(dev, 0x9097, 0x07e8, 0x00000000); 1189 + nv_mthd(dev, 0x9097, 0x07ec, 0x00000000); 1190 + nv_mthd(dev, 0x9097, 0x07f0, 0x00000000); 1191 + nv_mthd(dev, 0x9097, 0x07f4, 0x00000000); 1192 + nv_mthd(dev, 0x9097, 0x196c, 0x00000011); 1193 + nv_mthd(dev, 0x9097, 0x197c, 0x00000000); 1194 + nv_mthd(dev, 0x9097, 0x0fcc, 0x00000000); 1195 + nv_mthd(dev, 0x9097, 0x0fd0, 0x00000000); 1196 + nv_mthd(dev, 0x9097, 0x02d8, 0x00000040); 1197 + nv_mthd(dev, 0x9097, 0x1980, 0x00000080); 1198 + nv_mthd(dev, 0x9097, 0x1504, 0x00000080); 1199 + nv_mthd(dev, 0x9097, 0x1984, 0x00000000); 1200 + nv_mthd(dev, 0x9097, 0x0300, 0x00000001); 1201 + nv_mthd(dev, 0x9097, 0x13a8, 0x00000000); 1202 + nv_mthd(dev, 0x9097, 0x12ec, 0x00000000); 1203 + nv_mthd(dev, 0x9097, 0x1310, 0x00000000); 1204 + nv_mthd(dev, 0x9097, 0x1314, 0x00000001); 1205 + nv_mthd(dev, 0x9097, 0x1380, 0x00000000); 1206 + nv_mthd(dev, 0x9097, 0x1384, 0x00000001); 1207 + nv_mthd(dev, 0x9097, 0x1388, 0x00000001); 1208 + nv_mthd(dev, 0x9097, 0x138c, 0x00000001); 1209 + nv_mthd(dev, 0x9097, 0x1390, 0x00000001); 1210 + nv_mthd(dev, 0x9097, 0x1394, 0x00000000); 1211 + nv_mthd(dev, 0x9097, 0x139c, 0x00000000); 1212 + nv_mthd(dev, 0x9097, 0x1398, 0x00000000); 1213 + nv_mthd(dev, 0x9097, 0x1594, 0x00000000); 1214 + nv_mthd(dev, 0x9097, 0x1598, 0x00000001); 1215 + nv_mthd(dev, 0x9097, 0x159c, 0x00000001); 1216 + nv_mthd(dev, 0x9097, 0x15a0, 0x00000001); 1217 + nv_mthd(dev, 0x9097, 0x15a4, 0x00000001); 1218 + nv_mthd(dev, 0x9097, 0x0f54, 0x00000000); 1219 + nv_mthd(dev, 0x9097, 0x0f58, 0x00000000); 1220 + nv_mthd(dev, 0x9097, 0x0f5c, 0x00000000); 1221 + nv_mthd(dev, 0x9097, 0x19bc, 0x00000000); 1222 + nv_mthd(dev, 0x9097, 0x0f9c, 0x00000000); 1223 + nv_mthd(dev, 0x9097, 0x0fa0, 0x00000000); 1224 + nv_mthd(dev, 0x9097, 0x12cc, 0x00000000); 1225 + nv_mthd(dev, 0x9097, 0x12e8, 0x00000000); 1226 + nv_mthd(dev, 0x9097, 0x130c, 0x00000001); 1227 + nv_mthd(dev, 0x9097, 0x1360, 0x00000000); 1228 + nv_mthd(dev, 0x9097, 0x1364, 0x00000000); 1229 + nv_mthd(dev, 0x9097, 0x1368, 0x00000000); 1230 + nv_mthd(dev, 0x9097, 0x136c, 0x00000000); 1231 + nv_mthd(dev, 0x9097, 0x1370, 0x00000000); 1232 + nv_mthd(dev, 0x9097, 0x1374, 0x00000000); 1233 + nv_mthd(dev, 0x9097, 0x1378, 0x00000000); 1234 + nv_mthd(dev, 0x9097, 0x137c, 0x00000000); 1235 + nv_mthd(dev, 0x9097, 0x133c, 0x00000001); 1236 + nv_mthd(dev, 0x9097, 0x1340, 0x00000001); 1237 + nv_mthd(dev, 0x9097, 0x1344, 0x00000002); 1238 + nv_mthd(dev, 0x9097, 0x1348, 0x00000001); 1239 + nv_mthd(dev, 0x9097, 0x134c, 0x00000001); 1240 + nv_mthd(dev, 0x9097, 0x1350, 0x00000002); 1241 + nv_mthd(dev, 0x9097, 0x1358, 0x00000001); 1242 + nv_mthd(dev, 0x9097, 0x12e4, 0x00000000); 1243 + nv_mthd(dev, 0x9097, 0x131c, 0x00000000); 1244 + nv_mthd(dev, 0x9097, 0x1320, 0x00000000); 1245 + nv_mthd(dev, 0x9097, 0x1324, 0x00000000); 1246 + nv_mthd(dev, 0x9097, 0x1328, 0x00000000); 1247 + nv_mthd(dev, 0x9097, 0x19c0, 0x00000000); 1248 + nv_mthd(dev, 0x9097, 0x1140, 0x00000000); 1249 + nv_mthd(dev, 0x9097, 0x19c4, 0x00000000); 1250 + nv_mthd(dev, 0x9097, 0x19c8, 0x00001500); 1251 + nv_mthd(dev, 0x9097, 0x135c, 0x00000000); 1252 + nv_mthd(dev, 0x9097, 0x0f90, 0x00000000); 1253 + nv_mthd(dev, 0x9097, 0x19e0, 0x00000001); 1254 + nv_mthd(dev, 0x9097, 0x19e4, 0x00000001); 1255 + nv_mthd(dev, 0x9097, 0x19e8, 0x00000001); 1256 + nv_mthd(dev, 0x9097, 0x19ec, 0x00000001); 1257 + nv_mthd(dev, 0x9097, 0x19f0, 0x00000001); 1258 + nv_mthd(dev, 0x9097, 0x19f4, 0x00000001); 1259 + nv_mthd(dev, 0x9097, 0x19f8, 0x00000001); 1260 + nv_mthd(dev, 0x9097, 0x19fc, 0x00000001); 1261 + nv_mthd(dev, 0x9097, 0x19cc, 0x00000001); 1262 + nv_mthd(dev, 0x9097, 0x15b8, 0x00000000); 1263 + nv_mthd(dev, 0x9097, 0x1a00, 0x00001111); 1264 + nv_mthd(dev, 0x9097, 0x1a04, 0x00000000); 1265 + nv_mthd(dev, 0x9097, 0x1a08, 0x00000000); 1266 + nv_mthd(dev, 0x9097, 0x1a0c, 0x00000000); 1267 + nv_mthd(dev, 0x9097, 0x1a10, 0x00000000); 1268 + nv_mthd(dev, 0x9097, 0x1a14, 0x00000000); 1269 + nv_mthd(dev, 0x9097, 0x1a18, 0x00000000); 1270 + nv_mthd(dev, 0x9097, 0x1a1c, 0x00000000); 1271 + nv_mthd(dev, 0x9097, 0x0d6c, 0xffff0000); 1272 + nv_mthd(dev, 0x9097, 0x0d70, 0xffff0000); 1273 + nv_mthd(dev, 0x9097, 0x10f8, 0x00001010); 1274 + nv_mthd(dev, 0x9097, 0x0d80, 0x00000000); 1275 + nv_mthd(dev, 0x9097, 0x0d84, 0x00000000); 1276 + nv_mthd(dev, 0x9097, 0x0d88, 0x00000000); 1277 + nv_mthd(dev, 0x9097, 0x0d8c, 0x00000000); 1278 + nv_mthd(dev, 0x9097, 0x0d90, 0x00000000); 1279 + nv_mthd(dev, 0x9097, 0x0da0, 0x00000000); 1280 + nv_mthd(dev, 0x9097, 0x1508, 0x80000000); 1281 + nv_mthd(dev, 0x9097, 0x150c, 0x40000000); 1282 + nv_mthd(dev, 0x9097, 0x1668, 0x00000000); 1283 + nv_mthd(dev, 0x9097, 0x0318, 0x00000008); 1284 + nv_mthd(dev, 0x9097, 0x031c, 0x00000008); 1285 + nv_mthd(dev, 0x9097, 0x0d9c, 0x00000001); 1286 + nv_mthd(dev, 0x9097, 0x07dc, 0x00000000); 1287 + nv_mthd(dev, 0x9097, 0x074c, 0x00000055); 1288 + nv_mthd(dev, 0x9097, 0x1420, 0x00000003); 1289 + nv_mthd(dev, 0x9097, 0x17bc, 0x00000000); 1290 + nv_mthd(dev, 0x9097, 0x17c0, 0x00000000); 1291 + nv_mthd(dev, 0x9097, 0x17c4, 0x00000001); 1292 + nv_mthd(dev, 0x9097, 0x1008, 0x00000008); 1293 + nv_mthd(dev, 0x9097, 0x100c, 0x00000040); 1294 + nv_mthd(dev, 0x9097, 0x1010, 0x0000012c); 1295 + nv_mthd(dev, 0x9097, 0x0d60, 0x00000040); 1296 + nv_mthd(dev, 0x9097, 0x075c, 0x00000003); 1297 + nv_mthd(dev, 0x9097, 0x1018, 0x00000020); 1298 + nv_mthd(dev, 0x9097, 0x101c, 0x00000001); 1299 + nv_mthd(dev, 0x9097, 0x1020, 0x00000020); 1300 + nv_mthd(dev, 0x9097, 0x1024, 0x00000001); 1301 + nv_mthd(dev, 0x9097, 0x1444, 0x00000000); 1302 + nv_mthd(dev, 0x9097, 0x1448, 0x00000000); 1303 + nv_mthd(dev, 0x9097, 0x144c, 0x00000000); 1304 + nv_mthd(dev, 0x9097, 0x0360, 0x20164010); 1305 + nv_mthd(dev, 0x9097, 0x0364, 0x00000020); 1306 + nv_mthd(dev, 0x9097, 0x0368, 0x00000000); 1307 + nv_mthd(dev, 0x9097, 0x0de4, 0x00000000); 1308 + nv_mthd(dev, 0x9097, 0x0204, 0x00000006); 1309 + nv_mthd(dev, 0x9097, 0x0208, 0x00000000); 1310 + nv_mthd(dev, 0x9097, 0x02cc, 0x003fffff); 1311 + nv_mthd(dev, 0x9097, 0x02d0, 0x00000c48); 1312 + nv_mthd(dev, 0x9097, 0x1220, 0x00000005); 1313 + nv_mthd(dev, 0x9097, 0x0fdc, 0x00000000); 1314 + nv_mthd(dev, 0x9097, 0x0f98, 0x00300008); 1315 + nv_mthd(dev, 0x9097, 0x1284, 0x04000080); 1316 + nv_mthd(dev, 0x9097, 0x1450, 0x00300008); 1317 + nv_mthd(dev, 0x9097, 0x1454, 0x04000080); 1318 + nv_mthd(dev, 0x9097, 0x0214, 0x00000000); 1319 + /* in trace, right after 0x90c0, not here */ 1320 + nv_mthd(dev, 0x9097, 0x3410, 0x80002006); 1321 + } 1322 + 1323 + static void 1324 + nvc0_grctx_generate_902d(struct drm_device *dev) 1325 + { 1326 + nv_mthd(dev, 0x902d, 0x0200, 0x000000cf); 1327 + nv_mthd(dev, 0x902d, 0x0204, 0x00000001); 1328 + nv_mthd(dev, 0x902d, 0x0208, 0x00000020); 1329 + nv_mthd(dev, 0x902d, 0x020c, 0x00000001); 1330 + nv_mthd(dev, 0x902d, 0x0210, 0x00000000); 1331 + nv_mthd(dev, 0x902d, 0x0214, 0x00000080); 1332 + nv_mthd(dev, 0x902d, 0x0218, 0x00000100); 1333 + nv_mthd(dev, 0x902d, 0x021c, 0x00000100); 1334 + nv_mthd(dev, 0x902d, 0x0220, 0x00000000); 1335 + nv_mthd(dev, 0x902d, 0x0224, 0x00000000); 1336 + nv_mthd(dev, 0x902d, 0x0230, 0x000000cf); 1337 + nv_mthd(dev, 0x902d, 0x0234, 0x00000001); 1338 + nv_mthd(dev, 0x902d, 0x0238, 0x00000020); 1339 + nv_mthd(dev, 0x902d, 0x023c, 0x00000001); 1340 + nv_mthd(dev, 0x902d, 0x0244, 0x00000080); 1341 + nv_mthd(dev, 0x902d, 0x0248, 0x00000100); 1342 + nv_mthd(dev, 0x902d, 0x024c, 0x00000100); 1343 + } 1344 + 1345 + static void 1346 + nvc0_grctx_generate_9039(struct drm_device *dev) 1347 + { 1348 + nv_mthd(dev, 0x9039, 0x030c, 0x00000000); 1349 + nv_mthd(dev, 0x9039, 0x0310, 0x00000000); 1350 + nv_mthd(dev, 0x9039, 0x0314, 0x00000000); 1351 + nv_mthd(dev, 0x9039, 0x0320, 0x00000000); 1352 + nv_mthd(dev, 0x9039, 0x0238, 0x00000000); 1353 + nv_mthd(dev, 0x9039, 0x023c, 0x00000000); 1354 + nv_mthd(dev, 0x9039, 0x0318, 0x00000000); 1355 + nv_mthd(dev, 0x9039, 0x031c, 0x00000000); 1356 + } 1357 + 1358 + static void 1359 + nvc0_grctx_generate_90c0(struct drm_device *dev) 1360 + { 1361 + nv_mthd(dev, 0x90c0, 0x270c, 0x00000000); 1362 + nv_mthd(dev, 0x90c0, 0x272c, 0x00000000); 1363 + nv_mthd(dev, 0x90c0, 0x274c, 0x00000000); 1364 + nv_mthd(dev, 0x90c0, 0x276c, 0x00000000); 1365 + nv_mthd(dev, 0x90c0, 0x278c, 0x00000000); 1366 + nv_mthd(dev, 0x90c0, 0x27ac, 0x00000000); 1367 + nv_mthd(dev, 0x90c0, 0x27cc, 0x00000000); 1368 + nv_mthd(dev, 0x90c0, 0x27ec, 0x00000000); 1369 + nv_mthd(dev, 0x90c0, 0x030c, 0x00000001); 1370 + nv_mthd(dev, 0x90c0, 0x1944, 0x00000000); 1371 + nv_mthd(dev, 0x90c0, 0x0758, 0x00000100); 1372 + nv_mthd(dev, 0x90c0, 0x02c4, 0x00000000); 1373 + nv_mthd(dev, 0x90c0, 0x0790, 0x00000000); 1374 + nv_mthd(dev, 0x90c0, 0x0794, 0x00000000); 1375 + nv_mthd(dev, 0x90c0, 0x0798, 0x00000000); 1376 + nv_mthd(dev, 0x90c0, 0x079c, 0x00000000); 1377 + nv_mthd(dev, 0x90c0, 0x07a0, 0x00000000); 1378 + nv_mthd(dev, 0x90c0, 0x077c, 0x00000000); 1379 + nv_mthd(dev, 0x90c0, 0x0204, 0x00000000); 1380 + nv_mthd(dev, 0x90c0, 0x0208, 0x00000000); 1381 + nv_mthd(dev, 0x90c0, 0x020c, 0x00000000); 1382 + nv_mthd(dev, 0x90c0, 0x0214, 0x00000000); 1383 + nv_mthd(dev, 0x90c0, 0x024c, 0x00000000); 1384 + nv_mthd(dev, 0x90c0, 0x0d94, 0x00000001); 1385 + nv_mthd(dev, 0x90c0, 0x1608, 0x00000000); 1386 + nv_mthd(dev, 0x90c0, 0x160c, 0x00000000); 1387 + nv_mthd(dev, 0x90c0, 0x1664, 0x00000000); 1388 + } 1389 + 1390 + static void 1391 + nvc0_grctx_generate_dispatch(struct drm_device *dev) 1392 + { 1393 + int i; 1394 + 1395 + nv_wr32(dev, 0x404004, 0x00000000); 1396 + nv_wr32(dev, 0x404008, 0x00000000); 1397 + nv_wr32(dev, 0x40400c, 0x00000000); 1398 + nv_wr32(dev, 0x404010, 0x00000000); 1399 + nv_wr32(dev, 0x404014, 0x00000000); 1400 + nv_wr32(dev, 0x404018, 0x00000000); 1401 + nv_wr32(dev, 0x40401c, 0x00000000); 1402 + nv_wr32(dev, 0x404020, 0x00000000); 1403 + nv_wr32(dev, 0x404024, 0x00000000); 1404 + nv_wr32(dev, 0x404028, 0x00000000); 1405 + nv_wr32(dev, 0x40402c, 0x00000000); 1406 + nv_wr32(dev, 0x404044, 0x00000000); 1407 + nv_wr32(dev, 0x404094, 0x00000000); 1408 + nv_wr32(dev, 0x404098, 0x00000000); 1409 + nv_wr32(dev, 0x40409c, 0x00000000); 1410 + nv_wr32(dev, 0x4040a0, 0x00000000); 1411 + nv_wr32(dev, 0x4040a4, 0x00000000); 1412 + nv_wr32(dev, 0x4040a8, 0x00000000); 1413 + nv_wr32(dev, 0x4040ac, 0x00000000); 1414 + nv_wr32(dev, 0x4040b0, 0x00000000); 1415 + nv_wr32(dev, 0x4040b4, 0x00000000); 1416 + nv_wr32(dev, 0x4040b8, 0x00000000); 1417 + nv_wr32(dev, 0x4040bc, 0x00000000); 1418 + nv_wr32(dev, 0x4040c0, 0x00000000); 1419 + nv_wr32(dev, 0x4040c4, 0x00000000); 1420 + nv_wr32(dev, 0x4040c8, 0xf0000087); 1421 + nv_wr32(dev, 0x4040d4, 0x00000000); 1422 + nv_wr32(dev, 0x4040d8, 0x00000000); 1423 + nv_wr32(dev, 0x4040dc, 0x00000000); 1424 + nv_wr32(dev, 0x4040e0, 0x00000000); 1425 + nv_wr32(dev, 0x4040e4, 0x00000000); 1426 + nv_wr32(dev, 0x4040e8, 0x00001000); 1427 + nv_wr32(dev, 0x4040f8, 0x00000000); 1428 + nv_wr32(dev, 0x404130, 0x00000000); 1429 + nv_wr32(dev, 0x404134, 0x00000000); 1430 + nv_wr32(dev, 0x404138, 0x20000040); 1431 + nv_wr32(dev, 0x404150, 0x0000002e); 1432 + nv_wr32(dev, 0x404154, 0x00000400); 1433 + nv_wr32(dev, 0x404158, 0x00000200); 1434 + nv_wr32(dev, 0x404164, 0x00000055); 1435 + nv_wr32(dev, 0x404168, 0x00000000); 1436 + nv_wr32(dev, 0x404174, 0x00000000); 1437 + nv_wr32(dev, 0x404178, 0x00000000); 1438 + nv_wr32(dev, 0x40417c, 0x00000000); 1439 + for (i = 0; i < 8; i++) 1440 + nv_wr32(dev, 0x404200 + (i * 4), 0x00000000); /* subc */ 1441 + } 1442 + 1443 + static void 1444 + nvc0_grctx_generate_macro(struct drm_device *dev) 1445 + { 1446 + nv_wr32(dev, 0x404404, 0x00000000); 1447 + nv_wr32(dev, 0x404408, 0x00000000); 1448 + nv_wr32(dev, 0x40440c, 0x00000000); 1449 + nv_wr32(dev, 0x404410, 0x00000000); 1450 + nv_wr32(dev, 0x404414, 0x00000000); 1451 + nv_wr32(dev, 0x404418, 0x00000000); 1452 + nv_wr32(dev, 0x40441c, 0x00000000); 1453 + nv_wr32(dev, 0x404420, 0x00000000); 1454 + nv_wr32(dev, 0x404424, 0x00000000); 1455 + nv_wr32(dev, 0x404428, 0x00000000); 1456 + nv_wr32(dev, 0x40442c, 0x00000000); 1457 + nv_wr32(dev, 0x404430, 0x00000000); 1458 + nv_wr32(dev, 0x404434, 0x00000000); 1459 + nv_wr32(dev, 0x404438, 0x00000000); 1460 + nv_wr32(dev, 0x404460, 0x00000000); 1461 + nv_wr32(dev, 0x404464, 0x00000000); 1462 + nv_wr32(dev, 0x404468, 0x00ffffff); 1463 + nv_wr32(dev, 0x40446c, 0x00000000); 1464 + nv_wr32(dev, 0x404480, 0x00000001); 1465 + nv_wr32(dev, 0x404498, 0x00000001); 1466 + } 1467 + 1468 + static void 1469 + nvc0_grctx_generate_m2mf(struct drm_device *dev) 1470 + { 1471 + nv_wr32(dev, 0x404604, 0x00000015); 1472 + nv_wr32(dev, 0x404608, 0x00000000); 1473 + nv_wr32(dev, 0x40460c, 0x00002e00); 1474 + nv_wr32(dev, 0x404610, 0x00000100); 1475 + nv_wr32(dev, 0x404618, 0x00000000); 1476 + nv_wr32(dev, 0x40461c, 0x00000000); 1477 + nv_wr32(dev, 0x404620, 0x00000000); 1478 + nv_wr32(dev, 0x404624, 0x00000000); 1479 + nv_wr32(dev, 0x404628, 0x00000000); 1480 + nv_wr32(dev, 0x40462c, 0x00000000); 1481 + nv_wr32(dev, 0x404630, 0x00000000); 1482 + nv_wr32(dev, 0x404634, 0x00000000); 1483 + nv_wr32(dev, 0x404638, 0x00000004); 1484 + nv_wr32(dev, 0x40463c, 0x00000000); 1485 + nv_wr32(dev, 0x404640, 0x00000000); 1486 + nv_wr32(dev, 0x404644, 0x00000000); 1487 + nv_wr32(dev, 0x404648, 0x00000000); 1488 + nv_wr32(dev, 0x40464c, 0x00000000); 1489 + nv_wr32(dev, 0x404650, 0x00000000); 1490 + nv_wr32(dev, 0x404654, 0x00000000); 1491 + nv_wr32(dev, 0x404658, 0x00000000); 1492 + nv_wr32(dev, 0x40465c, 0x007f0100); 1493 + nv_wr32(dev, 0x404660, 0x00000000); 1494 + nv_wr32(dev, 0x404664, 0x00000000); 1495 + nv_wr32(dev, 0x404668, 0x00000000); 1496 + nv_wr32(dev, 0x40466c, 0x00000000); 1497 + nv_wr32(dev, 0x404670, 0x00000000); 1498 + nv_wr32(dev, 0x404674, 0x00000000); 1499 + nv_wr32(dev, 0x404678, 0x00000000); 1500 + nv_wr32(dev, 0x40467c, 0x00000002); 1501 + nv_wr32(dev, 0x404680, 0x00000000); 1502 + nv_wr32(dev, 0x404684, 0x00000000); 1503 + nv_wr32(dev, 0x404688, 0x00000000); 1504 + nv_wr32(dev, 0x40468c, 0x00000000); 1505 + nv_wr32(dev, 0x404690, 0x00000000); 1506 + nv_wr32(dev, 0x404694, 0x00000000); 1507 + nv_wr32(dev, 0x404698, 0x00000000); 1508 + nv_wr32(dev, 0x40469c, 0x00000000); 1509 + nv_wr32(dev, 0x4046a0, 0x007f0080); 1510 + nv_wr32(dev, 0x4046a4, 0x00000000); 1511 + nv_wr32(dev, 0x4046a8, 0x00000000); 1512 + nv_wr32(dev, 0x4046ac, 0x00000000); 1513 + nv_wr32(dev, 0x4046b0, 0x00000000); 1514 + nv_wr32(dev, 0x4046b4, 0x00000000); 1515 + nv_wr32(dev, 0x4046b8, 0x00000000); 1516 + nv_wr32(dev, 0x4046bc, 0x00000000); 1517 + nv_wr32(dev, 0x4046c0, 0x00000000); 1518 + nv_wr32(dev, 0x4046c4, 0x00000000); 1519 + nv_wr32(dev, 0x4046c8, 0x00000000); 1520 + nv_wr32(dev, 0x4046cc, 0x00000000); 1521 + nv_wr32(dev, 0x4046d0, 0x00000000); 1522 + nv_wr32(dev, 0x4046d4, 0x00000000); 1523 + nv_wr32(dev, 0x4046d8, 0x00000000); 1524 + nv_wr32(dev, 0x4046dc, 0x00000000); 1525 + nv_wr32(dev, 0x4046e0, 0x00000000); 1526 + nv_wr32(dev, 0x4046e4, 0x00000000); 1527 + nv_wr32(dev, 0x4046e8, 0x00000000); 1528 + nv_wr32(dev, 0x4046f0, 0x00000000); 1529 + nv_wr32(dev, 0x4046f4, 0x00000000); 1530 + } 1531 + 1532 + static void 1533 + nvc0_grctx_generate_unk47xx(struct drm_device *dev) 1534 + { 1535 + nv_wr32(dev, 0x404700, 0x00000000); 1536 + nv_wr32(dev, 0x404704, 0x00000000); 1537 + nv_wr32(dev, 0x404708, 0x00000000); 1538 + nv_wr32(dev, 0x40470c, 0x00000000); 1539 + nv_wr32(dev, 0x404710, 0x00000000); 1540 + nv_wr32(dev, 0x404714, 0x00000000); 1541 + nv_wr32(dev, 0x404718, 0x00000000); 1542 + nv_wr32(dev, 0x40471c, 0x00000000); 1543 + nv_wr32(dev, 0x404720, 0x00000000); 1544 + nv_wr32(dev, 0x404724, 0x00000000); 1545 + nv_wr32(dev, 0x404728, 0x00000000); 1546 + nv_wr32(dev, 0x40472c, 0x00000000); 1547 + nv_wr32(dev, 0x404730, 0x00000000); 1548 + nv_wr32(dev, 0x404734, 0x00000100); 1549 + nv_wr32(dev, 0x404738, 0x00000000); 1550 + nv_wr32(dev, 0x40473c, 0x00000000); 1551 + nv_wr32(dev, 0x404740, 0x00000000); 1552 + nv_wr32(dev, 0x404744, 0x00000000); 1553 + nv_wr32(dev, 0x404748, 0x00000000); 1554 + nv_wr32(dev, 0x40474c, 0x00000000); 1555 + nv_wr32(dev, 0x404750, 0x00000000); 1556 + nv_wr32(dev, 0x404754, 0x00000000); 1557 + } 1558 + 1559 + static void 1560 + nvc0_grctx_generate_unk58xx(struct drm_device *dev) 1561 + { 1562 + nv_wr32(dev, 0x405800, 0x078000bf); 1563 + nv_wr32(dev, 0x405830, 0x02180000); 1564 + nv_wr32(dev, 0x405834, 0x00000000); 1565 + nv_wr32(dev, 0x405838, 0x00000000); 1566 + nv_wr32(dev, 0x405854, 0x00000000); 1567 + nv_wr32(dev, 0x405870, 0x00000001); 1568 + nv_wr32(dev, 0x405874, 0x00000001); 1569 + nv_wr32(dev, 0x405878, 0x00000001); 1570 + nv_wr32(dev, 0x40587c, 0x00000001); 1571 + nv_wr32(dev, 0x405a00, 0x00000000); 1572 + nv_wr32(dev, 0x405a04, 0x00000000); 1573 + nv_wr32(dev, 0x405a18, 0x00000000); 1574 + } 1575 + 1576 + static void 1577 + nvc0_grctx_generate_unk60xx(struct drm_device *dev) 1578 + { 1579 + nv_wr32(dev, 0x406020, 0x000103c1); 1580 + nv_wr32(dev, 0x406028, 0x00000001); 1581 + nv_wr32(dev, 0x40602c, 0x00000001); 1582 + nv_wr32(dev, 0x406030, 0x00000001); 1583 + nv_wr32(dev, 0x406034, 0x00000001); 1584 + } 1585 + 1586 + static void 1587 + nvc0_grctx_generate_unk64xx(struct drm_device *dev) 1588 + { 1589 + nv_wr32(dev, 0x4064a8, 0x00000000); 1590 + nv_wr32(dev, 0x4064ac, 0x00003fff); 1591 + nv_wr32(dev, 0x4064b4, 0x00000000); 1592 + nv_wr32(dev, 0x4064b8, 0x00000000); 1593 + } 1594 + 1595 + static void 1596 + nvc0_grctx_generate_unk78xx(struct drm_device *dev) 1597 + { 1598 + nv_wr32(dev, 0x407804, 0x00000023); 1599 + nv_wr32(dev, 0x40780c, 0x0a418820); 1600 + nv_wr32(dev, 0x407810, 0x062080e6); 1601 + nv_wr32(dev, 0x407814, 0x020398a4); 1602 + nv_wr32(dev, 0x407818, 0x0e629062); 1603 + nv_wr32(dev, 0x40781c, 0x0a418820); 1604 + nv_wr32(dev, 0x407820, 0x000000e6); 1605 + nv_wr32(dev, 0x4078bc, 0x00000103); 1606 + } 1607 + 1608 + static void 1609 + nvc0_grctx_generate_unk80xx(struct drm_device *dev) 1610 + { 1611 + nv_wr32(dev, 0x408000, 0x00000000); 1612 + nv_wr32(dev, 0x408004, 0x00000000); 1613 + nv_wr32(dev, 0x408008, 0x00000018); 1614 + nv_wr32(dev, 0x40800c, 0x00000000); 1615 + nv_wr32(dev, 0x408010, 0x00000000); 1616 + nv_wr32(dev, 0x408014, 0x00000069); 1617 + nv_wr32(dev, 0x408018, 0xe100e100); 1618 + nv_wr32(dev, 0x408064, 0x00000000); 1619 + } 1620 + 1621 + static void 1622 + nvc0_grctx_generate_rop(struct drm_device *dev) 1623 + { 1624 + struct drm_nouveau_private *dev_priv = dev->dev_private; 1625 + 1626 + // ROPC_BROADCAST 1627 + nv_wr32(dev, 0x408800, 0x02802a3c); 1628 + nv_wr32(dev, 0x408804, 0x00000040); 1629 + nv_wr32(dev, 0x408808, 0x0003e00d); 1630 + switch (dev_priv->chipset) { 1631 + case 0xc0: 1632 + nv_wr32(dev, 0x408900, 0x0080b801); 1633 + break; 1634 + case 0xc3: 1635 + case 0xc4: 1636 + nv_wr32(dev, 0x408900, 0x3080b801); 1637 + break; 1638 + } 1639 + nv_wr32(dev, 0x408904, 0x02000001); 1640 + nv_wr32(dev, 0x408908, 0x00c80929); 1641 + nv_wr32(dev, 0x40890c, 0x00000000); 1642 + nv_wr32(dev, 0x408980, 0x0000011d); 1643 + } 1644 + 1645 + static void 1646 + nvc0_grctx_generate_gpc(struct drm_device *dev) 1647 + { 1648 + int i; 1649 + 1650 + // GPC_BROADCAST 1651 + nv_wr32(dev, 0x418380, 0x00000016); 1652 + nv_wr32(dev, 0x418400, 0x38004e00); 1653 + nv_wr32(dev, 0x418404, 0x71e0ffff); 1654 + nv_wr32(dev, 0x418408, 0x00000000); 1655 + nv_wr32(dev, 0x41840c, 0x00001008); 1656 + nv_wr32(dev, 0x418410, 0x0fff0fff); 1657 + nv_wr32(dev, 0x418414, 0x00200fff); 1658 + nv_wr32(dev, 0x418450, 0x00000000); 1659 + nv_wr32(dev, 0x418454, 0x00000000); 1660 + nv_wr32(dev, 0x418458, 0x00000000); 1661 + nv_wr32(dev, 0x41845c, 0x00000000); 1662 + nv_wr32(dev, 0x418460, 0x00000000); 1663 + nv_wr32(dev, 0x418464, 0x00000000); 1664 + nv_wr32(dev, 0x418468, 0x00000001); 1665 + nv_wr32(dev, 0x41846c, 0x00000000); 1666 + nv_wr32(dev, 0x418470, 0x00000000); 1667 + nv_wr32(dev, 0x418600, 0x0000001f); 1668 + nv_wr32(dev, 0x418684, 0x0000000f); 1669 + nv_wr32(dev, 0x418700, 0x00000002); 1670 + nv_wr32(dev, 0x418704, 0x00000080); 1671 + nv_wr32(dev, 0x418708, 0x00000000); 1672 + nv_wr32(dev, 0x41870c, 0x07c80000); 1673 + nv_wr32(dev, 0x418710, 0x00000000); 1674 + nv_wr32(dev, 0x418800, 0x0006860a); 1675 + nv_wr32(dev, 0x418808, 0x00000000); 1676 + nv_wr32(dev, 0x41880c, 0x00000000); 1677 + nv_wr32(dev, 0x418810, 0x00000000); 1678 + nv_wr32(dev, 0x418828, 0x00008442); 1679 + nv_wr32(dev, 0x418830, 0x00000001); 1680 + nv_wr32(dev, 0x4188d8, 0x00000008); 1681 + nv_wr32(dev, 0x4188e0, 0x01000000); 1682 + nv_wr32(dev, 0x4188e8, 0x00000000); 1683 + nv_wr32(dev, 0x4188ec, 0x00000000); 1684 + nv_wr32(dev, 0x4188f0, 0x00000000); 1685 + nv_wr32(dev, 0x4188f4, 0x00000000); 1686 + nv_wr32(dev, 0x4188f8, 0x00000000); 1687 + nv_wr32(dev, 0x4188fc, 0x00100000); 1688 + nv_wr32(dev, 0x41891c, 0x00ff00ff); 1689 + nv_wr32(dev, 0x418924, 0x00000000); 1690 + nv_wr32(dev, 0x418928, 0x00ffff00); 1691 + nv_wr32(dev, 0x41892c, 0x0000ff00); 1692 + for (i = 0; i < 8; i++) { 1693 + nv_wr32(dev, 0x418a00 + (i * 0x20), 0x00000000); 1694 + nv_wr32(dev, 0x418a04 + (i * 0x20), 0x00000000); 1695 + nv_wr32(dev, 0x418a08 + (i * 0x20), 0x00000000); 1696 + nv_wr32(dev, 0x418a0c + (i * 0x20), 0x00010000); 1697 + nv_wr32(dev, 0x418a10 + (i * 0x20), 0x00000000); 1698 + nv_wr32(dev, 0x418a14 + (i * 0x20), 0x00000000); 1699 + nv_wr32(dev, 0x418a18 + (i * 0x20), 0x00000000); 1700 + } 1701 + nv_wr32(dev, 0x418b00, 0x00000000); 1702 + nv_wr32(dev, 0x418b08, 0x0a418820); 1703 + nv_wr32(dev, 0x418b0c, 0x062080e6); 1704 + nv_wr32(dev, 0x418b10, 0x020398a4); 1705 + nv_wr32(dev, 0x418b14, 0x0e629062); 1706 + nv_wr32(dev, 0x418b18, 0x0a418820); 1707 + nv_wr32(dev, 0x418b1c, 0x000000e6); 1708 + nv_wr32(dev, 0x418bb8, 0x00000103); 1709 + nv_wr32(dev, 0x418c08, 0x00000001); 1710 + nv_wr32(dev, 0x418c10, 0x00000000); 1711 + nv_wr32(dev, 0x418c14, 0x00000000); 1712 + nv_wr32(dev, 0x418c18, 0x00000000); 1713 + nv_wr32(dev, 0x418c1c, 0x00000000); 1714 + nv_wr32(dev, 0x418c20, 0x00000000); 1715 + nv_wr32(dev, 0x418c24, 0x00000000); 1716 + nv_wr32(dev, 0x418c28, 0x00000000); 1717 + nv_wr32(dev, 0x418c2c, 0x00000000); 1718 + nv_wr32(dev, 0x418c80, 0x20200004); 1719 + nv_wr32(dev, 0x418c8c, 0x00000001); 1720 + nv_wr32(dev, 0x419000, 0x00000780); 1721 + nv_wr32(dev, 0x419004, 0x00000000); 1722 + nv_wr32(dev, 0x419008, 0x00000000); 1723 + nv_wr32(dev, 0x419014, 0x00000004); 1724 + } 1725 + 1726 + static void 1727 + nvc0_grctx_generate_tp(struct drm_device *dev) 1728 + { 1729 + struct drm_nouveau_private *dev_priv = dev->dev_private; 1730 + 1731 + // GPC_BROADCAST.TP_BROADCAST 1732 + nv_wr32(dev, 0x419848, 0x00000000); 1733 + nv_wr32(dev, 0x419864, 0x0000012a); 1734 + nv_wr32(dev, 0x419888, 0x00000000); 1735 + nv_wr32(dev, 0x419a00, 0x000001f0); 1736 + nv_wr32(dev, 0x419a04, 0x00000001); 1737 + nv_wr32(dev, 0x419a08, 0x00000023); 1738 + nv_wr32(dev, 0x419a0c, 0x00020000); 1739 + nv_wr32(dev, 0x419a10, 0x00000000); 1740 + nv_wr32(dev, 0x419a14, 0x00000200); 1741 + nv_wr32(dev, 0x419a1c, 0x00000000); 1742 + nv_wr32(dev, 0x419a20, 0x00000800); 1743 + if (dev_priv->chipset != 0xc0) 1744 + nv_wr32(dev, 0x00419ac4, 0x0007f440); // 0xc3 1745 + nv_wr32(dev, 0x419b00, 0x0a418820); 1746 + nv_wr32(dev, 0x419b04, 0x062080e6); 1747 + nv_wr32(dev, 0x419b08, 0x020398a4); 1748 + nv_wr32(dev, 0x419b0c, 0x0e629062); 1749 + nv_wr32(dev, 0x419b10, 0x0a418820); 1750 + nv_wr32(dev, 0x419b14, 0x000000e6); 1751 + nv_wr32(dev, 0x419bd0, 0x00900103); 1752 + nv_wr32(dev, 0x419be0, 0x00000001); 1753 + nv_wr32(dev, 0x419be4, 0x00000000); 1754 + nv_wr32(dev, 0x419c00, 0x00000002); 1755 + nv_wr32(dev, 0x419c04, 0x00000006); 1756 + nv_wr32(dev, 0x419c08, 0x00000002); 1757 + nv_wr32(dev, 0x419c20, 0x00000000); 1758 + nv_wr32(dev, 0x419cbc, 0x28137606); 1759 + nv_wr32(dev, 0x419ce8, 0x00000000); 1760 + nv_wr32(dev, 0x419cf4, 0x00000183); 1761 + nv_wr32(dev, 0x419d20, 0x02180000); 1762 + nv_wr32(dev, 0x419d24, 0x00001fff); 1763 + nv_wr32(dev, 0x419e04, 0x00000000); 1764 + nv_wr32(dev, 0x419e08, 0x00000000); 1765 + nv_wr32(dev, 0x419e0c, 0x00000000); 1766 + nv_wr32(dev, 0x419e10, 0x00000002); 1767 + nv_wr32(dev, 0x419e44, 0x001beff2); 1768 + nv_wr32(dev, 0x419e48, 0x00000000); 1769 + nv_wr32(dev, 0x419e4c, 0x0000000f); 1770 + nv_wr32(dev, 0x419e50, 0x00000000); 1771 + nv_wr32(dev, 0x419e54, 0x00000000); 1772 + nv_wr32(dev, 0x419e58, 0x00000000); 1773 + nv_wr32(dev, 0x419e5c, 0x00000000); 1774 + nv_wr32(dev, 0x419e60, 0x00000000); 1775 + nv_wr32(dev, 0x419e64, 0x00000000); 1776 + nv_wr32(dev, 0x419e68, 0x00000000); 1777 + nv_wr32(dev, 0x419e6c, 0x00000000); 1778 + nv_wr32(dev, 0x419e70, 0x00000000); 1779 + nv_wr32(dev, 0x419e74, 0x00000000); 1780 + nv_wr32(dev, 0x419e78, 0x00000000); 1781 + nv_wr32(dev, 0x419e7c, 0x00000000); 1782 + nv_wr32(dev, 0x419e80, 0x00000000); 1783 + nv_wr32(dev, 0x419e84, 0x00000000); 1784 + nv_wr32(dev, 0x419e88, 0x00000000); 1785 + nv_wr32(dev, 0x419e8c, 0x00000000); 1786 + nv_wr32(dev, 0x419e90, 0x00000000); 1787 + nv_wr32(dev, 0x419e98, 0x00000000); 1788 + if (dev_priv->chipset != 0xc0) 1789 + nv_wr32(dev, 0x419ee0, 0x00011110); 1790 + nv_wr32(dev, 0x419f50, 0x00000000); 1791 + nv_wr32(dev, 0x419f54, 0x00000000); 1792 + if (dev_priv->chipset != 0xc0) 1793 + nv_wr32(dev, 0x419f58, 0x00000000); 1794 + } 1795 + 1796 + int 1797 + nvc0_grctx_generate(struct nouveau_channel *chan) 1798 + { 1799 + struct drm_nouveau_private *dev_priv = chan->dev->dev_private; 1800 + struct nvc0_graph_priv *priv = dev_priv->engine.graph.priv; 1801 + struct nvc0_graph_chan *grch = chan->pgraph_ctx; 1802 + struct drm_device *dev = chan->dev; 1803 + int i, gpc, tp, id; 1804 + u32 r000260; 1805 + 1806 + r000260 = nv_rd32(dev, 0x000260); 1807 + nv_wr32(dev, 0x000260, r000260 & ~1); 1808 + nv_wr32(dev, 0x400208, 0x00000000); 1809 + 1810 + nvc0_grctx_generate_dispatch(dev); 1811 + nvc0_grctx_generate_macro(dev); 1812 + nvc0_grctx_generate_m2mf(dev); 1813 + nvc0_grctx_generate_unk47xx(dev); 1814 + nvc0_grctx_generate_unk58xx(dev); 1815 + nvc0_grctx_generate_unk60xx(dev); 1816 + nvc0_grctx_generate_unk64xx(dev); 1817 + nvc0_grctx_generate_unk78xx(dev); 1818 + nvc0_grctx_generate_unk80xx(dev); 1819 + nvc0_grctx_generate_rop(dev); 1820 + nvc0_grctx_generate_gpc(dev); 1821 + nvc0_grctx_generate_tp(dev); 1822 + 1823 + nv_wr32(dev, 0x404154, 0x00000000); 1824 + 1825 + /* fuc "mmio list" writes */ 1826 + for (i = 0; i < grch->mmio_nr * 8; i += 8) { 1827 + u32 reg = nv_ro32(grch->mmio, i + 0); 1828 + nv_wr32(dev, reg, nv_ro32(grch->mmio, i + 4)); 1829 + } 1830 + 1831 + for (tp = 0, id = 0; tp < 4; tp++) { 1832 + for (gpc = 0; gpc < priv->gpc_nr; gpc++) { 1833 + if (tp <= priv->tp_nr[gpc]) { 1834 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x698), id); 1835 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x4e8), id); 1836 + nv_wr32(dev, GPC_UNIT(gpc, 0x0c10 + tp * 4), id); 1837 + nv_wr32(dev, TP_UNIT(gpc, tp, 0x088), id); 1838 + id++; 1839 + } 1840 + 1841 + nv_wr32(dev, GPC_UNIT(gpc, 0x0c08), priv->tp_nr[gpc]); 1842 + nv_wr32(dev, GPC_UNIT(gpc, 0x0c8c), priv->tp_nr[gpc]); 1843 + } 1844 + } 1845 + 1846 + nv_wr32(dev, 0x406028, 0x00000443); 1847 + nv_wr32(dev, 0x405870, 0x00000443); 1848 + nv_wr32(dev, 0x40602c, 0x00000000); 1849 + nv_wr32(dev, 0x405874, 0x00000000); 1850 + nv_wr32(dev, 0x406030, 0x00000000); 1851 + nv_wr32(dev, 0x405878, 0x00000000); 1852 + nv_wr32(dev, 0x406034, 0x00000000); 1853 + nv_wr32(dev, 0x40587c, 0x00000000); 1854 + 1855 + if (1) { 1856 + const u8 chipset_tp_max[] = { 16, 0, 0, 4, 8 }; 1857 + u8 max = chipset_tp_max[dev_priv->chipset & 0x0f]; 1858 + u8 tpnr[GPC_MAX]; 1859 + u8 data[32]; 1860 + 1861 + memcpy(tpnr, priv->tp_nr, sizeof(priv->tp_nr)); 1862 + memset(data, 0x1f, sizeof(data)); 1863 + 1864 + gpc = -1; 1865 + for (tp = 0; tp < priv->tp_total; tp++) { 1866 + do { 1867 + gpc = (gpc + 1) % priv->gpc_nr; 1868 + } while (!tpnr[gpc]); 1869 + tpnr[gpc]--; 1870 + data[tp] = gpc; 1871 + } 1872 + 1873 + for (i = 0; i < max / 4; i++) 1874 + nv_wr32(dev, 0x4060a8 + (i * 4), ((u32 *)data)[i]); 1875 + } 1876 + 1877 + if (1) { 1878 + u32 data[6] = {}; 1879 + u8 tpnr[GPC_MAX]; 1880 + 1881 + memcpy(tpnr, priv->tp_nr, sizeof(priv->tp_nr)); 1882 + 1883 + for (tp = 0; tp < priv->tp_total; tp++) { 1884 + do { 1885 + gpc = (gpc + 1) % priv->gpc_nr; 1886 + } while (!tpnr[gpc]); 1887 + tpnr[gpc]--; 1888 + 1889 + data[tp / 6] |= gpc << ((tp % 6) * 5); 1890 + } 1891 + 1892 + for (; tp < 32; tp++) 1893 + data[tp / 6] |= 7 << ((tp % 6) * 5); 1894 + 1895 + // GPC_BROADCAST 1896 + nv_wr32(dev, 0x418bb8, (priv->tp_total << 8) | 1897 + priv->magic_not_rop_nr); 1898 + for (i = 0; i < 6; i++) 1899 + nv_wr32(dev, 0x418b08 + (i * 4), data[i]); 1900 + 1901 + // GPC_BROADCAST.TP_BROADCAST 1902 + nv_wr32(dev, 0x419bd0, (priv->tp_total << 8) | 1903 + priv->magic_not_rop_nr | 1904 + priv->magic419bd0); 1905 + nv_wr32(dev, 0x419be4, priv->magic419be4); 1906 + for (i = 0; i < 6; i++) 1907 + nv_wr32(dev, 0x419b00 + (i * 4), data[i]); 1908 + 1909 + // UNK78xx 1910 + nv_wr32(dev, 0x4078bc, (priv->tp_total << 8) | 1911 + priv->magic_not_rop_nr); 1912 + for (i = 0; i < 6; i++) 1913 + nv_wr32(dev, 0x40780c + (i * 4), data[i]); 1914 + } 1915 + 1916 + if (1) { 1917 + u32 tp_mask = 0, tp_set = 0; 1918 + u8 tpnr[GPC_MAX]; 1919 + 1920 + memcpy(tpnr, priv->tp_nr, sizeof(priv->tp_nr)); 1921 + for (gpc = 0; gpc < priv->gpc_nr; gpc++) 1922 + tp_mask |= ((1 << priv->tp_nr[gpc]) - 1) << (gpc * 8); 1923 + 1924 + gpc = -1; 1925 + for (i = 0, gpc = -1; i < 32; i++) { 1926 + int ltp = i * (priv->tp_total - 1) / 32; 1927 + 1928 + do { 1929 + gpc = (gpc + 1) % priv->gpc_nr; 1930 + } while (!tpnr[gpc]); 1931 + tp = priv->tp_nr[gpc] - tpnr[gpc]--; 1932 + 1933 + tp_set |= 1 << ((gpc * 8) + tp); 1934 + 1935 + do { 1936 + nv_wr32(dev, 0x406800 + (i * 0x20), tp_set); 1937 + tp_set ^= tp_mask; 1938 + nv_wr32(dev, 0x406c00 + (i * 0x20), tp_set); 1939 + tp_set ^= tp_mask; 1940 + } while (ltp == (++i * (priv->tp_total - 1) / 32)); 1941 + i--; 1942 + } 1943 + } 1944 + 1945 + nv_wr32(dev, 0x400208, 0x80000000); 1946 + 1947 + nv_icmd(dev, 0x00001000, 0x00000004); 1948 + nv_icmd(dev, 0x000000a9, 0x0000ffff); 1949 + nv_icmd(dev, 0x00000038, 0x0fac6881); 1950 + nv_icmd(dev, 0x0000003d, 0x00000001); 1951 + nv_icmd(dev, 0x000000e8, 0x00000400); 1952 + nv_icmd(dev, 0x000000e9, 0x00000400); 1953 + nv_icmd(dev, 0x000000ea, 0x00000400); 1954 + nv_icmd(dev, 0x000000eb, 0x00000400); 1955 + nv_icmd(dev, 0x000000ec, 0x00000400); 1956 + nv_icmd(dev, 0x000000ed, 0x00000400); 1957 + nv_icmd(dev, 0x000000ee, 0x00000400); 1958 + nv_icmd(dev, 0x000000ef, 0x00000400); 1959 + nv_icmd(dev, 0x00000078, 0x00000300); 1960 + nv_icmd(dev, 0x00000079, 0x00000300); 1961 + nv_icmd(dev, 0x0000007a, 0x00000300); 1962 + nv_icmd(dev, 0x0000007b, 0x00000300); 1963 + nv_icmd(dev, 0x0000007c, 0x00000300); 1964 + nv_icmd(dev, 0x0000007d, 0x00000300); 1965 + nv_icmd(dev, 0x0000007e, 0x00000300); 1966 + nv_icmd(dev, 0x0000007f, 0x00000300); 1967 + nv_icmd(dev, 0x00000050, 0x00000011); 1968 + nv_icmd(dev, 0x00000058, 0x00000008); 1969 + nv_icmd(dev, 0x00000059, 0x00000008); 1970 + nv_icmd(dev, 0x0000005a, 0x00000008); 1971 + nv_icmd(dev, 0x0000005b, 0x00000008); 1972 + nv_icmd(dev, 0x0000005c, 0x00000008); 1973 + nv_icmd(dev, 0x0000005d, 0x00000008); 1974 + nv_icmd(dev, 0x0000005e, 0x00000008); 1975 + nv_icmd(dev, 0x0000005f, 0x00000008); 1976 + nv_icmd(dev, 0x00000208, 0x00000001); 1977 + nv_icmd(dev, 0x00000209, 0x00000001); 1978 + nv_icmd(dev, 0x0000020a, 0x00000001); 1979 + nv_icmd(dev, 0x0000020b, 0x00000001); 1980 + nv_icmd(dev, 0x0000020c, 0x00000001); 1981 + nv_icmd(dev, 0x0000020d, 0x00000001); 1982 + nv_icmd(dev, 0x0000020e, 0x00000001); 1983 + nv_icmd(dev, 0x0000020f, 0x00000001); 1984 + nv_icmd(dev, 0x00000081, 0x00000001); 1985 + nv_icmd(dev, 0x00000085, 0x00000004); 1986 + nv_icmd(dev, 0x00000088, 0x00000400); 1987 + nv_icmd(dev, 0x00000090, 0x00000300); 1988 + nv_icmd(dev, 0x00000098, 0x00001001); 1989 + nv_icmd(dev, 0x000000e3, 0x00000001); 1990 + nv_icmd(dev, 0x000000da, 0x00000001); 1991 + nv_icmd(dev, 0x000000f8, 0x00000003); 1992 + nv_icmd(dev, 0x000000fa, 0x00000001); 1993 + nv_icmd(dev, 0x0000009f, 0x0000ffff); 1994 + nv_icmd(dev, 0x000000a0, 0x0000ffff); 1995 + nv_icmd(dev, 0x000000a1, 0x0000ffff); 1996 + nv_icmd(dev, 0x000000a2, 0x0000ffff); 1997 + nv_icmd(dev, 0x000000b1, 0x00000001); 1998 + nv_icmd(dev, 0x000000b2, 0x00000000); 1999 + nv_icmd(dev, 0x000000b3, 0x00000000); 2000 + nv_icmd(dev, 0x000000b4, 0x00000000); 2001 + nv_icmd(dev, 0x000000b5, 0x00000000); 2002 + nv_icmd(dev, 0x000000b6, 0x00000000); 2003 + nv_icmd(dev, 0x000000b7, 0x00000000); 2004 + nv_icmd(dev, 0x000000b8, 0x00000000); 2005 + nv_icmd(dev, 0x000000b9, 0x00000000); 2006 + nv_icmd(dev, 0x000000ba, 0x00000000); 2007 + nv_icmd(dev, 0x000000bb, 0x00000000); 2008 + nv_icmd(dev, 0x000000bc, 0x00000000); 2009 + nv_icmd(dev, 0x000000bd, 0x00000000); 2010 + nv_icmd(dev, 0x000000be, 0x00000000); 2011 + nv_icmd(dev, 0x000000bf, 0x00000000); 2012 + nv_icmd(dev, 0x000000c0, 0x00000000); 2013 + nv_icmd(dev, 0x000000c1, 0x00000000); 2014 + nv_icmd(dev, 0x000000c2, 0x00000000); 2015 + nv_icmd(dev, 0x000000c3, 0x00000000); 2016 + nv_icmd(dev, 0x000000c4, 0x00000000); 2017 + nv_icmd(dev, 0x000000c5, 0x00000000); 2018 + nv_icmd(dev, 0x000000c6, 0x00000000); 2019 + nv_icmd(dev, 0x000000c7, 0x00000000); 2020 + nv_icmd(dev, 0x000000c8, 0x00000000); 2021 + nv_icmd(dev, 0x000000c9, 0x00000000); 2022 + nv_icmd(dev, 0x000000ca, 0x00000000); 2023 + nv_icmd(dev, 0x000000cb, 0x00000000); 2024 + nv_icmd(dev, 0x000000cc, 0x00000000); 2025 + nv_icmd(dev, 0x000000cd, 0x00000000); 2026 + nv_icmd(dev, 0x000000ce, 0x00000000); 2027 + nv_icmd(dev, 0x000000cf, 0x00000000); 2028 + nv_icmd(dev, 0x000000d0, 0x00000000); 2029 + nv_icmd(dev, 0x000000d1, 0x00000000); 2030 + nv_icmd(dev, 0x000000d2, 0x00000000); 2031 + nv_icmd(dev, 0x000000d3, 0x00000000); 2032 + nv_icmd(dev, 0x000000d4, 0x00000000); 2033 + nv_icmd(dev, 0x000000d5, 0x00000000); 2034 + nv_icmd(dev, 0x000000d6, 0x00000000); 2035 + nv_icmd(dev, 0x000000d7, 0x00000000); 2036 + nv_icmd(dev, 0x000000d8, 0x00000000); 2037 + nv_icmd(dev, 0x000000d9, 0x00000000); 2038 + nv_icmd(dev, 0x00000210, 0x00000040); 2039 + nv_icmd(dev, 0x00000211, 0x00000040); 2040 + nv_icmd(dev, 0x00000212, 0x00000040); 2041 + nv_icmd(dev, 0x00000213, 0x00000040); 2042 + nv_icmd(dev, 0x00000214, 0x00000040); 2043 + nv_icmd(dev, 0x00000215, 0x00000040); 2044 + nv_icmd(dev, 0x00000216, 0x00000040); 2045 + nv_icmd(dev, 0x00000217, 0x00000040); 2046 + nv_icmd(dev, 0x00000218, 0x0000c080); 2047 + nv_icmd(dev, 0x00000219, 0x0000c080); 2048 + nv_icmd(dev, 0x0000021a, 0x0000c080); 2049 + nv_icmd(dev, 0x0000021b, 0x0000c080); 2050 + nv_icmd(dev, 0x0000021c, 0x0000c080); 2051 + nv_icmd(dev, 0x0000021d, 0x0000c080); 2052 + nv_icmd(dev, 0x0000021e, 0x0000c080); 2053 + nv_icmd(dev, 0x0000021f, 0x0000c080); 2054 + nv_icmd(dev, 0x000000ad, 0x0000013e); 2055 + nv_icmd(dev, 0x000000e1, 0x00000010); 2056 + nv_icmd(dev, 0x00000290, 0x00000000); 2057 + nv_icmd(dev, 0x00000291, 0x00000000); 2058 + nv_icmd(dev, 0x00000292, 0x00000000); 2059 + nv_icmd(dev, 0x00000293, 0x00000000); 2060 + nv_icmd(dev, 0x00000294, 0x00000000); 2061 + nv_icmd(dev, 0x00000295, 0x00000000); 2062 + nv_icmd(dev, 0x00000296, 0x00000000); 2063 + nv_icmd(dev, 0x00000297, 0x00000000); 2064 + nv_icmd(dev, 0x00000298, 0x00000000); 2065 + nv_icmd(dev, 0x00000299, 0x00000000); 2066 + nv_icmd(dev, 0x0000029a, 0x00000000); 2067 + nv_icmd(dev, 0x0000029b, 0x00000000); 2068 + nv_icmd(dev, 0x0000029c, 0x00000000); 2069 + nv_icmd(dev, 0x0000029d, 0x00000000); 2070 + nv_icmd(dev, 0x0000029e, 0x00000000); 2071 + nv_icmd(dev, 0x0000029f, 0x00000000); 2072 + nv_icmd(dev, 0x000003b0, 0x00000000); 2073 + nv_icmd(dev, 0x000003b1, 0x00000000); 2074 + nv_icmd(dev, 0x000003b2, 0x00000000); 2075 + nv_icmd(dev, 0x000003b3, 0x00000000); 2076 + nv_icmd(dev, 0x000003b4, 0x00000000); 2077 + nv_icmd(dev, 0x000003b5, 0x00000000); 2078 + nv_icmd(dev, 0x000003b6, 0x00000000); 2079 + nv_icmd(dev, 0x000003b7, 0x00000000); 2080 + nv_icmd(dev, 0x000003b8, 0x00000000); 2081 + nv_icmd(dev, 0x000003b9, 0x00000000); 2082 + nv_icmd(dev, 0x000003ba, 0x00000000); 2083 + nv_icmd(dev, 0x000003bb, 0x00000000); 2084 + nv_icmd(dev, 0x000003bc, 0x00000000); 2085 + nv_icmd(dev, 0x000003bd, 0x00000000); 2086 + nv_icmd(dev, 0x000003be, 0x00000000); 2087 + nv_icmd(dev, 0x000003bf, 0x00000000); 2088 + nv_icmd(dev, 0x000002a0, 0x00000000); 2089 + nv_icmd(dev, 0x000002a1, 0x00000000); 2090 + nv_icmd(dev, 0x000002a2, 0x00000000); 2091 + nv_icmd(dev, 0x000002a3, 0x00000000); 2092 + nv_icmd(dev, 0x000002a4, 0x00000000); 2093 + nv_icmd(dev, 0x000002a5, 0x00000000); 2094 + nv_icmd(dev, 0x000002a6, 0x00000000); 2095 + nv_icmd(dev, 0x000002a7, 0x00000000); 2096 + nv_icmd(dev, 0x000002a8, 0x00000000); 2097 + nv_icmd(dev, 0x000002a9, 0x00000000); 2098 + nv_icmd(dev, 0x000002aa, 0x00000000); 2099 + nv_icmd(dev, 0x000002ab, 0x00000000); 2100 + nv_icmd(dev, 0x000002ac, 0x00000000); 2101 + nv_icmd(dev, 0x000002ad, 0x00000000); 2102 + nv_icmd(dev, 0x000002ae, 0x00000000); 2103 + nv_icmd(dev, 0x000002af, 0x00000000); 2104 + nv_icmd(dev, 0x00000420, 0x00000000); 2105 + nv_icmd(dev, 0x00000421, 0x00000000); 2106 + nv_icmd(dev, 0x00000422, 0x00000000); 2107 + nv_icmd(dev, 0x00000423, 0x00000000); 2108 + nv_icmd(dev, 0x00000424, 0x00000000); 2109 + nv_icmd(dev, 0x00000425, 0x00000000); 2110 + nv_icmd(dev, 0x00000426, 0x00000000); 2111 + nv_icmd(dev, 0x00000427, 0x00000000); 2112 + nv_icmd(dev, 0x00000428, 0x00000000); 2113 + nv_icmd(dev, 0x00000429, 0x00000000); 2114 + nv_icmd(dev, 0x0000042a, 0x00000000); 2115 + nv_icmd(dev, 0x0000042b, 0x00000000); 2116 + nv_icmd(dev, 0x0000042c, 0x00000000); 2117 + nv_icmd(dev, 0x0000042d, 0x00000000); 2118 + nv_icmd(dev, 0x0000042e, 0x00000000); 2119 + nv_icmd(dev, 0x0000042f, 0x00000000); 2120 + nv_icmd(dev, 0x000002b0, 0x00000000); 2121 + nv_icmd(dev, 0x000002b1, 0x00000000); 2122 + nv_icmd(dev, 0x000002b2, 0x00000000); 2123 + nv_icmd(dev, 0x000002b3, 0x00000000); 2124 + nv_icmd(dev, 0x000002b4, 0x00000000); 2125 + nv_icmd(dev, 0x000002b5, 0x00000000); 2126 + nv_icmd(dev, 0x000002b6, 0x00000000); 2127 + nv_icmd(dev, 0x000002b7, 0x00000000); 2128 + nv_icmd(dev, 0x000002b8, 0x00000000); 2129 + nv_icmd(dev, 0x000002b9, 0x00000000); 2130 + nv_icmd(dev, 0x000002ba, 0x00000000); 2131 + nv_icmd(dev, 0x000002bb, 0x00000000); 2132 + nv_icmd(dev, 0x000002bc, 0x00000000); 2133 + nv_icmd(dev, 0x000002bd, 0x00000000); 2134 + nv_icmd(dev, 0x000002be, 0x00000000); 2135 + nv_icmd(dev, 0x000002bf, 0x00000000); 2136 + nv_icmd(dev, 0x00000430, 0x00000000); 2137 + nv_icmd(dev, 0x00000431, 0x00000000); 2138 + nv_icmd(dev, 0x00000432, 0x00000000); 2139 + nv_icmd(dev, 0x00000433, 0x00000000); 2140 + nv_icmd(dev, 0x00000434, 0x00000000); 2141 + nv_icmd(dev, 0x00000435, 0x00000000); 2142 + nv_icmd(dev, 0x00000436, 0x00000000); 2143 + nv_icmd(dev, 0x00000437, 0x00000000); 2144 + nv_icmd(dev, 0x00000438, 0x00000000); 2145 + nv_icmd(dev, 0x00000439, 0x00000000); 2146 + nv_icmd(dev, 0x0000043a, 0x00000000); 2147 + nv_icmd(dev, 0x0000043b, 0x00000000); 2148 + nv_icmd(dev, 0x0000043c, 0x00000000); 2149 + nv_icmd(dev, 0x0000043d, 0x00000000); 2150 + nv_icmd(dev, 0x0000043e, 0x00000000); 2151 + nv_icmd(dev, 0x0000043f, 0x00000000); 2152 + nv_icmd(dev, 0x000002c0, 0x00000000); 2153 + nv_icmd(dev, 0x000002c1, 0x00000000); 2154 + nv_icmd(dev, 0x000002c2, 0x00000000); 2155 + nv_icmd(dev, 0x000002c3, 0x00000000); 2156 + nv_icmd(dev, 0x000002c4, 0x00000000); 2157 + nv_icmd(dev, 0x000002c5, 0x00000000); 2158 + nv_icmd(dev, 0x000002c6, 0x00000000); 2159 + nv_icmd(dev, 0x000002c7, 0x00000000); 2160 + nv_icmd(dev, 0x000002c8, 0x00000000); 2161 + nv_icmd(dev, 0x000002c9, 0x00000000); 2162 + nv_icmd(dev, 0x000002ca, 0x00000000); 2163 + nv_icmd(dev, 0x000002cb, 0x00000000); 2164 + nv_icmd(dev, 0x000002cc, 0x00000000); 2165 + nv_icmd(dev, 0x000002cd, 0x00000000); 2166 + nv_icmd(dev, 0x000002ce, 0x00000000); 2167 + nv_icmd(dev, 0x000002cf, 0x00000000); 2168 + nv_icmd(dev, 0x000004d0, 0x00000000); 2169 + nv_icmd(dev, 0x000004d1, 0x00000000); 2170 + nv_icmd(dev, 0x000004d2, 0x00000000); 2171 + nv_icmd(dev, 0x000004d3, 0x00000000); 2172 + nv_icmd(dev, 0x000004d4, 0x00000000); 2173 + nv_icmd(dev, 0x000004d5, 0x00000000); 2174 + nv_icmd(dev, 0x000004d6, 0x00000000); 2175 + nv_icmd(dev, 0x000004d7, 0x00000000); 2176 + nv_icmd(dev, 0x000004d8, 0x00000000); 2177 + nv_icmd(dev, 0x000004d9, 0x00000000); 2178 + nv_icmd(dev, 0x000004da, 0x00000000); 2179 + nv_icmd(dev, 0x000004db, 0x00000000); 2180 + nv_icmd(dev, 0x000004dc, 0x00000000); 2181 + nv_icmd(dev, 0x000004dd, 0x00000000); 2182 + nv_icmd(dev, 0x000004de, 0x00000000); 2183 + nv_icmd(dev, 0x000004df, 0x00000000); 2184 + nv_icmd(dev, 0x00000720, 0x00000000); 2185 + nv_icmd(dev, 0x00000721, 0x00000000); 2186 + nv_icmd(dev, 0x00000722, 0x00000000); 2187 + nv_icmd(dev, 0x00000723, 0x00000000); 2188 + nv_icmd(dev, 0x00000724, 0x00000000); 2189 + nv_icmd(dev, 0x00000725, 0x00000000); 2190 + nv_icmd(dev, 0x00000726, 0x00000000); 2191 + nv_icmd(dev, 0x00000727, 0x00000000); 2192 + nv_icmd(dev, 0x00000728, 0x00000000); 2193 + nv_icmd(dev, 0x00000729, 0x00000000); 2194 + nv_icmd(dev, 0x0000072a, 0x00000000); 2195 + nv_icmd(dev, 0x0000072b, 0x00000000); 2196 + nv_icmd(dev, 0x0000072c, 0x00000000); 2197 + nv_icmd(dev, 0x0000072d, 0x00000000); 2198 + nv_icmd(dev, 0x0000072e, 0x00000000); 2199 + nv_icmd(dev, 0x0000072f, 0x00000000); 2200 + nv_icmd(dev, 0x000008c0, 0x00000000); 2201 + nv_icmd(dev, 0x000008c1, 0x00000000); 2202 + nv_icmd(dev, 0x000008c2, 0x00000000); 2203 + nv_icmd(dev, 0x000008c3, 0x00000000); 2204 + nv_icmd(dev, 0x000008c4, 0x00000000); 2205 + nv_icmd(dev, 0x000008c5, 0x00000000); 2206 + nv_icmd(dev, 0x000008c6, 0x00000000); 2207 + nv_icmd(dev, 0x000008c7, 0x00000000); 2208 + nv_icmd(dev, 0x000008c8, 0x00000000); 2209 + nv_icmd(dev, 0x000008c9, 0x00000000); 2210 + nv_icmd(dev, 0x000008ca, 0x00000000); 2211 + nv_icmd(dev, 0x000008cb, 0x00000000); 2212 + nv_icmd(dev, 0x000008cc, 0x00000000); 2213 + nv_icmd(dev, 0x000008cd, 0x00000000); 2214 + nv_icmd(dev, 0x000008ce, 0x00000000); 2215 + nv_icmd(dev, 0x000008cf, 0x00000000); 2216 + nv_icmd(dev, 0x00000890, 0x00000000); 2217 + nv_icmd(dev, 0x00000891, 0x00000000); 2218 + nv_icmd(dev, 0x00000892, 0x00000000); 2219 + nv_icmd(dev, 0x00000893, 0x00000000); 2220 + nv_icmd(dev, 0x00000894, 0x00000000); 2221 + nv_icmd(dev, 0x00000895, 0x00000000); 2222 + nv_icmd(dev, 0x00000896, 0x00000000); 2223 + nv_icmd(dev, 0x00000897, 0x00000000); 2224 + nv_icmd(dev, 0x00000898, 0x00000000); 2225 + nv_icmd(dev, 0x00000899, 0x00000000); 2226 + nv_icmd(dev, 0x0000089a, 0x00000000); 2227 + nv_icmd(dev, 0x0000089b, 0x00000000); 2228 + nv_icmd(dev, 0x0000089c, 0x00000000); 2229 + nv_icmd(dev, 0x0000089d, 0x00000000); 2230 + nv_icmd(dev, 0x0000089e, 0x00000000); 2231 + nv_icmd(dev, 0x0000089f, 0x00000000); 2232 + nv_icmd(dev, 0x000008e0, 0x00000000); 2233 + nv_icmd(dev, 0x000008e1, 0x00000000); 2234 + nv_icmd(dev, 0x000008e2, 0x00000000); 2235 + nv_icmd(dev, 0x000008e3, 0x00000000); 2236 + nv_icmd(dev, 0x000008e4, 0x00000000); 2237 + nv_icmd(dev, 0x000008e5, 0x00000000); 2238 + nv_icmd(dev, 0x000008e6, 0x00000000); 2239 + nv_icmd(dev, 0x000008e7, 0x00000000); 2240 + nv_icmd(dev, 0x000008e8, 0x00000000); 2241 + nv_icmd(dev, 0x000008e9, 0x00000000); 2242 + nv_icmd(dev, 0x000008ea, 0x00000000); 2243 + nv_icmd(dev, 0x000008eb, 0x00000000); 2244 + nv_icmd(dev, 0x000008ec, 0x00000000); 2245 + nv_icmd(dev, 0x000008ed, 0x00000000); 2246 + nv_icmd(dev, 0x000008ee, 0x00000000); 2247 + nv_icmd(dev, 0x000008ef, 0x00000000); 2248 + nv_icmd(dev, 0x000008a0, 0x00000000); 2249 + nv_icmd(dev, 0x000008a1, 0x00000000); 2250 + nv_icmd(dev, 0x000008a2, 0x00000000); 2251 + nv_icmd(dev, 0x000008a3, 0x00000000); 2252 + nv_icmd(dev, 0x000008a4, 0x00000000); 2253 + nv_icmd(dev, 0x000008a5, 0x00000000); 2254 + nv_icmd(dev, 0x000008a6, 0x00000000); 2255 + nv_icmd(dev, 0x000008a7, 0x00000000); 2256 + nv_icmd(dev, 0x000008a8, 0x00000000); 2257 + nv_icmd(dev, 0x000008a9, 0x00000000); 2258 + nv_icmd(dev, 0x000008aa, 0x00000000); 2259 + nv_icmd(dev, 0x000008ab, 0x00000000); 2260 + nv_icmd(dev, 0x000008ac, 0x00000000); 2261 + nv_icmd(dev, 0x000008ad, 0x00000000); 2262 + nv_icmd(dev, 0x000008ae, 0x00000000); 2263 + nv_icmd(dev, 0x000008af, 0x00000000); 2264 + nv_icmd(dev, 0x000008f0, 0x00000000); 2265 + nv_icmd(dev, 0x000008f1, 0x00000000); 2266 + nv_icmd(dev, 0x000008f2, 0x00000000); 2267 + nv_icmd(dev, 0x000008f3, 0x00000000); 2268 + nv_icmd(dev, 0x000008f4, 0x00000000); 2269 + nv_icmd(dev, 0x000008f5, 0x00000000); 2270 + nv_icmd(dev, 0x000008f6, 0x00000000); 2271 + nv_icmd(dev, 0x000008f7, 0x00000000); 2272 + nv_icmd(dev, 0x000008f8, 0x00000000); 2273 + nv_icmd(dev, 0x000008f9, 0x00000000); 2274 + nv_icmd(dev, 0x000008fa, 0x00000000); 2275 + nv_icmd(dev, 0x000008fb, 0x00000000); 2276 + nv_icmd(dev, 0x000008fc, 0x00000000); 2277 + nv_icmd(dev, 0x000008fd, 0x00000000); 2278 + nv_icmd(dev, 0x000008fe, 0x00000000); 2279 + nv_icmd(dev, 0x000008ff, 0x00000000); 2280 + nv_icmd(dev, 0x0000094c, 0x000000ff); 2281 + nv_icmd(dev, 0x0000094d, 0xffffffff); 2282 + nv_icmd(dev, 0x0000094e, 0x00000002); 2283 + nv_icmd(dev, 0x000002ec, 0x00000001); 2284 + nv_icmd(dev, 0x00000303, 0x00000001); 2285 + nv_icmd(dev, 0x000002e6, 0x00000001); 2286 + nv_icmd(dev, 0x00000466, 0x00000052); 2287 + nv_icmd(dev, 0x00000301, 0x3f800000); 2288 + nv_icmd(dev, 0x00000304, 0x30201000); 2289 + nv_icmd(dev, 0x00000305, 0x70605040); 2290 + nv_icmd(dev, 0x00000306, 0xb8a89888); 2291 + nv_icmd(dev, 0x00000307, 0xf8e8d8c8); 2292 + nv_icmd(dev, 0x0000030a, 0x00ffff00); 2293 + nv_icmd(dev, 0x0000030b, 0x0000001a); 2294 + nv_icmd(dev, 0x0000030c, 0x00000001); 2295 + nv_icmd(dev, 0x00000318, 0x00000001); 2296 + nv_icmd(dev, 0x00000340, 0x00000000); 2297 + nv_icmd(dev, 0x00000375, 0x00000001); 2298 + nv_icmd(dev, 0x00000351, 0x00000100); 2299 + nv_icmd(dev, 0x0000037d, 0x00000006); 2300 + nv_icmd(dev, 0x000003a0, 0x00000002); 2301 + nv_icmd(dev, 0x000003aa, 0x00000001); 2302 + nv_icmd(dev, 0x000003a9, 0x00000001); 2303 + nv_icmd(dev, 0x00000380, 0x00000001); 2304 + nv_icmd(dev, 0x00000360, 0x00000040); 2305 + nv_icmd(dev, 0x00000366, 0x00000000); 2306 + nv_icmd(dev, 0x00000367, 0x00000000); 2307 + nv_icmd(dev, 0x00000368, 0x00001fff); 2308 + nv_icmd(dev, 0x00000370, 0x00000000); 2309 + nv_icmd(dev, 0x00000371, 0x00000000); 2310 + nv_icmd(dev, 0x00000372, 0x003fffff); 2311 + nv_icmd(dev, 0x0000037a, 0x00000012); 2312 + nv_icmd(dev, 0x000005e0, 0x00000022); 2313 + nv_icmd(dev, 0x000005e1, 0x00000022); 2314 + nv_icmd(dev, 0x000005e2, 0x00000022); 2315 + nv_icmd(dev, 0x000005e3, 0x00000022); 2316 + nv_icmd(dev, 0x000005e4, 0x00000022); 2317 + nv_icmd(dev, 0x00000619, 0x00000003); 2318 + nv_icmd(dev, 0x00000811, 0x00000003); 2319 + nv_icmd(dev, 0x00000812, 0x00000004); 2320 + nv_icmd(dev, 0x00000813, 0x00000006); 2321 + nv_icmd(dev, 0x00000814, 0x00000008); 2322 + nv_icmd(dev, 0x00000815, 0x0000000b); 2323 + nv_icmd(dev, 0x00000800, 0x00000001); 2324 + nv_icmd(dev, 0x00000801, 0x00000001); 2325 + nv_icmd(dev, 0x00000802, 0x00000001); 2326 + nv_icmd(dev, 0x00000803, 0x00000001); 2327 + nv_icmd(dev, 0x00000804, 0x00000001); 2328 + nv_icmd(dev, 0x00000805, 0x00000001); 2329 + nv_icmd(dev, 0x00000632, 0x00000001); 2330 + nv_icmd(dev, 0x00000633, 0x00000002); 2331 + nv_icmd(dev, 0x00000634, 0x00000003); 2332 + nv_icmd(dev, 0x00000635, 0x00000004); 2333 + nv_icmd(dev, 0x00000654, 0x3f800000); 2334 + nv_icmd(dev, 0x00000657, 0x3f800000); 2335 + nv_icmd(dev, 0x00000655, 0x3f800000); 2336 + nv_icmd(dev, 0x00000656, 0x3f800000); 2337 + nv_icmd(dev, 0x000006cd, 0x3f800000); 2338 + nv_icmd(dev, 0x000007f5, 0x3f800000); 2339 + nv_icmd(dev, 0x000007dc, 0x39291909); 2340 + nv_icmd(dev, 0x000007dd, 0x79695949); 2341 + nv_icmd(dev, 0x000007de, 0xb9a99989); 2342 + nv_icmd(dev, 0x000007df, 0xf9e9d9c9); 2343 + nv_icmd(dev, 0x000007e8, 0x00003210); 2344 + nv_icmd(dev, 0x000007e9, 0x00007654); 2345 + nv_icmd(dev, 0x000007ea, 0x00000098); 2346 + nv_icmd(dev, 0x000007ec, 0x39291909); 2347 + nv_icmd(dev, 0x000007ed, 0x79695949); 2348 + nv_icmd(dev, 0x000007ee, 0xb9a99989); 2349 + nv_icmd(dev, 0x000007ef, 0xf9e9d9c9); 2350 + nv_icmd(dev, 0x000007f0, 0x00003210); 2351 + nv_icmd(dev, 0x000007f1, 0x00007654); 2352 + nv_icmd(dev, 0x000007f2, 0x00000098); 2353 + nv_icmd(dev, 0x000005a5, 0x00000001); 2354 + nv_icmd(dev, 0x00000980, 0x00000000); 2355 + nv_icmd(dev, 0x00000981, 0x00000000); 2356 + nv_icmd(dev, 0x00000982, 0x00000000); 2357 + nv_icmd(dev, 0x00000983, 0x00000000); 2358 + nv_icmd(dev, 0x00000984, 0x00000000); 2359 + nv_icmd(dev, 0x00000985, 0x00000000); 2360 + nv_icmd(dev, 0x00000986, 0x00000000); 2361 + nv_icmd(dev, 0x00000987, 0x00000000); 2362 + nv_icmd(dev, 0x00000988, 0x00000000); 2363 + nv_icmd(dev, 0x00000989, 0x00000000); 2364 + nv_icmd(dev, 0x0000098a, 0x00000000); 2365 + nv_icmd(dev, 0x0000098b, 0x00000000); 2366 + nv_icmd(dev, 0x0000098c, 0x00000000); 2367 + nv_icmd(dev, 0x0000098d, 0x00000000); 2368 + nv_icmd(dev, 0x0000098e, 0x00000000); 2369 + nv_icmd(dev, 0x0000098f, 0x00000000); 2370 + nv_icmd(dev, 0x00000990, 0x00000000); 2371 + nv_icmd(dev, 0x00000991, 0x00000000); 2372 + nv_icmd(dev, 0x00000992, 0x00000000); 2373 + nv_icmd(dev, 0x00000993, 0x00000000); 2374 + nv_icmd(dev, 0x00000994, 0x00000000); 2375 + nv_icmd(dev, 0x00000995, 0x00000000); 2376 + nv_icmd(dev, 0x00000996, 0x00000000); 2377 + nv_icmd(dev, 0x00000997, 0x00000000); 2378 + nv_icmd(dev, 0x00000998, 0x00000000); 2379 + nv_icmd(dev, 0x00000999, 0x00000000); 2380 + nv_icmd(dev, 0x0000099a, 0x00000000); 2381 + nv_icmd(dev, 0x0000099b, 0x00000000); 2382 + nv_icmd(dev, 0x0000099c, 0x00000000); 2383 + nv_icmd(dev, 0x0000099d, 0x00000000); 2384 + nv_icmd(dev, 0x0000099e, 0x00000000); 2385 + nv_icmd(dev, 0x0000099f, 0x00000000); 2386 + nv_icmd(dev, 0x000009a0, 0x00000000); 2387 + nv_icmd(dev, 0x000009a1, 0x00000000); 2388 + nv_icmd(dev, 0x000009a2, 0x00000000); 2389 + nv_icmd(dev, 0x000009a3, 0x00000000); 2390 + nv_icmd(dev, 0x000009a4, 0x00000000); 2391 + nv_icmd(dev, 0x000009a5, 0x00000000); 2392 + nv_icmd(dev, 0x000009a6, 0x00000000); 2393 + nv_icmd(dev, 0x000009a7, 0x00000000); 2394 + nv_icmd(dev, 0x000009a8, 0x00000000); 2395 + nv_icmd(dev, 0x000009a9, 0x00000000); 2396 + nv_icmd(dev, 0x000009aa, 0x00000000); 2397 + nv_icmd(dev, 0x000009ab, 0x00000000); 2398 + nv_icmd(dev, 0x000009ac, 0x00000000); 2399 + nv_icmd(dev, 0x000009ad, 0x00000000); 2400 + nv_icmd(dev, 0x000009ae, 0x00000000); 2401 + nv_icmd(dev, 0x000009af, 0x00000000); 2402 + nv_icmd(dev, 0x000009b0, 0x00000000); 2403 + nv_icmd(dev, 0x000009b1, 0x00000000); 2404 + nv_icmd(dev, 0x000009b2, 0x00000000); 2405 + nv_icmd(dev, 0x000009b3, 0x00000000); 2406 + nv_icmd(dev, 0x000009b4, 0x00000000); 2407 + nv_icmd(dev, 0x000009b5, 0x00000000); 2408 + nv_icmd(dev, 0x000009b6, 0x00000000); 2409 + nv_icmd(dev, 0x000009b7, 0x00000000); 2410 + nv_icmd(dev, 0x000009b8, 0x00000000); 2411 + nv_icmd(dev, 0x000009b9, 0x00000000); 2412 + nv_icmd(dev, 0x000009ba, 0x00000000); 2413 + nv_icmd(dev, 0x000009bb, 0x00000000); 2414 + nv_icmd(dev, 0x000009bc, 0x00000000); 2415 + nv_icmd(dev, 0x000009bd, 0x00000000); 2416 + nv_icmd(dev, 0x000009be, 0x00000000); 2417 + nv_icmd(dev, 0x000009bf, 0x00000000); 2418 + nv_icmd(dev, 0x000009c0, 0x00000000); 2419 + nv_icmd(dev, 0x000009c1, 0x00000000); 2420 + nv_icmd(dev, 0x000009c2, 0x00000000); 2421 + nv_icmd(dev, 0x000009c3, 0x00000000); 2422 + nv_icmd(dev, 0x000009c4, 0x00000000); 2423 + nv_icmd(dev, 0x000009c5, 0x00000000); 2424 + nv_icmd(dev, 0x000009c6, 0x00000000); 2425 + nv_icmd(dev, 0x000009c7, 0x00000000); 2426 + nv_icmd(dev, 0x000009c8, 0x00000000); 2427 + nv_icmd(dev, 0x000009c9, 0x00000000); 2428 + nv_icmd(dev, 0x000009ca, 0x00000000); 2429 + nv_icmd(dev, 0x000009cb, 0x00000000); 2430 + nv_icmd(dev, 0x000009cc, 0x00000000); 2431 + nv_icmd(dev, 0x000009cd, 0x00000000); 2432 + nv_icmd(dev, 0x000009ce, 0x00000000); 2433 + nv_icmd(dev, 0x000009cf, 0x00000000); 2434 + nv_icmd(dev, 0x000009d0, 0x00000000); 2435 + nv_icmd(dev, 0x000009d1, 0x00000000); 2436 + nv_icmd(dev, 0x000009d2, 0x00000000); 2437 + nv_icmd(dev, 0x000009d3, 0x00000000); 2438 + nv_icmd(dev, 0x000009d4, 0x00000000); 2439 + nv_icmd(dev, 0x000009d5, 0x00000000); 2440 + nv_icmd(dev, 0x000009d6, 0x00000000); 2441 + nv_icmd(dev, 0x000009d7, 0x00000000); 2442 + nv_icmd(dev, 0x000009d8, 0x00000000); 2443 + nv_icmd(dev, 0x000009d9, 0x00000000); 2444 + nv_icmd(dev, 0x000009da, 0x00000000); 2445 + nv_icmd(dev, 0x000009db, 0x00000000); 2446 + nv_icmd(dev, 0x000009dc, 0x00000000); 2447 + nv_icmd(dev, 0x000009dd, 0x00000000); 2448 + nv_icmd(dev, 0x000009de, 0x00000000); 2449 + nv_icmd(dev, 0x000009df, 0x00000000); 2450 + nv_icmd(dev, 0x000009e0, 0x00000000); 2451 + nv_icmd(dev, 0x000009e1, 0x00000000); 2452 + nv_icmd(dev, 0x000009e2, 0x00000000); 2453 + nv_icmd(dev, 0x000009e3, 0x00000000); 2454 + nv_icmd(dev, 0x000009e4, 0x00000000); 2455 + nv_icmd(dev, 0x000009e5, 0x00000000); 2456 + nv_icmd(dev, 0x000009e6, 0x00000000); 2457 + nv_icmd(dev, 0x000009e7, 0x00000000); 2458 + nv_icmd(dev, 0x000009e8, 0x00000000); 2459 + nv_icmd(dev, 0x000009e9, 0x00000000); 2460 + nv_icmd(dev, 0x000009ea, 0x00000000); 2461 + nv_icmd(dev, 0x000009eb, 0x00000000); 2462 + nv_icmd(dev, 0x000009ec, 0x00000000); 2463 + nv_icmd(dev, 0x000009ed, 0x00000000); 2464 + nv_icmd(dev, 0x000009ee, 0x00000000); 2465 + nv_icmd(dev, 0x000009ef, 0x00000000); 2466 + nv_icmd(dev, 0x000009f0, 0x00000000); 2467 + nv_icmd(dev, 0x000009f1, 0x00000000); 2468 + nv_icmd(dev, 0x000009f2, 0x00000000); 2469 + nv_icmd(dev, 0x000009f3, 0x00000000); 2470 + nv_icmd(dev, 0x000009f4, 0x00000000); 2471 + nv_icmd(dev, 0x000009f5, 0x00000000); 2472 + nv_icmd(dev, 0x000009f6, 0x00000000); 2473 + nv_icmd(dev, 0x000009f7, 0x00000000); 2474 + nv_icmd(dev, 0x000009f8, 0x00000000); 2475 + nv_icmd(dev, 0x000009f9, 0x00000000); 2476 + nv_icmd(dev, 0x000009fa, 0x00000000); 2477 + nv_icmd(dev, 0x000009fb, 0x00000000); 2478 + nv_icmd(dev, 0x000009fc, 0x00000000); 2479 + nv_icmd(dev, 0x000009fd, 0x00000000); 2480 + nv_icmd(dev, 0x000009fe, 0x00000000); 2481 + nv_icmd(dev, 0x000009ff, 0x00000000); 2482 + nv_icmd(dev, 0x00000468, 0x00000004); 2483 + nv_icmd(dev, 0x0000046c, 0x00000001); 2484 + nv_icmd(dev, 0x00000470, 0x00000000); 2485 + nv_icmd(dev, 0x00000471, 0x00000000); 2486 + nv_icmd(dev, 0x00000472, 0x00000000); 2487 + nv_icmd(dev, 0x00000473, 0x00000000); 2488 + nv_icmd(dev, 0x00000474, 0x00000000); 2489 + nv_icmd(dev, 0x00000475, 0x00000000); 2490 + nv_icmd(dev, 0x00000476, 0x00000000); 2491 + nv_icmd(dev, 0x00000477, 0x00000000); 2492 + nv_icmd(dev, 0x00000478, 0x00000000); 2493 + nv_icmd(dev, 0x00000479, 0x00000000); 2494 + nv_icmd(dev, 0x0000047a, 0x00000000); 2495 + nv_icmd(dev, 0x0000047b, 0x00000000); 2496 + nv_icmd(dev, 0x0000047c, 0x00000000); 2497 + nv_icmd(dev, 0x0000047d, 0x00000000); 2498 + nv_icmd(dev, 0x0000047e, 0x00000000); 2499 + nv_icmd(dev, 0x0000047f, 0x00000000); 2500 + nv_icmd(dev, 0x00000480, 0x00000000); 2501 + nv_icmd(dev, 0x00000481, 0x00000000); 2502 + nv_icmd(dev, 0x00000482, 0x00000000); 2503 + nv_icmd(dev, 0x00000483, 0x00000000); 2504 + nv_icmd(dev, 0x00000484, 0x00000000); 2505 + nv_icmd(dev, 0x00000485, 0x00000000); 2506 + nv_icmd(dev, 0x00000486, 0x00000000); 2507 + nv_icmd(dev, 0x00000487, 0x00000000); 2508 + nv_icmd(dev, 0x00000488, 0x00000000); 2509 + nv_icmd(dev, 0x00000489, 0x00000000); 2510 + nv_icmd(dev, 0x0000048a, 0x00000000); 2511 + nv_icmd(dev, 0x0000048b, 0x00000000); 2512 + nv_icmd(dev, 0x0000048c, 0x00000000); 2513 + nv_icmd(dev, 0x0000048d, 0x00000000); 2514 + nv_icmd(dev, 0x0000048e, 0x00000000); 2515 + nv_icmd(dev, 0x0000048f, 0x00000000); 2516 + nv_icmd(dev, 0x00000490, 0x00000000); 2517 + nv_icmd(dev, 0x00000491, 0x00000000); 2518 + nv_icmd(dev, 0x00000492, 0x00000000); 2519 + nv_icmd(dev, 0x00000493, 0x00000000); 2520 + nv_icmd(dev, 0x00000494, 0x00000000); 2521 + nv_icmd(dev, 0x00000495, 0x00000000); 2522 + nv_icmd(dev, 0x00000496, 0x00000000); 2523 + nv_icmd(dev, 0x00000497, 0x00000000); 2524 + nv_icmd(dev, 0x00000498, 0x00000000); 2525 + nv_icmd(dev, 0x00000499, 0x00000000); 2526 + nv_icmd(dev, 0x0000049a, 0x00000000); 2527 + nv_icmd(dev, 0x0000049b, 0x00000000); 2528 + nv_icmd(dev, 0x0000049c, 0x00000000); 2529 + nv_icmd(dev, 0x0000049d, 0x00000000); 2530 + nv_icmd(dev, 0x0000049e, 0x00000000); 2531 + nv_icmd(dev, 0x0000049f, 0x00000000); 2532 + nv_icmd(dev, 0x000004a0, 0x00000000); 2533 + nv_icmd(dev, 0x000004a1, 0x00000000); 2534 + nv_icmd(dev, 0x000004a2, 0x00000000); 2535 + nv_icmd(dev, 0x000004a3, 0x00000000); 2536 + nv_icmd(dev, 0x000004a4, 0x00000000); 2537 + nv_icmd(dev, 0x000004a5, 0x00000000); 2538 + nv_icmd(dev, 0x000004a6, 0x00000000); 2539 + nv_icmd(dev, 0x000004a7, 0x00000000); 2540 + nv_icmd(dev, 0x000004a8, 0x00000000); 2541 + nv_icmd(dev, 0x000004a9, 0x00000000); 2542 + nv_icmd(dev, 0x000004aa, 0x00000000); 2543 + nv_icmd(dev, 0x000004ab, 0x00000000); 2544 + nv_icmd(dev, 0x000004ac, 0x00000000); 2545 + nv_icmd(dev, 0x000004ad, 0x00000000); 2546 + nv_icmd(dev, 0x000004ae, 0x00000000); 2547 + nv_icmd(dev, 0x000004af, 0x00000000); 2548 + nv_icmd(dev, 0x000004b0, 0x00000000); 2549 + nv_icmd(dev, 0x000004b1, 0x00000000); 2550 + nv_icmd(dev, 0x000004b2, 0x00000000); 2551 + nv_icmd(dev, 0x000004b3, 0x00000000); 2552 + nv_icmd(dev, 0x000004b4, 0x00000000); 2553 + nv_icmd(dev, 0x000004b5, 0x00000000); 2554 + nv_icmd(dev, 0x000004b6, 0x00000000); 2555 + nv_icmd(dev, 0x000004b7, 0x00000000); 2556 + nv_icmd(dev, 0x000004b8, 0x00000000); 2557 + nv_icmd(dev, 0x000004b9, 0x00000000); 2558 + nv_icmd(dev, 0x000004ba, 0x00000000); 2559 + nv_icmd(dev, 0x000004bb, 0x00000000); 2560 + nv_icmd(dev, 0x000004bc, 0x00000000); 2561 + nv_icmd(dev, 0x000004bd, 0x00000000); 2562 + nv_icmd(dev, 0x000004be, 0x00000000); 2563 + nv_icmd(dev, 0x000004bf, 0x00000000); 2564 + nv_icmd(dev, 0x000004c0, 0x00000000); 2565 + nv_icmd(dev, 0x000004c1, 0x00000000); 2566 + nv_icmd(dev, 0x000004c2, 0x00000000); 2567 + nv_icmd(dev, 0x000004c3, 0x00000000); 2568 + nv_icmd(dev, 0x000004c4, 0x00000000); 2569 + nv_icmd(dev, 0x000004c5, 0x00000000); 2570 + nv_icmd(dev, 0x000004c6, 0x00000000); 2571 + nv_icmd(dev, 0x000004c7, 0x00000000); 2572 + nv_icmd(dev, 0x000004c8, 0x00000000); 2573 + nv_icmd(dev, 0x000004c9, 0x00000000); 2574 + nv_icmd(dev, 0x000004ca, 0x00000000); 2575 + nv_icmd(dev, 0x000004cb, 0x00000000); 2576 + nv_icmd(dev, 0x000004cc, 0x00000000); 2577 + nv_icmd(dev, 0x000004cd, 0x00000000); 2578 + nv_icmd(dev, 0x000004ce, 0x00000000); 2579 + nv_icmd(dev, 0x000004cf, 0x00000000); 2580 + nv_icmd(dev, 0x00000510, 0x3f800000); 2581 + nv_icmd(dev, 0x00000511, 0x3f800000); 2582 + nv_icmd(dev, 0x00000512, 0x3f800000); 2583 + nv_icmd(dev, 0x00000513, 0x3f800000); 2584 + nv_icmd(dev, 0x00000514, 0x3f800000); 2585 + nv_icmd(dev, 0x00000515, 0x3f800000); 2586 + nv_icmd(dev, 0x00000516, 0x3f800000); 2587 + nv_icmd(dev, 0x00000517, 0x3f800000); 2588 + nv_icmd(dev, 0x00000518, 0x3f800000); 2589 + nv_icmd(dev, 0x00000519, 0x3f800000); 2590 + nv_icmd(dev, 0x0000051a, 0x3f800000); 2591 + nv_icmd(dev, 0x0000051b, 0x3f800000); 2592 + nv_icmd(dev, 0x0000051c, 0x3f800000); 2593 + nv_icmd(dev, 0x0000051d, 0x3f800000); 2594 + nv_icmd(dev, 0x0000051e, 0x3f800000); 2595 + nv_icmd(dev, 0x0000051f, 0x3f800000); 2596 + nv_icmd(dev, 0x00000520, 0x000002b6); 2597 + nv_icmd(dev, 0x00000529, 0x00000001); 2598 + nv_icmd(dev, 0x00000530, 0xffff0000); 2599 + nv_icmd(dev, 0x00000531, 0xffff0000); 2600 + nv_icmd(dev, 0x00000532, 0xffff0000); 2601 + nv_icmd(dev, 0x00000533, 0xffff0000); 2602 + nv_icmd(dev, 0x00000534, 0xffff0000); 2603 + nv_icmd(dev, 0x00000535, 0xffff0000); 2604 + nv_icmd(dev, 0x00000536, 0xffff0000); 2605 + nv_icmd(dev, 0x00000537, 0xffff0000); 2606 + nv_icmd(dev, 0x00000538, 0xffff0000); 2607 + nv_icmd(dev, 0x00000539, 0xffff0000); 2608 + nv_icmd(dev, 0x0000053a, 0xffff0000); 2609 + nv_icmd(dev, 0x0000053b, 0xffff0000); 2610 + nv_icmd(dev, 0x0000053c, 0xffff0000); 2611 + nv_icmd(dev, 0x0000053d, 0xffff0000); 2612 + nv_icmd(dev, 0x0000053e, 0xffff0000); 2613 + nv_icmd(dev, 0x0000053f, 0xffff0000); 2614 + nv_icmd(dev, 0x00000585, 0x0000003f); 2615 + nv_icmd(dev, 0x00000576, 0x00000003); 2616 + nv_icmd(dev, 0x00000586, 0x00000040); 2617 + nv_icmd(dev, 0x00000582, 0x00000080); 2618 + nv_icmd(dev, 0x00000583, 0x00000080); 2619 + nv_icmd(dev, 0x000005c2, 0x00000001); 2620 + nv_icmd(dev, 0x00000638, 0x00000001); 2621 + nv_icmd(dev, 0x00000639, 0x00000001); 2622 + nv_icmd(dev, 0x0000063a, 0x00000002); 2623 + nv_icmd(dev, 0x0000063b, 0x00000001); 2624 + nv_icmd(dev, 0x0000063c, 0x00000001); 2625 + nv_icmd(dev, 0x0000063d, 0x00000002); 2626 + nv_icmd(dev, 0x0000063e, 0x00000001); 2627 + nv_icmd(dev, 0x000008b8, 0x00000001); 2628 + nv_icmd(dev, 0x000008b9, 0x00000001); 2629 + nv_icmd(dev, 0x000008ba, 0x00000001); 2630 + nv_icmd(dev, 0x000008bb, 0x00000001); 2631 + nv_icmd(dev, 0x000008bc, 0x00000001); 2632 + nv_icmd(dev, 0x000008bd, 0x00000001); 2633 + nv_icmd(dev, 0x000008be, 0x00000001); 2634 + nv_icmd(dev, 0x000008bf, 0x00000001); 2635 + nv_icmd(dev, 0x00000900, 0x00000001); 2636 + nv_icmd(dev, 0x00000901, 0x00000001); 2637 + nv_icmd(dev, 0x00000902, 0x00000001); 2638 + nv_icmd(dev, 0x00000903, 0x00000001); 2639 + nv_icmd(dev, 0x00000904, 0x00000001); 2640 + nv_icmd(dev, 0x00000905, 0x00000001); 2641 + nv_icmd(dev, 0x00000906, 0x00000001); 2642 + nv_icmd(dev, 0x00000907, 0x00000001); 2643 + nv_icmd(dev, 0x00000908, 0x00000002); 2644 + nv_icmd(dev, 0x00000909, 0x00000002); 2645 + nv_icmd(dev, 0x0000090a, 0x00000002); 2646 + nv_icmd(dev, 0x0000090b, 0x00000002); 2647 + nv_icmd(dev, 0x0000090c, 0x00000002); 2648 + nv_icmd(dev, 0x0000090d, 0x00000002); 2649 + nv_icmd(dev, 0x0000090e, 0x00000002); 2650 + nv_icmd(dev, 0x0000090f, 0x00000002); 2651 + nv_icmd(dev, 0x00000910, 0x00000001); 2652 + nv_icmd(dev, 0x00000911, 0x00000001); 2653 + nv_icmd(dev, 0x00000912, 0x00000001); 2654 + nv_icmd(dev, 0x00000913, 0x00000001); 2655 + nv_icmd(dev, 0x00000914, 0x00000001); 2656 + nv_icmd(dev, 0x00000915, 0x00000001); 2657 + nv_icmd(dev, 0x00000916, 0x00000001); 2658 + nv_icmd(dev, 0x00000917, 0x00000001); 2659 + nv_icmd(dev, 0x00000918, 0x00000001); 2660 + nv_icmd(dev, 0x00000919, 0x00000001); 2661 + nv_icmd(dev, 0x0000091a, 0x00000001); 2662 + nv_icmd(dev, 0x0000091b, 0x00000001); 2663 + nv_icmd(dev, 0x0000091c, 0x00000001); 2664 + nv_icmd(dev, 0x0000091d, 0x00000001); 2665 + nv_icmd(dev, 0x0000091e, 0x00000001); 2666 + nv_icmd(dev, 0x0000091f, 0x00000001); 2667 + nv_icmd(dev, 0x00000920, 0x00000002); 2668 + nv_icmd(dev, 0x00000921, 0x00000002); 2669 + nv_icmd(dev, 0x00000922, 0x00000002); 2670 + nv_icmd(dev, 0x00000923, 0x00000002); 2671 + nv_icmd(dev, 0x00000924, 0x00000002); 2672 + nv_icmd(dev, 0x00000925, 0x00000002); 2673 + nv_icmd(dev, 0x00000926, 0x00000002); 2674 + nv_icmd(dev, 0x00000927, 0x00000002); 2675 + nv_icmd(dev, 0x00000928, 0x00000001); 2676 + nv_icmd(dev, 0x00000929, 0x00000001); 2677 + nv_icmd(dev, 0x0000092a, 0x00000001); 2678 + nv_icmd(dev, 0x0000092b, 0x00000001); 2679 + nv_icmd(dev, 0x0000092c, 0x00000001); 2680 + nv_icmd(dev, 0x0000092d, 0x00000001); 2681 + nv_icmd(dev, 0x0000092e, 0x00000001); 2682 + nv_icmd(dev, 0x0000092f, 0x00000001); 2683 + nv_icmd(dev, 0x00000648, 0x00000001); 2684 + nv_icmd(dev, 0x00000649, 0x00000001); 2685 + nv_icmd(dev, 0x0000064a, 0x00000001); 2686 + nv_icmd(dev, 0x0000064b, 0x00000001); 2687 + nv_icmd(dev, 0x0000064c, 0x00000001); 2688 + nv_icmd(dev, 0x0000064d, 0x00000001); 2689 + nv_icmd(dev, 0x0000064e, 0x00000001); 2690 + nv_icmd(dev, 0x0000064f, 0x00000001); 2691 + nv_icmd(dev, 0x00000650, 0x00000001); 2692 + nv_icmd(dev, 0x00000658, 0x0000000f); 2693 + nv_icmd(dev, 0x000007ff, 0x0000000a); 2694 + nv_icmd(dev, 0x0000066a, 0x40000000); 2695 + nv_icmd(dev, 0x0000066b, 0x10000000); 2696 + nv_icmd(dev, 0x0000066c, 0xffff0000); 2697 + nv_icmd(dev, 0x0000066d, 0xffff0000); 2698 + nv_icmd(dev, 0x000007af, 0x00000008); 2699 + nv_icmd(dev, 0x000007b0, 0x00000008); 2700 + nv_icmd(dev, 0x000007f6, 0x00000001); 2701 + nv_icmd(dev, 0x000006b2, 0x00000055); 2702 + nv_icmd(dev, 0x000007ad, 0x00000003); 2703 + nv_icmd(dev, 0x00000937, 0x00000001); 2704 + nv_icmd(dev, 0x00000971, 0x00000008); 2705 + nv_icmd(dev, 0x00000972, 0x00000040); 2706 + nv_icmd(dev, 0x00000973, 0x0000012c); 2707 + nv_icmd(dev, 0x0000097c, 0x00000040); 2708 + nv_icmd(dev, 0x00000979, 0x00000003); 2709 + nv_icmd(dev, 0x00000975, 0x00000020); 2710 + nv_icmd(dev, 0x00000976, 0x00000001); 2711 + nv_icmd(dev, 0x00000977, 0x00000020); 2712 + nv_icmd(dev, 0x00000978, 0x00000001); 2713 + nv_icmd(dev, 0x00000957, 0x00000003); 2714 + nv_icmd(dev, 0x0000095e, 0x20164010); 2715 + nv_icmd(dev, 0x0000095f, 0x00000020); 2716 + nv_icmd(dev, 0x00000683, 0x00000006); 2717 + nv_icmd(dev, 0x00000685, 0x003fffff); 2718 + nv_icmd(dev, 0x00000687, 0x00000c48); 2719 + nv_icmd(dev, 0x000006a0, 0x00000005); 2720 + nv_icmd(dev, 0x00000840, 0x00300008); 2721 + nv_icmd(dev, 0x00000841, 0x04000080); 2722 + nv_icmd(dev, 0x00000842, 0x00300008); 2723 + nv_icmd(dev, 0x00000843, 0x04000080); 2724 + nv_icmd(dev, 0x00000818, 0x00000000); 2725 + nv_icmd(dev, 0x00000819, 0x00000000); 2726 + nv_icmd(dev, 0x0000081a, 0x00000000); 2727 + nv_icmd(dev, 0x0000081b, 0x00000000); 2728 + nv_icmd(dev, 0x0000081c, 0x00000000); 2729 + nv_icmd(dev, 0x0000081d, 0x00000000); 2730 + nv_icmd(dev, 0x0000081e, 0x00000000); 2731 + nv_icmd(dev, 0x0000081f, 0x00000000); 2732 + nv_icmd(dev, 0x00000848, 0x00000000); 2733 + nv_icmd(dev, 0x00000849, 0x00000000); 2734 + nv_icmd(dev, 0x0000084a, 0x00000000); 2735 + nv_icmd(dev, 0x0000084b, 0x00000000); 2736 + nv_icmd(dev, 0x0000084c, 0x00000000); 2737 + nv_icmd(dev, 0x0000084d, 0x00000000); 2738 + nv_icmd(dev, 0x0000084e, 0x00000000); 2739 + nv_icmd(dev, 0x0000084f, 0x00000000); 2740 + nv_icmd(dev, 0x00000850, 0x00000000); 2741 + nv_icmd(dev, 0x00000851, 0x00000000); 2742 + nv_icmd(dev, 0x00000852, 0x00000000); 2743 + nv_icmd(dev, 0x00000853, 0x00000000); 2744 + nv_icmd(dev, 0x00000854, 0x00000000); 2745 + nv_icmd(dev, 0x00000855, 0x00000000); 2746 + nv_icmd(dev, 0x00000856, 0x00000000); 2747 + nv_icmd(dev, 0x00000857, 0x00000000); 2748 + nv_icmd(dev, 0x00000738, 0x00000000); 2749 + nv_icmd(dev, 0x000006aa, 0x00000001); 2750 + nv_icmd(dev, 0x000006ab, 0x00000002); 2751 + nv_icmd(dev, 0x000006ac, 0x00000080); 2752 + nv_icmd(dev, 0x000006ad, 0x00000100); 2753 + nv_icmd(dev, 0x000006ae, 0x00000100); 2754 + nv_icmd(dev, 0x000006b1, 0x00000011); 2755 + nv_icmd(dev, 0x000006bb, 0x000000cf); 2756 + nv_icmd(dev, 0x000006ce, 0x2a712488); 2757 + nv_icmd(dev, 0x00000739, 0x4085c000); 2758 + nv_icmd(dev, 0x0000073a, 0x00000080); 2759 + nv_icmd(dev, 0x00000786, 0x80000100); 2760 + nv_icmd(dev, 0x0000073c, 0x00010100); 2761 + nv_icmd(dev, 0x0000073d, 0x02800000); 2762 + nv_icmd(dev, 0x00000787, 0x000000cf); 2763 + nv_icmd(dev, 0x0000078c, 0x00000008); 2764 + nv_icmd(dev, 0x00000792, 0x00000001); 2765 + nv_icmd(dev, 0x00000794, 0x00000001); 2766 + nv_icmd(dev, 0x00000795, 0x00000001); 2767 + nv_icmd(dev, 0x00000796, 0x00000001); 2768 + nv_icmd(dev, 0x00000797, 0x000000cf); 2769 + nv_icmd(dev, 0x00000836, 0x00000001); 2770 + nv_icmd(dev, 0x0000079a, 0x00000002); 2771 + nv_icmd(dev, 0x00000833, 0x04444480); 2772 + nv_icmd(dev, 0x000007a1, 0x00000001); 2773 + nv_icmd(dev, 0x000007a3, 0x00000001); 2774 + nv_icmd(dev, 0x000007a4, 0x00000001); 2775 + nv_icmd(dev, 0x000007a5, 0x00000001); 2776 + nv_icmd(dev, 0x00000831, 0x00000004); 2777 + nv_icmd(dev, 0x0000080c, 0x00000002); 2778 + nv_icmd(dev, 0x0000080d, 0x00000100); 2779 + nv_icmd(dev, 0x0000080e, 0x00000100); 2780 + nv_icmd(dev, 0x0000080f, 0x00000001); 2781 + nv_icmd(dev, 0x00000823, 0x00000002); 2782 + nv_icmd(dev, 0x00000824, 0x00000100); 2783 + nv_icmd(dev, 0x00000825, 0x00000100); 2784 + nv_icmd(dev, 0x00000826, 0x00000001); 2785 + nv_icmd(dev, 0x0000095d, 0x00000001); 2786 + nv_icmd(dev, 0x0000082b, 0x00000004); 2787 + nv_icmd(dev, 0x00000942, 0x00010001); 2788 + nv_icmd(dev, 0x00000943, 0x00000001); 2789 + nv_icmd(dev, 0x00000944, 0x00000022); 2790 + nv_icmd(dev, 0x000007c5, 0x00010001); 2791 + nv_icmd(dev, 0x00000834, 0x00000001); 2792 + nv_icmd(dev, 0x000007c7, 0x00000001); 2793 + nv_icmd(dev, 0x0000c1b0, 0x0000000f); 2794 + nv_icmd(dev, 0x0000c1b1, 0x0000000f); 2795 + nv_icmd(dev, 0x0000c1b2, 0x0000000f); 2796 + nv_icmd(dev, 0x0000c1b3, 0x0000000f); 2797 + nv_icmd(dev, 0x0000c1b4, 0x0000000f); 2798 + nv_icmd(dev, 0x0000c1b5, 0x0000000f); 2799 + nv_icmd(dev, 0x0000c1b6, 0x0000000f); 2800 + nv_icmd(dev, 0x0000c1b7, 0x0000000f); 2801 + nv_icmd(dev, 0x0000c1b8, 0x0fac6881); 2802 + nv_icmd(dev, 0x0000c1b9, 0x00fac688); 2803 + nv_icmd(dev, 0x0001e100, 0x00000001); 2804 + nv_icmd(dev, 0x00001000, 0x00000002); 2805 + nv_icmd(dev, 0x000006aa, 0x00000001); 2806 + nv_icmd(dev, 0x000006ad, 0x00000100); 2807 + nv_icmd(dev, 0x000006ae, 0x00000100); 2808 + nv_icmd(dev, 0x000006b1, 0x00000011); 2809 + nv_icmd(dev, 0x0000078c, 0x00000008); 2810 + nv_icmd(dev, 0x00000792, 0x00000001); 2811 + nv_icmd(dev, 0x00000794, 0x00000001); 2812 + nv_icmd(dev, 0x00000795, 0x00000001); 2813 + nv_icmd(dev, 0x00000796, 0x00000001); 2814 + nv_icmd(dev, 0x00000797, 0x000000cf); 2815 + nv_icmd(dev, 0x0000079a, 0x00000002); 2816 + nv_icmd(dev, 0x00000833, 0x04444480); 2817 + nv_icmd(dev, 0x000007a1, 0x00000001); 2818 + nv_icmd(dev, 0x000007a3, 0x00000001); 2819 + nv_icmd(dev, 0x000007a4, 0x00000001); 2820 + nv_icmd(dev, 0x000007a5, 0x00000001); 2821 + nv_icmd(dev, 0x00000831, 0x00000004); 2822 + nv_icmd(dev, 0x0001e100, 0x00000001); 2823 + nv_icmd(dev, 0x00001000, 0x00000014); 2824 + nv_icmd(dev, 0x00000351, 0x00000100); 2825 + nv_icmd(dev, 0x00000957, 0x00000003); 2826 + nv_icmd(dev, 0x0000095d, 0x00000001); 2827 + nv_icmd(dev, 0x0000082b, 0x00000004); 2828 + nv_icmd(dev, 0x00000942, 0x00010001); 2829 + nv_icmd(dev, 0x00000943, 0x00000001); 2830 + nv_icmd(dev, 0x000007c5, 0x00010001); 2831 + nv_icmd(dev, 0x00000834, 0x00000001); 2832 + nv_icmd(dev, 0x000007c7, 0x00000001); 2833 + nv_icmd(dev, 0x0001e100, 0x00000001); 2834 + nv_icmd(dev, 0x00001000, 0x00000001); 2835 + nv_icmd(dev, 0x0000080c, 0x00000002); 2836 + nv_icmd(dev, 0x0000080d, 0x00000100); 2837 + nv_icmd(dev, 0x0000080e, 0x00000100); 2838 + nv_icmd(dev, 0x0000080f, 0x00000001); 2839 + nv_icmd(dev, 0x00000823, 0x00000002); 2840 + nv_icmd(dev, 0x00000824, 0x00000100); 2841 + nv_icmd(dev, 0x00000825, 0x00000100); 2842 + nv_icmd(dev, 0x00000826, 0x00000001); 2843 + nv_icmd(dev, 0x0001e100, 0x00000001); 2844 + nv_wr32(dev, 0x400208, 0x00000000); 2845 + nv_wr32(dev, 0x404154, 0x00000400); 2846 + 2847 + nvc0_grctx_generate_9097(dev); 2848 + nvc0_grctx_generate_902d(dev); 2849 + nvc0_grctx_generate_9039(dev); 2850 + nvc0_grctx_generate_90c0(dev); 2851 + 2852 + nv_wr32(dev, 0x000260, r000260); 2853 + return 0; 2854 + }