Mercurial > mplayer.hg
annotate DOCS/video.html @ 6478:feb97a44080b
added yvu9
author | alex |
---|---|
date | Fri, 21 Jun 2002 16:01:18 +0000 |
parents | d0d74f9d8d4a |
children | ce4647b864e5 |
rev | line source |
---|---|
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
1612 | 2 <HTML> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4920
diff
changeset
|
3 |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4920
diff
changeset
|
4 <HEAD> |
6391 | 5 <LINK REL="stylesheet" TYPE="text/css" HREF="default.css"> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
6 <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1"> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4920
diff
changeset
|
7 </HEAD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4920
diff
changeset
|
8 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
9 <BODY> |
1704 | 10 |
1612 | 11 |
2745 | 12 <P><B><A NAME=2.3.1>2.3.1. Video output devices</A></B></P> |
1612 | 13 |
14 | |
2745 | 15 <P><B><A NAME=2.3.1.1>2.3.1.1. Setting up MTRR</A></B></P> |
1612 | 16 |
1946 | 17 <P>It is VERY recommended to check if the MTRR registers are set up properly, |
18 because they can give a big performance boost.</P> | |
19 | |
20 <P>Do a '<CODE>cat /proc/mtrr</CODE>' :</P> | |
21 | |
22 <P><CODE> | |
23 --($:~)-- cat /proc/mtrr<BR> | |
24 reg00: base=0xe4000000 (3648MB), size= 16MB: write-combining, count=9<BR> | |
25 reg01: base=0xd8000000 (3456MB), size= 128MB: write-combining, count=1<BR> | |
26 </CODE></P> | |
27 | |
28 <P>It's right, shows my Matrox G400 with 16Mb memory. I did this from | |
29 XFree 4.x.x , which sets up MTRR registers automatically.</P> | |
30 | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
31 <P>If nothing worked, you have to do it manually. First, you have to find the base |
1946 | 32 address. |
1682 | 33 You have 3 ways to find it:</P> |
1612 | 34 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
35 <UL> |
1682 | 36 <LI>from X11 startup messages, for example: |
37 <P><CODE>(--) SVGA: PCI: Matrox MGA G400 AGP rev 4, Memory @ 0xd8000000, 0xd4000000<BR> | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
38 (--) SVGA: Linear framebuffer at 0xD8000000</CODE></P></LI> |
1682 | 39 <LI>from /proc/pci (use lspci -v command): |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
40 <P> |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
41 <CODE>01:00.0 VGA compatible controller: Matrox Graphics, Inc.: Unknown device 0525</CODE> |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
42 <CODE>Memory at d8000000 (32-bit, prefetchable)</CODE> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
43 </P></LI> |
1682 | 44 <LI>from mga_vid kernel driver messages (use dmesg): |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
45 <P><CODE>mga_mem_base = d8000000</CODE></P></LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
46 </UL> |
1612 | 47 |
1682 | 48 <P>Then let's find the memory size. This is very easy, just convert video ram |
49 size to hexadecimal, or use this table:</P> | |
1612 | 50 |
1682 | 51 <TABLE BORDER=0> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
52 <TR><TD> </TD><TD>1 MB</TD><TD WIDTH="10%"></TD><TD>0x100000</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
53 <TR><TD></TD><TD>2 MB</TD><TD></TD><TD>0x200000</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
54 <TR><TD></TD><TD>4 MB</TD><TD></TD><TD>0x400000</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
55 <TR><TD></TD><TD>8 MB</TD><TD></TD><TD>0x800000</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
56 <TR><TD></TD><TD>16 MB</TD><TD></TD><TD>0x1000000</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
57 <TR><TD></TD><TD>32 MB</TD><TD></TD><TD>0x2000000</TD></TR> |
1682 | 58 </TABLE> |
1612 | 59 |
60 | |
1682 | 61 <P>You know base address and memory size, let's setup mtrr registers! |
62 For example, for the Matrox card above (base=0xd8000000) with 32MB | |
63 ram (size=0x2000000) just execute:</P> | |
1612 | 64 |
65 | |
1682 | 66 <P><CODE> echo "base=0xd8000000 size=0x2000000 type=write-combining" >| /proc/mtrr</CODE></P> |
1612 | 67 |
68 | |
1682 | 69 <P>Not all CPUs support MTRRs. For example older K6-2's [around 266Mhz, |
70 stepping 0] doesn't support MTRR, but stepping 12's do ('<CODE>cat /proc/cpuinfo</CODE>' | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
71 to check it').</P> |
1612 | 72 |
2745 | 73 <P><B><A NAME=2.3.1.2>2.3.1.2. Xv</A></B></P> |
1612 | 74 |
1682 | 75 <P>Under XFree86 4.0.2 or newer, you can use your card's hardware YUV routines |
4498 | 76 using the XVideo extension. This is what the option '-vo xv' uses. Also, |
77 this is driver supports adjusting brightness/contrast/hue/etc (unless you use | |
78 the old, slow DirectShow DivX codec, which supports it everywhere), see the | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
79 man page.</P> |
4498 | 80 |
81 <P>In order to make this work, be sure to check the following:</P> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
82 <UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
83 <LI>You have to use XFree86 4.0.2 or newer (former versions don't have XVideo)</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
84 <LI>Your card actually supports hardware acceleration (modern cards do)</LI> |
1682 | 85 <LI>X loads the XVideo extension, it's something like this: |
1612 | 86 |
1682 | 87 <P><CODE> (II) Loading extension XVideo</CODE></P> |
88 <P>in /var/log/XFree86.0.log</P> | |
1612 | 89 |
1682 | 90 <P>NOTE: this loads only the XFree86's extension. In a good install, this is |
91 always loaded, and doesn't mean that the _card's_ XVideo support is loaded!</P> | |
1612 | 92 |
1682 | 93 <LI>Your card has Xv support under Linux. To check, try 'xvinfo', it is the |
94 part of the XFree86 distribution. It should display a long text, similar | |
95 to this: | |
96 <PRE> | |
1612 | 97 X-Video Extension version 2.2 |
98 screen #0 | |
99 Adaptor #0: "Savage Streams Engine" | |
100 number of ports: 1 | |
101 port base: 43 | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
102 operations supported: PutImage |
1612 | 103 supported visuals: |
104 depth 16, visualID 0x22 | |
105 depth 16, visualID 0x23 | |
106 number of attributes: 5 | |
107 (...) | |
108 Number of image formats: 7 | |
109 id: 0x32595559 (YUY2) | |
110 guid: 59555932-0000-0010-8000-00aa00389b71 | |
111 bits per pixel: 16 | |
112 number of planes: 1 | |
113 type: YUV (packed) | |
114 id: 0x32315659 (YV12) | |
115 guid: 59563132-0000-0010-8000-00aa00389b71 | |
116 bits per pixel: 12 | |
117 number of planes: 3 | |
118 type: YUV (planar) | |
119 (...etc...) | |
1682 | 120 </PRE> |
1612 | 121 |
1682 | 122 <P>It must support YUY2 packed, and YV12 planar pixel formats to be |
123 usable with <B>MPlayer</B>.</P> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
124 </LI> |
1612 | 125 |
1682 | 126 <LI>And finally, check if <B>MPlayer</B> was compiled with 'xv' support. |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
127 ./configure prints this.</LI> |
1612 | 128 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
129 </UL> |
1682 | 130 |
2745 | 131 <P><B><A NAME=2.3.1.2.1>2.3.1.2.1. 3dfx cards</A></B></P> |
1612 | 132 |
1682 | 133 <P>Older 3dfx drivers were known to have problems with XVideo acceleration, |
134 it didn't support either YUY2 or YV12, and so. Verify that you have | |
5116 | 135 XFree86 version 4.2.0 or greater, it works ok with YV12 and YUY2. Previous |
136 versions, including 4.1.0 <B>crashes with YV12</B>! | |
1682 | 137 If you experience strange effects using -vo xv, try SDL (it has XVideo too) |
2745 | 138 and see if it helps. Check the <A HREF="#2.3.1.4">SDL section</A> for details.</P> |
1612 | 139 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
140 <P><B>OR</B>, try the NEW -vo tdfxfb driver! See the <A HREF="#2.3.1.9">2.3.1.9</A> |
1992 | 141 section!</P> |
1612 | 142 |
2865 | 143 |
2745 | 144 <P><B><A NAME=2.3.1.2.2>2.3.1.2.2. S3 cards</A></B></P> |
1682 | 145 |
146 <P>S3 Savage3D's should work fine, but for Savage4, use XFree86 version 4.0.3 | |
3942 | 147 or greater (in case of image problems, try 16bpp). As for S3 Virge.. there is |
148 xv support, but the card itself is very slow, so you better sell it.</P> | |
1682 | 149 |
3027 | 150 <P><B>NOTE</B>: Savage cards have a slow YV12 image displaying capability (it needs |
2883 | 151 to do YV12->YUY2 conversion, because the Savage hardware can't display YV12). |
152 So when this documentation says at some point "this has YV12 output use this, | |
4920
089485d69edd
added notes about enhanced Neomagic and Savage4 drivers
gabucino
parents:
4908
diff
changeset
|
153 it's faster", it's not sure. Try <A HREF="http://www.mplayerhq.hu/MPlayer/contrib/Savage-driver/savage_drv.o.mmx2.bz2">this |
089485d69edd
added notes about enhanced Neomagic and Savage4 drivers
gabucino
parents:
4908
diff
changeset
|
154 driver</A>, it uses MMX2 for this task and is faster than the native X driver.</P> |
2865 | 155 |
156 | |
2745 | 157 <P><B><A NAME=2.3.1.2.3>2.3.1.2.3. nVidia cards</A></B></P> |
1612 | 158 |
3938 | 159 <P>nVidia isn't a very good choice under Linux (according to NVidia, this |
160 is <A HREF="users_against_developers.html#nvidia">not true</A>).. You'll have to use the | |
3290 | 161 binary closed-source nVidia driver, available at nVidia's website. The standard XFree86 |
1682 | 162 driver doesn't support XVideo for these cards, due to nVidia's closed |
163 sources/specifications.</P> | |
1612 | 164 |
3290 | 165 <P>As far as I know the latest XFree86 driver contains XVideo support for |
166 Geforce 2 and 3.</P> | |
167 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
168 <P>Riva128 cards don't have XVideo support even with the nvidia driver :( |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
169 Complain to NVidia.</P> |
1612 | 170 |
171 | |
2745 | 172 <P><B><A NAME=2.3.1.2.4>2.3.1.2.4. ATI cards</A></B></P> |
1612 | 173 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
174 <UL> |
4177 | 175 <LI>The <A HREF="http://www.linuxvideo.org/gatos">GATOS driver</A> (which you |
176 should use, unless you have Rage128 or Radeon) has VSYNC enabled by default. It | |
177 means that decoding speed (!) is synced to the monitor's refresh rate. If | |
178 playing seems to be slow, try disabling VSYNC somehow, or set refresh rate to | |
179 n*(fps of the movie) Hz.</LI> | |
1920 | 180 |
181 <LI>Radeon VE - currently only XFree86 CVS has driver for this card, version | |
3027 | 182 4.1.0 doesn't. And no TV out support. Of course with <B>MPlayer</B> you can |
183 happily get <B>accelerated</B> display, with or without <B>TV output</B>, and | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
184 no libraries or X are needed. Read <A HREF="#2.3.1.15">Vidix</A> section.</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
185 </UL> |
1612 | 186 |
187 | |
2745 | 188 <P><B><A NAME=2.3.1.2.5>2.3.1.2.5. NeoMagic cards</A></B></P> |
1922
5f0e4310dd4d
NeoMagic stuff added (legyen egyszer gyereknap...)
gabucino
parents:
1920
diff
changeset
|
189 |
4920
089485d69edd
added notes about enhanced Neomagic and Savage4 drivers
gabucino
parents:
4908
diff
changeset
|
190 <P>These cards can be found in many laptops. Unfortunately, the driver in |
089485d69edd
added notes about enhanced Neomagic and Savage4 drivers
gabucino
parents:
4908
diff
changeset
|
191 X 4.2.0 can't do Xv, but we have a modified, Xv-capable driver for you. |
089485d69edd
added notes about enhanced Neomagic and Savage4 drivers
gabucino
parents:
4908
diff
changeset
|
192 <A HREF="http://www.mplayerhq.hu/MPlayer/contrib/NeoMagic-driver/neomagic_drv.o.4.2.0.bz2">Download from here</A>. |
5359 | 193 Driver provided by Stefan Seyfried.</P> |
5378 | 194 |
195 <P>To allow playback of DVD sized content change your XF86Config like this :</P> | |
196 | |
197 <P> | |
5359 | 198 Section "Device"<BR> |
199 <I>[...]</I><BR> | |
200 Driver "neomagic"<BR> | |
201 <B>Option "OverlayMem" "829440"</B><BR> | |
202 <I>[...]</I><BR> | |
5378 | 203 EndSection |
5359 | 204 </P> |
1922
5f0e4310dd4d
NeoMagic stuff added (legyen egyszer gyereknap...)
gabucino
parents:
1920
diff
changeset
|
205 |
5378 | 206 |
3794 | 207 <P><B><A NAME=2.3.1.2.6>2.3.1.2.6. Trident cards</A></B></P> |
208 | |
209 <P>If you want to use xv with a trident card, provided that it doesn't | |
210 work with 4.1.0, try the latest cvs of Xfree or wait for Xfree 4.2.0. | |
211 The latest cvs adds support for fullscreen xv support with the | |
212 Cyberblade XP card.</P> | |
1922
5f0e4310dd4d
NeoMagic stuff added (legyen egyszer gyereknap...)
gabucino
parents:
1920
diff
changeset
|
213 |
2745 | 214 <P><B><A NAME=2.3.1.3>2.3.1.3. DGA</A></B></P> |
1612 | 215 |
2745 | 216 <P><B><A NAME=2.3.1.3.1>2.3.1.3.1. Summary</A></B></P> |
1612 | 217 |
1682 | 218 <P>This document tries to explain in some words what DGA is in general and |
219 what the DGA video output driver for mplayer can do (and what it can't).</P> | |
1612 | 220 |
221 | |
2745 | 222 <P><B><A NAME=2.3.1.3.2>2.3.1.3.2. What is DGA</A></B></P> |
1612 | 223 |
1682 | 224 <P>DGA is short for Direct Graphics Access and is a means for a program to |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
225 bypass the X-Server and directly modifying the framebuffer memory. |
1682 | 226 Technically spoken this happens by mapping the framebuffer memory into |
227 the memory range of your process. This is allowed by the kernel only | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
228 if you have superuser privileges. You can get these either by logging in |
1682 | 229 as root or by setting the suid bit on the mplayer excecutable (NOT |
230 recommended!).</P> | |
1612 | 231 |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
232 <P>There are two versions of DGA: DGA1 is used by XFree 3.x.x and DGA2 was |
1682 | 233 introduced with XFree 4.0.1.</P> |
1612 | 234 |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
235 <P>DGA1 provides only direct framebuffer access as described above. For |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
236 switching the resolution of the video signal you have to rely on the |
1682 | 237 XVidMode extension.</P> |
1612 | 238 |
1682 | 239 <P>DGA2 incorporates the features of XVidMode extension and also allows |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
240 switching the depth of the display. So you may, although basically |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
241 running a 32 bit depth XServer, switch to a depth of 15 bits and vice |
1682 | 242 versa. </P> |
1612 | 243 |
1682 | 244 <P>However DGA has some drawbacks. It seems it is somewhat dependent on the |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
245 graphics chip you use and on the implementation of the XServer's video |
1682 | 246 driver that controls this chip. So it does not work on every system ...</P> |
1612 | 247 |
248 | |
2745 | 249 <P><B><A NAME=2.3.1.3.3>2.3.1.3.3. Installing DGA support for MPlayer</A></B></P> |
1682 | 250 |
251 <P>First make sure X loads the DGA extension, see in /var/log/XFree86.0.log:</P> | |
252 | |
253 <P> <CODE>(II) Loading extension XFree86-DGA</CODE></P> | |
254 | |
255 <P>See, XFree86 4.0.x or greater is VERY RECOMMENDED! | |
256 <B>MPlayer</B>'s DGA driver is autodetected on ./configure, or you can force it | |
257 with --enable-dga.</P> | |
1612 | 258 |
1682 | 259 <P>If the driver couldn't switch to a smaller resolution, experiment with |
260 switches -vm (only with X 3.3.x), -fs, -bpp, -zoom to find a video mode that | |
261 the movie fits in. There is no converter right now.. :(</P> | |
1612 | 262 |
1682 | 263 <P>Become ROOT. DGA needs root access to be able to write directly video memory. |
264 If you want to run it as user, then install <B>MPlayer</B> SUID root:</P> | |
1612 | 265 |
1682 | 266 <P><CODE> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
267 chown root /usr/local/bin/mplayer<BR> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
268 chmod 750 /usr/local/bin/mplayer<BR> |
1686 | 269 chmod +s /usr/local/bin/mplayer</CODE></P> |
1612 | 270 |
271 | |
1682 | 272 <P>Now it works as a simple user, too.</P> |
1612 | 273 |
274 | |
1682 | 275 <P><B>!!!! BUT STAY TUNED !!!!</B><BR> |
276 This is a <B>BIG</B> security risk! Never do this on a server or on a computer | |
277 can be accessed by more people than only you because they can gain root | |
278 privilegies through suid root mplayer.<BR> | |
279 <B>!!!! SO YOU HAVE BEEN WARNED ... !!!!</B></P> | |
280 | |
281 <P>Now use '-vo dga' option, and there you go! (hope so:) | |
282 You should also try if the '-vo sdl:dga' option works for you! It's much | |
283 faster!!!</P> | |
284 | |
2745 | 285 <P><B><A NAME=2.3.1.3.4>2.3.1.3.4. Resolution switching</A></B></P> |
1682 | 286 |
287 <P>The DGA driver allows for switching the resolution of the output signal. | |
288 This avoids the need for doing (slow) software scaling and at the same | |
289 time provides a fullscreen image. Ideally it would switch to the exact | |
290 resolution (except for honouring aspect ratio) of the video data, but the | |
1686 | 291 XServer only allows switching to resolutions predefined in |
1682 | 292 <CODE>/etc/X11/XF86Config</CODE> (<CODE>/etc/X11/XF86Config-4</CODE> for XFree 4.0.X respectively). |
293 Those are defined by so-called modelines and depend on the capabilites | |
294 of your video hardware. The XServer scans this config file on startup and | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
295 disables the modelines not suitable for your hardware. You can find |
1682 | 296 out which modes survive with the X11 log file. It can be found at: |
297 <CODE>/var/log/XFree86.0.log</CODE>.</P> | |
298 <P>See appendix A for some sample modeline definitions.</P> | |
299 | |
2745 | 300 <P><B><A NAME=2.3.1.3.5>2.3.1.3.5. DGA & MPlayer</A></B></P> |
1612 | 301 |
1682 | 302 <P>DGA is used in two places with <B>MPlayer</B>: The SDL driver can be made to make |
303 use of it (-vo sdl:dga) and within the DGA driver (-vo dga). | |
304 The above said is true for both; in the following sections I'll explain | |
305 how the DGA driver for <B>MPlayer</B> works.</P> | |
1612 | 306 |
2745 | 307 <P><B><A NAME=2.3.1.3.6>2.3.1.3.6. Features of the DGA driver</A></B></P> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
308 |
1682 | 309 <P>The DGA driver is invoked by specifying -vo dga at the command line. |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
310 The default behaviour is to switch to a resolution matching the original |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
311 resolution of the video as close as possible. It deliberately ignores the |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
312 -vm and -fs switches (enabling of video mode switching and fullscreen) - |
1682 | 313 it always tries to cover as much area of your screen as possible by switching |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
314 the video mode, thus refraining to use a single additional cycle of your CPU |
1682 | 315 to scale the image. |
316 If you don't like the mode it chooses you may force it to choose the mode | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
317 matching closest the resolution you specify by -x and -y. |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
318 By providing the -v option, the DGA driver will print, among a lot of other |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
319 things, a list of all resolutions supported by your current XF86-Config |
1682 | 320 file. |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
321 Having DGA2 you may also force it to use a certain depth by using the -bpp |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
322 option. Valid depths are 15, 16, 24 and 32. It depends on your hardware |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
323 whether these depths are natively supported or if a (possibly slow) |
1682 | 324 conversion has to be done.</P> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
325 |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
326 <P>If you should be lucky enough to have enough offscreen memory left to |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
327 put a whole image there, the DGA driver will use doublebuffering, which |
1682 | 328 results in much smoother movie replaying. It will tell you whether double- |
329 buffering is enabled or not.</P> | |
1612 | 330 |
1682 | 331 <P>Doublebuffering means that the next frame of your video is being drawn in |
332 some offscreen memory while the current frame is being displayed. When the | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
333 next frame is ready, the graphics chip is just told the location in memory |
1682 | 334 of the new frame and simply fetches the data to be displayed from there. |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
335 In the meantime the other buffer in memory will be filled again with new |
1682 | 336 video data.</P> |
337 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
338 <P>Doublebuffering may be switched on by using the option -double and may be |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
339 disabled with -nodouble. Current default option is to disable |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
340 doublebuffering. When using the DGA driver, onscreen display (OSD) only |
1682 | 341 works with doublebuffering enabled. However, enabling doublebuffering may |
342 result in a big speed penalty (on my K6-II+ 525 it used an additional 20% of | |
343 CPU time!) depending on the implementation of DGA for your hardware.</P> | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
344 |
1682 | 345 |
2745 | 346 <P><B><A NAME=2.3.1.3.7>2.3.1.3.7. Speed issues</A></B></P> |
1682 | 347 |
348 <P>Generally spoken, DGA framebuffer access should be at least as fast as using | |
349 the X11 driver with the additional benefit of getting a fullscreen image. | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
350 The percentage speed values printed by mplayer have to be interpreted with |
1682 | 351 some care, as for example, with the X11 driver they do not include the time |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
352 used by the X-Server needed for the actual drawing. Hook a terminal to a |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
353 serial line of your box and start top to see what is really going on in your |
1682 | 354 box ...</P> |
355 | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
356 <P>Generally spoken, the speedup done by using DGA against 'normal' use of X11 |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
357 highly depends on your graphics card and how well the X-Server module for it |
1682 | 358 is optimized.</P> |
359 | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
360 <P>If you have a slow system, better use 15 or 16bit depth since they require |
1682 | 361 only half the memory bandwidth of a 32 bit display.</P> |
1612 | 362 |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
363 <P>Using a depth of 24bit is even a good idea if your card natively just supports |
1682 | 364 32 bit depth since it transfers 25% less data compared to the 32/32 mode.</P> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
365 |
1682 | 366 <P>I've seen some avi files already be replayed on a Pentium MMX 266. AMD K6-2 |
367 CPUs might work at 400 MHZ and above.</P> | |
1612 | 368 |
2745 | 369 <P><B><A NAME=2.3.1.3.8>2.3.1.3.8. Known bugs</A></B></P> |
1682 | 370 |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
371 <P>Well, according to some developpers of XFree, DGA is quite a beast. They |
1682 | 372 tell you better not to use it. Its implementation is not always flawless |
373 with every chipset driver for XFree out there.</P> | |
1612 | 374 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
375 <UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
376 <LI>With XFree 4.0.3 and nv.o there is a bug resulting in strange colors.</LI> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
377 <LI>ATI driver requires to switch mode back more than once after finishing |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
378 using of DGA.</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
379 <LI>Some drivers simply fail to switch back to normal resolution (use |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
380 Ctrl-Alt-Keypad +, - to switch back manually).</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
381 <LI>Some drivers simply display strange colors.</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
382 <LI>Some drivers lie about the amount of memory they map into the process's |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
383 address space, thus vo_dga won't use doublebuffering (SIS?).</LI> |
1682 | 384 <LI>some drivers seem to fail to report even a single valid mode. In this |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
385 case the DGA driver will crash telling you about a nonsense mode of |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
386 100000x100000 or the like ...</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
387 <LI>OSD only works with doublebuffering enabled.</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
388 </UL> |
1682 | 389 |
2745 | 390 <P><B><A NAME=2.3.1.3.9>2.3.1.3.9. Future work</A></B></P> |
1682 | 391 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
392 <UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
393 <LI>use of the new X11 render interface for OSD</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
394 <LI>where is my TODO list ???? :-(((</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
395 </UL> |
1612 | 396 |
397 | |
2745 | 398 <P><B><A NAME=2.3.1.3.A>2.3.1.3.A. Some modelines</A></B></P> |
1612 | 399 |
1682 | 400 <PRE> |
1612 | 401 Section "Modes" |
402 Identifier "Modes[0]" | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
403 Modeline "800x600" 40 800 840 968 1056 600 601 605 628 |
1612 | 404 Modeline "712x600" 35.0 712 740 850 900 400 410 412 425 |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
405 Modeline "640x480" 25.175 640 664 760 800 480 491 493 525 |
1612 | 406 Modeline "400x300" 20 400 416 480 528 300 301 303 314 Doublescan |
407 Modeline "352x288" 25.10 352 368 416 432 288 296 290 310 | |
408 Modeline "352x240" 15.750 352 368 416 432 240 244 246 262 Doublescan | |
409 Modeline "320x240" 12.588 320 336 384 400 240 245 246 262 Doublescan | |
410 EndSection | |
1682 | 411 </PRE> |
1612 | 412 |
1682 | 413 <P>These entries work fine with my Riva128 chip, using nv.o XServer driver |
414 module.</P> | |
1612 | 415 |
416 | |
2745 | 417 <P><B><A NAME=2.3.1.3.B>2.3.1.3.B. Bug Reports</A></B></P> |
1612 | 418 |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
419 <P>If you experience troubles with the DGA driver please feel free to file |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
420 a bug report to me (e-mail address below). Please start mplayer with the |
1682 | 421 -v option and include all lines in the bug report that start with vo_dga:</P> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
422 |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
423 <P>Please do also include the version of X11 you are using, the graphics card |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
424 and your CPU type. The X11 driver module (defined in XF86-Config) might |
1682 | 425 also help. Thanks!</P> |
1612 | 426 |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
427 |
1682 | 428 <P><I>Acki (acki@acki-netz.de, www.acki-netz.de)</I></P> |
1612 | 429 |
430 | |
2745 | 431 <P><B><A NAME=2.3.1.4>2.3.1.4. SDL</A></B></P> |
1612 | 432 |
3988 | 433 <P>SDL (Simple Directmedia Layer) is basically an unified video/audio |
434 interface. Programs that use it know only about SDL, and not about what video | |
435 or audio driver does SDL actually use. For example a Doom port using SDL can | |
436 run on svgalib, aalib, X, fbdev, and others, you only have to specify the | |
437 (for example) video driver to use with the SDL_VIDEODRIVER environment | |
438 variable. Well, in theory.</P> | |
439 | |
440 <P>With <B>MPlayer</B>, we used its X11 driver's software scaler ability for | |
441 cards/drivers that doesn't support XVideo, until we made our own (faster, | |
442 nicer) software scaler. Also we used its aalib output, but now we have ours | |
443 which is more comfortable. Its DGA mode was better than ours, until | |
444 recently. Get it now? :)</P> | |
445 | |
446 <P>It also helps with some buggy drivers/cards if the video is jerky | |
447 (not slow system problem), or audio is lagging.</P> | |
448 | |
5119 | 449 <P>SDL video output supports displaying subtitles under the movie, on the (if |
450 present) black bar.</P> | |
451 | |
1682 | 452 <P>Here are some notes about SDL out in <B>MPlayer</B>.</P> |
1612 | 453 |
454 | |
455 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
456 <TABLE BORDER=0> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
457 <TR><TD COLSPAN=4><P><B>There are several commandline switches for SDL:</B></P></TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
458 <TR><TD> </TD><TD>-vo sdl:name</TD><TD> </TD><TD> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
459 specifies sdl video driver to use (ie. aalib, dga, x11)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
460 <TR><TD></TD><TD>-ao sdl:name</TD><TD></TD><TD>specifies sdl audio driver to use (ie. dsp, |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
461 esd, arts)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
462 <TR><TD></TD><TD>-noxv</TD><TD></TD><TD>disables Xvideo hardware acceleration</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
463 <TR><TD></TD><TD>-forcexv</TD><TD></TD><TD>tries to force Xvideo acceleration</TD></TR> |
1612 | 464 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
465 <TR><TD COLSPAN=4><P><B>SDL Keys:</B></P></TD></TR> |
1612 | 466 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
467 <TR><TD></TD><TD>F</TD><TD></TD><TD>toggles fullscreen/windowed mode</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
468 <TR><TD></TD><TD>C</TD><TD></TD><TD>cycles available fullscreen modes</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
469 <TR><TD></TD><TD>W/S</TD><TD></TD><TD>mappings for * and / (mixer control)</TD></TR> |
1612 | 470 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
471 </TABLE> |
1612 | 472 |
1682 | 473 <P><B>KNOWN BUGS:</B></P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
474 <UL><LI>Keys pressed under sdl:aalib console driver repeat forever. (use -vo aa !) |
1682 | 475 It's bug in SDL, I can't change it (tested with SDL 1.2.1). |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
476 </UL> |
1612 | 477 |
2745 | 478 <P><B><A NAME=2.3.1.5>2.3.1.5. SVGAlib</A></B></P> |
1682 | 479 |
480 <P>If you don't have X, you can use the SVGAlib target! Be sure not to use the | |
481 -fs switch, since it toggles the usage of the software scaler, and it's | |
482 SLOOOW now, unless you have a real fast CPU (and/or MTRR?). :(</P> | |
1612 | 483 |
1682 | 484 <P>Of course you'll have to install svgalib and its development package in |
485 order for <B>MPlayer</B> build its SVGAlib driver (autodetected, but can be | |
486 forced), and don't forget to edit /etc/vga/libvga.config to suit your | |
487 card & monitor.</P> | |
1612 | 488 |
2745 | 489 <P><B><A NAME=2.3.1.6>2.3.1.6. Framebuffer output (FBdev)</A></B></P> |
1682 | 490 |
491 <P>Whether to build the FBdev target is autodetected during ./configure . | |
492 Read the framebuffer documentation in the kernel sources | |
493 (Documentation/fb/*) for info on how to enable it, etc.. !</P> | |
1612 | 494 |
1682 | 495 <P>If your card doesn't support VBE 2.0 standard (older ISA/PCI |
496 cards, such as S3 Trio64), only VBE 1.2 (or older?) : | |
497 Well, VESAfb is still available, but you'll have to load SciTech Display | |
498 Doctor (formerly UniVBE) before booting Linux. Use a DOS boot disk or | |
499 whatever. And don't forget to register your UniVBE ;))</P> | |
1612 | 500 |
1682 | 501 <P>The FBdev output takes some additional parameters above the others:</P> |
1612 | 502 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
503 <TABLE BORDER=0> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
504 <TR><TD> </TD><TD>-fb</TD><TD> </TD><TD> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
505 specify the framebuffer device to use (/dev/fb0)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
506 <TR><TD></TD><TD>-fbmode</TD><TD></TD><TD>mode name to use (according to /etc/fb.modes)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
507 <TR><TD></TD><TD>-fbmodeconfig</TD><TD></TD><TD> config file of modes (default /etc/fb.modes)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
508 <TR><TD></TD><TD>-monitor_hfreq</TD><TD></TD><TD ROWSPAN=3>IMPORTANT values, see example.conf</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
509 <TR><TD></TD><TD>-monitor_vfreq</TD><TD></TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
510 <TR><TD></TD><TD>-monitor_dotclock</TD><TD></TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
511 </TABLE> |
1612 | 512 |
1682 | 513 <P>If you want to change to a specific mode, then use</P> |
1612 | 514 |
1682 | 515 <P><CODE> mplayer -vm -fbmode (NameOfMode) filename</CODE></P> |
1612 | 516 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
517 <UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
518 <LI><B>-vm</B> alone will choose the most suitable mode from /etc/fb.modes . Can be |
1682 | 519 used together with -x and -y options too. The -flip option is supported only |
520 if the movie's pixel format matches the video mode's pixel format. | |
521 Pay attention to the bpp value, fbdev driver tries to use the current, | |
2507 | 522 or if you specify the -bpp option, then that.</LI> |
1682 | 523 <LI><B>-zoom</B> option isn't supported (software scaling is slow). -fs option |
2507 | 524 isn't supported. You can't use 8bpp (or less) modes.</LI> |
4701 | 525 <LI>you possibly want to turn the cursor off : <CODE>echo -e '\033[?25l'</CODE> |
526 or <CODE>setterm -cursor off</CODE><BR> | |
2507 | 527 and the screen saver: <CODE>setterm -blank 0</CODE><BR> |
528 To turn the cursor back on : <CODE>echo -e '\033[?25h'</CODE> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
529 or <CODE>setterm -cursor on</CODE></LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
530 </UL> |
1612 | 531 |
1682 | 532 <P>NOTE: FBdev video mode changing _does not work_ with the VESA framebuffer, |
533 and don't ask for it, since it's not an <B>MPlayer</B> limitation.</P> | |
1612 | 534 |
2745 | 535 <P><B><A NAME=2.3.1.7>2.3.1.7. Matrox framebuffer (mga_vid)</A></B></P> |
1612 | 536 |
1992 | 537 <P>This section is about the Matrox G200/G400/G450/G550 BES (Back-End Scaler) |
1682 | 538 support, the mga_vid kernel driver. It's active developed by me (A'rpi), and |
539 it has hardware VSYNC support with triple buffering. It works on both | |
540 framebuffer console and under X.</P> | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
541 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
542 <P><B>WARNING</B>: on non-Linux systems, use <A HREF="#2.3.1.15">Vidix</A> for |
4505
fdeee8424d90
on non-Linux use Vidix instead of mga_vid kernelmodule
gabucino
parents:
4504
diff
changeset
|
543 mga_vid !!!</P> |
fdeee8424d90
on non-Linux use Vidix instead of mga_vid kernelmodule
gabucino
parents:
4504
diff
changeset
|
544 |
1682 | 545 <P>To use it, you first have to compile mga_vid.o:</P> |
1612 | 546 |
1682 | 547 <P><CODE> cd drivers<BR> |
548 make</CODE></P> | |
1612 | 549 |
1682 | 550 <P>Then create /dev/mga_vid device:</P> |
1612 | 551 |
1682 | 552 <P><CODE> mknod /dev/mga_vid c 178 0</CODE></P> |
1612 | 553 |
1682 | 554 <P>and load the driver with</P> |
555 | |
556 <P><CODE> insmod mga_vid.o</CODE></P> | |
1612 | 557 |
1682 | 558 <P>You should verify the memory size detection using the 'dmesg' command. If |
559 it's bad, use the mga_ram_size option (rmmod mga_vid first), specify card's | |
560 memory size in MB:</P> | |
1612 | 561 |
1682 | 562 <P><CODE> insmod mga_vid.o mga_ram_size=16</CODE></P> |
1612 | 563 |
3664
f3a20477f042
added "copy mga_vid to /lib/modules" to install instructions
gabucino
parents:
3583
diff
changeset
|
564 <P>To make it load/unload automatically when needed, first insert the following line |
1682 | 565 at the end of /etc/modules.conf:</P> |
1612 | 566 |
1682 | 567 <P><CODE> alias char-major-178 mga_vid</CODE></P> |
1612 | 568 |
3664
f3a20477f042
added "copy mga_vid to /lib/modules" to install instructions
gabucino
parents:
3583
diff
changeset
|
569 <P>Then copy the <CODE>mga_vid.o</CODE> module to the appropriate place under |
f3a20477f042
added "copy mga_vid to /lib/modules" to install instructions
gabucino
parents:
3583
diff
changeset
|
570 <CODE>/lib/modules/<kernel version>/somewhere</CODE>.</P> |
f3a20477f042
added "copy mga_vid to /lib/modules" to install instructions
gabucino
parents:
3583
diff
changeset
|
571 |
1682 | 572 <P>Then run</P> |
1612 | 573 |
1682 | 574 <P><CODE> depmod -a</CODE></P> |
1612 | 575 |
1682 | 576 <P>Now you have to (re)compile <B>MPlayer</B>, ./configure will detect /dev/mga_vid |
577 and build the 'mga' driver. Using it from <B>MPlayer</B> goes by '-vo mga' if | |
578 you have matroxfb console, or '-vo xmga' under XFree86 3.x.x or 4.x.x.</P> | |
579 | |
2108 | 580 <P>The mga_vid driver cooperates with Xv.</P> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
581 |
4504 | 582 <P>The <CODE>/dev/mga_vid</CODE> device file can be read (for example by |
583 <CODE>cat /dev/mga_vid</CODE>) for some info, and written for brightness | |
584 change : <CODE>echo "brightness=120" > /dev/mga_vid</CODE></P> | |
585 | |
1612 | 586 |
2745 | 587 <P><B><A NAME=2.3.1.8>2.3.1.8. SiS 6326 framebuffer (sis_vid)</A></B></P> |
1682 | 588 |
589 <P>SiS 6326 YUV Framebuffer driver -> sis_vid kernel driver</P> | |
1612 | 590 |
1682 | 591 <P>Its interface should be compatible with the mga_vid, but the driver was not |
592 updated after the mga_vid changes, so it's outdated now. Volunteers | |
593 needed to test it and bring the code up-to-date.</P> | |
1612 | 594 |
2745 | 595 <P><B><A NAME=2.3.1.9>2.3.1.9. 3dfx YUV support (tdfxfb)</A></B></P> |
1612 | 596 |
1992 | 597 <P>This driver uses the kernel's tdfx framebuffer driver to play movies with |
598 YUV acceleration. You'll need a kernel with tdfxfb support, and recompile with | |
599 <CODE>./configure --enable-tdfxfb</CODE></P> | |
1612 | 600 |
2745 | 601 <P><B><A NAME=2.3.1.10>2.3.1.10. OpenGL output</A></B></P> |
1612 | 602 |
6309 | 603 <P><B>MPlayer</B> supports displaying movies using OpenGL, but if your |
604 platform/driver supports xv as should be the case on a PC with Linux, use xv | |
605 instead, OpenGL performance is considerably worse. If you have an X11 | |
606 implementation without xv support, OpenGL is a viable alternative.</P> | |
607 | |
608 <P>Unfortunately not all drivers support this feature. The Utah-GLX drivers | |
609 (for XFree86 3.3.6) support it for all cards. See | |
610 <A HREF="http://utah-glx.sourceforge.net">http://utah-glx.sourceforge.net</A> | |
1682 | 611 for details about how to install it.</P> |
1612 | 612 |
6309 | 613 <P>XFree86(DRI) >= 4.0.3 supports OpenGL with Matrox and Radeon cards, >= 4.2 |
614 supports Rage128. See | |
615 <A HREF="http://dri.sourceforge.net">http://dri.sourceforge.net</A> | |
616 for download and installation instructions.</P> | |
1612 | 617 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
618 <P><B><A NAME=2.3.1.11>2.3.1.11. AAlib - text mode displaying</A></B></P> |
1612 | 619 |
1682 | 620 <P><B>AAlib</B> is a library for displaying graphics in text mode, using powerful |
621 ASCII renderer. There are LOTS of programs already supporting it, like Doom, | |
622 Quake, etc. MPlayer contains a very usable driver for it. | |
623 If ./configure detects aalib installed, the aalib libvo driver will be built.</P> | |
1612 | 624 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
625 <TABLE BORDER=0> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
626 <TR><TD COLSPAN=4><P><B>You can use some keys in the AA Window to change rendering options:</B></P></TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
627 <TR><TD> </TD><TD>1</TD><TD> </TD><TD>decrease contrast</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
628 <TR><TD></TD><TD>2</TD><TD></TD><TD>increase contrast</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
629 <TR><TD></TD><TD>3</TD><TD></TD><TD>decrease brightness</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
630 <TR><TD></TD><TD>4</TD><TD></TD><TD>increase brightness</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
631 <TR><TD></TD><TD>5</TD><TD></TD><TD>switch fast rendering on/off</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
632 <TR><TD></TD><TD>6</TD><TD></TD><TD>set dithering mode (none, error distribution, floyd steinberg)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
633 <TR><TD></TD><TD>7</TD><TD></TD><TD>invert image</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
634 <TR><TD></TD><TD>a</TD><TD></TD><TD>toggles between aa and mplayer control)</TD></TR> |
1682 | 635 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
636 <TR><TD COLSPAN=4><P><B>The following command line options can be used:</B></P></TD></TR> |
1612 | 637 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
638 <TR><TD></TD><TD>-aaosdcolor=V</TD><TD></TD><TD>change osd color</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
639 <TR><TD></TD><TD>-aasubcolor=V</TD><TD></TD><TD>change subtitle color</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
640 <TR><TD COLSPAN=3></TD><TD><P><I>where V can be: (0/normal, 1/dark, 2/bold, 3/boldfont, 4/reverse, 5/special)</I></P></TD></TR> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
641 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
642 <TR><TD COLSPAN=4><P><B>AAlib itselves provides a large sum of options. |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
643 Here are some important:</B></P></TD></TR> |
1682 | 644 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
645 <TR><TD></TD><TD>-aadriver</TD><TD></TD><TD>set recommended aa driver (X11, curses, linux)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
646 <TR><TD></TD><TD>-aaextended</TD><TD></TD><TD>use all 256 characters</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
647 <TR><TD></TD><TD>-aaeight</TD><TD></TD><TD>use eight bit ascii</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
648 <TR><TD></TD><TD>-aahelp</TD><TD></TD><TD>prints out all aalib options</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
649 </TABLE> |
1682 | 650 |
651 <P>NOTE: the rendering is very CPU intensive, especially when using AA-on-X | |
652 (using aalib on X), and it's least CPU intensive on standard, | |
653 non-framebuffer console. Use SVGATextMode to set up a big textmode, | |
654 then enjoy! (secondary head Hercules cards rock :)) (anyone can enhance | |
655 bdev to do conversion/dithering to hgafb? Would be neat :)</P> | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
656 |
1682 | 657 <P>Use the -framedrop option if your comp isn't fast enough to render all frames!</P> |
1612 | 658 |
1682 | 659 <P>Playing on terminal you'll get better speed and quality using the linux driver, not |
660 curses (-aadriver linux). But therefore you need write access on /dev/vcsa<terminal>! | |
661 That isn't autodetected by aalib, bu vo_aa tries to find the best mode. | |
1731 | 662 See <A HREF="http://aa-project.sourceforge.net/tune/">http://aa-project.sourceforge.net/tune/</A> for further tuning issues.</P> |
1612 | 663 |
2471 | 664 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
665 <P><B><A NAME=2.3.1.12>2.3.1.12. VESA - output to VESA BIOS</A></B></P> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
666 <P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
667 This driver was designed and introduced as <B>generic driver</B> for any video |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
668 card which has VESA VBE 2.0 compatible BIOS. But exists still one reason of |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
669 developing of this driver - it's multiple troubles with displaying movie on TV.<BR> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
670 <B>VESA BIOS EXTENSION (VBE) Version 3.0 Date: September 16, 1998</B> (Page 70) |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
671 says: |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
672 </P> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
673 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
674 <BLOCKQUOTE> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
675 <B>Dual-Controller Designs</B><BR> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
676 VBE 3.0 supports the dual-controller design by assuming that since both |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
677 controllers are typically provided by the same OEM, under control of a |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
678 single BIOS ROM on the same graphics card, it is possible to hide the fact |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
679 that two controllers are indeed present from the application. This has the |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
680 limitation of preventing simultaneous use of the independent controllers, |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
681 but allows applications released before VBE 3.0 to operate normally. The |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
682 VBE Function 00h (Return Controller Information) returns the combined |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
683 information of both controllers, including the combined list of available modes. |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
684 When the application selects a mode, the appropriate controller is activated. |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
685 Each of the remaining VBE functions then operates on the active controller. |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
686 </BLOCKQUOTE> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
687 |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
688 <P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
689 So you have chances to get working TV-out by using this driver.<BR> |
2471 | 690 (I guess that TV-out frequently is standalone head or standalone output |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
691 at least.) |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
692 </P> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
693 |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
694 <P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
695 <B>What are pluses:</B><BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
696 - You have chances to watch movies <B>if Linux even doesn't know</B> your video hardware.<BR> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
697 - You don't need to have installed any graphics' related things on your Linux |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
698 (like X11 (aka XFree86), fbdev and so on). This driver can be run from |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
699 <B>text-mode</B>.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
700 - You have chances to get <B>working TV-out</B>. (It's known at least for ATI's cards).<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
701 - This driver calls <B>int 10h</B> handler thus it's not an emulator - it |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
702 calls <B>real</B> things of <B>real</B> BIOS in <B>real</B>-mode. (Finely - |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
703 in vm86 mode).<BR> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
704 - Most important :) You can watch <B>DVD at 320x200</B> if you don't have a powerful CPU.<BR> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
705 </P> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
706 |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
707 <P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
708 <B>What are minuses:</B><BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
709 - It works only on <B>x86 systems</B>.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
710 - <B>It's the slowest driver</B> from all the available ones for MPlayer.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
711 (But only if your card doesn't support <B>DGA mode</B> - otherwise this |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
712 driver is comparable by speed with <B>-vo dga</B> and <B>-vo fbdev</B> ones.<BR> |
2747 | 713 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
714 - It can be used only by <B>ROOT</B>.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
715 - Currently it's available only for <B>Linux</B>.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
716 - It <B>doesn't use</B> any <B>hardware accelerations</B> (like YUV overlay or hw scaling).<BR> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
717 </P> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
718 |
3141 | 719 <P>Don't use this driver with <B>GCC 2.96</B> ! It won't work !</P> |
720 | |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
721 <TABLE BORDER=0> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
722 <TR><TD COLSPAN=4><P><B>These switches of command line currently are available for VESA:</B></P></TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
723 <TR><TD> </TD><TD>-vo vesa:opts</TD><TD></TD><TD>currently recognized: <B>dga</B> to force dga mode and <B>nodga</B> to disable dga mode. Note: you may omit these parameters to enable <B>autodetect</B> of dga mode. (In the future also will specify mode parameters such as refresh rate, interlacing, doublescan and so on. Samples: i43, 85, d100)</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
724 <TR><TD></TD><TD>-screenw, -screenh, -bpp</TD><TD></TD><TD>force userdefined mode</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
725 <TR><TD></TD><TD>-x, -y</TD><TD></TD><TD>set userdefined prescaling</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
726 <TR><TD></TD><TD>-zoom</TD><TD></TD><TD>enables userdefined prescaling</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
727 <TR><TD></TD><TD>-fs</TD><TD></TD><TD>scales image to fullscreen</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
728 <TR><TD></TD><TD>-fs -zoom</TD><TD></TD><TD>scales userdefined prescaling to fullscreen</TD></TR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
729 <TR><TD></TD><TD>-double</TD><TD></TD><TD>enables double buffering mode. (Available only in DGA mode). Should be slower of single buffering, but has no flickering effects.</TD></TR> |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
730 </TABLE> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
731 |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
732 <P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
733 <B>Known problems and workaround:</B><BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
734 - If you have installed <B>NLS</B> font on your Linux box and run VESA driver |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
735 from text-mode then after terminating mplayer you will have <B>ROM font</B> loaded instead |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
736 of national. You can load national font again by using <B><I>setsysfont</I></B> utility |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
737 from for example Mandrake distribution.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
738 (<B>Hint</B>: The same utility is used for localizating fbdev).<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
739 - Some <B>Linux graphics drivers</B> don't update active <B>BIOS mode</B> in DOS memory. So if you have such |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
740 problem - always use VESA driver only from <B>text-mode</B>. Otherwise text-mode (#03) will be |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
741 activated anyway and you will need restart your computer.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
742 - Often after terminating VESA driver you get <B>black screen</B>. To return your screen |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
743 to original state - simply switch to other console (by pressing <B>Alt-Fx</B>) then switch |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
744 to your previous console by the same way.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
745 - To get <B>working TV-out</B> you need have plugged tv-connector in before booting |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
746 your PC since video BIOS initializes itself only once during POST procedure. |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
747 </P> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
748 |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
749 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
750 <P><B><A NAME=2.3.1.13>2.3.1.13. X11</A></B></P> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
751 |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
752 <P>Avoid if possible. Outputs to X11 (uses shared memory extension), with no |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
753 hardware acceleration at all. Supports (MMX/3DNow/SSE accelerated, but still |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
754 slow) software scaling, use the options <CODE>-fs -zoom</CODE>. Most cards have |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
755 hardware scaling support, use the <CODE>-vo xv</CODE> output for them, or |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
756 <CODE>-vo xmga</CODE> for Matroxes.</P> |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
757 |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
758 <P>The problem is that most cards' driver doesn't support |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
759 hardware acceleration on the second head/TV. In those cases, you see green/blue |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
760 coloured window instead of the movie. This is where this driver comes in |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
761 handy, but you need powerful CPU to use software scaling. Don't use the |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
762 SDL driver's software output+scaler, it has worse image quality !</P> |
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
763 |
3290 | 764 <P>Software scaling is very slow, you better try changing video modes instead. |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
765 It's very simple. See the <A HREF="#2.3.1.3.A">DGA section's modelines</A>, and |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
766 insert them into your XF86Config.</P> |
3290 | 767 <UL> |
768 <LI>If you have XFree86 4.x.x - use the <CODE>-vm</CODE> option. It will | |
769 change to a resolution your movie fits in. If it doesn't :</LI> | |
770 <LI>With XFree86 3.x.x - you have to cycle through available resolutions | |
771 with the <B>CTRL-ALT-plus</B> and <B>minus</B> keys.</LI> | |
772 </UL> | |
773 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
774 <P>If you can't find the modes you inserted, browse XFree86's output. Some |
3290 | 775 drivers can't use low pixelclocks that are needed for low resolution |
776 video modes.</P> | |
777 | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
778 |
3224 | 779 <P><B><A NAME=2.3.1.14>2.3.1.14. Rage128 (Pro) / Radeon video overlay (radeon_vid)</A></B></P> |
2956
f6b51da0a50d
DOXized and applied Nick's radeon_vid patch. Nick, should I update
gabucino
parents:
2883
diff
changeset
|
780 |
5119 | 781 <P>This section is OBSOLETED ! Use Vidix !</P> |
2956
f6b51da0a50d
DOXized and applied Nick's radeon_vid patch. Nick, should I update
gabucino
parents:
2883
diff
changeset
|
782 |
4339 | 783 |
4199 | 784 <P><B><A NAME=2.3.1.15>2.3.1.15. VIDIX</A></B></P> |
785 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
786 <P><B>WHAT IS VIDIX?</B></P> |
4199 | 787 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
788 <P>VIDIX is the abbreviation for <B>VID</B>eo <B>I</B>nterface for |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
789 *ni<B>X</B>.<BR> |
4199 | 790 VIDIX was designed and introduced as an interface for fast user-space drivers |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
791 providing <B>DGA</B> everywhere where it's possible (<B>unlike X11</B>). I |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
792 hope that these drivers will be as portable as X11 (<B>not only on |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
793 *nix</B>).<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
794 What it is:</P> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
795 |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
796 <UL> |
4199 | 797 <LI>It's a portable successor of mga_vid technology, but it's located in |
798 user-space.</LI> | |
799 <LI>Unlike X11 it provides DGA everywhere it's possible</LI> | |
800 <LI>Unlike v4l it provides interface for video playback</LI> | |
801 <LI>Unlike linux's drivers it uses mathematics library</LI> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
802 </UL> |
4199 | 803 |
804 <P>I can tell you in bold capital letters :<BR> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
805 <B>VIDIX PROVIDES DIRECT GRAPHICS ACCESS TO BES YUV MEMORY.</B> |
4199 | 806 </P> |
807 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
808 <P><I>Well (it's in my todo) - implement DGA to MPEG2 decoder.</I></P> |
4199 | 809 |
810 <P>This interface was designed as an attempt to fit existing video acceleration | |
811 interfaces (known as mga_vid, mga_yuv, radeon_vid) into a fixed scheme. It | |
812 provides highlevel interface to chips which are known as BES (BackEnd | |
813 scalers) or OV (Video Overlays). It doesn't provide lowlevel interface to | |
814 things which are known as graphics servers. (I don't want to compete with X11 | |
815 team in graphics mode switching). I.e. main goal of this interface is to | |
816 provide maximal speed of video playback but not putting video signal on | |
817 screen of your TV or on tape of your VCR. Although these things are also very | |
818 significant - it's perfectly other task. (However I guess that it would be | |
819 possible to implement something like mini-X (don't mix it with Minix ;) in | |
820 the future, if some number of volunteers will be found. | |
821 </P> | |
822 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
823 <P><B>USAGE</B></P> |
4199 | 824 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
825 <UL> |
4199 | 826 <LI>You can use standalone video output driver: <CODE>-vo xvidix</CODE><BR> |
827 This driver was developed as X11's front end to VIDIX technology. It | |
828 requires XServer and can work only under XServer.</LI> | |
829 <LI>You can use VIDIX subdevice which was applied to several video output | |
830 drivers, such as:<BR> | |
831 <CODE>-vo vesa:vidix</CODE> and <CODE>-vo fbdev:vidix</CODE></LI> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
832 </UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
833 Indeed it doesn't matter which video output driver is used with <B>VIDIX</B>. |
4199 | 834 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
835 <P><B>REQUIREMENTS</B></P> |
4199 | 836 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
837 <UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
838 <LI>video card should be in graphics mode (I write <B>should</B> simply |
4199 | 839 because I tested it in text mode - it works but has awful output ;) Use |
840 AAlib for that).<BR> | |
841 <I>Note: Everyone can try this trick by commenting out mode switching in | |
842 vo_vesa driver.</I></LI> | |
843 <LI><B>MPlayer</B>'s video output driver should know active video mode and be | |
844 able to tell to VIDIX subdevice some video characteristics of server.</LI> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
845 </UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
846 I hope that probably every video output driver of <B>MPlayer</B> will |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
847 recognize <CODE>:vidix</CODE> subdevice. |
4199 | 848 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
849 <P><B>USAGE METHODS</B></P> |
4199 | 850 |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
851 <P>When VIDIX is used as <B>subdevice</B> (<CODE>-vo vesa:vidix</CODE>) then |
4199 | 852 video mode configuration is performed by video output device |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
853 (<B>vo_server</B> in short). Therefore you can pass into command line of |
4199 | 854 <B>MPlayer</B> the same keys as for vo_server. In addition it understands |
855 <CODE>-double</CODE> key as globally visible parameter. (I recommend using | |
856 this key with VIDIX at least for ATI's card).<BR> | |
857 As for <CODE>-vo xvidix</CODE> : currently it recognizes the following | |
4356 | 858 options: <CODE>-fs -zoom -x -y -double</CODE>.<BR> |
4199 | 859 </P> |
860 | |
861 <P>Also you can specify VIDIX's driver directly as third subargument in command | |
862 line :<BR> | |
863 <BR> | |
864 <code>mplayer -vo xvidix:mga_vid.so -fs -zoom -double | |
865 file.avi</code><BR> | |
866 or<BR> | |
867 <code>mplayer -vo vesa:vidix:radeon_vid.so -fs -zoom -double -bpp | |
868 32 file.avi</code><BR> | |
869 <BR> | |
870 But it's dangerous, and you shouldn't do that. In this case given driver will | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
871 be forced and result is unpredictable (it may <B>freeze</B> your |
4339 | 872 computer). You should do that ONLY if you are absolutely sure it will work, |
873 and <B>MPlayer</B> doesn't do it automatically. Please tell about it to the | |
874 developers. The Right Way is to use VIDIX without arguments to enable driver | |
4199 | 875 autodetection. |
876 </P> | |
877 | |
878 <P> | |
879 VIDIX is very new technology and it's extremely possible that on your system | |
880 (OS=abc CPU=xyz) it won't work. In this case only solution for you it's port | |
881 it (mainly libdha). But there is hope that it will work on those systems | |
882 where X11 does. | |
883 </P> | |
884 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
885 <P>And the last <B>WARNING</B>: (un)fortunately you <B>MUST</B> have |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
886 <B>ROOT</B> privileges to use VIDIX due to direct hardware access. At least |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
887 set the <B>suid</B> bit on the <B>MPlayer</B> excecutable. |
4199 | 888 </P> |
889 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
890 <P><B>VIDEO EQUALIZER</B></P> |
4496 | 891 |
892 <P> | |
4506 | 893 This is a video equalizer implemented especially for Vidix. You can use |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
894 it either with <B>1-8</B> keys as described in the man page, or |
4506 | 895 by command line arguments. <B>MPlayer</B> recognizes the |
4496 | 896 following options : |
897 </P> | |
898 | |
899 <P> | |
900 <CODE>-brightness</CODE> - adjust <B>BRIGHTNESS</B> of video | |
901 output. It's not equal to brightness adjusting on monitor panel or on TV. It | |
902 changes intensity of RGB components of video signal from black to white | |
903 screen.<BR> | |
904 <CODE>-contrast</CODE> - adjust <B>CONTRAST</B> of video output. | |
905 Works in similar manner as brightness.<BR> | |
906 <CODE>-saturation</CODE> - adjust <B>SATURATION</B> of video | |
907 output. You can get grayscale output with this option.<BR> | |
908 <CODE>-hue</CODE> - adjust <B>HUE</B> of video signal. You can | |
909 get colored negative of image with this option.<BR> | |
910 <CODE>-red_intensity</CODE> - adjust intensity of <B>RED</B> | |
911 component of video signal.<BR> | |
912 <CODE>-green_intensity</CODE> - adjust intensity of <B>GREEN</B> | |
913 component of video signal.<BR> | |
914 <CODE>-blue_intensity</CODE> - adjust intensity of <B>BLUE</B> | |
915 component of video signal. | |
916 </P> | |
917 <P> | |
918 Each parameter can accept values from <B>-1000</B> to <B>+1000</B>.<BR> | |
919 Default value for each parameter is <B>0</B>. | |
920 </P> | |
921 <P> | |
922 <B>Note:</B> Not every driver provides support for each of those parameters. | |
923 Currently only <B>radeon_vid.so</B> provides full support for video eqalizing. | |
924 Other drivers only partly support these options. | |
925 </P> | |
926 <P><B>Examples:</B><BR> | |
927 <CODE>mplayer -vo vesa:vidix -brightness -300 -contrast 200 | |
928 filename.avi</CODE><BR> | |
929 or<BR> | |
930 <CODE>mplayer -vo xvidix -red_intensity -50 -saturation 400 -hue 300 | |
931 filename.vob</CODE> | |
932 </P> | |
933 | |
2956
f6b51da0a50d
DOXized and applied Nick's radeon_vid patch. Nick, should I update
gabucino
parents:
2883
diff
changeset
|
934 |
4339 | 935 <P><B><A NAME=2.3.1.16>2.3.1.16. Zr</A></B></P> |
936 | |
937 <P>This is a display-driver (<CODE>-vo zr</CODE>) for a number of MJPEG | |
4360 | 938 capture/playback cards (tested for DC10+ and Buz, and it should work for the |
4339 | 939 LML33, the DC10). The driver works by encoding the frame to jpeg and then |
940 sending it to the card. For the jpeg encoding <B>libavcodec</B> is | |
941 used, and required.</P> | |
942 | |
943 <P>This driver talks to the kernel driver available at | |
944 <A HREF="http://mjpeg.sourceforge.net">http://mjpeg.sourceforge.net</A>, so | |
945 you must get it working first. Then recompile <B>MPlayer</B> with | |
946 <CODE>--enable-zr</CODE>.</P> | |
947 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
948 Some remarks: |
4339 | 949 <UL> |
4360 | 950 <LI>don't start or stop XawTV on the playback device during playback, |
951 it will crash your computer. It is, however, fine to <B>FIRST</B> start | |
952 XawTV, <B>THEN</B> start <B>MPlayer</B>, wait for <B>MPlayer</B> to finish | |
953 and <B>THEN</B> stop XawTV.</LI> | |
4339 | 954 <LI>this driver adds <CODE>-zr*</CODE> commandline options. The explanation |
955 of these options can be viewed with <CODE>-zrhelp</CODE>. It is possible to | |
956 crop the input frame (cut borders to make it fit or to enhance performace) | |
957 and to do other things.</LI> | |
4360 | 958 <LI>the driver takes data in YV12 and YUY2 format, this means that some |
959 codecs won't work. Some old VfW (Video for Windows) codecs, for example, | |
960 are incompatible with this driver. The errormessage that you will see is: | |
961 <CODE>Sorry, selected video_out device is incompatible with this codec. | |
962 </CODE></LI> | |
963 <LI>OSD is currently not supported, so you won't see | |
964 subtitles.</LI> | |
4339 | 965 </UL> |
966 | |
967 | |
4496 | 968 |
2745 | 969 <P><B><A NAME=2.3.1.A>2.3.1.A. TV-out support</A></B></P> |
1612 | 970 |
5116 | 971 <P><B><A NAME=2.3.1.A.1>2.3.1.A.1. Matrox G400 cards</A></B></P> |
1612 | 972 |
5116 | 973 <P>Under Linux you have 2 methods to get G400 TV out working :</P> |
974 | |
975 <P><B>IMPORTANT:</B> Only Matrox G400DH/G400MAX has TV-out support under Linux, others (G450, G550) has <B>NOT!</B></P> | |
2309 | 976 |
2486 | 977 <UL> |
978 <LI><B>XFree86</B>: using the driver and the HAL module, available from | |
979 <A HREF="http://www.matrox.com">Matrox's site</A>. This will give you X on | |
980 the TV.<BR> <B>This method doesn't give you accelerated playback</B> as | |
981 under Windoze! The second head has only YUV framebuffer, the <I>BES</I> | |
982 (Back End Scaler, the YUV scaler on G200/G400/G450/G550 cards) doesn't work | |
983 on it! The windows driver somehow workarounds this, probably by using the | |
984 3D engine to zoom, and the YUV framebuffer to display the zoomed | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2747
diff
changeset
|
985 image. If you really want to use X, use the <CODE>-vo x11 -fs -zoom</CODE> |
2486 | 986 options, but it will be <B>SLOW</B>, and has <B>Macrovision</B> copyprotection |
4177 | 987 enabled (you can "workaround" Macrovision using |
988 <A HREF="http://avifile.sourceforge.net/mgamacro.pl">this</A> perl | |
989 script.</LI> | |
2486 | 990 <LI><B>Framebuffer</B>: using the <B>matroxfb modules</B> in the 2.4 kernels. |
991 2.2 kernels don't have the TVout feature in them, thus unusable for this. | |
3030 | 992 You have to enable ALL matroxfb-specific feature during compilation (except |
5713 | 993 MultiHead), and compile them into <B>modules</B>! You'll also need I2C |
994 enabled. | |
2486 | 995 <UL> |
996 <LI> | |
997 Enter <CODE>TVout/matroxset</CODE> and type <CODE>make</CODE>. Install | |
998 <CODE>matroxset</CODE> into somewhere in your PATH.</LI> | |
999 <LI> | |
1000 If you don't have <CODE>fbset</CODE> installed, enter | |
1001 <CODE>TVout/fbset</CODE> and type <CODE>make</CODE>. Install | |
1002 <CODE>fbset</CODE> into somewhere in your PATH.</LI> | |
1003 <LI> | |
1004 Then enter into the <CODE>TVout/</CODE> directory in the <B>MPlayer</B> | |
1005 source, and execute <CODE>./modules</CODE> as root. Your text-mode console | |
1006 will enter into framebuffer mode (no way back!).</LI> | |
1007 <LI>Next, run the <CODE>./matroxtv</CODE> script. This will present you | |
1008 to a very simple menu. Press <B>2</B> and <B>ENTER</B>. Now you should | |
1009 have the same picture on your monitor, and TV. The <B>3.</B> option | |
1010 will turn on independent display, but then you <B>can't use X</B>! If | |
3030 | 1011 the TV (PAL !) picture has some weird stripes on it, the script wasn't able to |
2486 | 1012 set the resolution correctly (to 640x512 by default). Use other menu |
1013 items randomly and it'll be OK :)</LI> | |
1014 </UL> | |
1015 | |
1016 <P> | |
1017 Yoh. Next task is to make the cursor on tty1 (or whatever) to disappear, | |
1018 and turn off screen blanking. Execute the following commands:</P> | |
1019 | |
1020 <P> | |
4701 | 1021 <CODE>echo -e '\033[?25l'</CODE> or <CODE>setterm -cursor off<BR> |
2486 | 1022 setterm -blank 0</CODE> |
1023 </P> | |
1024 | |
1025 <P> | |
1026 You possibly want to put the above into a script, and also clear | |
1027 the screen.. To turn the cursor back :<BR><CODE>echo -e '\033[?25h'</CODE> | |
4701 | 1028 or <CODE>setterm -cursor on</CODE> |
2486 | 1029 </P> |
1030 | |
1031 <P>Yeah kewl. Start movie playing with <CODE>mplayer -vo mga -fs -screenw 640 | |
1032 -screenh 512 <filename></CODE><BR> | |
1033 (if you use X, now change to matroxfb with for example CTRL-ALT-F1 !)<BR> | |
1034 Change 640x512 if you set the resolution to other..<BR> | |
1035 <B>Enjoy the ultra-fast ultra-featured Matrox TV output (better than Xv) !</B> | |
1036 </P> | |
1037 </LI> | |
1038 </UL> | |
2309 | 1039 |
1040 | |
2745 | 1041 <P><B><A NAME=2.3.1.A.2>2.3.1.A.2. ATI cards</A></B></P> |
2206 | 1042 |
1043 <P> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1044 <B>A few word about ATI's TV-out:</B><BR> |
2206 | 1045 Currently ATI doesn't want to support any of its TV-out chips under Linux. |
1046 Below is official answer from ATI Inc.: | |
1047 | |
1048 <P> | |
1049 <code> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1050 <I> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1051 <BR>> Hello! |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1052 <BR>> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1053 <BR>> On your pages you wrote that you support linux developers. |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1054 <BR>> Currently I participate with mplayer project (www.mplayerhq.hu) |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1055 <BR>> I'm interesting with enabling TV-out on Radeon VE chips during |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1056 <BR>> movie playback. I would be glad to add this feature to radeonfb driver |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1057 <BR>> (which can be found in CVS tree of mplayer project at main/drivers/radeon). |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1058 <BR>> Do I have a chance to get any official technical documenation? |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1059 </I> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1060 <BR>We will not provide TV out related documents due to macrovision concerns. |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1061 <BR>Also mpeg2 decoding is something that we MAY consider in the future but not |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1062 <BR>at this current time. This is again due to proprietary and 3rd party |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1063 <BR>information. |
2206 | 1064 </code> |
1065 </P> | |
1066 | |
1067 <P>Pity isn't?</P> | |
1068 | |
1069 <P> | |
1070 <code> | |
1071 <B>Q:What is Macrovision?</B><BR> | |
1072 A:It's copy protection mechanism.</code> | |
1073 </P> | |
1074 | |
1075 <P>It means that if they open any TV-out related information then | |
1076 hackers will be able to disable copy protection on their chips. Therefore | |
1077 we have no chance to get working TV-out on ATI.</P> | |
1078 | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1079 What's status of ATI's tv-out chips under Linux: |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1080 <UL> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1081 <LI><B>ATI Mach64</B> has <I>ImpacTV</I> which is supported by <A HREF="http://gatos.sf.net">gatos</A>.</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1082 <LI><B>ASIC Radeon VIVO</B> has <I>Rage Theatre</I> which is supported by <A HREF="http://gatos.sf.net">gatos</A>.</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1083 <LI><B>Radeon VE</B> and <B>Rage PRO LT</B> have <I>ImpacTV2+</I> which is not supported under Linux. |
3027 | 1084 But with <B>MPlayer</B> you get <B>full hardware acceleration</B> and <B>TV out</B> |
1085 for Radeons ! | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1086 Check <a href="#2.3.1.12">VESA driver</a> and <A HREF="#2.3.1.14">Radeon |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1087 acceleration</A> sections.</LI> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1088 </UL> |
2206 | 1089 |
1090 <P> | |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1091 Fortunately, owners of fast enough CPUs (Duron, Celeron2 and better) <B>can watch |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1092 movies on their TV</B> through <a href="#2.3.1.12">VESA drivers</a>. |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1093 </P> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1094 |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1095 <P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1096 I should say good words to ATI Inc. too:<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1097 <B>they produce top quality BIOSes.</B> |
2206 | 1098 </P> |
1099 | |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1100 <P> |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1101 <B>VESA drivers</B> don't use any hardware acceleration but it simulates |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1102 <B>DGA</B> through 64K window, which is configured through 32-bit mode |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1103 functions of BIOS. ATI cards have enough <B>fast video memory</B> (DIMM or DDR |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1104 chips with 64 - 128-bit access) so it's not bottleneck for them. There are no |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1105 limitations on which video mode can be displayed on your TV (like on other |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1106 cards) so you can use <B>any video mode</B> on your <B>TV</B> (from |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1107 <B>320x200</B> up to <B>1024x768</B>).<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1108 From other side (it's known at least for <B>Radeons</B>) there is <B>DGA</B> |
2747 | 1109 mode which is detected automatically and in this case you'll get comparable |
6435
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1110 with <B>-vo dga</B> and <B>-vo fbdev</B> drivers speed.<BR> |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1111 Only thing you need to do - <B>have TV connector plugged in before booting your |
d0d74f9d8d4a
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1112 PC</B> since video BIOS initializes itself only once during POST procedure. |
2448
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1113 </P> |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1114 |
1e56c3381d55
'vesa' vo driver added. By Nick Kurshev. (spellchecked, fixed, mplayerdoxized)
gabucino
parents:
2408
diff
changeset
|
1115 <P> |
2745 | 1116 For detail see <a href="video.html#2.3.1.12">VESA</a> sections of this |
2471 | 1117 documentation. |
2206 | 1118 </P> |
1119 | |
2472
487f5bbb38ae
link to tomi ollila's voodoo3 tvout text. if he has interest to integrate
gabucino
parents:
2471
diff
changeset
|
1120 |
3027 | 1121 <P><B><A NAME=2.3.1.A.3>2.3.1.A.3. Voodoo 3</A></B></P> |
2472
487f5bbb38ae
link to tomi ollila's voodoo3 tvout text. if he has interest to integrate
gabucino
parents:
2471
diff
changeset
|
1122 |
487f5bbb38ae
link to tomi ollila's voodoo3 tvout text. if he has interest to integrate
gabucino
parents:
2471
diff
changeset
|
1123 <P> |
487f5bbb38ae
link to tomi ollila's voodoo3 tvout text. if he has interest to integrate
gabucino
parents:
2471
diff
changeset
|
1124 Check <A HREF="http://www.iki.fi/too/tvout-voodoo3-3000-xfree">this URL</A>. |
487f5bbb38ae
link to tomi ollila's voodoo3 tvout text. if he has interest to integrate
gabucino
parents:
2471
diff
changeset
|
1125 </P> |
487f5bbb38ae
link to tomi ollila's voodoo3 tvout text. if he has interest to integrate
gabucino
parents:
2471
diff
changeset
|
1126 |
1612 | 1127 </BODY> |
1128 </HTML> |