xref: /linux/drivers/video/fbdev/nvidia/nvidia.c (revision 5e3c6a312a0946d2d83e32359612cbb925a8bed0)
1 /*
2  * linux/drivers/video/nvidia/nvidia.c - nVidia fb driver
3  *
4  * Copyright 2004 Antonino Daplas <adaplas@pol.net>
5  *
6  * This file is subject to the terms and conditions of the GNU General Public
7  * License.  See the file COPYING in the main directory of this archive
8  * for more details.
9  *
10  */
11 
12 #include <linux/module.h>
13 #include <linux/kernel.h>
14 #include <linux/errno.h>
15 #include <linux/string.h>
16 #include <linux/mm.h>
17 #include <linux/slab.h>
18 #include <linux/delay.h>
19 #include <linux/fb.h>
20 #include <linux/init.h>
21 #include <linux/pci.h>
22 #include <linux/console.h>
23 #include <linux/backlight.h>
24 #ifdef CONFIG_BOOTX_TEXT
25 #include <asm/btext.h>
26 #endif
27 
28 #include "nv_local.h"
29 #include "nv_type.h"
30 #include "nv_proto.h"
31 #include "nv_dma.h"
32 
33 #ifdef CONFIG_FB_NVIDIA_DEBUG
34 #define NVTRACE          printk
35 #else
36 #define NVTRACE          if (0) printk
37 #endif
38 
39 #define NVTRACE_ENTER(...)  NVTRACE("%s START\n", __func__)
40 #define NVTRACE_LEAVE(...)  NVTRACE("%s END\n", __func__)
41 
42 #ifdef CONFIG_FB_NVIDIA_DEBUG
43 #define assert(expr) \
44 	if (!(expr)) { \
45 	printk( "Assertion failed! %s,%s,%s,line=%d\n",\
46 	#expr,__FILE__,__func__,__LINE__); \
47 	BUG(); \
48 	}
49 #else
50 #define assert(expr)
51 #endif
52 
53 #define PFX "nvidiafb: "
54 
55 /* HW cursor parameters */
56 #define MAX_CURS		32
57 
58 static const struct pci_device_id nvidiafb_pci_tbl[] = {
59 	{PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID,
60 	 PCI_BASE_CLASS_DISPLAY << 16, 0xff0000, 0},
61 	{ 0, }
62 };
63 MODULE_DEVICE_TABLE(pci, nvidiafb_pci_tbl);
64 
65 /* command line data, set in nvidiafb_setup() */
66 static int flatpanel = -1;	/* Autodetect later */
67 static int fpdither = -1;
68 static int forceCRTC = -1;
69 static int hwcur = 0;
70 static int noaccel = 0;
71 static int noscale = 0;
72 static int paneltweak = 0;
73 static int vram = 0;
74 static int bpp = 8;
75 static int reverse_i2c;
76 static bool nomtrr = false;
77 #ifdef CONFIG_PMAC_BACKLIGHT
78 static int backlight = 1;
79 #else
80 static int backlight = 0;
81 #endif
82 
83 static char *mode_option = NULL;
84 
85 static struct fb_fix_screeninfo nvidiafb_fix = {
86 	.type = FB_TYPE_PACKED_PIXELS,
87 	.xpanstep = 8,
88 	.ypanstep = 1,
89 };
90 
91 static struct fb_var_screeninfo nvidiafb_default_var = {
92 	.xres = 640,
93 	.yres = 480,
94 	.xres_virtual = 640,
95 	.yres_virtual = 480,
96 	.bits_per_pixel = 8,
97 	.red = {0, 8, 0},
98 	.green = {0, 8, 0},
99 	.blue = {0, 8, 0},
100 	.transp = {0, 0, 0},
101 	.activate = FB_ACTIVATE_NOW,
102 	.height = -1,
103 	.width = -1,
104 	.pixclock = 39721,
105 	.left_margin = 40,
106 	.right_margin = 24,
107 	.upper_margin = 32,
108 	.lower_margin = 11,
109 	.hsync_len = 96,
110 	.vsync_len = 2,
111 	.vmode = FB_VMODE_NONINTERLACED
112 };
113 
114 static void nvidiafb_load_cursor_image(struct nvidia_par *par, u8 * data8,
115 				       u16 bg, u16 fg, u32 w, u32 h)
116 {
117 	u32 *data = (u32 *) data8;
118 	int i, j, k = 0;
119 	u32 b, tmp;
120 
121 	w = (w + 1) & ~1;
122 
123 	for (i = 0; i < h; i++) {
124 		b = *data++;
125 		reverse_order(&b);
126 
127 		for (j = 0; j < w / 2; j++) {
128 			tmp = 0;
129 #if defined (__BIG_ENDIAN)
130 			tmp = (b & (1 << 31)) ? fg << 16 : bg << 16;
131 			b <<= 1;
132 			tmp |= (b & (1 << 31)) ? fg : bg;
133 			b <<= 1;
134 #else
135 			tmp = (b & 1) ? fg : bg;
136 			b >>= 1;
137 			tmp |= (b & 1) ? fg << 16 : bg << 16;
138 			b >>= 1;
139 #endif
140 			NV_WR32(&par->CURSOR[k++], 0, tmp);
141 		}
142 		k += (MAX_CURS - w) / 2;
143 	}
144 }
145 
146 static void nvidia_write_clut(struct nvidia_par *par,
147 			      u8 regnum, u8 red, u8 green, u8 blue)
148 {
149 	NVWriteDacMask(par, 0xff);
150 	NVWriteDacWriteAddr(par, regnum);
151 	NVWriteDacData(par, red);
152 	NVWriteDacData(par, green);
153 	NVWriteDacData(par, blue);
154 }
155 
156 static void nvidia_read_clut(struct nvidia_par *par,
157 			     u8 regnum, u8 * red, u8 * green, u8 * blue)
158 {
159 	NVWriteDacMask(par, 0xff);
160 	NVWriteDacReadAddr(par, regnum);
161 	*red = NVReadDacData(par);
162 	*green = NVReadDacData(par);
163 	*blue = NVReadDacData(par);
164 }
165 
166 static int nvidia_panel_tweak(struct nvidia_par *par,
167 			      struct _riva_hw_state *state)
168 {
169 	int tweak = 0;
170 
171    if (par->paneltweak) {
172 	   tweak = par->paneltweak;
173    } else {
174 	   /* begin flat panel hacks */
175 	   /* This is unfortunate, but some chips need this register
176 	      tweaked or else you get artifacts where adjacent pixels are
177 	      swapped.  There are no hard rules for what to set here so all
178 	      we can do is experiment and apply hacks. */
179 
180 	   if(((par->Chipset & 0xffff) == 0x0328) && (state->bpp == 32)) {
181 		   /* At least one NV34 laptop needs this workaround. */
182 		   tweak = -1;
183 	   }
184 
185 	   if((par->Chipset & 0xfff0) == 0x0310) {
186 		   tweak = 1;
187 	   }
188 	   /* end flat panel hacks */
189    }
190 
191    return tweak;
192 }
193 
194 static void nvidia_screen_off(struct nvidia_par *par, int on)
195 {
196 	unsigned char tmp;
197 
198 	if (on) {
199 		/*
200 		 * Turn off screen and disable sequencer.
201 		 */
202 		tmp = NVReadSeq(par, 0x01);
203 
204 		NVWriteSeq(par, 0x00, 0x01);		/* Synchronous Reset */
205 		NVWriteSeq(par, 0x01, tmp | 0x20);	/* disable the display */
206 	} else {
207 		/*
208 		 * Reenable sequencer, then turn on screen.
209 		 */
210 
211 		tmp = NVReadSeq(par, 0x01);
212 
213 		NVWriteSeq(par, 0x01, tmp & ~0x20);	/* reenable display */
214 		NVWriteSeq(par, 0x00, 0x03);		/* End Reset */
215 	}
216 }
217 
218 static void nvidia_save_vga(struct nvidia_par *par,
219 			    struct _riva_hw_state *state)
220 {
221 	int i;
222 
223 	NVTRACE_ENTER();
224 	NVLockUnlock(par, 0);
225 
226 	NVUnloadStateExt(par, state);
227 
228 	state->misc_output = NVReadMiscOut(par);
229 
230 	for (i = 0; i < NUM_CRT_REGS; i++)
231 		state->crtc[i] = NVReadCrtc(par, i);
232 
233 	for (i = 0; i < NUM_ATC_REGS; i++)
234 		state->attr[i] = NVReadAttr(par, i);
235 
236 	for (i = 0; i < NUM_GRC_REGS; i++)
237 		state->gra[i] = NVReadGr(par, i);
238 
239 	for (i = 0; i < NUM_SEQ_REGS; i++)
240 		state->seq[i] = NVReadSeq(par, i);
241 	NVTRACE_LEAVE();
242 }
243 
244 #undef DUMP_REG
245 
246 static void nvidia_write_regs(struct nvidia_par *par,
247 			      struct _riva_hw_state *state)
248 {
249 	int i;
250 
251 	NVTRACE_ENTER();
252 
253 	NVLoadStateExt(par, state);
254 
255 	NVWriteMiscOut(par, state->misc_output);
256 
257 	for (i = 1; i < NUM_SEQ_REGS; i++) {
258 #ifdef DUMP_REG
259 		printk(" SEQ[%02x] = %08x\n", i, state->seq[i]);
260 #endif
261 		NVWriteSeq(par, i, state->seq[i]);
262 	}
263 
264 	/* Ensure CRTC registers 0-7 are unlocked by clearing bit 7 of CRTC[17] */
265 	NVWriteCrtc(par, 0x11, state->crtc[0x11] & ~0x80);
266 
267 	for (i = 0; i < NUM_CRT_REGS; i++) {
268 		switch (i) {
269 		case 0x19:
270 		case 0x20 ... 0x40:
271 			break;
272 		default:
273 #ifdef DUMP_REG
274 			printk("CRTC[%02x] = %08x\n", i, state->crtc[i]);
275 #endif
276 			NVWriteCrtc(par, i, state->crtc[i]);
277 		}
278 	}
279 
280 	for (i = 0; i < NUM_GRC_REGS; i++) {
281 #ifdef DUMP_REG
282 		printk(" GRA[%02x] = %08x\n", i, state->gra[i]);
283 #endif
284 		NVWriteGr(par, i, state->gra[i]);
285 	}
286 
287 	for (i = 0; i < NUM_ATC_REGS; i++) {
288 #ifdef DUMP_REG
289 		printk("ATTR[%02x] = %08x\n", i, state->attr[i]);
290 #endif
291 		NVWriteAttr(par, i, state->attr[i]);
292 	}
293 
294 	NVTRACE_LEAVE();
295 }
296 
297 static int nvidia_calc_regs(struct fb_info *info)
298 {
299 	struct nvidia_par *par = info->par;
300 	struct _riva_hw_state *state = &par->ModeReg;
301 	int i, depth = fb_get_color_depth(&info->var, &info->fix);
302 	int h_display = info->var.xres / 8 - 1;
303 	int h_start = (info->var.xres + info->var.right_margin) / 8 - 1;
304 	int h_end = (info->var.xres + info->var.right_margin +
305 		     info->var.hsync_len) / 8 - 1;
306 	int h_total = (info->var.xres + info->var.right_margin +
307 		       info->var.hsync_len + info->var.left_margin) / 8 - 5;
308 	int h_blank_s = h_display;
309 	int h_blank_e = h_total + 4;
310 	int v_display = info->var.yres - 1;
311 	int v_start = info->var.yres + info->var.lower_margin - 1;
312 	int v_end = (info->var.yres + info->var.lower_margin +
313 		     info->var.vsync_len) - 1;
314 	int v_total = (info->var.yres + info->var.lower_margin +
315 		       info->var.vsync_len + info->var.upper_margin) - 2;
316 	int v_blank_s = v_display;
317 	int v_blank_e = v_total + 1;
318 
319 	/*
320 	 * Set all CRTC values.
321 	 */
322 
323 	if (info->var.vmode & FB_VMODE_INTERLACED)
324 		v_total |= 1;
325 
326 	if (par->FlatPanel == 1) {
327 		v_start = v_total - 3;
328 		v_end = v_total - 2;
329 		v_blank_s = v_start;
330 		h_start = h_total - 5;
331 		h_end = h_total - 2;
332 		h_blank_e = h_total + 4;
333 	}
334 
335 	state->crtc[0x0] = Set8Bits(h_total);
336 	state->crtc[0x1] = Set8Bits(h_display);
337 	state->crtc[0x2] = Set8Bits(h_blank_s);
338 	state->crtc[0x3] = SetBitField(h_blank_e, 4: 0, 4:0)
339 		| SetBit(7);
340 	state->crtc[0x4] = Set8Bits(h_start);
341 	state->crtc[0x5] = SetBitField(h_blank_e, 5: 5, 7:7)
342 		| SetBitField(h_end, 4: 0, 4:0);
343 	state->crtc[0x6] = SetBitField(v_total, 7: 0, 7:0);
344 	state->crtc[0x7] = SetBitField(v_total, 8: 8, 0:0)
345 		| SetBitField(v_display, 8: 8, 1:1)
346 		| SetBitField(v_start, 8: 8, 2:2)
347 		| SetBitField(v_blank_s, 8: 8, 3:3)
348 		| SetBit(4)
349 		| SetBitField(v_total, 9: 9, 5:5)
350 		| SetBitField(v_display, 9: 9, 6:6)
351 		| SetBitField(v_start, 9: 9, 7:7);
352 	state->crtc[0x9] = SetBitField(v_blank_s, 9: 9, 5:5)
353 		| SetBit(6)
354 		| ((info->var.vmode & FB_VMODE_DOUBLE) ? 0x80 : 0x00);
355 	state->crtc[0x10] = Set8Bits(v_start);
356 	state->crtc[0x11] = SetBitField(v_end, 3: 0, 3:0) | SetBit(5);
357 	state->crtc[0x12] = Set8Bits(v_display);
358 	state->crtc[0x13] = ((info->var.xres_virtual / 8) *
359 			     (info->var.bits_per_pixel / 8));
360 	state->crtc[0x15] = Set8Bits(v_blank_s);
361 	state->crtc[0x16] = Set8Bits(v_blank_e);
362 
363 	state->attr[0x10] = 0x01;
364 
365 	if (par->Television)
366 		state->attr[0x11] = 0x00;
367 
368 	state->screen = SetBitField(h_blank_e, 6: 6, 4:4)
369 		| SetBitField(v_blank_s, 10: 10, 3:3)
370 		| SetBitField(v_start, 10: 10, 2:2)
371 		| SetBitField(v_display, 10: 10, 1:1)
372 		| SetBitField(v_total, 10: 10, 0:0);
373 
374 	state->horiz = SetBitField(h_total, 8: 8, 0:0)
375 		| SetBitField(h_display, 8: 8, 1:1)
376 		| SetBitField(h_blank_s, 8: 8, 2:2)
377 		| SetBitField(h_start, 8: 8, 3:3);
378 
379 	state->extra = SetBitField(v_total, 11: 11, 0:0)
380 		| SetBitField(v_display, 11: 11, 2:2)
381 		| SetBitField(v_start, 11: 11, 4:4)
382 		| SetBitField(v_blank_s, 11: 11, 6:6);
383 
384 	if (info->var.vmode & FB_VMODE_INTERLACED) {
385 		h_total = (h_total >> 1) & ~1;
386 		state->interlace = Set8Bits(h_total);
387 		state->horiz |= SetBitField(h_total, 8: 8, 4:4);
388 	} else {
389 		state->interlace = 0xff;	/* interlace off */
390 	}
391 
392 	/*
393 	 * Calculate the extended registers.
394 	 */
395 
396 	if (depth < 24)
397 		i = depth;
398 	else
399 		i = 32;
400 
401 	if (par->Architecture >= NV_ARCH_10)
402 		par->CURSOR = (volatile u32 __iomem *)(info->screen_base +
403 						       par->CursorStart);
404 
405 	if (info->var.sync & FB_SYNC_HOR_HIGH_ACT)
406 		state->misc_output &= ~0x40;
407 	else
408 		state->misc_output |= 0x40;
409 	if (info->var.sync & FB_SYNC_VERT_HIGH_ACT)
410 		state->misc_output &= ~0x80;
411 	else
412 		state->misc_output |= 0x80;
413 
414 	NVCalcStateExt(par, state, i, info->var.xres_virtual,
415 		       info->var.xres, info->var.yres_virtual,
416 		       1000000000 / info->var.pixclock, info->var.vmode);
417 
418 	state->scale = NV_RD32(par->PRAMDAC, 0x00000848) & 0xfff000ff;
419 	if (par->FlatPanel == 1) {
420 		state->pixel |= (1 << 7);
421 
422 		if (!par->fpScaler || (par->fpWidth <= info->var.xres)
423 		    || (par->fpHeight <= info->var.yres)) {
424 			state->scale |= (1 << 8);
425 		}
426 
427 		if (!par->crtcSync_read) {
428 			state->crtcSync = NV_RD32(par->PRAMDAC, 0x0828);
429 			par->crtcSync_read = 1;
430 		}
431 
432 		par->PanelTweak = nvidia_panel_tweak(par, state);
433 	}
434 
435 	state->vpll = state->pll;
436 	state->vpll2 = state->pll;
437 	state->vpllB = state->pllB;
438 	state->vpll2B = state->pllB;
439 
440 	VGA_WR08(par->PCIO, 0x03D4, 0x1C);
441 	state->fifo = VGA_RD08(par->PCIO, 0x03D5) & ~(1<<5);
442 
443 	if (par->CRTCnumber) {
444 		state->head = NV_RD32(par->PCRTC0, 0x00000860) & ~0x00001000;
445 		state->head2 = NV_RD32(par->PCRTC0, 0x00002860) | 0x00001000;
446 		state->crtcOwner = 3;
447 		state->pllsel |= 0x20000800;
448 		state->vpll = NV_RD32(par->PRAMDAC0, 0x00000508);
449 		if (par->twoStagePLL)
450 			state->vpllB = NV_RD32(par->PRAMDAC0, 0x00000578);
451 	} else if (par->twoHeads) {
452 		state->head = NV_RD32(par->PCRTC0, 0x00000860) | 0x00001000;
453 		state->head2 = NV_RD32(par->PCRTC0, 0x00002860) & ~0x00001000;
454 		state->crtcOwner = 0;
455 		state->vpll2 = NV_RD32(par->PRAMDAC0, 0x0520);
456 		if (par->twoStagePLL)
457 			state->vpll2B = NV_RD32(par->PRAMDAC0, 0x057C);
458 	}
459 
460 	state->cursorConfig = 0x00000100;
461 
462 	if (info->var.vmode & FB_VMODE_DOUBLE)
463 		state->cursorConfig |= (1 << 4);
464 
465 	if (par->alphaCursor) {
466 		if ((par->Chipset & 0x0ff0) != 0x0110)
467 			state->cursorConfig |= 0x04011000;
468 		else
469 			state->cursorConfig |= 0x14011000;
470 		state->general |= (1 << 29);
471 	} else
472 		state->cursorConfig |= 0x02000000;
473 
474 	if (par->twoHeads) {
475 		if ((par->Chipset & 0x0ff0) == 0x0110) {
476 			state->dither = NV_RD32(par->PRAMDAC, 0x0528) &
477 			    ~0x00010000;
478 			if (par->FPDither)
479 				state->dither |= 0x00010000;
480 		} else {
481 			state->dither = NV_RD32(par->PRAMDAC, 0x083C) & ~1;
482 			if (par->FPDither)
483 				state->dither |= 1;
484 		}
485 	}
486 
487 	state->timingH = 0;
488 	state->timingV = 0;
489 	state->displayV = info->var.xres;
490 
491 	return 0;
492 }
493 
494 static void nvidia_init_vga(struct fb_info *info)
495 {
496 	struct nvidia_par *par = info->par;
497 	struct _riva_hw_state *state = &par->ModeReg;
498 	int i;
499 
500 	for (i = 0; i < 0x10; i++)
501 		state->attr[i] = i;
502 	state->attr[0x10] = 0x41;
503 	state->attr[0x11] = 0xff;
504 	state->attr[0x12] = 0x0f;
505 	state->attr[0x13] = 0x00;
506 	state->attr[0x14] = 0x00;
507 
508 	memset(state->crtc, 0x00, NUM_CRT_REGS);
509 	state->crtc[0x0a] = 0x20;
510 	state->crtc[0x17] = 0xe3;
511 	state->crtc[0x18] = 0xff;
512 	state->crtc[0x28] = 0x40;
513 
514 	memset(state->gra, 0x00, NUM_GRC_REGS);
515 	state->gra[0x05] = 0x40;
516 	state->gra[0x06] = 0x05;
517 	state->gra[0x07] = 0x0f;
518 	state->gra[0x08] = 0xff;
519 
520 	state->seq[0x00] = 0x03;
521 	state->seq[0x01] = 0x01;
522 	state->seq[0x02] = 0x0f;
523 	state->seq[0x03] = 0x00;
524 	state->seq[0x04] = 0x0e;
525 
526 	state->misc_output = 0xeb;
527 }
528 
529 static int nvidiafb_cursor(struct fb_info *info, struct fb_cursor *cursor)
530 {
531 	struct nvidia_par *par = info->par;
532 	u8 data[MAX_CURS * MAX_CURS / 8];
533 	int i, set = cursor->set;
534 	u16 fg, bg;
535 
536 	if (cursor->image.width > MAX_CURS || cursor->image.height > MAX_CURS)
537 		return -ENXIO;
538 
539 	NVShowHideCursor(par, 0);
540 
541 	if (par->cursor_reset) {
542 		set = FB_CUR_SETALL;
543 		par->cursor_reset = 0;
544 	}
545 
546 	if (set & FB_CUR_SETSIZE)
547 		memset_io(par->CURSOR, 0, MAX_CURS * MAX_CURS * 2);
548 
549 	if (set & FB_CUR_SETPOS) {
550 		u32 xx, yy, temp;
551 
552 		yy = cursor->image.dy - info->var.yoffset;
553 		xx = cursor->image.dx - info->var.xoffset;
554 		temp = xx & 0xFFFF;
555 		temp |= yy << 16;
556 
557 		NV_WR32(par->PRAMDAC, 0x0000300, temp);
558 	}
559 
560 	if (set & (FB_CUR_SETSHAPE | FB_CUR_SETCMAP | FB_CUR_SETIMAGE)) {
561 		u32 bg_idx = cursor->image.bg_color;
562 		u32 fg_idx = cursor->image.fg_color;
563 		u32 s_pitch = (cursor->image.width + 7) >> 3;
564 		u32 d_pitch = MAX_CURS / 8;
565 		u8 *dat = (u8 *) cursor->image.data;
566 		u8 *msk = (u8 *) cursor->mask;
567 		u8 *src;
568 
569 		src = kmalloc_array(s_pitch, cursor->image.height, GFP_ATOMIC);
570 
571 		if (src) {
572 			switch (cursor->rop) {
573 			case ROP_XOR:
574 				for (i = 0; i < s_pitch * cursor->image.height; i++)
575 					src[i] = dat[i] ^ msk[i];
576 				break;
577 			case ROP_COPY:
578 			default:
579 				for (i = 0; i < s_pitch * cursor->image.height; i++)
580 					src[i] = dat[i] & msk[i];
581 				break;
582 			}
583 
584 			fb_pad_aligned_buffer(data, d_pitch, src, s_pitch,
585 						cursor->image.height);
586 
587 			bg = ((info->cmap.red[bg_idx] & 0xf8) << 7) |
588 			    ((info->cmap.green[bg_idx] & 0xf8) << 2) |
589 			    ((info->cmap.blue[bg_idx] & 0xf8) >> 3) | 1 << 15;
590 
591 			fg = ((info->cmap.red[fg_idx] & 0xf8) << 7) |
592 			    ((info->cmap.green[fg_idx] & 0xf8) << 2) |
593 			    ((info->cmap.blue[fg_idx] & 0xf8) >> 3) | 1 << 15;
594 
595 			NVLockUnlock(par, 0);
596 
597 			nvidiafb_load_cursor_image(par, data, bg, fg,
598 						   cursor->image.width,
599 						   cursor->image.height);
600 			kfree(src);
601 		}
602 	}
603 
604 	if (cursor->enable)
605 		NVShowHideCursor(par, 1);
606 
607 	return 0;
608 }
609 
610 static struct fb_ops nvidia_fb_ops;
611 
612 static int nvidiafb_set_par(struct fb_info *info)
613 {
614 	struct nvidia_par *par = info->par;
615 
616 	NVTRACE_ENTER();
617 
618 	NVLockUnlock(par, 1);
619 	if (!par->FlatPanel || !par->twoHeads)
620 		par->FPDither = 0;
621 
622 	if (par->FPDither < 0) {
623 		if ((par->Chipset & 0x0ff0) == 0x0110)
624 			par->FPDither = !!(NV_RD32(par->PRAMDAC, 0x0528)
625 					   & 0x00010000);
626 		else
627 			par->FPDither = !!(NV_RD32(par->PRAMDAC, 0x083C) & 1);
628 		printk(KERN_INFO PFX "Flat panel dithering %s\n",
629 		       par->FPDither ? "enabled" : "disabled");
630 	}
631 
632 	info->fix.visual = (info->var.bits_per_pixel == 8) ?
633 	    FB_VISUAL_PSEUDOCOLOR : FB_VISUAL_DIRECTCOLOR;
634 
635 	nvidia_init_vga(info);
636 	nvidia_calc_regs(info);
637 
638 	NVLockUnlock(par, 0);
639 	if (par->twoHeads) {
640 		VGA_WR08(par->PCIO, 0x03D4, 0x44);
641 		VGA_WR08(par->PCIO, 0x03D5, par->ModeReg.crtcOwner);
642 		NVLockUnlock(par, 0);
643 	}
644 
645 	nvidia_screen_off(par, 1);
646 
647 	nvidia_write_regs(par, &par->ModeReg);
648 	NVSetStartAddress(par, 0);
649 
650 #if defined (__BIG_ENDIAN)
651 	/* turn on LFB swapping */
652 	{
653 		unsigned char tmp;
654 
655 		VGA_WR08(par->PCIO, 0x3d4, 0x46);
656 		tmp = VGA_RD08(par->PCIO, 0x3d5);
657 		tmp |= (1 << 7);
658 		VGA_WR08(par->PCIO, 0x3d5, tmp);
659     }
660 #endif
661 
662 	info->fix.line_length = (info->var.xres_virtual *
663 				 info->var.bits_per_pixel) >> 3;
664 	if (info->var.accel_flags) {
665 		nvidia_fb_ops.fb_imageblit = nvidiafb_imageblit;
666 		nvidia_fb_ops.fb_fillrect = nvidiafb_fillrect;
667 		nvidia_fb_ops.fb_copyarea = nvidiafb_copyarea;
668 		nvidia_fb_ops.fb_sync = nvidiafb_sync;
669 		info->pixmap.scan_align = 4;
670 		info->flags &= ~FBINFO_HWACCEL_DISABLED;
671 		info->flags |= FBINFO_READS_FAST;
672 		NVResetGraphics(info);
673 	} else {
674 		nvidia_fb_ops.fb_imageblit = cfb_imageblit;
675 		nvidia_fb_ops.fb_fillrect = cfb_fillrect;
676 		nvidia_fb_ops.fb_copyarea = cfb_copyarea;
677 		nvidia_fb_ops.fb_sync = NULL;
678 		info->pixmap.scan_align = 1;
679 		info->flags |= FBINFO_HWACCEL_DISABLED;
680 		info->flags &= ~FBINFO_READS_FAST;
681 	}
682 
683 	par->cursor_reset = 1;
684 
685 	nvidia_screen_off(par, 0);
686 
687 #ifdef CONFIG_BOOTX_TEXT
688 	/* Update debug text engine */
689 	btext_update_display(info->fix.smem_start,
690 			     info->var.xres, info->var.yres,
691 			     info->var.bits_per_pixel, info->fix.line_length);
692 #endif
693 
694 	NVLockUnlock(par, 0);
695 	NVTRACE_LEAVE();
696 	return 0;
697 }
698 
699 static int nvidiafb_setcolreg(unsigned regno, unsigned red, unsigned green,
700 			      unsigned blue, unsigned transp,
701 			      struct fb_info *info)
702 {
703 	struct nvidia_par *par = info->par;
704 	int i;
705 
706 	NVTRACE_ENTER();
707 	if (regno >= (1 << info->var.green.length))
708 		return -EINVAL;
709 
710 	if (info->var.grayscale) {
711 		/* gray = 0.30*R + 0.59*G + 0.11*B */
712 		red = green = blue = (red * 77 + green * 151 + blue * 28) >> 8;
713 	}
714 
715 	if (regno < 16 && info->fix.visual == FB_VISUAL_DIRECTCOLOR) {
716 		((u32 *) info->pseudo_palette)[regno] =
717 		    (regno << info->var.red.offset) |
718 		    (regno << info->var.green.offset) |
719 		    (regno << info->var.blue.offset);
720 	}
721 
722 	switch (info->var.bits_per_pixel) {
723 	case 8:
724 		/* "transparent" stuff is completely ignored. */
725 		nvidia_write_clut(par, regno, red >> 8, green >> 8, blue >> 8);
726 		break;
727 	case 16:
728 		if (info->var.green.length == 5) {
729 			for (i = 0; i < 8; i++) {
730 				nvidia_write_clut(par, regno * 8 + i, red >> 8,
731 						  green >> 8, blue >> 8);
732 			}
733 		} else {
734 			u8 r, g, b;
735 
736 			if (regno < 32) {
737 				for (i = 0; i < 8; i++) {
738 					nvidia_write_clut(par, regno * 8 + i,
739 							  red >> 8, green >> 8,
740 							  blue >> 8);
741 				}
742 			}
743 
744 			nvidia_read_clut(par, regno * 4, &r, &g, &b);
745 
746 			for (i = 0; i < 4; i++)
747 				nvidia_write_clut(par, regno * 4 + i, r,
748 						  green >> 8, b);
749 		}
750 		break;
751 	case 32:
752 		nvidia_write_clut(par, regno, red >> 8, green >> 8, blue >> 8);
753 		break;
754 	default:
755 		/* do nothing */
756 		break;
757 	}
758 
759 	NVTRACE_LEAVE();
760 	return 0;
761 }
762 
763 static int nvidiafb_check_var(struct fb_var_screeninfo *var,
764 			      struct fb_info *info)
765 {
766 	struct nvidia_par *par = info->par;
767 	int memlen, vramlen, mode_valid = 0;
768 	int pitch, err = 0;
769 
770 	NVTRACE_ENTER();
771 
772 	var->transp.offset = 0;
773 	var->transp.length = 0;
774 
775 	var->xres &= ~7;
776 
777 	if (var->bits_per_pixel <= 8)
778 		var->bits_per_pixel = 8;
779 	else if (var->bits_per_pixel <= 16)
780 		var->bits_per_pixel = 16;
781 	else
782 		var->bits_per_pixel = 32;
783 
784 	switch (var->bits_per_pixel) {
785 	case 8:
786 		var->red.offset = 0;
787 		var->red.length = 8;
788 		var->green.offset = 0;
789 		var->green.length = 8;
790 		var->blue.offset = 0;
791 		var->blue.length = 8;
792 		var->transp.offset = 0;
793 		var->transp.length = 0;
794 		break;
795 	case 16:
796 		var->green.length = (var->green.length < 6) ? 5 : 6;
797 		var->red.length = 5;
798 		var->blue.length = 5;
799 		var->transp.length = 6 - var->green.length;
800 		var->blue.offset = 0;
801 		var->green.offset = 5;
802 		var->red.offset = 5 + var->green.length;
803 		var->transp.offset = (5 + var->red.offset) & 15;
804 		break;
805 	case 32:		/* RGBA 8888 */
806 		var->red.offset = 16;
807 		var->red.length = 8;
808 		var->green.offset = 8;
809 		var->green.length = 8;
810 		var->blue.offset = 0;
811 		var->blue.length = 8;
812 		var->transp.length = 8;
813 		var->transp.offset = 24;
814 		break;
815 	}
816 
817 	var->red.msb_right = 0;
818 	var->green.msb_right = 0;
819 	var->blue.msb_right = 0;
820 	var->transp.msb_right = 0;
821 
822 	if (!info->monspecs.hfmax || !info->monspecs.vfmax ||
823 	    !info->monspecs.dclkmax || !fb_validate_mode(var, info))
824 		mode_valid = 1;
825 
826 	/* calculate modeline if supported by monitor */
827 	if (!mode_valid && info->monspecs.gtf) {
828 		if (!fb_get_mode(FB_MAXTIMINGS, 0, var, info))
829 			mode_valid = 1;
830 	}
831 
832 	if (!mode_valid) {
833 		const struct fb_videomode *mode;
834 
835 		mode = fb_find_best_mode(var, &info->modelist);
836 		if (mode) {
837 			fb_videomode_to_var(var, mode);
838 			mode_valid = 1;
839 		}
840 	}
841 
842 	if (!mode_valid && info->monspecs.modedb_len)
843 		return -EINVAL;
844 
845 	/*
846 	 * If we're on a flat panel, check if the mode is outside of the
847 	 * panel dimensions. If so, cap it and try for the next best mode
848 	 * before bailing out.
849 	 */
850 	if (par->fpWidth && par->fpHeight && (par->fpWidth < var->xres ||
851 					      par->fpHeight < var->yres)) {
852 		const struct fb_videomode *mode;
853 
854 		var->xres = par->fpWidth;
855 		var->yres = par->fpHeight;
856 
857 		mode = fb_find_best_mode(var, &info->modelist);
858 		if (!mode) {
859 			printk(KERN_ERR PFX "mode out of range of flat "
860 			       "panel dimensions\n");
861 			return -EINVAL;
862 		}
863 
864 		fb_videomode_to_var(var, mode);
865 	}
866 
867 	if (var->yres_virtual < var->yres)
868 		var->yres_virtual = var->yres;
869 
870 	if (var->xres_virtual < var->xres)
871 		var->xres_virtual = var->xres;
872 
873 	var->xres_virtual = (var->xres_virtual + 63) & ~63;
874 
875 	vramlen = info->screen_size;
876 	pitch = ((var->xres_virtual * var->bits_per_pixel) + 7) / 8;
877 	memlen = pitch * var->yres_virtual;
878 
879 	if (memlen > vramlen) {
880 		var->yres_virtual = vramlen / pitch;
881 
882 		if (var->yres_virtual < var->yres) {
883 			var->yres_virtual = var->yres;
884 			var->xres_virtual = vramlen / var->yres_virtual;
885 			var->xres_virtual /= var->bits_per_pixel / 8;
886 			var->xres_virtual &= ~63;
887 			pitch = (var->xres_virtual *
888 				 var->bits_per_pixel + 7) / 8;
889 			memlen = pitch * var->yres;
890 
891 			if (var->xres_virtual < var->xres) {
892 				printk("nvidiafb: required video memory, "
893 				       "%d bytes, for %dx%d-%d (virtual) "
894 				       "is out of range\n",
895 				       memlen, var->xres_virtual,
896 				       var->yres_virtual, var->bits_per_pixel);
897 				err = -ENOMEM;
898 			}
899 		}
900 	}
901 
902 	if (var->accel_flags) {
903 		if (var->yres_virtual > 0x7fff)
904 			var->yres_virtual = 0x7fff;
905 		if (var->xres_virtual > 0x7fff)
906 			var->xres_virtual = 0x7fff;
907 	}
908 
909 	var->xres_virtual &= ~63;
910 
911 	NVTRACE_LEAVE();
912 
913 	return err;
914 }
915 
916 static int nvidiafb_pan_display(struct fb_var_screeninfo *var,
917 				struct fb_info *info)
918 {
919 	struct nvidia_par *par = info->par;
920 	u32 total;
921 
922 	total = var->yoffset * info->fix.line_length + var->xoffset;
923 
924 	NVSetStartAddress(par, total);
925 
926 	return 0;
927 }
928 
929 static int nvidiafb_blank(int blank, struct fb_info *info)
930 {
931 	struct nvidia_par *par = info->par;
932 	unsigned char tmp, vesa;
933 
934 	tmp = NVReadSeq(par, 0x01) & ~0x20;	/* screen on/off */
935 	vesa = NVReadCrtc(par, 0x1a) & ~0xc0;	/* sync on/off */
936 
937 	NVTRACE_ENTER();
938 
939 	if (blank)
940 		tmp |= 0x20;
941 
942 	switch (blank) {
943 	case FB_BLANK_UNBLANK:
944 	case FB_BLANK_NORMAL:
945 		break;
946 	case FB_BLANK_VSYNC_SUSPEND:
947 		vesa |= 0x80;
948 		break;
949 	case FB_BLANK_HSYNC_SUSPEND:
950 		vesa |= 0x40;
951 		break;
952 	case FB_BLANK_POWERDOWN:
953 		vesa |= 0xc0;
954 		break;
955 	}
956 
957 	NVWriteSeq(par, 0x01, tmp);
958 	NVWriteCrtc(par, 0x1a, vesa);
959 
960 	NVTRACE_LEAVE();
961 
962 	return 0;
963 }
964 
965 /*
966  * Because the VGA registers are not mapped linearly in its MMIO space,
967  * restrict VGA register saving and restore to x86 only, where legacy VGA IO
968  * access is legal. Consequently, we must also check if the device is the
969  * primary display.
970  */
971 #ifdef CONFIG_X86
972 static void save_vga_x86(struct nvidia_par *par)
973 {
974 	struct resource *res= &par->pci_dev->resource[PCI_ROM_RESOURCE];
975 
976 	if (res && res->flags & IORESOURCE_ROM_SHADOW) {
977 		memset(&par->vgastate, 0, sizeof(par->vgastate));
978 		par->vgastate.flags = VGA_SAVE_MODE | VGA_SAVE_FONTS |
979 			VGA_SAVE_CMAP;
980 		save_vga(&par->vgastate);
981 	}
982 }
983 
984 static void restore_vga_x86(struct nvidia_par *par)
985 {
986 	struct resource *res= &par->pci_dev->resource[PCI_ROM_RESOURCE];
987 
988 	if (res && res->flags & IORESOURCE_ROM_SHADOW)
989 		restore_vga(&par->vgastate);
990 }
991 #else
992 #define save_vga_x86(x) do {} while (0)
993 #define restore_vga_x86(x) do {} while (0)
994 #endif /* X86 */
995 
996 static int nvidiafb_open(struct fb_info *info, int user)
997 {
998 	struct nvidia_par *par = info->par;
999 
1000 	if (!par->open_count) {
1001 		save_vga_x86(par);
1002 		nvidia_save_vga(par, &par->initial_state);
1003 	}
1004 
1005 	par->open_count++;
1006 	return 0;
1007 }
1008 
1009 static int nvidiafb_release(struct fb_info *info, int user)
1010 {
1011 	struct nvidia_par *par = info->par;
1012 	int err = 0;
1013 
1014 	if (!par->open_count) {
1015 		err = -EINVAL;
1016 		goto done;
1017 	}
1018 
1019 	if (par->open_count == 1) {
1020 		nvidia_write_regs(par, &par->initial_state);
1021 		restore_vga_x86(par);
1022 	}
1023 
1024 	par->open_count--;
1025 done:
1026 	return err;
1027 }
1028 
1029 static struct fb_ops nvidia_fb_ops = {
1030 	.owner          = THIS_MODULE,
1031 	.fb_open        = nvidiafb_open,
1032 	.fb_release     = nvidiafb_release,
1033 	.fb_check_var   = nvidiafb_check_var,
1034 	.fb_set_par     = nvidiafb_set_par,
1035 	.fb_setcolreg   = nvidiafb_setcolreg,
1036 	.fb_pan_display = nvidiafb_pan_display,
1037 	.fb_blank       = nvidiafb_blank,
1038 	.fb_fillrect    = nvidiafb_fillrect,
1039 	.fb_copyarea    = nvidiafb_copyarea,
1040 	.fb_imageblit   = nvidiafb_imageblit,
1041 	.fb_cursor      = nvidiafb_cursor,
1042 	.fb_sync        = nvidiafb_sync,
1043 };
1044 
1045 #ifdef CONFIG_PM
1046 static int nvidiafb_suspend(struct pci_dev *dev, pm_message_t mesg)
1047 {
1048 	struct fb_info *info = pci_get_drvdata(dev);
1049 	struct nvidia_par *par = info->par;
1050 
1051 	if (mesg.event == PM_EVENT_PRETHAW)
1052 		mesg.event = PM_EVENT_FREEZE;
1053 	console_lock();
1054 	par->pm_state = mesg.event;
1055 
1056 	if (mesg.event & PM_EVENT_SLEEP) {
1057 		fb_set_suspend(info, 1);
1058 		nvidiafb_blank(FB_BLANK_POWERDOWN, info);
1059 		nvidia_write_regs(par, &par->SavedReg);
1060 		pci_save_state(dev);
1061 		pci_disable_device(dev);
1062 		pci_set_power_state(dev, pci_choose_state(dev, mesg));
1063 	}
1064 	dev->dev.power.power_state = mesg;
1065 
1066 	console_unlock();
1067 	return 0;
1068 }
1069 
1070 static int nvidiafb_resume(struct pci_dev *dev)
1071 {
1072 	struct fb_info *info = pci_get_drvdata(dev);
1073 	struct nvidia_par *par = info->par;
1074 
1075 	console_lock();
1076 	pci_set_power_state(dev, PCI_D0);
1077 
1078 	if (par->pm_state != PM_EVENT_FREEZE) {
1079 		pci_restore_state(dev);
1080 
1081 		if (pci_enable_device(dev))
1082 			goto fail;
1083 
1084 		pci_set_master(dev);
1085 	}
1086 
1087 	par->pm_state = PM_EVENT_ON;
1088 	nvidiafb_set_par(info);
1089 	fb_set_suspend (info, 0);
1090 	nvidiafb_blank(FB_BLANK_UNBLANK, info);
1091 
1092 fail:
1093 	console_unlock();
1094 	return 0;
1095 }
1096 #else
1097 #define nvidiafb_suspend NULL
1098 #define nvidiafb_resume NULL
1099 #endif
1100 
1101 static int nvidia_set_fbinfo(struct fb_info *info)
1102 {
1103 	struct fb_monspecs *specs = &info->monspecs;
1104 	struct fb_videomode modedb;
1105 	struct nvidia_par *par = info->par;
1106 	int lpitch;
1107 
1108 	NVTRACE_ENTER();
1109 	info->flags = FBINFO_DEFAULT
1110 	    | FBINFO_HWACCEL_IMAGEBLIT
1111 	    | FBINFO_HWACCEL_FILLRECT
1112 	    | FBINFO_HWACCEL_COPYAREA
1113 	    | FBINFO_HWACCEL_YPAN;
1114 
1115 	fb_videomode_to_modelist(info->monspecs.modedb,
1116 				 info->monspecs.modedb_len, &info->modelist);
1117 	fb_var_to_videomode(&modedb, &nvidiafb_default_var);
1118 
1119 	switch (bpp) {
1120 	case 0 ... 8:
1121 		bpp = 8;
1122 		break;
1123 	case 9 ... 16:
1124 		bpp = 16;
1125 		break;
1126 	default:
1127 		bpp = 32;
1128 		break;
1129 	}
1130 
1131 	if (specs->modedb != NULL) {
1132 		const struct fb_videomode *mode;
1133 
1134 		mode = fb_find_best_display(specs, &info->modelist);
1135 		fb_videomode_to_var(&nvidiafb_default_var, mode);
1136 		nvidiafb_default_var.bits_per_pixel = bpp;
1137 	} else if (par->fpWidth && par->fpHeight) {
1138 		char buf[16];
1139 
1140 		memset(buf, 0, 16);
1141 		snprintf(buf, 15, "%dx%dMR", par->fpWidth, par->fpHeight);
1142 		fb_find_mode(&nvidiafb_default_var, info, buf, specs->modedb,
1143 			     specs->modedb_len, &modedb, bpp);
1144 	}
1145 
1146 	if (mode_option)
1147 		fb_find_mode(&nvidiafb_default_var, info, mode_option,
1148 			     specs->modedb, specs->modedb_len, &modedb, bpp);
1149 
1150 	info->var = nvidiafb_default_var;
1151 	info->fix.visual = (info->var.bits_per_pixel == 8) ?
1152 		FB_VISUAL_PSEUDOCOLOR : FB_VISUAL_DIRECTCOLOR;
1153 	info->pseudo_palette = par->pseudo_palette;
1154 	fb_alloc_cmap(&info->cmap, 256, 0);
1155 	fb_destroy_modedb(info->monspecs.modedb);
1156 	info->monspecs.modedb = NULL;
1157 
1158 	/* maximize virtual vertical length */
1159 	lpitch = info->var.xres_virtual *
1160 		((info->var.bits_per_pixel + 7) >> 3);
1161 	info->var.yres_virtual = info->screen_size / lpitch;
1162 
1163 	info->pixmap.scan_align = 4;
1164 	info->pixmap.buf_align = 4;
1165 	info->pixmap.access_align = 32;
1166 	info->pixmap.size = 8 * 1024;
1167 	info->pixmap.flags = FB_PIXMAP_SYSTEM;
1168 
1169 	if (!hwcur)
1170 	    nvidia_fb_ops.fb_cursor = NULL;
1171 
1172 	info->var.accel_flags = (!noaccel);
1173 
1174 	switch (par->Architecture) {
1175 	case NV_ARCH_04:
1176 		info->fix.accel = FB_ACCEL_NV4;
1177 		break;
1178 	case NV_ARCH_10:
1179 		info->fix.accel = FB_ACCEL_NV_10;
1180 		break;
1181 	case NV_ARCH_20:
1182 		info->fix.accel = FB_ACCEL_NV_20;
1183 		break;
1184 	case NV_ARCH_30:
1185 		info->fix.accel = FB_ACCEL_NV_30;
1186 		break;
1187 	case NV_ARCH_40:
1188 		info->fix.accel = FB_ACCEL_NV_40;
1189 		break;
1190 	}
1191 
1192 	NVTRACE_LEAVE();
1193 
1194 	return nvidiafb_check_var(&info->var, info);
1195 }
1196 
1197 static u32 nvidia_get_chipset(struct fb_info *info)
1198 {
1199 	struct nvidia_par *par = info->par;
1200 	u32 id = (par->pci_dev->vendor << 16) | par->pci_dev->device;
1201 
1202 	printk(KERN_INFO PFX "Device ID: %x \n", id);
1203 
1204 	if ((id & 0xfff0) == 0x00f0 ||
1205 	    (id & 0xfff0) == 0x02e0) {
1206 		/* pci-e */
1207 		id = NV_RD32(par->REGS, 0x1800);
1208 
1209 		if ((id & 0x0000ffff) == 0x000010DE)
1210 			id = 0x10DE0000 | (id >> 16);
1211 		else if ((id & 0xffff0000) == 0xDE100000) /* wrong endian */
1212 			id = 0x10DE0000 | ((id << 8) & 0x0000ff00) |
1213                             ((id >> 8) & 0x000000ff);
1214 		printk(KERN_INFO PFX "Subsystem ID: %x \n", id);
1215 	}
1216 
1217 	return id;
1218 }
1219 
1220 static u32 nvidia_get_arch(struct fb_info *info)
1221 {
1222 	struct nvidia_par *par = info->par;
1223 	u32 arch = 0;
1224 
1225 	switch (par->Chipset & 0x0ff0) {
1226 	case 0x0100:		/* GeForce 256 */
1227 	case 0x0110:		/* GeForce2 MX */
1228 	case 0x0150:		/* GeForce2 */
1229 	case 0x0170:		/* GeForce4 MX */
1230 	case 0x0180:		/* GeForce4 MX (8x AGP) */
1231 	case 0x01A0:		/* nForce */
1232 	case 0x01F0:		/* nForce2 */
1233 		arch = NV_ARCH_10;
1234 		break;
1235 	case 0x0200:		/* GeForce3 */
1236 	case 0x0250:		/* GeForce4 Ti */
1237 	case 0x0280:		/* GeForce4 Ti (8x AGP) */
1238 		arch = NV_ARCH_20;
1239 		break;
1240 	case 0x0300:		/* GeForceFX 5800 */
1241 	case 0x0310:		/* GeForceFX 5600 */
1242 	case 0x0320:		/* GeForceFX 5200 */
1243 	case 0x0330:		/* GeForceFX 5900 */
1244 	case 0x0340:		/* GeForceFX 5700 */
1245 		arch = NV_ARCH_30;
1246 		break;
1247 	case 0x0040:		/* GeForce 6800 */
1248 	case 0x00C0:		/* GeForce 6800 */
1249 	case 0x0120:		/* GeForce 6800 */
1250 	case 0x0140:		/* GeForce 6600 */
1251 	case 0x0160:		/* GeForce 6200 */
1252 	case 0x01D0:		/* GeForce 7200, 7300, 7400 */
1253 	case 0x0090:		/* GeForce 7800 */
1254 	case 0x0210:		/* GeForce 6800 */
1255 	case 0x0220:		/* GeForce 6200 */
1256 	case 0x0240:		/* GeForce 6100 */
1257 	case 0x0290:		/* GeForce 7900 */
1258 	case 0x0390:		/* GeForce 7600 */
1259 	case 0x03D0:
1260 		arch = NV_ARCH_40;
1261 		break;
1262 	case 0x0020:		/* TNT, TNT2 */
1263 		arch = NV_ARCH_04;
1264 		break;
1265 	default:		/* unknown architecture */
1266 		break;
1267 	}
1268 
1269 	return arch;
1270 }
1271 
1272 static int nvidiafb_probe(struct pci_dev *pd, const struct pci_device_id *ent)
1273 {
1274 	struct nvidia_par *par;
1275 	struct fb_info *info;
1276 	unsigned short cmd;
1277 
1278 
1279 	NVTRACE_ENTER();
1280 	assert(pd != NULL);
1281 
1282 	info = framebuffer_alloc(sizeof(struct nvidia_par), &pd->dev);
1283 
1284 	if (!info)
1285 		goto err_out;
1286 
1287 	par = info->par;
1288 	par->pci_dev = pd;
1289 	info->pixmap.addr = kzalloc(8 * 1024, GFP_KERNEL);
1290 
1291 	if (info->pixmap.addr == NULL)
1292 		goto err_out_kfree;
1293 
1294 	if (pci_enable_device(pd)) {
1295 		printk(KERN_ERR PFX "cannot enable PCI device\n");
1296 		goto err_out_enable;
1297 	}
1298 
1299 	if (pci_request_regions(pd, "nvidiafb")) {
1300 		printk(KERN_ERR PFX "cannot request PCI regions\n");
1301 		goto err_out_enable;
1302 	}
1303 
1304 	par->FlatPanel = flatpanel;
1305 	if (flatpanel == 1)
1306 		printk(KERN_INFO PFX "flatpanel support enabled\n");
1307 	par->FPDither = fpdither;
1308 
1309 	par->CRTCnumber = forceCRTC;
1310 	par->FpScale = (!noscale);
1311 	par->paneltweak = paneltweak;
1312 	par->reverse_i2c = reverse_i2c;
1313 
1314 	/* enable IO and mem if not already done */
1315 	pci_read_config_word(pd, PCI_COMMAND, &cmd);
1316 	cmd |= (PCI_COMMAND_IO | PCI_COMMAND_MEMORY);
1317 	pci_write_config_word(pd, PCI_COMMAND, cmd);
1318 
1319 	nvidiafb_fix.mmio_start = pci_resource_start(pd, 0);
1320 	nvidiafb_fix.smem_start = pci_resource_start(pd, 1);
1321 	nvidiafb_fix.mmio_len = pci_resource_len(pd, 0);
1322 
1323 	par->REGS = ioremap(nvidiafb_fix.mmio_start, nvidiafb_fix.mmio_len);
1324 
1325 	if (!par->REGS) {
1326 		printk(KERN_ERR PFX "cannot ioremap MMIO base\n");
1327 		goto err_out_free_base0;
1328 	}
1329 
1330 	par->Chipset = nvidia_get_chipset(info);
1331 	par->Architecture = nvidia_get_arch(info);
1332 
1333 	if (par->Architecture == 0) {
1334 		printk(KERN_ERR PFX "unknown NV_ARCH\n");
1335 		goto err_out_arch;
1336 	}
1337 
1338 	sprintf(nvidiafb_fix.id, "NV%x", (pd->device & 0x0ff0) >> 4);
1339 
1340 	if (NVCommonSetup(info))
1341 		goto err_out_arch;
1342 
1343 	par->FbAddress = nvidiafb_fix.smem_start;
1344 	par->FbMapSize = par->RamAmountKBytes * 1024;
1345 	if (vram && vram * 1024 * 1024 < par->FbMapSize)
1346 		par->FbMapSize = vram * 1024 * 1024;
1347 
1348 	/* Limit amount of vram to 64 MB */
1349 	if (par->FbMapSize > 64 * 1024 * 1024)
1350 		par->FbMapSize = 64 * 1024 * 1024;
1351 
1352 	if(par->Architecture >= NV_ARCH_40)
1353   	        par->FbUsableSize = par->FbMapSize - (560 * 1024);
1354 	else
1355 		par->FbUsableSize = par->FbMapSize - (128 * 1024);
1356 	par->ScratchBufferSize = (par->Architecture < NV_ARCH_10) ? 8 * 1024 :
1357 	    16 * 1024;
1358 	par->ScratchBufferStart = par->FbUsableSize - par->ScratchBufferSize;
1359 	par->CursorStart = par->FbUsableSize + (32 * 1024);
1360 
1361 	info->screen_base = ioremap_wc(nvidiafb_fix.smem_start,
1362 				       par->FbMapSize);
1363 	info->screen_size = par->FbUsableSize;
1364 	nvidiafb_fix.smem_len = par->RamAmountKBytes * 1024;
1365 
1366 	if (!info->screen_base) {
1367 		printk(KERN_ERR PFX "cannot ioremap FB base\n");
1368 		goto err_out_free_base1;
1369 	}
1370 
1371 	par->FbStart = info->screen_base;
1372 
1373 	if (!nomtrr)
1374 		par->wc_cookie = arch_phys_wc_add(nvidiafb_fix.smem_start,
1375 						  par->RamAmountKBytes * 1024);
1376 
1377 	info->fbops = &nvidia_fb_ops;
1378 	info->fix = nvidiafb_fix;
1379 
1380 	if (nvidia_set_fbinfo(info) < 0) {
1381 		printk(KERN_ERR PFX "error setting initial video mode\n");
1382 		goto err_out_iounmap_fb;
1383 	}
1384 
1385 	nvidia_save_vga(par, &par->SavedReg);
1386 
1387 	pci_set_drvdata(pd, info);
1388 
1389 	if (backlight)
1390 		nvidia_bl_init(par);
1391 
1392 	if (register_framebuffer(info) < 0) {
1393 		printk(KERN_ERR PFX "error registering nVidia framebuffer\n");
1394 		goto err_out_iounmap_fb;
1395 	}
1396 
1397 
1398 	printk(KERN_INFO PFX
1399 	       "PCI nVidia %s framebuffer (%dMB @ 0x%lX)\n",
1400 	       info->fix.id,
1401 	       par->FbMapSize / (1024 * 1024), info->fix.smem_start);
1402 
1403 	NVTRACE_LEAVE();
1404 	return 0;
1405 
1406 err_out_iounmap_fb:
1407 	iounmap(info->screen_base);
1408 err_out_free_base1:
1409 	fb_destroy_modedb(info->monspecs.modedb);
1410 	nvidia_delete_i2c_busses(par);
1411 err_out_arch:
1412 	iounmap(par->REGS);
1413  err_out_free_base0:
1414 	pci_release_regions(pd);
1415 err_out_enable:
1416 	kfree(info->pixmap.addr);
1417 err_out_kfree:
1418 	framebuffer_release(info);
1419 err_out:
1420 	return -ENODEV;
1421 }
1422 
1423 static void nvidiafb_remove(struct pci_dev *pd)
1424 {
1425 	struct fb_info *info = pci_get_drvdata(pd);
1426 	struct nvidia_par *par = info->par;
1427 
1428 	NVTRACE_ENTER();
1429 
1430 	unregister_framebuffer(info);
1431 
1432 	nvidia_bl_exit(par);
1433 	arch_phys_wc_del(par->wc_cookie);
1434 	iounmap(info->screen_base);
1435 	fb_destroy_modedb(info->monspecs.modedb);
1436 	nvidia_delete_i2c_busses(par);
1437 	iounmap(par->REGS);
1438 	pci_release_regions(pd);
1439 	kfree(info->pixmap.addr);
1440 	framebuffer_release(info);
1441 	NVTRACE_LEAVE();
1442 }
1443 
1444 /* ------------------------------------------------------------------------- *
1445  *
1446  * initialization
1447  *
1448  * ------------------------------------------------------------------------- */
1449 
1450 #ifndef MODULE
1451 static int nvidiafb_setup(char *options)
1452 {
1453 	char *this_opt;
1454 
1455 	NVTRACE_ENTER();
1456 	if (!options || !*options)
1457 		return 0;
1458 
1459 	while ((this_opt = strsep(&options, ",")) != NULL) {
1460 		if (!strncmp(this_opt, "forceCRTC", 9)) {
1461 			char *p;
1462 
1463 			p = this_opt + 9;
1464 			if (!*p || !*(++p))
1465 				continue;
1466 			forceCRTC = *p - '0';
1467 			if (forceCRTC < 0 || forceCRTC > 1)
1468 				forceCRTC = -1;
1469 		} else if (!strncmp(this_opt, "flatpanel", 9)) {
1470 			flatpanel = 1;
1471 		} else if (!strncmp(this_opt, "hwcur", 5)) {
1472 			hwcur = 1;
1473 		} else if (!strncmp(this_opt, "noaccel", 6)) {
1474 			noaccel = 1;
1475 		} else if (!strncmp(this_opt, "noscale", 7)) {
1476 			noscale = 1;
1477 		} else if (!strncmp(this_opt, "reverse_i2c", 11)) {
1478 			reverse_i2c = 1;
1479 		} else if (!strncmp(this_opt, "paneltweak:", 11)) {
1480 			paneltweak = simple_strtoul(this_opt+11, NULL, 0);
1481 		} else if (!strncmp(this_opt, "vram:", 5)) {
1482 			vram = simple_strtoul(this_opt+5, NULL, 0);
1483 		} else if (!strncmp(this_opt, "backlight:", 10)) {
1484 			backlight = simple_strtoul(this_opt+10, NULL, 0);
1485 		} else if (!strncmp(this_opt, "nomtrr", 6)) {
1486 			nomtrr = true;
1487 		} else if (!strncmp(this_opt, "fpdither:", 9)) {
1488 			fpdither = simple_strtol(this_opt+9, NULL, 0);
1489 		} else if (!strncmp(this_opt, "bpp:", 4)) {
1490 			bpp = simple_strtoul(this_opt+4, NULL, 0);
1491 		} else
1492 			mode_option = this_opt;
1493 	}
1494 	NVTRACE_LEAVE();
1495 	return 0;
1496 }
1497 #endif				/* !MODULE */
1498 
1499 static struct pci_driver nvidiafb_driver = {
1500 	.name = "nvidiafb",
1501 	.id_table = nvidiafb_pci_tbl,
1502 	.probe    = nvidiafb_probe,
1503 	.suspend  = nvidiafb_suspend,
1504 	.resume   = nvidiafb_resume,
1505 	.remove   = nvidiafb_remove,
1506 };
1507 
1508 /* ------------------------------------------------------------------------- *
1509  *
1510  * modularization
1511  *
1512  * ------------------------------------------------------------------------- */
1513 
1514 static int nvidiafb_init(void)
1515 {
1516 #ifndef MODULE
1517 	char *option = NULL;
1518 
1519 	if (fb_get_options("nvidiafb", &option))
1520 		return -ENODEV;
1521 	nvidiafb_setup(option);
1522 #endif
1523 	return pci_register_driver(&nvidiafb_driver);
1524 }
1525 
1526 module_init(nvidiafb_init);
1527 
1528 static void __exit nvidiafb_exit(void)
1529 {
1530 	pci_unregister_driver(&nvidiafb_driver);
1531 }
1532 
1533 module_exit(nvidiafb_exit);
1534 
1535 module_param(flatpanel, int, 0);
1536 MODULE_PARM_DESC(flatpanel,
1537 		 "Enables experimental flat panel support for some chipsets. "
1538 		 "(0=disabled, 1=enabled, -1=autodetect) (default=-1)");
1539 module_param(fpdither, int, 0);
1540 MODULE_PARM_DESC(fpdither,
1541 		 "Enables dithering of flat panel for 6 bits panels. "
1542 		 "(0=disabled, 1=enabled, -1=autodetect) (default=-1)");
1543 module_param(hwcur, int, 0);
1544 MODULE_PARM_DESC(hwcur,
1545 		 "Enables hardware cursor implementation. (0 or 1=enabled) "
1546 		 "(default=0)");
1547 module_param(noaccel, int, 0);
1548 MODULE_PARM_DESC(noaccel,
1549 		 "Disables hardware acceleration. (0 or 1=disable) "
1550 		 "(default=0)");
1551 module_param(noscale, int, 0);
1552 MODULE_PARM_DESC(noscale,
1553 		 "Disables screen scaling. (0 or 1=disable) "
1554 		 "(default=0, do scaling)");
1555 module_param(paneltweak, int, 0);
1556 MODULE_PARM_DESC(paneltweak,
1557 		 "Tweak display settings for flatpanels. "
1558 		 "(default=0, no tweaks)");
1559 module_param(forceCRTC, int, 0);
1560 MODULE_PARM_DESC(forceCRTC,
1561 		 "Forces usage of a particular CRTC in case autodetection "
1562 		 "fails. (0 or 1) (default=autodetect)");
1563 module_param(vram, int, 0);
1564 MODULE_PARM_DESC(vram,
1565 		 "amount of framebuffer memory to remap in MiB"
1566 		 "(default=0 - remap entire memory)");
1567 module_param(mode_option, charp, 0);
1568 MODULE_PARM_DESC(mode_option, "Specify initial video mode");
1569 module_param(bpp, int, 0);
1570 MODULE_PARM_DESC(bpp, "pixel width in bits"
1571 		 "(default=8)");
1572 module_param(reverse_i2c, int, 0);
1573 MODULE_PARM_DESC(reverse_i2c, "reverse port assignment of the i2c bus");
1574 module_param(nomtrr, bool, false);
1575 MODULE_PARM_DESC(nomtrr, "Disables MTRR support (0 or 1=disabled) "
1576 		 "(default=0)");
1577 
1578 MODULE_AUTHOR("Antonino Daplas");
1579 MODULE_DESCRIPTION("Framebuffer driver for nVidia graphics chipset");
1580 MODULE_LICENSE("GPL");
1581