view DOCS/Hungarian/DGA @ 1437:4fa90be8da03

made mmx/mmxext idct public -> now libavcodec can use it
author arpi
date Fri, 03 Aug 2001 18:46:08 +0000
parents cc74775864d8
children
line wrap: on
line source


Tartalom
~~~~~~~~

 1. Előszó
 2. Mi az a DGA
 3. Felbontásváltás
 4. DGA és MPlayer
 5. A DGA driver képességei
 6. Sebesség
 7. Ismert hibák
 8. Beepítendő dolgok
 
 A. Néhány modeline



1. Előszó
~~~~~~~~~
 Ez a dokumentum néhány szóban elmagyarázza, hogy általában véve mi is az a
 DGA, és mit tud az MPlayerben (és mit nem).

2. Mi a DGA?
~~~~~~~~~~~~

 A DGA szó a Direct Graphics Access rövidítése, és egy olyan módszert takar,
 amivel a program az X szerver kikerülésével közvetlenül írhat a framebuffer
 memóriába. Szaknyelven szólva ez a framebuffer memóriának a processz
 területére történő lapozásával történik. Ezt a kernel csak root jogosultsággal
 engedi. Ez történhet root-ként történő bejelentkezéssel, vagy a suid bit
 beállításával az mplayer programon (NEM ajánlott!).

 A DGA-nak két verziója van: a DGA1-et az XFree 3.X.X használja, a DGA2
 pedig az XFree 4.0.1 óta létezik.

 A DGA1 csak a fent leírt közvetlen hozzáférést nyújtja. A felbontásváltáshoz
 itt szükség van az XVidMode kiterjesztésre.

 A DGA2 tartalmazza az XVidMode tudását, továbbá engedélyezi a színmélység
 megváltoztatását. Így lehetséges, hogy egy 32 bites mélységű X szervert
 átváltsunk 15 bitesbe, vagy fordítva.

 A DGA-nak van néhány hátránya. Valamelyest függ a grafikus chiptől és ennek
 X-es driverétől, ezért nem minden rendszeren működik ...


3. Felbontásváltás
~~~~~~~~~~~~~~~~~~
 A DGA driver képes felbontásváltásra. Ezzel kikerülhető a (lassú) szoftveres
 scale, ugyanakkor teljesképernyős lesz a lejátszás. Ideális esetben pontosan
 egyező felbontást választ, de csak azon videomódok közül tud választani,
 ami az /etc/X11/XF86Config fileban szerepel. Ezeket úgynevezett modeline-okkal
 definiáljuk, és a videokártya képességeitől függenek. Az X szerver ezt
 a config file-t nézi át induláskor, és kikapcsolja mindazokat, amiket a
 kártya nem tud. A fennmaradó módok az X11 log-jában találhatóak:
 /var/log/XFree86.0.log
 Az A függelékben néhány modeline példa található.

4. DGA és MPlayer
~~~~~~~~~~~~~~~~

 Az MPlayer-ben két helyen lehet DGA-t használni: az SDL driverben
 (-vo sdl:dga), valamint a DGA driverben (-vo dga). A fentiek mindkettőre
 igazak; a következő néhány részben elmagyarazom, hogy is működik az MPlayer
 DGA drivere.


5. A DGA driver képességei
~~~~~~~~~~~~~~~~~~~~~~~~~~

 A DGA driver meghívása a -vo dga parancssori opció megadásával történik.
 Az alapértelmezett magatartás szerint a video méretéhez legközelebb eső
 felbontásba vált. Figyelmen kívül hagyja a -vm és -fs kapcsolókat
 (felbontásváltás és teljesképernyő) - mindig az adott felbontás lehető legjobb
 kihasználására törekszik, így egy árva CPU ciklusnak sem kell fordítódnia a
 kép nagyítására.
 Ha nem tetszik a mód amit kiválasztott, megadhatod, hogy az -x és -y által
 kijelölt mérethez válasszon felbontást.
 A -v opció megadásaval a DGA driver többek között kiírja az XF86Config
 file-od által elérhető felbontásokat.
 DGA2-vel megadhatod a használandó színmélységet is a -bpp opcióval.
 A megadott szám lehet: 15, 16, 24 és 32. A hardware-edtől függ, hogy ezek
 közül melyeket használhatod, valamint, hogy (lassú) konverzió lehetséges-e.

 Ha szerencséd van és van még elég memóriád hogy a kép mégegyszer elférjen,
 akkor a DGA driver doublebuffering-et fog alkalmazni, ami sokkal folyamatosabb
 lejátszást eredményez.

 A doublebuffering azt jelenti, hogy a video következő képkockájának kirajzolása
 a videomemórián kívül történik, amíg az előző képkocka kirajzolódik. Amint
 elkészül, a grafikus kártya megkapja ennek a memóriaterületnek a címét, és azt
 jeleníti meg, ami ott van. Mindeközben a másik memóriaterület újra feltöltődik.

 A doublebuffering a -double opcióval kapcsolható be és a -nodouble opcióval ki.
 Jelenleg alapállapotban ki van kapcsolva. Ha a DGA drivert használod, csak
 doublebuffering esetén lesz OSD-d. Viszont, ha bekapcsolod az nagy
 teljesítménycsökkenéssel járhat (a K6-II+ 525 gépemen plusz 20% CPU idő!),
 függően a videokártyád DGA driverértől.



6. Sebesség
~~~~~~~~~~~
 A DGA framebuffer használatával legalább olyan gyors képet kapunk mint X11-el,
 plusz teljeskepérnyős módot. A százalékos CPU használati értekeket, amiket az
 MPlayer kiír óvatosan kezeljuk, mert pl. az X11 drivernél nem tartalmazzák
 az X szerver által a megjelenítéshez használt időt. Kapcsolj egy terminált
 a soros portodra és indíts egy top-ot, hogy lásd valójában mi történik.

 Általánosan szólva a DGA sebességnövekedése az X11-hez képest erősen függ
 a videokártyádtól és annak driverétől.

 Ha lassú a rendszered, jobb, ha 15 vagy 16bpp-s színmélységet használsz,
 mivel ezek a 32bites mód memóriasávszélességének csak a felét igénylik.

 A 24bites mélység használata akkor jó, ha a kártyád csak 32bites módot
 támogat, mivel így 25%-al kevesebb adatnak kell átjutnia, a 32/32bites
 módhoz képest.

 Már láttam (divx) AVI file-okat lejátszódni Pentium MMX 266-on. AMD K6/2 CPU-k
 400Mhz-en vagy afölött már jók.

7. Ismert hibák
~~~~~~~~~~~~~~~

 Nos, néhány XFree fejlesztő szerint a DGA nagy szörnyűség. Szerintük nem
 érdemes használni. Az implementációja nem minden driverben tökeletes.

 o XFree 4.0.3-mal és nv.o driverrel van egy bug, ami furcsa színeket eredményez
 o az ATI driverrel egynél többször kell módot váltani, miután a DGA használat
   befejeződott
 o némely driverek egyszerűen nem tudnak visszaváltani a normális felbontásba
   (használd a Ctrl-Alt-Keypad +, - billentyűket)
 o néhány driver furcsa színeket jelenít meg
 o mások hazudnak arról, hogy mennyi memóriát map-elnek be, így vo_dga
   nem fog doublebuffering-et használni (SIS?)
 o megint mások nem adnak vissza egyetlen videomódot se. Ebben az esetben
   a DGA driver leáll valami nonszensz üzenettel mint pl 100000x100000 vagy
   ilyesmi ...
 o az OSD csak doublebuffering-el működik

8. Beépítendő dolgok
~~~~~~~~~~~~~~~~~~~~

 o az új X11 render interface használata OSD-hez
 o hol van a TODO listám ???? :-((((


A. Néhány modeline
~~~~~~~~~~~~~~~~~~
Section "Modes"
  Identifier    "Modes[0]"
		# 800x600 @ 60 Hz, 37.8 kHz hsync
  Modeline	"800x600"  40     800 840 968 1056  600 601 605 628 
  Modeline      "712x600"  35.0   712 740 850 900   400 410 412 425
  Modeline      "640x480"  25.175 640 664 760 800   480 491 493 525 
  Modeline 	"400x300"  20     400  416  480  528   300  301  303  314 Doublescan
  Modeline	"352x288"  25.10  352 368 416 432   288 296 290 310
  Modeline      "352x240"  15.750 352 368 416 432   240 244 246 262 Doublescan
  Modeline	"320x240"     12.588  320 336 384 400 240 245 246 262 Doublescan
EndSection


 Ezek a bejegyzések működnek az én Riva128-asomon, az nv.o driverrel.

B. Bugreport
~~~~~~~~~~~~

 Ha bármi problémád van a DGA driverrel, bátran jelezd nekem (e-mail címem lásd
 alább). Ehhez  -v opcióval futtasd mplayert, és a vo_dga: kezdetű sorokat
 küldd el nekem.
 
 Kérlek mellékeld az általad használt grafikus kártya és processzor típusát,
 valamint az X11 verzióját. Az X11 driver module (XF86-Config file-ban) is
 segíthet. Köszönöm!


 Acki (acki@acki-netz.de, www.acki-netz.de)                  18.06.2001