aboutsummaryrefslogtreecommitdiff
path: root/engines/sci/sfx/doc
diff options
context:
space:
mode:
Diffstat (limited to 'engines/sci/sfx/doc')
-rw-r--r--engines/sci/sfx/doc/README7
-rw-r--r--engines/sci/sfx/doc/patch001.txt118
-rw-r--r--engines/sci/sfx/doc/sound01.txt213
3 files changed, 0 insertions, 338 deletions
diff --git a/engines/sci/sfx/doc/README b/engines/sci/sfx/doc/README
deleted file mode 100644
index 502ad7d619..0000000000
--- a/engines/sci/sfx/doc/README
+++ /dev/null
@@ -1,7 +0,0 @@
-The files in this direcory are a bit outdated. There are some small non
-critical errors in "patch.001", they are obvious if you bother to read
-the source (which is correct). "sound01.txt" is just meant to give you a
-basic understanding of the structures invovled in
-SCI01/SCI1/SCI1.1/SCI32 sound resources.
-
-Ravi has made some really good documentation for SCI0.
diff --git a/engines/sci/sfx/doc/patch001.txt b/engines/sci/sfx/doc/patch001.txt
deleted file mode 100644
index 0037eea9b4..0000000000
--- a/engines/sci/sfx/doc/patch001.txt
+++ /dev/null
@@ -1,118 +0,0 @@
-SCI patch.001 Resource Format Revision 0.1
-Rickard Lind 1999-12-16
-
-The patch.001 file for Roland MT-32, MT-100, LAPC-1, CM-32L and CM-64.
-
-This specification will sometimes look very incomprehensible without some
-knowledge concerning the MT-32 MIDI implementation.
-Have a look at http://members.xoom.com/_XMCM/TomLewandowski/docs.html
-
-
-1. The header (494 bytes) which is always present.
-
-Offset Size Type Description
-----------------------------------------------------------------------------
- 0x000 2 89 00 First Two Bytes
- 0x002 20 ASCII String for MT-32 Display ("*It's Only A Model* ")
- 0x016 20 ASCII String for MT-32 Display (" CAMELOT, CAMELOT! ")
- 0x02a 20 ASCII String for MT-32 Display ("Ham & Jam & SpamAlot")
- 0x03e 2 word MT-32 Master Volume
- 0x040 1 Index in Predefined reverb settings at 0x04c (0-10)
- 0x041 11 MT-32 SysEx block setting reverb
- (last 3 bytes are dummies)
- 0x04c 3 Predefined reverb setting #1 (Mode, Time, Level)
- : : :
- 0x06a 3 Predefined reverb setting #11
- 0x06d 8 MT-32 Patch Memory #1 (see Patch Memory description below)
- : : :
- 0x1e5 8 MT-32 Patch Memory #48
- 0x1ed 1 n = Number of Timbre Memory (0-64 userdefined instruments)
-----------------------------------------------------------------------------
-
-
- Patch Memory description
-
- Offset Description
- --------------------------------------------------------------------
- 0x00 Timbre Group (0 = Bank A, 1 = Bank B, 2 = Memory, 3 = Rythm)
- 0x01 Timbre Number (0 - 63)
- 0x02 Key Shift (0-48) [-24 - +24]
- 0x03 Fine Tune (0-100) [-50 - +50]
- 0x04 Bender Range (0-24)
- 0x05 Assign Mode (0 = Poly 1, 1 = Poly 2, 2 = Poly 3, 3 = Poly 4)
- 0x06 Reverb Switch (0 = OFF, 1 = ON)
- 0x07 Dummy
- --------------------------------------------------------------------
-
- Mapping MT-32 to GM instruments is done with Timbre Group and
- Timbre Number.
-
- Instrument 0-63: Bank A, 0-63
- Instrument 64-127: Bank B, 0-63
-
-
-2. The Timbre Memory block (if n > 0), offset relative to 0x1ee
-
-Offset Size Type Description
-------------------------------------------------------------------------------
- 0x000 246 MT-32 Timbre Memory #1 (see Timbre Memory description below)
- : : :
- 0x??? 246 MT-32 Timbre Memory #n
-------------------------------------------------------------------------------
-
-
- Timbre Memory description
-
- Offset Size Description
- -----------------------------------------------------------------------
- 0x00 10 Timbre Name (ASCII String)
- 0x0a See http://members.xoom.com/_XMCM/TomLewandowski/lapc1.txt
- -----------------------------------------------------------------------
-
-
-3. Second MT-32 Patch Memory Block, offset realtive to 0x1ee + n * 246
-
-Offset Size Description
----------------------------------------------------
- 0x000 2 0xab 0xcd (if this this is not present
- there is no second block)
- 0x002 8 MT-32 Patch Memory #49
- : : :
- 0x17a 8 MT-32 Patch Memory #96
----------------------------------------------------
-
-
-4. Block for setting up Patch Temporary Area (rythm part) and
- System Area - Partial Reserve, offset relative to 0x370 + n * 246
-
-Offset Size Description
----------------------------------------------------
- 0x000 2 0xdc 0xba (if this this is not present
- this block is non existent)
- 0x002 4 Rythm Setup for Key #24 (see below)
- : : :
- 0x0fe 4 Rythm Setup for Key #87
- 0x102 9 System Area - Partial Reserve
----------------------------------------------------
-
- Rythm Setup description
- See http://members.xoom.com/_XMCM/TomLewandowski/lapc1.txt
-
-
-TODO:
-
- * Clearly describe which parts are interesting for a quick and dirty
- GeneralMidi/patch.001/FreeSCI implementation
-
- * Describe how the Sierra MT-32 driver uses patch.001
-
- * Make this readable to someone who has not been reading reference
- manuals since early childhood
-
- * SGML
-
-
-Revision history
-
- Revision 0.1 - 1999-12-16
- - First pre-release of the specification
diff --git a/engines/sci/sfx/doc/sound01.txt b/engines/sci/sfx/doc/sound01.txt
deleted file mode 100644
index 8aae367da7..0000000000
--- a/engines/sci/sfx/doc/sound01.txt
+++ /dev/null
@@ -1,213 +0,0 @@
-The SCI01+ sound resource format
-
-Originally written by Rickard Lind, 2000-01-05
-Extensively rewritten by Lars Skovlund, 2002-10-27
-Again updated by Lars Skovlund, 2005-10-12
-
-Used in:
-Quest for Glory II: Trial by Fire (QfG2)
-Christmas greeting card 1990 (CC1990)
-
-The magic number (84 00) is left out, offset 0 is directly after these two
-bytes.
-
-If you examine a SCI01 sound resource use "sciunpack --without-header" to
-get the pointers within the file correct for your hex viewer.
-
-DESCRIPTION
------------
-
-The SCI01 sound resource consists of a number of track lists and the
-tracks themselves. There is one track list for (almost) every piece of
-sound hardware supported by the game. Each track either contains track
-data for one specific channel or a digital sample.
-
-SCI1 resources are the same, except that sample chunks are no longer
-allowed (since they are now separate resources).
-
- Optional Priority Header
- ------------------------
-
- Some SCI1 songs contain an 8-byte header before the track list. At
- least on PC platforms, its data is mostly unused. The priority value
- is used if the script does not override it.
-
- offset size description
- -------------------------------------------------------
- 0 byte 0xf0 Priority header marker byte
- 1 byte Recommended priority for this song
- 2 6 bytes Apparently unused
-
- Track List
- ----------
-
- The track list tells us which tracks are to be played on particular
- hardware platforms. Each entry either terminates the previous list
- or contains an entry for the current one.
-
- List Termination
- ----------------
-
- offset size description
- -----------------------
- 0 byte 0xff
- 1 byte Hardware ID of next list, 0xff if none
-
- List Entry
- ----------
-
- offset size description
- -----------------------
- 0 byte 0
- 1 byte 0
- 2 word Data Chunk pointer
- 4 word Data Chunk size
-
- The very first list in a file looks a little odd, in that it
- starts with a single byte which tells us the hardware ID
- associated with the first list (0 in all the cases I've seen)
- followed by list entries as usual.
-
- Known Hardware IDs
- ------------------
-
- Some of these are used by multiple drivers, probably because they
- support the same number of polyphonic voices. Note that the
- hardware ID does not necessarily tell us whether samples are
- supported - thus, the list for Roland MT-32 also contains sample
- tracks, because the user may also have a Sound Blaster card
- connected. SCI1 most likely has more hardware IDs than these.
-
- 0x00 - Sound Blaster, Adlib
- 0x06 - MT-32 with Sound Blaster (for digital audio)
- 0x09 - CMS/Game Blaster
- 0x0c - Roland MT-32
- 0x12 - PC Speaker
- 0x13 - IBM PS/1, Tandy 3-voice
-
- Data Chunks
- -----------
-
- In the sound resources of QfG2 and CC1990 I've seen two types of Data
- Chunks, Sample and MIDI channel track.
-
-
- Sample Chunk
- ------------
-
- offset size description
- -----------------------
- 0 byte =0xfe
- 1 byte !=0xfe (always 0 in QfG2 and CC1990)
- 2 word Sample rate (Hz)
- 4 word Sample length
- 6 word Sample point 1 (begin?)
- 8 word Sample point 2 (end?)
- 10 Unsigned 8-bit mono sample data
-
-
- MIDI channel track Chunk
- ------------------------
-
- This chunk begins with a 2 byte header. The low nibble of the
- first byte indicates the channel number. The high nibble controls
- certain aspects of (dynamic) track channel/hardware channel mapping.
-
- The second byte tells us how many notes will be
- playing simultaneously in the channel. From the third byte onward
- is the MIDI track data which looks just like normal SCI0 MIDI
- track data, but all status bytes are targeted at one specific MIDI
- channel.
-
-Example, sound.833 from QfG2 (--without-header)
------------------------------------------------
-
-offset data description
-------------------------
- 0000 00 Hardware ID for first track list
- 0001 00 Track list continuation
- 0002 00 Same hardware device
- 0003 003F Data Chunk pointer (Little Endian)
- 0005 0013 Data Chunk length (LE)
- 0007 00 Track list continuation
- 0008 00 Same hardware device
- 0009 006A Data Chunk pointer (LE)
- 000B 0015 Data Chunk length (LE)
- 000D FF Next track list
- 000E 09 for hardware device 0x09
- 000F 00 Track list continuation
- 0010 00 Same hardware device
- 0011 003F Data Chunk pointer (LE)
- 0013 0013 Data Chunk length (LE)
- 0015 00 Track list continuation
- 0016 00 Same hardware device
- 0017 0052 Data Chunk pointer (LE)
- 0019 0018 Data Chunk length (LE)
- 001B 00 Track list continuation
- 001C 00 Same hardware device
- 001D 0094 Data Chunk pointer (LE)
- 001F 0012 Data Chunk length (LE)
- 0021 FF Next track list
- 0022 0C for hardware device 0x0C
- 0023 00 Track list continuation
- 0024 00 Same hardware device
- 0025 003F Data Chunk pointer (LE)
- 0027 0013 Data Chunk length (LE)
- 0029 00 Track list continuation
- 002A 00 Same hardware device
- 002B 0052 Data Chunk pointer (LE)
- 002D 0018 Data Chunk length (LE)
- 002F FF Next track list
- 0030 13 for hardware device 0x13
- 0031 00 Track list continuation
- 0032 00 Same hardware device
- 0033 003F Data Chunk pointer (LE)
- 0035 0013 Data Chunk length (LE)
- 0037 00 Track list continuation
- 0038 00 Same hardware device
- 0039 007F Data Chunk pointer (LE)
- 003B 0015 Data Chunk length (LE)
-
- 003D FF FF Sequence Control - End of Sequence Blocks
- ------------------------------------------------------------
- 003F 0F MIDI Track channel 15 (control channel)
- 0040 01 One note playing on track (probably just to satisfy the
- MIDI engine)
- 0041 MIDI Track data like SCI0
- 0052 02 MIDI Track channel 2
- 0053 02 Two notes playing on track
- 0054 MIDI Track data like SCI0
- 006A 03 MIDI Track channel 3
- 006B 01 One note playing on track
- 006C MIDI Track data like SCI0
- 007F 0A MIDI Track channel 10
- 0080 01 One note playing on track
- 0081 MIDI Track data like SCI0
- 0094 02 MIDI Track channel 2
- 0095 01 One note playing on track
- 0096 MIDI Track data like SCI0
-
-Addendum (provided by Lars Skovlund)
-------------------------------------
-
-First of all, tracks do not loop individually. No loop signals are
-reported.
-
-Absolute cues are generally stored in the signal selector, and
-cumulative cues are generally stored in the dataInc selector, with
-some interesting twists:
-
-1. The server's record of the absolute cue value is reset as part of
- UPDATE_CUES.
-2. When a cumulative cue is reported to the VM object, it will be
- placed in _both_ fields. In such a case, a constant of 0x7f will be
- added to the _signal_ selector only, to be able to distinguish the
- two kinds of cue (this has already been coded).
-3. The above only happens if the sound does not use absolute cues
- (i.e. if the signal is 0 a priori). Note that, because of 1)
- above, this does not cause problems neither with successive
- cumulative cues nor with mixed cumulative/absolute cues.
-4. A signal of 0xff will stop the sound object playing. This may be
- for purely internal purposes.
-5. There no longer is a field indicating the amount of increment for
- a cue.