docs/ikteam: Delete most files.
[haiku.git] / docs / develop / midi / stuff.html
bloba19754d66196373a4676f98e08818d26e0772144
1 <HTML>
2 <BODY>
4 <H1>Misc notes</H1>
6 <UL>
8 <LI><P><B>MPU401 kernel module.</B> If your soundcard supports MIDI input and
9 output, chances are that it is powered by an MPU401 chip. Because this
10 interface is so popular, BeOS comes with a kernel module that makes it easy to
11 write drivers for the MPU401. Thanks to Greg Crain, we now have an open source
12 version of this kernel module.</P>
14 <P>The mpu401 module lives in <CODE>src/add-ons/kernel/generic/mpu401</CODE>.
15 It supports both the v1 and (undocumented) v2 protocols, although v2 is not
16 complete since we don't really know how it works. Unfortunately, almost no
17 existing drivers use v1; most of the drivers provided by Be require v2.
18 Currently, the module returns B_ERROR when a MIDI device is opened with
19 v2.</P>
21 <P>For an example on how to use the MPU401 module in your own driver, see
22 the source code for the "emuxki" driver elsewhere in the source tree.</P></LI>
24 <LI><P><B>Clients without a BApplication.</B> Sometimes the midi_server's
25 debug output shows an "Application -1 not registered" error message. This
26 means it cannot figure out which app an incoming BMessage came from. The
27 server ignores those messages.</P>
29 <P>How can this happen? libmidi2 has two ways of sending messages to the
30 midi_server: it either expects a reply back or not. In the first case, it is
31 obvious to the midi_server what the reply address of the message is. In the
32 second case, even though it is not necessary for the server to send a message
33 back, it still uses the reply address to determine which app the message came
34 from. For this, BMessenger uses be_app_messenger of the client app.</P>
36 <P>However, if the client app has no BApplication object, there is no
37 be_app_messenger either. Now, the midi_server cannot determine where the
38 message came from and will ignore it. Is this important? For example, when such
39 a client app Release()'s its endpoints, it sends a message to the server
40 without a return address. Now the server ignores that message and does not
41 remove the endpoint from the roster. Of course, after the client app has died,
42 the endpoints will be removed eventually. Does all of this matter? Not really,
43 because only trivial apps will have no BApplication object.</P></LI>
45 </UL>
47 </BODY>
48 </HTML>