279 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			279 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
Intel 810/815 Framebuffer driver
 | 
						|
 	Tony Daplas <adaplas@pol.net>
 | 
						|
	http://i810fb.sourceforge.net
 | 
						|
 | 
						|
	March 17, 2002
 | 
						|
 | 
						|
	First Released: July 2001
 | 
						|
	Last Update:    September 12, 2005
 | 
						|
================================================================
 | 
						|
 | 
						|
A. Introduction
 | 
						|
 | 
						|
	This is a framebuffer driver for various Intel 810/815 compatible
 | 
						|
	graphics devices.  These include:
 | 
						|
 | 
						|
	Intel 810
 | 
						|
	Intel 810E
 | 
						|
	Intel 810-DC100
 | 
						|
	Intel 815 Internal graphics only, 100Mhz FSB
 | 
						|
	Intel 815 Internal graphics only
 | 
						|
	Intel 815 Internal graphics and AGP
 | 
						|
 | 
						|
B.  Features
 | 
						|
 | 
						|
	- Choice of using Discrete Video Timings, VESA Generalized Timing
 | 
						|
	  Formula, or a framebuffer specific database to set the video mode
 | 
						|
 | 
						|
	- Supports a variable range of horizontal and vertical resolution and
 | 
						|
	  vertical refresh rates if the VESA Generalized Timing Formula is
 | 
						|
	  enabled.
 | 
						|
 | 
						|
	- Supports color depths of 8, 16, 24 and 32 bits per pixel
 | 
						|
 | 
						|
	- Supports pseudocolor, directcolor, or truecolor visuals
 | 
						|
 | 
						|
	- Full and optimized hardware acceleration at 8, 16 and 24 bpp
 | 
						|
 | 
						|
	- Robust video state save and restore
 | 
						|
 | 
						|
	- MTRR support
 | 
						|
 | 
						|
	- Utilizes user-entered monitor specifications to automatically
 | 
						|
	  calculate required video mode parameters.
 | 
						|
 | 
						|
	- Can concurrently run with xfree86 running with native i810 drivers
 | 
						|
 | 
						|
	- Hardware Cursor Support
 | 
						|
 
 | 
						|
	- Supports EDID probing either by DDC/I2C or through the BIOS
 | 
						|
 | 
						|
C.  List of available options
 | 
						|
 | 
						|
   a. "video=i810fb"
 | 
						|
	enables the i810 driver
 | 
						|
 | 
						|
	Recommendation: required
 | 
						|
 | 
						|
   b. "xres:<value>"
 | 
						|
	select horizontal resolution in pixels. (This parameter will be
 | 
						|
	ignored if 'mode_option' is specified.  See 'o' below).
 | 
						|
 | 
						|
	Recommendation: user preference
 | 
						|
	(default = 640)
 | 
						|
 | 
						|
   c. "yres:<value>"
 | 
						|
	select vertical resolution in scanlines. If Discrete Video Timings
 | 
						|
	is enabled, this will be ignored and computed as 3*xres/4.  (This
 | 
						|
	parameter will be ignored if 'mode_option' is specified.  See 'o'
 | 
						|
	below)
 | 
						|
 | 
						|
	Recommendation: user preference
 | 
						|
	(default = 480)
 | 
						|
 | 
						|
   d. "vyres:<value>"
 | 
						|
	select virtual vertical resolution in scanlines. If (0) or none
 | 
						|
	is specified, this will be computed against maximum available memory.
 | 
						|
 | 
						|
	Recommendation: do not set
 | 
						|
	(default = 480)
 | 
						|
 | 
						|
   e. "vram:<value>"
 | 
						|
	select amount of system RAM in MB to allocate for the video memory
 | 
						|
 | 
						|
	Recommendation: 1 - 4 MB.
 | 
						|
	(default = 4)
 | 
						|
 | 
						|
   f. "bpp:<value>"
 | 
						|
	select desired pixel depth
 | 
						|
 | 
						|
	Recommendation: 8
 | 
						|
	(default = 8)
 | 
						|
 | 
						|
   g. "hsync1/hsync2:<value>"
 | 
						|
	select the minimum and maximum Horizontal Sync Frequency of the
 | 
						|
	monitor in kHz.  If using a fixed frequency monitor, hsync1 must
 | 
						|
	be equal to hsync2. If EDID probing is successful, these will be
 | 
						|
	ignored and values will be taken from the EDID block.
 | 
						|
 | 
						|
	Recommendation: check monitor manual for correct values
 | 
						|
	(default = 29/30)
 | 
						|
 | 
						|
   h. "vsync1/vsync2:<value>"
 | 
						|
	select the minimum and maximum Vertical Sync Frequency of the monitor
 | 
						|
	in Hz. You can also use this option to lock your monitor's refresh
 | 
						|
	rate. If EDID probing is successful, these will be ignored and values
 | 
						|
	will be taken from the EDID block.
 | 
						|
 | 
						|
	Recommendation: check monitor manual for correct values
 | 
						|
	(default = 60/60)
 | 
						|
 | 
						|
	IMPORTANT:  If you need to clamp your timings, try to give some
 | 
						|
	leeway for computational errors (over/underflows).  Example: if
 | 
						|
	using vsync1/vsync2 = 60/60, make sure hsync1/hsync2 has at least
 | 
						|
	a 1 unit difference, and vice versa.
 | 
						|
 | 
						|
   i. "voffset:<value>"
 | 
						|
	select at what offset in MB of the logical memory to allocate the
 | 
						|
	framebuffer memory.  The intent is to avoid the memory blocks
 | 
						|
	used by standard graphics applications (XFree86).  The default
 | 
						|
	offset (16 MB for a 64 MB aperture, 8 MB for a 32 MB aperture) will
 | 
						|
	avoid XFree86's usage and allows up to 7 MB/15 MB of framebuffer
 | 
						|
	memory.  Depending on your usage, adjust the value up or down
 | 
						|
	(0 for maximum usage, 31/63 MB for the least amount).  Note, an
 | 
						|
	arbitrary setting may conflict with XFree86.
 | 
						|
 | 
						|
	Recommendation: do not set
 | 
						|
	(default = 8 or 16 MB)
 | 
						|
 | 
						|
   j. "accel"
 | 
						|
	enable text acceleration.  This can be enabled/reenabled anytime
 | 
						|
	by using 'fbset -accel true/false'.
 | 
						|
 | 
						|
	Recommendation: enable
 | 
						|
	(default = not set)
 | 
						|
 | 
						|
   k. "mtrr"
 | 
						|
	enable MTRR.  This allows data transfers to the framebuffer memory
 | 
						|
	to occur in bursts which can significantly increase performance.
 | 
						|
	Not very helpful with the i810/i815 because of 'shared memory'.
 | 
						|
 | 
						|
	Recommendation: do not set
 | 
						|
	(default = not set)
 | 
						|
 | 
						|
   l. "extvga"
 | 
						|
	if specified, secondary/external VGA output will always be enabled.
 | 
						|
	Useful if the BIOS turns off the VGA port when no monitor is attached.
 | 
						|
	The external VGA monitor can then be attached without rebooting.
 | 
						|
 | 
						|
	Recommendation: do not set
 | 
						|
	(default = not set)
 | 
						|
 | 
						|
   m. "sync"
 | 
						|
	Forces the hardware engine to do a "sync" or wait for the hardware
 | 
						|
	to finish before starting another instruction. This will produce a
 | 
						|
	more stable setup, but will be slower.
 | 
						|
 | 
						|
	Recommendation: do not set
 | 
						|
	(default = not set)
 | 
						|
 | 
						|
   n. "dcolor"
 | 
						|
        Use directcolor visual instead of truecolor for pixel depths greater
 | 
						|
	than 8 bpp.  Useful for color tuning, such as gamma control.
 | 
						|
 | 
						|
	Recommendation: do not set
 | 
						|
	(default = not set)
 | 
						|
 | 
						|
   o. <xres>x<yres>[-<bpp>][@<refresh>]
 | 
						|
	The driver will now accept specification of boot mode option.  If this
 | 
						|
	is specified, the options 'xres' and 'yres' will be ignored. See
 | 
						|
	Documentation/fb/modedb.txt for usage.
 | 
						|
 | 
						|
D. Kernel booting
 | 
						|
 | 
						|
Separate each option/option-pair by commas (,) and the option from its value
 | 
						|
with a colon (:) as in the following:
 | 
						|
 | 
						|
video=i810fb:option1,option2:value2
 | 
						|
 | 
						|
Sample Usage
 | 
						|
------------
 | 
						|
 | 
						|
In /etc/lilo.conf, add the line:
 | 
						|
 | 
						|
append="video=i810fb:vram:2,xres:1024,yres:768,bpp:8,hsync1:30,hsync2:55, \
 | 
						|
        vsync1:50,vsync2:85,accel,mtrr"
 | 
						|
 | 
						|
This will initialize the framebuffer to 1024x768 at 8bpp.  The framebuffer
 | 
						|
will use 2 MB of System RAM. MTRR support will be enabled. The refresh rate
 | 
						|
will be computed based on the hsync1/hsync2 and vsync1/vsync2 values.
 | 
						|
 | 
						|
IMPORTANT:
 | 
						|
You must include hsync1, hsync2, vsync1 and vsync2 to enable video modes
 | 
						|
better than 640x480 at 60Hz. HOWEVER, if your chipset/display combination
 | 
						|
supports I2C and has an EDID block, you can safely exclude hsync1, hsync2,
 | 
						|
vsync1 and vsync2 parameters.  These parameters will be taken from the EDID
 | 
						|
block.
 | 
						|
 | 
						|
E.  Module options
 | 
						|
 | 
						|
The module parameters are essentially similar to the kernel
 | 
						|
parameters. The main difference is that you need to include a Boolean value
 | 
						|
(1 for TRUE, and 0 for FALSE) for those options which don't need a value.
 | 
						|
 | 
						|
Example, to enable MTRR, include "mtrr=1".
 | 
						|
 | 
						|
Sample Usage
 | 
						|
------------
 | 
						|
 | 
						|
Using the same setup as described above, load the module like this:
 | 
						|
 | 
						|
	modprobe i810fb vram=2 xres=1024 bpp=8 hsync1=30 hsync2=55 vsync1=50 \
 | 
						|
	         vsync2=85 accel=1 mtrr=1
 | 
						|
 | 
						|
Or just add the following to a configuration file in /etc/modprobe.d/
 | 
						|
 | 
						|
	options i810fb vram=2 xres=1024 bpp=16 hsync1=30 hsync2=55 vsync1=50 \
 | 
						|
	vsync2=85 accel=1 mtrr=1
 | 
						|
 | 
						|
and just do a
 | 
						|
 | 
						|
	modprobe i810fb
 | 
						|
 | 
						|
 | 
						|
F.  Setup
 | 
						|
 | 
						|
	a. Do your usual method of configuring the kernel.
 | 
						|
 | 
						|
	make menuconfig/xconfig/config
 | 
						|
 | 
						|
	b. Under "Code maturity level options" enable "Prompt for development
 | 
						|
	   and/or incomplete code/drivers".
 | 
						|
 | 
						|
 	c. Enable agpgart support for the Intel 810/815 on-board graphics.
 | 
						|
	   This is required.  The option is under "Character Devices".
 | 
						|
 | 
						|
	d. Under "Graphics Support", select "Intel 810/815" either statically
 | 
						|
	   or as a module.  Choose "use VESA Generalized Timing Formula" if
 | 
						|
	   you need to maximize the capability of your display.  To be on the
 | 
						|
	   safe side, you can leave this unselected.
 | 
						|
 | 
						|
	e. If you want support for DDC/I2C probing (Plug and Play Displays),
 | 
						|
	   set 'Enable DDC Support' to 'y'. To make this option appear, set
 | 
						|
	   'use VESA Generalized Timing Formula' to 'y'.
 | 
						|
 | 
						|
        f. If you want a framebuffer console, enable it under "Console
 | 
						|
	   Drivers".
 | 
						|
 | 
						|
	g. Compile your kernel.
 | 
						|
 | 
						|
	h. Load the driver as described in sections D and E.
 | 
						|
 | 
						|
	i.  Try the DirectFB (http://www.directfb.org) + the i810 gfxdriver
 | 
						|
	    patch to see the chipset in action (or inaction :-).
 | 
						|
 | 
						|
G.  Acknowledgment:
 | 
						|
 | 
						|
	1.  Geert Uytterhoeven - his excellent howto and the virtual
 | 
						|
	    framebuffer driver code made this possible.
 | 
						|
 | 
						|
	2.  Jeff Hartmann for his agpgart code.
 | 
						|
 | 
						|
	3.  The X developers.  Insights were provided just by reading the
 | 
						|
	    XFree86 source code.
 | 
						|
 | 
						|
	4.  Intel(c).  For this value-oriented chipset driver and for
 | 
						|
	    providing documentation.
 | 
						|
 | 
						|
	5. Matt Sottek.  His inputs and ideas  helped in making some
 | 
						|
	   optimizations possible.
 | 
						|
 | 
						|
H.  Home Page:
 | 
						|
 | 
						|
	A more complete, and probably updated information is provided at
 | 
						|
	http://i810fb.sourceforge.net.
 | 
						|
 | 
						|
###########################
 | 
						|
Tony
 | 
						|
 |