Top secrets sources NedoPC pentevo

Rev

Rev 799 | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed | ?url?

----------------------------------------------------------------------
                      UnrealSpeccy 0.36.7 by SMT
----------------------------------------------------------------------

        contents

                1. features
                2. system requirements
                3. keys in emulator
                4. bugs and incompatibilities
                5. greets
                6. license


----------------------------------------------------------------------

features


  cpu
        Z80: all (un)documented commands and flags


  memory

        Pentagon 128/512/1024 and 48K ROM
        Scorpion 256/1024 RAM and 64K ROM
        Scorpion PROF-ROM with SMUC support (128/256/512K)
        KAY-256/1024 and 64K ROM
        Profi 1024 RAM/ROM and memory mapper
        ATM TURBO 1 v4.50 512/1024 RAM, 64-1024K ROM
        ATM TURBO 2+ v7.10 128/512/1024 RAM, 64-1024K ROM
        cache 16/32K
        CMOS/RTC: russian chip (512Bu1, 64 bytes, 1st day is monday) or
          pc-compatible (DALLAS, 256 bytes, 1st day of week is sunday)
        SMUC RTC and NVRAM (24LC16)

  sound

        beeper, tape saving and loading tones

        AY-3-8910/YM2149: excellent sound emulation, including digital
        and unusual effects, parallel ports on R14/R15 are not emulated

        Turbo-AY (Turbo-Sound): two AY(or YM) chips by PoS and NedoPC schemes

        TurboSound FM: two YM2203 chips (6 AY channels + 6 FM channels)

        also there is 'unreal' (not available in real Spectrum) mode:
        playing AY music using digital player - emul plays three sound samples
        with volumes and frequencies taken from corresponding AY registers
        and 'pseudo-turbo' - two parallel YM chips with some phase shift

        two covoxes - Pentagon (port #FB) & Scorpion (port #DD)

        SounDrive

        saving sound to WAV or VTX (VTX - good format for AY sound, much
        more compact than PSG, but you need lha.exe somewhere in %PATH%)

        General Sound - FX & MOD player through BASS sound system.
        You can save music and listen it in your favourite mod-player

        General Sound low level emulation (including internal Z80 on 12MHz,
        512Kb onboard memory, internal ports and DACs)

        BASS offers higher quality and more sound channels than low-level
        emulation. Low-level emulation is useful for programs altering the
        firmware player and using second Z80 for their own needs. In general,
        use BASS for games, and low-level emulation for advanced sound/music
        editors (RIFF tracker)

  video

        several video drivers, from simple and fastest to complex bi-linear
        filtering, that upsamples Spectrum display to 512x384 * 64 colors;
        'noflic' filter is specially for programs fast switching two screens
        to get more colors;
        several chunky filters for 21st century demos

        amazing video filter: Anti-Text64. Designed for reading e-zines.
        It converts 4x8 fonts to 8x8 or 8x16 on the fly and saves your eyes

        multicolors are fixed for Pentagon & Scorpion, 1T screen update
        for all border effects

        able to emulate scorpion timings, including scorpion border update

        nopaper mode for debugging border effects

        flash-color (using 128 ink colors with black paper when FLASH bit on)

        hi-res modes: Pentagon 512x192, Profi 512x240, ATM
        (works with 'double' video filter)

        ATM-TURBO color video modes (works with 'double' video filter):
        text mode 80x25, EGA mode 320x200, 640x200.
        To use custom text-mode font, place your "SGEN.ROM" to unreal directory.
        Don't use border=none with ATM video modes

        Pentagon 384x304 mode [see ZX-Guide#2, AlCoNews#32]

        Pentagon color-per-pixel mode [see Info Guide#8, #9]

        hardware multicolor

        attribute port #FF


  tune-up video/sound with hotkeys

        change video settings, such as number of t-states/frame, t-states/line,
        fix with grey+, grey-, grey*

        t-states/frame is a computer speed, so it's easy to adjust speed in
        fast (or slow) games in very wide range for comfortable playing

        alt+grey*, grey-, grey+ selects soundchip (AY/YM) and
        stereo mode (ABC/ACB), or palette


  beta 128 disk interface

        implemented all FDC WD1793 commands, including read/format track

        traps for read/write sector - more then 256 times speedup


  tape

        full TAP and TZX support

        CSW support

        tape browser

        auto-start tape when accessing to ROM load routine

        fast loading: UnrealSpeccy is able to recognize loader logic
           and speed up loader by removing delay loops and edge detection loops.
           (Of course, UnrealSpeccy leaves original t-states timing,
           so max speed mode must be enabled for fast loading - press NumLock)
           With this technique any 128K game may be loaded in 10-20 secs.
           I've developed this feature independent from RAMSOFT, but looks like
           they used the same idea in RS 0.90.38...
           For really fast loading, also choose 'normal' video driver


  IDE

        UnrealSpeccy is able to use KAY, SCORPION and ATM-2 IDE interfaces with
        two devices on it (hard disks or CD-ROMs)

        for hard disks you may use image file or Spectrum drive, connected to
        computer. CD-ROM requires physical or windows-level emulated device

        schemes supported:
        Nemo - controller for ZX-BUS manufactured by Nemo and NedoPC
        ATM - ATM TURBO 2+ v7.10
        Nemo(A8) - Nemo scheme modification: uses A8 instead of A0 to
                   select high/low byte of 16bit data (easy to
                   transfer sector with just two commands INIR:INIR)
        SMUC - IDE controller for ZS Scorpion

  modem

        ISA modem, configured to use COM1 ports 03F8-03FF
        translated to Spectrum's ports #F8EF-#FFEF.
        Modem interrupt (translated to Spectrum NMI) is not emulated
        Host computer should have installed windows driver for real modem.
        At least ping/dns by Kamil Karimov tested and works fine
        with empty 'modem initialization string'


  input devices

        fully customizable keyboard
        copy text from clipboard via emulation of Spectrum keyboard
        AY-mouse (KORVET mouse, connected to AY-3-8910/12 port A)
        kempston mouse with adjustable speed and swap-buttons option,
        mouse wheel included (D7..D4 in buttons' port or UP/DOWN keys)
        kempston joystick on keyboard
        kempston joystick on mouse (joystick will follow mouse cursor)
        mouse wheel and buttons can be bound to any zx keys or kempston
        PC joystick/gamepad can be bound to any zx keys or kempston
        sticky keys mode [stolen from ZX_Emul, read description there]
        autofire (with adjustable key and period)

  files

        reading:

           SP, SNA and Z80 (all versions, 48k and 128k)
           TAP, TZX, CSW
           FDI, TRD, SCL, TD0, UDI
                  if disk image does not contain boot.B, it may be appended.
                  Disk images for every drive may be loaded automatically
                  at start of UnrealSpeccy
           HOBETA format - appends file to existing disk; if no disk, then empty
                  TR-DOS disk will be created. Best use with command line:
                  unreal.exe prog.$B prog.$C   <- will be placed on same disk
                  You can also load it from 'F3' dialog, but only by one file

        writing:

           SNA 48k and 128k
           TRD, FDI, UDI
           TD0  (saved unpacked, so expect saved file larger than loaded)
           SCR, BMP (screenshots)
           WAV, VTX


        disk images converter:

           emulator can open disk image in any format (TRD/TD0/FDI/SCL/UDI)
           and save it to any other format


  leds

        1. AY volume/status. Just for fun. White color - tone, yellow - noise,
           green - envelope; also shows YM2203 and GS volumes

        2. perfomance leds. One displays how much Z80 t-states is between two
           interrupts. While watching some demo you can see how much time
           takes one or another effect. Second led shows PC framerate - at
           normal speed it must be 50. If it is less, then your CPU is too
           slow, and sound may be jerky - try to select faster video driver,
           disable some devices, increase skipframe or decrease t-states
           per int. When running on max speed, framerate shows how fast you
           computer is. For example, 800 fps is 16 times faster than
           Spectrum, so average game will load in 20 secs.

        3. input led. Shows which input devices are active - keyboard, mouse,
           kempston joystick. For keyboard, displays queried keyrows.
           One example: I've noticed, that in KOL0BOK2 intro active keyrows
           are <B>-<SPACE> and A-G. <SPACE> is an exit, but why program
           scans <A>-<G> ? I've pressed <A>, and I saw that now program
           queries <Y>-<P>. After pressing A+P, program queries <CAPS>-<V>.
           When pressing A+P+X active keyrow areonly <B>-<SPACE>. So, I've
           found cheat without digging in program code! (Another way was to
           set breakpoint on reading port #FE and analyze code nearby)

        4. loading led. When saving/loading from disk, emulator shows
           blue or red diskette. When formatting track, yellow disk is
           displayed. When loading from tape, emulator displays
           cassette picture and progress for current block (or 'PS' - tape
           silence)

        5. local time - for those ZX Spectrum fans, who spend all their
           time with virtual Spectrum

        6. on-screen watches - display used RAM and ROM banks in last frame,
           count user-defined expressions

        7. using leds on AT keyboard to display AY amplitude peaks


        leds look strange when flash-color is enabled. It's not a bug


  monitor

        software that in PC world is called 'debugger', in Spectrum world
        is often called 'monitor'

        find text or code.
        Using mask: code matches when ((code & mask) == (pattern & mask))

        unlimited number of code breakpoints

        conditional breakpoints of any complexity, uses C-like expression
        syntax (with this feature can be easily done: breakpoint on range,
        breakpoint to port in and out, on instruction, etc..)

        memory access breakpoints (on reading/writing/executing of given memory
        areas)

        built-in Z80 assembler/disassembler

        save-load memory blocks

        disk editor

        ripper's tool: for ripping routines with their data.
        Marks which bytes were read/written, and saves whole 64kb memory,
        replacing unreferenced bytes with user-defined byte (default is #CF)

        hotkeys to save/restore cursor position in disasm window

        hotkeys for location instruction operand in Z80 or dump window

        on-screen watches: show memory areas addressed by register pairs


  GUI

        all settings, that present in INI file, may be changed in GUI
        (but will not be saved, for permanent effect edit INI file)

        easy entering POKEs, if you don't want to use monitor or use
        HEX addresses. Delimiters for numbers are space, comma, colon,
        semicolon - so POKEs can be cut'n'pasted from any cheats collection

        loading from archives. Now supported: CAB,ZIP,RAR.
        You can add your own archivers to INI file

----------------------------------------------------------------------

system requirements

        Windows 95 or higher, or NT (not tested).
        Windows 2000/XP/2003 are required for real HDD support.

        for running UnrealSpeccy you need:

            Pentium-166 CPU MMX for basic functionality
            Celeron-266 CPU for Profi/Pentagon/ATM/Anti-Text64 hi-res modes
            Celeron-400 CPU for GS low-level emulation
            UnrealSpeccy eats only 12Mb of RAM, so
             if you've started Windows, then memory is enough
            2D accelerared video card with hardware support of
             video overlays and color keying for overlay modes
            3D accelerared video card for hardware chunky bilinear filter
            2 Mb of video memory in fullscreen
            4 Mb of video memory for windowed mode
            16-bit sound card [optional, but recommended]


        if you have such hardware, but emulator runs slow, try the
        following:

            0. install latest directX and videocard drivers
            1. increase sound buffer size (especially for Win95) in INI file
            2. select video filter='small', video driver='ddraw'
            3. disable vsync
            4. set 'ShareCPU=0' in INI file
            5. do not use General Sound low-level emulation
            6. do not use YM2203
            7. set 'skipframe=4' in INI file
            8. set 'Frame=30000' in INI file (if nothing else does not work)
            9. disable sound (without sound emulator runs much faster)

        this should help


----------------------------------------------------------------------

keys in emulator

these are default keys, can be changed in INI file


Ctrl-F1         monitor
Shift-ESC       only for windowed mode: give mouse to emulator or to MS Windows
Alt-F1          help on keys
F1              options/GUI
F2              write snapshot/disk image
Alt-F2          quicksave to qsave1.sna
Ctrl-F2         quicksave to qsave2.sna
Shift-F2        quicksave to qsave3.sna
F3              read snapshot/tape/disk image
Alt-F3          quickload from qsave1.sna
Ctrl-F3         quickload from qsave2.sna
Shift-F3        quickload from qsave3.sna
(SHIFT+)F4      select video driver (filter)
Alt-F4          exit emulator
F5              start/stop saving sound (WAV or VTX formats).
                May be used from monitor: set breakpoint to
                start/stop routines and save;
                when saving to vtx, start and end silence are wiped
F6              enter POKE(s)
Alt-F6          search in memory for changed values (cheats, etc)
F7              start/stop tape
Shift-F7        tape browser
Alt-F8          screenshot
F9              quicksave all altered disk images and CMOS
Alt-Shift-F11   NMI
Alt-F11         NMI to cache
Ctrl-F11        NMI to TR-DOS ("magic")
F12             reset to default mode, as specified in INI file
Ctrl-Shift-F12  reset to basic-128
Ctrl-F12        reset TR-DOS (128)
Shift-F12       reset to 48 basic, but port 7FFD unlocked
Alt-Shift-F12   reset to 48 basic, port 7FFD locked
Alt-F12         reset to system ROM
Ctrl-Alt-F12    reset to cache
pause/break     pause
grey/           leds on/off
grey*           select parameter to change: t-states/int (speed), fix, etc...
Alt+grey*       select parameter to change: AY/palette
grey+,grey-     change sound/video parameter (press with SHIFT for finetuning)
NumLock         max speed on/off (no sound on max speed)
Alt-NumLock     toggle autofire on/off
Alt-Ctrl-Z      toggle ATM XT(AT)-keyboard controller on/off
Alt-Enter       toggle full-screen mode
Alt-Shift-Ins   copy text from clipboard to keyboard buffer
Alt-1           set window size to 1x scale in windowed mode
Alt-2           set window size to 2x scale, useful for hardware-stretched
                modes like overlay and blitter
Alt-3           maximize window


keys in monitor

(CTRL,SHIFT,ALT+)F1,F2,F3,F5,F11,F12 - see above
Ctrl-F1         exit, run program
F7              step
F8              trace, skip calls and loops
F9              show Spectrum screen
Shift-F9        show alternative 128k screen
Alt-F9          show screen until painted point with border, mc and 2-scr 
effects
F11             run program until address (SP)
TAB             next window
SHIFT-TAB       previous window
Alt-D           toggle text/hex dump
Alt-B           write to port 7FFD (select bank / screen)
Alt-M           write to model-specific extended memory port (like 
#1FFD,#FDFD,#DFFD,...)
Alt-P           enter POKE(s)
Alt-F6          search in memory for changed values (cheats, etc)
Alt-R           load memory block from file
Alt-W           save memory block to file
Alt-F           fill memory block with hex pattern
                (note: to copy block, please use save+load)
Alt-G           General Sound status (double-click - play sample)
Alt-T           ripper's tool
Alt-O           configure on-screen watches
Alt-U           disasm to file
Alt-S           cycle screenshot (ray-painted) / screendump (screen memory) / 
watches
Alt-F           render current frame to video buffer without border and MC 
effects
Ctrl-U          set user-defined watch address
Ctrl-L          view labels, visible for Z80 in current memory state
Ctrl-J          select and go to label
Alt-C           breakpoints manager
Alt-Y           switch active sound chip in Turbo-Sound mode


       manager can handle 3 types of breakpoints:

       1. conditional breakpoints and on-screen watches
       are using C expression syntax.

       operators (in priority order):
         () ! ~ M(x) -> * % / + - >> << > < == = <= >= != & ^ | && ||
       operands:
         a,b,c,d,e,h,l,bc,de,hl                 - common registers
         a',b',c',d',e',h',l',bc',de',hl'       - alternative registers
         ix,iy,pc,sp,i,r                        - control registers
         FD     - memory port #FD (also known as #7FFD)
         OUT    - port used in 'OUT' command (or 0FFFFFFFF when no outs)
         IN     - port used in 'IN'  command (or 0FFFFFFFF when no ins)
         VAL    - read/written value to port (only meaningful when OUT != 
0FFFFFFFF or IN != 0FFFFFFFF)
         numbers - hex, must start with digit: DFFD - wrong, 0DFFD - right
         characters - must be enclosed in single quotes ('A','B',etc..)
       All calculations use 32-bit unsigned interger arithmetic.
       If you are not familiar with C, use brackets as much as possible, due to
       non-intuitive operator's precedence, e.g.
       out & 0FF == 0FE   is treated as 'out & (0FF == 0FE)' <- always 0

       M(x) is byte from memory address x (same as x->0)
       '=' is an alias for '==' (for Pascal programmers)

       examples:

           (out+1) | (in+1)       - in/out to any port
           (in & 8001) == 0       - read keyboard row from <B> to <SPACE>
           !(out & 1)             - any out to port #FE
           (out & 0FF)==0BB && (val==0F3 || val==0F4) - reset General Sound
           (out & 0FF)==0FD && (val&7)==3   - set 3rd memory page
           (FD & 7) == 3                    - the same
           M(pc)==0CB && pc->1 >= 10 && pc->1 <= 17
                - set break on executing instruction "rl <reg>"

       I hope, these examples will be enough to get idea

       note: double-click on breakpoint to edit it

       2. execution breakpoints (also set in CPU window by pressing SPACE).
          In manager window it is easy to setup breakpoint on execution
          range like 6000-FFFF

       3. breakpoints on reading/writing memory. Similar to execution
          breakpoints, but have flags "R" and "W" to issue interrupt on
          reading/writing memory address (flags may be set together)


monitor: registers window

Cursor          select register
ENTER,0-F       change register
Ctrl+A,F,B,D,H,S,P,X,Y,I,R,M,1,2 edit A,F,BC,DE,HL,SP,PC,IX,IY,I,R,IM,IFF1,IFF2
Alt+S,Z,5,H,3,P,N,C              toggle flag
'               go to value under cursor in CPU window
;               go to value under cursor in memory window


monitor: CPU window

F4              trace to cursor
Alt-F7          find text
Ctrl-F7         find code with mask
HOME            go to PC
Ctrl-G          go to address
SPACE           set/reset breakpoint under cursor
ENTER           edit Z80 instruction, opcode bytes or cursor address
A-X             assemble new Z80 instruction
Z               set PC to cursor
Ctrl-1,.,Ctrl-8 save current position to slot 1-8
1-8             save current position to stack, go to saved position in slot 1-8
Backspace       restore position from jumpstack
'               push cursor position and go to instruction operand
;               jump to instruction operand in data window
Ctrl-A          reading labels from XAS or ALASM, using 3 methods:
   1. XAS7: assembler should be in bank 6 (or bank #46 for Pentagon-512)
   2. ALASM: version 4.42-5.0x should be in 128k-memory (pages 1-7)
   3. ALASM+STS: STS should be in bank#7 (or bank #47 for Pentagon-512)


monitor: memory window

Alt-F7          find text in memory / disk track
Ctrl-F7         find code with mask in memory / disk track
Cursor,Home,End,PgUp,PgDn        move
Ctrl-G                           go to address
Ctrl-M                           select memory editor
Ctrl-V                           select disk editor (physical track)
Ctrl-O                           select disk editor (logical sectors)
Ctrl-T                           select disk/track/sector in diskeditor
Ctrl-TAB                         move to hex/ascii
Ctrl+S,P,B,D,H,X,Y               go to SP,PC,BC,DE,HL,IX,IY
other keys                       edit

monitor: Beta 128 window

here is a typical FDC indicator content
CD:1820
STAT:21
SECT:09
T:01/01
S:3C/00

first line is command and data register (cmd18,data20 - seek track 20)
2nd line - status register
3rd line - sector register
4th line - actual FDD head position and track register
5th line - Beta disk system register and DRQ/INTRQ port

----------------------------------------------------------------------

bugs and incompatibilities


   some programs, such as Manic Miner and Lode Runner, require
   old 48K ROM (1982.rom), while some other programs require
   ZX Spectrum 128 ROM (48for128.rom + 128tr!.rom)

   some TR-DOS programs (Unreal Megademo by KSA, Street Fighter)
   work only if TR-DOS traps are disabled and all delays enabled

   Profi service ROM can work only when all TR-DOS delays are enabled

   Bumpy does not work in default configuration, it tries to read port
   #FFDF for kempston joystick - so disable kempston mouse before
   playing [bug found by Paul Pavlov]

   sounddrv=wave does not work with CTSB128PCI (Creative Sound Blaster),
   there is a bug in drivers for this card. [bug found by Nuts]

   some ABS adventures (ALIEN.SCL, LENIN.SCL) do not work with TR-DOS 5.04TM,
   use version 5.03 - it is most compatible [bug found by Paul Pavlov]

   Vixen 1,2,3 - incompatible with SounDrive [bug found by Paul Pavlov]
   Fernandez - incompatible with SounDrive [bug found by Shadow Maker]

   port #FF sometimes is not responding when SkipFrame!=0
   (the same to SkipFrameMaxSpeed!=0 and max speed mode)

   Scorpion 'MAGIC' generates NMI even if PC < #4000, but shadow
   monitor is not designed for this situation and may crash

   CacheVox by AlCo requires TR-DOS delays enabled and [BETA128] IL=1

   If the emulator after returning of focus seems to have a sticky key,
   press Scroll Lock, deactivate blinking key, then press Scroll Lock again.

   If emulator control keys work wrong after returning of focus, press Enter,
   and keys must go normal.
   
   If emulator hangs with General Sound, try DSPrimary=0.

   If emulator crashes with General Sound, try GSType=Z80.
   
   If Kempston Joystick doesn't work, go to menu, press NumLock there,
then return.

   In case of bad sound, try DSPrimary=1 (may crash emulator eventually!)
or SoundDrv=wave in .ini.

   Screenshots are saved to the emulator directory.
   Files to read and write via debugger are situated in a current directory
(which is seen by F3).

Download sys.trd (for drive B:) from http://alonecoder.narod.ru/zx/SYS.rar
Download xBIOS for ATM Turbo2+ from http://atmturbo.nedopc.com/
Get WNASPI32.DLL from Ahead Nero or from Ahead website

BASS.DLL v2.3 was taken from http://www.un4seen.com/ 

----------------------------------------------------------------------

greetings from SMT:

   * dj.Z, IMP and MIC - I enjoyed your music a lot !
   * Nik-O and Fatal Snipe - for adherence to ay scene
   * Hacker KAY - thanks for most accurate information about AY/YM
   * Paul Pavlov - maintainer of largest TR-DOS archive
   * Raul Gomez Sanchez (author of R80)
   * Stalker - thanks for STS
   * Placebo, Extreme, Digital Reality, CBS - for quality demos
   * V_Soft (Roman Scherbakov) - for Vortex format
   * Sergey Bulba - for AY_Emul
   * Alone Coder - you keep Spectrum alive
   * Ian Luck - thanks for BASS
   * SirX - just a hello
   * all ZX Spectrum fans - Speccy is da best!


special thanks to people, who were interested in
UnrealSpeccy's development and sent me info about hard/soft:

   * Maxim Vasilyev - sent me many bugreports
   * Mac Buster - some info about beta 128 disk interface
   * Shiru Otaku - sent me GSPAK.ZIP
   * Alexey Kravchenko - Scorpion timing info
   * Vitaliy Pigo - testing and benchmarking
   * Alex Baskakov - helped me with TD0 format
   * Alone Coder - thnx for many info about Pentagon hardware
   * Dexus - for integrating YM2203 support
   * Maksagor - ATM information
   * and many others, who emailed me congratulations/suggestions/etc

----------------------------------------------------------------------

license

        UnrealSpeccy is completely freeware. You may use this emulator
        and its sources without any restrictions. You may use the
        sources in your own emul or to release bugfixed/new versions.
        in this case you do not have to release updated source code,
        (unlike GNU Public License requires, for example). You may port
        emulator to any other platform (but there are many
        MSVC-specific language constructions, so it's doubtful that
        you can compile it with another compiler)

Send me bug reports, ideas, and changed source lines
http://dlcorp.nedopc.com/viewforum.php?f=8