xref: /openbmc/linux/drivers/gpu/drm/nouveau/nvkm/subdev/bios/init.c (revision 4da722ca19f30f7db250db808d1ab1703607a932)
1 /*
2  * Copyright 2012 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 #include <subdev/bios.h>
25 #include <subdev/bios/bit.h>
26 #include <subdev/bios/bmp.h>
27 #include <subdev/bios/conn.h>
28 #include <subdev/bios/dcb.h>
29 #include <subdev/bios/dp.h>
30 #include <subdev/bios/gpio.h>
31 #include <subdev/bios/init.h>
32 #include <subdev/bios/ramcfg.h>
33 
34 #include <subdev/devinit.h>
35 #include <subdev/gpio.h>
36 #include <subdev/i2c.h>
37 #include <subdev/vga.h>
38 
39 #define bioslog(lvl, fmt, args...) do {                                        \
40 	nvkm_printk(init->subdev, lvl, info, "0x%08x[%c]: "fmt,                \
41 		    init->offset, init_exec(init) ?                            \
42 		    '0' + (init->nested - 1) : ' ', ##args);                   \
43 } while(0)
44 #define cont(fmt, args...) do {                                                \
45 	if (init->subdev->debug >= NV_DBG_TRACE)                               \
46 		printk(fmt, ##args);                                           \
47 } while(0)
48 #define trace(fmt, args...) bioslog(TRACE, fmt, ##args)
49 #define warn(fmt, args...) bioslog(WARN, fmt, ##args)
50 #define error(fmt, args...) bioslog(ERROR, fmt, ##args)
51 
52 /******************************************************************************
53  * init parser control flow helpers
54  *****************************************************************************/
55 
56 static inline bool
57 init_exec(struct nvbios_init *init)
58 {
59 	return (init->execute == 1) || ((init->execute & 5) == 5);
60 }
61 
62 static inline void
63 init_exec_set(struct nvbios_init *init, bool exec)
64 {
65 	if (exec) init->execute &= 0xfd;
66 	else      init->execute |= 0x02;
67 }
68 
69 static inline void
70 init_exec_inv(struct nvbios_init *init)
71 {
72 	init->execute ^= 0x02;
73 }
74 
75 static inline void
76 init_exec_force(struct nvbios_init *init, bool exec)
77 {
78 	if (exec) init->execute |= 0x04;
79 	else      init->execute &= 0xfb;
80 }
81 
82 /******************************************************************************
83  * init parser wrappers for normal register/i2c/whatever accessors
84  *****************************************************************************/
85 
86 static inline int
87 init_or(struct nvbios_init *init)
88 {
89 	if (init_exec(init)) {
90 		if (init->or >= 0)
91 			return init->or;
92 		error("script needs OR!!\n");
93 	}
94 	return 0;
95 }
96 
97 static inline int
98 init_link(struct nvbios_init *init)
99 {
100 	if (init_exec(init)) {
101 		if (init->link)
102 			return init->link == 2;
103 		error("script needs OR link\n");
104 	}
105 	return 0;
106 }
107 
108 static inline int
109 init_head(struct nvbios_init *init)
110 {
111 	if (init_exec(init)) {
112 		if (init->head >= 0)
113 			return init->head;
114 		error("script needs head\n");
115 	}
116 	return 0;
117 }
118 
119 static u8
120 init_conn(struct nvbios_init *init)
121 {
122 	struct nvkm_bios *bios = init->subdev->device->bios;
123 	struct nvbios_connE connE;
124 	u8  ver, hdr;
125 	u32 conn;
126 
127 	if (init_exec(init)) {
128 		if (init->outp) {
129 			conn = init->outp->connector;
130 			conn = nvbios_connEp(bios, conn, &ver, &hdr, &connE);
131 			if (conn)
132 				return connE.type;
133 		}
134 
135 		error("script needs connector type\n");
136 	}
137 
138 	return 0xff;
139 }
140 
141 static inline u32
142 init_nvreg(struct nvbios_init *init, u32 reg)
143 {
144 	struct nvkm_devinit *devinit = init->subdev->device->devinit;
145 
146 	/* C51 (at least) sometimes has the lower bits set which the VBIOS
147 	 * interprets to mean that access needs to go through certain IO
148 	 * ports instead.  The NVIDIA binary driver has been seen to access
149 	 * these through the NV register address, so lets assume we can
150 	 * do the same
151 	 */
152 	reg &= ~0x00000003;
153 
154 	/* GF8+ display scripts need register addresses mangled a bit to
155 	 * select a specific CRTC/OR
156 	 */
157 	if (init->subdev->device->card_type >= NV_50) {
158 		if (reg & 0x80000000) {
159 			reg += init_head(init) * 0x800;
160 			reg &= ~0x80000000;
161 		}
162 
163 		if (reg & 0x40000000) {
164 			reg += init_or(init) * 0x800;
165 			reg &= ~0x40000000;
166 			if (reg & 0x20000000) {
167 				reg += init_link(init) * 0x80;
168 				reg &= ~0x20000000;
169 			}
170 		}
171 	}
172 
173 	if (reg & ~0x00fffffc)
174 		warn("unknown bits in register 0x%08x\n", reg);
175 
176 	return nvkm_devinit_mmio(devinit, reg);
177 }
178 
179 static u32
180 init_rd32(struct nvbios_init *init, u32 reg)
181 {
182 	struct nvkm_device *device = init->subdev->device;
183 	reg = init_nvreg(init, reg);
184 	if (reg != ~0 && init_exec(init))
185 		return nvkm_rd32(device, reg);
186 	return 0x00000000;
187 }
188 
189 static void
190 init_wr32(struct nvbios_init *init, u32 reg, u32 val)
191 {
192 	struct nvkm_device *device = init->subdev->device;
193 	reg = init_nvreg(init, reg);
194 	if (reg != ~0 && init_exec(init))
195 		nvkm_wr32(device, reg, val);
196 }
197 
198 static u32
199 init_mask(struct nvbios_init *init, u32 reg, u32 mask, u32 val)
200 {
201 	struct nvkm_device *device = init->subdev->device;
202 	reg = init_nvreg(init, reg);
203 	if (reg != ~0 && init_exec(init)) {
204 		u32 tmp = nvkm_rd32(device, reg);
205 		nvkm_wr32(device, reg, (tmp & ~mask) | val);
206 		return tmp;
207 	}
208 	return 0x00000000;
209 }
210 
211 static u8
212 init_rdport(struct nvbios_init *init, u16 port)
213 {
214 	if (init_exec(init))
215 		return nvkm_rdport(init->subdev->device, init->head, port);
216 	return 0x00;
217 }
218 
219 static void
220 init_wrport(struct nvbios_init *init, u16 port, u8 value)
221 {
222 	if (init_exec(init))
223 		nvkm_wrport(init->subdev->device, init->head, port, value);
224 }
225 
226 static u8
227 init_rdvgai(struct nvbios_init *init, u16 port, u8 index)
228 {
229 	struct nvkm_subdev *subdev = init->subdev;
230 	if (init_exec(init)) {
231 		int head = init->head < 0 ? 0 : init->head;
232 		return nvkm_rdvgai(subdev->device, head, port, index);
233 	}
234 	return 0x00;
235 }
236 
237 static void
238 init_wrvgai(struct nvbios_init *init, u16 port, u8 index, u8 value)
239 {
240 	struct nvkm_device *device = init->subdev->device;
241 
242 	/* force head 0 for updates to cr44, it only exists on first head */
243 	if (device->card_type < NV_50) {
244 		if (port == 0x03d4 && index == 0x44)
245 			init->head = 0;
246 	}
247 
248 	if (init_exec(init)) {
249 		int head = init->head < 0 ? 0 : init->head;
250 		nvkm_wrvgai(device, head, port, index, value);
251 	}
252 
253 	/* select head 1 if cr44 write selected it */
254 	if (device->card_type < NV_50) {
255 		if (port == 0x03d4 && index == 0x44 && value == 3)
256 			init->head = 1;
257 	}
258 }
259 
260 static struct i2c_adapter *
261 init_i2c(struct nvbios_init *init, int index)
262 {
263 	struct nvkm_i2c *i2c = init->subdev->device->i2c;
264 	struct nvkm_i2c_bus *bus;
265 
266 	if (index == 0xff) {
267 		index = NVKM_I2C_BUS_PRI;
268 		if (init->outp && init->outp->i2c_upper_default)
269 			index = NVKM_I2C_BUS_SEC;
270 	} else
271 	if (index == 0x80) {
272 		index = NVKM_I2C_BUS_PRI;
273 	} else
274 	if (index == 0x81) {
275 		index = NVKM_I2C_BUS_SEC;
276 	}
277 
278 	bus = nvkm_i2c_bus_find(i2c, index);
279 	return bus ? &bus->i2c : NULL;
280 }
281 
282 static int
283 init_rdi2cr(struct nvbios_init *init, u8 index, u8 addr, u8 reg)
284 {
285 	struct i2c_adapter *adap = init_i2c(init, index);
286 	if (adap && init_exec(init))
287 		return nvkm_rdi2cr(adap, addr, reg);
288 	return -ENODEV;
289 }
290 
291 static int
292 init_wri2cr(struct nvbios_init *init, u8 index, u8 addr, u8 reg, u8 val)
293 {
294 	struct i2c_adapter *adap = init_i2c(init, index);
295 	if (adap && init_exec(init))
296 		return nvkm_wri2cr(adap, addr, reg, val);
297 	return -ENODEV;
298 }
299 
300 static struct nvkm_i2c_aux *
301 init_aux(struct nvbios_init *init)
302 {
303 	struct nvkm_i2c *i2c = init->subdev->device->i2c;
304 	if (!init->outp) {
305 		if (init_exec(init))
306 			error("script needs output for aux\n");
307 		return NULL;
308 	}
309 	return nvkm_i2c_aux_find(i2c, init->outp->i2c_index);
310 }
311 
312 static u8
313 init_rdauxr(struct nvbios_init *init, u32 addr)
314 {
315 	struct nvkm_i2c_aux *aux = init_aux(init);
316 	u8 data;
317 
318 	if (aux && init_exec(init)) {
319 		int ret = nvkm_rdaux(aux, addr, &data, 1);
320 		if (ret == 0)
321 			return data;
322 		trace("auxch read failed with %d\n", ret);
323 	}
324 
325 	return 0x00;
326 }
327 
328 static int
329 init_wrauxr(struct nvbios_init *init, u32 addr, u8 data)
330 {
331 	struct nvkm_i2c_aux *aux = init_aux(init);
332 	if (aux && init_exec(init)) {
333 		int ret = nvkm_wraux(aux, addr, &data, 1);
334 		if (ret)
335 			trace("auxch write failed with %d\n", ret);
336 		return ret;
337 	}
338 	return -ENODEV;
339 }
340 
341 static void
342 init_prog_pll(struct nvbios_init *init, u32 id, u32 freq)
343 {
344 	struct nvkm_devinit *devinit = init->subdev->device->devinit;
345 	if (init_exec(init)) {
346 		int ret = nvkm_devinit_pll_set(devinit, id, freq);
347 		if (ret)
348 			warn("failed to prog pll 0x%08x to %dkHz\n", id, freq);
349 	}
350 }
351 
352 /******************************************************************************
353  * parsing of bios structures that are required to execute init tables
354  *****************************************************************************/
355 
356 static u16
357 init_table(struct nvkm_bios *bios, u16 *len)
358 {
359 	struct bit_entry bit_I;
360 
361 	if (!bit_entry(bios, 'I', &bit_I)) {
362 		*len = bit_I.length;
363 		return bit_I.offset;
364 	}
365 
366 	if (bmp_version(bios) >= 0x0510) {
367 		*len = 14;
368 		return bios->bmp_offset + 75;
369 	}
370 
371 	return 0x0000;
372 }
373 
374 static u16
375 init_table_(struct nvbios_init *init, u16 offset, const char *name)
376 {
377 	struct nvkm_bios *bios = init->subdev->device->bios;
378 	u16 len, data = init_table(bios, &len);
379 	if (data) {
380 		if (len >= offset + 2) {
381 			data = nvbios_rd16(bios, data + offset);
382 			if (data)
383 				return data;
384 
385 			warn("%s pointer invalid\n", name);
386 			return 0x0000;
387 		}
388 
389 		warn("init data too short for %s pointer", name);
390 		return 0x0000;
391 	}
392 
393 	warn("init data not found\n");
394 	return 0x0000;
395 }
396 
397 #define init_script_table(b) init_table_((b), 0x00, "script table")
398 #define init_macro_index_table(b) init_table_((b), 0x02, "macro index table")
399 #define init_macro_table(b) init_table_((b), 0x04, "macro table")
400 #define init_condition_table(b) init_table_((b), 0x06, "condition table")
401 #define init_io_condition_table(b) init_table_((b), 0x08, "io condition table")
402 #define init_io_flag_condition_table(b) init_table_((b), 0x0a, "io flag conditon table")
403 #define init_function_table(b) init_table_((b), 0x0c, "function table")
404 #define init_xlat_table(b) init_table_((b), 0x10, "xlat table");
405 
406 static u16
407 init_script(struct nvkm_bios *bios, int index)
408 {
409 	struct nvbios_init init = { .subdev = &bios->subdev };
410 	u16 bmp_ver = bmp_version(bios), data;
411 
412 	if (bmp_ver && bmp_ver < 0x0510) {
413 		if (index > 1 || bmp_ver < 0x0100)
414 			return 0x0000;
415 
416 		data = bios->bmp_offset + (bmp_ver < 0x0200 ? 14 : 18);
417 		return nvbios_rd16(bios, data + (index * 2));
418 	}
419 
420 	data = init_script_table(&init);
421 	if (data)
422 		return nvbios_rd16(bios, data + (index * 2));
423 
424 	return 0x0000;
425 }
426 
427 static u16
428 init_unknown_script(struct nvkm_bios *bios)
429 {
430 	u16 len, data = init_table(bios, &len);
431 	if (data && len >= 16)
432 		return nvbios_rd16(bios, data + 14);
433 	return 0x0000;
434 }
435 
436 static u8
437 init_ram_restrict_group_count(struct nvbios_init *init)
438 {
439 	return nvbios_ramcfg_count(init->subdev->device->bios);
440 }
441 
442 static u8
443 init_ram_restrict(struct nvbios_init *init)
444 {
445 	/* This appears to be the behaviour of the VBIOS parser, and *is*
446 	 * important to cache the NV_PEXTDEV_BOOT0 on later chipsets to
447 	 * avoid fucking up the memory controller (somehow) by reading it
448 	 * on every INIT_RAM_RESTRICT_ZM_GROUP opcode.
449 	 *
450 	 * Preserving the non-caching behaviour on earlier chipsets just
451 	 * in case *not* re-reading the strap causes similar breakage.
452 	 */
453 	if (!init->ramcfg || init->subdev->device->bios->version.major < 0x70)
454 		init->ramcfg = 0x80000000 | nvbios_ramcfg_index(init->subdev);
455 	return (init->ramcfg & 0x7fffffff);
456 }
457 
458 static u8
459 init_xlat_(struct nvbios_init *init, u8 index, u8 offset)
460 {
461 	struct nvkm_bios *bios = init->subdev->device->bios;
462 	u16 table = init_xlat_table(init);
463 	if (table) {
464 		u16 data = nvbios_rd16(bios, table + (index * 2));
465 		if (data)
466 			return nvbios_rd08(bios, data + offset);
467 		warn("xlat table pointer %d invalid\n", index);
468 	}
469 	return 0x00;
470 }
471 
472 /******************************************************************************
473  * utility functions used by various init opcode handlers
474  *****************************************************************************/
475 
476 static bool
477 init_condition_met(struct nvbios_init *init, u8 cond)
478 {
479 	struct nvkm_bios *bios = init->subdev->device->bios;
480 	u16 table = init_condition_table(init);
481 	if (table) {
482 		u32 reg = nvbios_rd32(bios, table + (cond * 12) + 0);
483 		u32 msk = nvbios_rd32(bios, table + (cond * 12) + 4);
484 		u32 val = nvbios_rd32(bios, table + (cond * 12) + 8);
485 		trace("\t[0x%02x] (R[0x%06x] & 0x%08x) == 0x%08x\n",
486 		      cond, reg, msk, val);
487 		return (init_rd32(init, reg) & msk) == val;
488 	}
489 	return false;
490 }
491 
492 static bool
493 init_io_condition_met(struct nvbios_init *init, u8 cond)
494 {
495 	struct nvkm_bios *bios = init->subdev->device->bios;
496 	u16 table = init_io_condition_table(init);
497 	if (table) {
498 		u16 port = nvbios_rd16(bios, table + (cond * 5) + 0);
499 		u8 index = nvbios_rd08(bios, table + (cond * 5) + 2);
500 		u8  mask = nvbios_rd08(bios, table + (cond * 5) + 3);
501 		u8 value = nvbios_rd08(bios, table + (cond * 5) + 4);
502 		trace("\t[0x%02x] (0x%04x[0x%02x] & 0x%02x) == 0x%02x\n",
503 		      cond, port, index, mask, value);
504 		return (init_rdvgai(init, port, index) & mask) == value;
505 	}
506 	return false;
507 }
508 
509 static bool
510 init_io_flag_condition_met(struct nvbios_init *init, u8 cond)
511 {
512 	struct nvkm_bios *bios = init->subdev->device->bios;
513 	u16 table = init_io_flag_condition_table(init);
514 	if (table) {
515 		u16 port = nvbios_rd16(bios, table + (cond * 9) + 0);
516 		u8 index = nvbios_rd08(bios, table + (cond * 9) + 2);
517 		u8  mask = nvbios_rd08(bios, table + (cond * 9) + 3);
518 		u8 shift = nvbios_rd08(bios, table + (cond * 9) + 4);
519 		u16 data = nvbios_rd16(bios, table + (cond * 9) + 5);
520 		u8 dmask = nvbios_rd08(bios, table + (cond * 9) + 7);
521 		u8 value = nvbios_rd08(bios, table + (cond * 9) + 8);
522 		u8 ioval = (init_rdvgai(init, port, index) & mask) >> shift;
523 		return (nvbios_rd08(bios, data + ioval) & dmask) == value;
524 	}
525 	return false;
526 }
527 
528 static inline u32
529 init_shift(u32 data, u8 shift)
530 {
531 	if (shift < 0x80)
532 		return data >> shift;
533 	return data << (0x100 - shift);
534 }
535 
536 static u32
537 init_tmds_reg(struct nvbios_init *init, u8 tmds)
538 {
539 	/* For mlv < 0x80, it is an index into a table of TMDS base addresses.
540 	 * For mlv == 0x80 use the "or" value of the dcb_entry indexed by
541 	 * CR58 for CR57 = 0 to index a table of offsets to the basic
542 	 * 0x6808b0 address.
543 	 * For mlv == 0x81 use the "or" value of the dcb_entry indexed by
544 	 * CR58 for CR57 = 0 to index a table of offsets to the basic
545 	 * 0x6808b0 address, and then flip the offset by 8.
546 	 */
547 	const int pramdac_offset[13] = {
548 		0, 0, 0x8, 0, 0x2000, 0, 0, 0, 0x2008, 0, 0, 0, 0x2000 };
549 	const u32 pramdac_table[4] = {
550 		0x6808b0, 0x6808b8, 0x6828b0, 0x6828b8 };
551 
552 	if (tmds >= 0x80) {
553 		if (init->outp) {
554 			u32 dacoffset = pramdac_offset[init->outp->or];
555 			if (tmds == 0x81)
556 				dacoffset ^= 8;
557 			return 0x6808b0 + dacoffset;
558 		}
559 
560 		if (init_exec(init))
561 			error("tmds opcodes need dcb\n");
562 	} else {
563 		if (tmds < ARRAY_SIZE(pramdac_table))
564 			return pramdac_table[tmds];
565 
566 		error("tmds selector 0x%02x unknown\n", tmds);
567 	}
568 
569 	return 0;
570 }
571 
572 /******************************************************************************
573  * init opcode handlers
574  *****************************************************************************/
575 
576 /**
577  * init_reserved - stub for various unknown/unused single-byte opcodes
578  *
579  */
580 static void
581 init_reserved(struct nvbios_init *init)
582 {
583 	struct nvkm_bios *bios = init->subdev->device->bios;
584 	u8 opcode = nvbios_rd08(bios, init->offset);
585 	u8 length, i;
586 
587 	switch (opcode) {
588 	case 0xaa:
589 		length = 4;
590 		break;
591 	default:
592 		length = 1;
593 		break;
594 	}
595 
596 	trace("RESERVED 0x%02x\t", opcode);
597 	for (i = 1; i < length; i++)
598 		cont(" 0x%02x", nvbios_rd08(bios, init->offset + i));
599 	cont("\n");
600 	init->offset += length;
601 }
602 
603 /**
604  * INIT_DONE - opcode 0x71
605  *
606  */
607 static void
608 init_done(struct nvbios_init *init)
609 {
610 	trace("DONE\n");
611 	init->offset = 0x0000;
612 }
613 
614 /**
615  * INIT_IO_RESTRICT_PROG - opcode 0x32
616  *
617  */
618 static void
619 init_io_restrict_prog(struct nvbios_init *init)
620 {
621 	struct nvkm_bios *bios = init->subdev->device->bios;
622 	u16 port = nvbios_rd16(bios, init->offset + 1);
623 	u8 index = nvbios_rd08(bios, init->offset + 3);
624 	u8  mask = nvbios_rd08(bios, init->offset + 4);
625 	u8 shift = nvbios_rd08(bios, init->offset + 5);
626 	u8 count = nvbios_rd08(bios, init->offset + 6);
627 	u32  reg = nvbios_rd32(bios, init->offset + 7);
628 	u8 conf, i;
629 
630 	trace("IO_RESTRICT_PROG\tR[0x%06x] = "
631 	      "((0x%04x[0x%02x] & 0x%02x) >> %d) [{\n",
632 	      reg, port, index, mask, shift);
633 	init->offset += 11;
634 
635 	conf = (init_rdvgai(init, port, index) & mask) >> shift;
636 	for (i = 0; i < count; i++) {
637 		u32 data = nvbios_rd32(bios, init->offset);
638 
639 		if (i == conf) {
640 			trace("\t0x%08x *\n", data);
641 			init_wr32(init, reg, data);
642 		} else {
643 			trace("\t0x%08x\n", data);
644 		}
645 
646 		init->offset += 4;
647 	}
648 	trace("}]\n");
649 }
650 
651 /**
652  * INIT_REPEAT - opcode 0x33
653  *
654  */
655 static void
656 init_repeat(struct nvbios_init *init)
657 {
658 	struct nvkm_bios *bios = init->subdev->device->bios;
659 	u8 count = nvbios_rd08(bios, init->offset + 1);
660 	u16 repeat = init->repeat;
661 
662 	trace("REPEAT\t0x%02x\n", count);
663 	init->offset += 2;
664 
665 	init->repeat = init->offset;
666 	init->repend = init->offset;
667 	while (count--) {
668 		init->offset = init->repeat;
669 		nvbios_exec(init);
670 		if (count)
671 			trace("REPEAT\t0x%02x\n", count);
672 	}
673 	init->offset = init->repend;
674 	init->repeat = repeat;
675 }
676 
677 /**
678  * INIT_IO_RESTRICT_PLL - opcode 0x34
679  *
680  */
681 static void
682 init_io_restrict_pll(struct nvbios_init *init)
683 {
684 	struct nvkm_bios *bios = init->subdev->device->bios;
685 	u16 port = nvbios_rd16(bios, init->offset + 1);
686 	u8 index = nvbios_rd08(bios, init->offset + 3);
687 	u8  mask = nvbios_rd08(bios, init->offset + 4);
688 	u8 shift = nvbios_rd08(bios, init->offset + 5);
689 	s8  iofc = nvbios_rd08(bios, init->offset + 6);
690 	u8 count = nvbios_rd08(bios, init->offset + 7);
691 	u32  reg = nvbios_rd32(bios, init->offset + 8);
692 	u8 conf, i;
693 
694 	trace("IO_RESTRICT_PLL\tR[0x%06x] =PLL= "
695 	      "((0x%04x[0x%02x] & 0x%02x) >> 0x%02x) IOFCOND 0x%02x [{\n",
696 	      reg, port, index, mask, shift, iofc);
697 	init->offset += 12;
698 
699 	conf = (init_rdvgai(init, port, index) & mask) >> shift;
700 	for (i = 0; i < count; i++) {
701 		u32 freq = nvbios_rd16(bios, init->offset) * 10;
702 
703 		if (i == conf) {
704 			trace("\t%dkHz *\n", freq);
705 			if (iofc > 0 && init_io_flag_condition_met(init, iofc))
706 				freq *= 2;
707 			init_prog_pll(init, reg, freq);
708 		} else {
709 			trace("\t%dkHz\n", freq);
710 		}
711 
712 		init->offset += 2;
713 	}
714 	trace("}]\n");
715 }
716 
717 /**
718  * INIT_END_REPEAT - opcode 0x36
719  *
720  */
721 static void
722 init_end_repeat(struct nvbios_init *init)
723 {
724 	trace("END_REPEAT\n");
725 	init->offset += 1;
726 
727 	if (init->repeat) {
728 		init->repend = init->offset;
729 		init->offset = 0;
730 	}
731 }
732 
733 /**
734  * INIT_COPY - opcode 0x37
735  *
736  */
737 static void
738 init_copy(struct nvbios_init *init)
739 {
740 	struct nvkm_bios *bios = init->subdev->device->bios;
741 	u32  reg = nvbios_rd32(bios, init->offset + 1);
742 	u8 shift = nvbios_rd08(bios, init->offset + 5);
743 	u8 smask = nvbios_rd08(bios, init->offset + 6);
744 	u16 port = nvbios_rd16(bios, init->offset + 7);
745 	u8 index = nvbios_rd08(bios, init->offset + 9);
746 	u8  mask = nvbios_rd08(bios, init->offset + 10);
747 	u8  data;
748 
749 	trace("COPY\t0x%04x[0x%02x] &= 0x%02x |= "
750 	      "((R[0x%06x] %s 0x%02x) & 0x%02x)\n",
751 	      port, index, mask, reg, (shift & 0x80) ? "<<" : ">>",
752 	      (shift & 0x80) ? (0x100 - shift) : shift, smask);
753 	init->offset += 11;
754 
755 	data  = init_rdvgai(init, port, index) & mask;
756 	data |= init_shift(init_rd32(init, reg), shift) & smask;
757 	init_wrvgai(init, port, index, data);
758 }
759 
760 /**
761  * INIT_NOT - opcode 0x38
762  *
763  */
764 static void
765 init_not(struct nvbios_init *init)
766 {
767 	trace("NOT\n");
768 	init->offset += 1;
769 	init_exec_inv(init);
770 }
771 
772 /**
773  * INIT_IO_FLAG_CONDITION - opcode 0x39
774  *
775  */
776 static void
777 init_io_flag_condition(struct nvbios_init *init)
778 {
779 	struct nvkm_bios *bios = init->subdev->device->bios;
780 	u8 cond = nvbios_rd08(bios, init->offset + 1);
781 
782 	trace("IO_FLAG_CONDITION\t0x%02x\n", cond);
783 	init->offset += 2;
784 
785 	if (!init_io_flag_condition_met(init, cond))
786 		init_exec_set(init, false);
787 }
788 
789 /**
790  * INIT_GENERIC_CONDITION - opcode 0x3a
791  *
792  */
793 static void
794 init_generic_condition(struct nvbios_init *init)
795 {
796 	struct nvkm_bios *bios = init->subdev->device->bios;
797 	struct nvbios_dpout info;
798 	u8  cond = nvbios_rd08(bios, init->offset + 1);
799 	u8  size = nvbios_rd08(bios, init->offset + 2);
800 	u8  ver, hdr, cnt, len;
801 	u16 data;
802 
803 	trace("GENERIC_CONDITION\t0x%02x 0x%02x\n", cond, size);
804 	init->offset += 3;
805 
806 	switch (cond) {
807 	case 0:
808 		if (init_conn(init) != DCB_CONNECTOR_eDP)
809 			init_exec_set(init, false);
810 		break;
811 	case 1:
812 	case 2:
813 		if ( init->outp &&
814 		    (data = nvbios_dpout_match(bios, DCB_OUTPUT_DP,
815 					       (init->outp->or << 0) |
816 					       (init->outp->sorconf.link << 6),
817 					       &ver, &hdr, &cnt, &len, &info)))
818 		{
819 			if (!(info.flags & cond))
820 				init_exec_set(init, false);
821 			break;
822 		}
823 
824 		if (init_exec(init))
825 			warn("script needs dp output table data\n");
826 		break;
827 	case 5:
828 		if (!(init_rdauxr(init, 0x0d) & 1))
829 			init_exec_set(init, false);
830 		break;
831 	default:
832 		warn("INIT_GENERIC_CONDITON: unknown 0x%02x\n", cond);
833 		init->offset += size;
834 		break;
835 	}
836 }
837 
838 /**
839  * INIT_IO_MASK_OR - opcode 0x3b
840  *
841  */
842 static void
843 init_io_mask_or(struct nvbios_init *init)
844 {
845 	struct nvkm_bios *bios = init->subdev->device->bios;
846 	u8 index = nvbios_rd08(bios, init->offset + 1);
847 	u8    or = init_or(init);
848 	u8  data;
849 
850 	trace("IO_MASK_OR\t0x03d4[0x%02x] &= ~(1 << 0x%02x)\n", index, or);
851 	init->offset += 2;
852 
853 	data = init_rdvgai(init, 0x03d4, index);
854 	init_wrvgai(init, 0x03d4, index, data &= ~(1 << or));
855 }
856 
857 /**
858  * INIT_IO_OR - opcode 0x3c
859  *
860  */
861 static void
862 init_io_or(struct nvbios_init *init)
863 {
864 	struct nvkm_bios *bios = init->subdev->device->bios;
865 	u8 index = nvbios_rd08(bios, init->offset + 1);
866 	u8    or = init_or(init);
867 	u8  data;
868 
869 	trace("IO_OR\t0x03d4[0x%02x] |= (1 << 0x%02x)\n", index, or);
870 	init->offset += 2;
871 
872 	data = init_rdvgai(init, 0x03d4, index);
873 	init_wrvgai(init, 0x03d4, index, data | (1 << or));
874 }
875 
876 /**
877  * INIT_ANDN_REG - opcode 0x47
878  *
879  */
880 static void
881 init_andn_reg(struct nvbios_init *init)
882 {
883 	struct nvkm_bios *bios = init->subdev->device->bios;
884 	u32  reg = nvbios_rd32(bios, init->offset + 1);
885 	u32 mask = nvbios_rd32(bios, init->offset + 5);
886 
887 	trace("ANDN_REG\tR[0x%06x] &= ~0x%08x\n", reg, mask);
888 	init->offset += 9;
889 
890 	init_mask(init, reg, mask, 0);
891 }
892 
893 /**
894  * INIT_OR_REG - opcode 0x48
895  *
896  */
897 static void
898 init_or_reg(struct nvbios_init *init)
899 {
900 	struct nvkm_bios *bios = init->subdev->device->bios;
901 	u32  reg = nvbios_rd32(bios, init->offset + 1);
902 	u32 mask = nvbios_rd32(bios, init->offset + 5);
903 
904 	trace("OR_REG\tR[0x%06x] |= 0x%08x\n", reg, mask);
905 	init->offset += 9;
906 
907 	init_mask(init, reg, 0, mask);
908 }
909 
910 /**
911  * INIT_INDEX_ADDRESS_LATCHED - opcode 0x49
912  *
913  */
914 static void
915 init_idx_addr_latched(struct nvbios_init *init)
916 {
917 	struct nvkm_bios *bios = init->subdev->device->bios;
918 	u32 creg = nvbios_rd32(bios, init->offset + 1);
919 	u32 dreg = nvbios_rd32(bios, init->offset + 5);
920 	u32 mask = nvbios_rd32(bios, init->offset + 9);
921 	u32 data = nvbios_rd32(bios, init->offset + 13);
922 	u8 count = nvbios_rd08(bios, init->offset + 17);
923 
924 	trace("INDEX_ADDRESS_LATCHED\tR[0x%06x] : R[0x%06x]\n", creg, dreg);
925 	trace("\tCTRL &= 0x%08x |= 0x%08x\n", mask, data);
926 	init->offset += 18;
927 
928 	while (count--) {
929 		u8 iaddr = nvbios_rd08(bios, init->offset + 0);
930 		u8 idata = nvbios_rd08(bios, init->offset + 1);
931 
932 		trace("\t[0x%02x] = 0x%02x\n", iaddr, idata);
933 		init->offset += 2;
934 
935 		init_wr32(init, dreg, idata);
936 		init_mask(init, creg, ~mask, data | iaddr);
937 	}
938 }
939 
940 /**
941  * INIT_IO_RESTRICT_PLL2 - opcode 0x4a
942  *
943  */
944 static void
945 init_io_restrict_pll2(struct nvbios_init *init)
946 {
947 	struct nvkm_bios *bios = init->subdev->device->bios;
948 	u16 port = nvbios_rd16(bios, init->offset + 1);
949 	u8 index = nvbios_rd08(bios, init->offset + 3);
950 	u8  mask = nvbios_rd08(bios, init->offset + 4);
951 	u8 shift = nvbios_rd08(bios, init->offset + 5);
952 	u8 count = nvbios_rd08(bios, init->offset + 6);
953 	u32  reg = nvbios_rd32(bios, init->offset + 7);
954 	u8  conf, i;
955 
956 	trace("IO_RESTRICT_PLL2\t"
957 	      "R[0x%06x] =PLL= ((0x%04x[0x%02x] & 0x%02x) >> 0x%02x) [{\n",
958 	      reg, port, index, mask, shift);
959 	init->offset += 11;
960 
961 	conf = (init_rdvgai(init, port, index) & mask) >> shift;
962 	for (i = 0; i < count; i++) {
963 		u32 freq = nvbios_rd32(bios, init->offset);
964 		if (i == conf) {
965 			trace("\t%dkHz *\n", freq);
966 			init_prog_pll(init, reg, freq);
967 		} else {
968 			trace("\t%dkHz\n", freq);
969 		}
970 		init->offset += 4;
971 	}
972 	trace("}]\n");
973 }
974 
975 /**
976  * INIT_PLL2 - opcode 0x4b
977  *
978  */
979 static void
980 init_pll2(struct nvbios_init *init)
981 {
982 	struct nvkm_bios *bios = init->subdev->device->bios;
983 	u32  reg = nvbios_rd32(bios, init->offset + 1);
984 	u32 freq = nvbios_rd32(bios, init->offset + 5);
985 
986 	trace("PLL2\tR[0x%06x] =PLL= %dkHz\n", reg, freq);
987 	init->offset += 9;
988 
989 	init_prog_pll(init, reg, freq);
990 }
991 
992 /**
993  * INIT_I2C_BYTE - opcode 0x4c
994  *
995  */
996 static void
997 init_i2c_byte(struct nvbios_init *init)
998 {
999 	struct nvkm_bios *bios = init->subdev->device->bios;
1000 	u8 index = nvbios_rd08(bios, init->offset + 1);
1001 	u8  addr = nvbios_rd08(bios, init->offset + 2) >> 1;
1002 	u8 count = nvbios_rd08(bios, init->offset + 3);
1003 
1004 	trace("I2C_BYTE\tI2C[0x%02x][0x%02x]\n", index, addr);
1005 	init->offset += 4;
1006 
1007 	while (count--) {
1008 		u8  reg = nvbios_rd08(bios, init->offset + 0);
1009 		u8 mask = nvbios_rd08(bios, init->offset + 1);
1010 		u8 data = nvbios_rd08(bios, init->offset + 2);
1011 		int val;
1012 
1013 		trace("\t[0x%02x] &= 0x%02x |= 0x%02x\n", reg, mask, data);
1014 		init->offset += 3;
1015 
1016 		val = init_rdi2cr(init, index, addr, reg);
1017 		if (val < 0)
1018 			continue;
1019 		init_wri2cr(init, index, addr, reg, (val & mask) | data);
1020 	}
1021 }
1022 
1023 /**
1024  * INIT_ZM_I2C_BYTE - opcode 0x4d
1025  *
1026  */
1027 static void
1028 init_zm_i2c_byte(struct nvbios_init *init)
1029 {
1030 	struct nvkm_bios *bios = init->subdev->device->bios;
1031 	u8 index = nvbios_rd08(bios, init->offset + 1);
1032 	u8  addr = nvbios_rd08(bios, init->offset + 2) >> 1;
1033 	u8 count = nvbios_rd08(bios, init->offset + 3);
1034 
1035 	trace("ZM_I2C_BYTE\tI2C[0x%02x][0x%02x]\n", index, addr);
1036 	init->offset += 4;
1037 
1038 	while (count--) {
1039 		u8  reg = nvbios_rd08(bios, init->offset + 0);
1040 		u8 data = nvbios_rd08(bios, init->offset + 1);
1041 
1042 		trace("\t[0x%02x] = 0x%02x\n", reg, data);
1043 		init->offset += 2;
1044 
1045 		init_wri2cr(init, index, addr, reg, data);
1046 	}
1047 }
1048 
1049 /**
1050  * INIT_ZM_I2C - opcode 0x4e
1051  *
1052  */
1053 static void
1054 init_zm_i2c(struct nvbios_init *init)
1055 {
1056 	struct nvkm_bios *bios = init->subdev->device->bios;
1057 	u8 index = nvbios_rd08(bios, init->offset + 1);
1058 	u8  addr = nvbios_rd08(bios, init->offset + 2) >> 1;
1059 	u8 count = nvbios_rd08(bios, init->offset + 3);
1060 	u8 data[256], i;
1061 
1062 	trace("ZM_I2C\tI2C[0x%02x][0x%02x]\n", index, addr);
1063 	init->offset += 4;
1064 
1065 	for (i = 0; i < count; i++) {
1066 		data[i] = nvbios_rd08(bios, init->offset);
1067 		trace("\t0x%02x\n", data[i]);
1068 		init->offset++;
1069 	}
1070 
1071 	if (init_exec(init)) {
1072 		struct i2c_adapter *adap = init_i2c(init, index);
1073 		struct i2c_msg msg = {
1074 			.addr = addr, .flags = 0, .len = count, .buf = data,
1075 		};
1076 		int ret;
1077 
1078 		if (adap && (ret = i2c_transfer(adap, &msg, 1)) != 1)
1079 			warn("i2c wr failed, %d\n", ret);
1080 	}
1081 }
1082 
1083 /**
1084  * INIT_TMDS - opcode 0x4f
1085  *
1086  */
1087 static void
1088 init_tmds(struct nvbios_init *init)
1089 {
1090 	struct nvkm_bios *bios = init->subdev->device->bios;
1091 	u8 tmds = nvbios_rd08(bios, init->offset + 1);
1092 	u8 addr = nvbios_rd08(bios, init->offset + 2);
1093 	u8 mask = nvbios_rd08(bios, init->offset + 3);
1094 	u8 data = nvbios_rd08(bios, init->offset + 4);
1095 	u32 reg = init_tmds_reg(init, tmds);
1096 
1097 	trace("TMDS\tT[0x%02x][0x%02x] &= 0x%02x |= 0x%02x\n",
1098 	      tmds, addr, mask, data);
1099 	init->offset += 5;
1100 
1101 	if (reg == 0)
1102 		return;
1103 
1104 	init_wr32(init, reg + 0, addr | 0x00010000);
1105 	init_wr32(init, reg + 4, data | (init_rd32(init, reg + 4) & mask));
1106 	init_wr32(init, reg + 0, addr);
1107 }
1108 
1109 /**
1110  * INIT_ZM_TMDS_GROUP - opcode 0x50
1111  *
1112  */
1113 static void
1114 init_zm_tmds_group(struct nvbios_init *init)
1115 {
1116 	struct nvkm_bios *bios = init->subdev->device->bios;
1117 	u8  tmds = nvbios_rd08(bios, init->offset + 1);
1118 	u8 count = nvbios_rd08(bios, init->offset + 2);
1119 	u32  reg = init_tmds_reg(init, tmds);
1120 
1121 	trace("TMDS_ZM_GROUP\tT[0x%02x]\n", tmds);
1122 	init->offset += 3;
1123 
1124 	while (count--) {
1125 		u8 addr = nvbios_rd08(bios, init->offset + 0);
1126 		u8 data = nvbios_rd08(bios, init->offset + 1);
1127 
1128 		trace("\t[0x%02x] = 0x%02x\n", addr, data);
1129 		init->offset += 2;
1130 
1131 		init_wr32(init, reg + 4, data);
1132 		init_wr32(init, reg + 0, addr);
1133 	}
1134 }
1135 
1136 /**
1137  * INIT_CR_INDEX_ADDRESS_LATCHED - opcode 0x51
1138  *
1139  */
1140 static void
1141 init_cr_idx_adr_latch(struct nvbios_init *init)
1142 {
1143 	struct nvkm_bios *bios = init->subdev->device->bios;
1144 	u8 addr0 = nvbios_rd08(bios, init->offset + 1);
1145 	u8 addr1 = nvbios_rd08(bios, init->offset + 2);
1146 	u8  base = nvbios_rd08(bios, init->offset + 3);
1147 	u8 count = nvbios_rd08(bios, init->offset + 4);
1148 	u8 save0;
1149 
1150 	trace("CR_INDEX_ADDR C[%02x] C[%02x]\n", addr0, addr1);
1151 	init->offset += 5;
1152 
1153 	save0 = init_rdvgai(init, 0x03d4, addr0);
1154 	while (count--) {
1155 		u8 data = nvbios_rd08(bios, init->offset);
1156 
1157 		trace("\t\t[0x%02x] = 0x%02x\n", base, data);
1158 		init->offset += 1;
1159 
1160 		init_wrvgai(init, 0x03d4, addr0, base++);
1161 		init_wrvgai(init, 0x03d4, addr1, data);
1162 	}
1163 	init_wrvgai(init, 0x03d4, addr0, save0);
1164 }
1165 
1166 /**
1167  * INIT_CR - opcode 0x52
1168  *
1169  */
1170 static void
1171 init_cr(struct nvbios_init *init)
1172 {
1173 	struct nvkm_bios *bios = init->subdev->device->bios;
1174 	u8 addr = nvbios_rd08(bios, init->offset + 1);
1175 	u8 mask = nvbios_rd08(bios, init->offset + 2);
1176 	u8 data = nvbios_rd08(bios, init->offset + 3);
1177 	u8 val;
1178 
1179 	trace("CR\t\tC[0x%02x] &= 0x%02x |= 0x%02x\n", addr, mask, data);
1180 	init->offset += 4;
1181 
1182 	val = init_rdvgai(init, 0x03d4, addr) & mask;
1183 	init_wrvgai(init, 0x03d4, addr, val | data);
1184 }
1185 
1186 /**
1187  * INIT_ZM_CR - opcode 0x53
1188  *
1189  */
1190 static void
1191 init_zm_cr(struct nvbios_init *init)
1192 {
1193 	struct nvkm_bios *bios = init->subdev->device->bios;
1194 	u8 addr = nvbios_rd08(bios, init->offset + 1);
1195 	u8 data = nvbios_rd08(bios, init->offset + 2);
1196 
1197 	trace("ZM_CR\tC[0x%02x] = 0x%02x\n", addr,  data);
1198 	init->offset += 3;
1199 
1200 	init_wrvgai(init, 0x03d4, addr, data);
1201 }
1202 
1203 /**
1204  * INIT_ZM_CR_GROUP - opcode 0x54
1205  *
1206  */
1207 static void
1208 init_zm_cr_group(struct nvbios_init *init)
1209 {
1210 	struct nvkm_bios *bios = init->subdev->device->bios;
1211 	u8 count = nvbios_rd08(bios, init->offset + 1);
1212 
1213 	trace("ZM_CR_GROUP\n");
1214 	init->offset += 2;
1215 
1216 	while (count--) {
1217 		u8 addr = nvbios_rd08(bios, init->offset + 0);
1218 		u8 data = nvbios_rd08(bios, init->offset + 1);
1219 
1220 		trace("\t\tC[0x%02x] = 0x%02x\n", addr, data);
1221 		init->offset += 2;
1222 
1223 		init_wrvgai(init, 0x03d4, addr, data);
1224 	}
1225 }
1226 
1227 /**
1228  * INIT_CONDITION_TIME - opcode 0x56
1229  *
1230  */
1231 static void
1232 init_condition_time(struct nvbios_init *init)
1233 {
1234 	struct nvkm_bios *bios = init->subdev->device->bios;
1235 	u8  cond = nvbios_rd08(bios, init->offset + 1);
1236 	u8 retry = nvbios_rd08(bios, init->offset + 2);
1237 	u8  wait = min((u16)retry * 50, 100);
1238 
1239 	trace("CONDITION_TIME\t0x%02x 0x%02x\n", cond, retry);
1240 	init->offset += 3;
1241 
1242 	if (!init_exec(init))
1243 		return;
1244 
1245 	while (wait--) {
1246 		if (init_condition_met(init, cond))
1247 			return;
1248 		mdelay(20);
1249 	}
1250 
1251 	init_exec_set(init, false);
1252 }
1253 
1254 /**
1255  * INIT_LTIME - opcode 0x57
1256  *
1257  */
1258 static void
1259 init_ltime(struct nvbios_init *init)
1260 {
1261 	struct nvkm_bios *bios = init->subdev->device->bios;
1262 	u16 msec = nvbios_rd16(bios, init->offset + 1);
1263 
1264 	trace("LTIME\t0x%04x\n", msec);
1265 	init->offset += 3;
1266 
1267 	if (init_exec(init))
1268 		mdelay(msec);
1269 }
1270 
1271 /**
1272  * INIT_ZM_REG_SEQUENCE - opcode 0x58
1273  *
1274  */
1275 static void
1276 init_zm_reg_sequence(struct nvbios_init *init)
1277 {
1278 	struct nvkm_bios *bios = init->subdev->device->bios;
1279 	u32 base = nvbios_rd32(bios, init->offset + 1);
1280 	u8 count = nvbios_rd08(bios, init->offset + 5);
1281 
1282 	trace("ZM_REG_SEQUENCE\t0x%02x\n", count);
1283 	init->offset += 6;
1284 
1285 	while (count--) {
1286 		u32 data = nvbios_rd32(bios, init->offset);
1287 
1288 		trace("\t\tR[0x%06x] = 0x%08x\n", base, data);
1289 		init->offset += 4;
1290 
1291 		init_wr32(init, base, data);
1292 		base += 4;
1293 	}
1294 }
1295 
1296 /**
1297  * INIT_PLL_INDIRECT - opcode 0x59
1298  *
1299  */
1300 static void
1301 init_pll_indirect(struct nvbios_init *init)
1302 {
1303 	struct nvkm_bios *bios = init->subdev->device->bios;
1304 	u32  reg = nvbios_rd32(bios, init->offset + 1);
1305 	u16 addr = nvbios_rd16(bios, init->offset + 5);
1306 	u32 freq = (u32)nvbios_rd16(bios, addr) * 1000;
1307 
1308 	trace("PLL_INDIRECT\tR[0x%06x] =PLL= VBIOS[%04x] = %dkHz\n",
1309 	      reg, addr, freq);
1310 	init->offset += 7;
1311 
1312 	init_prog_pll(init, reg, freq);
1313 }
1314 
1315 /**
1316  * INIT_ZM_REG_INDIRECT - opcode 0x5a
1317  *
1318  */
1319 static void
1320 init_zm_reg_indirect(struct nvbios_init *init)
1321 {
1322 	struct nvkm_bios *bios = init->subdev->device->bios;
1323 	u32  reg = nvbios_rd32(bios, init->offset + 1);
1324 	u16 addr = nvbios_rd16(bios, init->offset + 5);
1325 	u32 data = nvbios_rd32(bios, addr);
1326 
1327 	trace("ZM_REG_INDIRECT\tR[0x%06x] = VBIOS[0x%04x] = 0x%08x\n",
1328 	      reg, addr, data);
1329 	init->offset += 7;
1330 
1331 	init_wr32(init, addr, data);
1332 }
1333 
1334 /**
1335  * INIT_SUB_DIRECT - opcode 0x5b
1336  *
1337  */
1338 static void
1339 init_sub_direct(struct nvbios_init *init)
1340 {
1341 	struct nvkm_bios *bios = init->subdev->device->bios;
1342 	u16 addr = nvbios_rd16(bios, init->offset + 1);
1343 	u16 save;
1344 
1345 	trace("SUB_DIRECT\t0x%04x\n", addr);
1346 
1347 	if (init_exec(init)) {
1348 		save = init->offset;
1349 		init->offset = addr;
1350 		if (nvbios_exec(init)) {
1351 			error("error parsing sub-table\n");
1352 			return;
1353 		}
1354 		init->offset = save;
1355 	}
1356 
1357 	init->offset += 3;
1358 }
1359 
1360 /**
1361  * INIT_JUMP - opcode 0x5c
1362  *
1363  */
1364 static void
1365 init_jump(struct nvbios_init *init)
1366 {
1367 	struct nvkm_bios *bios = init->subdev->device->bios;
1368 	u16 offset = nvbios_rd16(bios, init->offset + 1);
1369 
1370 	trace("JUMP\t0x%04x\n", offset);
1371 
1372 	if (init_exec(init))
1373 		init->offset = offset;
1374 	else
1375 		init->offset += 3;
1376 }
1377 
1378 /**
1379  * INIT_I2C_IF - opcode 0x5e
1380  *
1381  */
1382 static void
1383 init_i2c_if(struct nvbios_init *init)
1384 {
1385 	struct nvkm_bios *bios = init->subdev->device->bios;
1386 	u8 index = nvbios_rd08(bios, init->offset + 1);
1387 	u8  addr = nvbios_rd08(bios, init->offset + 2);
1388 	u8   reg = nvbios_rd08(bios, init->offset + 3);
1389 	u8  mask = nvbios_rd08(bios, init->offset + 4);
1390 	u8  data = nvbios_rd08(bios, init->offset + 5);
1391 	u8 value;
1392 
1393 	trace("I2C_IF\tI2C[0x%02x][0x%02x][0x%02x] & 0x%02x == 0x%02x\n",
1394 	      index, addr, reg, mask, data);
1395 	init->offset += 6;
1396 	init_exec_force(init, true);
1397 
1398 	value = init_rdi2cr(init, index, addr, reg);
1399 	if ((value & mask) != data)
1400 		init_exec_set(init, false);
1401 
1402 	init_exec_force(init, false);
1403 }
1404 
1405 /**
1406  * INIT_COPY_NV_REG - opcode 0x5f
1407  *
1408  */
1409 static void
1410 init_copy_nv_reg(struct nvbios_init *init)
1411 {
1412 	struct nvkm_bios *bios = init->subdev->device->bios;
1413 	u32  sreg = nvbios_rd32(bios, init->offset + 1);
1414 	u8  shift = nvbios_rd08(bios, init->offset + 5);
1415 	u32 smask = nvbios_rd32(bios, init->offset + 6);
1416 	u32  sxor = nvbios_rd32(bios, init->offset + 10);
1417 	u32  dreg = nvbios_rd32(bios, init->offset + 14);
1418 	u32 dmask = nvbios_rd32(bios, init->offset + 18);
1419 	u32 data;
1420 
1421 	trace("COPY_NV_REG\tR[0x%06x] &= 0x%08x |= "
1422 	      "((R[0x%06x] %s 0x%02x) & 0x%08x ^ 0x%08x)\n",
1423 	      dreg, dmask, sreg, (shift & 0x80) ? "<<" : ">>",
1424 	      (shift & 0x80) ? (0x100 - shift) : shift, smask, sxor);
1425 	init->offset += 22;
1426 
1427 	data = init_shift(init_rd32(init, sreg), shift);
1428 	init_mask(init, dreg, ~dmask, (data & smask) ^ sxor);
1429 }
1430 
1431 /**
1432  * INIT_ZM_INDEX_IO - opcode 0x62
1433  *
1434  */
1435 static void
1436 init_zm_index_io(struct nvbios_init *init)
1437 {
1438 	struct nvkm_bios *bios = init->subdev->device->bios;
1439 	u16 port = nvbios_rd16(bios, init->offset + 1);
1440 	u8 index = nvbios_rd08(bios, init->offset + 3);
1441 	u8  data = nvbios_rd08(bios, init->offset + 4);
1442 
1443 	trace("ZM_INDEX_IO\tI[0x%04x][0x%02x] = 0x%02x\n", port, index, data);
1444 	init->offset += 5;
1445 
1446 	init_wrvgai(init, port, index, data);
1447 }
1448 
1449 /**
1450  * INIT_COMPUTE_MEM - opcode 0x63
1451  *
1452  */
1453 static void
1454 init_compute_mem(struct nvbios_init *init)
1455 {
1456 	struct nvkm_devinit *devinit = init->subdev->device->devinit;
1457 
1458 	trace("COMPUTE_MEM\n");
1459 	init->offset += 1;
1460 
1461 	init_exec_force(init, true);
1462 	if (init_exec(init))
1463 		nvkm_devinit_meminit(devinit);
1464 	init_exec_force(init, false);
1465 }
1466 
1467 /**
1468  * INIT_RESET - opcode 0x65
1469  *
1470  */
1471 static void
1472 init_reset(struct nvbios_init *init)
1473 {
1474 	struct nvkm_bios *bios = init->subdev->device->bios;
1475 	u32   reg = nvbios_rd32(bios, init->offset + 1);
1476 	u32 data1 = nvbios_rd32(bios, init->offset + 5);
1477 	u32 data2 = nvbios_rd32(bios, init->offset + 9);
1478 	u32 savepci19;
1479 
1480 	trace("RESET\tR[0x%08x] = 0x%08x, 0x%08x", reg, data1, data2);
1481 	init->offset += 13;
1482 	init_exec_force(init, true);
1483 
1484 	savepci19 = init_mask(init, 0x00184c, 0x00000f00, 0x00000000);
1485 	init_wr32(init, reg, data1);
1486 	udelay(10);
1487 	init_wr32(init, reg, data2);
1488 	init_wr32(init, 0x00184c, savepci19);
1489 	init_mask(init, 0x001850, 0x00000001, 0x00000000);
1490 
1491 	init_exec_force(init, false);
1492 }
1493 
1494 /**
1495  * INIT_CONFIGURE_MEM - opcode 0x66
1496  *
1497  */
1498 static u16
1499 init_configure_mem_clk(struct nvbios_init *init)
1500 {
1501 	u16 mdata = bmp_mem_init_table(init->subdev->device->bios);
1502 	if (mdata)
1503 		mdata += (init_rdvgai(init, 0x03d4, 0x3c) >> 4) * 66;
1504 	return mdata;
1505 }
1506 
1507 static void
1508 init_configure_mem(struct nvbios_init *init)
1509 {
1510 	struct nvkm_bios *bios = init->subdev->device->bios;
1511 	u16 mdata, sdata;
1512 	u32 addr, data;
1513 
1514 	trace("CONFIGURE_MEM\n");
1515 	init->offset += 1;
1516 
1517 	if (bios->version.major > 2) {
1518 		init_done(init);
1519 		return;
1520 	}
1521 	init_exec_force(init, true);
1522 
1523 	mdata = init_configure_mem_clk(init);
1524 	sdata = bmp_sdr_seq_table(bios);
1525 	if (nvbios_rd08(bios, mdata) & 0x01)
1526 		sdata = bmp_ddr_seq_table(bios);
1527 	mdata += 6; /* skip to data */
1528 
1529 	data = init_rdvgai(init, 0x03c4, 0x01);
1530 	init_wrvgai(init, 0x03c4, 0x01, data | 0x20);
1531 
1532 	for (; (addr = nvbios_rd32(bios, sdata)) != 0xffffffff; sdata += 4) {
1533 		switch (addr) {
1534 		case 0x10021c: /* CKE_NORMAL */
1535 		case 0x1002d0: /* CMD_REFRESH */
1536 		case 0x1002d4: /* CMD_PRECHARGE */
1537 			data = 0x00000001;
1538 			break;
1539 		default:
1540 			data = nvbios_rd32(bios, mdata);
1541 			mdata += 4;
1542 			if (data == 0xffffffff)
1543 				continue;
1544 			break;
1545 		}
1546 
1547 		init_wr32(init, addr, data);
1548 	}
1549 
1550 	init_exec_force(init, false);
1551 }
1552 
1553 /**
1554  * INIT_CONFIGURE_CLK - opcode 0x67
1555  *
1556  */
1557 static void
1558 init_configure_clk(struct nvbios_init *init)
1559 {
1560 	struct nvkm_bios *bios = init->subdev->device->bios;
1561 	u16 mdata, clock;
1562 
1563 	trace("CONFIGURE_CLK\n");
1564 	init->offset += 1;
1565 
1566 	if (bios->version.major > 2) {
1567 		init_done(init);
1568 		return;
1569 	}
1570 	init_exec_force(init, true);
1571 
1572 	mdata = init_configure_mem_clk(init);
1573 
1574 	/* NVPLL */
1575 	clock = nvbios_rd16(bios, mdata + 4) * 10;
1576 	init_prog_pll(init, 0x680500, clock);
1577 
1578 	/* MPLL */
1579 	clock = nvbios_rd16(bios, mdata + 2) * 10;
1580 	if (nvbios_rd08(bios, mdata) & 0x01)
1581 		clock *= 2;
1582 	init_prog_pll(init, 0x680504, clock);
1583 
1584 	init_exec_force(init, false);
1585 }
1586 
1587 /**
1588  * INIT_CONFIGURE_PREINIT - opcode 0x68
1589  *
1590  */
1591 static void
1592 init_configure_preinit(struct nvbios_init *init)
1593 {
1594 	struct nvkm_bios *bios = init->subdev->device->bios;
1595 	u32 strap;
1596 
1597 	trace("CONFIGURE_PREINIT\n");
1598 	init->offset += 1;
1599 
1600 	if (bios->version.major > 2) {
1601 		init_done(init);
1602 		return;
1603 	}
1604 	init_exec_force(init, true);
1605 
1606 	strap = init_rd32(init, 0x101000);
1607 	strap = ((strap << 2) & 0xf0) | ((strap & 0x40) >> 6);
1608 	init_wrvgai(init, 0x03d4, 0x3c, strap);
1609 
1610 	init_exec_force(init, false);
1611 }
1612 
1613 /**
1614  * INIT_IO - opcode 0x69
1615  *
1616  */
1617 static void
1618 init_io(struct nvbios_init *init)
1619 {
1620 	struct nvkm_bios *bios = init->subdev->device->bios;
1621 	u16 port = nvbios_rd16(bios, init->offset + 1);
1622 	u8  mask = nvbios_rd16(bios, init->offset + 3);
1623 	u8  data = nvbios_rd16(bios, init->offset + 4);
1624 	u8 value;
1625 
1626 	trace("IO\t\tI[0x%04x] &= 0x%02x |= 0x%02x\n", port, mask, data);
1627 	init->offset += 5;
1628 
1629 	/* ummm.. yes.. should really figure out wtf this is and why it's
1630 	 * needed some day..  it's almost certainly wrong, but, it also
1631 	 * somehow makes things work...
1632 	 */
1633 	if (bios->subdev.device->card_type >= NV_50 &&
1634 	    port == 0x03c3 && data == 0x01) {
1635 		init_mask(init, 0x614100, 0xf0800000, 0x00800000);
1636 		init_mask(init, 0x00e18c, 0x00020000, 0x00020000);
1637 		init_mask(init, 0x614900, 0xf0800000, 0x00800000);
1638 		init_mask(init, 0x000200, 0x40000000, 0x00000000);
1639 		mdelay(10);
1640 		init_mask(init, 0x00e18c, 0x00020000, 0x00000000);
1641 		init_mask(init, 0x000200, 0x40000000, 0x40000000);
1642 		init_wr32(init, 0x614100, 0x00800018);
1643 		init_wr32(init, 0x614900, 0x00800018);
1644 		mdelay(10);
1645 		init_wr32(init, 0x614100, 0x10000018);
1646 		init_wr32(init, 0x614900, 0x10000018);
1647 	}
1648 
1649 	value = init_rdport(init, port) & mask;
1650 	init_wrport(init, port, data | value);
1651 }
1652 
1653 /**
1654  * INIT_SUB - opcode 0x6b
1655  *
1656  */
1657 static void
1658 init_sub(struct nvbios_init *init)
1659 {
1660 	struct nvkm_bios *bios = init->subdev->device->bios;
1661 	u8 index = nvbios_rd08(bios, init->offset + 1);
1662 	u16 addr, save;
1663 
1664 	trace("SUB\t0x%02x\n", index);
1665 
1666 	addr = init_script(bios, index);
1667 	if (addr && init_exec(init)) {
1668 		save = init->offset;
1669 		init->offset = addr;
1670 		if (nvbios_exec(init)) {
1671 			error("error parsing sub-table\n");
1672 			return;
1673 		}
1674 		init->offset = save;
1675 	}
1676 
1677 	init->offset += 2;
1678 }
1679 
1680 /**
1681  * INIT_RAM_CONDITION - opcode 0x6d
1682  *
1683  */
1684 static void
1685 init_ram_condition(struct nvbios_init *init)
1686 {
1687 	struct nvkm_bios *bios = init->subdev->device->bios;
1688 	u8  mask = nvbios_rd08(bios, init->offset + 1);
1689 	u8 value = nvbios_rd08(bios, init->offset + 2);
1690 
1691 	trace("RAM_CONDITION\t"
1692 	      "(R[0x100000] & 0x%02x) == 0x%02x\n", mask, value);
1693 	init->offset += 3;
1694 
1695 	if ((init_rd32(init, 0x100000) & mask) != value)
1696 		init_exec_set(init, false);
1697 }
1698 
1699 /**
1700  * INIT_NV_REG - opcode 0x6e
1701  *
1702  */
1703 static void
1704 init_nv_reg(struct nvbios_init *init)
1705 {
1706 	struct nvkm_bios *bios = init->subdev->device->bios;
1707 	u32  reg = nvbios_rd32(bios, init->offset + 1);
1708 	u32 mask = nvbios_rd32(bios, init->offset + 5);
1709 	u32 data = nvbios_rd32(bios, init->offset + 9);
1710 
1711 	trace("NV_REG\tR[0x%06x] &= 0x%08x |= 0x%08x\n", reg, mask, data);
1712 	init->offset += 13;
1713 
1714 	init_mask(init, reg, ~mask, data);
1715 }
1716 
1717 /**
1718  * INIT_MACRO - opcode 0x6f
1719  *
1720  */
1721 static void
1722 init_macro(struct nvbios_init *init)
1723 {
1724 	struct nvkm_bios *bios = init->subdev->device->bios;
1725 	u8  macro = nvbios_rd08(bios, init->offset + 1);
1726 	u16 table;
1727 
1728 	trace("MACRO\t0x%02x\n", macro);
1729 
1730 	table = init_macro_table(init);
1731 	if (table) {
1732 		u32 addr = nvbios_rd32(bios, table + (macro * 8) + 0);
1733 		u32 data = nvbios_rd32(bios, table + (macro * 8) + 4);
1734 		trace("\t\tR[0x%06x] = 0x%08x\n", addr, data);
1735 		init_wr32(init, addr, data);
1736 	}
1737 
1738 	init->offset += 2;
1739 }
1740 
1741 /**
1742  * INIT_RESUME - opcode 0x72
1743  *
1744  */
1745 static void
1746 init_resume(struct nvbios_init *init)
1747 {
1748 	trace("RESUME\n");
1749 	init->offset += 1;
1750 	init_exec_set(init, true);
1751 }
1752 
1753 /**
1754  * INIT_STRAP_CONDITION - opcode 0x73
1755  *
1756  */
1757 static void
1758 init_strap_condition(struct nvbios_init *init)
1759 {
1760 	struct nvkm_bios *bios = init->subdev->device->bios;
1761 	u32 mask = nvbios_rd32(bios, init->offset + 1);
1762 	u32 value = nvbios_rd32(bios, init->offset + 5);
1763 
1764 	trace("STRAP_CONDITION\t(R[0x101000] & 0x%08x) == 0x%08x\n", mask, value);
1765 	init->offset += 9;
1766 
1767 	if ((init_rd32(init, 0x101000) & mask) != value)
1768 		init_exec_set(init, false);
1769 }
1770 
1771 /**
1772  * INIT_TIME - opcode 0x74
1773  *
1774  */
1775 static void
1776 init_time(struct nvbios_init *init)
1777 {
1778 	struct nvkm_bios *bios = init->subdev->device->bios;
1779 	u16 usec = nvbios_rd16(bios, init->offset + 1);
1780 
1781 	trace("TIME\t0x%04x\n", usec);
1782 	init->offset += 3;
1783 
1784 	if (init_exec(init)) {
1785 		if (usec < 1000)
1786 			udelay(usec);
1787 		else
1788 			mdelay((usec + 900) / 1000);
1789 	}
1790 }
1791 
1792 /**
1793  * INIT_CONDITION - opcode 0x75
1794  *
1795  */
1796 static void
1797 init_condition(struct nvbios_init *init)
1798 {
1799 	struct nvkm_bios *bios = init->subdev->device->bios;
1800 	u8 cond = nvbios_rd08(bios, init->offset + 1);
1801 
1802 	trace("CONDITION\t0x%02x\n", cond);
1803 	init->offset += 2;
1804 
1805 	if (!init_condition_met(init, cond))
1806 		init_exec_set(init, false);
1807 }
1808 
1809 /**
1810  * INIT_IO_CONDITION - opcode 0x76
1811  *
1812  */
1813 static void
1814 init_io_condition(struct nvbios_init *init)
1815 {
1816 	struct nvkm_bios *bios = init->subdev->device->bios;
1817 	u8 cond = nvbios_rd08(bios, init->offset + 1);
1818 
1819 	trace("IO_CONDITION\t0x%02x\n", cond);
1820 	init->offset += 2;
1821 
1822 	if (!init_io_condition_met(init, cond))
1823 		init_exec_set(init, false);
1824 }
1825 
1826 /**
1827  * INIT_ZM_REG16 - opcode 0x77
1828  *
1829  */
1830 static void
1831 init_zm_reg16(struct nvbios_init *init)
1832 {
1833 	struct nvkm_bios *bios = init->subdev->device->bios;
1834 	u32 addr = nvbios_rd32(bios, init->offset + 1);
1835 	u16 data = nvbios_rd16(bios, init->offset + 5);
1836 
1837 	trace("ZM_REG\tR[0x%06x] = 0x%04x\n", addr, data);
1838 	init->offset += 7;
1839 
1840 	init_wr32(init, addr, data);
1841 }
1842 
1843 /**
1844  * INIT_INDEX_IO - opcode 0x78
1845  *
1846  */
1847 static void
1848 init_index_io(struct nvbios_init *init)
1849 {
1850 	struct nvkm_bios *bios = init->subdev->device->bios;
1851 	u16 port = nvbios_rd16(bios, init->offset + 1);
1852 	u8 index = nvbios_rd16(bios, init->offset + 3);
1853 	u8  mask = nvbios_rd08(bios, init->offset + 4);
1854 	u8  data = nvbios_rd08(bios, init->offset + 5);
1855 	u8 value;
1856 
1857 	trace("INDEX_IO\tI[0x%04x][0x%02x] &= 0x%02x |= 0x%02x\n",
1858 	      port, index, mask, data);
1859 	init->offset += 6;
1860 
1861 	value = init_rdvgai(init, port, index) & mask;
1862 	init_wrvgai(init, port, index, data | value);
1863 }
1864 
1865 /**
1866  * INIT_PLL - opcode 0x79
1867  *
1868  */
1869 static void
1870 init_pll(struct nvbios_init *init)
1871 {
1872 	struct nvkm_bios *bios = init->subdev->device->bios;
1873 	u32  reg = nvbios_rd32(bios, init->offset + 1);
1874 	u32 freq = nvbios_rd16(bios, init->offset + 5) * 10;
1875 
1876 	trace("PLL\tR[0x%06x] =PLL= %dkHz\n", reg, freq);
1877 	init->offset += 7;
1878 
1879 	init_prog_pll(init, reg, freq);
1880 }
1881 
1882 /**
1883  * INIT_ZM_REG - opcode 0x7a
1884  *
1885  */
1886 static void
1887 init_zm_reg(struct nvbios_init *init)
1888 {
1889 	struct nvkm_bios *bios = init->subdev->device->bios;
1890 	u32 addr = nvbios_rd32(bios, init->offset + 1);
1891 	u32 data = nvbios_rd32(bios, init->offset + 5);
1892 
1893 	trace("ZM_REG\tR[0x%06x] = 0x%08x\n", addr, data);
1894 	init->offset += 9;
1895 
1896 	if (addr == 0x000200)
1897 		data |= 0x00000001;
1898 
1899 	init_wr32(init, addr, data);
1900 }
1901 
1902 /**
1903  * INIT_RAM_RESTRICT_PLL - opcde 0x87
1904  *
1905  */
1906 static void
1907 init_ram_restrict_pll(struct nvbios_init *init)
1908 {
1909 	struct nvkm_bios *bios = init->subdev->device->bios;
1910 	u8  type = nvbios_rd08(bios, init->offset + 1);
1911 	u8 count = init_ram_restrict_group_count(init);
1912 	u8 strap = init_ram_restrict(init);
1913 	u8 cconf;
1914 
1915 	trace("RAM_RESTRICT_PLL\t0x%02x\n", type);
1916 	init->offset += 2;
1917 
1918 	for (cconf = 0; cconf < count; cconf++) {
1919 		u32 freq = nvbios_rd32(bios, init->offset);
1920 
1921 		if (cconf == strap) {
1922 			trace("%dkHz *\n", freq);
1923 			init_prog_pll(init, type, freq);
1924 		} else {
1925 			trace("%dkHz\n", freq);
1926 		}
1927 
1928 		init->offset += 4;
1929 	}
1930 }
1931 
1932 /**
1933  * INIT_GPIO - opcode 0x8e
1934  *
1935  */
1936 static void
1937 init_gpio(struct nvbios_init *init)
1938 {
1939 	struct nvkm_gpio *gpio = init->subdev->device->gpio;
1940 
1941 	trace("GPIO\n");
1942 	init->offset += 1;
1943 
1944 	if (init_exec(init))
1945 		nvkm_gpio_reset(gpio, DCB_GPIO_UNUSED);
1946 }
1947 
1948 /**
1949  * INIT_RAM_RESTRICT_ZM_GROUP - opcode 0x8f
1950  *
1951  */
1952 static void
1953 init_ram_restrict_zm_reg_group(struct nvbios_init *init)
1954 {
1955 	struct nvkm_bios *bios = init->subdev->device->bios;
1956 	u32 addr = nvbios_rd32(bios, init->offset + 1);
1957 	u8  incr = nvbios_rd08(bios, init->offset + 5);
1958 	u8   num = nvbios_rd08(bios, init->offset + 6);
1959 	u8 count = init_ram_restrict_group_count(init);
1960 	u8 index = init_ram_restrict(init);
1961 	u8 i, j;
1962 
1963 	trace("RAM_RESTRICT_ZM_REG_GROUP\t"
1964 	      "R[0x%08x] 0x%02x 0x%02x\n", addr, incr, num);
1965 	init->offset += 7;
1966 
1967 	for (i = 0; i < num; i++) {
1968 		trace("\tR[0x%06x] = {\n", addr);
1969 		for (j = 0; j < count; j++) {
1970 			u32 data = nvbios_rd32(bios, init->offset);
1971 
1972 			if (j == index) {
1973 				trace("\t\t0x%08x *\n", data);
1974 				init_wr32(init, addr, data);
1975 			} else {
1976 				trace("\t\t0x%08x\n", data);
1977 			}
1978 
1979 			init->offset += 4;
1980 		}
1981 		trace("\t}\n");
1982 		addr += incr;
1983 	}
1984 }
1985 
1986 /**
1987  * INIT_COPY_ZM_REG - opcode 0x90
1988  *
1989  */
1990 static void
1991 init_copy_zm_reg(struct nvbios_init *init)
1992 {
1993 	struct nvkm_bios *bios = init->subdev->device->bios;
1994 	u32 sreg = nvbios_rd32(bios, init->offset + 1);
1995 	u32 dreg = nvbios_rd32(bios, init->offset + 5);
1996 
1997 	trace("COPY_ZM_REG\tR[0x%06x] = R[0x%06x]\n", dreg, sreg);
1998 	init->offset += 9;
1999 
2000 	init_wr32(init, dreg, init_rd32(init, sreg));
2001 }
2002 
2003 /**
2004  * INIT_ZM_REG_GROUP - opcode 0x91
2005  *
2006  */
2007 static void
2008 init_zm_reg_group(struct nvbios_init *init)
2009 {
2010 	struct nvkm_bios *bios = init->subdev->device->bios;
2011 	u32 addr = nvbios_rd32(bios, init->offset + 1);
2012 	u8 count = nvbios_rd08(bios, init->offset + 5);
2013 
2014 	trace("ZM_REG_GROUP\tR[0x%06x] =\n", addr);
2015 	init->offset += 6;
2016 
2017 	while (count--) {
2018 		u32 data = nvbios_rd32(bios, init->offset);
2019 		trace("\t0x%08x\n", data);
2020 		init_wr32(init, addr, data);
2021 		init->offset += 4;
2022 	}
2023 }
2024 
2025 /**
2026  * INIT_XLAT - opcode 0x96
2027  *
2028  */
2029 static void
2030 init_xlat(struct nvbios_init *init)
2031 {
2032 	struct nvkm_bios *bios = init->subdev->device->bios;
2033 	u32 saddr = nvbios_rd32(bios, init->offset + 1);
2034 	u8 sshift = nvbios_rd08(bios, init->offset + 5);
2035 	u8  smask = nvbios_rd08(bios, init->offset + 6);
2036 	u8  index = nvbios_rd08(bios, init->offset + 7);
2037 	u32 daddr = nvbios_rd32(bios, init->offset + 8);
2038 	u32 dmask = nvbios_rd32(bios, init->offset + 12);
2039 	u8  shift = nvbios_rd08(bios, init->offset + 16);
2040 	u32 data;
2041 
2042 	trace("INIT_XLAT\tR[0x%06x] &= 0x%08x |= "
2043 	      "(X%02x((R[0x%06x] %s 0x%02x) & 0x%02x) << 0x%02x)\n",
2044 	      daddr, dmask, index, saddr, (sshift & 0x80) ? "<<" : ">>",
2045 	      (sshift & 0x80) ? (0x100 - sshift) : sshift, smask, shift);
2046 	init->offset += 17;
2047 
2048 	data = init_shift(init_rd32(init, saddr), sshift) & smask;
2049 	data = init_xlat_(init, index, data) << shift;
2050 	init_mask(init, daddr, ~dmask, data);
2051 }
2052 
2053 /**
2054  * INIT_ZM_MASK_ADD - opcode 0x97
2055  *
2056  */
2057 static void
2058 init_zm_mask_add(struct nvbios_init *init)
2059 {
2060 	struct nvkm_bios *bios = init->subdev->device->bios;
2061 	u32 addr = nvbios_rd32(bios, init->offset + 1);
2062 	u32 mask = nvbios_rd32(bios, init->offset + 5);
2063 	u32  add = nvbios_rd32(bios, init->offset + 9);
2064 	u32 data;
2065 
2066 	trace("ZM_MASK_ADD\tR[0x%06x] &= 0x%08x += 0x%08x\n", addr, mask, add);
2067 	init->offset += 13;
2068 
2069 	data =  init_rd32(init, addr);
2070 	data = (data & mask) | ((data + add) & ~mask);
2071 	init_wr32(init, addr, data);
2072 }
2073 
2074 /**
2075  * INIT_AUXCH - opcode 0x98
2076  *
2077  */
2078 static void
2079 init_auxch(struct nvbios_init *init)
2080 {
2081 	struct nvkm_bios *bios = init->subdev->device->bios;
2082 	u32 addr = nvbios_rd32(bios, init->offset + 1);
2083 	u8 count = nvbios_rd08(bios, init->offset + 5);
2084 
2085 	trace("AUXCH\tAUX[0x%08x] 0x%02x\n", addr, count);
2086 	init->offset += 6;
2087 
2088 	while (count--) {
2089 		u8 mask = nvbios_rd08(bios, init->offset + 0);
2090 		u8 data = nvbios_rd08(bios, init->offset + 1);
2091 		trace("\tAUX[0x%08x] &= 0x%02x |= 0x%02x\n", addr, mask, data);
2092 		mask = init_rdauxr(init, addr) & mask;
2093 		init_wrauxr(init, addr, mask | data);
2094 		init->offset += 2;
2095 	}
2096 }
2097 
2098 /**
2099  * INIT_AUXCH - opcode 0x99
2100  *
2101  */
2102 static void
2103 init_zm_auxch(struct nvbios_init *init)
2104 {
2105 	struct nvkm_bios *bios = init->subdev->device->bios;
2106 	u32 addr = nvbios_rd32(bios, init->offset + 1);
2107 	u8 count = nvbios_rd08(bios, init->offset + 5);
2108 
2109 	trace("ZM_AUXCH\tAUX[0x%08x] 0x%02x\n", addr, count);
2110 	init->offset += 6;
2111 
2112 	while (count--) {
2113 		u8 data = nvbios_rd08(bios, init->offset + 0);
2114 		trace("\tAUX[0x%08x] = 0x%02x\n", addr, data);
2115 		init_wrauxr(init, addr, data);
2116 		init->offset += 1;
2117 	}
2118 }
2119 
2120 /**
2121  * INIT_I2C_LONG_IF - opcode 0x9a
2122  *
2123  */
2124 static void
2125 init_i2c_long_if(struct nvbios_init *init)
2126 {
2127 	struct nvkm_bios *bios = init->subdev->device->bios;
2128 	u8 index = nvbios_rd08(bios, init->offset + 1);
2129 	u8  addr = nvbios_rd08(bios, init->offset + 2) >> 1;
2130 	u8 reglo = nvbios_rd08(bios, init->offset + 3);
2131 	u8 reghi = nvbios_rd08(bios, init->offset + 4);
2132 	u8  mask = nvbios_rd08(bios, init->offset + 5);
2133 	u8  data = nvbios_rd08(bios, init->offset + 6);
2134 	struct i2c_adapter *adap;
2135 
2136 	trace("I2C_LONG_IF\t"
2137 	      "I2C[0x%02x][0x%02x][0x%02x%02x] & 0x%02x == 0x%02x\n",
2138 	      index, addr, reglo, reghi, mask, data);
2139 	init->offset += 7;
2140 
2141 	adap = init_i2c(init, index);
2142 	if (adap) {
2143 		u8 i[2] = { reghi, reglo };
2144 		u8 o[1] = {};
2145 		struct i2c_msg msg[] = {
2146 			{ .addr = addr, .flags = 0, .len = 2, .buf = i },
2147 			{ .addr = addr, .flags = I2C_M_RD, .len = 1, .buf = o }
2148 		};
2149 		int ret;
2150 
2151 		ret = i2c_transfer(adap, msg, 2);
2152 		if (ret == 2 && ((o[0] & mask) == data))
2153 			return;
2154 	}
2155 
2156 	init_exec_set(init, false);
2157 }
2158 
2159 /**
2160  * INIT_GPIO_NE - opcode 0xa9
2161  *
2162  */
2163 static void
2164 init_gpio_ne(struct nvbios_init *init)
2165 {
2166 	struct nvkm_bios *bios = init->subdev->device->bios;
2167 	struct nvkm_gpio *gpio = bios->subdev.device->gpio;
2168 	struct dcb_gpio_func func;
2169 	u8 count = nvbios_rd08(bios, init->offset + 1);
2170 	u8 idx = 0, ver, len;
2171 	u16 data, i;
2172 
2173 	trace("GPIO_NE\t");
2174 	init->offset += 2;
2175 
2176 	for (i = init->offset; i < init->offset + count; i++)
2177 		cont("0x%02x ", nvbios_rd08(bios, i));
2178 	cont("\n");
2179 
2180 	while ((data = dcb_gpio_parse(bios, 0, idx++, &ver, &len, &func))) {
2181 		if (func.func != DCB_GPIO_UNUSED) {
2182 			for (i = init->offset; i < init->offset + count; i++) {
2183 				if (func.func == nvbios_rd08(bios, i))
2184 					break;
2185 			}
2186 
2187 			trace("\tFUNC[0x%02x]", func.func);
2188 			if (i == (init->offset + count)) {
2189 				cont(" *");
2190 				if (init_exec(init))
2191 					nvkm_gpio_reset(gpio, func.func);
2192 			}
2193 			cont("\n");
2194 		}
2195 	}
2196 
2197 	init->offset += count;
2198 }
2199 
2200 static struct nvbios_init_opcode {
2201 	void (*exec)(struct nvbios_init *);
2202 } init_opcode[] = {
2203 	[0x32] = { init_io_restrict_prog },
2204 	[0x33] = { init_repeat },
2205 	[0x34] = { init_io_restrict_pll },
2206 	[0x36] = { init_end_repeat },
2207 	[0x37] = { init_copy },
2208 	[0x38] = { init_not },
2209 	[0x39] = { init_io_flag_condition },
2210 	[0x3a] = { init_generic_condition },
2211 	[0x3b] = { init_io_mask_or },
2212 	[0x3c] = { init_io_or },
2213 	[0x47] = { init_andn_reg },
2214 	[0x48] = { init_or_reg },
2215 	[0x49] = { init_idx_addr_latched },
2216 	[0x4a] = { init_io_restrict_pll2 },
2217 	[0x4b] = { init_pll2 },
2218 	[0x4c] = { init_i2c_byte },
2219 	[0x4d] = { init_zm_i2c_byte },
2220 	[0x4e] = { init_zm_i2c },
2221 	[0x4f] = { init_tmds },
2222 	[0x50] = { init_zm_tmds_group },
2223 	[0x51] = { init_cr_idx_adr_latch },
2224 	[0x52] = { init_cr },
2225 	[0x53] = { init_zm_cr },
2226 	[0x54] = { init_zm_cr_group },
2227 	[0x56] = { init_condition_time },
2228 	[0x57] = { init_ltime },
2229 	[0x58] = { init_zm_reg_sequence },
2230 	[0x59] = { init_pll_indirect },
2231 	[0x5a] = { init_zm_reg_indirect },
2232 	[0x5b] = { init_sub_direct },
2233 	[0x5c] = { init_jump },
2234 	[0x5e] = { init_i2c_if },
2235 	[0x5f] = { init_copy_nv_reg },
2236 	[0x62] = { init_zm_index_io },
2237 	[0x63] = { init_compute_mem },
2238 	[0x65] = { init_reset },
2239 	[0x66] = { init_configure_mem },
2240 	[0x67] = { init_configure_clk },
2241 	[0x68] = { init_configure_preinit },
2242 	[0x69] = { init_io },
2243 	[0x6b] = { init_sub },
2244 	[0x6d] = { init_ram_condition },
2245 	[0x6e] = { init_nv_reg },
2246 	[0x6f] = { init_macro },
2247 	[0x71] = { init_done },
2248 	[0x72] = { init_resume },
2249 	[0x73] = { init_strap_condition },
2250 	[0x74] = { init_time },
2251 	[0x75] = { init_condition },
2252 	[0x76] = { init_io_condition },
2253 	[0x77] = { init_zm_reg16 },
2254 	[0x78] = { init_index_io },
2255 	[0x79] = { init_pll },
2256 	[0x7a] = { init_zm_reg },
2257 	[0x87] = { init_ram_restrict_pll },
2258 	[0x8c] = { init_reserved },
2259 	[0x8d] = { init_reserved },
2260 	[0x8e] = { init_gpio },
2261 	[0x8f] = { init_ram_restrict_zm_reg_group },
2262 	[0x90] = { init_copy_zm_reg },
2263 	[0x91] = { init_zm_reg_group },
2264 	[0x92] = { init_reserved },
2265 	[0x96] = { init_xlat },
2266 	[0x97] = { init_zm_mask_add },
2267 	[0x98] = { init_auxch },
2268 	[0x99] = { init_zm_auxch },
2269 	[0x9a] = { init_i2c_long_if },
2270 	[0xa9] = { init_gpio_ne },
2271 	[0xaa] = { init_reserved },
2272 };
2273 
2274 #define init_opcode_nr (sizeof(init_opcode) / sizeof(init_opcode[0]))
2275 
2276 int
2277 nvbios_exec(struct nvbios_init *init)
2278 {
2279 	struct nvkm_bios *bios = init->subdev->device->bios;
2280 
2281 	init->nested++;
2282 	while (init->offset) {
2283 		u8 opcode = nvbios_rd08(bios, init->offset);
2284 		if (opcode >= init_opcode_nr || !init_opcode[opcode].exec) {
2285 			error("unknown opcode 0x%02x\n", opcode);
2286 			return -EINVAL;
2287 		}
2288 
2289 		init_opcode[opcode].exec(init);
2290 	}
2291 	init->nested--;
2292 	return 0;
2293 }
2294 
2295 int
2296 nvbios_post(struct nvkm_subdev *subdev, bool execute)
2297 {
2298 	struct nvkm_bios *bios = subdev->device->bios;
2299 	int ret = 0;
2300 	int i = -1;
2301 	u16 data;
2302 
2303 	if (execute)
2304 		nvkm_debug(subdev, "running init tables\n");
2305 	while (!ret && (data = (init_script(bios, ++i)))) {
2306 		ret = nvbios_init(subdev, data,
2307 			init.execute = execute ? 1 : 0;
2308 		      );
2309 	}
2310 
2311 	/* the vbios parser will run this right after the normal init
2312 	 * tables, whereas the binary driver appears to run it later.
2313 	 */
2314 	if (!ret && (data = init_unknown_script(bios))) {
2315 		ret = nvbios_init(subdev, data,
2316 			init.execute = execute ? 1 : 0;
2317 		      );
2318 	}
2319 
2320 	return ret;
2321 }
2322