home *** CD-ROM | disk | FTP | other *** search
/ Amiga ISO Collection / AmigaUtilCD2.iso / Misc / MAXONNOG2NOGURU.DMS / in.adf / sim.doc < prev    next >
Encoding:
Text File  |  1992-12-28  |  103.6 KB  |  3,084 lines

  1.  
  2. -------------------------------------------------------------------------------
  3.  
  4.                                   S.I.M.
  5.  
  6.                         System-Independent Monitor
  7.                                Version 1.68
  8.  
  9.                 Copyright © 1990/1991/1992 by Stefan Walter
  10.                             ALL RIGHTS RESERVED
  11.  
  12. -------------------------------------------------------------------------------
  13.  
  14.  
  15.  
  16.             The User Manual, refering to version 1.68 of S.I.M.,
  17.                           distributed with NOG2.
  18.  
  19.  
  20.  
  21.  
  22.  
  23.  
  24.                                  CONTENTS
  25.                                  ========
  26.  
  27.  
  28. 1.      Introduction
  29. --------------------
  30.  
  31.         1.1     Welcome to SIM
  32.         1.3     Disclaimer
  33.         1.2     About this Documentation
  34.  
  35. 2.      Getting aquainted with SIM
  36. ----------------------------------
  37.  
  38.         2.1     What is SIM?
  39.         2.2     Qualifications, Requirements and Limitations
  40.         2.3     The 68020+ Version
  41.         2.4     Configuring SIM
  42.         2.5     The SIM Program
  43.  
  44. 3.      Some words about...
  45. ---------------------------
  46.  
  47.         3.1     The Display
  48.         3.2     Breakpoints
  49.         3.3     Trace
  50.         3.4     The Keyboard
  51.         3.5     Disk Access
  52.         3.6     Files
  53.         3.7     Breaking
  54.         3.8     The Actual Address
  55.         3.9     The Matchbuffer
  56.         3.10    Command History
  57.         3.11    Traps
  58.         3.12    Functionkeys
  59.         3.13    SIM and the Hardware
  60.         3.14    The Colors Red and Yellow
  61.         3.15    Printer Support
  62.         3.16    Memory Managing
  63.         3.17    Screen Blanker
  64.         3.18    Effective Address Calculation
  65.         3.19    Symbols
  66.         3.20    PAL/NTSC
  67.   
  68. 4.      Communication between YOU and SIM
  69. -----------------------------------------
  70.  
  71.          4.1    The SIM Environement
  72.          4.2    The Monitor
  73.          4.3    The Commands and their Syntax
  74.          4.4    The Debugger Window
  75.          4.5    Debugger Window Shortcuts
  76.  
  77. 5.      Additional Information
  78. ------------------------------
  79.  
  80.          5.1    Assembler Usage
  81.          5.2    Calculator Usage
  82.          5.3    Data Line
  83.          5.4    The Debug Server Entrance
  84.          5.5    The SIM Base
  85.          5.6    Errors
  86.          5.7    Footer Messages
  87.  
  88. 6.      Appendix
  89. ----------------
  90.  
  91.         6.1     Acknowledgements
  92.         6.2     Registered Users
  93.         6.3     My Address
  94.  
  95.  
  96.  
  97.  
  98. *******************************************************************************
  99.         1.      Introduction
  100. *******************************************************************************
  101.  
  102.  
  103.  
  104.  
  105. 1.1     Welcome to SIM
  106. ======================
  107.  
  108.  
  109.   Congratulations dear user. You have just obtained the third release
  110.   of 'S.I.M.', a high performance monitor and debugger for the Commodore
  111.   Amiga.
  112.  
  113.   This version of SIM is distributed along with NOG2. Buyers of NOG2
  114.   automatically obtain the status of a registered user and gain the
  115.   right to use SIM.
  116.  
  117.   'S.I.M.' is a shareware product. This means that it can be used, copied
  118.   and distributed freely, provided that:
  119.  
  120.     1)   No fee is charged for copying and distribution.
  121.     2)   It is distributed ONLY in its original, unmodified state.
  122.     3)   This document is copied along with the program.
  123.  
  124.   If you copied this version from somebody else and you like it and keep using
  125.   it, you are asked to send a little contribution of 20 SFr or 15 US$ to the
  126.   author in order to get registered and to obtain support and the final
  127.   version when it's finished.
  128.  
  129.  
  130.  
  131. 1.2     Disclaimer
  132. ==================
  133.  
  134.  
  135.   This program is provided "as is" without warranty of any kind. The entier
  136.   risk of using it is to the user himself. In no event I (the author) will
  137.   be liable for direct or indirect damage, loss of data or criminal actions
  138.   done due to the use of this program. If you do not agree with this, you 
  139.   may not use SIM.
  140.  
  141.  
  142.  
  143. 1.3     About this Documentation
  144. ================================
  145.  
  146.  
  147.   You should carefully skim this documentation if you are not used to SIM
  148.   yet. SIM bases on a concept that especially programers lacking detailed
  149.   knowledge of assembly language or C will first need to get aquainted
  150.   with.
  151.  
  152.  
  153.  
  154.  
  155. *******************************************************************************
  156.         2.      Getting aquainted with SIM
  157. *******************************************************************************
  158.  
  159.  
  160.  
  161.  
  162. 2.1     What is SIM?
  163. ====================
  164.  
  165.  
  166.   SIM is a very powerful debugger and monitor. It was designed to work under
  167.   all circumstances and especially to supervise rather unconventional programs
  168.   which do not make much use of the operating system or do completely disable
  169.   it for more or less long time. It is intended for people who need to debug
  170.   games, demonstration programs and even other operating systems on the Amiga.
  171.  
  172.   SIM works below the operating system and does not interact with any of its
  173.   facilities or routines. It disposes of ways to enable you relatively
  174.   comfortable debugging of any piece of machine language. Be it a task list
  175.   manipulating routine, an interrupt or direct access on hardware like disk
  176.   drives or the blitter, routines you can't monitor with an ordinary system
  177.   based debugger. There are practically no limits. You can invoke SIM at any
  178.   moment and it will pop up and work properly.
  179.  
  180.   SIM will do as less changes to the software and hardware (ram, custom/cia
  181.   registers) as it can. When you exit SIM, it will try to leave everything the
  182.   way it was when SIM was started. SIM does neiter use blitter nor copper,
  183.   so any 'interrupted' program can continue to run with no defects due to
  184.   a call to SIM.
  185.   
  186.   SIM will be very useful for you if you need to debug programs belonging in
  187.   the cathegories described above. If you only need to debug 'ordinary'
  188.   programs with no critical or nonmultitasking routines, you are better served
  189.   with a full system debugger. There are plenty of good debuggers of that
  190.   kind available, also in the Public Domain.
  191.   
  192.  
  193.  
  194. 2.2     Qualifications, Requirements and Limitations
  195. ====================================================
  196.  
  197.  
  198.   To use SIM efficiently, detailed knowledge of the AMIGAs hardware,
  199.   the 680x0 processors and assembly language is ABSOLUTELY neccessary.
  200.   If you lack this knowledge, get Commodores 'Amiga Technical Reference
  201.   Series' and Motorolas documentations of the 68000 family.
  202.  
  203.   SIM is completely independent of the OS the Amiga uses. There is a certain
  204.   support for the normal OS, but no dependancy.
  205.  
  206.   SIM does several things by directly accessing the hardware. This however
  207.   is no longer allowed by Commodore and will probably cause SIM not to work
  208.   on Amigas of the next generation(s). If an incompatibility occurs, an
  209.   update will be released.
  210.  
  211.   You should not invoke SIM while doing any kind of timed access to hardware,
  212.   i.e. serial transfer. Because SIM shuts down everything, data transfer
  213.   will be interrupted. SIM may get in troubble if your Amiga is connected
  214.   to a harddisk which is accessed by an interrupt polled driver, damage
  215.   however should not be inflicted.
  216.  
  217.  
  218.  
  219.  
  220. 2.3     The 68020+ Version
  221. ==========================
  222.  
  223.   The 68020+ version is only an 68000 version with the neccessary changes
  224.   to get it working on better CPUs. Special features of these processors
  225.   (additional exception vectors, instructions, registers, etc.) are not
  226.   supported if not absolutely neccessary.
  227.  
  228.   The 68020+ version however works only with some limitations:
  229.  
  230.         - VBR must be at a known position. Default location $0,
  231.           if vectorbase is not at 0, the real location must be
  232.           stored in the base of SIM (offset 264).
  233.  
  234.         - The 'v' command can only push stackframes back, not
  235.           generate artificial ones.
  236.  
  237.         - The disassembler and assembler do not support any instructions
  238.           added in the 68010+ processors, except Bcc.B/W/L and EXT.B.
  239.  
  240.         - MMU activities are not dealt with yet. SIM deactivates the MMU by
  241.           default. If an active MMU tree i.e. only remaps the Kickstart image,
  242.           you can switch the MMU on while SIM is active, if some sort of
  243.           virtual memory or enforce MMU tree is active, you should keep the
  244.           MMU shut while SIM is active.
  245.  
  246.  
  247.  
  248. 2.4     Configuring SIM
  249. =======================
  250.  
  251.  
  252.   You can't use SIM right away, you need to configure a copy to your
  253.   Amiga first. Therefore you have to use 'SIMConfig'. This program
  254.   configurates SIM for your machine and your personal needs.
  255.  
  256.   The program is selfexplaining except when it comes to define the
  257.   memory pages. Here you shall make no mistake or the copy generated will
  258.   not work properly. First think about what must be viewable. That is:
  259.  
  260.         - graphic memory
  261.         - all fastmem expansions
  262.         - Kickstart image
  263.  
  264.   Get all start and endaddresses and sort them from lowest to highest.
  265.   If you can merge pages then do so for same memory types. Do not define
  266.   overlapping pages. Pages must also start and end at even addresses. The
  267.   program  'SIMConfig' does not check for correctness of what you enter.
  268.   If you define incorrect pages, SIM may crash later. In case you do not
  269.   want any memory managing enter $1000000 as first page endaddress for
  270.   the 68000 version, $80000000 for the 68020+ version.
  271.  
  272.   You can exit this program anytime by entering 'exit'.
  273.  
  274.  
  275.  
  276. 2.5     The SIM Program
  277. =======================
  278.  
  279.  
  280.   SIM is not an executable (it has no hunkstructure, so you cannot
  281.   simply start it from the CLI or workbench) but a simple PC-relative file
  282.   that can be loaded somewhere into the memory or included in one of your
  283.   own programs.
  284.  
  285.   SIM is a nonmultitasking debugger. When it is activated, Multitasking
  286.   is immediately stopped, much like by Disable().
  287.  
  288.  
  289.  
  290.  
  291. *******************************************************************************
  292.         3.      Some words about...
  293. *******************************************************************************
  294.  
  295.  
  296.  
  297.  
  298. 3.1     The Display
  299. ===================
  300.  
  301.  
  302.   The display creates some of the more tricky problems for SIM and you.
  303.   As you know, you need 20480/$5000 bytes of chipmem for a medres bitplane
  304.   you want to display. SIM uses a 640*256 bitplane for it's display. But at a
  305.   certain moment, there may be no 20480 bytes chipmem available.
  306.  
  307.   The solution is the backup. When you have an area of $5000 free chipmem
  308.   that will stay free for sure (that means it is allocated with allocmem or
  309.   will never be used), you simply set the display address to the start
  310.   of that area and the backup address to zero (this means no backup). SIM will
  311.   then concider these $5000 bytes its own and use it as display. When you enter
  312.   SIM, the data in this area are then destroyed.
  313.  
  314.   In case there is not enough free chipmem or the chipmem will be used entierly
  315.   in near future and you have enough (that means $5000 bytes) unused fastmem
  316.   that won't be used for sure (disable fastmem...), you set the backup address
  317.   to the start of a free $5000 block of fastmem and the display address just to
  318.   somewhere in the chipmem. When SIM is activated, It copies the content of the
  319.   $5000 bytes display- to the backupmem and uses the displaymem. When you leave
  320.   SIM again, it copies the $5000 bytes back from the backup- to the displaymem.
  321.   That way, the chip ram is unchanged.
  322.  
  323.   The memory manager claimed to be missing in earlier versions
  324.   is now integrated in several functions. If you have defined a backup area
  325.   the memory manager automatically fades it in at the location of the display.
  326.  
  327.   Because the interrupt vectors are used, you may not specify a display below
  328.   $70 or above $7b000 when you have the normal amount of chipmem (the chipmem
  329.   is reflected at $80000, except if you have fastmem there).
  330.  
  331.   Both the display- and the backupaddress are entered in the SIM-basearea
  332.   before starting SIM or set by the 's' command while working.
  333.  
  334.   NTSC users please note that although a 640*200 plane only uses 16000 bytes,
  335.   you too need $5000 display memory because it is also used as MFM buffer
  336.   for all disk operations.
  337.  
  338.  
  339.  
  340. 3.2     Breakpoints
  341. ===================
  342.  
  343.  
  344.   A breakpoint is basically a change in the program that is monitored that
  345.   stops it and gives control to the debugger that set it. In other terms, you
  346.   can run the program at full speed until it arrives at a certain instruction.
  347.   This is a very important feature when you have to control the flow of a
  348.   program. Therefore the breakpoint system of SIM is very sophisticated. SIM
  349.   can handle three kinds of breakpoints:
  350.  
  351.         - ILLEGAL breakpoints
  352.         - JSR breakpoints
  353.         - STACK breakpoints
  354.  
  355.   Each kind is used for different problems and has its advantages and
  356.   disadvantages.
  357.  
  358.   SIM is able to handle 16 different breakpoints at a time. When you enter
  359.   SIM, it removes the breakpoints from the memory, so the memory looks like it
  360.   would look with no breakpoints set. That enables you to change instructions
  361.   that are at a breakpoint without first removing the breakpoint before
  362.   changeing and putting it back afterwards.
  363.  
  364.   A critical situation occurs when the breakpoint is overwritten by a
  365.   program (i.e. by a copyroutine). Such a breakpoint is in 'modified' state
  366.   When SIM removes the breakpoints at entry, it checks if they are still there.
  367.   Modified breakpoints are not removed and not restored, when you leave SIM
  368.   again. If you want to have the modified breakpoint set again, you must first
  369.   'forget' it (this means that SIM simply frees the place in the breakpoint
  370.   list but does not put the original opcode or words back). Then you can set
  371.   it again.
  372.  
  373.   You cannot set breakpoints everywhere. SIM tests if there is ram at the
  374.   location where you want to set a breakpoint. If there is none, this causes
  375.   an error. SIM also prohibits to set breakpoints in the SIM codesegment.
  376.  
  377.  
  378.   1. ILLEGAL breakpoints
  379.   ----------------------
  380.  
  381.   Illegal breakpoints are normally the most used ones and offer the most
  382.   possibilities. When you set an ILLEGAL breakpoint at a certain instruction,
  383.   SIM replaces the opcode word of that instruction by the ILLEGAL opcode $4afc.
  384.   When the ILLEGAL instruction is executed instead of the original instruction,
  385.   an ILLEGAL INSTRUCTION exception happens.
  386.  
  387.   Therefore it is neccessary that the ILLEGAL INSTRUCTION vector somehow jumps
  388.   to SIM, either directly, set by the 'w' command, or indirectly by the task
  389.   traphandle, set by 'SIM-BUG' or another SIM-loader. If this is not so, your
  390.   machine crashes.
  391.  
  392.   Illegal breakpoints have the advantage that they can be 'conditioned'.
  393.   This means that this breakpoint only forces entry when one or one of several
  394.   conditions are fullfilled. The following criterias can decide whether or
  395.   not the breakpoint forces entry:
  396.  
  397.  
  398.     - condition term:
  399.  
  400.       You can specify a formula that is calculated each time when the program
  401.       arrives at the breakpoint. When the result of the term is zero, the
  402.       program continues, if it is nonzero, SIM is entered.
  403.  
  404.       You can use that feature to i.e. break a program at a certain point if
  405.       a register contains a certain value.
  406.  
  407.  
  408.     - counter breakpoint:
  409.  
  410.       A counter breakpoint will enter SIM if the program has passed the
  411.       breakpoint a certain number of times.
  412.  
  413.       This way you can i.e. break a subroutine after it was called a certain
  414.       number of times.
  415.  
  416.  
  417.     - button breakpoint:
  418.  
  419.       When the program arrives at a button breakpoint, SIM will look if the
  420.       left or right mousebutton or the firebutton of a joystick in port 1 is
  421.       pressed and enter SIM if one is pressed. You can specify what buttons
  422.       are concidered.
  423.  
  424.       Button breakpoints can i.e. be set in a vertical blanking interrupt.
  425.       every fiftieth/sixtieth of a second, SIM can check if you want to enter
  426.       or not.
  427.  
  428.  
  429.   Additionally you can make resident Illegal breakpoints. A nonresident
  430.   breakpoint will be removed after it caused entry. A resident breakpoint
  431.   will stay active until you remove it. A resident breakpoint can be used
  432.   in situations when you want to stop a program several times at the same
  433.   address.
  434.  
  435.   SIMs breakpoint system enables to combine all these elements, to make
  436.   resident breakpoinst that break at SEVERAL conditions. You can set a resident
  437.   breakpoint at $70000 that either breaks when d3 is 3245 or the left or right
  438.   mousebutton is pressed and that is limited to 1000 passes. The command line
  439.   to set that breakpoint would look like that: 'b 70000 * ?d3=3245 lr 1000'.
  440.  
  441.   You may ask the question how to go over a breakpoint. SIM does this in three
  442.   steps:
  443.  
  444.     - remove the Illegal opcode and put back the original one.
  445.  
  446.     - do a tracestep to execute the instruction.
  447.  
  448.     - remember the (possibly new) opcode and set the $4afc again.
  449.  
  450.   As you see, SIM uses the TRACE vector to ignore a breakpoint. This means
  451.   that you must not only set the ILLEGAL INSTRUCTION vector but also the
  452.   TRACE vector. This is neccessary as soon as you have set a conditioned or
  453.   a resident breakpoint.
  454.  
  455.  
  456.   2. JSR breakpoints
  457.   ------------------
  458.  
  459.   The second type of breakpoint is a rather a 'heavy duty' one. When you
  460.   set a JSR breakpoint, SIM remembers the 6 bytes at the breakpoint address
  461.   and puts a JSR instruction there that jumps absolutely into SIM (i.e.
  462.   'JSR $c50726'). When the breakpoint is reached, the program jumps
  463.   directly into SIM which then puts back the 6 bytes.
  464.  
  465.   This breakpoint has two advantages. The first is that you do not need any
  466.   vectors to be set. The second is that a JSR breakpoint can be transfered.
  467.   When you have an Illegal breakpoint in a routine and that routine is
  468.   transfered to another location and the breakpoint is reached in the
  469.   copied routine, SIM will not know that that illegal is a breakpoint
  470.   because it is not at any of the addresses at which a breakpoint was set,
  471.   so it will not be replaced by the original opcode.
  472.  
  473.   JSR breakpoints are recognized at their entrance, because each of the 16
  474.   possible JSR breakpoints has another entrance. That way, SIM can recognize
  475.   that breakpoint whereever it is. But be carefull, never enter SIM by
  476.   these entrances on your own. You must also see to it that after the
  477.   transfered breakpoint forced entry and was removed, the original one is
  478.   NOT reached too.
  479.  
  480.   Because of these two advantages, you can use JSR breakpoints in delicate
  481.   situations, where you are not sure if the vectors are not changed.
  482.  
  483.   A disadvantage of JSR breakpoints is that they use not one but three
  484.   words. The minimum size for an instruction is a word, an Illegal
  485.   breakpoint can be set at any instruction because the instruction ILLEGAL
  486.   uses one word. A JSR breakpoint may replace three instructions. Therefore
  487.   you have to set the JSR breakpoint in a 'linearly' executed part of the
  488.   program. Here are two examples where the JSR breakpoint is not set
  489.   correctly. The breakpoint is always set at the label 'bkpt':
  490.  
  491.   1. .
  492.      .
  493.      .
  494.      bsr.s label      ;this bsr would jump in the middle of the breakpoint!
  495.     bkpt:
  496.      bra.s label2     ;JSR opcode
  497.     label:
  498.      nop              ;HIword of entrance
  499.      nop              ;LO word of entrance
  500.      .
  501.      .
  502.      .
  503.  
  504.  
  505.   2. .
  506.      .
  507.      .
  508.     bkpt:
  509.      moveq #1,d0      ;JSR opcode
  510.     label:
  511.      moveq #0,d1      ;HI word of entrance
  512.      rts              ;LO word of entrance
  513.      .
  514.      .
  515.      .
  516.      moveq #-1,d0
  517.      bra.s label      ;again in the middle...
  518.  
  519.  
  520.   3. Stack breakpoints
  521.   --------------------
  522.  
  523.   Contrarily to the Illegal and JSR breakpoint, the Stack breakpoint is
  524.   not a change in the program but a change on the Stack. When SIM sets a
  525.   Stack breakpoint, it replaces a returnaddress on the stack by the address
  526.   of an entrance of SIM. When the appropriate rts, rtr or rte that would
  527.   return to that address is reached, it returns to SIM instead. SIM sets the
  528.   pc to the returnaddress and replaces the SIM entrance address on the stack
  529.   (should now be at a7-4!) by the original address for security.
  530.  
  531.   For SIM, it does not differe, if the Stack breakpoint is set in the
  532.   supervisor or userstack (in earlier versions it did, this is no longer
  533.   so).
  534.  
  535.   Use this feature wisely! SIM cannot test if the Stack breakpoint you set
  536.   is put in a stack and is taken off stack by a rts. Its upon you to set Stack
  537.   breakpoints at the right position.
  538.  
  539.   Stack breakpoints are also used by for the nextstep and the leave
  540.   subroutine command.
  541.  
  542.  
  543.  
  544. 3.3     Trace
  545. =============
  546.  
  547.  
  548.   Tracing is the second way of keeping a program under control. SIM can
  549.   singlestep a program. Therefore you must see that the TRACE exception caused
  550.   by that somehow ends up in SIM, either set it directly or set the
  551.   tasktraphandle. It can also let a program run step by step and stop when
  552.   one or several conditions are fullfilled, much like the illegal breakpoints:
  553.  
  554.  
  555.     - condition term:
  556.  
  557.       You can specify a formula that is calculated after each step. When the
  558.       result of the term is zero, the trace continues, if it is nonzero,
  559.       SIM is entered.
  560.  
  561.       You can use that feature to i.e. break a program as soon as a certain
  562.       register is changed.
  563.  
  564.  
  565.     - counter trace:
  566.  
  567.       You can specify a maximum number of steps to do. When that amount of steps
  568.       is done, SIM is entered.
  569.  
  570.       Counter trace is mostly use to just get back after a routine is done.
  571.  
  572.  
  573.     - button trace:
  574.  
  575.       After each step, SIM will look if the left or right mousebutton or the
  576.       firebutton of a joystick in port 1 is pressed and enter SIM if one is
  577.       pressed. You can specify what buttons are concidered.
  578.  
  579.       Button trace can i.e. be used for stoping a program by hand at any moment.
  580.  
  581.  
  582.     - trace breakpoint:
  583.  
  584.       You can define an address that is compared to the PC after each step.
  585.       If the program has arrived at that address, SIM is entered.
  586.  
  587.       This feature is used when you cannot use breakpoints for some reasons.
  588.  
  589.  
  590.     - 68020 emulation:
  591.  
  592.       This is also a condition. SIM is only entered when a change in the flow
  593.       would happen, this means that the pc points on a BRA, JMP etc.
  594.  
  595.       I do not know what this is for, but people like it.
  596.  
  597.  
  598.   SIM uses the trace flag to do single steps. What some people do not know is
  599.   that you can trace over some instructions that may clear that flag. These are
  600.  
  601.    RTE
  602.    MOVE to SR
  603.    ORI #x,SR
  604.    EORI #x,SR
  605.    ANDI #x,SR
  606.  
  607.   Additionally you can enter the TRAP #x exception routines with the trace.
  608.  
  609.   Tracing has one weak spot: if you are tracing and an interrupt happens that
  610.   somehow causes entry in SIM (i.e. by a breakpoint), SIM loses the control
  611.   over the trace. When you exit SIM again and the interrupt ends, a TRACE
  612.   exception happens. You must then start to trace again or clear the trace flag
  613.   by hand.
  614.  
  615.   Some words about the speed: It is clear that the more conditions you allow,
  616.   the slower the program runs. Additionally some conditions cause longer delays
  617.   than others. Condition trace is slower than button trace because it has to
  618.   call the calculator which is relatively complex and slow.
  619.  
  620.  
  621.  
  622. 3.4     The Keyboard
  623. ====================
  624.  
  625.  
  626.   The most difficult problems are imposed by the keyboard. The Amigas keyboard
  627.   hardware cannot tell you which keys are pressed at a certain moment, it
  628.   reports only key changes. This makes it difficult for systemindependent
  629.   programs. When you press a key under system and release it in a program
  630.   that has its own keyboardhandler, the system will never know that you
  631.   released that key, it will report repeats of that key all the time until you
  632.   press another key. To prevent this, SIM will look that all keys are in the
  633.   same state when you leave SIM as they were in when you entered SIM. When you
  634.   leave SIM and a key is not in the same state, SIM will ask you to either
  635.   press that key or to release it. Therefore, in the headline you will find the
  636.   keys rawkey number and if in the keymap there is a printable char, that char
  637.   too. You can only exit SIM if you press or release all keys that it wants
  638.   you to.
  639.  
  640.   If you leave SIM by accident (hit wrong key?) and you are requested to
  641.   press/release a key, you can do the following operation to return to the
  642.   monitor:
  643.  
  644.   - press another key that is not a qualifier (shift etc.), not 'r', 'e', 't',
  645.     'u', 'n' or one that you must press to exit (esc is a good choice).
  646.  
  647.   - release all other keys
  648.  
  649.   - type 'return'
  650.  
  651.   - release the keys you pressed for that operation
  652.  
  653.   If you are tired to press keys again and again to exit, you can use the
  654.   flush keystatefield shortcut. SIM will then clear the internal list of
  655.   keys that were pressed when SIM was activated.
  656.  
  657.   As you know, the keyboard can store upto ten rawkeys on its own if
  658.   the CPU has no time or need to get keyboard events. It is possible
  659.   that several key hits are waiting to be replied. When SIM is activated
  660.   then, it would recieve all those old keys that may invoke shortcuts or
  661.   commands that are not desired. Similar problems occur when you link SIM
  662.   in the CIA-A interrupt and it is invoked before the key is replied. The
  663.   keyboardbuffer killer is used to reply to all possibly waiting keys and
  664.   to flush the keyboard buffer. This feature can be toggled on or off.
  665.   
  666.  
  667.  
  668. 3.5     Disk Access
  669. ===================
  670.  
  671.  
  672.   Because ram is a too transitory datacarier, SIM can read and write
  673.   DOS-tracks and sectors. It does this by directly accessing the hardware.
  674.   Unfortunately, I know only one way to find out if a drive is running or
  675.   not: To activate the drive and look if its on full speed with no delay.
  676.   This system is only working when the running drives have a disk inserted.
  677.   If no disk is in a running drive and you access disk, it will be stoped
  678.   after disk access.
  679.  
  680.   When SIM is writing or reading, the display is used as buffer. You still
  681.   see it, but it contains chaos. The top line is used to give you status
  682.   information about the track that is operated or errors occured.
  683.  
  684.   When an error occures, you can either break with CTRL, retry with SHIFT
  685.   or ignore the error with ALT (when file operation, ALT=CTRL).
  686.  
  687.   When a track is not correct, SIM tries to read it three times. Then it
  688.   reports the error but displays also which sectors were okay. It is
  689.   possible that only one sector is damaged, press SHIFT several times, SIM
  690.   may find some sectors more that are okay and simply were after the damaged
  691.   sector last time.
  692.  
  693.   SIM is tollerant concerning the integrity of the sectors. Checksums are
  694.   calculated and SIM reports an error if one is wrong, but it decodes the
  695.   sector anyway. This enables SIM to reapair partially destroyed tracks.
  696.  
  697.   HD disks as used in the A4000 are not supported yet.
  698.  
  699.  
  700.  
  701. 3.6     Files
  702. =============
  703.  
  704.  
  705.   The capabilitys of SIM to read, list and write files are some of its newest
  706.   and most usefull features. You can load any files of a DOS disk, also
  707.   from user directories to memory. You can list the files and their length
  708.   contained in any directory. And you can save any area of memory as a file
  709.   on a disk.
  710.  
  711.   The file save system is quite sophisticated. It writes files in a way
  712.   that they can be loaded and listed fast. Info- and extension blocks are
  713.   located on track 79 and higher, data blocks from 79 down to 0 and from 159
  714.   to 79. Additionally, SIM will first look if a file fits the disk before
  715.   it begins to save. The bad sideeffect of this is that saving takes some time.
  716.  
  717.   One thing you must remember is to be carefull with saving files when you
  718.   work with the normal operating system afterwards. When you save a file,
  719.   the bitmap on the disk is changed. The system keeps its own copy of the
  720.   bitmap of a disk in memory. When it accesses that disk again, it possibly
  721.   discovers a totally different bitmap. When it comes to the worst, the DOS
  722.   crashes with the guru 07000007 (bitmap corrupt). To prevent this, you
  723.   simply remove that disk from its drive and put it back again. The DOS
  724.   then rereads the bitmap and everything's okay.
  725.  
  726.  
  727.  
  728. 3.7     Breaking
  729. ================
  730.  
  731.  
  732.   In certain situations, it may be neccessary to break an operation or to
  733.   pause it. SIM can both. You can break the dump commands, find and compare
  734.   by shortly hitting CTRL. If you press it longer, SIM only pauses and
  735.   continues when you release CTRL. When you press SHIFT-CTRL or additionaly
  736.   hit the SHIFT key when you pause, SIM locks until you release, press and
  737.   relese CTRL again. This enables you i.e. to make notes without holding
  738.   CTRL all the time.
  739.  
  740.   While locked or paused, you can press the ALT key. When you release CTRL
  741.   (if locked, press it first), SIM breaks also. This is used when you have
  742.   paused and want to stop immediately.
  743.  
  744.   ALT-CTRL is used to break command execution in general. Before SIM looks
  745.   for a new command in a command line, it tests for ALT-CTRL. If that's so,
  746.   it breaks. This enables you to break a commandline like 'P0:X' since you
  747.   cannot break the 'P' and 'X' commands.
  748.  
  749.   An exception to this rules are the disk operation and the list directory
  750.   command. These commands can only be broken. Therefore simply keep the CTRL
  751.   key pressed until SIM gets it.
  752.  
  753.  
  754.  
  755. 3.8     The Actual Address
  756. ==========================
  757.  
  758.  
  759.   The dump and edit commands share a default address variable that is used
  760.   each time, you do not give a startaddress. This address has the name '@'
  761.   for the calculator. It contains the endaddress of the last dump or edit
  762.   command or it is set by find and compare.
  763.  
  764.  
  765.  
  766. 3.9     The Matchbuffer
  767. =======================
  768.  
  769.  
  770.   The matchbuffer is used to collect addresses. You can force the find and
  771.   compare commands to put the addresses they report into this buffer. Well,
  772.   this is nothing special. But you can also say under what conditions an
  773.   address is put in the buffer or one that is already in buffer stays there.
  774.   There are three possible conditions:
  775.  
  776.  
  777.   - old:     If an address that was already in buffer did not match with any
  778.              reported by the find or compare command, it only stays in the
  779.              buffer when you enable oldies.
  780.  
  781.   - match:   If an address that is reported is already somewhere in the buffer,
  782.              it stays only when you enable matches.
  783.  
  784.   - new:     If an address is new, it is only put in the buffer when you enable
  785.              new ones.
  786.  
  787.   You can combine the three conditions in any way (there are eight possible),
  788.   some may make not much sence.
  789.  
  790.   This feature enables you to search for counters or changes. It is implented
  791.   for people using SIM to cheat in games.
  792.  
  793.   To show the addresses in the buffer, the 'k' command is used.
  794.  
  795.   An example: you are searching for the address of a counter. You know that
  796.   the counter is on 10 now:
  797.  
  798.   1. define matchbuffer, i.e. 'k c00000 c10000'
  799.   2. search for 10, i.e. 'f 0 20000 !n 0a'
  800.   3. exit, perform any neccessary operation to change the counter to another
  801.      known value, i.e. 15
  802.   4. search for 15, i.e. 'f 0 20000 !m 0f'
  803.   5. list addresse(s) in matchbuffer, i.e. 'k 0'
  804.   6. if more than one address stays in the buffer, go to step 3 and
  805.      search again until one address stays.
  806.  
  807.  
  808.  
  809. 3.10    Command History
  810. =======================
  811.  
  812.  
  813.   SIM remembers the last commands executed in the monitor. 128 bytes are
  814.   reserved for that. These 128 bytes contain the last packed command lines
  815.   that fit. If you get an old command line back by the command history
  816.   shortcuts and execute it, it is not remembered as the newest executed
  817.   command.
  818.  
  819.  
  820.  
  821. 3.11    Traps
  822. =============
  823.  
  824.  
  825.   The traps are one of the major connections of sim to the outer world. They are
  826.   used for breakpoints and to handle crashes. You can set the ten basic
  827.   exception vectors directly. When you enter SIM, it puts back the original
  828.   vectors, so you can edit them. When exited, SIM sets the set traps again.
  829.  
  830.   Problems occure when the program that is debugged sets the traps itself.
  831.   When the program changes a vector previously set by SIM, this is handled the
  832.   same way as it is done with changed breakpoints.
  833.  
  834.   Additionally you can force SIM to set traps again if they are modified by
  835.   toggeling 'Auto Unmodify Traps' on. If traps set by SIM are changed, the
  836.   display color of SIM turns yellow in order to inform you of this.
  837.  
  838.   While working under operating system, it is not recomended to set the
  839.   exception vectors directly to SIM, except if it becomes neccessary.
  840.  
  841.  
  842.  
  843. 3.12    Functionkeys
  844. ====================
  845.  
  846.  
  847.   You can define all ten functionkeys with a text or command line. If you define
  848.   a text, it is copied at the location of the cursor. If you define a command
  849.   line, it is executed directly.
  850.  
  851.   The system used bases much on the one used by the Sharp PC-1500, thanks to
  852.   Sharp for that.
  853.  
  854.   The functionkeys share 300 bytes of 'intelligent' textbuffer with the
  855.   condition breakpoints and linkterms.
  856.  
  857.   The ten functionkeys are partially allready defined in the original
  858.   SIM version. These are the definitions:
  859.  
  860.   F1:  z@        ;for easy tracing
  861.   F2:  u@        ;also for easy tracing
  862.   F3:  i@        ;dito
  863.   F4:  f@        ;for repeated finding
  864.   F5:  c@        ;for repeated comparing
  865.   F8:  v:X@      ;when exceptionvectors are set and an exception happens
  866.                   and has to be handled by the original vector
  867.   F9:  dm0 m0@   ;for finding disassembly without debugger window. Initially
  868.                   deselected
  869.   F10: r:dpc pc@ ;for tracing without debugger window. Initially deselected
  870.  
  871.  
  872.  
  873. 3.13    SIM and the Hardware
  874. ============================
  875.  
  876.  
  877.   SIM does only use a very limited part of the hardware registers, the ones
  878.   that are indispensable or must be set on fix values to provide security.
  879.   Some of these registers can be read, some not. The values of the readable
  880.   ones are remembered in a special part of SIM called 'SIM base' when SIM is
  881.   activated. The SIM base is located, as its name says, at the start of SIM.
  882.   In chapter 6.1 you find the structure of the base.
  883.  
  884.   These are the registers that are read out and stored in the base at entry.
  885.   When you exit SIM, it copies the remembered values back:
  886.  
  887.  
  888.   - DMACON
  889.   - INTENA
  890.   - INTREQ *)
  891.  
  892.   - Level 2 interrupt
  893.   - Level 3 interrupt
  894.  
  895.   - CIA-A: CRA
  896.   - CIA-A: CRB
  897.   - CIA-B: CRA
  898.   - CIA-B: CRB
  899.  
  900.   - CIA-A: PRA write buffer
  901.   - CIA-A: PRB write buffer
  902.   - CIA-A: DDRA
  903.   - CIA-A: DDRB
  904.  
  905.   - CIA-B: DDRA
  906.  
  907.   - CIA-A: SR write buffer
  908.  
  909.   - VPOS **)
  910.  
  911.  
  912.   All these registers are used by SIM when working. If you have to know
  913.   what vaule was in one of those, you have to look in the SIM base where SIM
  914.   remembered them.
  915.  
  916.  
  917.   *) This register is handled in a special way. While SIM is active, it leaves
  918.   the disk-DMA switched on. If it wouldn't, this would possibly destroy your
  919.   disks. Now since the disk-DMA is left on, remember that when the disk-DMA is
  920.   terminated, bit 1 in the INTREQ is set. But this may happen during SIM is
  921.   active because the DMA was still transfering when the INTREQ was read. Therefore
  922.   you will find only the interrupt requests in the backup that were waiting
  923.   when SIM was activated. If you want to know abaout the actual ones, you must
  924.   read out INTREQR using the calculator command '?[$dff09c].w'.
  925.  
  926.   When you exit and didn't edit the INTREQ backup, SIM does not restore
  927.   the bits EXTER, DSKSYN, RBF, AUDX, DSKBLK and TBE from the backup. If you
  928.   edited the backup, the bits that are changed are restored , even if they
  929.   contain some of the bits named above.
  930.  
  931.   **) This value is not written back. SIM rather waits for the rasterbeam
  932.   to be aproximately at that position that it was on when the register was
  933.   read. The register is read at a late point of time when SIM is activated,
  934.   quite some instructions have been executed then, so it is not very precise.
  935.   hopefully this can be improved.
  936.  
  937.   As quoted, some of the custom register contain information that is lost
  938.   because SIM cannot read from these registers. For the more important
  939.   ones, SIM disposes of an editable list of 'reentry' values which it puts
  940.   back when exiting. Those registers are:
  941.  
  942.  
  943.   - DIWSTRT
  944.   - DIWSTOP
  945.   - DDFSTRT
  946.   - DDFSTOP
  947.   - BPLCON0
  948.   - BPLCON1
  949.   - BPLMOD1
  950.   - COLOR00
  951.   - COLOR01
  952.   - BEAMCON0*)
  953.  
  954.   *) The BEAMCON0 register is only accessed under ECS or AGA. Unter OS,
  955.   this register however is only updated at calls to LoadView(), not in
  956.   the copperlist. You may need to concider that if you are using an
  957.   advanced resolution (i.e. VGA) on your Workbench screen and don't
  958.   access SIM via SIMBug or PostSIM which both update the BEAMCON0 reentry
  959.   value to the value used by the OS.
  960.  
  961.   As you see, these registers all concern the display. In most cases, they
  962.   are reset anyway by a copperlist. If not, you have to look in the program
  963.   where it sets them for the initial value and enter it in the base or decide
  964.   on your own what value to use.
  965.  
  966.   Some of the registers are modified but do not have a reentry value,
  967.   because they are either too temporary (DSKPTX for example) or compleetely
  968.   unimportant (BPL1PTX). If it becomes neccessary, you can edit some with
  969.   the 'e' command:
  970.  
  971.  
  972.   - CLXDAT
  973.   - DSKBTR *)
  974.   - DSKPTX *)
  975.   - DSKLEN *)
  976.   - DSKSYNC *)
  977.   - BPL1PTX
  978.   - BPL1DAT
  979.   - SPRXDATA/B
  980.   - CIAA: ICR state and mask
  981.  
  982.  
  983.   *) These registers are only used and changed when you read or write from or
  984.   to disk.
  985.  
  986.  
  987.  
  988. 3.14    The Colors Red and Yellow
  989. =================================
  990.  
  991.  
  992.   When you start to use SIM quite often and in critical situations, it may
  993.   happen that the text color of SIM, which normally is green, turns red.
  994.   This means that the SIM code has been partially changed. SIM calculates
  995.   a checksum over its main code segment and looks if it is the same each time.
  996.   If not, it changes the color to red.
  997.  
  998.   When the color is red you must be rather carefull. SIM seems to run well but
  999.   it may crash when you execute a certain command or do something else. If
  1000.   you can, load a new copy and don't keep using the destroyed one.  
  1001.  
  1002.   A yellow text color means that one or more of the traps set has been
  1003.   overwritten.
  1004.  
  1005.  
  1006.  
  1007. 3.15    Printer Support
  1008. =======================
  1009.  
  1010.  
  1011.   SIM allows you to send all output on the monitor to the printer. Therefore
  1012.   it simply sends the text as ASCII codes to the parallel port. This should
  1013.   allow you to use practically any parallel printer. If you want to send ESC
  1014.   codes (to select NLQ, reset etc.) you can do this by entering CTRL-[ and
  1015.   the rest of the ESC code as a command and press return. Remember to use
  1016.   the printer specific codes and not the AMIGA specific ones.
  1017.  
  1018.   Printer support does not work quite right with laser printers and certain
  1019.   other non-matrix printers which need a FF before printing or which
  1020.   demand both LF and CR.
  1021.  
  1022.  
  1023.  
  1024. 3.16    Memory Managing
  1025. =======================
  1026.  
  1027.  
  1028.   SIM now disposes of the memory manager that was missing in v1.51. It does
  1029.   this:
  1030.  
  1031.       - It fades in the backup of the display at the location of the display.
  1032.         If there is no backup it zeroes the display.   
  1033.  
  1034.       - At VBR+$68 and VBR+$6c it inserts the level 2 and level 3 vectors.
  1035.  
  1036.       - It handles five pages of memory that can be read and written to.
  1037.         Other areas are zeroed.
  1038.  
  1039.   The memory manager is currently not supported by all functions. Only the
  1040.   'm', 'a', 'd', 'p' and 'l' commands (and the corresponding debugger window
  1041.   output forms), 'c', 't', 'o', 'P', 'H', 'L', 'S', 'e', 'n' and 'q' commands
  1042.   use it, the rest still doesn't.
  1043.  
  1044.  
  1045.  
  1046. 3.17    Screen Blanker
  1047. ======================
  1048.  
  1049.  
  1050.   When you do not press any key during 10 minutes and SIM is not doing any
  1051.   operation, it automatically darkens the monitor.
  1052.  
  1053.  
  1054.  
  1055. 3.18    Effective Address Calculation
  1056. =====================================
  1057.  
  1058.  
  1059.   SIM can now calculate effective addresses. The source EA of the command at
  1060.   the PC is displayed below A6 of the registerlist, the destination EA below
  1061.   A7. Further use of this new capability has not yet been made, but it sure
  1062.   leaves a wide field of powerfull features to be made.
  1063.  
  1064.  
  1065.  
  1066. 3.19    Symbols
  1067. ===============
  1068.  
  1069.  
  1070.   SIM now supports a symbol list generated by an external program. The symbols
  1071.   can't be edited yet or new ones added. Symbols are used in the calculator
  1072.   and the disassembler.
  1073.  
  1074.  
  1075.  
  1076. 3.20    PAL/NTSC
  1077. ================
  1078.  
  1079.   When SIM is invoked on any PAL/NTSC machine for the first time, it adapts
  1080.   its display to the machine type. If ECS (or AGA) chipset is available,
  1081.   you are allowed to toggle between PAL/NTSC. NTSC users also can use an
  1082.   NTSC overscan display with 28 lines.
  1083.  
  1084.  
  1085.  
  1086.  
  1087. *******************************************************************************
  1088.  4. Communication between YOU and SIM
  1089. *******************************************************************************
  1090.  
  1091.  
  1092.  
  1093. 4.1     The SIM Environement
  1094. ============================
  1095.  
  1096.  
  1097.   As quoted in the chapter about the display, SIM provides its own. It is
  1098.   basically used for all output SIM produces (leave alone the printer and
  1099.   disk).
  1100.  
  1101.   You have a display of 200/224/256*640 pixels or 25/28/32 lines and 80 rows.
  1102.   The screens colors are green and dark blue but may be set by you to any
  1103.   colors you like. The screen is devided in header, worktable/debugger window
  1104.   and footer, all seperated by a line of '­'.
  1105.  
  1106.   The header normally contains the title and copyrights but serves also as
  1107.   statusline when accessing disk and keyboard cleanup.
  1108.  
  1109.   The worktable and the debugger window share 28 lines.
  1110.    - In the worktable, actually the monitor, you can move the cursor around
  1111.      and enter commands and get output.
  1112.    - The debugger window shows you one or two views of the memory in different
  1113.      forms at different addresses, read more about that feature in the
  1114.      appropriate chapter.
  1115.  
  1116.   The footer contains the cause of SIM's entry, a status and result field
  1117.   and the addresses of SIM itself, the display- and backupaddresses.
  1118.  
  1119.  
  1120.  
  1121. 4.2     The Monitor
  1122. ===================
  1123.  
  1124.  
  1125.   On the worktable, several basic features are provided:
  1126.  
  1127.    - What you see on the monitor (the text) is stored in SIM, when you leave
  1128.      and enter again, the display will be the same.
  1129.  
  1130.    - SIM has two entier keymaps for not qualified,
  1131.      shifted, alternated and shifted+alternated keys, one USA and one custom.
  1132.      In the original version, the custom one is Swiss.
  1133.  
  1134.    - Ctrl+chars with ascii values from $40-$60 will cause a char from
  1135.      $0-$20 (i.e. 'J' (=$4a) => <CR> (=$a))
  1136.  
  1137.    - Ctrl+chars with ascii values from $60-$80 will cause a char from
  1138.      $80-$a0
  1139.  
  1140.    - The cursor can be moved around one char by pressing the cursor keys.
  1141.  
  1142.    - The cursor can be moved to the extreme positions by pressing
  1143.      <SHIFT>+cursor keys (i.e. <SHIFT>+cursor right => cursor in row 79)
  1144.  
  1145.    - <DEL> will delete the char above the cursor and shift all chars right
  1146.      of the cursor one row left, inserting a space at row 79
  1147.  
  1148.    - <BACKSPACE> will clear the char left of the cursor and shift all chars
  1149.      above and right of the cursor one row left.
  1150.  
  1151.    - <SHIFT>+<DEL> will insert a space at the cursor position and shift all
  1152.      chars above and right of the cursor one row right.
  1153.  
  1154.    - <SHIFT>+<BACKSPACE> will clear the char above the cursor move the
  1155.      cursor one row left
  1156.  
  1157.    - <ALT>+<DEL> will clear the monitor part and put the cursor in the left
  1158.      upper corner next to a point.
  1159.  
  1160.    - <ALT>+<BACKSPACE> will clear the line in which the cursor is, put a '.' in
  1161.      row 1 and the cursor in row 2.
  1162.  
  1163.    - <HELP> prints the first helppage, starting in the line below the line the
  1164.      cursor is in actually.
  1165.  
  1166.    - <SHIFT+HELP> prints the second helppage.
  1167.  
  1168.    - <F1-F10>: you can freely define the ten function keys.
  1169.  
  1170.    - <SHIFT>+<ESC> copies the last executed command in the line of the
  1171.      cursor.
  1172.  
  1173.    - <ALT>+<ESC> copies the line of the cursor in the command
  1174.      buffer. It can then be inserted anywhere by <SHIFT>+<ESC>.
  1175.  
  1176.    - <CR> will execute the commands in the actual line (the one in which
  1177.      the cursor is).
  1178.  
  1179.    - <ALT+CURSOR UP> goes one step back in command history and fill the actual
  1180.      line with the actuall command in history.
  1181.  
  1182.    - <ALT+CURSOR DOWN> goes one step forth in command history.
  1183.  
  1184.  
  1185.    You can execute commands by entering them in one line and pressing
  1186.    return. When all commands are executed, SIM looks if a point '.' is in
  1187.    row 0 of the actual line. If so, the cursor is set left of it and the
  1188.    line is not cleared. If no point is found there, SIM puts one there
  1189.    and clears the rest of the line. That way, the point signals wheather or
  1190.    not a line is a previous command line. That enables to use again the
  1191.    commands that  have been entered earlier and are still visible on the
  1192.    screen.
  1193.  
  1194.  
  1195. 4.3     The Commands and their Syntax
  1196. =====================================
  1197.  
  1198.   The command line contains the different commands to be executed.
  1199.   It has this form:
  1200.  
  1201.               .<command> <options> (: <command> <options> ...)
  1202.  
  1203.   You can enter several commands in one line, seperated by a
  1204.   doubble point. The doubble point is needed, except if the next char
  1205.   is the same as of the last executed command (i.e. 'mmmm' is allowed
  1206.   and shows $200 bytes at once, starting at the actual address).
  1207.  
  1208.   While working in SIM, you can get a little overview of them in the two
  1209.   helppages:
  1210.  
  1211.    n (s)(i) :assemble    | t [s][e][t] :transfer mem | A (s) :set viewstart
  1212.    e (s)(d) :edit mem    | o [s][e][d] :occupy mem   | w (x) :CPU traps
  1213.    d (s)(e) :disassemble | c (s)(e)(t) :compare mem  | v (x) :create trap
  1214.    a (s)(e) :show ascii  | f (sejd)(m) :find data    | h (n) :history
  1215.    m (s)(e) :show hex    | f (sej'i'i) :find disasm  | g [s] :go sub
  1216.    l (s)(e) :show copper | s (p)(b)(c) :set SIM-adrs | i (n) :leave out
  1217.    p (s)(e) :show text   | F (n)(c){@} :edit F-keys  | u     :next step
  1218.    k (s)(e) :matchbuffer | z (n*n?cb)  :trace steps  | r (rs):edit regs
  1219.    P (s)(m) :show plane  | b (s)(*n?b) :breakpoints  | q/Q   :quit prog
  1220.    ? (expr) :calculate   | T (expr){@} :set linkterm | x/X   :exit and go
  1221.  
  1222.   and
  1223.  
  1224.    >f(n)    :format disk | <s [s][b](n) :read secs
  1225.    D (n)    :set drive   | >s [s][b](n) :write secs
  1226.    D?(n)    :find head   | <t [s][t](n) :read tracks
  1227.    B [s]    :bootchksum  | >t [s][t](n) :write tracks
  1228.    K [s]    :blockchksum | L  [fs](n)(s):load file
  1229.    V (path) :directory   | S  [f][s][e] :save file
  1230.    R [s]    :set range   | H  [s][e](p) :hear memory
  1231.  
  1232.   In the helppage and the explanations, the following shortenings are used for
  1233.   options:
  1234.  
  1235.    s: (start)address/seek     e: endaddress         t: targetaddress/track
  1236.    i: assembler instructions  d: dataline           c: a text or SIM commands
  1237.    n: decimal number          x: hexadecimal number m: mask/modulo
  1238.    r: register                p: plane              b: backup/breakmode/block
  1239.    ?: condition term          f: file               j: jokers
  1240.  
  1241.   Options in '[]' are neccessary.
  1242.   Options in '()' are optional.
  1243.   Chars in '{}' serve as sign or flag.
  1244.  
  1245.   Because space in SIM is limited, these helppages tell only the basic
  1246.   syntax of a command. Here comes a short but detailed list of all commands
  1247.   and what they do:
  1248.  
  1249.  
  1250.  Dump Commands
  1251.  -------------
  1252.  
  1253.     m (s)(e) : print memory as hexdump
  1254.     a (s)(e) : print memory as asciidump
  1255.     d (s)(e) : disassemble memory
  1256.     l (s)(e) : interprete memory as copperlist
  1257.     p (s)(e) : print memory as text
  1258.  
  1259.    Dump commands have all the same options, only the output changes:
  1260.  
  1261.      command (startaddress) (endaddress)
  1262.  
  1263.    If you give both addresses, SIM starts to dump from the startaddress and
  1264.    stops when the endaddress is reached or passed over.
  1265.  
  1266.    If you give only the startaddress, SIM starts to dump from that address
  1267.    and calculates an endaddress. That endaddress will be:
  1268.  
  1269.     for 'm': start+128
  1270.     for 'a': start+512
  1271.     for 'd': start+32
  1272.     for 'l': start+32
  1273.     for 'p': start+eight lines
  1274.  
  1275.    If you do not give any address, SIM takes the actual address as
  1276.    startaddress.
  1277.  
  1278.    Do not try to dump the customregisters area.
  1279.  
  1280.    In the disassembly, the instructions BSR,JSR and TRAP #x are indented
  1281.    and after the instructions JMP, BRA, ILLEGAL, RTS, RTE, RTR and RESET a
  1282.    line of '-' is printed for seperation. Additionally, breakpoints are
  1283.    marked by an asterix.
  1284.  
  1285.  
  1286.    EXAMPLES:
  1287.  
  1288.     m 0 100
  1289.     a 100
  1290.     d
  1291.     l 51236 !+60
  1292.     p $25364
  1293.  
  1294.  
  1295.  Edit Commands
  1296.  -------------
  1297.  
  1298.     e (s)(d) : edit memory
  1299.     n (s)(n) : assemle
  1300.  
  1301.    You can modify the memory with these two commands. They both ignore the
  1302.    memory manager and write diectly to memory.
  1303.  
  1304.    The edit command can write data at a location in the memory (see chapter
  1305.    'line forms' for details)
  1306.  
  1307.    The assemle command can assemble one or more instructions seperated by a
  1308.    ',' at a location in memory (see chapter 'Assembler and Calculator' for
  1309.    info)
  1310.  
  1311.    If you give both startaddress and data/instructions, SIM simply edits
  1312.    the memory.
  1313.  
  1314.    If you only give the startaddress, SIM will start to assemble or edit in
  1315.    a continuous mode where it always prepares the next line for further data
  1316.    or instructions. To stop this simply give no instruction or data. The
  1317.    system is as clever as it recognices if in the line it prepares for a new
  1318.    data or assemble line, there is already a data or assemble line that was
  1319.    prepared for continuous mode. If that is so, it only updates the address
  1320.    but does not clear the line. That enables you to i.e. correct a program
  1321.    assembled in continuous mode and to insert instructions.
  1322.  
  1323.    If you do not give any option, SIM starts to edit/assemble in continuous
  1324.    mode at the actual address.
  1325.  
  1326.  
  1327.    EXAMPLES:
  1328.  
  1329.     e 70000
  1330.     e>00070000: 0121
  1331.     n 100 nop
  1332.  
  1333.  
  1334.  Transfer and Occupy
  1335.  -------------------
  1336.  
  1337.    t (s)(e)(t) : Transfer memory
  1338.    o (s)(e)(d) : Occupy memory
  1339.  
  1340.    Transfer:
  1341.  
  1342.    This command simply copies a part of the memory to another location smartly.
  1343.    This means that SIM uses as- or descending mode for copying, not to destroy
  1344.    the memory:
  1345.  
  1346.    - t [s][e][t] : Transfers memory from s to e at new address t
  1347.  
  1348.  
  1349.    Occpuy:
  1350.  
  1351.    Occupy is generaly used to clear the memory or to fill it with repeated data:
  1352.  
  1353.    - o [s][e][d] : Occupy memory from s to e with data d
  1354.  
  1355.  
  1356.    EXAMPLES:
  1357.  
  1358.    t 0 10000 c00000
  1359.    o 12564 !+60 nnop
  1360.  
  1361.  
  1362.  Find and Compare
  1363.  ----------------
  1364.  
  1365.    f (s)(e)(j)(d)(m) - find data
  1366.    f (s)(e)(j) i (i) - find disassembly
  1367.    c (s)(e)(t)(j)    - compare memory
  1368.    k {@}(s)(e)       - show/set matchbuffer
  1369.  
  1370.    SIM disposes of a sophisticated find and compare system. For any of the
  1371.    three you can specify some jokers:
  1372.  
  1373.    - +/-n : Sets a step, only at every nth address is searched or compared.
  1374.  
  1375.    - '*'  : To say that all addresses where nothing was found or two bytes
  1376.             are the same are reported.
  1377.  
  1378.    - '@'  : When you do not want a list of addresses but to have them reported
  1379.             one by one, set this joker. SIM will then execute F9 each time
  1380.             something is reported and put the active view of the debugger
  1381.             window at that address.
  1382.  
  1383.    - '!'  : If you want to collect and filter addresses with the matchbuffer,
  1384.             set this flag. After the '!' you can enter an 'o' to say that old
  1385.             ones stay, a 'm' to say that same addresses stay, or a 'n' to say
  1386.             that new ones stay. Combinations are allowed. 
  1387.  
  1388.  
  1389.    Find data:
  1390.  
  1391.    You can search in a defined area in the memory for a certain bytecombination
  1392.    with this command. Depending of how many options you enter, the command does
  1393.    different things:
  1394.  
  1395.    - f [s][e](j)[d][m] : Starts to find from s to e with the jokers j for
  1396.      the bytes d that are masked by the mask m. Only the bits that are set in m
  1397.      are concidered when comparing. If the mask is shorter than the data, the
  1398.      rest of the mask will be set to $ff
  1399.  
  1400.    - f [s][e](j)[d] :Starts to search for data with all bits set in the mask.
  1401.  
  1402.    - f [s][e](j) : Starts to find for the same data with the same mask as last
  1403.      time in the area from s to e with new jokers j.
  1404.  
  1405.    - f [s][e] : Searches again in the area from s to e.
  1406.  
  1407.    - f [s] : Starts to search from s to the last e.
  1408.  
  1409.    - f : Continues to find after the last address reported.
  1410.  
  1411.  
  1412.    Find disassembly:
  1413.  
  1414.    You can find an instruction or a fragment of it in a defined are in the
  1415.    memory. Like find data, find disassembly does not need all options:
  1416.  
  1417.    - f [s][e](j) i [i] : Starts to find from s to e with jokers j for the
  1418.      instruction i.
  1419.  
  1420.    - f [s][e](j) : Starts to find for the same instruction in the area
  1421.      from s to e with new jokers j.
  1422.  
  1423.    - f [s][e] : Searches again in the area from s to e.
  1424.  
  1425.    - f [s] : Starts to search from s to the last e.
  1426.  
  1427.    - f : Continues to find after the last address reported.
  1428.  
  1429.    The instruction i can be only a fragment like '4(a6)' or an entier
  1430.    instruction like 'moveq #3,d0'. Several things must be made right:
  1431.  
  1432.    - When you have entered a space, SIM will concider what is before the
  1433.      space to be the mnemonic. Because the disassembler leaves an eight
  1434.      chars large field for the mnemonic where the rest is filled with
  1435.      spaces, SIM does tabulate your entries. 'clr.l d0' will internally
  1436.      made to 'clr.l   d0'.
  1437.  
  1438.    - The char '*' is used as joker. It says that this char is not compared.
  1439.      I.e. '(a*)' searches for all indirect accesses with any address register.
  1440.  
  1441.    - The char '_' is replaced by a space. I.e. '_d0' searches for
  1442.      all accesses on d0 as source ea.
  1443.  
  1444.    - The char '@' at the start or the end of your fragment limits the
  1445.      search on the start or end of the fragment. I.e. '@st' finds only
  1446.      'st.b d0' but not 'tst.l d3'.
  1447.  
  1448.  
  1449.    Compare:
  1450.  
  1451.    You can compare two areas in the memory. Different amount of options for
  1452.    different results:
  1453.  
  1454.    - c [s][e][t](j) : Compares area from s to e with area t to (t+(e-s)) with
  1455.      jokers j.
  1456.  
  1457.    - c [s][e][t] : Compares with no jokers.
  1458.  
  1459.    - c [s][t] : Continues to compare from s with t.
  1460.  
  1461.    - c [s] : Compares from s to last e with last t
  1462.  
  1463.    - c : Continues to compare after last address reported.
  1464.  
  1465.  
  1466.    Matchbuffer:
  1467.  
  1468.    You can read out or define the matchbuffer:
  1469.  
  1470.    - k [s][e] : Defines a new matchbuffer from s to e and clears it.
  1471.  
  1472.    - k * : Clears matchbuffer.
  1473.  
  1474.    - k ? : Shows you where the matchbuffer is.
  1475.  
  1476.    - k @ [s] : Shows all matchbuffer entries larger than s by reporting
  1477.      them one by one over F9.
  1478.  
  1479.    - k [s] : Lists all entries higher than s
  1480.  
  1481.    - k : Lists or shows next entrie(s)
  1482.  
  1483.  
  1484.    EXAMPLES:
  1485.  
  1486.     f 0 100 00
  1487.     f 10000 20000 !nm 05
  1488.     f 0 20000 @ imoveq #*,d*
  1489.     c 0 100 200 *
  1490.     k 100
  1491.     k@ 0
  1492.  
  1493.  
  1494.  Processor Commands
  1495.  ------------------
  1496.  
  1497.    r (r)(x) : set/view registers
  1498.    w (x)    : set/view traps
  1499.    v (x)    : create trap
  1500.  
  1501.    Registers:
  1502.  
  1503.    The 'r' command is used to either set a register d0-d7, a0-a7, ssp, usp, pc,
  1504.    sr, m0-m7 or to view them:
  1505.  
  1506.    - r [r][x] : Sets register r vith new value x
  1507.    - r        : Views registers
  1508.    - r?       : Views memories m0-m7
  1509.  
  1510.  
  1511.    Trapsetting:
  1512.  
  1513.    The 'w' command is used to either set or clear the ten basic CPU exception
  1514.    vectors or to view their status:
  1515.  
  1516.    - w [x] : Sets or clears Vector x
  1517.    - w     : Lists status of vectors
  1518.    - wk    : Clears all traps
  1519.  
  1520.    You can set or clear several vectors at a time by seperating the vector
  1521.    numbers by kommas. The vector numbers correspond to the exception numbers, 2
  1522.    for bus error upto $b for linef.
  1523.  
  1524.  
  1525.    Trapcreating:
  1526.  
  1527.    The 'v' command is used to simulate the occurence of an exception or to
  1528.    remove one from the stack:
  1529.  
  1530.    - v [x]  : Simulates exception x
  1531.    - v [-x] : Removes exception x from stack
  1532.    - v      : Simulates occurence of same exception that forced entry
  1533.    - v?     : Gives information about trap that forced entry
  1534.  
  1535.    SIM can simulate exceptions 2 upto $40. When you simulate an address or bus
  1536.    error, SIM takes either the ssw, ir and aa from the last bus or address
  1537.    error or zero for all when none happened yet.
  1538.  
  1539.    When you simulate an exception 2 upto $b, which is set by the 'w' command,
  1540.    SIM takes the old vector as new pc.
  1541.  
  1542.    When you simulate an interrupt, the sr will also contain the interrupt
  1543.    level.
  1544.  
  1545.    The 'v' command without options is used to put an exception back on the
  1546.    stack when i.e. you want the old vector to handle the problem. This works
  1547.    only if SIM was entered by one of the exceptions.
  1548.  
  1549.    You can only remove traps from the stack when you are in supervisor mode.
  1550.    The vector number is only used to know how much has to be taken from the
  1551.    stack (14 bytes when 2 or 3, 6 for the rest).
  1552.  
  1553.    The 'v?' command is used to know more about the exception, especially
  1554.    address and bus errors.
  1555.  
  1556.    In the 68020+ version, the 'v' command can only be called without options.
  1557.  
  1558.  
  1559.    EXAMPLES:
  1560.  
  1561.    r pc pc+20
  1562.    r m7 d0
  1563.    r?
  1564.    w 4,9
  1565.    wk
  1566.    v 3
  1567.    v -3
  1568.    v?
  1569.  
  1570.  
  1571.  Breakpoints and Trace
  1572.  ---------------------
  1573.  
  1574.    b (s)(j)  : set/clear breakpoints
  1575.    u         : nextstep
  1576.    z (j)     : tracestep
  1577.    i (n)     : leave out instructions
  1578.  
  1579.    Breakpoints:
  1580.  
  1581.    The 'b' command is used to handle breakpoints. Different options are
  1582.    available:
  1583.  
  1584.    - b [s][j] : Sets a breakpoint at address s with the options:
  1585.  
  1586.      - 'l' or 'r' or 'f' : button breakpoint
  1587.      - [n]               : counter breakpoint
  1588.      - '?' [n]           : condition breakpoint
  1589.      - '*'               : resident breakpoint
  1590.  
  1591.    - b [s] : Sets a simple breakpoint
  1592.  
  1593.    - b : Lists all breakpoints
  1594.  
  1595.    - bj [s] : Sets a JSR breakpoint at s
  1596.  
  1597.    - bs [s] : Sets a STACK breakpoint at s
  1598.  
  1599.    - bk : Kills all breakpoints
  1600.  
  1601.    You can seperate several breakpoints at a time by seperating the next
  1602.    address from the previous address or options by a komma.
  1603.  
  1604.  
  1605.    Trace:
  1606.  
  1607.    The 'z' command executes tracesteps. It either stops after one step or when
  1608.    a certain condition is fullfilled:
  1609.  
  1610.    - z [j] : Does trace until:
  1611.  
  1612.      - 'l' or 'r' or 'f' : trace until button pressed
  1613.      - [n]               : trace n steps
  1614.      - '?' [n]           : trace until n not zero
  1615.      - '*' [s]           : trace until pc=s
  1616.      - 'c'               : emulate 68020 trace
  1617.  
  1618.    - z : Does one tracestep
  1619.  
  1620.  
  1621.    Nextstep:
  1622.  
  1623.    The 'u' command does either one tracestep or when it is done at a JSR, BSR
  1624.    or TRAP #x, it does also a tracestep and sets a stack breakpoint at a7
  1625.    (or a7+2 when TRAP) and exits:
  1626.  
  1627.    - u : Do one nextstep
  1628.  
  1629.  
  1630.    Leave Out:
  1631.  
  1632.    This simply leaves instructions away:
  1633.  
  1634.    - i [n] : Leaves out n instructions
  1635.  
  1636.    - i : Leaves out one instruction
  1637.  
  1638.  
  1639.    EXAMPLES:
  1640.  
  1641.     b 100 *j100 ?[4]<>$c00276
  1642.     bj 100,200
  1643.     bssp
  1644.     z *pc
  1645.     z j
  1646.     n
  1647.     i 2
  1648.  
  1649.  
  1650.    Flow
  1651.    ----
  1652.  
  1653.    x     : Exit
  1654.    X     : Exit directly
  1655.    q     : Quit
  1656.    Q     : Quit directly
  1657.    g [s] : go to subroutine
  1658.    h (n) : history
  1659.  
  1660.    Exit:
  1661.  
  1662.    The 'x' or 'X' commands are used to simply continue the program at full
  1663.    speed. 'x' asks first if you are sure, 'X' simply exits:
  1664.  
  1665.    - x : Exits, but asks for confirmation first
  1666.  
  1667.    - X : Exits directly
  1668.  
  1669.  
  1670.    Quit:
  1671.  
  1672.    The 'q' or 'Q' commands are used to return control to the debug server.
  1673.    'q' asks first if you are sure, 'Q' simply returs directly:
  1674.  
  1675.    - q : Quits, but asks for confirmation first
  1676.  
  1677.    - Q : Quits directly
  1678.  
  1679.  
  1680.    Gosub:
  1681.  
  1682.    The 'g' command is used to execute a little program from SIM:
  1683.  
  1684.    - g [s]  : goes to subroutine at s
  1685.  
  1686.    - gw [s] : goes to subroutine at s but does not exit yet
  1687.  
  1688.    When SIM goes to subroutine, it first pushes the old pc on the stack and then
  1689.    the return address for the rts.
  1690.  
  1691.    The 'gw' command does only prepare the stack for the operation but does not
  1692.    exit yet. This is i.e. used to trace a subroutine.
  1693.  
  1694.  
  1695.    History:
  1696.  
  1697.    SIM remembers the last five sets of registers as they were when SIM was left
  1698.    for the last five times. The list is also updated after each step when doing
  1699.    conditioned trace:
  1700.  
  1701.    - h [n] : Print nth last history
  1702.  
  1703.    - h : Print all five histories
  1704.  
  1705.    SIM does not only remember the registers d0-a6, usp, ssp, sr and pc but
  1706.    also the instruction at the pc because of selfmodifying code.
  1707.  
  1708.  
  1709.    EXAMPLES:
  1710.  
  1711.    h 3
  1712.    X
  1713.    q
  1714.    g 100
  1715.    gw 200
  1716.  
  1717.  
  1718.    Diskoperations
  1719.    --------------
  1720.  
  1721.    D  (n)       : set drive
  1722.    <t (s)(s)(n) : read track
  1723.    >t (s)(s)(n) : write track
  1724.    <s (s)(s)(n) : read sector
  1725.    >s (s)(s)(n) : write sector
  1726.    >f (n)       : format disk
  1727.    B  (s)       : bootchecksum
  1728.    K  (s)       : blockchecksum
  1729.  
  1730.    Set Drive:
  1731.  
  1732.    The 'D' command is used to set the drive number that is used for further
  1733.    diskoperations (tracks, sectors or format, but not fot file operations!)
  1734.    or to ask for the actually used drive or to ask for the position of the
  1735.    head of a drive:
  1736.  
  1737.    - D [n] : Takes drive n (0-3) as actual drive
  1738.  
  1739.    - D : Shows actual drive
  1740.  
  1741.    - D? [n] : finds position of head of drive n
  1742.  
  1743.    - D? : finds position of head of actual drive
  1744.  
  1745.    The headposition is reported as logical track, the sideselect bit will be
  1746.    concidered when calculating the position. In most cases (DOS included)
  1747.    the sideselect bit will be set directly before DMA access and put to an
  1748.    undefined state afterwards. If that is so when you use this command, you
  1749.    must find the side that is used on your own, analyze the diskroutines.
  1750.  
  1751.  
  1752.    Read Track:
  1753.  
  1754.    The '<t' command simply reads entier logical tracks (0-159) somewhere into
  1755.    memory:
  1756.  
  1757.    - <t [s][t][n] : Reads n tracks starting with t to s
  1758.  
  1759.    - <t [s][t] : Reads one track t to s
  1760.  
  1761.    Well, SIM does not test where the data is read, you simply should not
  1762.    'overread' the display or SIM.
  1763.  
  1764.  
  1765.    Write Track:
  1766.  
  1767.    The '>t' command writes an area of the memory as logical tracks on disk:
  1768.  
  1769.    - >t [s][t][n] : Writes n tracks starting with t, data start at s
  1770.  
  1771.    - >t [s][t] : Writes one track t, data start at s
  1772.  
  1773.  
  1774.    Read Sector:
  1775.  
  1776.    With the '<s' command you can now read single sectors from disk to memory:
  1777.  
  1778.    - <s [s][b][n] : reads n sectors starting with b to s
  1779.  
  1780.    - <s [s][b] : reads one sector b to s
  1781.  
  1782.  
  1783.    Write Sector:
  1784.  
  1785.    With the '>s' command you can write single sectors from disk to memory:
  1786.  
  1787.    - <s [s][b][n] : writes n sectors starting with b, data start at s
  1788.  
  1789.    - <s [s][b] : writes one sector b, data start at s
  1790.  
  1791.    The sector writeroutine is clever enough. If you only write some
  1792.    sectors of a track, it reads the rest of them from disk to complete the
  1793.    track and writes the track afterwards.
  1794.  
  1795.  
  1796.    Format Disk:
  1797.  
  1798.    Because you can now save files, you may have to make a datadisk first.
  1799.    The '>f' command is used to format and initialize a disk:
  1800.  
  1801.    - >f [n] : Formats disk in drive n
  1802.  
  1803.    - >f : Formats disk in actual drive
  1804.  
  1805.    You can't yet enter a name for the disk, it will automatically be
  1806.    'DATA-DISK'. The creation date is zeroed too. But the DOS cannot seperate
  1807.    disks with the same name and same date. So never keep two datadisks
  1808.    in two drives simultaneously, your machine would crash if you do so.
  1809.  
  1810.    If you format a disk that was previously in a drive and you return to DOS,
  1811.    remove and reinsert that disk for the DOS must know the new name and new
  1812.    bitmap.
  1813.  
  1814.  
  1815.    Bootchecksum:
  1816.  
  1817.    When you want to save a bootblock on a disk, you may have to update the
  1818.    checksum with this command:
  1819.  
  1820.    - B [s] : Sets new checksum of bootblock that starts at s
  1821.  
  1822.  
  1823.    Blockchecksum:
  1824.  
  1825.    When you want to save an edited datablock on a disk, you may have to update
  1826.    the checksum with this command:
  1827.  
  1828.    - K [s] : Sets new checksum of block that starts at s
  1829.  
  1830.  
  1831.  
  1832.    EXAMPLES:
  1833.  
  1834.     <t c00000 0 80
  1835.     >t c00000 0 80
  1836.     >s 70000 0 2
  1837.     <s 60000 880
  1838.     D1
  1839.     D? 2
  1840.     >f 0
  1841.     B 60000
  1842.     K 70000
  1843.  
  1844.  
  1845.    Fileoperations
  1846.    --------------
  1847.  
  1848.    L [f][s](n)(s) : Load file
  1849.    S [f][s][e]    : Save file
  1850.    V (path)       : List directory
  1851.  
  1852.  
  1853.    Paths and filenames can either be given plainly or between ' or ".
  1854.    The only devices known are DF0:, DF1:, DF2: and DF3:, disknames
  1855.    are not supported.
  1856.  
  1857.  
  1858.    Load File:
  1859.  
  1860.    This command loads a file directly into memory:
  1861.  
  1862.    - L [f][s] : Loads file f to s
  1863.  
  1864.    - L [f][s](n) : Loads n bytes from file f to s
  1865.  
  1866.    - L [f][s](n)(s) : Loads n bytes from file f to s, s bytes from the
  1867.                       start of the file
  1868.  
  1869.    Just make sure that you don't load files over SIM or the display.
  1870.  
  1871.  
  1872.    Save file:
  1873.  
  1874.    With this command you can save an area of the memory as file:
  1875.  
  1876.    - S [f][s][e] : Saves memory from s to e as file f
  1877.  
  1878.    This command is also used to delete files. To do so simply save a file
  1879.    with the name of the file you want to delete and the same start- and
  1880.    endaddress (filelength=0).
  1881.  
  1882.  
  1883.    List Directory:
  1884.  
  1885.    This command is used to list the directory of a disk or a user directory.
  1886.  
  1887.    - V [path] : Lists directory of directory specified by path.
  1888.  
  1889.    - V : Lists directory of last drive used for fileoperations.
  1890.  
  1891.    SIM reads the directory page by page because the display is used as buffer.
  1892.    If a page is full or the directory is read, it displays it. If there stays
  1893.    stuff to be displayed, SIM writes 'more' in the footer. You can then continue
  1894.    by pressing <SPACE>.
  1895.  
  1896.  
  1897.    EXAMPLES:
  1898.  
  1899.     L 'df0:c/dir' 60000
  1900.     S df1:data 0 100
  1901.     V df0:c
  1902.  
  1903.  
  1904.    Miscellaneous
  1905.    -------------
  1906.  
  1907.    ? [n]{,}(n) : Calculate
  1908.    F (n)(c){@} : Define functionkeys
  1909.    P (s)(m)    : Start graphic searcher
  1910.    H [s][e](p) : Hear sound
  1911.    s (p)(b)(c) : Set display, backup and program addresses
  1912.    l*          : Show copperlist
  1913.    l? (s)(e)   : Find active copperlist
  1914.    l= [n]      : Find copperlist one or two
  1915.    R [s]       : Set range for access scan
  1916.  
  1917.  
  1918.    Calculator:
  1919.  
  1920.    If you need to calculate something, you can do it with the '?' command.
  1921.    SIM will calculate the result of one or several terms and return the
  1922.    result(s) as hexadecimal, signed hexadecimal, decimal and binary number
  1923.    and as ascii chars:
  1924.  
  1925.    - ? [n] : calculate result of n
  1926.  
  1927.    You can calculate the result of several terms at the same time by seperating
  1928.    the terms by a komma.
  1929.  
  1930.  
  1931.    Functionkeys:
  1932.  
  1933.    The 'F' command is used to set and view the functionkeys functions:
  1934.  
  1935.    - F [n][c] @ : Occupies Fkey n with commandline c that is executed directly
  1936.    - F [n][c]   : Occupies Fkey n with text c
  1937.    - F [n]      : Clears Fkey n
  1938.    - F          : Lists Fkeys
  1939.  
  1940.    When you set a functionkey, the entier rest of the commandline will be
  1941.    taken for the command or text.
  1942.  
  1943.    When you list the functionkeys, the ones that are locked by Amiga-Fx are
  1944.    marked by an asterix, the directly executable have an '@' at the end.
  1945.  
  1946.  
  1947.    Graphic Searcher:
  1948.  
  1949.    The 'P' command starts the graphic searcher:
  1950.  
  1951.    - P [s][m] : Starts at address s with modulo m
  1952.    - P [s]    : Starts at address s with last modulo
  1953.    - P        : Starts at last address with last modulo
  1954.  
  1955.    When you have activated the graphic searcher, several keys are used for
  1956.    display modifications:
  1957.  
  1958.    Cursor up:         Scrolls plane one line down
  1959.  
  1960.    Cursor down:       Scrolls plane one line up
  1961.  
  1962.    Cursor left:       Scrolls plane one line right
  1963.  
  1964.    Cursor right:      Scrolls plane one line left
  1965.  
  1966.    Shift+Cursor up:   Scrolls plane one screen down
  1967.  
  1968.    Shift+Cursor down: Scrolls plane one screen up
  1969.  
  1970.    Help:              Modulo=modulo+2
  1971.  
  1972.    Del:               Modulo=modulo-2
  1973.  
  1974.    Shift+Help:        Modulo=modulo+16
  1975.  
  1976.    Shift+Del:         Modulo=modulo-16
  1977.  
  1978.    Backspace:         Modulo=0
  1979.  
  1980.    Return:            Switches between hires and lores
  1981.  
  1982.    Control:           Ends graphic searcher
  1983.  
  1984.  
  1985.    Since the graphic searcher also supports the memory manager a further
  1986.    improvement has been made. It is now possible not only to look at the
  1987.    chipmem but at the entier space of addressable memory including fastmem
  1988.    and rom.
  1989.  
  1990.    Because of technical reasons the status bar is now located at the bottom.
  1991.    It has also become neccessary to limit the modulo. It can now range from
  1992.    $ffb2 to $3ffe for a hires and from $ffda to $3ffe for a lores plane.
  1993.  
  1994.  
  1995.    Hear Sound:
  1996.  
  1997.    The 'H' command makes you listen to parts of the memory.
  1998.  
  1999.    H [s][e](p) : Hear memory from s to e with period p
  2000.    H [s][e]    : Hear memory from s to e with last period
  2001.  
  2002.    Memory manager is supported.
  2003.  
  2004.  
  2005.    SIM Addresses:
  2006.  
  2007.    The 's' command is used to transfer the display and backup and the SIM
  2008.    code itself:
  2009.  
  2010.    s [p][b][c] : New display at p, new backup at b and SIM copied to c
  2011.    s [p][b]    : New display at p, new backup at b and SIM stays where it is
  2012.    s [p]       : New display at p, backup and program stay where they are
  2013.    s           : Repaints the display
  2014.  
  2015.    Be carefull when you transfer the SIM code. SIM does adjust breakpoint and
  2016.    traps to the new address. But a possible debug server will only know
  2017.    about the new location when you quit. The old copy of SIM will still work,
  2018.    but its breakpoint and trap system will be confused. The same problem
  2019.    occurs when the tasktraphandle is set to SIM. Use this command only when
  2020.    the system is dead. Also do not copy SIM below $70!
  2021.  
  2022.  
  2023.    Copperlist:
  2024.  
  2025.    The 'l' command is basically used to disassemble a copperlist. The
  2026.    following variations are used for different actions:
  2027.  
  2028.    - l*        : Shows the active copperlist
  2029.  
  2030.    - l? [s][e] : Starts to search for the copperlist from s to e
  2031.  
  2032.    - l? [s]    : Starts to search for the copperlist from s to $80000
  2033.  
  2034.    - l?        : Starts to search for the copperlist from $70 to $80000
  2035.  
  2036.    - l= [n]    : Starts to search quickly for copperlist 1 or 2
  2037.  
  2038.    To end copperlist display or searching, press <CTRL>.
  2039.  
  2040.    When you search quickly, the copperlist you are looking for will be
  2041.    activated. If this one is not the running one, search again for the other to
  2042.    set the other copperlist again. This kind of searching has the risk that you
  2043.    may search for a copperlist that does not exist.
  2044.  
  2045.    This function does not work properly on MC68020+ due to some timing
  2046.    problems. Calling it on any MC68020+ may not find a copperlist.
  2047.  
  2048.  
  2049.    Set range:
  2050.  
  2051.    The 'R' command is used to define the range in which the access scan
  2052.    shortcuts will search for accesses. Default is $10000.
  2053.  
  2054.    - R [s]     : Sets range to s
  2055.  
  2056.  
  2057.    EXAMPLES:
  2058.  
  2059.    ? 256*5,52*56
  2060.    F10 r:dpc pc@
  2061.    F
  2062.    P 12356 52
  2063.    s 70000 c50000 c40000
  2064.    l*
  2065.    l=1
  2066.    l? 20000
  2067.    R $80000
  2068.  
  2069.  
  2070.  Debugger Window Support
  2071.  -----------------------
  2072.  
  2073.   A [s]    : Set new startaddress
  2074.   T [s]{@} : Set linkterm
  2075.  
  2076.  
  2077.   These two commands are used to set new startaddresses for the views of
  2078.   the debugger window.
  2079.  
  2080.  
  2081.   Startaddress:
  2082.  
  2083.   With this command you can directly set the startaddress of the active view:
  2084.  
  2085.   - A [s] : Set new startaddress of view to s
  2086.  
  2087.  
  2088.   Linkterm:
  2089.  
  2090.   To set a linkterm for a view, you use the 'T' command. SIM will calculate
  2091.   the result of this formula and use it as new startaddress each time it is
  2092.   entered:
  2093.  
  2094.   - T [s] @ : Set smart linkterm for active view
  2095.  
  2096.   - T [s] : Set simple linkterm for active view
  2097.  
  2098.   When SIM calculates a simple linkterm, it takes the result as new
  2099.   startaddress. The result of a smart linkterm is only used as new startaddress
  2100.   if it is not in the frame of the view. Normally this is only used to link
  2101.   a view to the PC.
  2102.  
  2103.  
  2104.   EXAMPLES:
  2105.  
  2106.   A a0+56
  2107.   T a0+d0
  2108.   T pc @
  2109.  
  2110.  
  2111.  
  2112. 4.4     The Debugger Window
  2113. ===========================
  2114.  
  2115.  
  2116.   You can switch it on or off by pressing <esc>. When you do so, a part
  2117.   of the worktable is locked for the cursor and used to print out the
  2118.   registers and one or two different views of the memory in different
  2119.   forms (hex, ascii etc.). The window is updated as soon as you execute
  2120.   a command that may change the memory and at entry of SIM.
  2121.  
  2122.   The two views have two startaddresses that are stored in m0 and m1.
  2123.   m1 is unused when you did not splitt the window and use only one view.
  2124.  
  2125.   You can link the two views to two terms, the socalled 'linkterms'.
  2126.  
  2127.  
  2128.  
  2129.  4.5 Debugger Window Shortcuts
  2130.  =============================
  2131.  
  2132.  
  2133.   If you have to deal with the window, you do this by use of shortcuts that
  2134.   are qualified by either left or right Amiga. If you splitted the window,
  2135.   you can select the view that recieves the command by pressing <TAB>.
  2136.  
  2137.  
  2138.  Window Handling
  2139.  ---------------
  2140.  
  2141.   <cursor up>     Decreases the views startaddress and scrolls the
  2142.                   content one line down. How much the startaddress is decreased
  2143.                   depends on what the window output form is:
  2144.  
  2145.                    - disassembly: the length of the instruction above the
  2146.                      startaddress.
  2147.                    - hexdump:     16 bytes.
  2148.                    - asciidump:   64 bytes.
  2149.                    - copperdump:  4 bytes.
  2150.                    - text:        one line.
  2151.  
  2152.   <cursor down>   Increases the views startaddress and scrolls the
  2153.                   content one line up. How much the startaddress is decreased
  2154.                   depends on what the window output form is:
  2155.  
  2156.                    - disassembly: the length of the instruction at the
  2157.                      actual startaddress.
  2158.                    - hexdump:     16 bytes.
  2159.                    - asciidump:   64 bytes.
  2160.                    - copperdump:  4 bytes.
  2161.                    - text:        one line.
  2162.  
  2163.   <cursor left>  Decreases the views startaddress one or two bytes:
  2164.  
  2165.                    - disassembly: two bytes.
  2166.                    - hexdump:     one byte.
  2167.                    - asciidump:   one byte.
  2168.                    - copperdump:  two bytes.
  2169.                    - text:        one byte.
  2170.  
  2171.   <cursor right> Increases the views startaddress one or two bytes:
  2172.  
  2173.                    - disassembly: two bytes.
  2174.                    - hexdump:     one byte.
  2175.                    - asciidump:   one byte.
  2176.                    - copperdump:  two bytes.
  2177.                    - text:        one byte.
  2178.  
  2179.   <shift cu>     Decreases the views startaddress and moves back to last
  2180.                  page, depending on the output form:
  2181.  
  2182.                    - disassembly: the sum of instruction lengths of the number
  2183.                      of instructions fitting the window back from the actual
  2184.                      startaddress.
  2185.                    - hexdump:     <number of lines>*16 bytes.
  2186.                    - asciidump:   <number of lines>*64 bytes.
  2187.                    - copperdump:  <number of lines>*4 bytes.
  2188.                    - text:        one page.
  2189.  
  2190.   <shift cd>     Increases the views startaddress and moves to next
  2191.                  page, depending on the output form:
  2192.  
  2193.                    - disassembly: sets startaddress to the address of the
  2194.                      instruction following the last one visible.
  2195.                    - hexdump:     <number of lines>*16 bytes.
  2196.                    - asciidump:   <number of lines>*64 bytes.
  2197.                    - copperdump:  <number of lines>*4 bytes.
  2198.                    - text:        one page.
  2199.  
  2200.   <alt cu>       Decreases the size of the debugger window by one line.
  2201.                  The minimum size is one line. The space that becomes free
  2202.                  for the monitor is cleared with spaces.
  2203.  
  2204.   <alt cd>       Increases the size of the debugger window by one line.
  2205.                  The maximum size is as large as there stays one line for the
  2206.                  monitor. If the cursor was in the line now belonging to the
  2207.                  debugger window, it is moved to the line below which is then
  2208.                  initialized.
  2209.  
  2210.   <shift alt cu> Works only when you splitted the window. This moves the bar
  2211.                  seperating the two views one line up, which decreases the
  2212.                  upper view and increases the lower view one line.
  2213.  
  2214.   <shift alt cu> Works only when you splitted the window. This moves the bar
  2215.                  seperating the two views one line down, which increases the
  2216.                  upper view and decreases the lower view one line.
  2217.  
  2218.   <s>            Splitts or unsplitts the window into two views. When you
  2219.                  unsplitt, the startaddress and linkterm of the active view
  2220.                  are taken as the one of the now single view, the ones of the
  2221.                  inactive view are stored and taken as the ones for the second
  2222.                  view when you splitt again.
  2223.  
  2224.   <r>            This recalculates the linkterm(s) and sets the
  2225.                  views startaddresses again.
  2226.  
  2227.  
  2228.   Output Form Selection
  2229.   ---------------------
  2230.  
  2231.   <a>            Selects asciidump for the active view.
  2232.  
  2233.   <m>            Selects hexdump for the active view.
  2234.  
  2235.   <l>            Selects copperdump for the active view.
  2236.  
  2237.   <m>            Selects disassembly for the active view.
  2238.  
  2239.   <p>            Selects text for the active view.
  2240.  
  2241.   <D>            Dis-/enables symbols in general.
  2242.  
  2243.   <S>            Allows symbols also for $xxxx(An) either only at the PC
  2244.                  or always.
  2245.  
  2246.  
  2247.   Breakpoints
  2248.   -----------
  2249.  
  2250.   <b>            Sets a simple Illegal breakpoint at the startaddress of
  2251.                  the active view.
  2252.  
  2253.   <v>            Sets a resident Illegal breakpoint at the startaddress of
  2254.                  the active view.
  2255.  
  2256.   <B>            Sets a JSR-breakpoint at the startaddress of the active view.
  2257.  
  2258.  
  2259.   Flow
  2260.   ----
  2261.  
  2262.   <z>            Does a tracestep.
  2263.  
  2264.   <u>            Does a nextstep that does not follow into subroutines.
  2265.  
  2266.   <i>            Leaves out one instruction/puts pc to next instruction.
  2267.  
  2268.   <x>            Exits SIM.
  2269.  
  2270.   <q>            Exits SIM and goes back to debug server.
  2271.  
  2272.   <g>            Leaves a subroutine. Therefore SIM puts a STACK-breakpoint at
  2273.                  the actual stackpointer and exits. Do not use this when the
  2274.                  subroutine has already put more data on the stack. This
  2275.                  corresponds to the command 'bssp:X'.
  2276.  
  2277.   <G>            Performs an RTS. Basically does 'rpc[sp]:rspsp+4'.
  2278.  
  2279.   <j>            Sets the pc to the startaddress of the active view.
  2280.  
  2281.  
  2282.   Edit
  2283.   ----
  2284.  
  2285.   <e>            Starts to edit in loopmode at the startaddress of the
  2286.                  active view.
  2287.  
  2288.   <n>            Starts to assemble in loopmode at the startaddress of the
  2289.                  active view.
  2290.  
  2291.   <N>            Replaces the Instruction at the startaddress of the active
  2292.                  view by NOPs.
  2293.  
  2294.  
  2295.   Indirects
  2296.   ---------
  2297.  
  2298.   <[>            Goes to next higher indirectlevel and takes the longword
  2299.                  at the startaddress of the active view as the new
  2300.                  startaddress and stores the old one.
  2301.  
  2302.   <]>            Goes to last indirectlevel and takes the stored
  2303.                  startaddress as the new one.
  2304.  
  2305.   <{>            Same as <[> but the longword will be taken as BCPL and
  2306.                  multiplied by four.
  2307.  
  2308.   <}>            Goes to next higher indirectlevel and takes the stored
  2309.                  address of that one as the new startaddress.
  2310.  
  2311.   <alt shift right>    If the instruction at the PC is a branch
  2312.                  of any kind, An indirection to the address of the branch
  2313.                  is done.
  2314.  
  2315.   <alt right>    If the instruction at the start of the view is a branch
  2316.                  of any kind, An indirection to the address of the branch
  2317.                  is done.
  2318.  
  2319.   <alt left>     Exdirects too.
  2320.  
  2321.   <shift alt left> Exdirects too.
  2322.  
  2323.  
  2324.   Find
  2325.   ----
  2326.  
  2327.   <f>            Continues to search at the startaddress of the active
  2328.                  view.
  2329.  
  2330.   <c>            Continues to compare. The source address will be the
  2331.                  startaddress of the first view , the destination address
  2332.                  the  startaddress of the second view.
  2333.  
  2334.   <>>            Initiates scan for accesses on start address of current
  2335.                  view. The range can be set with the 'R' command, default
  2336.                  is $10000. SIM will search both upwards and downwards for
  2337.                  accesses, the range specifies the maximum distance to test.
  2338.  
  2339.   <<>            Continues scan.
  2340.  
  2341.  
  2342.   Miscellaneous
  2343.   -------------
  2344.  
  2345.   <P>            Toggles the printer on/off. The printer can only be
  2346.                  activated if there is an active one connected to the parallel
  2347.                  port.
  2348.  
  2349.   <H>            Makes a hardcopy of the actual display by printing it as
  2350.                  text. You do not have to activate the printer first.
  2351.  
  2352.   <k>            Toggles between US keymap and custom keymap (originally CH)
  2353.  
  2354.   <!>            Flushes keystatefield, see chapter 'the keyboard'.
  2355.  
  2356.   <?>            Toggles keyboardbuffer killer, see chapter 'the keyboard'
  2357.  
  2358.   <+>            Toggles fully printable charset. When switched on (full), the
  2359.                  chars $0-$1f and $80-$9f are not replaced by a point in
  2360.                  asciidump, hexdump etc. Switch it off (semi) when using the
  2361.                  printer because else these chars would trouble it.
  2362.  
  2363.   <\>            Toggles Auto-Unmodify Traps. When this feature is switched
  2364.                  on, all modified traps are set again when you leave SIM.
  2365.  
  2366.   <F1-F10>       Toggles availability of funktionkeys.
  2367.  
  2368.   <0-9>          Takes one of the ten position memories as the startaddress
  2369.                  of the active view.
  2370.  
  2371.   <shift 0-9>    Works only with the keypad! Stores the startaddress of the
  2372.                  active view in one of the ten position memories.
  2373.  
  2374.   <M>            Toggles the MMU on or off (68020+ only).
  2375.  
  2376.   <L>            Switches between PAL, NTSC and NTSC overscan if ECS is
  2377.                  available. If not, NTSC users can switch between NTSC
  2378.                  and NTSC overscan only.
  2379.  
  2380.   <R>            Toggles register display mode: Either display MSP or
  2381.                  SR flags (68020+ only).
  2382.  
  2383.  
  2384.   Most of these shortcuts are only functioning when the debugger window is
  2385.   activated. Only <h>,<p>,<!>,<?>,<F1-F10>,<k>,<z>,<u>,<i>,<q>, <L>, <S>,
  2386.   <D>, <\>, <+>, <M>, <R> and <x> are always functioning.
  2387.  
  2388.  
  2389.  
  2390.  
  2391. *******************************************************************************
  2392.         5.      Additional Information
  2393. *******************************************************************************
  2394.  
  2395.  
  2396. 5.1     Assembler Usage
  2397. =======================
  2398.  
  2399.  
  2400.   SIM contains a full 68000 assembler which allows you to make changes to
  2401.   programs while debugging. It supports the standard optimisations and
  2402.   aliases used by most other assemblers:
  2403.  
  2404.  
  2405.         - ADDI and ADDA can be replaced by ADD. ADDX can also be replaced
  2406.           by ADD if the effective addresses are address register indirect
  2407.           with predecrement.
  2408.  
  2409.         - SUBI and SUBA can be replaced by SUB. SUBX can also be replaced
  2410.           by SUB if the effective addresses are address register indirect
  2411.           with predecrement.
  2412.  
  2413.         - CMP can be used instead of CMPA, CMPI and CMPM.
  2414.  
  2415.         - EOR, OR and AND can be used instead of EORI, ORI and ANDI.
  2416.  
  2417.         - Bcc and DBcc instructions and PC-relative effective addresses
  2418.           use absolute addresses. It is possible to specify the offset
  2419.           directly by puting a '+' or '-' sign in front (but note that
  2420.           the offset is counted from start of instruction plus 2):
  2421.  
  2422.                 00060010:       bra     $60000
  2423.             or  00060010:       bra     -$12
  2424.  
  2425.         - If no size is given, Bcc will be optimised to short if possible.
  2426.  
  2427.         - If no size given, memory direct effective addresses are optimised
  2428.           to WORD if possible.
  2429.  
  2430.         - If no size given for an instruction, the default size is used
  2431.           which in most cases is WORD.
  2432.  
  2433.         - The interpreter is very tollerant concerning spaces, a line like
  2434.  
  2435.                 move.l    (  $75 ) (   PC  , D7.l  )  , ( $4 ).w
  2436.  
  2437.           will be accepted and assembled correctly.
  2438.  
  2439.  
  2440.  
  2441. 5.2     Calculator Usage
  2442. ========================
  2443.  
  2444.  
  2445.   The calculator is one of the central functions of SIM, all numeric input
  2446.   is handled by it. It disposes of several very useful operations and value
  2447.   forms. The following operators are supported, sorted after priority:
  2448.  
  2449.  
  2450.         ()      Brackets: Correspond to normal brackets. Number of opening
  2451.                 and closing brackets must be the same. Maximum nesting
  2452.                 is 127.
  2453.  
  2454.         []      Memory indirection: The result of the term in these brackets
  2455.                 an address and the content of the memory at that address will
  2456.                 be read.
  2457.  
  2458.                 A size directly after the closing bracket will define if
  2459.                 the value will be read as a BYTE, WORD or LONG and extended
  2460.                 to LONG. I.e.: [4].l reads out AbsExecBase, [$dff002].w reads
  2461.                 out the actual DMACON as a WORD.
  2462.  
  2463.         -       Prefix change: Changes a positive value to a negative and vice
  2464.                 versa. I.e.: -5 is -5, -0 is 0, --6 is 6.
  2465.  
  2466.         ~       Logical NOT: Inverts all 32 bits of the value. I.e.: ~5 is -6.
  2467.  
  2468.         .s      Sizing: Any value will be extended to LONG from the size
  2469.                 specified. I.e.: $89.b is $ffffff89.
  2470.  
  2471.                 The size of the result is used both for the assembler when
  2472.                 using memory direct effective addresses and for data input
  2473.                 for the memory edit command etc. If multiple sizing operations
  2474.                 occure, the last sizing operation in the lowest bracket level
  2475.                 defines the finial size of the result.
  2476.  
  2477.         *,/     Multiply and divide: Signed LONG multiplication and division.
  2478.                 I.e.: -$56*5 is fffffe52, 9/-3 is -3.
  2479.  
  2480.         \       Modulo: Signed LONG modulo. I.e.: 11\4 is 3.
  2481.  
  2482.         +,-     Addition and subtraction: LONG addition and subtraction.
  2483.                 I.e.:   1000-9 is 991.
  2484.  
  2485.         <<      Shift left: Correspond to a multiplication with 2 to the nth
  2486.                 power, whereas n is the numer of bits to be shifted.
  2487.                 I.e.: $20<<8 is $2000.
  2488.  
  2489.         >>      Shift right: Corresponds to a division by 2 to the nth power,
  2490.                 whereas n is the numer of bits to be shifted.
  2491.                 I.e.: $2000>>8 is $20.
  2492.  
  2493.         &       Logical AND: LONG AND operation. I.e.: $1234&$ff00 is $1200.
  2494.  
  2495.         !       Logical EOR: LONG EOR operation. I.e.: $c1!$54 is $a5.
  2496.  
  2497.         |       Logical OR: LONG OR operation. I.e.: $1200|$34 is $1234.
  2498.  
  2499.         <>      Not equal: Result of this operation is -1 if values not equal,
  2500.                 else 0. I.e.: 5<>6 is -1, 3<>3 is 0.
  2501.  
  2502.         =       Equal:  Result of this operation is -1 if values are equal,
  2503.                 else 0. I.e.: 5=6 is 0, 3=3 is -1.
  2504.  
  2505.         <=,=<   Lower or same: Signed comparison, result is -1 if value left
  2506.                 of operator is lower or the same than the right value.
  2507.                 I.e.: 1<=1 is -1, 6<=5 is 0.
  2508.  
  2509.         =>,>=   Greater or equal: Signed comparison, result is -1 if value left
  2510.                 of operator is greater or equal than the right value.
  2511.                 I.e.: 2=>1 is -1, 0=>5 is 0.
  2512.  
  2513.         <       Less: Signed comparison, result is -1 if value left
  2514.                 of operator is less than the right value.
  2515.                 I.e.: 1<1 is 0, 0<5 is -1.
  2516.  
  2517.         >       Greater: Signed comparison, result is -1 if value left
  2518.                 of operator is greater than the right value.
  2519.                 I.e.: 2>1 is -1, 0>5 is 0.
  2520.  
  2521.  
  2522.   As for the form of values, the following are supported:
  2523.  
  2524.  
  2525.         $x      Hexadecimal number: A number in hexadecimal form, consisting
  2526.                 of max. 8 digits 0-9 and a-f. I.e.: $badcode1
  2527.  
  2528.         #x      Decimal number: A number in decimal form, consisting of
  2529.                 digits 0-9. I.e.: #1992.
  2530.  
  2531.         %x      Binary number: A number in binary form, consisting of
  2532.                 max. 32 digits 0 and 1. I.e.: %1010001011.
  2533.  
  2534.         ',"     ASCII chars: A number consisting of max. 4 ASCII chars.
  2535.                 The string must be introduced and ended with the same
  2536.                 sign. If a ' must appear in a string introduced with
  2537.                 ', two ' following each other mark one '. The same is valid
  2538.                 for the ". I.e.: "SIM!", 'DATA', 'it''s','''' , '"MC"'.
  2539.  
  2540.         !       Last result: Stands for the result of the last term
  2541.                 calculated. I.e.: To display 16 bytes at $50000 one can
  2542.                 enter the command 'm $50000 !+$10'.
  2543.  
  2544.         @       Actual address. Stands for the actual address used by dump
  2545.                 commands and edit/assembly commands. I.e.: @-100.
  2546.  
  2547.         SIM     SIM start: The program and base address of SIM.
  2548.  
  2549.         D0-D7 ,A0-A7 ,PC ,SP ,SSP ,USP ,SR ,CCR and M0-M7
  2550.         (MSP/ISP instead of SSP for 68020+)
  2551.  
  2552.                 CPU registers: The calculator can directly use the content
  2553.                 of these registers. SSP is the supervisor stack pointer,
  2554.                 USP the userstack pointer SP and A7 the actual stack pointer.
  2555.                 MSP and ISP are iaster and interrupt stack pointers.
  2556.                 M0-M7 are variables, M0 and M1 are used as view start
  2557.                 registers. I.e.: pc+10-d0.
  2558.  
  2559.         SEA, TEA, SX, TX
  2560.  
  2561.                 The effective address of the source and destination EA of
  2562.                 the instruction at the PC. The SX and TX registers are 1
  2563.                 if the instruction has an source/destination EA, otherwise
  2564.                 0 and the corresponding EA register is undefined. You shall
  2565.                 not use any of these registers in a condition expression
  2566.                 for trace or breakpoints. I.e.: sea*sx
  2567.  
  2568.         x,\x    Symbols: Uses the symbol specified after the '\'. I.e. \start.
  2569.  
  2570.  
  2571.  
  2572.   A calculator term normally ends at a space, a doubble point, a semikolon,
  2573.   a komma or a carriage return. If you have opened a bracket, you can have
  2574.   spaces between operators and values, but ONLY then. Otherwise, the end of
  2575.   the term will not be there where you wanted.
  2576.  
  2577.   The calculator can work in decimal or hexadecimal mode. In decimal mode you
  2578.   do not have to write the '#' before a decimal number, but for hexadecimal
  2579.   numbers, the '$' is neccessary. In hexadecimal mode you do not have to write
  2580.   the '$' before a hexadecimal number, but for decimal numbers, the '#' is
  2581.   neccessary.
  2582.  
  2583.   Hexadecimal mode is usually used to get addresses and hexadecimal numbers.
  2584.   For the other cases decimal mode is used, also for the assembler.
  2585.  
  2586.  
  2587.  
  2588. 5.3     Data Line
  2589. =================
  2590.  
  2591.  
  2592.   The data line is used to specify data for different commands like
  2593.   find, edit, occupy. The dataline consists of four elements:
  2594.  
  2595.         -       Hexadecimaly numbers are introduced with or without '$'.
  2596.                 They can be as long as neccessary. The number is ended by a
  2597.                 char that is no digit. If you enter an odd number of digits,
  2598.                 the last digit will be taken as byte, its higher nibble
  2599.                 zeroed. Spaces are allowed between digits.
  2600.  
  2601.         -       Assembler instructions are initiated by a 'n', then the
  2602.                 instruction follows.
  2603.  
  2604.         -       Calculator terms are initiated by a '?', then the term
  2605.                 follows. The size of the result will be considered
  2606.                 (LONG=4 bytes,WORD=2 bytes and BYTE=1 byte).
  2607.  
  2608.         -       Ascii chars are either initiated by ' or " and closed with
  2609.                 the same or a <CR>.
  2610.  
  2611.  
  2612.   An example, using all the elements from above. The line:
  2613.  
  2614.         45,"ABC",njmp $60000,?[$fc0000].w,6666
  2615.  
  2616.   is interpreted as:
  2617.  
  2618.         45  41 42 43  4e f9 00 06 00 00  11 11        66 66
  2619.         |-  |-------  |----------------  |----        |----
  2620.         |   |         |                  |            |
  2621.         45  "ABC"     jmp $60000         [$fc0000].w  6666
  2622.  
  2623.  
  2624.    A dataline ends at a space or an illegal char. Between the komma that
  2625.    seperates two datatypes and the next datatype there can be spaces. also
  2626.    between digits (only for the edit command, not find and occupy).
  2627.  
  2628.  
  2629.  
  2630. 5.4     The Debug Server Entrance
  2631. =================================
  2632.  
  2633.  
  2634.   The debug server entrance is specially concieved for the cooperation
  2635.   between SIM and another debugger or loader, i.e. SIM-BUG. It enables
  2636.   the debug server to give control over a program to SIM and SIM to return
  2637.   control to the debug server.
  2638.  
  2639.   In a part of the SIM base, there is space to store the registers d0-a6,
  2640.   USP and SSP (ISP/MSP), SR and PC of the program that is monitored. The
  2641.   debug server can fill in this table. Additionally, It can specify a
  2642.   reentry PC, SR, USP and SSP (ISP/MSP). When it enters SIM by the debug
  2643.   server entrance, SIM takes the registers out of the table and copies them
  2644.   into the workregister buffer. SIM has now the control over the program.
  2645.  
  2646.   If you want to give control back to the debug server, i.e. to unload the
  2647.   program, you can use the 'q' command (or 'Q' or AMIGA-q). SIM does then
  2648.   copy the workregisters back into the base area and takes the reentry PC, SR
  2649.   USP and SSP (ISP/MSP) as the actual ones. To be sure that the debug server
  2650.   is still there, SIM looks at the address <reentrypc-4> if the longword
  2651.   $4f4b4159 ("OKAY") is there. If the longword is there, it exits. That way,
  2652.   it returns to the address specified by the reentry PC with reentry stacks
  2653.   and a reentry SR. The registers do not contain sencefull information, appart
  2654.   a6 which contains the base/codeaddress of SIM. In case you transfered SIM,
  2655.   the debug server knows where you put it.
  2656.  
  2657.   The debug server can now read out the table with the registers and use
  2658.   them for itself.
  2659.  
  2660.  
  2661.  
  2662. 5.5     The SIM Base
  2663. ====================
  2664.  
  2665.  
  2666.   At the start of the SIM program, the different entrances are located,
  2667.   the backups and reentry values and the debug server datastructure. The
  2668.   structure of this base is documented here. The offsets described won't
  2669.   be changed in higher versions, I hope, but I feel free to extend it at
  2670.   the upper end.
  2671.  
  2672.   You may cut this list out and print it in order to have it ready when
  2673.   you need to edit a value in the base.
  2674.  
  2675.  
  2676. -------------------------------------------------------------------------------
  2677.  The S.I.M. Base Structure
  2678. -------------------------------------------------------------------------------
  2679.  
  2680. ;--- Base ---------
  2681.  
  2682.  struct toolbase       ;+0  The startadress of S.I.M. in memory
  2683.  
  2684.  
  2685. ;--- Display ------
  2686.  
  2687.  aptr  plane           ;+0  The startaddress of the $5000 bytes display ram
  2688.                             (must be chipmem!)
  2689.  aptr  backup          ;+4  The startaddress of the backup of the display.
  2690.                             When not zero, S.I.M. will copy what is in the
  2691.                             memory of the future display to this part of memory
  2692.                             when entered and copy it back when left.
  2693.  
  2694.  
  2695. ;--- Entrances ----
  2696.  
  2697.  jmp   entrance1       ;+8  Entrance for JSR. Here you can simply enter S.I.M.
  2698.                             by a 'JSR' to this address.
  2699.  jmp   entrance2       ;+12 Entrance for Exec's traphandle. When you want to
  2700.                             use S.I.M. as traphandler of your task, write this
  2701.                             address to <taskstruct+50>.
  2702.  jmp   entrance3       ;+16 Debug server entrance.
  2703.  
  2704.  long  0               ;+20 *** RESERVED FOR EXPANSION ***
  2705.  
  2706.  
  2707. ;--- Our Traps ----    ;When a trap is set directly, its vector is set to
  2708.                         the corresponding entrance in here.
  2709.  
  2710.  jmp   entrance22      ;+24 Bus error
  2711.  jmp   entrance23      ;+28 Address error
  2712.  jmp   entrance24      ;+32 Illegal instruction
  2713.  jmp   entrance25      ;+36 Divide-by-zero
  2714.  jmp   entrance26      ;+40 CHK instruction
  2715.  jmp   entrance27      ;+44 TRAPV instruction
  2716.  jmp   entrance28      ;+48 Privilege violation
  2717.  jmp   entrance29      ;+52 Trace
  2718.  jmp   entrance2a      ;+56 Op Code 1010
  2719.  jmp   entrance2b      ;+60 Op Code 1111
  2720.  
  2721.  
  2722. ;--- Signal -------
  2723.  
  2724.  long  "SIM!"          ;+64 This Long signals that this is S.I.M.
  2725.  long  version         ;+68 Version of S.I.M. as 4 ASCII chars
  2726.  
  2727.  
  2728. ;--- Backups ------    ;when S.I.M. is entered it backups some customregisters
  2729.                         and vectors here.
  2730.  
  2731.  word  dmacon          ;+72 $DFF096/002
  2732.  word  intena          ;+74 $DFF09A/01C
  2733.  word  intreq          ;+76 $DFF09C/01E
  2734.  long  level2          ;+78 $68
  2735.  long  level3          ;+82 $6C
  2736.  
  2737.  byte  ciaacra         ;+86 $BFEE01
  2738.  byte  ciaacrb         ;+87 $BFEF01
  2739.  byte  ciabcra         ;+88 $BFDE00
  2740.  byte  ciabcrb         ;+89 $BFDF00
  2741.  byte  ciaapra         ;+90 $BFE001
  2742.  byte  ciaaprb         ;+91 $BFE101
  2743.  byte  ciaaddra        ;+92 $BFE201
  2744.  byte  ciaaddrb        ;+93 $BFE301
  2745.  byte  ciabddra        ;+94 $BFD200
  2746.  byte  ciaasp          ;+95 $BFEC01
  2747.  long  vpos            ;+96 $DFF004
  2748.  
  2749. ;--- Reentry ------    ;Reentry values of things that can't be saved.
  2750.                         When S.I.M. is left, it inits the registers named
  2751.                         with the values in this list.
  2752.  
  2753.  word  $2981           ;+100 DIWSTRT
  2754.  word  $29c1           ;+102 DIWSTOP
  2755.  word  $0038           ;+104 DDFSTRT
  2756.  word  $00d0           ;+106 DDFSTOP
  2757.  word  $5200           ;+108 BPLCON0
  2758.  word  $0000           ;+110 BPLCON1
  2759.  word  $0000           ;+112 BPLMOD1
  2760.  word  $0000           ;+114 COLOR00
  2761.  word  $0000           ;+116 COLOR01
  2762.  
  2763. ;--- ICR Special --    ;The ICR data and mask.
  2764.  
  2765.  byte  lasticr         ;+118 $BFED00 read
  2766.  byte  reentryicrmask  ;+119 $BFED00 write
  2767.  
  2768. ;--- Distances ----    ;Distances to internal structures.
  2769.  
  2770.  long  disasscalc-base ;+120 Distance to disasscalc module
  2771.  long  preferences-base;+124 Distance to preference structure
  2772.  
  2773. ;--- Debug --------    ;Debug server structure for entrance 3.
  2774.  
  2775.  long  0               ;+128 Offset from base to end of inited part
  2776.  long  "????"          ;+132 Sign of server
  2777.  
  2778. ;--- Program ------    ;The registers of the program that is debugged.
  2779.  
  2780.  long  0               ;+136 Register d0
  2781.  long  0               ;+140 Register d1
  2782.  long  0               ;+144 Register d2
  2783.  long  0               ;+148 Register d3
  2784.  long  0               ;+152 Register d4
  2785.  long  0               ;+156 Register d5
  2786.  long  0               ;+160 Register d6
  2787.  long  0               ;+164 Register d7
  2788.  long  0               ;+168 Register a0
  2789.  long  0               ;+172 Register a1
  2790.  long  0               ;+176 Register a2
  2791.  long  0               ;+180 Register a3
  2792.  long  0               ;+184 Register a4
  2793.  long  0               ;+188 Register a5
  2794.  long  0               ;+192 Register a6
  2795.  long  0               ;+196 User stack pointer
  2796.  long  0               ;+200 Supervisor stack pointer/ISP
  2797.  long  0               ;+204 PC of program
  2798.  word  0               ;+208 SR of program
  2799.  
  2800. ;--- Server data --
  2801.  
  2802.  long  0               ;+210 Reentry routine of server
  2803.  long  0               ;+214 Reentry usp of server
  2804.  long  0               ;+218 Reentry ssp of server/ISP
  2805.  long  0               ;+222 Reentry sr of server
  2806.  
  2807. ;--- Extension ----
  2808.  
  2809.  aptr  0               ;+224 Pointer to zero ended list of aptrs that point
  2810.                              to zero ended texts. The texts in this list are
  2811.                              printed and the pointer is cleared
  2812.  aptr  0               ;+228 Pointer to task structure, currently unused
  2813.  aptr  0               ;+232 Segmentlist, currently unused
  2814.  aptr  0               ;+236 Symbollist with labels, currently unused
  2815.  
  2816.  long  0               ;+240 MSP (68020+ only)
  2817.  long  0               ;+244 Reentry MSP (68020+ only)
  2818.  
  2819.  long  0,0,0,0         ; RESERVED
  2820.  
  2821.  long  sim_size        ;+256 Size of SIM
  2822.  byte  0               ;+260 CPU information
  2823.  byte  0               ;+261 MMU information
  2824.  word  0               ;+262 BEAMCON0 reentry value
  2825.  long  0               ;+264 VBR
  2826.  
  2827. ;--- End ----------    ;+240 This is the end of the actual structure
  2828.  
  2829. --------------------------------------------------------------------------------
  2830.  
  2831.  
  2832.  
  2833. 5.6     Errors
  2834. ==============
  2835.  
  2836.  
  2837.  SIM is a flexible tool. Therefore the user can do many mistakes.
  2838.  In this chapter, all errors are explained. When an error occurs that
  2839.  bases on an error in the command line (which in fact is in most cases so)
  2840.  SIM prints the error text in the line of the cursor and copies the command
  2841.  line in the next line. The cursor is in the line of the copied command line
  2842.  below the char or the word that probably caused the error.
  2843.  
  2844.  
  2845.  Assembler errors:
  2846.  
  2847.    illegal instruction:
  2848.      The assembler does not know this instruction.
  2849.  
  2850.    illegal value:
  2851.      An number is higher or less than it should be.
  2852.  
  2853.    illegal ea:
  2854.      This 'effective address' is not allowed. In fact it has not always
  2855.      to be an effective address for the assembler uses the same routine for
  2856.      all source- and destinationterms.
  2857.  
  2858.    illegal size:
  2859.      An instruction has either no size at all or does not support the
  2860.      one you have given.
  2861.  
  2862.    illegal operator:
  2863.      An operator is not just as it should be.
  2864.  
  2865.    line malformed:
  2866.      Something is undefinably wrong.
  2867.  
  2868.    too few info:
  2869.      Some part of this instruction is missing.
  2870.  
  2871.    illegal sea:
  2872.      An illegal effective address as source.
  2873.  
  2874.    illegal tea:
  2875.      An illegal effective address as destination.
  2876.  
  2877.    illegal char:
  2878.      The assembler is suprised to find that char.
  2879.  
  2880.    illegal condition:
  2881.      The condition of a Bcc, DBcc or Scc is inexistent.
  2882.  
  2883.    illegal direction:
  2884.      The direction for bitshifting is neither left nor right.
  2885.  
  2886.  
  2887.  Calculator errors:
  2888.  
  2889.    bracketerror:
  2890.      You have opened more brackets than you closed or vice versa.
  2891.  
  2892.    overflow:
  2893.      The result is larger than $ffffffff or ±$8000000, or you
  2894.      have divided by zero or you do more than 30 operations.
  2895.  
  2896.    illegal value:
  2897.      The calculator cannot interprete that as a number.
  2898.  
  2899.    illegal operator:
  2900.      This is no operator for mathematical operations supported by the
  2901.      calculator.
  2902.  
  2903.    no value given:
  2904.      You have forgotten to give a term, or the very first value of an
  2905.      expected term is of an unknown type.
  2906.  
  2907.  
  2908.  SIM errors:
  2909.  
  2910.    too much:
  2911.      The startaddres given for a command is higher than the endaddress.
  2912.  
  2913.    breakpointerror:
  2914.      SIM has no more breakpoints free or it could not set a breakpoint there,
  2915.      either because ROM is read only or it is not possible to put breakpoints
  2916.      in the memory presently occupied by the SIM code.
  2917.  
  2918.  
  2919.  Diskaccess errors:
  2920.  
  2921.   disk error:
  2922.     Something went wrong with the diskaccess, either the track that is read
  2923.     is damaged or the disk was writeprotected. In most cases you will get a
  2924.     warning in the statusline of the diskaccess display.
  2925.  
  2926.   file not found:
  2927.     SIM could not locate the file you want to load or a directory in its path.
  2928.  
  2929.   not enough space:
  2930.     When you want to save a file, SIM first checks if the file would fit.
  2931.     If it wouldn't, this error is returned.
  2932.  
  2933.   disk full:
  2934.     That error should not occure.
  2935.  
  2936.   directory error:
  2937.     If something goes wrong in the line of the listing of the directory,
  2938.     i.e. bad hashes or disk damaged, this error is returned.
  2939.  
  2940.   illegal path:
  2941.     SIM cannot locate the directory you want to list.
  2942.  
  2943.  
  2944.  
  2945. 5.7     Footer Messages
  2946. =======================
  2947.  
  2948.  
  2949.   As mentioned earlier, there is a status field in the footer line. This
  2950.   space is used to transmit messages to the user that are not as important as
  2951.   to be printed in the monitor or serve as additional information.
  2952.   Currently the following texts can appear there:
  2953.  
  2954.  
  2955.    - busy        : As soon as SIM is doing something this text is printed.
  2956.                    This shows you If SIM is working or not.
  2957.  
  2958.    - break       : When you break the execution of a command SIM replys with
  2959.                    this message.
  2960.  
  2961.    - pause       : When you pause.
  2962.  
  2963.    - lock        : When you press SHIFT-CTRL to stop all output for some time.
  2964.  
  2965.    - Fx on/off   : When you toggle function keys SIM returns the new state
  2966.                    to you this way.
  2967.  
  2968.    - flushed     : When you flush the keystatefield.
  2969.  
  2970.    - prt err     : When the printer has troubble (paper out/select...)
  2971.  
  2972.    - cnd err     : When an error occurs while calculating the condition terms
  2973.                    of breakpoints or trace, SIM is entered and this text
  2974.                    appears
  2975.  
  2976.    - prt on/off  : When you toggle the printer and it is available.
  2977.  
  2978.    - AUT on/off  : When you toggle Auto Unmodify Traps
  2979.  
  2980.    - US kmap     : When you select the secondary (US) keymap
  2981.  
  2982.    - xx kmap     : When you select the primary (custom) keymap
  2983.  
  2984.    - indir x     : When you use indirects the current indirect level
  2985.                    is told you so.
  2986.  
  2987.    - return      : When you return from the keyboard restoring routine
  2988.                    by entering 'return'.
  2989.  
  2990.    - KBF on/off  : When you toggle the Keyboard Buffer Killer.
  2991.  
  2992.    - more        : When the directory of a disk does not fit in the monitor
  2993.                    part SIM writes that message to tell you that there is more.
  2994.  
  2995.    - MMU on/off  : The status of the MMU tree (68020+ version only).
  2996.  
  2997.  
  2998.  
  2999.  
  3000. *******************************************************************************
  3001.         6.      Appendix
  3002. *******************************************************************************
  3003.  
  3004.  
  3005.  
  3006. 6.1     Acknowledgements
  3007. ========================
  3008.  
  3009.  
  3010.   Big thanks must go to all the people who helped me in this project and
  3011.   many others:
  3012.  
  3013.  
  3014.         Daniel Weber for continuous testing of all new features I
  3015.         inserted, some good and some bad ideas and his mighty ProAsm.
  3016.         Not to forget, for all the cool movies each saturday too.
  3017.  
  3018.         René Eberhard for more tips, betatesting, exchange of KS 2.0
  3019.         knowhow and loads of fun at MicroSpot and Feller and everywhere
  3020.         else.
  3021.  
  3022.         Bryan Ford for many good ideas, betatesting, tons of hints,
  3023.         proofreading my documentations and all the cool e-mail chat
  3024.         and much more.
  3025.  
  3026.         André Dietisheim, Oliver Ferlin, Stefan Strasser, Kay Temirel,
  3027.         Christian Schneider and Niel Ericson for bugreports and ideas.
  3028.  
  3029.         Michael Hitch for MC68040 testing.
  3030.  
  3031.         To all the registered users.
  3032.  
  3033.  
  3034.  
  3035. 6.2     Registered Users
  3036. ========================
  3037.  
  3038.  
  3039.   Thanks go to the following users who registered and persuaded me that some
  3040.   people use this tool:
  3041.  
  3042.  
  3043.         Daniel Weber            (Switzerland)
  3044.         René Eberhard           (Switzerland)
  3045.         Kay Temirel             (Germany)
  3046.         Niel Ericson            (Canada)
  3047.         Roby Leemann            (Switzerland)
  3048.         Steve Anderson          (Canada)
  3049.         Jörn Körner             (Germany)
  3050.         Bryan Ford              (USA)
  3051.         Dan Babcock             (USA)
  3052.         Gerd Hesina             (Austria)
  3053.         Jandl Mario             (Austria)
  3054.  
  3055.  
  3056.  
  3057. 6.3     My Address
  3058. ==================
  3059.  
  3060.  
  3061.   If you want to register, if you have bugreports, question, ideas or
  3062.   complaints (constructive criticism is always welcome), or if you just want
  3063.   to contact me, write or send a letter to:
  3064.  
  3065.         Stefan Walter
  3066.         Finsterruetistr. 57
  3067.         8135 Langnau a./A.
  3068.         SWITZERLAND
  3069.  
  3070.   Because snail mail is slow, you can also contact me by phone or by sending
  3071.   a message to the electronic mail address below (if you call by phone,
  3072.   please concider any possible time differences and don't wake me up in the
  3073.   night :).
  3074.  
  3075.         Phone:          Switzerland/(0)1/713-01-46
  3076.         Internet:       avalon.physik.unizh.ch!swalter
  3077.  
  3078.  
  3079.  
  3080.  
  3081. -------------------------------------------------------------------------------
  3082.                                                      Stefan Walter, 15.Nov.1992
  3083.  
  3084.