LVM_GetItemRect should not take text size in account for LVIR_LABEL in
[wine] / documentation / multimedia.sgml
1   <chapter id="multimedia">
2     <title>Wine and Multimedia</title>
3     
4     <para>
5       This file contains information about the implementation of the
6       multimedia layer of WINE. 
7     </para>
8     
9     <para>
10       The implementation can be found in the dlls/winmm/ directory (and in 
11       many of its subdirectories), but also in dlls/msacm/ (for the
12       audio compression/decompression manager) and dlls/msvideo/ (for the
13       video compression/decompression manager).
14     </para>   
15     
16     <para>
17       Written by &name-eric-pouech; <email>&email-eric-pouech;</email>
18       (Last updated: 02/16/2001)
19     </para>
20     
21     <sect1 id="mm-overview">
22       <title>Overview</title>
23       
24       <para>
25         The multimedia stuff is split into 3 layers. The low level (device
26         drivers), mid level (MCI commands) and high level abstraction layers.
27         The low level layer has also some helper DLLs (like the MSACM/MSACM32
28         and MSVIDEO/MSVFW32 pairs).
29       </para>
30       
31       <para>
32         The low level layer may depend on current hardware and OS services 
33         (like OSS on Unix). Mid level (MCI) and high level layers must be 
34          written independently from the hardware and OS services.
35       </para>
36       
37       <para>
38         There are two specific low level drivers (one for wave input/output, 
39         another one for MIDI output only), whose role is:
40         <itemizedlist>
41           <listitem>
42             <para>help choosing one low level driver between many</para>
43           </listitem>
44           <listitem>
45             <para>
46               add the possibility to convert streams (ie ADPCM =&gt; PCM)
47             </para>
48           </listitem>
49           <listitem>
50             <para>
51               add the possibility to filter a stream (adding echo, equalizer...
52               to a wave stream), or modify the instruments that have to be 
53               played (MIDI).
54             </para>
55           </listitem>
56         </itemizedlist>
57       </para>
58       
59       <para>
60         All of those components are defined as DLLs (one by one).
61       </para>
62       
63     </sect1>
64     
65     <sect1 id="mm-low">
66       <title>Low level layers</title>
67       
68       <para>
69         Please note that native low level drivers are not currently supported
70         in WINE, because they either access hardware components or require
71         VxDs to be loaded; WINE does not correctly supports those two so far.
72       </para>
73       
74       <para>
75         The following low level layers are implemented (as built-in DLLs):
76       </para>
77       
78       <sect2>
79         <title>(Wave form) Audio</title>
80         
81         <para>
82           MMSYSTEM and WINMM call the real low level audio driver using the
83           wodMessage/widMessage which handles the different requests.
84         </para>
85         
86         <sect3>
87           <title>OSS implementation</title>
88           
89           <para>
90             The low level audio driver is currently only implemented for the
91             OpenSoundSystem (OSS) as supplied in the Linux and FreeBSD kernels by
92             <ulink url="http://www.4front-tech.com/">4Front Technologies</ulink>. 
93             The presence of this driver is checked by configure (depends on the 
94             &lt;sys/soundcard.h&gt; file). Source code resides in 
95             dlls/winmm/wineoss/audio.c.
96           </para>
97           
98           <para>
99             The implementation contains all features commonly used, but has
100             several problems (see TODO list).
101           </para>
102
103           <para>
104             Note that some Wine specific flag has been added to the wodOpen function, 
105             so that the dsound DLL can share the /dev/dsp access. Currently, this 
106             only provides mutual exclusion for both DLLs. Future extension could add
107             a virtual mixer between the two output streams.
108           </para>
109           
110           <para>TODO:
111             <itemizedlist>
112               <listitem>
113                 <para>
114                   verify all functions for correctness
115                 </para>
116               </listitem>
117               <listitem>
118                 <para>
119                   Add virtual mixer between wave-out and dsound interfaces.
120                 </para>
121               </listitem>
122             </itemizedlist>
123           </para>
124           
125         </sect3>
126         
127         <sect3>
128           <title>Other sub systems</title>
129           
130           <para>
131             No other is available. Could think of Sun Audio, remote audio systems
132             (using X extensions, ...), ALSA, EsounD, ArTs...
133           </para>
134           
135         </sect3>
136         
137       </sect2>
138       
139       <sect2>
140         <title>MIDI</title>
141         
142         <para>
143           MMSYSTEM and WINMM call the low level driver functions using the
144           midMessage and the modMessage functions.
145         </para>
146         
147         <sect3>
148           <title>OSS driver</title>
149           
150           <para>
151             The low level audio driver is currently only implemented for the
152             OpenSoundSystem (OSS) as supplied in the Linux and FreeBSD kernels by
153             <ulink url="http://www.4front-tech.com/">4Front Technologies</ulink>.
154             The presence of this driver is checked by configure (depends on the 
155             &lt;sys/soundcard.h&gt; file, and also some specific defines because 
156             MIDI is not supported on all OSes by OSS). Source code resides in 
157             dlls/winmm/wineoss/midi.c
158           </para>
159           
160           <para>
161             Both Midi in and Midi out are provided. The type of MIDI devices
162             supported is external MIDI port (requires an MIDI capable device -
163             keyboard...) and OPL/2 synthesis (the OPL/2 patches for all
164             instruments are in midiPatch.c).
165           </para>
166           
167           <para>TODO:
168             <itemizedlist>
169               <listitem>
170                 <para>
171                   use better instrument definition for OPL/2 (midiPatch.c) or use
172                   existing instrument definition (from playmidi or kmid) with a
173                   .winerc option
174                 </para>
175               </listitem>
176               <listitem>
177                 <para>
178                   have a look at OPL/3 ?
179                 </para>
180               </listitem>
181               <listitem>
182                 <para>
183                   implement asynchronous playback of MidiHdr
184                 </para>
185               </listitem>
186               <listitem>
187                 <para>
188                   implement STREAM'ed MidiHdr (question: how shall we share the code
189                   between the midiStream functions in MMSYSTEM/WINMM and the code
190                   for the low level driver)
191                 </para>
192               </listitem>
193               <listitem>
194                 <para>
195                   use a more accurate read mechanism than the one of snooping on
196                   timers (like select on fd)
197                 </para>
198               </listitem>
199             </itemizedlist>
200           </para>
201           
202         </sect3>
203         
204         <sect3>
205           <title>Other sub systems</title>
206           
207           <para>
208             Could support other MIDI implementation for other sub systems (any
209             idea here ?)
210           </para>
211           
212           <para>
213             Could also implement a software synthesizer, either inside Wine or
214             using using MIDI loop back devices in an external program (like
215             timidity). The only trouble is that timidity is GPL'ed...
216           </para>
217           
218         </sect3>
219         
220       </sect2>
221       
222       <sect2>
223         <title>Mixer</title>
224         
225         <para>
226           MMSYSTEM and WINMM call the low level driver functions using the
227           mixMessage function.
228         </para>
229         
230         <sect3>
231           <title>OSS implementation</title>
232           
233           <para>
234             The current implementation uses the OpenSoundSystem mixer, and resides
235             in dlls/winmm/wineoss/mixer.c
236           </para>
237           
238           <para>TODO:
239             <itemizedlist>
240               <listitem>
241                 <para>
242                   implement notification mechanism when state of mixer's controls
243                   change
244                 </para>
245               </listitem>
246             </itemizedlist>
247           </para>
248           
249         </sect3>
250         
251         <sect3>
252           <title>Other sub systems</title>
253           
254           <para>TODO:
255             <itemizedlist>
256               <listitem>
257                 <para>
258                   implement mixing low level drivers for other mixers (ALSA...)
259                 </para>
260               </listitem>
261             </itemizedlist>
262           </para>
263           
264         </sect3>
265         
266       </sect2>
267       
268       <sect2>
269         <title>Aux</title>
270         
271         <para>
272           The AUX low level driver is the predecessor of the mixer driver
273           (introduced in Win 95).
274         </para>
275         
276         <sect3>
277           <title>OSS driver</title>
278           
279           <para>
280             The implementation uses the OSS mixer API, and is incomplete.
281           </para>
282           
283           <para>TODO:
284             <itemizedlist>
285               <listitem>
286                 <para>
287                   verify the implementation
288                 </para>
289               </listitem>
290               <listitem>
291                 <para>
292                   check with what is done in mixer
293                 </para>
294               </listitem>
295               <listitem>
296                 <para>
297                   open question: shall we implement it on top of the low level mixer
298                   functions ?
299                 </para>
300               </listitem>
301             </itemizedlist>
302        
303           </para>
304           
305         </sect3>
306         
307       </sect2>
308       
309       <sect2>
310         <title>Wine OSS</title>
311         
312         <para>
313            All the OSS dependent functions are stored into the WineOSS DLL. It still
314            lack a correct installation scheme (as any multimedia device under Windows), 
315            so that all the correct keys are created in the registry. This requires
316            an advanced model since, for example, the number of wave out devices can
317            only be known on the destination system (depends on the sound card driven
318            by the OSS interface). A solution would be to install all the multimedia
319            drivers through the SETUPX DLL; this is not doable yet (the multimedia 
320            extension to SETUPX isn't written yet).
321         </para>
322         
323       </sect2>
324
325       <sect2>
326         <title>Joystick</title>
327         
328         <para>
329           The API consists of the joy* functions found in dlls/winmm/joystick/joystick.c.
330           The implementation currently uses the Linux joystick device driver
331           API. It is lacking support for enhanced joysticks and has not been
332           extensively tested.
333         </para>
334         
335         <para>TODO:
336           <itemizedlist>
337             <listitem>
338               <para>
339                 better support of enhanced joysticks (Linux 2.2 interface is available)
340               </para>
341             </listitem>
342             <listitem>
343               <para>
344                 support more joystick drivers (like the XInput extension)
345               </para>
346             </listitem>
347             <listitem>
348               <para>
349                 should load joystick DLL as any other driver (instead of hardcoding)
350                 the driver's name, and load it as any low lever driver.
351               </para>
352             </listitem>
353           </itemizedlist>
354         </para>
355         
356       </sect2>
357       
358       <sect2>
359         <title>Wave mapper (msacm.drv)</title>
360         
361         <para>
362           The Wave mapper device allows to load on-demand codecs in order to
363           perform software conversion for the types the actual low level driver
364           (hardware). Those codecs are provided through the standard ACM
365           drivers.
366         </para>
367         
368         <sect3>
369           <title>Built-in</title>
370           
371           <para>
372             A first working implementation for wave out as been provided (wave in
373             exists, but doesn't allow conversion).
374           </para>
375           
376           <para>
377             Wave mapper driver implementation can be found in dlls/winmm/wavemap/
378             directory. This driver heavily relies on MSACM and MSACM32 DLLs which
379             can be found in dlls/msacm and dlls/msacm32. Those DLLs load ACM
380             drivers which provide the conversion to PCM format (which is normally
381             supported by low level drivers). ADPCM, MP3... fit into the category
382             of non PCM formats.
383           </para>
384           
385           <para>
386             There is currently no built-in ACM driver in Wine, so you must use
387             native ones if you're looking for non PCM playback.
388           </para>
389           
390           <para>TODO:
391             <itemizedlist>
392               <listitem>
393                 <para>
394                   check for correctness and robustness
395                 </para>
396               </listitem>
397             </itemizedlist>
398           </para>
399         </sect3>
400         
401         <sect3>
402           <title>Native</title>
403           
404           <para>
405             Seems to work quite ok (using of course native MSACM/MSACM32 DLLs)
406             Some other testings report some issues while reading back the registry
407             settings.
408           </para>
409           
410         </sect3>
411         
412       </sect2>
413       
414       <sect2>
415         <title>MIDI mapper</title>
416         
417         <para>
418           Midi mapper allows to map each one of 16 MIDI channels to a specific
419           instrument on an installed sound card. This allows for example to
420           support different MIDI instrument definition (XM, GM...). It also
421           permits to output on a per channel basis to different MIDI renderers.
422         </para>
423         
424         <sect3>
425           <title>Built-in</title>
426           
427           <para>
428             A built-in MIDI mapper can be found in dlls/winmm/midimap/. It partly
429             provides the same functionnality as the Windows' one. It allows to pick up
430             destination channels (you can map a given channel to a specific playback 
431             device channel (see the configuration bits for more details).
432           </para>
433           
434           <para>TODO:
435             <itemizedlist>
436               <listitem>
437                 <para>
438                   implement the Midi mapper features (instrument on the fly modification)
439                   if it has to be done as under Windows, it required parsing the midi
440                   configuration files (didn't find yet the specs)
441                 </para>
442               </listitem>
443             </itemizedlist>
444           </para>
445           
446         </sect3>
447         
448         <sect3>
449           <title>Native</title>
450           
451           <para>
452             The native midimapper from Win 98 works, but it requires a bunch of 
453             keys in the registry which are not part of the Wine source yet.
454           </para>
455           
456           <para>TODO:
457             <itemizedlist>
458               <listitem>
459                 <para>
460                   add native midimapper keys to the registry to let it run. This
461                   will require proper multimedia driver installation routines.
462                 </para>
463               </listitem>
464             </itemizedlist>
465           </para>
466           
467         </sect3>
468         
469       </sect2>
470       
471     </sect1>
472     
473     <sect1 id="mm-mci">
474       <title>Mid level drivers (MCI)</title>
475       
476       <para>                                       
477         The mid level drivers are represented by some common API functions,
478         mostly mciSendCommand and mciSendString. See status in chapter 3 for
479         more information. WINE implements several MCI mid level drivers
480         (status is given for both built-in and native implementation):
481       </para>
482       
483       <para>TODO: (apply to all built-in MCI drivers)
484         <itemizedlist>
485           <listitem>
486             <para>
487               use MMSYSTEM multitasking caps instead of the home grown
488             </para>
489           </listitem>
490         </itemizedlist>
491       </para>
492       
493       
494       <sect2>
495         <title>CDAUDIO</title>
496         
497         <sect3>
498           <title>Built-in</title>
499           
500           <para>
501             The currently best implementation is the MCI CDAUDIO driver that can
502             be found in dlls/winmm/mcicda/mcicda.c. The implementation is mostly
503             complete, there have been no reports of errors. It makes use of
504             misc/cdrom.c Wine internal cdrom interface.
505             This interface has been ported on Linux, FreeBSD and NetBSD. (Sun
506             should be similar, but are not implemented.)
507           </para>
508           
509           <para>
510             A very small example of a cdplayer consists just of the line
511             mciSendString("play cdaudio",NULL,0,0);
512           </para>
513           
514           <para>TODO:
515             <itemizedlist>
516               <listitem>
517                 <para>
518                   add support for other cdaudio drivers (Solaris...)
519                 </para>
520               </listitem>
521               <listitem>
522                 <para>
523                   add support for multiple cdaudio devices (plus a decent 
524                   configuration scheme)
525                 </para>
526               </listitem>
527               <listitem>
528                 <para>
529                   The DLL is not cleanly separated from the NTDLL DLL. The CDROM
530                   interface should be exported someway (or stored in a Wine only DLL)
531                 </para>
532               </listitem>
533             </itemizedlist>
534           </para>
535           
536         </sect3>
537         
538         <sect3>
539           <title>Native</title>
540           
541           <para>
542             Native MCICDA works also correctly... It uses the MSCDEX traps (on int
543             2f). However, some commands (like seeking) seem to be broken.
544           </para>
545           
546         </sect3>
547         
548       </sect2>
549       
550       <sect2>
551         <title>MCIWAVE</title>
552         
553         <sect3>
554           <title>Built-in</title>
555           
556           <para>
557             The implementation is rather complete and can be found in
558             dlls/winmm/mciwave/audio.c. It uses the low level audio API (although
559             not abstracted correctly).
560           </para>
561           
562           <para>FIXME:
563             <itemizedlist>
564               <listitem>
565                 <para>
566                   The MCI_STATUS command is broken.
567                 </para>
568               </listitem>
569             </itemizedlist>
570           </para>
571           
572           <para>TODO:
573             <itemizedlist>
574               <listitem>
575                 <para>
576                   check for correctness
577                 </para>
578               </listitem>
579               <listitem>
580                 <para>
581                   better use of asynchronous playback from low level
582                 </para>
583               </listitem>
584               <listitem>
585                 <para>
586                   better implement non waiting command (without the MCI_WAIT flag).
587                 </para>
588               </listitem>
589             </itemizedlist>
590           </para>
591           
592         </sect3>
593         
594         <sect3>
595           <title>Native</title>
596           
597           <para>
598             Native MCIWAVE works also correctly.
599           </para>
600           
601         </sect3>
602         
603       </sect2>
604       
605       <sect2>
606         <title>MCISEQ (MIDI sequencer)</title>
607         
608         <sect3>
609           <title>Built-in</title>
610           
611           <para>
612             The implementation can be found in dlls/winmm/mciseq/mcimidi.c. Except
613             from the Record command, should be close to completion (except for non
614             blocking commands, as many MCI drivers).
615           </para>
616           
617           <para>TODO:
618             <itemizedlist>
619               <listitem>
620                 <para>
621                   implement it correctly
622                 </para>
623               </listitem>
624               <listitem>
625                 <para>
626                   finish asynchronous commands (especially for reading/record)
627                 </para>
628               </listitem>
629               <listitem>
630                 <para>
631                   better implement non waiting command (without the MCI_WAIT flag).
632                 </para>
633               </listitem>
634               <listitem>
635                 <para>
636                   implement the recording features
637                 </para>
638               </listitem>
639             </itemizedlist>
640           </para>
641           
642         </sect3>
643         
644         <sect3>
645           <title>Native</title>
646           
647           <para>
648             Native MCIMIDI has been working but is currently blocked by scheduling
649             issues (mmTaskXXX no longer work).
650           </para><para>FIXME:
651             <itemizedlist>
652               <listitem>
653                 <para>
654                   midiStreamPlay get from time to time an incorrect MidiHdr when
655                   using the native MCI sequencer
656                 </para>
657               </listitem>
658             </itemizedlist>
659           </para>
660           
661         </sect3>
662         
663       </sect2>
664       
665       <sect2>
666         <title>MCIANIM</title>
667         
668         <sect3>
669           <title>Built-in</title>
670           
671           <para>
672             The implementation is in dlls/winmm/mcianim/.
673           </para>
674           
675           <para>TODO:
676             <itemizedlist>
677               <listitem>
678                 <para>
679                   implement it, probably using xanim or something similar.
680                 </para>
681               </listitem>
682             </itemizedlist>
683           </para>
684           
685         </sect3>
686         
687         <sect3>
688           <title>Native</title>
689           
690           <para>
691             Native MCIANIM is reported to work (but requires native video DLLs
692             also, even though the built-in video DLLs start to work correctly).
693           </para>
694           
695         </sect3>
696         
697       </sect2>
698       
699       <sect2>
700         <title>MCIAVI</title>
701         
702         <sect3>
703           <title>Built-in</title>
704           
705           <para>
706             The implementation is in dlls/winmm/mcianim/. Basic features are present, 
707             simple playing is available, even if lots remain to be done. It rather
708             heavily relies on MSVIDEO/MSVFW32 DLLs pair to work.
709           </para>
710           
711           <para>TODO:
712             <itemizedlist>
713               <listitem>
714                 <para>
715                   finish the implementation
716                 </para>
717               </listitem>
718               <listitem>
719                 <para>
720                   fix the audio/video synchronisation issue
721                 </para>
722               </listitem>
723             </itemizedlist>
724           </para>
725           
726         </sect3>
727         
728         <sect3>
729           <title>Native</title>
730           
731           <para>
732             Native MCIAVI is reported to work (but requires native video DLLs
733             also). Some files exhibit some deadlock issues anyway.
734           </para>
735           
736         </sect3>
737         
738       </sect2>
739       
740     </sect1>
741     
742     <sect1 id="mm-high">
743       <title>High level layers</title>
744       
745       <para>                                       
746         The rest (basically the MMSYSTEM and WINMM DLLs entry points). It also
747         provides the skeleton for the core functionality for multimedia
748         rendering. Note that native MMSYSTEM and WINMM do not currently work
749         under WINE and there is no plan to support them (it would require to
750         also fully support VxD, which is not done yet).
751         Moreover, native DLLs require 16 bit MCI and low level drivers. Wine
752         implements them as 32 bit drivers.
753         MCI and low level drivers can either be 16 or 32 bit for Wine.
754       </para>
755       
756       <para>TODO:
757         <itemizedlist>
758           <listitem>
759             <para>
760               it seems that some program check what's installed in registry
761               against value returned by drivers. Wine is currently broken
762               regarding this point.
763             </para>
764           </listitem>
765           <listitem>
766             <para>
767               add clean-up mechanisms when process detaches from MM DLLs
768             </para>
769           </listitem>
770           <listitem>
771             <para>
772               prepare for the 16/32 big split
773             </para>
774           </listitem>
775           <listitem>
776             <para>
777               check thread-safeness for MMSYSTEM and WINMM entry points
778             </para>
779           </listitem>
780           <listitem>
781             <para>
782               unicode entry points are badly supported
783             </para>
784           </listitem>
785         </itemizedlist>
786       </para>
787       
788       <sect2>
789         <title>MCI skeleton</title>
790         
791         <para>
792           Implementation of what is needed to load/unload MCI drivers, and to
793           pass correct information to them. This is implemented in
794           dlls/winmm/mci.c. The mciSendString function uses command strings,
795           which are translated into normal MCI commands as used by
796           mciSendCommand with the help of command tables. The API can be found
797           in dlls/winmm/mmsystem.c and dlls/winmm/mci.c. The functions there
798           (mciOpen,mciSysInfo) handle mid level driver allocation and calls. The
799           implementation is not complete.
800         </para>
801         
802         <para>
803           MCI drivers are seen as regular WINE modules, and can be loaded (with
804           a correct load order between built-in, native, elfdll, so), as any
805           other DLL. Please note, that MCI drivers module names must bear the
806           .drv extension to be correctly understood.
807         </para>
808         
809         <para>
810           The list of available MCI drivers is obtained as follows:
811           1. key 'mci' in [option] section from .winerc (or wineconf)
812           mci=CDAUDIO:SEQUENCER gives the list of MCI drivers (names, in
813           uppercase only) to be used in WINE.
814           2. This list, when defined, supersedes the mci key in
815           c:\windows\system.ini
816        </para>
817         
818         <para>
819           Note that native VIDEODISC crashes when the module is loaded, which
820           occurs when the MCI procedures are initialised. Make sure that this is
821           not in the list from above. Try adding:
822           mci=CDAUDIO:SEQUENCER:WAVEAUDIO:AVIVIDEO:MPEGVIDEO
823           to the [options] section of wine.conf.
824         </para>
825         
826         <para>TODO:
827           <itemizedlist>
828             <listitem>
829               <para>
830                 correctly handle the MCI_ALL_DEVICE_ID in functions.
831               </para>
832             </listitem>
833             <listitem>
834               <para>
835                 finish mapping 16 <=> 32 of MCI structures and commands
836               </para>
837             </listitem>
838             <listitem>
839               <para>
840                 MCI_SOUND is not handled correctly (should not be sent to MCI
841                 driver =&gt; same behavior as MCI_BREAK)
842               </para>
843             </listitem>
844             <listitem>
845               <para>
846                 implement auto-open feature (ie, when a string command is issued
847                 for a not yet opened device, MCI automatically opens it)
848               </para>
849             </listitem>
850           </itemizedlist>
851         </para>
852         
853       </sect2>
854       
855       <sect2>
856         <title>MCI multi-tasking</title>
857         
858         <para>
859           Multi-tasking capabilities used for the MCI drivers are provided in
860           dlls/winmm/mmsystem.c.
861         </para>
862         
863         <para>TODO:
864           <itemizedlist>
865             <listitem>
866               <para>
867                 mmTaskXXX functions are currently broken because the 16 loader does
868                 not support binary command lines =&gt; provide Wine's own mmtask.tsk not
869                 using binary command line.
870               </para>
871             </listitem>
872             <listitem>
873               <para>
874                 the Wine native MCI drivers should use the mmThreadXXX API (but since
875                 all built-in MCI drivers are 32 bit, this would require a special
876                 flag to mark 32 bit entry points)
877               </para>
878             </listitem>
879           </itemizedlist>
880         </para>
881         
882       </sect2>
883       
884       <sect2>
885         <title>Timers</title>
886         
887         <para>
888           It currently uses a service thread, run in the context of the calling
889           process, which should correctly mimic Windows behavior.
890         </para>
891         
892         <para>TODO:
893           <itemizedlist>
894             <listitem>
895               <para>
896                 Check if minimal time is satisfactory for most programs.
897               </para>
898             </listitem>
899             <listitem>
900               <para>
901                 current implementation may let a timer tick (once) after it has
902                 been destroyed
903               </para>
904             </listitem>
905           </itemizedlist>
906         </para>
907         
908       </sect2>
909       
910       <sect2>
911         <title>MMIO</title>
912         
913         <para>
914           The API consists of the mmio* functions found in mdlls/winmm/mmio.c.
915           Seems to work ok in most of the cases. There's some linear/segmented
916           issues with 16 bit code. There are also some bugs when writting MMIO
917           files.
918         </para>
919         
920       </sect2>
921       
922       <sect2>
923         <title>sndPlayXXX functions</title>
924         
925         <para>
926           Seem to work correctly.
927         </para>
928         
929       </sect2>
930       
931     </sect1>
932     
933     <sect1 id="mm-conf">
934       <title>Multimedia configuration</title>
935       
936       <para>
937         Currently, multimedia configuration heavily relies on Win 3.x
938         configuration model.
939       </para>
940       
941       <sect2>
942         <title>Drivers</title>
943         
944         <para>
945           Since all multimedia drivers (MCI, low level ones, ACM drivers,
946           mappers) are, at first, drivers they need to appear in the [mci] or
947           [mci32] section of the system.ini file.
948           Since all drivers are, at first, DLLs, you can choose to load their
949           Wine's (built-in) or Windows (native) version.
950         </para>
951         
952       </sect2>
953       
954       <sect2>
955         <title>MCI</title>
956         
957         <para>
958           A default [mci] section (in system.ini) looks like (see the note above
959           on videodisc):
960         </para>
961         
962         <screen>
963    [mci]
964    cdaudio=mcicda.drv
965    sequencer=mciseq.drv
966    waveaudio=mciwave.drv
967    avivideo=mciavi.drv
968    videodisc=mcipionr.drv
969    vcr=mcivisca.drv
970    MPEGVideo=mciqtz.drv
971         </screen>
972         
973         <para>
974           By default, the list of loadable MCI drivers will be made of those
975           drivers (in the [mci] section).
976         </para>
977         
978         <para>
979           The list of loadable (recognized) MCI drivers can be altered in the
980           [option] section of wine.conf, like:
981           mci=CDAUDIO:SEQUENCER:WAVEAUDIO:AVIVIDEO:MPEGVIDEO
982         </para>
983         
984         <para>TODO:
985           <itemizedlist>
986             <listitem>
987               <para>
988                 use a default registry setting to bypass this (ugly) configuration
989                 model
990               </para>
991             </listitem>
992           </itemizedlist>
993         </para>
994         
995       </sect2>
996       
997       <sect2>
998         <title>Low level drivers</title>
999         
1000         <para>
1001            Configuration of low level drivers is done with the Wine configuration file. 
1002            Default keys are provided in winedefault.reg.
1003         </para>
1004
1005         <para>
1006           The registry keys used here differ from the Windows' one. Using the Windows' one
1007           would require implementing something equivalent to a (real) driver installation. 
1008           Even if this would be necessary in a few cases (mainly using MS native multimedia)
1009           modules, there's no real need so far (or it hasn't been run into yet).
1010         </para>
1011
1012         <para>
1013           See the configuration part of the User's Guide for more details.
1014         </para>
1015
1016       </sect2>
1017
1018       <sect2>
1019         <title>Midi mapper</title>
1020
1021         <para>
1022           The Midi mapper configuration is the same as on Windows 9x. Under the key
1023           <screen>
1024 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Multimedia\MIDIMap
1025           </screen>
1026           if the 'UseScheme' value is not set, or is set to a null value, the midi 
1027           mapper will always use the driver identified by the 'CurrentInstrument' 
1028           value. Note: Wine (for simplicity while installing) allows to define 
1029           'CurrentInstrument' as "#n" (where n is a number), whereas Windows only
1030           allows the real device name here. If UseScheme is set to a non null value, 
1031           'CurrentScheme' defines the name of the scheme to map the different channels. 
1032           All the schemes are available with keys like
1033           <screen>
1034 HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\MediaProperties\PrivateProperties\Midi\Schemes\%name_of_scheme%
1035           </screen>
1036           For every scheme, under this key, will be a sub-key (which name is usually 
1037           a two digit index, starting at 00). Its default value is the name of the 
1038           output driver, and the value 'Channels' lists all channels (of the 16 
1039           standard MIDI ones) which have to be copied to this driver.
1040         </para>
1041
1042         <para>
1043           To provide enhanced configuration and mapping capabilities, each driver 
1044           can define under the key
1045           <screen>
1046 HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\MediaProperties\PrivateProperties\Midi\Ports\%driver_name%
1047           </screen>
1048           a link to and .IDF file which allows to remap channels internally (for 
1049           example 9 -&gt; 16), to change instruments identification, event 
1050           controlers values. See the source file dlls/winmm/midimap/midimap.c 
1051           for the details (this isn't implemented yet).
1052         </para>
1053       </sect2>
1054       
1055       <sect2>
1056         <title>ACM</title>
1057         
1058         <para>
1059           To be done (use the same mechanism as MCI drivers configuration).
1060         </para>
1061         
1062       </sect2>
1063       
1064       <sect2>
1065         <title>VIDC</title>
1066         
1067         <para>
1068           To be done (use the same mechanism as MCI drivers configuration).
1069         </para>
1070         
1071       </sect2>
1072       
1073     </sect1>
1074     
1075     <sect1 id="mm-arch">
1076       <title>Multimedia architecture</title>
1077       
1078       <sect2>
1079         <title>Windows 9x multimedia architecture</title>
1080         
1081         <screen>
1082              |
1083 Kernel space |                    Client applications
1084              |
1085              |           | |         ^ ^       | |          | |
1086              |        16>| |<32   16>| |<32 16>| |<32    16>| |<32
1087              |           | v         | |       | v          | v
1088              |      +----|-----------|---------|------------|-------+
1089              |      |    |           |         |            |       |  WinMM.dll
1090              |      |    |           |         |            |       |   32 bit
1091              |      +----|-----------|---------|------------|-------+
1092              |           | |         | ^       | |          |
1093              |  +------+ | |<16      | |       | |<16       |
1094              |  |   16>| | |         | |       | |          |
1095              |  |      v v v         | |       v v          v
1096              |  |   +---------------+---+-------------+-------------+
1097              |  |   | waveInXXX     |   | mciXXX      | *playSound* |
1098              |  |   | waveOutXXX    |   |             | mmioXXX     |
1099              |  |   | midiInXXX     |   |             | timeXXX     |
1100              |  |   | midiOutXXX    |   |             | driverXXX   |
1101              |  |   | midiStreamXXX |   |             |             |  MMSystem.dll
1102              |  |   | mixerXXX      |   |             |             |     16 bit
1103  +--------+  |  |   | auxXXX    +---+   +---+ mmThread|             |
1104  |MMDEVLDR|<------->| joyXXX    | Call back | mmTask  |             |
1105  +--------+  |  |   +-----------+-----------+---------+-------------+
1106      ^       |  |          |       ^    ^     | ^
1107      |       |  |       16>|       |<16>|  16>| |<16
1108      v       |  |          v       |    |     v |
1109  +--------+  |  |   +-------------+    +----------+
1110  |  VxD   |<------->|    *.drv    |    | mci*.drv |
1111  +--------+  |  |   +--------------+   +-----------+
1112              |  |    |  msacm.drv  |    | mciwave  |
1113              |  |    +--------------+   +-----------+
1114              |  |     | midimap.drv |    | mcimidi  |
1115              |  |     +-------------+    +-----------+
1116              |  |    Low-level drivers    |    ...   | MCI drivers
1117              |  |                         +----------+
1118              |  |                               |
1119              |  |                               |<16
1120              |  +-------------------------------+
1121              |
1122         </screen>
1123         
1124         <para>
1125           The important points to notice are:
1126           <itemizedlist>
1127             <listitem>
1128               <para>
1129                 all drivers (and most of the core code) is 16 bit
1130               </para>
1131             </listitem>
1132             <listitem>
1133               <para>
1134                 all hardware (or most of it) dependant code reside in the kernel
1135                 space (which is not surprising)
1136               </para>
1137             </listitem>
1138           </itemizedlist>
1139         </para>
1140         
1141       </sect2>
1142       
1143       <sect2>
1144         <title>Wine multimedia architecture</title>
1145         
1146         <screen>
1147              |
1148 Kernel space |                    Client applications
1149              |
1150              |           | |         ^ ^       | |          | |
1151              |        16>| |<32   16>| |<32 16>| |<32    16>| |<32
1152              |           | |         | |       | |          | |
1153              |  +------+ | |         | |       | |          | |
1154              |  |32/16>| | |         | |       | |          | |
1155              |  |      v v v         | |       v v          v v
1156              |  |   +---------------+---+-------------+-------------+
1157              |  |   | waveInXXX     |   | mciXXX      | *playSound* |
1158              |  |   | waveOutXXX    |   |             | mmioXXX     | WinMM.dll
1159              |  |   | midiInXXX     |   |             | timeXXX     |   32 bit
1160              |  |   | midiOutXXX    |   |             | driverXXX   |
1161              |  |   | midiStreamXXX |   |             |             | MMSystem.dll
1162              |  |   | mixerXXX      |   |             |             |   16 bit
1163              |  |   | auxXXX    +---+   +---+ mmThread|             |
1164              |  |   | joyXXX    | Call back | mmTask  |             |
1165              |  |   +-----------+-----------+---------+-------------+
1166              |  |         ||      ^    ^     ||    ^^
1167              |  |      16>||<32   |<16>|  16>||<32>||<16
1168              |  |         vv      |<32>|     vv    ||
1169 +---------+  |  |   +-------------+    +----------+
1170 |HW driver|<------->|    *.drv    |    | mci*.drv |
1171 +---------+  |  |   +--------------+   +-----------+
1172              |  |    |  msacm.drv  |    | mciwave  |
1173              |  |    +--------------+   +-----------+
1174              |  |     | midimap.drv |    | mcimidi  |
1175              |  |     +-------------+    +-----------+
1176              |  |    Low-level drivers    |    ...   | MCI drivers
1177              |  |                         +----------+
1178              |  |                               |
1179              |  |                               |<32/16
1180              |  +-------------------------------+
1181              |
1182         </screen>
1183         
1184         <para>
1185           From the previous drawings, the most noticeable differences are:
1186           <itemizedlist>
1187             <listitem>
1188               <para>
1189                 low-level drivers can either be 16 or 32 bit
1190               </para>
1191             </listitem>
1192             <listitem>
1193               <para>
1194                 MCI drivers can either be 16 or 32 bit
1195               </para>
1196             </listitem>
1197             <listitem>
1198               <para>
1199                 MMSystem and WinMM will be hosted in a single elfglue library
1200               </para>
1201             </listitem>
1202             <listitem>
1203               <para>
1204                 no link between the MMSystem/WinMM pair on kernel space shall
1205                 exist. For example, there will be a low level driver to talk to a
1206                 UNIX OSS (Open Sound System) driver
1207               </para>
1208             </listitem>
1209             <listitem>
1210               <para>
1211                 all built-in drivers (low-level and MCI) will be written as 32 bit
1212                 drivers
1213               </para>
1214             </listitem>
1215             <listitem>
1216               <para>
1217                 all native drivers will be 16 bits drivers
1218               </para>
1219             </listitem>
1220           </itemizedlist>
1221         </para>
1222         
1223       </sect2>
1224       
1225     </sect1>
1226     
1227           <sect1 id="msacm">
1228             <title>MS ACM Dlls</title>
1229             
1230             <sect2>
1231               <title>Contents</title>
1232
1233               <para>tbd</para>
1234             </sect2>
1235
1236             <sect2>
1237               <title>Status</title>
1238
1239               <para>tbd</para>
1240             </sect2>
1241             
1242             <sect2>
1243               <title>Caching</title>
1244               
1245               <para>
1246                 The MSACM/MSACM32 keeps some data cached for all known ACM
1247                 drivers. Under the key
1248                 <screen>
1249                   Software\Microsoft\AudioCompressionManager\DriverCache\&lt;driver
1250                   name&gt;
1251                 </screen>
1252                 are kept for values:
1253                 <itemizedlist>
1254                   <listitem>
1255                     <para>
1256                       aFormatTagCache which contains an array of
1257                       DWORD. There are two DWORDs per cFormatTags
1258                       entry. The first DWORD contains a format tag
1259                       value, and the second the associated maximum
1260                       size for a WAVEFORMATEX structure.
1261                       (Fields dwFormatTag and cbFormatSize from
1262                       ACMFORMATDETAILS) 
1263                     </para>
1264                   </listitem>
1265                   <listitem>
1266                     <para>
1267                       cFilterTags contains the number of tags supported by the driver
1268                       for filtering.
1269                     </para>
1270                   </listitem>
1271                   <listitem>
1272                     <para>
1273                       cFormatTags contains the number of tags support
1274                       by the driver for conversions.
1275                     </para>
1276                   </listitem>
1277                   <listitem>
1278                     <para>
1279                       fdwSupport (the same as the one returned from
1280                       acmDriverDetails). 
1281                     </para>
1282                   </listitem>
1283                 </itemizedlist>
1284               </para>
1285
1286               <para>
1287                 The cFilterTags, cFormatTags, fdwSupport are the same
1288                 values as the ones returned from acmDriverDetails
1289                 function.
1290               </para>
1291             </sect2>
1292           </sect1>
1293
1294
1295   </chapter>
1296
1297 <!-- Keep this comment at the end of the file
1298 Local variables:
1299 mode: sgml
1300 sgml-parent-document:("wine-doc.sgml" "set" "book" "part" "chapter" "")
1301 End:
1302 -->