1999-06-26 12:20:34 +02:00
|
|
|
This file contains information about the implementation of the
|
|
|
|
multimedia layer of WINE.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The libraries consist of MMSYSTEM.DLL (win16), WINMM.DLL (win32) and
|
|
|
|
some (abstracted, not Windows compatible) lowlevel drivers. The
|
|
|
|
implementation can be found in the multimedia/ subdirectory.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The multimedia stuff is split into 3 layers. The lowlevel (device
|
|
|
|
drivers), midlevel (MCI commands) and highlevel abstraction layers.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The lowlevel may depend on current hardware and OS services (like
|
|
|
|
OSS). Mid-level and high-level must be written independantly from the
|
|
|
|
hardware and OS services.
|
1998-11-24 19:54:18 +01:00
|
|
|
|
1998-03-15 21:29:56 +01:00
|
|
|
1. Lowlevel layers
|
1999-06-26 12:20:34 +02:00
|
|
|
==================
|
|
|
|
|
|
|
|
Please note that native low-level drivers are not currently
|
|
|
|
supported in WINE, because they either access hardware composants
|
|
|
|
or require VxDs to be loaded; WINE does not correctly supports
|
|
|
|
those two so far.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
Following lowlevel layers are implemented:
|
1999-05-02 12:21:49 +02:00
|
|
|
|
1998-03-15 21:29:56 +01:00
|
|
|
1.1 (Waveform) Audio
|
1999-06-26 12:20:34 +02:00
|
|
|
--------------------
|
|
|
|
|
|
|
|
MMSYSTEM and WINMM call the real lowlevel audiodriver using
|
|
|
|
the wodMessage/widMessage function in multimedia/audio.c, which
|
|
|
|
handles the different requests.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
1.1.1 OSS implementation
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The lowlevel audio driver is currently only implemented for the
|
|
|
|
OpenSoundSystem (OSS) as supplied in the Linux and FreeBSD kernels
|
|
|
|
by 4Front Technologies (http://www.4front-tech.com/). The presence
|
|
|
|
of this driver is checked by configure (depends on the
|
|
|
|
<sys/soundcard.h> file).
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The implementation contains all features commonly used, but has
|
|
|
|
several problems (see TODO list).
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
TODO:
|
1999-06-26 12:20:34 +02:00
|
|
|
- add asynchronous reads (must use threads) as done for writes
|
1998-03-15 21:29:56 +01:00
|
|
|
- verify all functions for correctness
|
1999-06-26 12:20:34 +02:00
|
|
|
- add drivers for other soundsystems (Sun Audio, remote audio
|
|
|
|
systems (using X extensions, ...), ALSA
|
|
|
|
- WaveHdr must be sent though mmsystem.c to get the linear
|
|
|
|
address set correctly. An application calling directly
|
|
|
|
(wod|wid)Message will fail
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
1.1.2 Wave mapper
|
|
|
|
|
|
|
|
The Wave mapper device allows to load on-demand codecs to perform
|
|
|
|
software conversion for the types the actual low level driver
|
|
|
|
(hardware) does not support. Those codecs are provided thru the
|
|
|
|
standard ACM drivers.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
Wave mapper driver implementation has not started. Core DLL for ACM
|
|
|
|
support can be found in dlls/msacm
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
TODO:
|
1999-06-26 12:20:34 +02:00
|
|
|
- implement wave mapper
|
|
|
|
- don't forget to fix builtin ms acm drivers loading which has
|
|
|
|
been disabled.
|
|
|
|
|
|
|
|
1.2 MIDI
|
|
|
|
--------
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
MMSYSTEM and WINMM call the lowlevel driver functions in
|
|
|
|
multimedia/midi.c using the midMessage and the modMessage
|
|
|
|
functions.
|
|
|
|
|
|
|
|
1.2.1 OSS driver
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The lowlevel audio driver is currently only implemented for the
|
|
|
|
OpenSoundSystem (OSS) as supplied in the Linux and FreeBSD kernels
|
|
|
|
by 4Front Technologies (http://www.4front-tech.com/). The presence
|
|
|
|
of this driver is checked by configure (depends on the
|
|
|
|
<sys/soundcard.h> file, and also some specfic defines because MIDI
|
|
|
|
is not supported on all OSes by OSS).
|
|
|
|
Both Midi in and Midi out are provided. The type of MIDI devices
|
|
|
|
supported is external MIDI port (requires an MIDI capable device -
|
|
|
|
keyboard...) and OPL/2 synthesis (the OPL/2 patches for all
|
|
|
|
instruments are in midiPatch.c).
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
TODO:
|
|
|
|
- Do not implement a software synthesizer. This should be done
|
1999-06-26 12:20:34 +02:00
|
|
|
using MIDI loopback devices in an external program (like
|
|
|
|
timidity). The only trouble is that timidity is GPL'ed...
|
1999-03-15 16:42:51 +01:00
|
|
|
- use better instrument definition for OPL/2 (midiPatch.c) or
|
|
|
|
use existing instrument definition (from playmidi or kmid)
|
|
|
|
with a .winerc option
|
Release 980927
Sun Sep 27 14:25:38 1998 Petter Reinholdtsen <pere@td.org.uit.no>
* [files/drive.c]
Make sure GetDriveType32A() handles param NULL. Added some
doc on function.
Sun Sep 27 14:07:26 1998 Huw D M Davies <daviesh@abacus.physics.ox.ac.uk>
* [controls/edit.c] [windows/win.c]
Don't call SetWindowLong() in EDIT_WM_NCREATE.
Fix SetWindowLong(GWL_[EX]STYLE) to work for 16bit windows. Remove
UpdateWindow() call.
Sun Sep 27 13:41:22 1998 Alexandre Julliard <julliard@lrc.epfl.ch>
* [scheduler/*.c] [server/event.c] [server/mutex.c]
[server/semaphore.c]
Implemented server-side synchronisation objects.
Sun Sep 27 01:13:35 1998 Alex Priem <alexp@sci.kun.nl>
* [dlls/comctl32/treeview.c] [include/treeview.h] [include/comctl.h]
Treeview implementation.
* [dlls/comctl32/trackbar.c] [include/trackbar.h]
Trackbar implementation.
Sat Sep 26 20:49:13 1998 Ulrich Weigand <weigand@informatik.uni-erlangen.de>
* [if1632/thunk.c] [tools/build.c] [win32/kernel32.c]
Bugfix: several problems with flat thunks fixed.
* [memory/selector.c]
Bugfix: IsBad...Ptr16 didn't work for limit_in_pages segments.
* [scheduler/thread.c]
Bugfix: CreateThread: Allow id parameter == NULL.
* [objects/gdiobj.c]
Bugfix: IsGDIObject: Return correct object type for stock objects.
* [msdos/dpmi.c]
Bugfix: fixed typo in INT_DoRealModeInt.
* [msdos/int21.c]
Bugfix: int21 READ *must* use WIN16_hread, not _hread16.
* [if1632/kernel.spec] [if1632/dummy.c] [if1632/thunk.c]
[loader/ne/module.c] [scheduler/event.c] [scheduler/synchro.c]
[scheduler/thread.c] [win32/kernel32.c] [win32/ordinals.c]
Added names/stubs for all undocumented KERNEL routines (Win95).
Added the following undoc. 16-bit equivalents to Win32 routines:
KERNEL.441-443,449-453,456-462,471-476,479-486,488.
Added stubs for some other KERNEL routines.
* [memory/heap.c] [memory/global.c] [include/global.h]
Implemented Local32... 32-bit local heap routines (KERNEL.208-215, 229).
* [miscemu/instr.c] [loader/module.c] [include/module.h]
Implemented __GP fault handling and HasGPHandler (KERNEL.338).
* [misc/error.c]
Implemented LogParamErrorRegs (KERNEL.327).
* [loader/task.c] [include/windows.h]
Implemented GetCodeInfo (KERNEL.104).
* [loader/task.c] [scheduler/thread.c] [include/thread.h]
Implemented [GS]etThreadQueue and [GS]etFastQueue (KERNEL.463/4, 624/5).
* [if1632/gdi.spec] [objects/dc.c] [objects/dib.c]
[objects/bitmap.c] [include/windows.h]
Bugfix: fixed wrong parameter for CreateDIBSection16.
Added [GS]etDIBColorTable16, stub for GetBoundsRect16.
Partially implemented BITMAP_GetObject16 for DIBs.
* [if1632/gdi.spec] [relay32/gdi32.spec] [objects/palette.c]
Added some GDI stubs.
* [if1632/Makefile.in] [if1632/display.spec] [if1632/mouse.spec]
[if1632/keyboard.spec] [if1632/builtin.c] [windows/keyboard.c]
Added some stubs for Win16 drivers: KEYBOARD, MOUSE, DISPLAY.
* [if1632/wprocs.spec] [msdos/vxd.c]
Added some stubs for VxDs: VMM, ConfigMG, TimerAPI.
* [msdos/int2f.c]
Added some stubs for real-mode network drivers.
Sat Sep 26 18:18:18 1998 Marcus Meissner <marcus@jet.franken.de>
* [configure.in]
Merged in some more of the FreeBSD ports/emulators/wine patches.
(Maintainer(s) of this port: You can just submit these
patches to Alexandre directly.)
* [loader/pe_image.c]
Check filesize of image against size derived from header
to spot truncated executeables without crashing.
* [files/directory.c]
Set envvar "COMSPEC". One win32(!!) program crashes without it.
* [multimedia/mmio.c]
Added mmioSetInfo32.
* [include/file.h]
Return STD_ERROR_HANDLE for AUX and PRT dos handles.
* [loader/module.c]
Handle executeables with spaces in their names a bit better in
CreateProcess.
* [relay32/msvfw32.spec][if1632/msvideo.spec][multimedia/msvideo.c][include/vfw.h]
Started on MS Video support (can load Win32 ICMs).
* [tools/testrun]
A bit smarter use of ps.
* [memory/virtual.c]
Report PAGE_GUARDed pages as PAGE_PROTECTED (AutoCAD LT R17 fails
without that check (since Win95 doesn't know about PAGE_GUARD)).
Sat Sep 26 15:04:05 1998 Ove Kaaven <ovek@arcticnet.no>
* [include/miscemu.h] [if1632/builtin.c] [loader/task.c]
[miscemu/instr.c] [msdos/dpmi.c] [msdos/int21.c]
[msdos/interrupts.c] [windows/user.c]
INT_[S|G]etHandler was renamed to INT_[S|G]etPMHandler.
Added handlers to deal with real-mode interrupts; DOS
programs are now able to hook real-mode interrupts.
* [loader/dos/module.c] [msdos/dosmem.c] [msdos/int21.c]
Moved real-mode interrupt table initialization to
msdos/dosmem.c, and made new V86 tasks get a full copy
of the existing "system memory" instead of almost empty
space. Misc fixes.
* [include/dosexe.h] [loader/dos/module.c] [msdos/dpmi.c]
[msdos/int2f.c]
First shot at letting DOS programs start up DPMI (but DPMI
is still disabled for DOS programs, for pkunzip's sake).
* [include/debugger.h] [debugger/break.c] [debugger/dbg.y]
[debugger/registers.c] [debugger/memory.c] [debugger/info.c]
[loader/dos/dosvm.c]
First shot at making Wine's debugger work for DOS programs.
The -debug flag works, as do "nexti" and "stepi".
Sat Sep 26 13:13:13 1998 Juergen Schmied <juergen.schmied@metronet.de>
* [dlls/shell32/dataobject.c]
New classes IEnumFORMATETC implemented, IDataObject stubs.
* [dlls/shell32/*.*][relay32/shell32.spec]
Bugfixes.
New: ICM_InsertItem(), ILCreateFromPath().
Implemented: ILCloneFirst().
Stubs: ILIsEqual(), ILFindChild(), SHLogILFromFSIL(),
PathMatchSpec(), PathIsExe().
Changed: ILGetSize(), _ILIsDesktop(), PathCombine().
* [include/shlobj.h]
New SHLGUID's
New structures: DVTARGETDEVICE32, STGMEDIUM32, FORMATETC32,
CLIPFORMAT32.
New interfaces: IEnumFORMATETC, IDataObject, ICommDlgBrowser
IDockingWindowFrame, IServiceProvider.
* [dlls/shell32/folders.c]
Stubs for IShellLink.
* [loader/resource.c]
Small fixes.
* [misc/crtdll.c][relay32/crtdll.spec]
New __dllonexit().
* [windows/message.c]
SendNotifyMessageA, SendMessageCallBack32A half implemented.
* [controls/edit.c]
EDIT_WM_SetText set EF_UPDATE flag not for ES_MULTILINE.
* [files/file.c]
Handling of fileposition fixed.
Fri Sep 25 18:13:30 1998 Patrik Stridvall <ps@leissner.se>
* [include/windows.h] [include/wintypes.h]
[ole/ole2nls.h] [relay32/kernel32.spec]
Implemented EnumDateFormats and EnumTimeFormats.
Only adds US English support.
* [Makefile.in] [configure.in]
[dlls/Makefile.in] [dlls/psapi/Makefile.in]
[dlls/psapi/psapi_main.c]
New files to implement stubs for PSAPI.DLL (NT only).
* [relay32/Makefile.in] [relay32/builtin32.c]
[relay32/psapi.spec]
New spec file for PSAPI.DLL (NT only).
* [scheduler/handle.c]
HANDLE_GetObjPtr should only interpret the pseudo handles as the
current thread or the current process if a thread or a process is
requested.
* [include/winversion.h] [misc/version.c]
Adds the global function VERSION_GetVersion() so functions can
have different behavior depending on the -winver flag.
* [include/oledlg.h] [ole/oledlg.c]
Minor fixes.
* [windows/winproc.c]
Minor changes.
* [include/imm.h] [misc/imm.c]
Now returns correct values under both Windows 95 and NT 4.0.
Thu Sep 24 22:11:44 1998 Kristian Nielsen <kristian.nielsen@risoe.dk>
* [configure.in] [include/acconfig.h] [include/thread.h]
[scheduler/sysdeps.c]
Autoconfig test for non-reentrant libc.
Wed Sep 23 19:52:12 1998 Matthew Becker <mbecker@glasscity.net>
* [*/*.c]
Miscellaneous documentation updates and debugging output
standardizations.
* [objects/clipping.c]
Added ExtSelectClipRgn.
Wed Sep 23 00:03:28 EDT 1998 Pete Ratzlaff <pratzlaff@cfa.harvard.edu>
* [include/windows.h] [if1632/user.spec] [relay32/user32.spec]
[windows/keyboard.c]
Added, marginally implemented, GetKeyboardLayoutName().
Only returns US English keyboard name.
Tue Sep 22 16:32:41 1998 Marcel Baur <mbaur@iiic.ethz.ch>
* [programs/control/*]
New Winelib application.
Mon Sep 21 00:29:18 1998 Peter Hunnisett <hunnise@nortel.ca>
* [include/dplay.h][multimedia/dplay.c][ole/compobj.c]
Added all DirectPlayLobby interfaces and enhanced DirectPlay
and DirectPlayLobby support. Still not all that much. Useful
enough if you just need to start a program, don't try any
real dplay/lobby stuff.
* [documentation/status/directplay]
Added a very little bit.
* [graphics/ddraw.c]
- Call to SetWindowLong32A wasn't working because there was no
memory set aside when the window class was registered.
- Fixed some xlib reference counting and change the behaviour
of DirectDrawSurface3_SetPalette to mimic observed behaviour
(palette is associated will all backbuffers)
- Also stored all palette colour fields and spit back our saved
colour fields rather than query X for them.
- Added plenty of AddRef and Release traces.
- Added Xlib support for using -desktop option.
- Fixed Xlib message handling. Messages weren't being passed to
the application. Fixes mouse movements in some xlib DDraw games.
- Added a few stubs.
* [windows/win.c][include/winerror.h]
Fixed up some error handling in WIN_SetWindowLong. SetLastError
wasn't being used. Could cause problems with 0 return codes.
Added new error in winerror (1400).
* [AUTHORS] [include/authors.h]
Added myself as a Wine author.
Sun Sep 20 21:22:44 1998 Alexander Larsson <alla@lysator.liu.se>
* [loader/module.c]
Changed GetModuleFileName32A so that is returns the
long version of the filename. Note that just the name
is long, not the directories.
Sat Sep 19 20:05:30 1998 Per ngstrm <pang@mind.nu>
* [controls/menu.c]
Made a couple of fixes to make life easier for applications that alter
their menus at runtime.
* [windows/defdlg.c]
Removed the cast of the return value from dialog procedures to a 16-bit
bool. The return value needs to retain all its 32 bits, since it is not
always a bool, such as when responding to the WM_NCHITTEST message.
Fri Sep 18 11:30:38 1998 Sergey Turchanov <turchanov@usa.net>
* [loader/resource.c]
Fixed very funny bug (though gravely affecting further excecution)
with FindResource[Ex]32 functions.
* [include/multimon.h] [windows/multimon.c] [relay32/user32.spec]
[include/windows.h] [windows/sysmetrics.c]
Default implementation for Multimonitor API.
* [include/windows.h] [windows/winpos.c]
Fixed incorrect declaration (and behaviour) of GetWindowRect32.
Wed Sep 16 10:21:15 1998 Gerard Patel <G.Patel@Wanadoo.fr>
* [controls/edit.c]
Fixed EDIT_EM_GetLine to use correctly length of lines.
Tue Sep 15 20:40:16 1998 Eric Kohl <ekohl@abo.rhein-zeitung.de>
* [misc/tweak.c][include/tweak.h][controls/menu.c]
Replaced the tweak graphic routines by calls to DrawEdge32().
* [misc/tweak.c][include/tweak.h][documentation/win95look]
[wine.ini][*/*]
Changed "look and feel" selection. Allows Win3.1, Win95 and
Win98 (no GUI code implemented) look and feel.
* [dlls/comctl32/header.c][include/header.h][include/commctrl.h]
Started callback item support and did some minor improvements.
* [dlls/comctl32/imagelist.c]
Fixed bug in transparent image display.
ImageList_GetIcon is still buggy :-(
* [dlls/comctl32/toolbar.c]
Fixed button drawing (partial hack).
* [dlls/comctl32/commctrl.c]
Fixed MenuHelp().
* [controls/button.c]
Added 3d effect for groupbox.
* [windows/msgbox.c]
Added font support for message boxes.
* [windows/nonclient.c]
Fixed window moving bug.
* [dlls/comctl32/*.c]
Various improvements.
* [dlls/comctl32/listview.c][dlls/comctl32/rebar.c]
[include/commctrl.h]
More messages.
* [windows/syscolor.c][include/windows.h]
Introduced new Win98 system colors.
Tue Sep 15 18:29:45 1998 Wesley Filardo <eightknots@aol.com>
* [files/profile.c]
Added support in PROFILE_LoadWineIni for -config option
* [misc/main.c] [include/options.h]
Added -config option.
Tue Sep 15 18:22:26 1998 Petter Reinholdtsen <pere@td.org.uit.no>
* [documentation/Makefile.in]
Make sure directory exists before installing into it.
Tue Sep 15 01:47:33 1998 Pablo Saratxaga <pablo.sarachaga@ping.be>
* [ole/nls/*] [ole/ole2nls.c] [include/winnls.h]
Fixed a few errors and completed some NLS files.
Mon Sep 14 01:23:45 1998 Joseph Pranevich <knight@baltimore.wwaves.com>
* [include/miscemu.h] [msdos/interrupts.c]
Removed a compilation warning, added INT 25 to the list of interrupts
callable from DOS applications, added a debug message when unsupported
interrupts are used.
Sun Sep 13 19:55:22 1998 Lawson Whitney <lawson_whitney@juno.com>
* [if1632/relay.c]
CallProcEx32W should not reverse arguments.
Sun Aug 17 21:18:12 1998 Eric Pouech <eric.pouech@lemel.fr>
* [multimedia/midi.c] [multimedia/init.c] [multimedia/mmsys.c]
[include/multimedia.h] [include/mmsystem.h]
[multimedia/Makefile.in] [multimedia/midipatch.c]
[if1632/multimedia.spec]
Made MIDI input and output functional on OSS capable systems.
* [multimedia/timer.c]
Changes to trigger callbacks at the accurate pace even when
fake timers are used.
1998-09-27 20:28:36 +02:00
|
|
|
- have a look at OPL/3 ?
|
1999-06-26 12:20:34 +02:00
|
|
|
- MidiHdr must be sent though mmsystem.c to get the linear
|
|
|
|
address set correctly. An application calling directly
|
|
|
|
(wod|wid)Message will fail
|
|
|
|
- implement asynchronous playback of MidiHdr (regular and/or
|
|
|
|
stream)
|
|
|
|
- use a more accurate read mechanism than the one of snooping
|
|
|
|
on timers
|
|
|
|
|
|
|
|
1.2.2 MIDI mapper
|
|
|
|
|
|
|
|
Midi mapper allows to map each one of 16 MIDI channels to a
|
|
|
|
specific instrument on an installed sound card. This allows for
|
|
|
|
example to support different MIDI instrument definition (XM,
|
|
|
|
GM...). It also permits to output on a per channel basis to
|
|
|
|
different MIDI renderers.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
TODO:
|
|
|
|
- implement the Midi mapper
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
1.3 Mixer
|
|
|
|
---------
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
MMSYSTEM and WINMM call the lowlevel driver functions in
|
|
|
|
multimedia/mixer.c using the mixMessage function.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
1.3.1 OSS implementation
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The current implementation uses the OpenSoundSystem mixer.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
TODO:
|
1999-06-26 12:20:34 +02:00
|
|
|
- implement mixing mute functionality for OSS.
|
|
|
|
- implement mixing lowlevel drivers for other mixers (ALSA...)
|
|
|
|
- implement notification mechanism when state of mixer's
|
|
|
|
controls change
|
|
|
|
- handlers used for mixer are currently poorly implemented
|
|
|
|
|
|
|
|
1.4 AUX
|
|
|
|
-------
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The API consists of the aux* functions found in
|
|
|
|
multimedia/mmsystem.c. They call auxMessage in multimedia/mmaux.c.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
The aux* functions are the predecessor of the mixer* functions.
|
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
1.4.1 OSS driver
|
|
|
|
|
1998-03-15 21:29:56 +01:00
|
|
|
The implementation uses the OSS mixer API, and is incomplete.
|
|
|
|
|
|
|
|
TODO:
|
|
|
|
- verify the implementation
|
1999-06-26 12:20:34 +02:00
|
|
|
- check with what is done in mixer
|
|
|
|
- open question: shall we implement it on top of the low level
|
|
|
|
mixer functions ?
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
1.7 JOYSTICK
|
1999-06-26 12:20:34 +02:00
|
|
|
------------
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The API consists of the joy* functions found in
|
|
|
|
multimedia/joystick.c. The implementation currently uses the Linux
|
|
|
|
joystick device driver API. It is lacking support for enhanced
|
|
|
|
joysticks and has not been extensively tested.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
TODO:
|
|
|
|
- better support of enhanced joysticks
|
|
|
|
- support more joystick drivers (like the XInput extension)
|
|
|
|
|
|
|
|
2. Midlevel drivers (MCI)
|
1999-06-26 12:20:34 +02:00
|
|
|
=========================
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
The midlevel drivers are represented by some common API functions,
|
1999-06-26 12:20:34 +02:00
|
|
|
mostly mciSendCommand and mciSendString.
|
|
|
|
See status in chapter 3 for more information.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
WINE implements several MCI midlevel drivers (status is given for
|
|
|
|
both builtin and native implementation):
|
1999-05-02 12:21:49 +02:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
TODO: (apply to all builtin MCI drivers)
|
|
|
|
- move mci drivers as regular DLLs (loading in wine,
|
|
|
|
elfglue...)
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
2.1 CDAUDIO
|
1999-06-26 12:20:34 +02:00
|
|
|
-----------
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
2.1.1 Builtin
|
|
|
|
|
1998-03-15 21:29:56 +01:00
|
|
|
The currently best implementation is the MCI CDAUDIO driver that can
|
1999-06-26 12:20:34 +02:00
|
|
|
be found in multimedia/mcicda.c. The implementation is mostly
|
|
|
|
complete, there have been no reports of errors.
|
1999-03-15 16:42:51 +01:00
|
|
|
|
|
|
|
It makes use of misc/cdrom.c Wine internal cdrom interface. This
|
|
|
|
interface has been ported on Linux, FreeBSD and NetBSD.
|
|
|
|
(Sun should be similair, but are not implemented.)
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
A very small example of a cdplayer consists just of the line
|
|
|
|
mciSendString("play cdaudio",NULL,0,0);
|
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
2.1.2 Native
|
|
|
|
|
|
|
|
Native MCICDA works also correctly... It uses the mscdex traps (on
|
|
|
|
int 2f).
|
1999-03-15 16:42:51 +01:00
|
|
|
|
1998-03-15 21:29:56 +01:00
|
|
|
TODO:
|
1999-06-26 12:20:34 +02:00
|
|
|
- add support for other cdaudio drivers (Solaris...)
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
2.2 MCIWAVE
|
1999-06-26 12:20:34 +02:00
|
|
|
-----------
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
2.2.1 Builtin
|
|
|
|
|
1998-11-24 19:54:18 +01:00
|
|
|
The implementation is rather complete and can be found in
|
|
|
|
multimedia/audio.c.
|
1999-06-26 12:20:34 +02:00
|
|
|
It uses the lowlevel audio API (although not abstracted
|
|
|
|
correctly).
|
|
|
|
|
|
|
|
FIXME:
|
|
|
|
- The MCI_STATUS command is broken.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-05-02 12:21:49 +02:00
|
|
|
TODO:
|
|
|
|
- check for correctness
|
|
|
|
- better use of asynchronous playback from low level
|
1999-06-26 12:20:34 +02:00
|
|
|
- record has to be checked
|
|
|
|
- MCI_CUE command is broken
|
|
|
|
- better implement non waiting command (without the MCI_WAIT
|
|
|
|
flag).
|
1999-05-02 12:21:49 +02:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
2.2.2 Native
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
Native MCIWAVE works also correctly.
|
|
|
|
|
|
|
|
2.3 MCISEQ (MIDI sequencer)
|
|
|
|
---------------------------
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
2.3.1 Builtin
|
|
|
|
|
|
|
|
The implementation can be found in multimedia/midi.c. Except from
|
|
|
|
the Record command, should be close to completion (except for non
|
|
|
|
blocking commands).
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
TODO:
|
|
|
|
- implement it correctly
|
1999-06-26 12:20:34 +02:00
|
|
|
- finish asynchronous commands (especially for reading/record)
|
|
|
|
- better implement non waiting command (without the MCI_WAIT
|
|
|
|
flag).
|
|
|
|
|
|
|
|
2.3.2 Native
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-05-02 12:21:49 +02:00
|
|
|
Native MCIMIDI has been working but is currently blocked by
|
1999-06-26 12:20:34 +02:00
|
|
|
scheduling issues (mmTaskXXX no longer work).
|
1999-05-02 12:21:49 +02:00
|
|
|
|
1998-03-15 21:29:56 +01:00
|
|
|
2.4 MCIANIM
|
1999-06-26 12:20:34 +02:00
|
|
|
-----------
|
|
|
|
|
|
|
|
2.4.1 Builtin
|
1998-03-15 21:29:56 +01:00
|
|
|
|
1999-06-26 12:20:34 +02:00
|
|
|
The implementation consists of stubs and is in
|
|
|
|
multimedia/mcianim.c.
|
1998-03-15 21:29:56 +01:00
|
|
|
|
|
|
|
TODO:
|
1999-06-26 12:20:34 +02:00
|
|
|
- implement it, probably using xanim or something similair.
|
|
|
|
|
|
|
|
2.4.2 Native
|
|
|
|
|
|
|
|
Native MCIANIM is reported to work (but requires native video DLLs
|
|
|
|
also).
|
1998-11-24 19:54:18 +01:00
|
|
|
|
1999-05-02 12:21:49 +02:00
|
|
|
2.5 MCIAVI
|
1999-06-26 12:20:34 +02:00
|
|
|
----------
|
|
|
|
|
|
|
|
2.5.1 Builtin
|
1999-05-02 12:21:49 +02:00
|
|
|
|
|
|
|
The implementation consists of stubs and is in multimedia/mciavi.c.
|
|
|
|
|
|
|
|
TODO:
|
1999-06-26 12:20:34 +02:00
|
|
|
- implement it, probably using xanim or something similair.
|
|
|
|
|
|
|
|
2.5.2 Native
|
|
|
|
|
|
|
|
Native MCIAVI is reported to work (but requires native video DLLs
|
|
|
|
also). Some files exhibit some deadlock issues anyway.
|
1999-05-02 12:21:49 +02:00
|
|
|
|
1998-11-24 19:54:18 +01:00
|
|
|
3 High-level layers
|
1999-06-26 12:20:34 +02:00
|
|
|
===================
|
1998-11-24 19:54:18 +01:00
|
|
|
|
1999-05-02 12:21:49 +02:00
|
|
|
The rest (basically the MMSYSTEM and WINMM DLLs entry points).
|
1999-06-26 12:20:34 +02:00
|
|
|
It also provides the skeletton for the core functionnalites for
|
|
|
|
multimedia rendering.
|
|
|
|
|
|
|
|
Note that native mmsystem and WINMM do not currently under WINE
|
|
|
|
and there is no plan to support them (it would require to also
|
|
|
|
fully support VxD, which is not done yet).
|
|
|
|
|
|
|
|
TODO:
|
|
|
|
- allow a dynamic loading of low level driver (should have one
|
|
|
|
for OSS, another one for ALSA...)
|
|
|
|
- add clean-up mechanisms when process detach from MM DLLs
|
|
|
|
- reimplement the sndPlay??? functions using MCI commands
|
|
|
|
rather than rewriting everything from scratch.
|
|
|
|
- prepare for the 16/32 bit split
|
|
|
|
- check thread-safeness for MMSYSTEM and WINMM entry points
|
|
|
|
|
|
|
|
3.1 MCI skeletton
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Implementation of what is needed to load/unload MCI drivers, and
|
|
|
|
to pass correct information to them. This is implemented in
|
|
|
|
multimedia/mci.c and multimedia/mcistring.c
|
|
|
|
|
|
|
|
The mciSendString function uses commandstrings, which are
|
|
|
|
translated into normal MCI commands as used by mciSendCommand.
|
|
|
|
The API can be found in multimedia/mmsystem.c and
|
|
|
|
multimedia/mcistring.c. The functions there (mciOpen,mciSysInfo)
|
|
|
|
handle midlevel driver allocation and calls.
|
|
|
|
|
|
|
|
The implementation is not complete.
|
|
|
|
|
|
|
|
MCI drivers are seen as regular WINE modules, and can be loaded
|
|
|
|
(with a correct loadorder between builtin, native, elfdll, so), as
|
|
|
|
any other DLL. Please note, that MCI drivers module names must
|
|
|
|
bear the .drv extension to be correctly understood.
|
|
|
|
|
|
|
|
The list of available MCI drivers is obtained as follows:
|
|
|
|
1/ key 'mci' in [option] section from .winerc (or wineconf)
|
|
|
|
mci=CDAUDIO:SEQUENCER
|
|
|
|
gives the list of MCI drivers (names, in uppercase only) to
|
|
|
|
be used in WINE.
|
|
|
|
2/ This list, when defined, supercedes the mci
|
|
|
|
key in c:\windows\system.ini
|
|
|
|
|
|
|
|
TODO:
|
|
|
|
- MCI command loading support mci(Load|Free)Command
|
|
|
|
- implement other stuff as yet unknown
|
|
|
|
- in mciString(), make use of hiword from mciSendMessage
|
|
|
|
return value to convert value into string...
|
|
|
|
- mmTaskXXX functions are currently broken because the 16
|
|
|
|
loader does not support binary command lines.
|
|
|
|
|
|
|
|
3.2 MCI multi-tasking
|
|
|
|
---------------------
|
|
|
|
Multi-tasking capabilities used for the MCI drivers are provided
|
|
|
|
in multimedia/mmsystem.c
|
|
|
|
|
|
|
|
3.3 Timers
|
|
|
|
----------
|
|
|
|
|
|
|
|
It currently uses a service thread, run in the context of the calling
|
|
|
|
process, which should correctly mimic Windows behaviour.
|
|
|
|
|
|
|
|
TODO:
|
|
|
|
- Check if minimal time is satisfactory for most programs.
|
|
|
|
|
|
|
|
3.4 MMIO
|
|
|
|
--------
|
|
|
|
|
|
|
|
The API consists of the mmio* functions found in multimedia/mmio.c.
|
|
|
|
|
|
|
|
Seems to work ok in most of the cases.
|
|
|
|
|
|
|
|
TODO:
|
|
|
|
- ...
|
|
|
|
|
|
|
|
@------------------------------------@
|
|
|
|
@ Last updated: 12, May 1999 @
|
|
|
|
@ Eric Pouech <eric.pouech@lemel.fr> @
|
|
|
|
@------------------------------------@
|