Supported hardware
The current S3 Server supports the following S3 chipsets: 911, 924,
801/805, 928, 732 (Trio32), 764, 765, 775, 785 (Trio64*),
864, 868, 964, 968 and M65 (Aurora64V+). The
S3 server will also recognise the 866, but it has not been tested with
this chipset. If you have any problems or success with these, please
report it to us.
Nevertheless, this is not enough to support every board using one of these
chipsets. The following list contains some data points on boards that are
known to work. If your card is similar to one of the described ones,
chances are good it might work for you, too.
S3 801/805, AT&T 20C490 (or similar) RAMDAC
- Orchid Fahrenheit 1280+ VLB
- Actix GE32
8 and 15/16 bpp
Note: Real AT&T20C490 RAMDACs should be automatically detected by
the server. For others which are compatible, you need to provide
a `S3 805 VLB, S3 GENDAC (RAMDAC + clock synthesizer)
- MIRO 10SD (available for VLB and PCI)
It is not known whether all 10SDs use the S3 GENDAC.
8 and 15/16 bpp
ClockChip "s3gendac"
RamDac "s3gendac"
S3 801/805, AT&T 20C490 RAMDAC, ICD2061A Clockchip
- STB PowerGraph X.24 S3 (ISA)
8 and 15/16 bpp
Note: Real AT&T20C490 RAMDACs should be automatically detected by
the server. For others which are compatible, you need to provide
a `
ClockChip "icd2061a"
RamDac "att20c490"
Option "dac_8_bit
S3 805, Diamond SS2410 RAMDAC, ICD2061A Clockchip
- Diamond Stealth 24 VLB
8 and 15bpp(*) only.
requires `S3 801/805, Chrontel 8391 Clockchip/Ramdac
- JAX 8241
- SPEA Mirage
8 and 15/16 bpp.
The 8391 is compatible with the AT&T 20C490 RAMDAC
ClockChip "ch8391"
Ramdac "ch8391"
Option "dac_8_bit"
S3 928, AT&T 20C490 RAMDAC
- Actix Ultra
8 and 15/16 bpp
Note: Real AT&T20C490 RAMDACs should be automatically detected by
the server. For others which are compatible, you need to provide
a `S3 928, Sierra SC15025 RAMDAC, ICD2061A Clockchip
- ELSA Winner 1000 ISA/EISA (``TwinBus'', not Winner1000ISA!!)
- ELSA Winner 1000 VL
8, 15/16 and 24(32) bpp
Supports 8bit/pixel RGB in 8bpp and gamma correction for 15/16
and 24bpp modes
24 bpp might get ``snowy'' if the clock is near the limit of
30MHz. This is not considered dangerous, but limits the
usability of 24 bpp.
D-step (or below) chips cannot be used with a line width of
1152; hence the most effective mode for a 1 MB board is about
1088x800x8 (similar to 2 MB, 1088x800x16).
ClockChip "icd2061a"
S3 928, Bt9485 RAMDAC, ICD2061A Clockchip
- STB Pegasus VL
8, 15/16 and 24(32) bpp
Supports RGB with sync-on-green if
ClockChip "icd2061a"
Option "stb_pegasus"
S3 928, Bt485 RAMDAC, SC11412 Clockchip
- SPEA Mercury 2MB VL
8, 15/16 and 24(32) bpp
ClockChip "SC11412"
Option "SPEA_Mercury"
S3 928, Bt485 RAMDAC, ICD2061A Clockchip
- #9 GXE Level 10, 11, 12
8, 15/16 and 24(32) bpp
ClockChip "icd2061a"
Option "number_nine"
S3 928, Ti3020 RAMDAC, ICD2061A Clockchip
- #9 GXE Level 14, 16
8, 15/16 and 24(32) bpp
Supports RGB with sync-on-green
ClockChip "icd2061a"
Option "number_nine"
S3 864, AT&T20C498, ICS2494 Clockchip
- MIRO 20SD (BIOS 1.xx)
The ICS2494 is a fixed frequency clockchip, you have to use
X -probeonly (without a Clocks line in XF86Config) to get the
correct clock values.
8, 15/16 and 24(32) bpp
S3 864, AT&T20C498 or STG1700 RAMDAC, ICD2061A or ICS9161 Clockchip
- Elsa Winner1000PRO VLB
- Elsa Winner1000PRO PCI
- MIRO 20SD (BIOS 2.xx)
- Actix GraphicsENGINE 64 VLB/2MB
8, 15/16 and 24(32) bpp
ClockChip "icd2061a"
S3 864, 20C498 or 21C498 RAMDAC, ICS2595 Clockchip
- SPEA MirageP64 2MB DRAM (BIOS 3.xx)
8, 15/16 and 24(32) bpp
Clockchip support is still sometimes flaky and on some machines
problems with the first mode after startup of XF86_S3 or after
switching back from VT have been seen; switching to next mode
with CTRL+ALT+``KP+'' and back seems to solve this problem.
Interlaced modes don't work correctly.
Mirage P64 with BIOS 4.xx uses the S3 SDAC.
ClockChip "ics2595"
S3 864, S3 86C716 SDAC RAMDAC and Clockchip
- Elsa Winner1000PRO
- MIRO 20SD (BIOS 3.xx)
- SPEA MirageP64 2MB DRAM (BIOS 4.xx)
- Diamond Stealth 64 DRAM
8, 15/16 and 24 bpp
S3 864, ICS5342 RAMDAC and Clockchip
- Diamond Stealth 64 DRAM (only some cards)
8, 15/16 and 24 bpp
ClockChip "ics5342"
Ramdac "ics5342"
S3 864, AT&T21C498-13 RAMDAC, ICD2061A Clockchip
- #9 GXE64 - PCI
8, 15/16, 24(32) bpp
ClockChip "icd2061a"
Option "number_nine"
S3 964, AT&T 20C505 RAMDAC, ICD2061A Clockchip
- Miro Crystal 20SV
8, 15/16, 24(32) bpp
ClockChip "icd2061a"
Ramdac "att20c505"
S3 964, Bt485 RAMDAC, ICD2061A Clockchip
- Diamond Stealth 64
8, 15/16, 24(32) bpp
ClockChip "icd2061a"
S3 964, Bt9485 or AT&T 20C505 RAMDAC, ICS9161a Clockchip
- SPEA Mercury 64
8, 15/16, 24(32) bpp
ClockChip "ics9161a"
Option "SPEA_Mercury"
S3 964, Ti3020 RAMDAC, ICD2061A Clockchip
- Elsa Winner2000PRO PCI
8, 15/16, 24(32) bpp
ClockChip "icd2061a"
S3 964, Ti3025 RAMDAC, Ti3025 Clockchip
- Miro Crystal 40SV
- #9 GXE64 Pro VLB
- #9 GXE64 Pro PCI
8 bpp, 15, 16 and 24(32) bpp
There are some known problems with the GXE64 Pro support,
including some image shifting/wrapping at 15/16/24 bpp.
We have found that #9 no longer support the GXE64 Pro
at 1600x1200. They do however have a new (and more expensive)
board called the GXE64Pro-1600 which uses a 220MHz RAMDAC
instead of 135MHz part used on the other boards.
S3 764 (Trio64)
- SPEA Mirage P64 (BIOS 5.xx)
- Diamond Stealth 64 DRAM
- #9 GXE64 Trio64
8/15/16/24 bpp
Note: The Trio64 has a builtin RAMDAC and clockchip, so the server
should work with all Trio64 cards, and there is no need to specify
the RAMDAC or clockchip in the S3 732 (Trio32)
- Diamond Stealth 64 DRAM SE
8/15/16/24 bpp
Note: The Trio32 has a builtin RAMDAC and clockchip, so the server
should work with all Trio32 cards, and there is no need to specify
the RAMDAC or clockchip in the S3 868, S3 86C716 SDAC RAMDAC and Clockchip
- ELSA Winner 1000AVI
- Diamond Stealth Video DRAM
8/15/16/24 bpp
S3 868, AT&T 20C409 RAMDAC and Clockchip
- ELSA Winner 1000AVI
8/15/16/24 bpp
Note: pixelmultiplexing is not supported yet, therefore limited
maximum dot clock for 8bpp (currently 67.5MHz, should be changed
to 100MHz if pixmux isn't fixed prior to release)
S3 968, Ti3026 RAMDAC, Ti3026 Clockchip
- Elsa Winner 2000PRO/X-2 and /X-4 (Revsions <= F)
- Elsa Winner 2000AVI-2 and -4
- Diamond Stealth 64 VIDEO VRAM
8/15/16/24 bpp
S3 968, Ti3026 RAMDAC, ICS9161A Clockchip
- Elsa Winner 2000PRO/X-2 and /X-4 (Revision G)
8/15/16/24 bpp
Note: clock doubling doesn't work, yet, therefore the maximum
usable dot clock is limited to about 120MHz.
S3 964, IBM RGB 514/524/525/528 RAMDAC & Clockchip
- Hercules Graphics Terminator 64
8/15/16/24 bpp
s3RefClk 50
DACspeed 170
Option "slow_vram"
S3 968, IBM RGB 514/524/525/528 RAMDAC & Clockchip
- Genoa Genoa VideoBlitz III AV
s3RefClk 50
DACspeed 170
- Hercules Graphics Terminator Pro 64
s3RefClk 16
DACspeed 220
This card may require the line:
Invert_VCLK "*" 0
in each Display subsection.
- STB Velocity 64
s3RefClk 24
DACspeed 220
- Number Nine FX Motion 771
s3RefClk 16
DACspeed 220
This card may require the line:
Invert_VCLK "*" 0
in each Display subsection.
- MIRO 80SV
s3RefClk 16
DACspeed 250
8/15/16/24 bpp
ELSA Winner 2000PRO/X-8 (S3 968, 8MB VRAM, 220MHz for 32bpp)
The server has only been tested for "revision C" of this card
(guess the serial number should start with C, but not sure since
mine says Ser.No. A-0000.000.000;) which have an IBM RGB528A
note the A; can't be probed though)
depending on the mode line etc there may be some display distortions like:
- many long horizontal lines/stripes
- pixel jitter or short horizontal stripes like snow all over the
screen
- Like 2., but only when doing graphics ops (like opaque move of
windows).
- additional pixel at the left display edge and some missing pixels
at the right edge.
All of these problems can be fixed by small adjustments to the mode line
(best to run `xvidtune' and make these adjustments interactively). E.g.,
for the first three problems, shift the display left or right a few steps.
For the last problem, increasing HSyncEnd (making the hsync pulse longer)
solves the problem. In some cases, a significant increase in the sync
pulse width is needed, and rarely, it needs to be shortened (by decreasing
HSyncEnd).
In rare cases, InvertVCLK and/or EarlySC may need to be adjusted, followed
by an adjustment of BlankDelay (see the bottom line of xvidtune).
If you see any of these problems, please contact
, and
send details of:
- Original mode showing the problem,
- Tuned/fixed mode, including all flags from the bottom line of
xvidtune,
- Colour depth used for this tuned mode line,
- Full server startup output.
16bpp and 32bpp
On 801/805 + AT&T490 Cards (like the Fahrenheit 1280+ VLB) only 15 and
16bpp are supported. 32bpp isn't available on this type of
card. (There is a 24 bit mode under MS Windows, but it's not a 32bpp
sparse mode but a real 3 bytes/pixel mode).
List of Supported Clock Chips
ICD2061A ==> ClockChip "icd2061a"
ICS9161A (ICD2061A compatible) ==> ClockChip "ics9161a"
DCS2824-0 (Diamond, ICD2061A comp.) ==> ClockChip "dcs2824"
S3 86c708 GENDAC ==> ClockChip "s3gendac"
ICS5300 GENDAC (86c708 compatible) ==> ClockChip "ics5300"
S3 86c716 SDAC ==> ClockChip "s3_sdac"
ICS5342 GENDAC ==> ClockChip "ics5342"
STG 1703 ==> ClockChip "stg1703"
Sierra SC11412 ==> ClockChip "sc11412"
ICS2595 ==> ClockChip "ics2595"
TI3025 ==> ClockChip "ti3025"
TI3026 ==> ClockChip "ti3026"
IBM RGB 5xx ==> ClockChip "ibm_rgb5xx"
Chrontel 8391 ==> ClockChip "ch8391"
AT&T 20C409 ==> ClockChip "att20c409"
AT&T 20C499 (untested) ==> ClockChip "att20c499"
List of Supported RAMDAC Chips
If you have a RAMDAC that is not listed here, be VERY careful not to
overdrive it using XF86_S3. Better contact the XFree86 team first to
verify that running XF86_S3 will not damage your board.
RAMDACs that are grouped together below are treated as compatible
with each other as far as the server is concerned. For example, the
server will report "bt485" when you actually specify
RAMDAC "bt9485", or "s3_gendac" when you specify
RAMDAC "ics5300".
ATT20C409 ==> RAMDAC "att20c409"
ATT20C490 ==> RAMDAC "att20c490"
ATT20C491 ==> RAMDAC "att20c491"
CH8391 ==> RAMDAC "ch8391"
ATT20C498 ==> RAMDAC "att20c498"
ATT21C498 ==> RAMDAC "att21c498"
ATT22C498 ==> RAMDAC "att22c498"
ATT20C505 ==> RAMDAC "att20c505"
BT485 ==> RAMDAC "bt485"
BT9485 ==> RAMDAC "bt9485"
IBMRGB514 ==> RAMDAC "ibm_rgb514"
IBMRGB525 ==> RAMDAC "ibm_rgb525"
IBMRGB524 ==> RAMDAC "ibm_rgb524"
IBMRGB526 ==> RAMDAC "ibm_rgb526"
IBMRGB528 ==> RAMDAC "ibm_rgb528"
S3_GENDAC ==> RAMDAC "s3gendac"
ICS5300 ==> RAMDAC "ics5300"
S3_SDAC ==> RAMDAC "s3_sdac"
ICS5342 ==> RAMDAC "ics5342"
S3_TRIO32 ==> RAMDAC "s3_trio32"
S3_TRIO64 ==> RAMDAC "s3_trio64"
S3_TRIO64 ==> RAMDAC "s3_trio"
SC11482 ==> RAMDAC "sc11482"
SC11483 ==> RAMDAC "sc11483"
SC11484 ==> RAMDAC "sc11484"
SC11485 ==> RAMDAC "sc11485"
SC11487 ==> RAMDAC "sc11487"
SC11489 ==> RAMDAC "sc11489"
SC15025 ==> RAMDAC "sc15025"
STG1700 ==> RAMDAC "stg1700"
STG1703 ==> RAMDAC "stg1703"
TI3020 ==> RAMDAC "ti3020"
TI3025 ==> RAMDAC "ti3025"
TI3026 ==> RAMDAC "ti3026"
None of the above ==> RAMDAC "normal"
If you feel adventurous you could also open up your computer and have
a peek at your RAMDAC. The RAMDAC is usually one of the larger chips
(second or third largest chip that is NOT an EPROM) on the board. The
markings on it are usually
-
For example:
@@@@
@@@@ AT&T
ATT20C490-11
9339S ES
9869874
This is an AT&T 20C490 with a speed grade of 110 MHz. This would then mean
that you put a `
S3 86C716-ME SDAC ==> DacSpeed 110
SC15025-8 ==> DacSpeed 80
ATT20C490-80 ==> DacSpeed 80
IBM 8190429 ==> DacSpeed 170
IBM 03H5428 ==> DacSpeed 170
IBM 03H6447 ==> DacSpeed 170
IBM 03H6448 ==> DacSpeed 220
IBM 03H5319 ==> DacSpeed 220
IBM 63G9902 ==> DacSpeed 250
IBM 37RGB514CF17 ==> DacSpeed 170
IBM 37RGB524CF22 ==> DacSpeed 220
^^
Additional Notes
Note that the Sierra SC1148{5,7,9} will not be distinguished from the
Sierra SC1148{2,3,4} by the probe. The only difference between the
two series as far as the server is concerned is that the {2,3,4} is
capable of 15bpp, while the {5,7,9} is capable of 16bpp. So if you
have a SC1148{5,7,9} and want to use 16bpp instead of 15bpp, you will
have to specify a RAMDAC "sc11485" line as shown above.
Some RAMDACs (like the Ti3025) require some mode timing consideration
for their hardware cursor to work correctly. The Ti3025 requires that
the mode have a back porch of at least 80 pixel-clock cycles. A
symptom of this not being correct is the HW cursor being chopped off
when positioned close to the right edge of the screen.
Reference clock value for IBM RGB 5xx RAMDACs
Cards with IBM RGB5xx RAMDACs use several different input frequencies
for the clock synthesizer which can't be probed without some knowledge
of the text mode clocks (which may be a wrong assumption if you're using
non-standard text modes). Here is the procedure you should use to
find out the input frequency:
First run
X -probeonly >& outfile
and check the output for the probed clock chip which might look like this:
(--) S3: Using IBM RGB52x programmable clock (MCLK 66.000 MHz)
(--) S3: with refclock 16.000 MHz (probed 15.952 & 16.041)
^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^
there will be a "good guessed" value which will be used
and two probed values in brackets based on the 25MHz and 28MHz
text clocks. This probing can only work if you run a normal 80x25
or 80x28 text mode!
The refclock values known so far are:
STB Velocity 64 24 Mhz
Genoa VideoBlitz II AV 50 MHz
Hercules S3 964 50 MHz
Hercules S3 968 16 MHz
#9 Motion 771 16 MHz
depending on the quartz on your card and maybe other features like
an additional clock chip on the Genoa card (which as a 14.3MHz quartz).
If you claim that your card has a 16MHz clock, but it really uses 50MHz,
all pixel clocks will be tripled and a 640x480 mode with 25MHz will
use a 75MHz pixel clock, so be very careful.
If you found the right refclock, you should set it in the config file
(device section) e.g. with
s3RefClk 16
or
s3RefClk 50
so that that this value will be used even if you use another text
mode and probing fails!
Hints for LCD configuration (S3 Aurora64V+)
If LCD is active the CRT will always output 1024x768 (or whatever is
the _physical_ LCD size) and smaller modes are zoomed to fit on the LCD
unless you specify Option "lcd_center" in the device section.
The pixel clock for this physical size (e.g. 1024x768) mode...
- ...can explicitly set in the config file (device section) with e.g. `Set_LCDClk 70'
(resulting 70 MHz pixel clock being used for all modes when LCD is on)
- ...is taken from the _first_ mode in the modes line iff this mode's display size
is the same as the physical LCD size
- ...the default LCD pixel clock of BIOS initialisation setup is used.
This value is output at server startup in the line `LCD size ...'
unless you're specifying a value using `Set_LCDClk ...'
If LCD is _not_ active, the normal mode lines and pixel clocks
are used for the VGA output.
Whenever you switch output sources with Fn-F5,
the Xserver won't get informed and pixel clock and other settings are wrong.
Because of this you have to switch modes _after_ switch output sources!
Then the server will check which outputs are active and select the correct
clocks etc.
So the recommended key sequence to switch output is
Fn-F5 Ctrl-Alt-Plus Ctrl-Alt-Minus
and everything should be ok..
on the Toshiba keypad you can first hold down Ctrl-Alt, then press `Fn' additionally
before pressing Plus/Minus too to avoid to explicitly enable/disable
the numeric keypad for mode switching.
How to avoid ``snowing'' display while performing graphics operations
For cards with the S3 Vision864 chip, there is an automatic correction which
depends on the pixel clock and the memory clock MCLK at which the S3 chip
operates. For most clock chips this value can't be read (only the S3 SDAC
allows reading the MCLK value so far), so this value has to be estimated
and specified by the user (the default is 60 [MHz]).
With the new `
s3MCLK 55
for a 55 MHz MCLK which will reduce snowing. Smaller MCLK values will reduce
performance a bit so you shouldn't use a too low value (55 or 50 should be a
good guess in most cases).
Below is a small shell script which might be useful to determine the
approximate value for MCLK (about +/- 1-2 MHz error). Before running
this script you have to add the line
s3MNadjust -31 255
to the device section in your
#!/bin/sh
exec 2> /dev/null
scale=2
calc() {
m=`awk 'BEGIN{printf "%.'$scale'f\n",'"( $1 + $2 ) / $3; exit}" `
[ -z "$m" ] && m=` echo "scale=$scale; ( $1 + $2 ) / $3" | bc `
[ -z "$m" ] && m=` echo "$scale $1 $2 + $3 / pq" | dc `
echo $m
}
run_xbench() {
r=` ( echo 1; echo 2; echo 3; echo 4 ) | xbench -only $1 | grep rate `
[ -z "$r" ] && return
cp="$2 $3"
set $r
calc $3 $cp
}
run_x11perf() {
r=` x11perf $1 | grep trep | tr '(/)' ' ' `
[ -z "$r" ] && return
cp="$2 $3"
set $r
calc `calc 1000 0 $4` $cp
}
run_x11perf "-rect500 -rop GXxor" 3.86 5.53 # 0 1 # 4.11 5.52 #
run_xbench invrects500 4.63 5.48 # 0 1 # 4.69 5.48 #
run_x11perf "-rect500 -rop GXcopy" -16.42 13.90 # 0 1 # -14.99 13.88 #
run_xbench fillrects500 -7.81 13.57 # 0 1 # -8.53 13.58 #
exit
New S3 SVGA driver
There is a new experimental S3 driver for
non-ViRGE S3 chipsets in the XF86_SVGA server. This is definitely
an ALPHA quality driver and hasn't been well tested, and has some known
problems.
Because of this, the configuration programs will install XF86_S3 by
default rather than this one. But if you're adventurous or had some
problems with XF86_S3, you might want to give it a try.
The driver includes generic S3 support which should work on
all non-ViRGE S3 chips (in theory, that is). It also has improved
support for chips that support S3's new style memory mapped I/O.
These chips include the 868, 968 and recent Trio64 variants (not
the plain old Trio64s). Chips that are capable of using the new
style MMIO will use it automatically. The option "NO_MMIO" can
be used to turn this off.
Performance for chips using the new style MMIO is expected
to be better than XF86_S3, especially on a PCI bus. Performance
without MMIO, however, is expected to be roughly comparable
to XF86_S3 (faster in some areas, slower in others).
All color depths achievable with XF86_S3 should be possible
with these drivers. Additionally, packed 24 bpp "sort of" works
for the 868 and 968. Your results may vary.
Nearly all the options and features supported by XF86_S3
are supported by this driver. Additionally, the standard XAA/SVGA
server options such as NO_ACCEL, SW_CURSOR, and NO_PIXMAP_CACHE are
also supported. XF86_S3 features which are NOT supported in this
driver are DPMS support and gamma correction.
The driver supports the PCI_RETRY option when using MMIO and
a PCI card. This option can give large performance boosts for
some operations, but has a tendency to hog the bus. Because
of this, the option is not set by default. Most hardware
combinations may not have any problems using this option, but
sound card glitches during intensive graphics operations have
been reported on some.
One shortcoming worth noting is that this driver does not yet
contain the work-around for some S3 PCI BIOSs that report
their memory usage incorrectly. This can result in conflicting
address spaces. If this is the case on your hardware you should
run XF86_S3 once and write down the address that your card is
relocated to (as printed out in the server output). Then you can
force the server to use this address with the MemBase field in the
XF86Config (see the man page on XF86Config).
$XFree86: xc/programs/Xserver/hw/xfree86/doc/sgml/S3.sgml,v 3.38 1999/08/23 06:38:52 dawes Exp $
$XConsortium: S3.sgml /main/14 1996/02/21 17:45:58 kaleb $