home *** CD-ROM | disk | FTP | other *** search
/ Emulator Universe CD / emulatoruniversecd1998.iso / Colleco / ROMs / ADAMEM.TXT < prev    next >
Encoding:
Text File  |  1996-11-15  |  21.1 KB  |  411 lines

  1.                           ******* ADAMEm *******
  2.                      The Portable Coleco ADAM Emulator
  3.                                 Version 0.2
  4.                                      
  5.                     Copyright (C) 1996  Marcel de Kogel
  6.  
  7. Hardware and Software Requirements
  8. ==================================
  9. MS-DOS version:
  10.  A 486SX-25 or better
  11.  A VLB- or PCI-based VGA compatible video card
  12.  An enhanced keyboard (101 or 102 keys)
  13.  MS-DOS version 3.0 or higher
  14.  A 486DX-33 with a SoundBlaster compatible sound card and a joystick is
  15.  recommended
  16.  To compile the MS-DOS version, you'll need DJGPP 2.0 or higher, ZLIB
  17.  recommended
  18. Linux/SVGALib version:
  19.  A 486DX-33 (486DX2-66 recommended)
  20.  A VLB- or PCI-based VGA compatible video card
  21.  An enhanced keyboard (101 or 102 keys)
  22.  SVGALib version 1.2.10 or higher
  23.  ZLIB recommended
  24.  Sound and joystick drivers supported
  25. Unix/X version:
  26.  A 486DX-66 or equivalent (P66 recommended)
  27.  An X-Windows server running in 8, 16 or 32 bpp mode
  28.  X11 revision 6 or higher
  29.  ZLIB recommended
  30.  USS(/Lite) sound system and Linux joystick driver supported
  31.  
  32. ZLIB is a general purpose data compression library used by ADAMEm to
  33. support GZIPped disk, tape and ROM images. ZLIB is available on the ZLIB
  34. home page at http://quest.jpl.nasa.gov/zlib/
  35.  
  36. Files included
  37. ==============
  38. adamem     The emulator
  39. cvem       A link starting the emulator in ColecoVision mode
  40. adamem.snd The sound data used by the emulator
  41. adamem.txt This file
  42. OS7.rom    ColecoVision OS ROM image
  43. WP.rom     SmartWRITER ROM image
  44. EOS.rom    Elementary Operating System ROM image
  45. keys       Program to alter key mappings for game controller #1
  46. CWSDMI.ZIP (MS-DOS version only) A DPMI server required by ADAMEm MS-DOS.
  47.            If you don't run ADAMEm MS-DOS in a DPMI environment (OS/2, MS-
  48.            Windows, Linux DOSEmu, QDPMI, ...), put CWSDPMI.EXE included in
  49.            this archive somewhere in your path or in the emulator's
  50.            directory
  51. Some utilities for use with ADAMEm can be found on the ADAMEm distribution
  52. site at http://www.komkon.org/~dekogel/adamem.html
  53.  
  54. What's emulated
  55. ===============
  56. - 4 disk drives
  57. - 4 tape drives
  58. - 1 ADAM printer
  59. - 2 ColecoVision game controllers
  60. - (Optional) 1 Roller controller, 1 Driving module, 1 Super Action
  61.   controller
  62.  
  63. Key Mappings
  64. ============
  65. ADAM keyboard:
  66. F1-F6        -  Smart keys
  67. F7           -  WILD CARD
  68. F8           -  UNDO
  69. Insert       -  INSERT
  70. Delete       -  DELETE
  71. Home         -  MOVE/COPY
  72. End          -  STORE/GET
  73. Page Up      -  CLEAR
  74. Page Down    -  PRINT
  75. Keypad 5     -  HOME
  76. ColecoVision game controllers:
  77. Cursor keys             - Joystick movement
  78. Left Alt (Space in      - Primary firing button
  79. Unix/X version)
  80. Left Ctrl               - Secondary firing button
  81. Left Shift              - Third firing button (port 1)
  82. Z                       - Fourth firing button (port 1)
  83. NumPad -                - Third firing button (port 2)
  84. NumPad +                - Fourth firing button (port 2)
  85. 0-9, -, =               - Numpad 1
  86. 0-9, Del, Enter(right)  - Numpad 2
  87. Special Keys:
  88. F9                      - Toggle joystick/keyboard mode. In joystick
  89.                           mode, the keyboard is used to emulate the
  90.                           ColecoVision game controllers. In keyboard
  91.                           mode, it is used to emulate the ADAM keyboard
  92. F1-F4                   - Toggle sound channel 1-4 on/off (Joystick mode
  93.                           only)
  94. F5                      - Toggle sound on/off (Joystick mode only)
  95. F11                     - Decrease sound volume
  96. F12                     - Increase sound volume
  97. Ctrl+F9                 - Change options
  98. Space                   - Make screen shot (Joystick mode only, not
  99.                           implemented in Unix/X version)
  100. Ctrl+F11                - Pause & Blank screen
  101. Ctrl+F12                - Pause
  102. Insert                  - Switch to joystick emulation mode 1 (Joystick
  103.                           mode only). For a description of the available
  104.                           joystick emulation modes, check the description
  105.                           of the -joystick command line option
  106. Home                    - Switch to joystick emulation mode 2 (Joystick
  107.                           mode only)
  108. Page Up                 - Switch to joystick emulation mode 3 (Joystick
  109.                           mode only)
  110. Delete                  - Swap joystick buttons (Joystick mode only)
  111. End                     - Swap keyboard buttons (Joystick mode only)
  112. Page Down               - Swap mouse buttons (Joystick mode only)
  113. Both Ctrls + Both Alts  - Main reset lever
  114. Both Ctrls + Both       - Cartridge reset lever
  115. Shifts
  116. F10                     - Quit emulator
  117.  
  118. Command line options
  119. ====================
  120. General options:
  121. -help                  -  Print a help page describing the available
  122.                           options
  123. -verbose <flags>       -  Select debugging messages [0]
  124.                             0 - Silent          1 - Startup messages
  125.                             2 - VDP             4 - Memory mapper
  126.                             8 - Tape&Disk      16 - PCB
  127.                           128 - Illegal Z80 ops
  128. -adam / -cv            -  Select emulation model
  129.                           -adam - Coleco ADAM
  130.                           -cv   - ColecoVision
  131.                           Default is -adam for adamem, -cv for cvem
  132. -os7 <file>            -  Select ColecoVision ROM image [OS7.rom]
  133. -eos <file>            -  Select EOS ROM image [EOS.rom]
  134. -wp <file>             -  Select SmartWriter ROM image [WP.rom]
  135. -diska, -diskb,        -  Select disk/tape images to use [none]
  136. -diskc, -diskd,
  137. -tapea, -tapeb,
  138. -tapec, -taped
  139. <filename>
  140. -printer <filename>    -  Select file to log printer output
  141.                           Default is PRN in the MS-DOS version, stdout in
  142.                           the Unix versions
  143. -printertype <value>   -  Select printer type [1]
  144.                           0 - ADAM Printer compatible
  145.                           1 - Generic/Text only
  146.                           2 - IBM Graphics compatible
  147.                           3 - Qume SPRINT 11 compatible
  148. -cpuspeed <percentage> -  Set Z80 CPU speed [100%]
  149.                           You won't normally need to use this option. If
  150.                           you've got a slow system however, you may be
  151.                           able to speed up some applications by lowering
  152.                           the CPU speed to 60%-80%
  153. -ifreq <frequency>     -  Set interrupt frequency [50Hz]
  154.                           Default interrupt frequency is 50Hz for a PAL
  155.                           system, and 60Hz for an NTSC system. If you
  156.                           find most of your applications running a bit
  157.                           too slow, try using -ifreq 60
  158. -sync <mode>           -  Select sync mode [1]
  159.                           0 - Do not sync emulation
  160.                           1 - Sync emulation on every VDP interrupt
  161.                           Using -sync 0 will let the emulator run at full
  162.                           speed. If you're not using games, you may want
  163.                           to use this option
  164. -expansion <mode>      -  Select expansion module emulation [0]
  165.                           0 - Do not emulate expansion modules
  166.                           1 - Emulate a roller controller with the mouse.
  167.                               Use your mouse buttons to press one of the
  168.                               first two roller controller buttons, use
  169.                               the ctrl and alt keys to press one of the
  170.                               second roller controller buttons
  171.                           2 - Emulate a roller controller with an
  172.                               analogue joystick
  173.                           3 - Emulate a driving module with an analogue
  174.                               joystick. Move your joystick forward to
  175.                               press the accelerator pedal, move your
  176.                               joystick to left or to the right to move
  177.                               the steering wheel, use the cursor keys or
  178.                               the joystick buttons to move the control
  179.                               stick
  180.                           4 - Emulate a driving module with a mouse.
  181.                               Press a mouse button to press the
  182.                               accelerator pedal, use the cursor keys to
  183.                               move the control stick
  184.                           5 - Emulate a super controller speed roller on
  185.                               both ports with a mouse. The third and
  186.                               fourth firing buttons of the super action
  187.                               controllers are always emulated.
  188.                           6 - Emulate a speed roller on port 1 with a
  189.                               mouse
  190.                           7 - Emulate a speed roller on port 2 with a
  191.                               mouse
  192.                           Please note that mouse support is currently
  193.                           only implemented in the MS-DOS version
  194. Controller options:
  195. -joystick <mode>       -  Select joystick mode [1]
  196.                           0 - No joystick support
  197.                           1 - Joystick support
  198.                           2 - Joystick emulates game controller #2
  199.                           3 - Joystick emulates game controller #1
  200.                           In joystick mode 1, both the keyboard and the
  201.                           joystick emulate both ColecoVision game ports.
  202.                           For head to head games, you'll have to use
  203.                           either -joystick 2 or -joystick 1
  204. -sensitivity <value>   -  Select mouse/joystick sensitivity [200]
  205.                           1 - Maximum   1000 - Minimum
  206.                           Use this option if you're having trouble
  207.                           controlling the roller controller or driving
  208.                           module. Useful values are between 150 and 400
  209. -swapbuttons <flags>   -  Swap/Do not swap buttons [0]
  210.                           1 - Swap joystick buttons
  211.                           2 - Swap keyboard buttons
  212.                           4 - Swap mouse buttons
  213.                           For the joystick and the mouse, only buttons A
  214.                           and B are swapped
  215. -keypad <mode>         -  Select numeric keypad operation [0]
  216.                           0 - Normal   1 - Reversed
  217.                           This option might be useful for games that use
  218.                           game controller overlays, like War Games
  219. -calibrate <mode>      -  Force/Do not force joystick calibration [0]
  220.                           0 - Do not force joystick calibration
  221.                           1 - Force joystick calibration
  222.                           Normally, the emulator loads the joystick
  223.                           settings from a file when it has been
  224.                           calibrated before. If you connected a new
  225.                           joystick, or you changed your joystick
  226.                           settings, and you're having trouble controlling
  227.                           your joystick, try using -calibrate 1
  228. -keys <string>         -  Alter key mappings
  229.                           You can use the keys program to get the syntax
  230.                           necessary for your favourite key mapping
  231. Video options:
  232. -uperiod <value>       -  Set maximum number of interrupts per screen
  233.                           update [3]
  234.                           If you are using a slow system, you may prefer
  235.                           using -uperiod 2 or -uperiod 1. This will
  236.                           probably slow down emulation, but emulation
  237.                           will be much smoother
  238. -sprite <mode>         -  Select sprite emulation method [0]
  239.                           0 - Show all sprites
  240.                           1 - Don't show more than 4 sprites per row
  241.                           While many applications will suffer from heavy
  242.                           sprite flicker when using -sprite 1, some
  243.                           applications require the option for best
  244.                           display results
  245. -video <mode>          -  Select video mode [0] (Not implemented in
  246.                           Unix/X version)
  247.                           MS-DOS version:
  248.                           0 - 320x200    1 - 256x192
  249.                           2 - 256x240
  250.                           Linux/SVGALib version:
  251.                           0 - 320x200    1 - 320x240
  252.                           Please note that video modes 1 and 2 may not
  253.                           work on every system
  254. -overscan <mode>       -  Emulate/Do not emulate overscan colour [1] (Not
  255.                           implemented in Unix/X version)
  256.                           0 - Do not emulate overscan colour
  257.                           1 - Emulate overscan colour
  258.                           Since overscan colours show quite differently
  259.                           on a television set compared to a VGA monitor,
  260.                           you may want to turn emulation of it off
  261. -chipset <value>       -  Select video chipset [1] (Linux/SVGALib only)
  262.                           0 - VGA        1 - Autodetect
  263.                           If you are having video related problems, using
  264.                           -chipset 0 might solve your problems
  265. -shots <mode>          -  Select screen shots mode [0] (Not implemented
  266.                           in Unix/X version)
  267.                           0 - Don't allow screen shots
  268.                           1 - Allow screen shots
  269.                           A screen shot taken will have the filename
  270.                           CART.XXX where cart is the name of the cart
  271.                           loaded (e.g. DKONG), and XXX is the number of
  272.                           screen shots taken so far (e.g. 002). The
  273.                           screen shots will be in uncompressed windows
  274.                           bitmap format, 256x192 with 17 colours
  275. Sound options:
  276. -soundtrack <file>     -  Select file for sound logging [none]
  277. -sound <mode>          -  Select sound mode [255]
  278.                           MS-DOS version:
  279.                           0 - No sound       1 - PC Speaker
  280.                           2 - Adlib          3 - Adlib + SoundBlaster
  281.                           4 - SoundBlaster   5 - GUS
  282.                           6 - SB AWE32     255 - Detect
  283.                           The emulator uses the BLASTER environment
  284.                           variable to 'detect' the presence of a Sound
  285.                           Blaster. Some older Sound Blaster cards are not
  286.                           supported. Make sure your BLASTER setting is
  287.                           right or you may crash your system when running
  288.                           the emulator. The syntax of the BLASTER
  289.                           environment variable is: BLASTER=Aaaa Ii Dd Hh
  290.                           Tt Eeee, where aaa is the port address
  291.                           (default=220), i is the interrupt used
  292.                           (default=7 or 5, depending on the model you
  293.                           have), d is the DMA channel used (default=1), h
  294.                           is the high DMA channel used (SB16/AWE32 only,
  295.                           default=5), t is the model type (4=SB Pro,
  296.                           5=SB16, 6=AWE32) and eee is the EMU baseport
  297.                           (AWE32 only, default=620). All other settings
  298.                           are ignored. If you have a GUS compatible sound
  299.                           card, make sure your ULTRASND environment
  300.                           variable is set correctly. It's syntax is:
  301.                           ULTRASND=Port,DMA,Record DMA,IRQ,MIDI IRQ. Only
  302.                           the Port parameter is used by the emulator.
  303.                           You might want to use -sound 3 if you have a
  304.                           slow system or a system with an 8-bit sound
  305.                           card
  306.                           Unix versions:
  307.                           0   - No sound
  308.                           1   - USS(/Lite) /dev/dsp
  309.                           255 - Detect
  310. -reverb <level>        -  Select reverb send level (SB AWE32 only) [7]
  311.                           0 - Minimum  100 - Maximum
  312. -chorus <level>        -  Select chorus send level (SB AWE32 only) [0]
  313.                           0 - Minimum  100 - Maximum
  314. -stereo <level>        -  Select stereo panning level (SB AWE32 only) [0]
  315.                           0 - Mono     100 - Maximum
  316.                           Useful values are from 0 to about 60
  317. -soundquality <value>  -  Select sound quality (SoundBlaster and /dev/dsp
  318.                           only) [3]
  319.                           1 - Lowest     5 - Highest
  320.                           While using higher sound qualities will improve
  321.                           sound output quite a lot, it will also cause a
  322.                           considerable slowdown
  323. -speakerchannels       -  Select PC Speaker channel list (PC Speaker
  324. <channel list>            only) [4,3,2,1]
  325.                           If you don't have a sound card, and sound
  326.                           quality is extremely poor, try messing with
  327.                           this option a bit. Useful alternatives include
  328.                           1,2,3 and 2,3,1
  329. -volume <level>        -  Select initial volume [10]
  330.                           0 - Silent    15 - Maximum
  331. Miscellaneous options:
  332. -shm <mode>            -  Use/Don't use MITSHM extensions for X [1] (X-
  333.                           Windows version only)
  334.                           0 - Don't use SHM   1 - Use SHM
  335.                           Using SHM greatly speeds up emulation, but may
  336.                           not be compatible with your system
  337. -savecpu <mode>        -  Save/Don't save CPU when inactive [1] (X-
  338.                           Windows version only)
  339.                           0 - Don't save CPU   1 - Save CPU
  340. Many command line options may be abbreviated. Use the -help options to get
  341. a list of currently supported abbreviations
  342.  
  343. Soundtrack file format
  344. ======================
  345. The soundtrack file format is as follows:
  346. Header:
  347. string         'Coleco Sound File',0x1A
  348. word           Version number (LSB first, currently 0x101 for 1.01)
  349. byte           Interrupt frequency in hertz
  350. Data:
  351. 0xFF           Single interrupt mark
  352. 0xFE <n(byte)> Interrupt mark
  353. 0xFD <n(word)> Interrupt mark (LSB first)
  354. 0xFC <byte>    Change interrupt frequency
  355. 0x00-0x7F      Sound register write. High nibble is the register number,
  356.                low nibble is the register value. Registers 0,2 and 4 are
  357.                12 bits wide (lower 8 bits are in second byte), all others
  358.                are 4 bits wide
  359. Example: 13 FF 20 04 56 FD 05 01 45 06
  360.           ^--------------------------- Write 3 to register 1
  361.              ^------------------------ Interrupt
  362.                 ^--------------------- Write 004 to register 2
  363.                       ^--------------- Write 6 to register 5
  364.                          ^------------ 261 Interrupts
  365.                                   ^--- Write 506 to register 4
  366.  
  367. Configuration files
  368. ===================
  369. The emulator loads two configuration files (if present) before it loads a
  370. cartridge rom: adamem.cfg or cvem.cfg located in the emulator's directory
  371. and CART.cfg (e.g. DKONG.cfg) located in the cartridge dump's directory.
  372. These are plain text files containing optional command line options.
  373. Options can be separated with spaces, tabs or returns.
  374.  
  375. History
  376. =======
  377. 0.2  15-11-1996   Completely rewrote VDP emulation engine; it now has
  378.                   support for sprite clipping, detection of 5th sprite in
  379.                   a row and non-standard screen modes, added support for
  380.                   GZIPped disk images, added ADAM printer control code
  381.                   emulation, added Unix/X and Linux/SVGALib ports, fixed
  382.                   some bugs
  383. 0.1  28-10-1996   Initial release
  384.  
  385. Credits
  386. =======
  387. - The Z80 emulator used is based on code written by Marat Fayzullin
  388.   (fms@freeflight.com). The original Z80 emulator can be downloaded from
  389.   http://freeflight.com/fms/CPUs/
  390. - Joe Blenkle, Jim Marshall, Stephen Geyer, Grant Frost and Jim Notini
  391.   were of invaluable help getting ADAM software and technical information.
  392.   Thanks!
  393. - Todd A. Aiken spent a lot of time finding bugs, many of which would have
  394.   never been fixed without his help. He also helped a lot improving the
  395.   sound output
  396. - Martijn Zeedijk tested the GUS routines and helped me fix lots of bugs
  397. - Neal Danner provided me with the sound hardware related technical
  398.   information on which the sound emulation code is based
  399. - The SB AWE32 routines are heavily based on 'The Unofficial Sound Blaster
  400.   AWE32 Programming Guide' written by Vince Vu a.k.a. Judge Dredd. Thanks
  401.   a million for writing this!
  402. - Some parts of the code were taken from Allegro. Allegro is a library for
  403.   DJGPP written by Shawn Hargreaves. Allegro is available at
  404.   ftp://x2ftp.oulu.fi/pub/msdos/programming/djgpp2
  405. - ADAMEm MS-DOS was compiled using DJ Delorie's DJGPP v2.0. DJGPP is a 32
  406.   bit C compiler for MS-DOS. Source code and binaries of DJGPP are
  407.   available at http://www.delorie.com
  408.  
  409. Please send your comments to Marcel at
  410. m.dekogel@student.utwente.nl
  411.