home *** CD-ROM | disk | FTP | other *** search
/ Enter 1999 April - Disc 1 / enter_04_1999_1.iso / OS2 / XFREE86 / XDOC.ZIP / XFree86 / lib / X11 / doc / README.cirrus < prev    next >
Encoding:
Text File  |  1999-01-09  |  46.0 KB  |  1,255 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.  
  8.  
  9.  
  10.                       Information for Cirrus Chipset Users
  11.  
  12.    Harm Hanemaayer (H.Hanemaayer@inter.nl.net), Randy Hendry (randy@sgi.com)
  13.                   (64xx), Corin Anderson (corina@the4cs.com)
  14.  
  15.                                 5 November 1998
  16.  
  17.  
  18.  
  19. 1.  Supported chipsets
  20.  
  21. There are two different SVGA drivers for Cirrus chipsets, one called ``cirrus''
  22. and one called ``cl64xx''.  The ``cirrus'' driver is used in the 256-color SVGA
  23. server (with acceleration) and the mono server (without acceleration). The SVGA
  24. server supports 16, 24, and 32 bits-per-pixel truecolor modes on some configu-
  25. rations.  The ``cl64xx'' driver is used in the 256-color SVGA, 16-color and
  26. mono servers.  Note that except where stated otherwise, this document is refer-
  27. ring to the ``cirrus'' driver.  The following chipsets by Cirrus Logic are sup-
  28. ported:
  29.  
  30.       CL-GD5420
  31.             ISA SVGA chipset, 1Mbyte; maximum dot clock is 45 MHz (256 color
  32.             server). Acceleration with extended write modes (used for scrolling
  33.             and solid filling in this driver). This chipset can not support
  34.             1024x768 non-interlaced in 256 colors.
  35.  
  36.       CL-GD5422
  37.             Enhanced version of the 5420 (32-bit internal memory interface).
  38.             Maximum dot clock is 80 MHz.
  39.  
  40.       CL-GD6205/6215/6225/6235
  41.             Laptop chipsets more or less compatible with the 5420. The only dot
  42.             clock supported is 25 MHz (more on an external display). Some prob-
  43.             lems have been reported with these chipsets (especially on external
  44.             displays). Take note of the "noaccel" option.
  45.  
  46.       CL-GD6420/6440
  47.             These chipsets are not compatible with the 542x series, but are
  48.             supported by the ``cl64xx'' driver. It is used in recent laptops,
  49.             and bears some similarity to old Cirrus chipsets (5410/AVGA2). The
  50.             driver may also work for other 64xx chips. The configuration iden-
  51.             tifiers for this driver are "cl6420" and "cl6440".  This driver is
  52.             discussed in detail in section The cl64xx Driver (section 6., page
  53.             11).
  54.  
  55.       CL-GD5424
  56.             Basically VLB version of the 5422, but resembles the 5426 in some
  57.             respects.
  58.  
  59.       CL-GD5426
  60.             Supports both ISA bus and VLB, and up to 2Mbyte of memory.  Has
  61.             BitBLT engine for improved acceleration (BitBlt, image transfer,
  62.  
  63.  
  64.  Information for Cirrus Chipset Users                                         1
  65.  
  66.  
  67.  
  68.  
  69.  
  70.  Information for Cirrus Chipset Users                                         2
  71.  
  72.  
  73.  
  74.             text). Dot clock limit is 85 MHz.
  75.  
  76.       CL-GD5428
  77.             Enhanced version of the 5426.
  78.  
  79.       CL-GD5429
  80.             Enhanced version of the 5428; officially supports higher MCLK and
  81.             has memory-mapped I/O.
  82.  
  83.       CL-GD5430
  84.             Similar to 5429, but with 543x core (32-bit host interface).  Does
  85.             not have 64-bit memory mode.
  86.  
  87.       CL-GD5434
  88.             `Alpine' family chip with 64-bit internal memory interface.  The
  89.             chip can only support 64-bit mode if equipped with 2 Mbytes of mem-
  90.             ory; cards with only 1 Mbyte are severely limited.  Supports dot
  91.             clocks up to 110 MHz (later chips support 135 MHz).
  92.  
  93.       CL-GD5436
  94.             Highly optimized 5434.
  95.  
  96.       CL-GD5440
  97.             Similar to the CL-GD5430, and detected as such.
  98.  
  99.       CL-GD5446
  100.             Another member of the Alpine family of 2D accelerators; similar to
  101.             the CL-GD5436.
  102.  
  103.       CL-GD5480
  104.             Newer Alpine family chip that support synchronous graphics RAM
  105.             (SGRAM).
  106.  
  107.       CL-GD5462, CL-GD5464 and CL-GD5465
  108.             The Laguna VisualMedia family of 2D  Accelerators.  These chips use
  109.             Rambus RDRAM memory.  The '62 is a 64-bit 2D accelerator, including
  110.             a BitBlit engine, video windows (not currently used by the server),
  111.             and 64x64 HW cursor.  Mono modes have not been tested. The CL-
  112.             GD5464 is the next chip in the Laguna family, and the CL-GD5465 is
  113.             the latest member, both have been tested.
  114.  
  115.       CL-GD7541/7542/7543/7548
  116.             Laptop chipsets more or less compatible with the 5428/3x.  While
  117.             has it been tested on some configurations, not all configuration
  118.             may work correctly.
  119.  
  120.       CL-GD7555
  121.             Limited untested support, without auto-detection, has been provided
  122.             for this chip which is a 64-bit extension of the 754x family. Use a
  123.             Chipset "clgd7555" line.
  124.  
  125. Here's a list of maximum dot clocks for each supported depth:
  126.  
  127.  
  128.  
  129.  
  130.  
  131.  
  132.  
  133.  
  134.  
  135.  
  136.  Information for Cirrus Chipset Users                                         3
  137.  
  138.  
  139.  
  140.                           mono     8 bpp (256c) 16 bpp       24 bpp       32 bpp
  141.           CL-GD62x5       45 MHz   45 MHz
  142.           CL-GD5420       80 MHz   45 MHz (1)
  143.           CL-GD542x/512K  80 MHz   45 MHz
  144.           CL-GD5422/24    80 MHz   80 MHz       40 MHz       27 MHz
  145.           CL-GD5426/28    85 MHz   85 MHz       45 MHz (2)   28 MHz
  146.           CL-GD5429       85 MHz   85 MHz       50 MHz       28 MHz
  147.           CL-GD5430       85 MHz   85 MHz       45 MHz (2)   28 MHz
  148.           CL-GD5434/1Mb   85 MHz   85 MHz       42 MHz       28 MHz
  149.           CL-GD5434/2Mb   85 MHz   110/135 MHz  85 MHz       28 MHz       45/50 MHz (2)
  150.           CL-GD5436/1Mb  85 MHz     110 MHz (3)  60 MHz (3)   40 MHz (3)
  151.           CL-GD5436/2Mb  85 MHz     135 MHz      85 MHz       85 MHz (3)   60 MHz (3)
  152.           CL-GD5446/1Mb  85 MHz     110 MHz (3)  60 MHz (3)   40 MHz (3)
  153.           CL-GD5446/2Mb  85 MHz     135 MHz      85 MHz       85 MHz (3)   60 MHz (3)
  154.           CL-GD5462 170 MHz  170 Mhz      170 MHz      170 MHz      135 MHz
  155.           CL-GD5464/65   170 MHz  230 Mhz      170 MHz      170 MHz      135 MHz
  156.           CL-GD5480 85 MHz     200 MHz      100 MHz      100 MHz      50 MHz
  157.           CL-GD754x 80 MHz   80 MHz       40 MHz (4)   (5)
  158.  
  159.           (1) with 512K memory.
  160.           (2) 50 MHz with high MCLK setting.
  161.           (3) Depends on memory clock.
  162.           (4) This may be too low for some chips.
  163.           (5) This depth may actually work if it is enabled and tested.
  164.  
  165.  
  166. Rough virtual/physical screen resolution limits for different amounts of video
  167. memory:
  168.  
  169.  
  170.                       mono        8 bpp        16 bpp     24 bpp     32 bpp
  171.           256K        800x600     640x400
  172.           512K        1152x900    800x600     640x400
  173.           1024K       1600x1200   1152x900    800x600     680x510
  174.           2048K       2304x1728   1600x1200   1152x900    960x720    800x600
  175.           4096K       2304x1728   2272x1704   1600x1200   1360x1020  1152x900
  176.  
  177.  
  178. For 546x chips, the above table isn't quite accurate.  While the virtual width
  179. may be any size, the screen pitch will be rounded up to the nearest value in
  180. the table below.  Thus, each line on the screen will take more video memory
  181. than just what is displayed.  To maximize video memory, then, choose the vir-
  182. tual desktop width from the table of pixel widths below:
  183.  
  184.  
  185.           8bpp:     640, 1024, 1280, 1664, 2048, 2560, 3328, 4096, 5120, 6656
  186.           16bpp:    320,  512,  640,  832, 1024, 1280, 1664, 2048, 2560, 3328
  187.           24bpp:    640, 1024, 1280, 1664, 2048, 2560, 3328, 4096, 5120, 6656
  188.           32bpp:    160,  256,  320,  416,  512,  640,  832, 1024, 1280, 1664
  189.  
  190.  
  191. For other Cirrus chips, it's advisable to have a virtual width that is a multi-
  192. ple of 32 if acceleration is used.  The horizontal monitor timings must be
  193. below 2048.
  194.  
  195.  
  196.  
  197.  
  198.  
  199.  
  200.  
  201.  
  202.  Information for Cirrus Chipset Users                                         4
  203.  
  204.  
  205.  
  206. To run XF86_SVGA at a higher color depth, pass options to the X server as fol-
  207. lows:
  208.  
  209.      startx -- -bpp 16        5-6-5 RGB ('64K color', XGA)
  210.      startx -- -bpp 16 -weight 555 5-5-5 RGB ('Hicolor') (not on 5462)
  211.      startx -- -bpp 24        8-8-8 RGB truecolor
  212.      startx -- -bpp 32        8-8-8 XRGB truecolor (543X/46/6X only)
  213.  
  214.  
  215. 2.  Basic configuration
  216.  
  217. It is recommended that you generate an XF86Config file using the `XF86Setup' or
  218. `xf86config' program, which should produce a working high-resolution 8bpp con-
  219. figuration. You may want to include mode timings in the Monitor section that
  220. better fit your monitor (e.g 1152x900 modes). The driver options are described
  221. in detail in the next section; here the basic options are hinted at.
  222.  
  223. For all chipsets, a Clockchip "cirrus" line in the Device section can be use-
  224. ful. This allows the use of any dot clocks, instead of one out of the fixed set
  225. of dot clocks supported by the driver. This is required if you want a 12.6 MHz
  226. dot clock for low-resolution modes. However, when this option used, clock fre-
  227. quencies be unstable leading to strange effects, so only use it if absolutely
  228. required.
  229.  
  230. For any chip with a BitBLT engine, the new XAA (XFree86 Acceleration Architec-
  231. ture) is used. This code is new and still in a beta stage.  If graphics redraw-
  232. ing goes wrong, try the "noaccel" option; if it is using memory-mapped I/O,
  233. "no_mmio" might be sufficient.
  234.  
  235. In order to be able to run at a depth of 16bpp, 24bpp, or 32bpp, and to improve
  236. performance at 8bpp, linear addressing must be enabled. This is generally
  237.  
  238. In order to be able to run at a depth of 16bpp, 24bpp or 32bpp, and to improve
  239. performance at 8bpp, linear addressing must be enabled. Linear addressing is
  240. the default mode of operation on any PCI-bus configuration; use "nolinear" to
  241. disable it.  For other bus types, it is generally possible on 543x local bus
  242. cards, and if you have less than 16Mb of system memory, on local bus 542x cards
  243. and ISA 543x cards. You must specify the "linear" option and possibly a Membase
  244. address. See the following sections for a detailed description.
  245.  
  246. Memory-mapped I/O is the default mode of operation for any Alpine family chip.
  247. For the 5429, the "mmio" option may be used to enable it, but it has not been
  248. tested.
  249.  
  250. Finally, if you have 546X chip, it will be on either a PCI or AGP bus.  As
  251. such, there is no problem about memory mapped I/O or linear frame buffer
  252. address spaces running into system memory.  The PCI spaces are mapped way up
  253. near the 4GB point.  Because the mmio and linear frame buffer don't conflict at
  254. all on the system, the "linear", Membase, and "mmio" options are ignored (mem-
  255. ory mapped I/O  and linear addressing are always used).
  256.  
  257.  
  258.  
  259.  
  260.  
  261.  
  262.  
  263.  
  264.  
  265.  
  266.  
  267.  
  268.  Information for Cirrus Chipset Users                                         5
  269.  
  270.  
  271.  
  272. 3.  XF86Config options
  273.  
  274. Don't use the `Clocks' command. The clocks are fixed (i.e. not probed), and
  275. there should be no variation between cards (other than the maximum supported
  276. clock for each chipset).
  277.  
  278. The following options are of particular interest to the Cirrus driver. Each of
  279. them must be specified in the `svga' driver section of the XF86Config file,
  280. within the Screen subsections of the depths to which they are applicable (you
  281. can enable options for all depths by specifying them in the Device section).
  282.  
  283.       Option "noaccel"
  284.             This option will disable the use of any accelerated functions. This
  285.             is likely to help with problems related to bugs in acceleration
  286.             functions, and perhaps high dot clocks and DRAM timing, at the cost
  287.             of performance (which will still be reasonable on a local bus).
  288.  
  289.       Option "fast_dram" "med_dram"
  290.             "slow_dram" (5424/6/8/9, 543x, 5446, 546x)" These options set the
  291.             internal memory clock (MCLK, or BCLK for the 546x) register to
  292.             another value. The default value programmed by the BIOS is usually
  293.             OK, don't mess with these options unless absolutely required.
  294.  
  295.             The "fast_dram" option will cause the driver to set the internal
  296.             memory clock (MCLK) register of the video card to a higher value
  297.             (recent chips use an even higher value by default).  Normally, this
  298.             register is not touched but it appears that the standard CL-GD542x
  299.             BIOS initializes it to a value that is somewhat on the low side
  300.             (limited by the chip specification), which has a negative influence
  301.             on performance of high dot clock modes. This is especially true if
  302.             extended RAS timing is being used (this is indicated in the server
  303.             probe).  The actual speed of DRAM is not a critical factor in the
  304.             determining whether   this option is appropriate; one CL-
  305.             GD5426-based card with 80ns DRAM using Extended RAS timing, which
  306.             came with a DOS driver utility to set the MCLK to this value
  307.             (0x22), seems to run stable at higher MCLK.
  308.  
  309.             There are also (mainly brand name) cards whose customized BIOS does
  310.             initialize to a higher non-standard value.
  311.  
  312.             The "slow_dram" option will set the MCLK to the value used by the
  313.             standard CL-GD542x BIOS (0x1c). Symptoms of a MCLK that is too high
  314.             can be vertical bands of flickering pixels on the screen, erroneous
  315.             pixels appearing in text, and loosing pixels in the textmode font
  316.             after running X (note that very similar effects can be caused by an
  317.             MCLK setting that is too low).
  318.  
  319.             Upon start-up, the driver will report the value of the MCLK regis-
  320.             ter (check this first), and also any changes that are made.
  321.  
  322.             Typical MCLK values:
  323.  
  324.                   0x1c (50 MHz)
  325.                         This is usually the BIOS default.  It is forced by the
  326.  
  327.  
  328.  
  329.  
  330.  
  331.  
  332.  
  333.  
  334.  Information for Cirrus Chipset Users                                         6
  335.  
  336.  
  337.  
  338.                         "slow_dram" option.
  339.  
  340.                   0x1f (55 MHz)
  341.                         Value used by the "med_dram" option.  Highest value
  342.                         that 542x based cards seem to be able to handle with
  343.                         linear addressing enabled.
  344.  
  345.                   0x22 (60 MHz)
  346.                         Value that most (Extended RAS) 542x cards seem to be
  347.                         able to handle, used by     the "fast_dram" option.
  348.  
  349.             The official maximum of the 542x chips is 50 MHz.  The official
  350.             spec. for the 5434 is also 50 MHz (0x1c) and that for the 5429 and
  351.             5430 is probably 60 MHz (0x22). Current revisions of the 5434 (E
  352.             and greater) support 60 MHz MCLK in graphics modes, and the driver
  353.             will program this automatically. If it causes problems, use the
  354.             "slow_dram" option.
  355.  
  356.             The driver takes the MCLK into account for clock limits that are
  357.             determined by DRAM bandwidth.
  358.  
  359.             For the 546x chips, the BCLK is the Rambus access clock.  Typical
  360.             values live in the range of 258 MHz to 300 MHz.  If you have trou-
  361.             bles, such as a black checkerboard pattern on the screen, try using
  362.             the "med_dram" or "slow_dram" options.
  363.  
  364.             In all cases, if you are not having any problems (performance or
  365.             stability at high dot clocks), it is best not to use any of the
  366.             DRAM options.
  367.  
  368.       Option "no_bitblt"
  369.             This option, when used with a 5426/28/29/3x/46/6x/754x, will have
  370.             the effect of disabling the use of the BitBLT engine (which the
  371.             5424 does not have), while retaining some acceleration. This will
  372.             be useful for problems related to functions that use the BitBLT
  373.             engine.  Performance is significantly decreased.
  374.  
  375.       Option "no_imageblt"
  376.             This option is now obsolete. The "xaa_no_color_exp" option has a
  377.             somewhat similar effect.
  378.  
  379.       chipset "clgd54xx"
  380.             Force detection of the given chipset. Useful if you have a sup-
  381.             ported chipset that is not properly detected, or if you have an
  382.             unsupported chip that might be compatible with a supported one.
  383.  
  384.       videoram 1024 (or another value)
  385.             This option will override the detected amount of video memory, and
  386.             pretend the given amount of memory is present on the card. This is
  387.             useful on cards with 2Mbyte of memory whose DRAM configuration is
  388.             not compatible with the way the driver enables the upper megabyte
  389.             of memory, or if the memory detection goes wrong. It must be speci-
  390.             fied in the Device section.
  391.  
  392.  
  393.  
  394.  
  395.  
  396.  
  397.  
  398.  
  399.  
  400.  Information for Cirrus Chipset Users                                         7
  401.  
  402.  
  403.  
  404.       Option "fifo_conservative" (5424/6/8/9/3x/46/6x/754x)
  405.             This option will set the CRT FIFO threshold to a conservative value
  406.             for high dot clocks (>= 65 MHz), reducing performance but hopefully
  407.             alleviating problems with what can be described as flashing
  408.             `streaks', `jitter' or horizontally repeated display areas on the
  409.             screen (especially when   a BitBLT operation is in progress, e.g.
  410.             scrolling).
  411.  
  412.       Option "fifo_aggressive" (5424/6/8/9/3x/46/6x/754x)
  413.             This option will set the CRT FIFO threshold to an aggressive value;
  414.             it will be the same as that used for lower dot clocks.  Theoreti-
  415.             cally it improves performance at high dot clocks, but it does not
  416.             help in the vast majority of cases.  In some cases with 546x chips,
  417.             however, this option can help reduce horizontal streaks or other-
  418.             wise fix abnormal display problems (display shifted to the left,
  419.             etc.).
  420.  
  421.       Option "no_2mb_banksel" (542x)
  422.             This option will cause the driver not to set the `DRAM bank select'
  423.             bit to enable the upper megabyte of memory on a 2Mbyte card. This
  424.             should be helpful with cards equipped with 512Kx8 DRAMs, as opposed
  425.             to 256Kx4/16 DRAMs, when using a virtual screen configuration that
  426.             uses more than 1Mbyte of memory.
  427.  
  428.       Option "probe_clocks"
  429.             This option will force probing of dot clocks on the card. This
  430.             should not be necessary, since the clocks are fixed and the same
  431.             for all Cirrus chipsets.
  432.  
  433.       Clockchip "cirrus"
  434.             This enables programmable clocks. It must be specified in the
  435.             Device section. With this option, the clocks the modes use will be
  436.             automatically selected. Do not specify any Clocks line. This option
  437.             makes a 12.5 MHz clock possible for a 320x200 Doublescan mode. Note
  438.             that some frequencies may be unstable (resulting in a `wavy'
  439.             screen). Only tried and tested frequencies (like the default
  440.             clocks) are guaranteed to be stable.
  441.  
  442.       Option "linear"  (542x/6/8/9/3x/754x on VL-bus)
  443.             This enables linear addressing, which is the mapping of the entire
  444.             framebuffer to a high address beyond system memory, so that SVGA
  445.             bank switching is not necessary. It enhances performance at 256
  446.             colors, and is currently required for 16bpp, 24bpp, and 32bpp. See
  447.             section 4 for details.
  448.  
  449.       Option "nolinear"  (542x/6/8/9/3x/754x on PCI bus)
  450.             Linear addressing is the default mode of operation on any PCI-bus
  451.             chip. For these configurations, this option disables linear
  452.             addressing.
  453.  
  454.       Membase 0x00e00000 (or a different address) (542x/6/8/9/3x/46/754x)
  455.             This sets the physical memory base address of the linear frame-
  456.             buffer. It must be specified in the Device section. It is required
  457.             for non-PCI linear addressing configurations.
  458.  
  459.  
  460.  
  461.  
  462.  
  463.  
  464.  
  465.  
  466.  Information for Cirrus Chipset Users                                         8
  467.  
  468.  
  469.  
  470.       Option "favour_bitblt" (5426 only)
  471.             This option is now obsolete.
  472.  
  473.       Option "mmio" (5429, 7548)
  474.             This enables the use of memory-mapped I/O to talk to the BitBLT
  475.             engine on the 543x/5429, which is a bit faster. This is option has
  476.             no effect when not using the BitBLT engine (e.g. when using
  477.             "no_bitblt").
  478.  
  479.       Option "no_mmio" (543x/4x)
  480.             This disables the use of memory-mapped I/O to talk to the BitBLT
  481.             engine on any chip for which it is the default mode of operation.
  482.  
  483.       Option "sw_cursor" (542x/3x/46/6x)
  484.             This disables use of the hardware cursor provided by the chip. Try
  485.             this if the cursor seems to have problems. In particular, use this
  486.             when using dot clocks greater than 85 MHz on the 5434/6 since those
  487.             chips don't fully support the hardware cursor at those clocks.
  488.  
  489.       Option "clgd6225_lcd"
  490.             Provides a work-around for problems on the LCD screen of some 62x5
  491.             laptop chipsets with maximum white colors.
  492.  
  493.       Option "no_pixmap_cache"
  494.             When XAA is used (on any BitBLT chip), this option disables the use
  495.             of a pixmap cache in XAA. It could help with certain drawing bugs.
  496.  
  497.       Option "xaa_no_color_exp"
  498.             When XAA is used, this option disables the use of hardware color
  499.             expansion features by XAA. Again, this might help with certain
  500.             drawing bugs.
  501.  
  502.       Option "no_stretch" (754x)
  503.             Disable automatic stretching (horizontal and vertical expansion) of
  504.             640x480 on a 800x600 LCD.
  505.  
  506.       Option "pci_retry" (546x)
  507.             Enables a performance feature for PCI based cards.  When this fea-
  508.             ture is enabled, the driver code will attempt to transmit data on
  509.             the PCI bus as fast as possible.  For the most part, this option is
  510.             safe, but may cause trouble with other PCI devices such as PCI net-
  511.             work cards, sound cards, SCSI controllers, etc.  When this option
  512.             is not selected, a safer approach (polling the VGA's command queue)
  513.             is taken.
  514.  
  515.  
  516. 4.  Mode issues
  517.  
  518. The accelerated 256-color driver uses 16K bytes of scratch space in video mem-
  519. ory, and the hardware cursor also uses 1K (2K on the '6X). Consequently, a
  520. 1024x1024 virtual resolution should not be used with a 1Mbyte card.
  521.  
  522. On older chips, the use of a higher dot clock frequencies has a negative effect
  523. on the performance of graphics operations, especially BitBlt, when little video
  524.  
  525.  
  526.  
  527.  
  528.  
  529.  
  530.  
  531.  
  532.  Information for Cirrus Chipset Users                                         9
  533.  
  534.  
  535.  
  536. memory bandwidth is left for drawing (the amount is displayed during start-up
  537. for 542x/3x/46/6x chips).  For the 542x/3x chips, with default MCLK setting
  538. (0x1c) and a 32-bit memory interface, performance with a 65 MHz dot clock can
  539. be half of that with a dot clock of 25 MHz.  So if you are short on memory
  540. bandwidth and experience blitting slowness, try using the lowest dot clock that
  541. is acceptable; for example, on a 14" or 15" screen 800x600 with high refresh
  542. (50 MHz dot clock) is not so bad, with a large virtual screen.
  543.  
  544. 5434-based cards with 2Mbyte of memory do much better at high dot clocks; the
  545. DRAM bandwidth is basically double that of the 542x series. The 543x chips also
  546. make more efficient use of the available DRAM bandwidth. The same goes for the
  547. 544x.
  548.  
  549.  
  550. 5.  Linear addressing and 16bpp/24bpp/32bpp modes
  551.  
  552. Currently the framebuffer code 16-bit, 24-bit, and 32-bit pixels  in the SVGA
  553. server requires linear addressing.  Option "linear" can be specified in a
  554. depth-specific screen section to enable linear addressing; a MemBase setting
  555. (in the device section) is probably also required (although they are both auto-
  556. matically selected with PCI cards, like 5446, 546x, and some 543x based cards).
  557. There are a number of different card configurations.
  558.  
  559. If you have a 542x/543x on the ISA bus, and you have 16Mb or more of system
  560. memory, linear addressing is impossible. 16bpp is out, sorry.  If you have less
  561. than 14Mb of memory, you may be able to map the framebuffer at 14Mb, using
  562. `MemBase 0x00e00000'. That's five zeros after the `e'. Unfortunately many ISA
  563. cards don't support linear addressing.
  564.  
  565. If you have a 5424/26/28/29 on VESA local bus, the situation is more compli-
  566. cated. There are two different types of cards w.r.t. linear addressing:
  567.  
  568.    o Cards that can only map in the lower 16Mb, like cards on the ISA bus.
  569.      This is the case with most cards. The same restrictions apply (i.e. you
  570.      must have less than 16Mb of memory).
  571.  
  572.    o Cards that connect address line A26 and always map at 64Mb + 14Mb or 64Mb.
  573.      In this case specify `MemBase 0x04e00000' or `MemBase 0x04000000'. This
  574.      assumes you have a VLB motherboard implementation that implements A26.
  575.      Alternatively the card may map to 0x2000000, and recent cards like the
  576.      5429 usually map to 0x03e00000 (62Mb).
  577.  
  578. You will probably have to rely on trial and error. If you have less than 16Mb
  579. memory, the `wrong' membase setting will result in no graphics being displayed,
  580. but you can probably exit with ctrl-alt-backspace.
  581.  
  582. If you have >= 16Mb memory, the first type of card (and even the second type
  583. with a stupid VLB motherboard) will result in a crash (probably a spontaneous
  584. hard reboot).
  585.  
  586. It may be possible to find out the type by visual inspection. If the card has a
  587. pin at A26, it is likely to map beyond 64Mb. To do this, take the card out. At
  588. the VESA local bus pins (this is the smaller strip of connector pins at the
  589. non-slot side of the card), consider the right side (this is the side of the
  590.  
  591.  
  592.  
  593.  
  594.  
  595.  
  596.  
  597.  
  598.  Information for Cirrus Chipset Users                                        10
  599.  
  600.  
  601.  
  602. board where all the chips are mounted). There are 45 pins here. They are num-
  603. bered 1 to 45, from the inside (i.e. the one nearest to the card end is 45).
  604. Counting from the inside, the 17th pin is probably not present, then there are
  605. pins at 18-20. The 21st is A30, the 22nd is A28 and the 23rd is A26. So, if we
  606. have no pins at at 21-23, the card doesn't map beyond 64Mb. If there's only a
  607. gap of two pins at 21 and 22 (or they are both present) and there's a pin at
  608. 23, the card does probably map beyond 64Mb. If there's a little logic near that
  609. pin on the card, it's more likely.
  610.  
  611. With a 543x on the local bus things are simpler (the Cirrus Logic windows
  612. drivers use it), but it is not quite without problems.
  613.  
  614. With a card on the PCI bus, there is a PCI configuration register that holds
  615. the framebuffer base address, which is read automatically by the driver if a
  616. PCI card is detected. The `scanpci' program can read out the PCI configuration
  617. and show the base address.
  618.  
  619. On the VESA local bus, most 543x cards have a default mapping address of 64Mb,
  620. with jumper options for 2048Mb and 32Mb. This is probably described in the doc-
  621. umentation that came with the card, or look in the MS-Windows system.ini file
  622. (something with linearaddr = <offset in megabytes>). These different settings
  623. were added by Cirrus Logic after finding that many VLB motherboard implementa-
  624. tions don't implement different address pins. The driver assumes a default of
  625. 64Mb if MemBase isn't specified. A few examples for MemBase:
  626.  
  627.           MemBase   0x02000000     32Mb
  628.           MemBase   0x04000000     64Mb
  629.           MemBase   0x80000000     2048Mb
  630.  
  631. Finally, for 546X cards, you are in luck:  there are no "issues" to worry
  632. about.  The '6X will always use linear addressing and memory-mapped I/O, and
  633. will use the memory addresses up near 4GB.  Yay for PCI!
  634.  
  635. The 16bpp and 32bpp modes are now fully accelerated, thanks to XAA. On more
  636. recent chips like the 5436/46 and the 546X, 24bpp is also fully accelerated.
  637. So although there are now up to 4 times as many bits to display, the X server
  638. shouldn't feel overly sluggish.  Note also that the 24bpp and 32bpp modes are
  639. only supported on a limited set of cards, and with at least 2Mb of memory.
  640.  
  641. In the XF86Config "Screen" section, a "Display" subsection must be defined for
  642. each depth that you want to run, with separate Modes and virtual screen size.
  643. Example (2Mb of video memory):
  644.  
  645.  
  646.  
  647.  
  648.  
  649.  
  650.  
  651.  
  652.  
  653.  
  654.  
  655.  
  656.  
  657.  
  658.  
  659.  
  660.  
  661.  
  662.  
  663.  
  664.  Information for Cirrus Chipset Users                                        11
  665.  
  666.  
  667.  
  668.      Section "screen"
  669.          SubSection "Display"
  670.           Depth 8
  671.           Virtual 1280 1024
  672.           ViewPort 0 0
  673.           Modes "640x480" "800x600" "1024x768"
  674.           Option "linear"
  675.          EndSubSection
  676.          SubSection "Display"
  677.           Depth 16
  678.           Virtual 1024 992
  679.           ViewPort 0 0
  680.           Modes "640x480" "800x600" "1024x768"
  681.           Option "linear"
  682.          EndSubSection
  683.          SubSection "Display"
  684.           Depth 32
  685.           Virtual 832 600
  686.           ViewPort 0 0
  687.           Modes "640x480" "800x600"
  688.           Option "linear"
  689.          EndSubSection
  690.      EndSection
  691.  
  692.  
  693. 6.  The ``cl64xx'' Driver
  694.  
  695. The cl64xx driver supports the cl-gd6440 found in many laptops.  For example,
  696. Nan Tan Computer's NP9200, NP3600, etc., which are OEM-ed by Sager, ProStar,
  697. etc. and Texas Instruments TI4000 series are supported.
  698.  
  699. The driver works in LCD-only, CRT-only, and the chip's SimulScan mode which
  700. allows one to use both the LCD and external CRT displays simultaneously.  The
  701. LCD and Simulscan modes' resolution is 640x480 while, for CRT-only, the stan-
  702. dard VESA modes of 640x480, 600x800, and 1024x768 have been tested.  Interlaced
  703. 1024x768 mode has never been debugged and does not work on the machines tested.
  704.  
  705. The chip has a documented maximum operating limit for its dot clock that is
  706. related to its core voltage.  Specifically, for 5.0V the maximum dot clock is
  707. 65MHz and for 3.3V the maximum dot clock is 40MHz.  The driver checks the core
  708. voltage and limits the maximum dot clock to the corresponding value.  This
  709. translates to a maximum resolution of about 1024x768 at a 60Hz refresh rate.
  710. The internal frequency generator can be programmed higher than these limits and
  711. is done so during server startup when the clocks are probed which momentarily
  712. exceeding the chip's operating limit.  Once a set of valid clocks is obtained,
  713. I would recommend using Clocks lines in XF86Config.  Doing so will also
  714. decrease startup time significantly.  The clocks may be obtained by running the
  715. X server -probeonly (see the XFree86 man page for more information about
  716. -probeonly).
  717.  
  718. The data book indicates that only a configuration of one megabyte of video mem-
  719. ory is supported by the chip.  This size has been directly set in the driver.
  720. If one finds a need, one should be able to override the default size in
  721. XF86Config.  Also, with 1MB of video memory, one should be able to have a
  722.  
  723.  
  724.  
  725.  
  726.  
  727.  
  728.  
  729.  
  730.  Information for Cirrus Chipset Users                                        12
  731.  
  732.  
  733.  
  734. virtual screen size of e.g. 1024x1024 and this is possible in CRT-only screen
  735. mode.  However, whenever the LCD is in use (LCD and SimulScan), the chip uses a
  736. portion of upper video ram for its own internal acceleration purposes.  Thus,
  737. the maximum video memory available for virtual resolution in LCD modes is about
  738. 0.75MB e.g.  1024x768.  If you set the virtual resolution above this, you will
  739. see what might be described as a compressed aliased band when the accelerated
  740. area is displayed.
  741.  
  742. Currently, the driver does not support switching of screen modes among LCD,
  743. CRT, and SimulScan, and, at least on the NP9200, the mode must be chosen at OS
  744. boot time (e.g. Linux's LILO) while the BIOS is still active.  It should be
  745. possible to add screen mode type selection as a ModeLine flag option in
  746. XF86Config to allow for dynamic screen mode selection from within the X server.
  747. Finally, the driver does not currently support any of the powerdown saving fea-
  748. tures of the chip nor does it shut off the LCD's backlight on screen blank.  I
  749. hope to implement all these features in future releases.
  750.  
  751. Some notes regarding the CL-GD6420:
  752.  
  753. The amount of video memory may not always be detected correctly. The driver
  754. source code includes two methods, one defined out. Better specify the amount of
  755. video memory with a VideoRam line in the Device section. Use the standard
  756. 640x480 60 Hz standard mode timing with 25.175 MHz dot clock for CRT or
  757. SIMulscan mode; for LCD-only operation, use the same mode timing but with a dot
  758. clock of 16.257 MHz. Standard 56 Hz 800x600 is also supported on the CRT.
  759.  
  760. The primary contact for the cl6440 problems with ``cl64xx'' driver is Randy
  761. Hendry <randy@sgi.com>.
  762.  
  763.  
  764. 7.  Trouble shooting with the ``cirrus'' driver
  765.  
  766. First of all, make sure that the default modes selected from your XF86Config is
  767. supported by your monitor, i.e. make sure the horizontal sync limit is correct.
  768. It is best to start with standard 640x480x256 with a 25.175 MHz clock (by spec-
  769. ifying a single horizontal sync of 31.5) to make sure the driver works on your
  770. configuration. The default mode used will always be the first mode listed in
  771. the modes line, with the highest dot clock listed for that resolution in the
  772. timing section.
  773.  
  774. Note that some VESA standard mode timings may give problems on some monitors
  775. (try increasing the horizontal sync pulse, i.e. the difference between the mid-
  776. dle two horizontal timing values, or try multiples of 16 or 32 for all of the
  777. horizontal timing parameters).
  778.  
  779.       There is a video signal, but the screen doesn't sync.
  780.             You are using a mode that your monitor cannot handle. If it is a
  781.             non-standard mode, maybe you need to tweak the timings a bit. If it
  782.             is a standard mode and frequency that your monitor should be able
  783.             to handle, try to find different timings for a similar mode and
  784.             frequency combination.
  785.  
  786.       Horizontal jitter at high dot clocks.
  787.             This problem shows especially when drawing operations such as
  788.  
  789.  
  790.  
  791.  
  792.  
  793.  
  794.  
  795.  
  796.  Information for Cirrus Chipset Users                                        13
  797.  
  798.  
  799.  
  800.             scrolling are in progress.  If you're using a 542x/3x/46/6x/754x,
  801.             try the "fifo_conservative" option. Failing that, you can try the
  802.             "fast_dram" option, or use a lower dot clock.  If that is not suf-
  803.             ficient, the "noaccel" option or "no_bitblt" will probably help.
  804.             When using a 546x, option "fifo_aggressive" can also be tried.
  805.  
  806.       `Wavy' screen.
  807.             Horizontal waving or jittering of the whole screen, continuously
  808.             (independent from drawing operations).  You are probably using a
  809.             dot clock that is too high; it is also possible that there is
  810.             interference with a close MCLK. Try a lower dot clock. You can also
  811.             try to tweak the mode timings; try increasing the second horizontal
  812.             value somewhat. Here's a 65 MHz dot clock 1024x768 mode (about 60
  813.             Hz) that might help:
  814.  
  815.                   "1024x768"     65      1024 1116 1228 1328     768  783  789  818
  816.  
  817.  
  818.             If you are using programmable clocks with Clockchip "cirrus", try
  819.             disabling it and using the default set of clocks.
  820.  
  821.       Crash or hang after start-up (probably with a black screen).
  822.             Try the "noaccel" option. If that works, try Option "no_bitblt" for
  823.             somewhat better performance. Check that the BIOS settings are OK;
  824.             in particular, disable caching of 0xa0000-0xaffff. Disabling hidden
  825.             DRAM refresh may also help.
  826.  
  827.       Crash, hang, or trash on the screen after a graphics operation.
  828.             This may be related to a bug in one of the accelerated functions,
  829.             or a problem with the BitBLT engine. Try the "noaccel" option, or
  830.             the "no_bitblt" option. Also check the BIOS settings.
  831.  
  832.       `Blitter timeout' messages from the server.
  833.             Same as for the above entry.
  834.  
  835.       Screen is `wrapped' vertically. (542x/3x/46)
  836.             This indicates a DRAM configuration problem. If your card has two
  837.             megabytes of memory, try the "no_2mb_banksel" option, or use video-
  838.             ram "1024" if you only use 1 Mbyte for the virtual screen.
  839.  
  840.       Corrupted text in terminal window.
  841.             This has been reported on non-standard video implementations.  Use
  842.             the "no_bitblt" option.
  843.  
  844.       Streaks or hangs with laptop chipset
  845.             This can happen if the dot clock is high enough to leave very lit-
  846.             tle bandwidth for drawing (e.g. 40 MHz on a 512K card), and
  847.             (5422-style) acceleration is used.
  848.  
  849.       Occasional erroneous pixels in text, pixel dust when moving window-frame
  850.             Probably related to MCLK setting that is too high (can happen with
  851.             linear addressing even though banked mode runs OK).
  852.  
  853.  
  854.  
  855.  
  856.  
  857.  
  858.  
  859.  
  860.  
  861.  
  862.  Information for Cirrus Chipset Users                                        14
  863.  
  864.  
  865.  
  866.       Chipset is not detected.
  867.             Try forcing the chipset to a type that is most similar to what you
  868.             have.
  869.  
  870.       Incorrect little lines (mostly white) appear occasionally
  871.             This may be related to a problem with system-to-video-memory BitBLT
  872.             operations. Try the "no_imageblt" option if it annoys you.
  873.  
  874.       Textmode is not properly restored
  875.             This has been reported on some configurations. In XFree86 3.1 the
  876.             SVGA server probe would corrupt a register on the 543x, requiring a
  877.             Chipset line. Normally you should be able to restore the textmode
  878.             font using a utility that sets it (setfont, runx, restorefont on
  879.             Linux).
  880.  
  881.       Erratic system behaviour at very high dot clocks
  882.             It is possible that high dot clocks on the video card interfere
  883.             with other components in the system (e.g. disk I/O), because of a
  884.             bad card and/or motherboard design. It has been observed on some
  885.             PCI 5428-based cards (which are very rare, since the 5428 chip
  886.             doesn't support PCI).
  887.  
  888.       No mouse cursor, or cursor appears twice on screen
  889.             With high dot clocks, the graphics card's hardware cursor doesn't
  890.             operate correctly.  Try option "sw_cursor" or use a lower screen
  891.             refresh.
  892.  
  893.       Random/garbage pixels on far right or bottom of screen (546x)
  894.             This problem is usually associated with using a virtual screen size
  895.             larger than the screen display size.  The garbage pixels are unused
  896.             portions of the frame buffer that result from padding each scanline
  897.             to an integral number of memory tiles.  To eliminate the extra pix-
  898.             els, use a screen display mode whose pixel width is evenly divisi-
  899.             ble by 128 / bits per pixel.
  900.  
  901.       Screen is wrapped horizontally on right side (546x)
  902.             Same as above entry.
  903.  
  904.       The screen is initially displayed correctly, but then turns all
  905.             white. (546x)" This problem usually happens at high bit depths and
  906.             while the screen is changing rapidly (catting a long file or drag-
  907.             ging a large window around).  The RamBus memory is being over-
  908.             driven.  Use Option "med_dram", or, if the problem persists, Option
  909.             "slow_dram".
  910.  
  911. For other screen drawing related problems, try the "noaccel" option (if
  912. "no_bitblt" doesn't help).
  913.  
  914. If are having driver-related problems that are not addressed by this document,
  915. or if you have found bugs in accelerated functions, you can try contacting the
  916. XFree86 team (the current driver maintainer, Corin Anderson, can be reached at
  917. corina@the4cs.com), or post in the Usenet newsgroup "comp.windows.x.i386unix".
  918.  
  919. In fact, reports (success or failure) are very welcome, especially on
  920.  
  921.  
  922.  
  923.  
  924.  
  925.  
  926.  
  927.  
  928.  Information for Cirrus Chipset Users                                        15
  929.  
  930.  
  931.  
  932. configurations that have not been tested. You can do this via the BetaReport
  933. form (mail to report@XFree86.org). You may want to keep an eye on forthcoming
  934. beta releases at www.xfree86.org.
  935.  
  936.  
  937. 8.  Tested Configurations
  938.  
  939. Version 3.3.3 has had the following configurations tested:
  940.  
  941.       CL-GD5446 with 2MB memory on PCI bus
  942.  
  943.       CL-GD5464 with 2MB memory on PCI bus
  944.  
  945.       CL-GD5465 with 4MB memory on PCI bus
  946.  
  947.       CL-GD5480 with 4MB memory on PCI bus
  948.  
  949.       CL-GD5465 with 4MB memory on AGP bus
  950.  
  951. For version 3.3, the following configurations have received a certain amount of
  952. testing:
  953.  
  954.       CL-GD5446 with 2MB memory on PCI bus
  955.             Support for dot clocks > 85 MHz has been fixed. At 16bpp, it has
  956.             been reported that some stippled edges of window frames may be cor-
  957.             rupted or show the wrong colors. The option "xaa_no_pixmap_cache"
  958.             eliminates the problem.
  959.  
  960.       CL-GD5464 with 4MB memory on PCI bus
  961.  
  962.       CL-GD7543 on PCI bus
  963.  
  964. This is a list of configurations that has received testing with one or more of
  965. the changes introduced in version XFree86 3.2A. The amount of testing is very
  966. small for some of the configurations, and the summaries may be incomplete. If
  967. you can contribute, please do so. For the latest information check the latest
  968. version of this document on www.xfree86.org.
  969.  
  970.       CL-GD5426 on VL-bus
  971.             This configuration was only tested with an early version of the XAA
  972.             code.
  973.  
  974.       CL-GD5434 with 2MB memory on VL-bus
  975.             MMIO operation is supported. This configuration was only tested
  976.             with an early version of the XAA code.
  977.  
  978.       CL-GD5436 with 2MB memory on PCI-bus
  979.             Works OK. Non-MMIO operation might have problems.
  980.  
  981.       CL-GD5446 with 2MB memory on PCI bus
  982.             Works OK in MMIO mode. 32bpp probably doesn't work. The support for
  983.             dot clocks > 85 MHz at 8bpp may or may not work.
  984.  
  985.  
  986.  
  987.  
  988.  
  989.  
  990.  
  991.  
  992.  
  993.  
  994.  Information for Cirrus Chipset Users                                        16
  995.  
  996.  
  997.  
  998.       CL-GD5462 with 2MB memory on PCI bus
  999.  
  1000.       CL-GD5462 with 4MB memory on PCI bus
  1001.  
  1002.       CL-GD5464 with 4MB memory on PCI bus
  1003.             Works OK at 8bpp, 16bpp, 24bpp and 32bpp.  CL-GD5464 works OK at
  1004.             16bpp, -weight 555.
  1005.  
  1006.       CL-GD7543 on PCI bus
  1007.             Works for 8bpp, 16bpp on TFT display (TI TravelMate 5000).
  1008.             Although the previous version, 3.2, was reported to broken, on some
  1009.             configurations it worked, while others were reported not to work
  1010.             correctly. On 800x600 displays, the recommended dot clock is 40 MHz
  1011.             for TFT and 33.7 MHz for a DSTN panel, with corresponding horizon-
  1012.             tal syncs of 33.7 kHz for TFT and 38.6 kHz for DSTN. However,
  1013.             reports indicate that the VESA standard 40 MHz 800x600 timing may
  1014.             cause problems. The solution is decrease the fourth horizontal tim-
  1015.             ing number or use a dot clock of 36 MHz.
  1016.  
  1017. Some configurations for which no up-to-date testing data is available:
  1018.  
  1019.       CL-GD5429 on VL-bus
  1020.             BitBLT operation should be fixed in 3.2. MMIO does not work, but
  1021.             not tested with with 3.2 or 3.2A.
  1022.  
  1023.       CL-GD5430 on PCI-bus
  1024.             Works OK. 24bpp was broken, but should be fixed in later versions
  1025.             (3.2A).
  1026.  
  1027.       CL-GD5430, and CL-GD5436 and CL-GD5446 with 1MB memory
  1028.             It would be nice to know whether these chips needs the same treat-
  1029.             ment at 16bpp as the CL-GD5434 with 1MB memory does.
  1030.  
  1031.       CL-GD5434 with 1MB memory on PCI bus
  1032.             8bpp, 16pp and 24bpp work OK. 16bpp no longer has "static" prob-
  1033.             lems. MMIO operation is supported.
  1034.  
  1035.       CL-GD5436 and CL-GD5446 with 1MB memory
  1036.             In particular the FIFO settings for this configuration are uncer-
  1037.             tain.
  1038.  
  1039.       CL-GD7541
  1040.  
  1041.       CL-GD7548
  1042.             Should be compatible with 7543, but untested. Reports indicate that
  1043.             it worked with 3.2, and there's no reason why it shouldn't work
  1044.             with 3.2A.
  1045.  
  1046.  
  1047. 9.  Driver Changes
  1048.  
  1049. Changes since XFree86 3.3.2:
  1050.  
  1051.  
  1052.  
  1053.  
  1054.  
  1055.  
  1056.  
  1057.  
  1058.  
  1059.  
  1060.  Information for Cirrus Chipset Users                                        17
  1061.  
  1062.  
  1063.  
  1064.    o Fix transparent screen-to-screen copies on 546x.
  1065.  
  1066.    o The built-in screen saver now correctly blanks the screen on 546x chips.
  1067.  
  1068.    o Driver prevents the use of the HW cursor on the 546x when the screen
  1069.      height is greater than 1023 scanlines (fix to double pointer problem).
  1070.  
  1071.    o CPU-to-screen BitBLT transfers disabled on the 5465.  This fix should pre-
  1072.      vent 5465 AGP lockups.
  1073.  
  1074.    o Fixed mode display problem with 5480 at high resolutions.
  1075.  
  1076. Changes since XFree86 3.2A:
  1077.  
  1078.    o A bug that caused a server crash with memory-mapped I/O operation on some
  1079.      chips has been fixed.
  1080.  
  1081.    o Correct handling of dot clocks > 85 MHz on the 5436 and 5446.
  1082.  
  1083.    o Preliminary support for the CL-GD7555 (no detection yet).
  1084.  
  1085.    o Support has been added for the CL-GD5480 and CL-GD5465.
  1086.  
  1087.    o 32bpp mode has been fixed on some Alpine family chips.
  1088.  
  1089.    o Support for dot clocks up to 230 MHz has been added for Laguna family
  1090.      chips.
  1091.  
  1092. Changes since XFree86 3.2:
  1093.  
  1094.    o Enhanced acceleration using XAA on all chips with a BitBLT engine.
  1095.  
  1096.    o Enhanced acceleration using XAA for the Laguna series (546x).
  1097.  
  1098.    o 24bpp mode on 5430 is fixed.
  1099.  
  1100.    o Improved support for 754x, including support for LCD stretching/centering.
  1101.  
  1102.      Generated from XFree86: xc/programs/Xserver/hw/xfree86/doc/sgml/cirrus.sgml,v 3.23.2.6 1998/11/07 13:37:51 dawes Exp $
  1103.  
  1104.  
  1105.  
  1106.  
  1107.  
  1108.      $XConsortium: cirrus.sgml /main/12 1996/10/28 05:43:32 kaleb $
  1109.  
  1110.  
  1111.  
  1112.  
  1113.  
  1114.  
  1115.  
  1116.  
  1117.  
  1118.  
  1119.  
  1120.  
  1121.  
  1122.  
  1123.  
  1124.  
  1125.  
  1126.  Information for Cirrus Chipset Users                                        18
  1127.  
  1128.  
  1129.  
  1130.  
  1131.  
  1132.  
  1133.  
  1134.  
  1135.  
  1136.  
  1137.  
  1138.  
  1139.  
  1140.  
  1141.  
  1142.  
  1143.  
  1144.  
  1145.  
  1146.  
  1147.  
  1148.  
  1149.  
  1150.  
  1151.  
  1152.  
  1153.  
  1154.  
  1155.  
  1156.  
  1157.  
  1158.  
  1159.  
  1160.  
  1161.  
  1162.  
  1163.  
  1164.  
  1165.  
  1166.  
  1167.  
  1168.  
  1169.  
  1170.  
  1171.  
  1172.  
  1173.  
  1174.  
  1175.  
  1176.  
  1177.  
  1178.  
  1179.  
  1180.  
  1181.  
  1182.  
  1183.  
  1184.  
  1185.  
  1186.  
  1187.  
  1188.  
  1189.  
  1190.  
  1191.  
  1192.  
  1193.  
  1194.  
  1195.  
  1196.                                    CONTENTS
  1197.  
  1198.  
  1199.  
  1200. 1. Supported chipsets  ...................................................... 1
  1201.  
  1202. 2. Basic configuration  ..................................................... 4
  1203.  
  1204. 3. XF86Config options  ...................................................... 5
  1205.  
  1206. 4. Mode issues  ............................................................. 8
  1207.  
  1208. 5. Linear addressing and 16bpp/24bpp/32bpp modes  ........................... 9
  1209.  
  1210. 6. The ``cl64xx'' Driver ................................................... 11
  1211.  
  1212. 7. Trouble shooting with the ``cirrus'' driver ............................. 12
  1213.  
  1214. 8. Tested Configurations  .................................................. 15
  1215.  
  1216. 9. Driver Changes  ......................................................... 16
  1217.  
  1218.  
  1219.  
  1220.  
  1221.  
  1222.  
  1223.  
  1224.  
  1225.  
  1226.  
  1227.  
  1228.  
  1229.  
  1230.  
  1231.  
  1232.  
  1233.  
  1234.  
  1235.  
  1236.  
  1237.  
  1238.  
  1239.  
  1240.  
  1241.  
  1242.  
  1243.  
  1244.  
  1245.  
  1246.  
  1247.  
  1248.  
  1249.  
  1250.  
  1251.  
  1252.                                        i
  1253.  
  1254.  
  1255.