summaryrefslogtreecommitdiff
path: root/README.mach64
diff options
context:
space:
mode:
authorLuc Verhaegen <libv@skynet.be>2006-03-11 01:39:04 +0000
committerLuc Verhaegen <libv@skynet.be>2006-03-11 01:39:04 +0000
commit08a92053c32255e1a71cbeb59c2ef510095d23f1 (patch)
tree64dd25e699d3a1c8abf17d7b3ad7b54215530ba6 /README.mach64
parentc60d9966f4596db0fcc85684b7fb4555761a74a9 (diff)
Move from ati to mach64. Kill atifillin, probably needed for the loader
with ati and atimisc, so a leftover of last commit.
Diffstat (limited to 'README.mach64')
-rw-r--r--README.mach64828
1 files changed, 828 insertions, 0 deletions
diff --git a/README.mach64 b/README.mach64
new file mode 100644
index 0000000..7dddbee
--- /dev/null
+++ b/README.mach64
@@ -0,0 +1,828 @@
+ $Id$ Based on
+ XFree86: xc/programs/Xserver/hw/xfree86/doc/sgml/ati.sgml,v
+ 3.42 2003/01/20 03:43:07 dawes Exp ATI Adapters README file
+ Marc Aurele La France
+ 2002 February 12
+
+ This is the README for the XAA ATI driver included in this release.
+ ______________________________________________________________________
+
+ Table of Contents
+
+
+ 1. Statement of intent
+ 2. A note on acceleration
+ 3. Current implementation for ATI adapters
+ 4. Current implementation of generic VGA support for non-ATI adapters
+ 5. xorg.conf specifications
+ 5.1 Driver ``ati''
+ 5.2 ChipSet ``name''
+ 5.3 ChipID & ChipRev specifications
+ 5.4 IOBase
+ 5.5 BusID
+ 5.6 Clocks
+ 5.6.1 Clocks for supported programmable clock generators
+ 5.6.2 Clocks for unsupported programmable clock generators
+ 5.6.3 Clocks for fixed clock generators on ATI adapters
+ 5.6.4 Clocks for non-ATI adapters
+ 5.7 Option ``nopanel_display''
+ 5.8 Option ``crt_display''
+ 5.9 Option ``noaccel''
+ 5.10 Option ``nolinear''
+ 5.11 Option ``HWCursor'' and Option ``SWCursor''
+ 5.12 Option ``SilkenMouse''
+ 5.13 Option ``shadowfb''
+ 5.14 Option ``dpms''
+ 5.15 Option ``backingstore''
+ 5.16 MemBase address
+ 5.17 Option ``ReferenceClock'' ``frequency''
+ 5.18 ClockChip ``name''
+
+ 6. Video modes
+ 7. Known problems and limitations
+ 8. Reporting problems
+ 9. Driver history
+ 10. Driver versions
+
+
+ ______________________________________________________________________
+
+ 1. Statement of intent
+
+ Generally speaking, the driver is intended for all ATI video adapters,
+ providing maximum video function within hardware limitations. The
+ driver is also intended to optionally provide the same level of
+ support for generic VGA or 8514/A adapters. This driver is still
+ being actively developed, meaning that it currently does not yet fully
+ meet these goals.
+
+ The driver will provide
+
+ +o accelerated support if an ATI accelerator is detected and the user
+ has not requested that this support be disabled; otherwise
+
+ +o accelerated support if a non-ATI 8514/A-capable adapter is detected
+ and the user has requested such support; otherwise
+
+ +o unaccelerated SuperVGA support if an ATI VGA-capable adapter is
+ detected; otherwise
+
+ +o generic VGA support if a non-ATI VGA-capable adapter is detected
+ and the user has requested such support.
+
+ Thus, the level of support provided not only depends on what the
+ driver detects in the system, but also, on what the user specifies
+ in the xorg.conf file. See the ``xorg.conf specifications''
+ section below for details.
+
+ If none of the above conditions are met, the ATI driver will
+ essentially disable itself to allow other drivers to examine the
+ system.
+
+ Note that I am currently considering removing the driver's support for
+ generic VGA. If you have any concerns about this, please contact me
+ at <tsi@xfree86.org>.
+
+ 2. A note on acceleration
+
+ The meaning of ``acceleration'', as used in this document, needs to be
+ clarified. Two of the many components in an accelerator are the CRT
+ controller (CRTC) and the Draw Engine. This is in addition to another
+ CRTC that, generally, is also present in the system (often in the same
+ chip) and typically provides EGA, VGA or SuperVGA functionality.
+
+ A CRTC is the component of a graphics controller that is responsible
+ for reading video memory for output to the screen. A Draw Engine is
+ an accelerator component that can be programmed to manipulate video
+ memory contents, thus freeing the CPU for other tasks.
+
+ When the VGA CRTC is used, all drawing operations into video memory
+ are the responsibility of the system's CPU, i.e. no Draw Engine can be
+ used. On the other hand, if the accelerator's CRTC is chosen to drive
+ the screen, the Draw Engine can also be used for drawing operations,
+ although the CPU can still be used for this purpose if it can access
+ the accelerator's video memory.
+
+ Video acceleration refers to the programming of an accelerator's Draw
+ Engine to offload drawing operations from the CPU, and thus also
+ implies the use of the accelerator's CRTC.
+
+
+ 3. Current implementation for ATI adapters
+
+ The driver currently supports the SuperVGA capabilities of all ATI
+ adapters except some early Mach8 and Mach32 adapters that do not
+ provide the required functionality. This support works for
+ monochrome, 16-colour and 256-colour video modes, if one of the
+ following ATI graphics controller chips is present:
+
+ VGAWonder series: 18800, 18800-1, 28800-2, 28800-4, 28800-5, 28800-6
+ Mach32 series: 68800-3, 68800-6, 68800AX, 68800LX
+ Mach64 series: 88800GX-C, 88800GX-D, 88800GX-E, 88800GX-F, 88800CX,
+ 264CT, 264ET, 264VT, 264GT (3D Rage), 264VT-B, 264VT3,
+ 264VT4, 264GT-B (3D Rage II), 3D Rage IIc, 3D Rage Pro,
+ 3D Rage LT, 3D Rage LT Pro, 3D Rage XL, 3D Rage XC,
+ 3D Rage Mobility (including the -M and -P variants)
+
+
+ The driver also supports 32K, 64K and 16M-colour modes on the 264xT
+ and 3D Rage series of adapters using the accelerator CRTC (but not the
+ VGA CRTC).
+
+
+ The newer Rage 128 and Radeon chips are not yet supported by this
+ driver. Rage 128's and Radeon's are, however, supported by separate
+ drivers, and owners of such adapters should consult the documentation
+ provided with these drivers. This driver will also invoke the
+ appropriate driver if it finds Rage 128 and/or Radeon adapter(s) in
+ the system.
+
+ Adapters based on the above chips have been marketed under a rather
+ large number of names over the years. Among them are:
+
+ VGAWonder series: VGAWonder V3, VGAWonder V4, VGAWonder V5, VGAWonder+,
+ VGAWonder XL, VGAWonder XL24, VGAWonder VLB, VGA Basic,
+ VGA Basic 16, VGA Edge, VGA Edge 16, VGA Integra,
+ VGA Charger, VGAStereo F/X, VGA 640, VGA 800, VGA 1024,
+ VGA 1024D, VGA 1024 XL, VGA 1024 DXL, VGA 1024 VLB
+ Mach8 series: Graphics Ultra, Graphics Vantage, VGAWonder GT
+ (None of the 8514/Ultra and 8514 Vantage series is
+ supported at this time)
+ Mach32 series: Graphics Ultra+, Graphics Ultra Pro, Graphics Wonder,
+ Graphics Ultra XLR, Graphics Ultra AXO, VLB mach32-D,
+ PCI mach32-D, ISA mach32
+ Mach64 series: Graphics Xpression, Graphics Pro Turbo, WinBoost,
+ WinTurbo, Graphics Pro Turbo 1600, Video Xpression,
+ 3D Xpression, Video Xpression+, 3D Xpression+,
+ 3D Charger, Video Charger, WinCharger, All-In-Wonder,
+ All-In-Wonder PRO, 3D Pro Turbo, XPERT@Play,
+ XPERT@Play 98, XPERT@Work, XPERT 98, XPERT LCD,
+ XPERT XL
+
+
+ Also, a number of mainboards, laptops and notebooks harbour a Mach32
+ or Mach64 controller.
+
+ VGAWonder, Mach8 and Mach32 ISA adapters are available with or without
+ a mouse.
+
+ These adapters are available with a variety of clock generators and
+ RAMDACs. The 264xT and 3D Rage series of chips are integrated
+ controllers, meaning that they include a programmable clock generator
+ and a RAMDAC.
+
+ For all but Mach64 adapters, this driver still does not provide
+ support for accelerated drawing to the screen. This means that all
+ drawing is done by the CPU, rather than by any accelerator present in
+ the system. This can make opaque moves, for example, quite ``jerky''.
+ Also, given that IBM 8514/A and ATI Mach8 do not allow CPU access to
+ their frame buffer, the driver will currently ignore these
+ accelerators. Most Mach32 adapters provide both accelerated function
+ and SuperVGA functionality, but the driver currently only uses the
+ VGA.
+
+ The driver does however support the accelerator CRTC present in all
+ ATI Mach64 adapters. For 256-colour, and higher depth modes, this
+ support will be used by default, although an xorg.conf option can be
+ specified to use the SuperVGA CRTC instead. A linear video memory
+ aperture is also available in 256-colour and higher depth modes and
+ enabled by default if a 264xT or 3D Rage controller is detected or, on
+ 88800 controllers, if the accelerator CRTC is used. xorg.conf options
+ are available to disable this aperture, or (for non-PCI adapters)
+ enable it or move it to some other address.
+
+ By default, the driver provides some acceleration for Mach64 if the
+ accelerator CRTC is used, and modes whose colour depth greater than or
+ equal to 8 are to be used. This support is as yet incomplete and can
+ be disabled entirely with an xorg.conf option.
+
+ On non-Intel platforms, the driver can, currently, only support PCI
+ Mach64 adapters.
+
+
+ 4. Current implementation of generic VGA support for non-ATI adapters
+
+ Support for generic VGA with non-ATI adapters is also implemented, but
+ has undergone only limited testing. The driver will intentionally
+ disallow the use of this support with ATI adapters. This support must
+ be explicitly requested through an xorg.conf ChipSet specification.
+ This prevents the current VGA generic driver from being disabled.
+
+ This driver's generic VGA support is intended as an extension of that
+ provided by the current generic driver. Specifically, within the
+ architectural bounds defined by IBM's VGA standard, this driver will
+ allow the use of any 256-colour mode, and any dot clock frequencies
+ both of which allow for many more mode possibilities.
+
+ The driver will enforce the following limitations derived from IBM's
+ original VGA implementation:
+
+ +o There can only be a set of four (non-programmable) clocks to choose
+ from.
+
+ +o Video memory is limited to 256kB in monochrome and 16-colour modes.
+
+ +o Video memory is limited to 64kB in 256-colour modes.
+
+ +o Interlaced modes are not available.
+
+ +o Colour depths higher than 8 are not available.
+
+ 5. xorg.conf specifications
+
+ The driver recognises a number of xorg.conf options. In general, all
+ such options should be specified in a ``Device'' section, and affect
+ only that ``Device'' section.
+
+ Those options that affect how the driver associates adapters with
+ ``Device'' sections are described first. The driver will ignore (with
+ a message) a ``Device'' section if the section cannot be associated
+ with exactly one adapter in the system. Similarly, the driver will
+ ignore, or disable, (with a message) any adapter that cannot be
+ associated with exactly one ``Device'' section. Thus, these options
+ will be required in those uncommon cases where such unique
+ associations cannot automatically be made by the driver.
+
+ Other options affect the driver's operation once an adapter has been
+ assigned to the ``Device'' section which contains them.
+
+
+ 5.1. Driver ``ati''
+
+ The use of this specification is highly recommended if the ``Device''
+ section is to be recognised by the driver. In fact, it is almost (but
+ not quite) mandatory, particularly when using the loader server as it
+ indicates what driver is to be loaded and associated with the
+ ``Device'' section.
+
+
+ 5.2. ChipSet ``name''
+
+ The default ChipSet name for this driver is ``ati''. In this case,
+ any ATI adapter can be associated with the ``Device'' section. If an
+ ATI accelerator is detected and the driver supports it, the
+ accelerator's CRTC will be used to drive the screen. Otherwise, the
+ driver will programme the adapter's SuperVGA CRTC.
+
+ If ``ativga'' is specified instead, the driver will ignore any ATI
+ accelerator it detects, but otherwise operate as if ``ati'' had been
+ specified. This specification ensures the VGA CRTC is used.
+
+ A ChipSet name of ``ibmvga'' causes any VGA-capable adapter in the
+ system to be associated with the ``Device'' section. It enables the
+ driver's generic VGA support, but only for non-ATI adapters. If an
+ ATI adapter is associated with the ``Device'' section, the driver will
+ operate as if ``ativga'' had been specified instead.
+
+ A ChipSet name of ``vgawonder'' is equivalent to ``ativga'', except
+ that only VGAWonder-capable adapters can be assigned to the ``Device''
+ section. This specifically excludes the newer integrated Mach64
+ controllers.
+
+ In some PCI or AGP systems, the driver will not, by default, probe for
+ non-PCI Mach32's or Mach64's. This is because, before doing any such
+ probe, the driver attempts to determine if the probe can cause a
+ lockup. If the driver has enough information to determine that a
+ lockup would occur, it will skip the probe. In some situations, this
+ determination cannot be accurate, and the driver will err on the side
+ of caution, skipping the probe. Specifying a ChipSet name of
+ ``mach32'' or ``mach64'', as appropriate, will force the driver to
+ probe for the non-PCI adapter. These ChipSet names should, therefore,
+ only be used when there is in fact such an adapter in the system.
+ They are otherwise equivalent to ``ati''.
+
+ On non-Intel platforms, only ``ati'' and ``mach64'' ChipSet values are
+ operative.
+
+
+ 5.3. ChipID & ChipRev specifications
+
+ These specifications will cause the driver to associate the ``Device''
+ section only with an adapter having the same attributes, or an adapter
+ whose PCI device ID the driver does not recognise. In the second
+ case, these options cause the driver to treat the adapter as if it was
+ one with the specified PCI device ID or revision. ChipID can only be
+ used with Mach32 or Mach64 adapters, and, thus, specifically excludes
+ any other adapter from matching the ``Device'' section. ChipRev is
+ meaningful only with Mach64 adapters, and then only if ChipID is also
+ specified in the same ``Device'' section.
+
+
+ 5.4. IOBase
+
+ This option limits the adapters that can be associated with the
+ ``Device'' section to the one with the specified I/O base. This
+ option only applies to Mach64 adapters and specifically excludes other
+ adapters.
+
+
+ 5.5. BusID
+
+ This option limits the adapters that can be associated with the
+ ``Device'' section to the one with the specified PCI Bus ID. This
+ specification excludes non-PCI adapters.
+
+
+ 5.6. Clocks
+
+ For the purpose of specifying a clock line in your xorg.conf, one of
+ four different situations can occur, as follows.
+
+ Those configuring the driver's generic VGA support for a non-ATI
+ adapter, can skip ahead to the ``Clocks for non-ATI adapters'' section
+ below. Those not trying to configure the driver for a Mach64 adapter,
+ can skip ahead to the ``Clocks for fixed clock generators on ATI
+ adapters'' section below.
+
+ The very earliest Mach64 adapters use fixed (i.e. non-programmable)
+ clock generators. Very few of these (mostly prototypes) are known to
+ exist, but if you have one of these, you can also skip ahead to the
+ ``Clocks for fixed clock generators on ATI adapters'' section below.
+
+ The two cases that are left deal with programmable clock generators,
+ which are used on the great majority of Mach64 adapters.
+
+ If you are uncertain which situation applies to your adapter, you can
+ run a clock probe with the command ``X -probeonly''.
+
+
+ 5.6.1. Clocks for supported programmable clock generators
+
+ At bootup, video BIOS initialisation programmes an initial set of
+ frequencies. Two of these are reserved to allow the setting of modes
+ that do not use a frequency from this initial set. One of these
+ reserved slots is used by the BIOS mode set routine, the other by the
+ particular driver used (e.g. MS-Windows, AutoCAD, X, etc.). The clock
+ numbers reserved in this way are dependent on the particular clock
+ generator used by the adapter.
+
+ The driver currently supports all programmable clock generators known
+ to exist on Mach64 adapters. In this case, the driver will completely
+ ignore any xorg.conf clock specification, and programme the clock
+ generator as needed by the modes used during the X session.
+
+
+ 5.6.2. Clocks for unsupported programmable clock generators
+
+ This case is unlikely to occur, but is documented for the sake of
+ completeness.
+
+ In this situation, the driver will probe the adapter for clock
+ frequencies unless xorg.conf clocks are already specified. In either
+ case, the driver will then attempt to normalise the clocks to one of
+ the following specifications:
+
+ BIOS setting 1:
+
+ Clocks 0.000 110.000 126.000 135.000 50.350 56.640 63.000 72.000
+ 0.000 80.000 75.000 65.000 40.000 44.900 49.500 50.000
+ 0.000 55.000 63.000 67.500 25.180 28.320 31.500 36.000
+ 0.000 40.000 37.500 32.500 20.000 22.450 24.750 25.000
+
+
+
+ BIOS setting 2:
+
+ Clocks 0.000 110.000 126.000 135.000 25.180 28.320 31.500 36.000
+ 0.000 80.000 75.000 65.000 40.000 44.900 49.500 50.000
+ 0.000 55.000 63.000 67.500 12.590 14.160 15.750 18.000
+ 0.000 40.000 37.500 32.500 20.000 22.450 24.750 25.000
+
+
+
+ BIOS setting 3:
+
+ Clocks 0.000 0.000 0.000 0.000 25.180 28.320 0.000 0.000
+ 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000
+ 0.000 0.000 0.000 0.000 12.590 14.160 0.000 0.000
+ 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000
+
+
+ If the driver matches the clocks to the third setting above, function-
+ ality will be extremely limited (assuming the driver works at all).
+
+
+ 5.6.3. Clocks for fixed clock generators on ATI adapters
+
+ This section applies to all VGAWonder and Mach32 adapters, and to
+ early Mach64 prototypes.
+
+ One of the following clocks specifications (or an initial subset
+ thereof) can be used depending on what the adapter uses to generate
+ dot clocks:
+
+ Crystals (VGA Wonder V3 and V4 adapters only):
+
+ Clocks 50.000 56.644 0.000 44.900 44.900 50.000 0.000 36.000
+ 25.000 28.322 0.000 22.450 22.450 25.000 0.000 18.000
+ 16.667 18.881 0.000 14.967 14.967 16.667 0.000 12.000
+ 12.500 14.161 0.000 11.225 11.225 12.500 0.000 9.000
+
+
+
+ ATI 18810 clock generator:
+
+ Clocks 30.240 32.000 37.500 39.000 42.954 48.771 0.000 36.000
+ 40.000 0.000 75.000 65.000 50.350 56.640 0.000 44.900
+ 15.120 16.000 18.750 19.500 21.477 24.386 0.000 18.000
+ 20.000 0.000 37.500 32.500 25.175 28.320 0.000 22.450
+ 10.080 10.667 12.500 13.000 14.318 16.257 0.000 12.000
+ 13.333 0.000 25.000 21.667 16.783 18.880 0.000 14.967
+ 7.560 8.000 9.375 9.750 10.739 12.193 0.000 9.000
+ 10.000 0.000 18.750 16.250 12.586 14.160 0.000 11.225
+
+
+
+ ATI 18811-0 and ATI 18812-0 clock generators:
+
+ Clocks 30.240 32.000 110.000 80.000 42.954 48.771 92.400 36.000
+ 39.910 44.900 75.000 65.000 50.350 56.640 0.000 44.900
+ 15.120 16.000 55.000 40.000 21.477 24.386 46.200 18.000
+ 19.955 22.450 37.500 32.500 25.175 28.320 0.000 22.450
+ 10.080 10.667 36.667 26.667 14.318 16.257 30.800 12.000
+ 13.303 14.967 25.000 21.667 16.783 18.880 0.000 14.967
+ 7.560 8.000 27.500 20.000 10.739 12.193 23.100 9.000
+ 9.978 11.225 18.750 16.250 12.588 14.160 0.000 11.225
+
+
+
+ ATI 18811-1 and ATI 18811-2 clock generators:
+
+ Clocks 135.000 32.000 110.000 80.000 100.000 126.000 92.400 36.000
+ 39.910 44.900 75.000 65.000 50.350 56.640 0.000 44.900
+ 67.500 16.000 55.000 40.000 50.000 63.000 46.200 18.000
+ 19.955 22.450 37.500 32.500 25.175 28.320 0.000 22.450
+ 45.000 10.667 36.667 26.667 33.333 42.000 30.800 12.000
+ 13.303 14.967 25.000 21.667 16.783 18.880 0.000 14.967
+ 33.750 8.000 27.500 20.000 25.000 31.500 23.100 9.000
+ 9.978 11.225 18.750 16.250 12.588 14.160 0.000 11.225
+
+
+
+ ICS 2494-AM clock generators (found on some Dell motherboards):
+
+ Clocks 75.000 77.500 80.000 90.000 25.175 28.322 31.500 36.000
+ 100.000 110.000 126.000 135.000 40.000 44.900 50.000 65.000
+ 37.500 38.750 40.000 45.000 12.588 14.161 15.750 18.000
+ 50.000 55.000 63.000 67.500 20.000 22.450 25.000 32.500
+ 25.000 25.833 26.667 30.000 8.392 9.441 10.500 12.000
+ 33.333 36.667 42.000 45.000 13.333 14.767 16.667 21.667
+ 18.750 19.375 20.000 22.500 6.294 7.081 7.875 9.000
+ 25.000 27.500 31.500 33.750 10.000 11.225 12.500 16.250
+
+
+ VGAWonder VLB, VGA 1024 VLB, Mach32 and Mach64 owners should only
+ specify up to the first 32 frequencies. Any more will be ignored.
+
+ Other clock generators that have been used on ATI adapters (which can
+ all be said to be clones of one of the above) might generate non-zero
+ frequencies for those that are zero above, or vice-versa.
+
+ The order of the clocks is very important, although the driver will
+ reorder the specified clocks if it deems it appropriate to do so.
+ Mach32 and Mach64 owners should note that this order is different than
+ what they would use for previous accelerated servers.
+
+
+ 5.6.4. Clocks for non-ATI adapters
+
+ If no clocks are specified in the xorg.conf, the driver will probe for
+ four clocks, the second of which will be assumed to be 28.322 MHz.
+ The first clock will typically be 25.175 MHz, but there are
+ exceptions. You can include up to four clock frequencies in your
+ xorg.conf to specify the actual values used by the adapter. Any more
+ will be ignored.
+
+
+ 5.7. Option ``nopanel_display''
+
+ This specification is only effective when the driver detects that the
+ adapter's BIOS has initialised both the digital flat panel and CRT
+ interfaces. In such a situation, the driver will normally drive both
+ the panel and the CRT. This specification causes the driver to
+ disable the digital flat panel and display the screen image on the CRT
+ instead, which could potentially allow for larger physical resolutions
+ than the panel can handle.
+
+
+ 5.8. Option ``crt_display''
+
+ This specification is only effective when the driver detects that the
+ adapter's BIOS has initialised the digital flat panel interface, but
+ has disabled the CRT interface. In such a situation the driver will
+ normally drive only the panel. This specification causes the driver
+ to instead display the same image on both the panel and the CRT.
+ 5.9. Option ``noaccel''
+
+ By default, the driver will accelerate draw operations if a Mach64
+ CRTC is used to drive the display. As implemented in this driver,
+ acceleration does not require a linear video memory aperture. This
+ option disables this acceleration.
+
+
+ 5.10. Option ``nolinear''
+
+ By default, the driver will enable a linear video memory aperture for
+ 256-colour and higher depth modes if it is also using a Mach64
+ accelerator CRTC or an integrated Mach64 graphics chip. This option
+ disables this linear aperture.
+
+ On non-Intel platforms, the driver requires a linear aperture and, so,
+ this option is ignored.
+
+
+ 5.11. Option ``HWCursor'' and Option ``SWCursor''
+
+ Option ``HWCursor'', which is the default, specifies that hardware
+ facilities are to be used to paint the mouse pointer on the screen.
+ Option ``SWCursor'' specifies that the mouse pointer is to be drawn by
+ software, which is much slower. If both options are specified, option
+ ``SWCursor'' prevails. Currently, these options are only acted upon
+ for 256-colour or higher depth modes, if a Mach64 accelerator CRTC, or
+ a Mach64 integrated controller is being used. In all other
+ situations, a software cursor will be used, regardless of what these
+ options specify.
+
+
+ 5.12. Option ``SilkenMouse''
+
+ This option is only acted upon when a hardware cursor is being used.
+ It specifies that the cursor's position on the screen is to be updated
+ as quickly as possible when the mouse is moved. This is the default
+ behaviour. If this option is negated, the cursor may lag the mouse
+ when the X server is very busy.
+
+
+ 5.13. Option ``shadowfb''
+
+ If this option is enabled, the driver will cause the CPU to do each
+ drawing operation first into a shadow frame buffer in system virtual
+ memory and then copy the result into video memory. If this option is
+ not active, the CPU will draw directly into video memory. Enabling
+ this option is beneficial for those systems where reading from video
+ memory is, on average, slower than the corresponding read/modify/write
+ operation in system virtual memory. This is normally the case for PCI
+ or AGP adapters, and, so, this option is enabled by default. For
+ other bus types, the default behaviour is to disable this option.
+
+ Note that, due to various limitations, this option is forcibly
+ disabled when a linear video memory aperture is not enabled, when the
+ frame buffer depth is less than 8, or when acceleration is used.
+
+
+ 5.14. Option ``dpms''
+
+ This option enables the driver's support for VESA's Display Power
+ Management Specification.
+
+
+
+ 5.15. Option ``backingstore''
+
+ This is not specifically a driver option. It is used to enable the
+ server's support for backing store, a mechanism by which pixel data
+ for occluded window regions is remembered by the server thereby
+ alleviating the need to send expose events to X clients when the data
+ needs to be redisplayed.
+
+
+ 5.16. MemBase address
+
+ This specification is only effective for non-PCI Mach64 adapters, and
+ is used to override the CPU address at which the adapter will map its
+ video memory. Normally, for non-PCI adapters, this address is set by
+ a DOS install utility provided with the adapter. The MemBase option
+ can also be used to enable the linear aperture in those cases where
+ ATI's utility was not, or can not be, used.
+
+ For PCI and AGP adapters, this address is determined at system bootup
+ according to the PCI Plug'n'Play specification which arbitrates the
+ resource requirements of most devices in the system. This means the
+ driver can not easily change the linear aperture address.
+
+
+ 5.17. Option ``ReferenceClock'' ``frequency''
+
+ This option is only applicable to non-Intel platforms, where an
+ adapter BIOS is not available to the driver. The option specifies the
+ reference frequency used by the adapter's clock generator. The
+ default is 14.318 MHz, and other typical values are 28.636, or 29.5
+ MHz.
+
+
+ 5.18. ClockChip ``name''
+
+ This option is only applicable to non-Intel platforms, where an
+ adapter BIOS is not available to the driver, and the driver cannot
+ reliably determine whether the clock generator the adapter uses is a
+ variant of an ATI 18818 (a.k.a. ICS 2595) or an unsupported clock
+ generator. The only values that are acted upon are ``ATI 18818-0'' or
+ ``ATI 18818-1''. From this specification, the driver derives a
+ reference divider of 43 or 46 (respectively) for use in clock
+ programming calculations. The driver's default behaviour, in this
+ case, is to assume an unsupported clock generator, which means it will
+ treat it as a fixed-frequency clock generator, as described under the
+ heading ``Clocks for unsupported programmable clock generators''
+ above.
+
+
+ 6. Video modes
+
+ Mode timings can be derived from the information in X's doc
+ subdirectory. However, it is no longer required to specify such
+ timings in an xorg.conf's ``Monitor'' section(s), if only standard
+ mode timings are to be used. The server automatically inserts VESA
+ standard mode timings in every ``Monitor'' section, and these modes
+ will be checked first for mode constraints (monitor sync tolerances,
+ video memory size, etc.).
+
+ Furthermore, it is also no longer required to specify mode names in
+ ``Display'' subsections. Should no mode names be specified (or those
+ specified do not yield a usable mode), the server will automatically
+ select as a default resolution the largest usable mode, whether or not
+ the chosen mode is specified in the corresponding ``Monitor'' section.
+
+
+ For a digital flat panel, any sync tolerances should be removed from
+ the corresponding ``Monitor'' section. The driver will automatically
+ calculate these from the mode that is active on server entry. The
+ driver also inserts timings for a mode called "Native panel mode" that
+ represents the panel's native resolution.
+
+
+ 7. Known problems and limitations
+
+ There are several known problems or limitations related to the ATI
+ driver. They include:
+
+
+ +o When using a Mach64's accelerator CRTC, the virtual resolution must
+ be less than 8192 pixels wide. The VGA CRTC further limits the
+ virtual resolution width to less than 4096 pixels, or to less than
+ 2048 pixels for adapters based on 18800-x's (with 256kB of memory)
+ and on Mach64 integrated controllers. These are hardware limits
+ that cannot be circumvented.
+
+ +o Virtual resolutions requiring more than 1MB of video memory (256kB
+ in the monochrome case) are not supported by the VGA CRTC on
+ 88800GX and 88800CX adapters. This is a hardware limit that cannot
+ be circumvented.
+
+ +o Due to hardware limitations, doublescanned modes are not supported
+ by the accelerator CRTC in 88800GX, 88800CX, 264CT and 264ET
+ adapters.
+
+ +o The ``VScan'' modeline parameter is only supported when using the
+ VGA CRTC.
+
+ +o Interlaced modes are not supported on 18800-x and 28800-x adapters
+ when using a virtual resolution that is 2048 pixels or wider. When
+ using a 18800-x with 256kB of video memory in 256-colour modes,
+ this limit is reduced to 1024. This is yet another hardware
+ limitation that cannot be circumvented.
+
+ +o Video memory banking does not work in monochrome and 16-colour
+ modes on 18800-x adapters. This appears to be another hardware
+ limit, but this conclusion cannot be confirmed at this time. The
+ driver's default behaviour in this case is to limit video memory to
+ 256kB.
+
+ +o Video memory corruption can still occur during mode switches on
+ 18800-x adapters. Symptoms of this problem include garbled fonts
+ on return to text mode, and various effects (snow, dashed lines,
+ etc) on initial entry into a graphics mode. In the first case, the
+ workaround is to use some other means of restoring the text font.
+ On Linux, this can be accomplished with the kbd or svgalib
+ packages. In the second case, xrefresh(1) will usually clean up
+ the image. No complete solution to this problem is currently
+ known. It appears this corruption occurs due to either video
+ memory bandwidth or RAMDAC limitations, and so the driver will
+ limit mode clocks to 40MHz.
+
+ +o There is some controversy over what the maximum allowed clock
+ frequency should be on 264xT and 3D Rage adapters. For now, clocks
+ will, by default, be limited to 80MHz, 135MHz, 170MHz, 200MHz or
+ 230MHz, depending on the specific controller. This limit can only
+ be increased (up to a driver-calculated absolute maximum) through
+ the DACSpeed specification in xorg.conf. Be aware however that
+ doing so is untested and might damage the adapter.
+
+ +o Except as in the previous items, clocks are limited to 80MHz on
+ most adapters, although many are capable of higher frequencies.
+ This will eventually be fixed in a future release.
+
+ +o The use of a laptop's hot-keys to switch displays while this driver
+ is active can cause lockups and/or other woes, and is therefore not
+ recommended. It is not currently possible to solve this problem.
+
+
+ +o In situations where the driver is to simultaneously display on both
+ a panel and a CRT, the same image will be seen on both. In
+ particular, this means the CRT must be able to synchronise with the
+ timings of the panel's native resolution. This is quite evident
+ when the panel has ``odd-ball'' dimensions, such as 1400x1050, a
+ resolution not commonly possible on CRTs or projection equipment.
+
+ Also, the display of independent images on the panel and CRT is not
+ currently implemented, and might never be, pending resolution of
+ the previous item.
+
+
+ Support for the following will be added in a future release:
+
+ +o Mach32's accelerator CRTC. This support is the first step towards
+ accelerated support for Mach32's, Mach8's, 8514/A's and other
+ clones.
+
+ +o Colour depth greater than 8 on non-integrated controllers, where
+ permitted by the hardware.
+
+ +o Mach32, Mach8 and 8514/A Draw Engines.
+
+ +o Hardware cursors where implemented by hardware. This has already
+ been done for Mach64 integrated controllers.
+
+ +o TVOut, i.e. the ability to use a television screen as a monitor.
+
+ +o Motion Video, i.e. displaying an asynchronous data stream (TV
+ signal, DVD, etc.) in a window or full-screen.
+
+ +o 3D operations.
+
+ 8. Reporting problems
+
+ If you are experiencing problems that are not already recorded in this
+ document, first ensure that you have the latest current release of
+ this driver and the Xorg X server.. Check the server's log (usually
+ found in /var/log/Xorg.0.log) and ftp://ftp.freedesktop.org/pub/Xorg
+ if you are uncertain.
+
+ Secondly, please check Xorg's doc directory for additional
+ information.
+
+ Thirdly, a scan through the comp.windows.x.i386unix and
+ comp.os.linux.x newsgroups and the xorg mailing list using your
+ favourite archiving service can also prove useful in resolving
+ problems.
+
+ If you are still experiencing problems, you can send me non-HTMLised
+ e-mail at <tsi@xfree86.org>. Please be as specific as possible when
+ describing the problem(s), and include an unedited copy of the
+ server's log and the xorg.conf file used.
+
+
+ 9. Driver history
+
+ The complete history of the driver is rather cloudy. The following is
+ more than likely to be incomplete and inaccurate.
+ Apparently, Per Lindqvist first got a driver working with an early ATI
+ adapter under X386 1.1a. This original driver might have actually
+ been based on a non-functional ATI driver written by Thomas Roell
+ (currently of Xi Graphics).
+
+ Then Doug Evans added support for the ATI VGA Wonder XL, trying in the
+ process to make the driver work with all other ATI adapters available
+ at the time.
+
+ Rik Faith obtained the X11R4 driver from Doug Evans in the summer of
+ 1992 and ported the code to the X386 part of X11R5. This subsequently
+ became part of XFree86.
+
+ I (Marc Aurele La France) took over development and maintenance of the
+ driver in the fall of 1993 after Rik got rid of his VGA Wonder
+ adapter.
+
+
+ 10. Driver versions
+
+ Due to the introduction of loadable drivers in XFree86 4.0, it has
+ become necessary to track driver versions separately. Driver releases
+ use the following version numbering scheme.
+
+ Version 1 of this driver is the one I inherited from Rik Faith. This
+ is the version found in XFree86 2.0 and 2.1.
+
+ Version 2 is my first rewrite of this code which only ended up being a
+ partially unsuccessful attempt at generalising the driver for all VGA
+ Wonder, Mach32, and early Mach64 adapters. Various releases of this
+ version of the driver can be found in XFree86 2.1.1, 3.1, 3.1.1 and
+ 3.1.2.
+
+ Version 3 represents my second rewrite (although a rather lame one as
+ rewrites go). Into version 3, I introduced clock programming for
+ Mach64 adapters and merged in the old ati_test debugging tool. This
+ is the version found in XFree86 3.2, 3.3 and 3.3.1.
+
+ Version 4 is a rather major restructuring of version 3, which became
+ larger than I could comfortably handle in one source file. This is
+ the version found in XFree86 3.3.2, 3.3.3, 3.3.3.1, 3.3.3.2, 3.3.4,
+ 3.3.5 and 3.3.6.
+
+ Version 5 is an almost complete restructuring of version 4 to fit in
+ the newer driver API of XFree86 4.0 and later.
+
+ The introduction of version 6 is a first swipe at porting the driver
+ to non-Intel architectures.
+
+
+