home *** CD-ROM | disk | FTP | other *** search
/ Amiga ISO Collection / AmigaUtilCD2.iso / Misc / SXI-TK-D.LHA / tk / TK_DOCUMENTATION.TXT < prev    next >
Encoding:
Text File  |  1996-12-14  |  110.4 KB  |  3,315 lines

  1. Title: Thrill Kill - The documentation
  2.  
  3.  
  4. -----------------------------------------------------------------------------
  5. Thrill Kill - Documentation
  6. -----------------------------------------------------------------------------
  7.  
  8.    o Disclaimer
  9.    o Read first/Introduction
  10.    o Requirements
  11.    o General usage
  12.    o The preferences
  13.    o The editor
  14.    o Command description - alphabetically
  15.    o Command description - sorted by groups
  16.    o Argument description
  17.    o How to make a NMI-button
  18.    o Registration/Demo limits/How to order
  19.    o Yet known bugs
  20.    o History
  21.    o Contact
  22.    o Future
  23.  
  24. -----------------------------------------------------------------------------
  25.  
  26. Disclaimer
  27. -----------------------------------------------------------------------------
  28.  
  29. THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE
  30. LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDER AND/OR
  31. OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND,
  32. EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  33. WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
  34. ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.
  35. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY
  36. SERVICING, REPAIR OR CORRECTION.
  37.  
  38. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL
  39. ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY REDISTRIBUTE THE PROGRAM AS
  40. PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL,
  41. SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR
  42. INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR
  43. DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR
  44. A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH
  45. HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
  46.  
  47. -----------------------------------------------------------------------------
  48. Thrill Kill - Read first/Introduction
  49. -----------------------------------------------------------------------------
  50.  
  51. If you do not know what a debugger, freezer is or if you have never
  52. programmed in assembler - forget it - i do not think that TK is something for
  53. you -(except if you just want to train some games..)
  54.  
  55. You probaly know the famous action replay. It was cool! However it was slow,
  56. partly bugged and missed major commands. When aga came out there was no toy
  57. for those machines. No real update came out - the software version of the
  58. action replay was buggy like... . TK is a freezer like the action replay, a
  59. lot commands have the same syntax. If you were used to ar then you will find
  60. usage very easy. TK supports a maximum of freezer possibility, if you take
  61. the time to check out all available functions/settings. This means you have
  62. to have major knowledge of your amiga-hardware. If you do not have it then i
  63. doubt that you can use the real power of this toy! Of course, TK can not
  64. offer such kind of invisibility like the ar as it does not need a 'special'
  65. hardware (beside a NMI-button). If you enjoy the demo version, think its
  66. useful and do not want to register do not wait for a cracked version. Every
  67. registrated version of TK has its own personal id. Any misuse of a registered
  68. version will be punished (!!!).
  69.  
  70. Just a last note! TK patches nearly the whole system! It can not be
  71. compatible with any hardware configuration available (eg gfxcards..). I give
  72. no warranty for any damage caused by TK! You use it on your own risk!
  73.  
  74. BTW: The html-documentation is best viewed with NETSCAPE3.0, else read the
  75. text version!
  76.  
  77. Enough said...check out the demo..
  78.  
  79. -----------------------------------------------------------------------------
  80.  
  81. Thrill Kill - Requirements
  82. -----------------------------------------------------------------------------
  83.  
  84. TK was designed to run on a system with a mmu, but it also works on non-mmu
  85. system. I use tk on a A4000 with 68030/25/68882 (with mmu) and 2 meg chip and
  86. 8 meg fast memory. I personally think it works very stable. However even some
  87. A4000 have strange behaviour when acessing non existing memory. (eg Goldmans'
  88. machine: accessing memory higher $0fffffff will cause not a bus-error (set to
  89. dsack) but it kicks around with the custom-regs - they are defintly lost.) As
  90. you are a talented user you can change the settings to suit for your
  91. configuration (eg disable the memory detection for the $1dc00000++ memory)
  92. and load them before TK is initialized!
  93.  
  94. TK was tested on:
  95.  
  96.    o A4000/30.25.mmu/68882/2mb-chip/8mb-fast at $7800000++
  97.    o A4000/30.25.mmu/2mb-chip/16mb-fast at $7000000++
  98.    o A1200/30.50.mmu/2mb-chip/8mb-fast at $1dc00000++ (blizzard3, however
  99.      Icarus reported trouble with the blizzard2..i will check this )
  100.    o A1200/30.50.mmu/2mb-chip/4mb-fast at $200000++ (mtec)
  101.    o A500/00.7.nommu/1mb-chip/1.5mb-'fast' at $c00000
  102.    o A4000/40.25.mmu/2mb-chip/8mb-fast at $7800000++ (thanx to apollo for
  103.      lending me his card, i hope it stills runs on 040 as i patched a lot of
  104.      stuff since then)
  105.  
  106. I can not promise that TK will run immediatly on your system. However if you
  107. have problems contact me, i will try to fix any incompatibility! So if the
  108. demo-version runs on your computer then the registered version will also work
  109. fine.
  110.  
  111. Before i forget it you need kickstart 3.0++ to use all functions (especially
  112. the ones to privatize memory). It works also fine with kick 2.04 (some
  113. functions will not work), but i do not think it will run suitable on
  114. kickstarts less 2.04! TK does not like programms that use the mmu (like vmm
  115. programms) TK does not support gfx-cards!
  116.  
  117. I hope it will also run on a 68060...not checked yet (also i think it should
  118. if it works on 68040..)
  119.  
  120. -----------------------------------------------------------------------------
  121. Thrill Kill - General usage
  122. -----------------------------------------------------------------------------
  123.  
  124. Here is a list of some (maybe) interesting topics:
  125.  
  126.    o Breakpoints(=brp) can be manipulated by BBSBDBDA. Breakpoints can
  127.      be marked with illegal or trap codes (see preferences). Whenever you
  128.      enter TK all breakpoints are removed, when you leave TK they are set
  129.      again. Do not forget that the breakpoints run via the +$10/$80..$bc
  130.      vectors.
  131.    o MemoryAccessRanges(=mar) can be used to get out which command did a
  132.      read/write access to the selected memory. The programm will be trace
  133.      step-by-step and the commands will be analyzed.It will return to TK
  134.      before the specified memory is accessed. MARs are very slow and will not
  135.      catch interrups. (If you want to catch interrupts than eg set a
  136.      breakpoint to the first command of the interrupt code..) Check
  137.      MAV,MAS,MAD,MADA.
  138.    o MemoryWatchPoints(=mwp) can be used to get out which command modified
  139.      the selected memory. The programm will be traced step-by-step to
  140.      determinate all manipulations. It will return to TK after the specified
  141.      memory has benn modfied. (so check the previous command) MWPs are slow
  142.      and will not catch interrupt routines. (If you want to catch interrupts
  143.      than eg set a breakpoint to the first command of the interrupt code..)
  144.      Check MVMSMDMDA.
  145.    o The VBR-Faker installs a own vbr who simulates the origional. This will
  146.      allow you to enter programms who manipulate the vectors at $0 and do not
  147.      change the vbr. If the programm should change the vbr, loacte the
  148.      command, set a breakpoint and adjust the vbr manually, skip the command
  149.      and leave - all should be fine. (In AR4,HRTMON this is default, but not
  150.      in TK!) Do this also if the programm move the vbr anywhere else. (see
  151.      ;4mpreferences)
  152.    o MMU-Catchlists can be changed by MMUVMMUSMMUSWMMUDMMUDA and
  153.      check the preferences. The function allows you a quick and reliable way
  154.      to get out all commands which access a certain memory range. This slows
  155.      the system just a bit down. Interrupt code is also checked. Make sure
  156.      that the +$8 (bus-error) vector is not destroyed by the programm. The
  157.      functions are only available in to professional version and require a
  158.      MMU!
  159.    o The ByteValueTrainer(=bvt) allows to search single byte values. The
  160.      trainer is started with the TS command. Whenever the watched value
  161.      changes run the Tcommand.(also if you think this would eliminate some
  162.      address) This will eleminate all invalid address and scan yet not
  163.      checked address. You must increase the size of the trainer-buffer if you
  164.      would like to scan the whole memory in one pass. Check TSTTXTV,
  165.      TB,TBDTBV. Each stored address needs about 2 bytes.
  166.    o The DeepTrainer(=dt) allows you to search staying/changing byte values.
  167.      The trainer is started with the TDS command. Whenever the watched value
  168.      changes run the TDC command to eliminate all address which have not
  169.      changed. Use the TDS command to elimnate all address which have changed.
  170.      After TDS/TDS the yet unchecked memory is checked. Each stored address
  171.      needs about 3 bytes. This trainer mode needs a lot of memory. In general
  172.      its advised to use an external trainer buffer (TBTBVTBD) Check also
  173.      ;4mTDS, TDCTDXTDV
  174.    o The usage of a external TrainerBuffer is recommended whenever you want
  175.      to scan a memory range in a few passes, especially for the deep-trainer.
  176.      Its not unusual to have buffers with a size of 4MB or more..
  177.    o Privatizing is a preference option which allows you to remove memory
  178.      from the system. This memory can be used for trainer-buffer, to freeze
  179.      the programm or for other purpose. Check also INFO.
  180.    o MMU-CustomBackup is a option which simulates a mirror ram for
  181.      $dff000-$dff200. By this way we do not need an external hardware which
  182.      does exactly this. The only disadvantage is that the system is slowed
  183.      down and the +$8(bus-error) vector is used.
  184.    o Labels are just a little short-cut for often used address, etc. They can
  185.      be easily in any expression. Check LABDLAB ,DLABA.
  186.    o FileSystemManagement is supported for DD/HD-disks and also
  187.      IDE-harddisk-partitions. Only DOS\0, DOS\1, DOS\2, DOS\3 are supported.
  188.      However also DOS\4, DOS\5 can be read. Soft-/Hardlinks are not
  189.      supported. Check CDDIRDELETEMAKEDIRTYPELMSM.
  190.    o The programm 'TK.REV' allows you to load TK to the end of the available
  191.      memory. This needs kickstart 3.0++. The effect is that TK will not lay
  192.      somewhere in the middle of a memory page (especiilly if you privatize
  193.      memory). Make sure 'TK.EXE' is in the same path.
  194.    o 'TK.EXE' will not do dynamic allocation of memory. This means you can
  195.      relocate the code eg to $7f00000 and load its binary image to this
  196.      address.
  197.  
  198. -----------------------------------------------------------------------------
  199. Thrill Kill - The preferences
  200.  
  201. -----------------------------------------------------------------------------
  202.  
  203. The preferences can be loaded and saved by the LE and SE commands
  204. In the TK-surface you have to press <F3> to enter the preference menu
  205. If you launch TK from shell and use as argument '-<your-prefs-file-any-path>'
  206. the selected prefs will be loaded before TK is started. This allows you to
  207. disable/enable functions which may cause conflicts.
  208. In the prefs-menu you can manipulate the following commands:
  209.  
  210.    o Freezer preferences:
  211.  
  212.       o Custom-backup:
  213.          o Minimum: Only custom-register that are destroyed by TK are
  214.            backuped and restored. This will work with games like soccer-kid.
  215.            (check out the copper faker)
  216.          o Maximum: Most custom-register are backuped and restored, including
  217.            register that are not destroyed by TK. This is necessary for
  218.            saving a complete programm. If you do not have a mmu/hadrware you
  219.            must adjust the register manually by the E command. If you want to
  220.            save a freezed programm the option should be enabled. Make sure
  221.            that you have enabled mmu-custom-backup or something equal.
  222.       o CIA-backup:
  223.          o Fast: The CIA-register are backuped in a fast way (eg the disksync
  224.            interrupt bit in the ICR will not be backuped)
  225.          o Most: This will try to backup most register. However, not all
  226.            register can be backuped without an immense time consumption (like
  227.            the ALARM regs). You can manully manipulate the CIA-register with
  228.            the W command.
  229.       o DrivesOn:
  230.          o Selected: When you enter TK and some disk-drives where on, only
  231.            drives selected in PRB/CIA-B will be enabled again.
  232.          o All: All drives will be turned on. (but not selected)
  233.       o Brp-Entrance:
  234.          o Illegal: Sets the breakpoint-code to illegal (dc.w $4afc) and
  235.            vector +$10. This may conflict with other running debuggers (eg
  236.            monam)
  237.          o Trap #x: Sets the breakpoint-code to trap#x (dc.w $4e4x) and
  238.            vector +$80+4*x. Make sure that the traps are not used be the
  239.            programm you debug.
  240.       o ExecValid:
  241.          o Yes: Make the asumption that system is running and exec,etc.. is
  242.            available. If system is not available this may cause major errors
  243.            (loops...etc). Set only if you want to use a system-command,you
  244.            know system is alive and TK thinks its not available.
  245.          o no: Make the asumption that system is not running. All
  246.            ;4msystem-command are not available.
  247.          o check: This will try to determinate if system is running or not.
  248.       o MemAccess:
  249.          o RAM: Your can read/write/access only the memory that was detected
  250.            by TK, check the INFO command.
  251.          o RAM+ROM: Your can read/write/access only memory that was detected
  252.            by TK plus the ROM-area.
  253.          o ALL: You can read/write/access the whole memory.Make sure you
  254.            access only memory that will not let your machine crash.
  255.       o VBRFaker:
  256.          o YES: This will exchange the freezed-programm-vbr with an own
  257.            vbr-simulator. This will allow you to enter programms which modify
  258.            the NMI-vector. However if you programm changes the vbr itself you
  259.            will not be able to enter TK again (in general). If you find such
  260.            a command set a breakpoint there, then adjust the vbr manually and
  261.            skip the command - works fine.
  262.          o NO: If the vbr-simulator was active it will be removed, else
  263.            nothing happens. (default)
  264.       o ROM-Avoid(NMI):
  265.          o YES: This disables entries via NMI if the freezed programm is
  266.            currently in a ROM memory.
  267.          o NO: You can enter TK via NMI at any time.
  268.       o TK-Memaccess:
  269.          o YES: This allows you to read/write/access the TK memory.
  270.          o NO: You can not read/write/acess the TK memory.
  271.  
  272.    o Editor preferences:
  273.       o Scrolling:
  274.          o BLITTER: The blitter will be used to scroll. If you want real-time
  275.            scrolling on 68000 then enable this option. The disadvantage is
  276.            that the blitter register will be destroyed! The blitter register
  277.            can be modified manually by the E command.
  278.          o CPU: The cpu will be used to scroll. This is faster than blitter
  279.            on 68020++. Also if you want to scroll in real-time on bigger
  280.            screen this option must be enabled.
  281.       o Insert-Mode:
  282.          o YES: If you hit a key the chars left from the current cursor
  283.            location will be shifted left before the new char is inserted. The
  284.            last char in the row is lost.
  285.          o NO: If you hit a key the char at the current cursor loaction is
  286.            replaced with the hit key. Use <TAB> to force a insert.
  287.       o Show-Page:
  288.          o If enabled and you jump to a new page, the page number will be
  289.            written to the right-top corner of the screen.
  290.       o Cursor-Type:
  291.          o LINE: The cursor will have the form of a line
  292.          o DOUBLE: The cursor will have the form of a thick line
  293.          o BLOCK: The cursor will have the form of a block
  294.       o Keyboard:
  295.          o GERMAN: The german keymap will be active.
  296.          o US: The us keymap will be active.
  297.       o BackGroundColor:
  298.          o The default background color of the TK-surface can be set in
  299.            12-bit-RGB format
  300.       o CharColor:
  301.          o The default char color of the TK-surface can be set in 12-bit-RGB
  302.            format
  303.       o CharColor2:
  304.          o The default char color for the MP command.
  305.       o WaitingColor:
  306.          o The default background color in hold-mode for the TK-surface can
  307.            be set in 12-bit-RGB format
  308.       o BlinkColor1:
  309.          o The first cursor color (alternating) of the TK-surface can be set
  310.            in 12-bit-RGB format
  311.       o BlinkColor2:
  312.          o The second cursor color (alternating) of the TK-surface can be set
  313.            in 12-bit-RGB format.
  314.       o BlinkTime:
  315.          o Amount of frames between alternating the cursor color (swap
  316.            between BlinkColor1 and BlinkColor2)
  317.       o KeyRepeatDelay:
  318.          o Amount of frames before a key is repeated
  319.       o KeyRepeatSpeed:
  320.          o Amount of frames between each key repeat
  321.  
  322.    o Screenmode preferences:
  323.       o Screenmode:
  324.          o NTSC: A NTSC screen (640x200,60Hz) will be used
  325.          o PAL: A PAL screen (640x256,50Hz) will be used
  326.          o CUSTOM: The register in the CUSTOM area will be used to set up
  327.            screen
  328.          o EURO72: A EURO72 screen (640x400,70Hz) will be used
  329.          o DBLPAL: A DBLPAL screen (640x512,50Hz) will be used
  330.          o CUSTOM2: The register in the CUSTOM2 area will be used to set up
  331.            screen
  332.       o ScreenBlank:
  333.          o If enabled and you use a aga-screen mode then the border-color
  334.            will be black, else the border has the same color as the
  335.            background
  336.       o If you know how to setup a screen by hardware then you can optimize
  337.         your screen. This is not described here, check out ecs/aga
  338.         documentation. NO WARRANTY FOR ANY DAMAGE!
  339.    o Reset preferences:
  340.       o Screenmode:
  341.          o PAL: The boot-picture will be shown on a PAL-screen
  342.          o NTSC: The boot -picture will be shown on a NTSC-screen
  343.       o MemorySequence:
  344.          o SKIP: No special operation is done.
  345.          o TEST: The detected memory is checked for any ram-failure.
  346.          o CLEAR: The detected memory is filled with the clear-pattern.
  347.          o TEST&CLEAR: The detected memory is checked and filled with the
  348.            clear-pattern.
  349.       o ClearPattern:
  350.          o The pattern used to fill memory. Usefull to find a suitable place
  351.            for patch-routines.
  352.       o External-BusTimeoutMode:
  353.          o IGNORE: If you have not a A4000 then this option should be
  354.            enabled.
  355.          o DSACK: If you access not-available memory on a A4000 usually a
  356.            bus-error is generated (and a long delay). With this option you
  357.            can set it to DSACK which results in no bus-errors and short
  358.            delays.
  359.          o BUSERR: This is the system-default TimeoutMode for the A4000
  360.       o KickStartPatch:
  361.          o This will enable all patches done when the kickstart is launched.
  362.            If this option is disabled all private-functions are disabled.
  363.       o ChipMemStart:
  364.          o Defines the location where the chip-memory starts (eg at
  365.            $100000-). Unused memory will be privatized.
  366.       o ChipMemEnd:
  367.          o Defines the location where the chip-memory ends. Unused memory
  368.            will be privatized.
  369.       o ExpansionMemoryX-Private:
  370.          o This option allows you to deactivate memory used by the system.
  371.            Unused memory will be privatized.
  372.       o ClearBreakpoints:
  373.          o All breakpoints will be cleared on reset.
  374.       o ClearMemoryWatchpoints:
  375.          o All memory-watchpoints will be cleared on reset.
  376.       o ClearMemoryAccessranges:
  377.          o All memory-accessranges will be clear on reset.
  378.       o DetectChipmem:
  379.          o Specifies the memory-range TK searches for chip-memory.
  380.       o DetectExpansionMemoryX:
  381.          o Specifies the memory-range TK searches for fast-memory. If your
  382.            memory is not detected by default then you can add your memory
  383.            manually. Also usefull if you get conflicts raised by illegal
  384.            memory accesses.
  385.  
  386.    o Misc preferences:
  387.       o AutoVerify:
  388.          o If enabled all disk-write operations will be verified.
  389.       o Support HD-disks:
  390.          o If enabled you can read/write high-density disks. This needs more
  391.            internal memory. Disable if you want eg a larger internal
  392.            trainer-buffer.
  393.       o Internal-TimeoutBusMode:
  394.          o IGNORE: If you have not a A4000 then this option should be
  395.            enabled.
  396.          o DSACK: This option should be enabled if you have a A4000, else the
  397.            memory detection will hang up your system.
  398.          o BUSERR: This is the system-default TimeoutMode for the A4000
  399.       o HighestTrack:
  400.          o Here you can overwrite the upper tracklimit, so that you can also
  401.            read/write tracks 80-85.
  402.            NO WARRARNTY FOR ANY DAMAGE CAUSED BY TK!!
  403.       o Add EjectTask:
  404.          o Add a Eject-Task to system which will do a automatic 'diskchange'
  405.            to any media modified in TK.
  406.       o CustomFrom:
  407.          o USER: The user has to adjust the custom-register before he leaves
  408.            TK.
  409.          o SYSTEM: Some destroyed custom-register are read from system. Only
  410.            possible if system is intact.
  411.          o HARDWARE: If you have hardware installed it will be used to
  412.            restore the custom-register.
  413.          o MMU: The MMU will be used to restore the custom-register. Make
  414.            sure the PrivateMMU option is enabled
  415.       o CustomMMU-Flicker:
  416.          o If enabled, the freezed programm will do a little flicker whenever
  417.            a write operation to a custom register is done.
  418.       o Default Valuemode:
  419.          o HEX: The default value base is 16. Like in the action-replay
  420.          o DEC: The default value base is 10. Like in asm-one.
  421.       o ParseCpuReg:
  422.          o TRY: The parser tries to match a valid cpu-register in every
  423.            expression. (eg 'd d0' will not disassemble at $d0)
  424.          o SLASH: If you want to use cpu-register in expressions just by a
  425.            leading '\' you have to enable this.
  426.       o ParsePriority:
  427.          o OPERATOR: Each operator has a specific priority, which is used to
  428.            calculate a expression. (eg '2+3*4'='14')
  429.          o LEFT-ASSIGNED: The 'left' operator has always a greater priority.
  430.            (eg '2+3*4'='24')
  431.       o CatchCustomBootBlock:
  432.          o Whenever the system tries to boot from a non-default
  433.            disk-bootblock it will enter TK before execution. The pc will
  434.            point to the first command of the bootblock.
  435.       o PrivateMMU:
  436.          o If enabled a own mmu-pagetable is set up. Must be enabled to use
  437.            the CustomMMU function. Do no enable if you run a VMM programm.
  438.       o ALT-FX:
  439.          o Here you can define the fast-macros. Multiple command are
  440.            possible.
  441.  
  442. -----------------------------------------------------------------------------
  443.  
  444. Thrill Kill - The editor
  445. -----------------------------------------------------------------------------
  446.  
  447. The basic surface for TK is the so called editor. Its like a system-shell
  448. with special commands and functions. The keyboard type can be changed by the
  449. preferences. Beside the usual keys the following functions are
  450. available:
  451.  
  452.    o <F1> : Clear screen
  453.    o <F2> : Toogle Insert-/Overwritemode
  454.    o <F3> : Enter preferences
  455.    o <F4> : Repeat last command
  456.    o <F5> : Enter 'debugger'
  457.    o <F6> : Jump to page 1
  458.    o <F7> : Jump to page 2
  459.    o <F8> : Jump to page 3
  460.    o <F9> : Jump to page 4
  461.    o <F10> : Jump to page 5
  462.    o <SHIFT>+<F6> : Copy actual page to page 1
  463.    o <SHIFT>+<F7> : Copy actual page to page 2
  464.    o <SHIFT>+<F8> : Copy actual page to page 3
  465.    o <SHIFT>+<F9> : Copy actual page to page 4
  466.    o <SHIFT>+<F10> : Copy actual page to page 5
  467.    o <ALT>+<FX> : Execute fast macro x, (macros can be modified in in the
  468.      ;4mpreferences)
  469.    o <AMIGA>+<F5> : Make snapshot and save it
  470.    o <ESC> : Abort/Cancel current running commands (if supported)
  471.    o <TAB> : Insert space at current position
  472.    o <HELP> : Show internal help
  473.    o <SHIFT> : Hold/Pause current command (if supported)
  474.    o <AMIGA>+<SHIFT>+<ESC> : Emergency exit!! This command allows you to
  475.      leave TK any any time. This can be useful to return when a command
  476.      (should) hang up. BE WARNED! You can abort the write-commands, too, this
  477.      can cause major damage to your harddisk etc..
  478.  
  479. Some commands support 'fast signs'. This means that if you scroll up/down and
  480. in the top/bottom line is a 'fast sign' the programm will automatically
  481. generate the previous/next line. Eg. you can easily disassemblel
  482. up/down.(check out)
  483. -----------------------------------------------------------------------------
  484. Thrill Kill - Command description  
  485. -----------------------------------------------------------------------------
  486.  
  487. Command index - alphabetically
  488.  
  489.    o ? <Value>
  490.    o A <Address>
  491.    o ADD <Bytes>,<Start> <End>
  492.    o AND <Bytes>,<Start> <End>
  493.    o AVAIL
  494.    o B
  495.    o BOOTCHK <Address>
  496.    o BD <Address>
  497.    o BD #<BreakpointNumber>
  498.    o BDA
  499.    o BITCHK <Address>
  500.    o BLKCHK <Address>
  501.    o BS [#<BreakpointNumber>] <Address>
  502.    o BT #<TrapNumber>
  503.    o BTI
  504.    o CATCHFILE <StringPattern>
  505.    o CD [Path]
  506.    o COMP <Start> <End> <Destination>
  507.    o D [#<Mode>]<Address>
  508.    o DELETE <Filename>
  509.    o DEVS
  510.    o DEVICES
  511.    o DIR [Path]
  512.    o DISKLEN [#Unit] [LOW <Track>] [HIGH <Track>]
  513.    o DLAB <Labelname>
  514.    o DLABA
  515.    o E[<CUSTOM-REG>]
  516.    o EOR <Bytes>,<Start> <End>
  517.    o F <Bytes> [,Range]
  518.    o FA <Address> [,Range]
  519.    o FAQ <Address> [,Range]
  520.    o FAR <Start> <End> [,Range]
  521.    o FARQ <Start> <End> [,Range]
  522.    o FC [Range]
  523.    o FCQ [Range]
  524.    o FD <DisassemblyPattern> [,Range]
  525.    o FDQ <DisassemblyPattern> [,Range]M[.<B|W|L] [#<Entries per row>]
  526.      ;4m<Address>
  527.    o FP <PBytes> [,Range]
  528.    o FR <Bytes> [,Range]
  529.    o FS <Bytes> [,Range]
  530.    o G <Address>
  531.    o GETKEY
  532.    o HELP
  533.    o INFO
  534.    o INTS
  535.    o INTERRUPTS
  536.    o LA <Address>
  537.    o LAB <Labelname>=<Value>
  538.    o LABS
  539.    o LABELS
  540.    o LE <Filename>
  541.    o LESS <Filename>
  542.    o LIBS
  543.    o LIBRARIES
  544.    o LM <Filename>,<Start> [<End>]
  545.    o LS [Path]
  546.    o M[.<B|W|L] [#<Entries per row>] <Address>
  547.    o MA
  548.    o MAD <Start> <End>
  549.    o MADA
  550.    o MAKEDIR <Path>
  551.    o MAS <Start> <End>
  552.    o MD <Address>
  553.    o MDA
  554.    o MEM
  555.    o MFMC <Start> <End> <Destination>
  556.    o MFMD <Start> <End> <Destination>
  557.    o MFMR [#<Unit>] [INDEX] [SYNC=<SYNC>] <Track> <DMA-Length> <Destination>
  558.    o MFMSL <Start> <End> <Destination> <BitShift>
  559.    o MFMSR <Start> <End> <Destination> <BitShift>
  560.    o MFMSS <Start> <End> <Destination> <Sync>
  561.    o MFMW [#<Unit>] [INDEX] <Track> <DMA-Length> <Source>
  562.    o MKDIR <Path>
  563.    o MMUD <Start> <End>
  564.    o MMUDA
  565.    o MMUS <Start> <End>
  566.    o MMUSW <Start> <End>
  567.    o MMUV
  568.    o MORE <Filename>
  569.    o MP
  570.    o MS [.<B|W|L] <Address>
  571.    o MV
  572.    o N [#<Entries per row>] <Address>
  573.    o NO <Offset>
  574.    o O <Bytes>,<Start> <End>
  575.    o OR <Bytes>,<Start> <End>
  576.    o PORTS
  577.    o Q <Start> <End> <Destination>
  578.    o R [<CPU-REG> <Value>]
  579.    o RB <Filename>,<Start> [<End>]
  580.    o RD [#<Unit>] <DiskOffset> <Length> <Destination>
  581.    o RESET
  582.    o RES
  583.    o RESOURCES
  584.    o RF [<FPU-REG> <Value>]
  585.    o RM [<MMU-REG> <Value>]
  586.    o RS [#<Unit>] <Sector> <SectorAmount> <Destination>
  587.    o RT [#<Unit>] <Track> <TrackAmount> <Destination>
  588.    o SA <Start> [<End>]
  589.    o SE <Filename>
  590.    o SETX
  591.    o SETEXCEPTIONS
  592.    o SHOWSTACKFRAME
  593.    o SI [<Count>]
  594.    o SIM <Rawkey>
  595.    o SM <Filename>,<Start> <End>
  596.    o ST [<Count>]
  597.    o T <Value>
  598.    o TASKS
  599.    o TB <Start> <End>
  600.    o TBD
  601.    o TBV
  602.    o TDC
  603.    o TDS [Range]
  604.    o TDV
  605.    o TDX
  606.    o TR [<Count>]
  607.    o TRACKER [<START>]
  608.    o TRANS <Start> <End> <Destination>
  609.    o TS <Value> [,Range]
  610.    o TV
  611.    o TX
  612.    o TYPE <Filename>
  613.    o USEBLIT
  614.    o USECPU
  615.    o VERSION
  616.    o W [<CIA-REG>]
  617.    o WB <Filename>,<Start> <End>
  618.    o WD [#<Unit>] <DiskOffset> <Length> <Source>
  619.    o WN [<Count>]
  620.    o WPC <Address>
  621.    o WS [#<Unit>] <Sector> <SectorAmount> <Source>
  622.    o WT [#<Unit>] <Track> <TrackAmount> <Source>
  623.    o X
  624.    o Y [#<Entries per row>] <Address>
  625.  
  626. -----------------------------------------------------------------------------
  627.  
  628. Command index - sorted by command groups
  629.  
  630.    o Commands for manipulation 
  631.    o Commands for searching data
  632.    o Commands for manipulating breakpoints
  633.    o Commands for 'Trace' actions
  634.    o Commands for MMU manipulation
  635.    o Commands for 'Training' actions
  636.    o Commands for io-access
  637.    o Commands for diskio-access only
  638.    o Commands for mfm manipulation
  639.    o Commands for misc usage
  640.    o Commands for sys usage
  641.  
  642. -----------------------------------------------------------------------------
  643. Commands for manipulation 
  644.  
  645.    o A <Address>
  646.    o ADD <Bytes>,<Start> <End>
  647.    o AND <Bytes>,<Start> <End>
  648.    o CATCHFILE <StringPattern>
  649.    o COMP <Start> <End> <Destination>
  650.    o D [#<Mode>]<Address>
  651.    o E[<CUSTOM-REG>]
  652.    o EOR <Bytes>,<Start> <End>
  653.    o G <Address>
  654.    o M[.<B|W|L] [#<Entries per row>] <Address>
  655.    o N [#<Entries per row>] <Address>
  656.    o NO <Offset>
  657.    o LA <Address>
  658.    o O <Bytes>,<Start> <End>
  659.    o OR <Bytes>,<Start> <End>
  660.    o Q <Start> <End> <Destination>
  661.    o R [<CPU-REG> <Value>]
  662.    o RF [<FPU-REG> <Value>]
  663.    o RM [<MMU-REG> <Value>]
  664.    o SA <Start> [<End>]
  665.    o SETEXCEPTIONS
  666.    o SETX
  667.    o SIM <Rawkey>
  668.    o TRANS <Start> <End> <Destination>
  669.    o W [<CIA-REG>]
  670.    o X
  671.    o Y [#<Entries per row>] <Address>
  672.  
  673. Commands for searching data
  674.  
  675.    o F <Bytes> [,Range]
  676.    o FA <Address> [,Range]
  677.    o FAQ <Address> [,Range]
  678.    o FAR <Start> <End> [,Range]
  679.    o FARQ <Start> <End> [,Range]
  680.    o FC [Range]
  681.    o FCQ [Range]
  682.    o FD <DisassemblyPattern> [,Range]
  683.    o FDQ <DisassemblyPattern> [,Range]
  684.    o FP <PBytes> [,Range]
  685.    o FR <Bytes> [,Range]
  686.    o FS <Bytes> [,Range]
  687.  
  688. Commands for manipulating breakpoints
  689.  
  690.    o B
  691.    o BD <Address>
  692.    o BD #<BreakpointNumber>
  693.    o BDA
  694.    o BT #<TrapNumber>
  695.    o BTI
  696.    o BS [#<BreakpointNumber>] <Address>
  697.  
  698. Commands for 'Trace' actions
  699.  
  700.    o MA
  701.    o MAD <Start> <End>
  702.    o MADA
  703.    o MAS <Start> <End>
  704.    o MD <Address>
  705.    o MDA
  706.    o MS [.<B|W|L] <Address>
  707.    o MV
  708.    o SI [<Count>]
  709.    o ST [<Count>]
  710.    o TR [<Count>]
  711.    o WN [<Count>]
  712.    o WPC <Address>
  713.  
  714. Commands for MMU manipulation
  715.  
  716.    o MMUD <Start> <End>
  717.    o MMUDA
  718.    o MMUS <Start> <End>
  719.    o MMUSW <Start> <End>
  720.    o MMUV
  721.    o RM [<MMU-REG> <Value>]
  722.  
  723. Commands for 'Training' actions
  724.  
  725.    o T <Value>
  726.    o TB <Start> <End>
  727.    o TBD
  728.    o TBV
  729.    o TDC
  730.    o TDS [Range]
  731.    o TDV
  732.    o TDX
  733.    o TS <Value> [,Range]
  734.    o TV
  735.    o TX
  736.  
  737. Commands for io-access
  738.  
  739.    o CD [Path]
  740.    o DELETE <Filename>
  741.    o DIR [Path]
  742.    o LESS <Filename>
  743.    o LM <Filename>,<Start> [<End>]
  744.    o LS [Path]
  745.    o MAKEDIR <Path>
  746.    o MORE <Filename>
  747.    o RB <Filename>,<Start> [<End>]
  748.    o SM <Filename>,<Start> <End>
  749.    o TYPE <Filename>
  750.    o WB <Filename>,<Start> <End>
  751.  
  752. Commands for diskio-access only
  753.  
  754.    o BITCHK <Address>
  755.    o BLKCHK <Address>
  756.    o BOOTCHK <Address>
  757.    o RD [#<Unit>] <DiskOffset> <Length> <Destination>
  758.    o RS [#<Unit>] <Sector> <SectorAmount> <Destination>
  759.    o RT [#<Unit>] <Track> <TrackAmount> <Destination>
  760.    o WD [#<Unit>] <DiskOffset> <Length> <Source>
  761.    o WS [#<Unit>] <Sector> <SectorAmount> <Source>
  762.    o WT [#<Unit>] <Track> <TrackAmount> <Source>
  763.  
  764. Commands for mfm manipulation
  765.  
  766.    o DISKLEN [#Unit] [LOW <Track>] [HIGH <Track>]
  767.    o MFMR [#<Unit>] [INDEX] [SYNC=<SYNC>] <Track> <DMA-Length> <Destination>
  768.    o MFMW [#<Unit>] [INDEX] <Track> <DMA-Length> <Source>
  769.    o MFMC <Start> <End> <Destination>
  770.    o MFMD <Start> <End> <Destination>
  771.    o MFMSL <Start> <End> <Destination> <BitShift>
  772.    o MFMSR <Start> <End> <Destination> <BitShift>
  773.    o MFMSS <Start> <End> <Destination> <Sync>
  774.  
  775. Commands for misc usage
  776.  
  777.    o ? <Value>
  778.    o DLAB <Labelname>
  779.    o DLABA
  780.    o GETKEY
  781.    o HELP
  782.    o INFO
  783.    o LAB <Labelname>=<Value>
  784.    o LABS
  785.    o LABELS
  786.    o LE <Filename>
  787.    o MP
  788.    o RESET
  789.    o SE <Filename>
  790.    o SHOWSTACKFRAME
  791.    o TRACKER [<START>]
  792.    o USEBLIT
  793.    o USECPU
  794.    o VERSION
  795.  
  796. Commands for system usage
  797.  
  798.    o AVAIL
  799.    o DEVS
  800.    o DEVICES
  801.    o INTS
  802.    o INTERRUPTS
  803.    o MEM
  804.    o LIBS
  805.    o LIBRARIES
  806.    o PORTS
  807.    o RES
  808.    o RESOURCES
  809.    o TASKS
  810.  
  811. -----------------------------------------------------------------------------
  812.  
  813. Commands description - no order
  814.  
  815. -----------------------------------------------------------------------------
  816.  
  817. Syntax:
  818.  
  819.      ? <Value>
  820.  
  821. Description:
  822.  
  823.      Print value <Value> in differnt bases. This function can be used as a
  824.      simple calculator.
  825.  
  826. Example:
  827.  
  828.       o ? (!123*345%4|234)<<3
  829.  
  830. -----------------------------------------------------------------------------
  831.  
  832. Syntax:
  833.  
  834.      A <Address>
  835.  
  836. Description:
  837.  
  838.      Start assembly at <Address>. The command uses the dis/assembler
  839.      specified with the D command.
  840.  
  841. Example:
  842.  
  843.       o a 100000
  844.         ^$00100000 movec vbr,d0
  845.         ^$00100004 btst #6,$bfe001
  846.         ^$0010000c bne 100004
  847.  
  848. -----------------------------------------------------------------------------
  849.  
  850. Syntax:
  851.  
  852.      ADD <Bytes>,<Start> <End>
  853.  
  854. Description:
  855.  
  856.      Add given pattern <Bytes> bytewise to memory from <Start> to <End>.
  857.  
  858. Example:
  859.  
  860.       o add "Mok",80000 90000
  861.  
  862. -----------------------------------------------------------------------------
  863.  
  864. Syntax:
  865.  
  866.      AND <Bytes>,<Start> <End>
  867.  
  868. Description:
  869.  
  870.      And given pattern <Bytes> bytewise to memory from <Start> to <End>.
  871.  
  872. Example:
  873.  
  874.       o and "Samir",80000 90000
  875.  
  876. -----------------------------------------------------------------------------
  877.  
  878. Syntax:
  879.  
  880.      AVAIL
  881.  
  882.      MEM
  883.  
  884. Description:
  885.  
  886.      Lists all currently available memory nodes and total memory usage.
  887.  
  888. Example:
  889.  
  890.       o avail
  891.  
  892. -----------------------------------------------------------------------------
  893. Syntax:
  894.  
  895.      B
  896.  
  897. Description:
  898.  
  899.      Display all current breakpoints and breakpoint method.
  900.  
  901. Example:
  902.  
  903.       o b
  904.  
  905. -----------------------------------------------------------------------------
  906.  
  907. Syntax:
  908.  
  909.      BD #<BreakpointNumber>
  910.  
  911.      BD <Address>
  912.  
  913. Description:
  914.  
  915.      Either delete breakpoint at <Address> or breakpoint with specified
  916.      <BreakpointNumber>. The value of <BreakpointNumber> must be one of
  917.      [0..31[.
  918.  
  919. Example:
  920.  
  921.       o bd pc
  922.       o bd 80000
  923.       o bd #!31
  924.  
  925. -----------------------------------------------------------------------------
  926.  
  927. Syntax:
  928.  
  929.      BDA
  930.  
  931. Description:
  932.  
  933.      Delete all breakpoints.
  934.  
  935. Example:
  936.  
  937.       o bda
  938.  
  939. -----------------------------------------------------------------------------
  940.  
  941. Syntax:
  942.  
  943.      BITCHK <Address>
  944.  
  945. Description:
  946.  
  947.      Correct bitmapblock-checksum for bitmapblock at <Address>.
  948.  
  949. Example:
  950.  
  951.       o bitchk 10000
  952.  
  953. -----------------------------------------------------------------------------
  954.  
  955. Syntax:
  956.  
  957.      BLKCHK <Address>
  958.  
  959. Description:
  960.  
  961.      Correct datablock-checksum for datablock at <Address>.
  962.  
  963. Example:
  964.  
  965.       o blkchk 10000
  966.  
  967. -----------------------------------------------------------------------------
  968.  
  969. Syntax:
  970.  
  971.      BOOTCHK <Address>
  972.  
  973. Description:
  974.  
  975.      Correct bootblock-checksum for bootblock at <Address>.
  976.  
  977. Example:
  978.  
  979.       o bootchk 10000
  980.  
  981. -----------------------------------------------------------------------------
  982.  
  983. Syntax:
  984.  
  985.      BS [#<BreakpointNumber>] <Address>
  986.  
  987. Description:
  988.  
  989.      Set breakpoint at <Address>. If <BreapointNumber> is not given the next
  990.      free breakpoint is used. The value of <BreakpointNumber> must be one of
  991.      [0..31[.
  992.  
  993. Example:
  994.  
  995.       o bs 80000
  996.       o bs #!31 80000
  997.  
  998. -----------------------------------------------------------------------------
  999.  
  1000. Syntax:
  1001.  
  1002.      BT #<TrapNumber>
  1003.  
  1004. Description:
  1005.  
  1006.      Set breakpoint method to 'trap #<TrapNumber>' (dc.w $4e4<TrapNumber>).
  1007.      The value of <Trapnumber> must be one of [0..15[.
  1008.  
  1009. Example:
  1010.  
  1011.       o bt #f
  1012.  
  1013. -----------------------------------------------------------------------------
  1014.  
  1015. Syntax:
  1016.  
  1017.      BTI
  1018.  
  1019. Description:
  1020.  
  1021.      Set breakpoint method to 'illegal' (dc.w $4afc) opcode.
  1022.  
  1023. Example:
  1024.  
  1025.       o bti
  1026.  
  1027. -----------------------------------------------------------------------------
  1028.  
  1029. Syntax:
  1030.  
  1031.      CATCHFILE <StringPattern>
  1032.  
  1033. Description:
  1034.  
  1035.      The function will patch the current LoadSeg() function from the the
  1036.      dos-library. If the system now tries to load a executable with the
  1037.      specified pattern/name TK will return before the executable is started.
  1038.      The patch is removed and the pc will point to the first instruction of
  1039.      the executable.
  1040.  
  1041. Example:
  1042.  
  1043.       o catchfile *tk.exe ; this will catch all executables, including eg
  1044.         'C:tk.exe'
  1045.       o catchfile tk.exe ; this will not catch eg 'C:tk.exe' !!
  1046.  
  1047. -----------------------------------------------------------------------------
  1048.  
  1049. Syntax:
  1050.  
  1051.      CD [Path]
  1052.  
  1053. Description:
  1054.  
  1055.      The command will try to set the current-directory to given path. If
  1056.      [Path] is not given it will just show the current path.
  1057.  
  1058. Example:
  1059.  
  1060.       o cd
  1061.       o cd hd1:tk/
  1062.  
  1063. -----------------------------------------------------------------------------
  1064.  
  1065. Syntax:
  1066.  
  1067.      D [#<Mode>]<Address>
  1068.  
  1069. Description:
  1070.  
  1071.      Disassembly memory at <Address>. If address is zero the current pc is
  1072.      used. (like in the AR). The <Mode> argument allows you to use different
  1073.      dis- and assembler; default mode is zero.
  1074.  
  1075.       o 0 : usual 680x0 dis/assembler
  1076.       o 1 : RNC mode 1 (old)
  1077.       o 2 : RNC mode 2
  1078.  
  1079. Example:
  1080.  
  1081.       o d f800d2
  1082.  
  1083. -----------------------------------------------------------------------------
  1084.  
  1085. Syntax:
  1086.  
  1087.      DELETE <Filename>
  1088.  
  1089. Description:
  1090.  
  1091.      Delete file <Filename>.
  1092.  
  1093. Example:
  1094.  
  1095.       o delete "hd1:tk/tk.exe"
  1096.  
  1097. -----------------------------------------------------------------------------
  1098.  
  1099. Syntax:
  1100.  
  1101.      DEVS
  1102.  
  1103.      DEVICES
  1104.  
  1105. Description:
  1106.  
  1107.      Lists all currently available devices.
  1108.  
  1109. Example:
  1110.  
  1111.       o devs
  1112.  
  1113. -----------------------------------------------------------------------------
  1114.  
  1115. Syntax:
  1116.  
  1117.      DIR [Path]
  1118.  
  1119.      LS [Path]
  1120.  
  1121. Description:
  1122.  
  1123.      The command will display the directory for given [Path]. If [Path] is
  1124.      not given it will use the current path.
  1125.  
  1126. Example:
  1127.  
  1128.       o dir hd1:tk/
  1129.  
  1130. -----------------------------------------------------------------------------
  1131.  
  1132. Syntax:
  1133.  
  1134.      DISKLEN [#<Unit>] [LOW <Track>] [HIGH <Track>]
  1135.  
  1136. Description:
  1137.  
  1138.      The function will determinate the disk-speed. Note that the data on the
  1139.      disk is lost (so use a empty one).
  1140.  
  1141. Example:
  1142.  
  1143.       o disklen
  1144.  
  1145. -----------------------------------------------------------------------------
  1146.  
  1147. Syntax:
  1148.  
  1149.      DLAB <Labelname>
  1150.  
  1151. Description:
  1152.  
  1153.      Delete label <Labelname>.
  1154.  
  1155. Example:
  1156.  
  1157.       o dlab mfmload
  1158.  
  1159. -----------------------------------------------------------------------------
  1160.  
  1161. Syntax:
  1162.  
  1163.      DLABA
  1164.  
  1165. Description:
  1166.  
  1167.      Delete all labels.
  1168.  
  1169. Example:
  1170.  
  1171.       o dlaba
  1172.  
  1173. -----------------------------------------------------------------------------
  1174.  
  1175. Syntax:
  1176.  
  1177.      E [<CUSTOM-REG>]
  1178.  
  1179. Description:
  1180.  
  1181.      If no paramter is specified it will show the first CUSTOM register. The
  1182.      output can be edited (hit return to accept new values). The following
  1183.      flags exist:
  1184.  
  1185.       o 'R': a read only register; just for information; no change possible
  1186.       o '-': reg has not been touched by TK; its kept at its original value;
  1187.         can be changed to '*'
  1188.       o '*': reg has been backuped correctly and will be written back
  1189.       o '?': reg has not been fully backuped but will be written back.
  1190.         (probably the reg was used by TK, too) It may be necessary to adjust
  1191.         it manually! (eg set $1dc to $20/$1bb8 for a PAL/MULTISCAN screen)
  1192.  
  1193. Example:
  1194.  
  1195.       o e 1dc ; show/edit beamcon0
  1196.  
  1197. -----------------------------------------------------------------------------
  1198.  
  1199. Syntax:
  1200.  
  1201.      EOR <Bytes>,<Start> <End>
  1202.  
  1203. Description:
  1204.  
  1205.      Eor bytewise memory from <Start> to <End> with given pattern <Bytes>.
  1206.  
  1207. Example:
  1208.  
  1209.       o eor "Mok",80000 90000
  1210.  
  1211. -----------------------------------------------------------------------------
  1212.  
  1213. Syntax:
  1214.  
  1215.      F <Bytes> [,Range]
  1216.  
  1217. Description:
  1218.  
  1219.      Find all locations in [Range] where <Bytes> occures.
  1220.  
  1221. Example:
  1222.  
  1223.       o f 4e 7b 00 f8 00 00
  1224.       o f "Hello" ; will find 'Hello' but not 'HELLO','hello'
  1225.  
  1226. -----------------------------------------------------------------------------
  1227.  
  1228. Syntax:
  1229.  
  1230.      FA <Address> [,Range]
  1231.  
  1232.      FAQ <Address> [,Range]
  1233.  
  1234. Description:
  1235.  
  1236.      Find all commands in [Range] which refer to <Address>. This code is
  1237.      analyzed and all commands accessing <Address> are reported. Note that
  1238.      the current registers are used for scanning. If quick mode is used then
  1239.      the range-pointer is always increased by the command-size instead of 2.
  1240.      This means that you may loose valid locations.
  1241.  
  1242. Example:
  1243.  
  1244.       o fa f800d2
  1245.  
  1246. -----------------------------------------------------------------------------
  1247.  
  1248. Syntax:
  1249.  
  1250.      FAR <Start> <End> [,Range]
  1251.  
  1252.      FARQ <Start> <End> [,Range]
  1253.  
  1254. Description:
  1255.  
  1256.      Find all commands in [Range] which refer to memory from <Start> to
  1257.      <End>. This code is analyzed and all commands accessing specified memory
  1258.      are reported. Note that the current registers are used for scanning,
  1259.      too. If quick mode is used then the range-pointer is always increased by
  1260.      the command-size instead of 2. This means that you may loose valid
  1261.      locations.
  1262.  
  1263. Example:
  1264.  
  1265.       o far dff09a dff09c,f80000 f90000
  1266.  
  1267. -----------------------------------------------------------------------------
  1268.  
  1269. Syntax:
  1270.  
  1271.      FC [Range]
  1272.  
  1273.      FCQ [Range]
  1274.  
  1275. Description:
  1276.  
  1277.      Find all commands in [Range] which match to the internal library.
  1278.  
  1279. Example:
  1280.  
  1281.       o fcq
  1282.  
  1283. -----------------------------------------------------------------------------
  1284.  
  1285. Syntax:
  1286.  
  1287.      FD <DisassemblyPattern> [,Range]
  1288.  
  1289.      FDQ <DisassemblyPattern> [,Range]
  1290.  
  1291. Description:
  1292.  
  1293.      Find all commands in [Range] which match to given pattern. The output of
  1294.      the disassmbler is check for given pattern. Note that you can also
  1295.      search for multiple commands. If quick mode is used then the
  1296.      range-pointer is always increased by the command-size instead of 2. This
  1297.      means that you may loose valid locations.
  1298.  
  1299. Example:
  1300.  
  1301.       o fdq "\move.l $*,(a?)\\tst.l #?"
  1302.  
  1303. -----------------------------------------------------------------------------
  1304.  
  1305. Syntax:
  1306.  
  1307.      FP <PBytes> [,Range]
  1308.  
  1309. Description:
  1310.  
  1311.      Find all locations in [Range] where pattern <PBytes> occures.
  1312.  
  1313. Example:
  1314.  
  1315.       o fp 4e ?? 00 ?8 00 0? ; will find eg $4e $4e $00 $f8 $00 $0f
  1316.  
  1317. -----------------------------------------------------------------------------
  1318.  
  1319. Syntax:
  1320.  
  1321.      FR <Bytes> [,Range]
  1322.  
  1323. Description:
  1324.  
  1325.      Find all locations in [Range] where relative <Bytes> occures. This means
  1326.      that only a 'differnce-pattern' is searched. The given offset can be
  1327.      used for the NO command.
  1328.  
  1329. Example:
  1330.  
  1331.       o f r "Hello" ; will find eg 'Hello','Ifmmp',..
  1332.  
  1333. -----------------------------------------------------------------------------
  1334.  
  1335. Syntax:
  1336.  
  1337.      FS <Bytes> [,Range]
  1338.  
  1339. Description:
  1340.  
  1341.      Find all locations in [Range] where uppercased <Bytes> occures. This
  1342.      means that eg 'f' and 'F' is treated as same.
  1343.  
  1344. Example:
  1345.  
  1346.       o fs "HeLLo" 0,80000 90000 ; will find eg 'HELLO','hello'
  1347.  
  1348. -----------------------------------------------------------------------------
  1349.  
  1350. Syntax:
  1351.  
  1352.      G <Address>
  1353.  
  1354. Description:
  1355.  
  1356.      Exit freezer programm and continue the freezed programm at <Address>.
  1357.  
  1358. Example:
  1359.  
  1360.       o r sr 2700
  1361.       o g f800d2
  1362.  
  1363. -----------------------------------------------------------------------------
  1364.  
  1365. Syntax:
  1366.  
  1367.      GETKEY
  1368.  
  1369. Description:
  1370.  
  1371.      The function will output the rawkey-code of every pressed key. (No need
  1372.      to look into a book)
  1373.  
  1374. Example:
  1375.  
  1376.       o getkey
  1377.  
  1378. -----------------------------------------------------------------------------
  1379.  
  1380. Syntax:
  1381.  
  1382.      HELP
  1383.  
  1384. Description:
  1385.  
  1386.      Show help-page. Press the <Help> key for the same effect.
  1387.  
  1388. Example:
  1389.  
  1390.       o help
  1391.  
  1392. -----------------------------------------------------------------------------
  1393.  
  1394. Syntax:
  1395.  
  1396.      INFO
  1397.  
  1398. Description:
  1399.  
  1400.      Show global system-information like available mem, privatized mem, cpu,
  1401.      fpu, mmu, current trackpos of drives, head pos, available devices, to be
  1402.      ejected devices and much more (check out).
  1403.  
  1404. Example:
  1405.  
  1406.       o info
  1407.  
  1408. -----------------------------------------------------------------------------
  1409. Syntax:
  1410.  
  1411.      INTS
  1412.  
  1413.      INTERRUPTS
  1414.  
  1415. Description:
  1416.  
  1417.      Lists all currently available interrupts. The first value is a pointer
  1418.      to the interrupt node and the second one is a pointer to the interrupt
  1419.      code.
  1420.  
  1421. Example:
  1422.  
  1423.       o ints
  1424.  
  1425. -----------------------------------------------------------------------------
  1426.  
  1427. Syntax:
  1428.  
  1429.      LA <Address>
  1430.  
  1431. Description:
  1432.  
  1433.      Load frozen programm-data from memory at <Address>. A programm can be
  1434.      saved using the SA command.
  1435.  
  1436. Example:
  1437.  
  1438.       o la 7c00000
  1439.  
  1440. -----------------------------------------------------------------------------
  1441.  
  1442. Syntax:
  1443.  
  1444.      LAB <Labelname>=<Value>
  1445.  
  1446. Description:
  1447.  
  1448.      Define label <Labelname> and set it to value <Value>. If the label
  1449.      already exists it will be redefined.
  1450.  
  1451. Example:
  1452.  
  1453.       o lab sync=$9521
  1454.       o lab mfmload=824
  1455.  
  1456. -----------------------------------------------------------------------------
  1457.  
  1458. Syntax:
  1459.  
  1460.      LABS
  1461.  
  1462.      LABELS
  1463.  
  1464. Description:
  1465.  
  1466.      Show all current defined labels.
  1467.  
  1468. Example:
  1469.  
  1470.       o labs
  1471.  
  1472. -----------------------------------------------------------------------------
  1473.  
  1474. Syntax:
  1475.  
  1476.      LE <Filename>
  1477.  
  1478. Description:
  1479.  
  1480.      Load envirement from given file <Filename>. Only settings that have been
  1481.      saved with the current programm version can be used. Settings can be
  1482.      genereated by the SE command.
  1483.  
  1484. Example:
  1485.  
  1486.       o le "hd1:tk/tk.prefs"
  1487.  
  1488. -----------------------------------------------------------------------------
  1489.  
  1490. Syntax:
  1491.  
  1492.      LIBS
  1493.  
  1494.      LIBRARIES
  1495.  
  1496. Description:
  1497.  
  1498.      Lists all currently available libraries.
  1499.  
  1500. Example:
  1501.  
  1502.       o libs
  1503.  
  1504. -----------------------------------------------------------------------------
  1505.  
  1506. Syntax:
  1507.  
  1508.      LM <Filename>,<Start> [<End>]
  1509.  
  1510.      RB <Filename>,<Start> [<End>]
  1511.  
  1512. Description:
  1513.  
  1514.      Load data-file <Filename> to memory starting at <Start>. If <End> is
  1515.      given, data will only be loaded upto <End>.
  1516.  
  1517. Example:
  1518.  
  1519.       o lm "hd1:tk/tk.exe",100000
  1520.  
  1521. -----------------------------------------------------------------------------
  1522.  
  1523. Syntax:
  1524.  
  1525.      M[.<B|W|L] [#<Entries per row>] <Address>
  1526.  
  1527. Description:
  1528.  
  1529.      Display memory at <Address> as <Entries per row> byte/word/long
  1530.      depending on the [.<B|W|L] parameter. The command uses the byte offset
  1531.      defined by the Y command. Using optional paramters will define the
  1532.      default paramter. The optinal parameter can be reseted by illegal values
  1533.      or just be using '#'.
  1534.  
  1535. Example:
  1536.  
  1537.       o m.b #5 80000
  1538.         $0080000 $41 $42 $43 $44 $45 "ABCDE"
  1539.  
  1540. -----------------------------------------------------------------------------
  1541.  
  1542. Syntax:
  1543.  
  1544.      MA
  1545.  
  1546. Description:
  1547.  
  1548.      View all current memory access ranges.
  1549.  
  1550. Example:
  1551.  
  1552.       o ma
  1553.  
  1554. -----------------------------------------------------------------------------
  1555.  
  1556. Syntax:
  1557.  
  1558.      MAD <Start> <End>
  1559.  
  1560. Description:
  1561.  
  1562.      Delete memory access range at area from <Start> to <End>.
  1563.  
  1564. Example:
  1565.  
  1566.       o mad dff000 dff200
  1567.  
  1568. -----------------------------------------------------------------------------
  1569.  
  1570. Syntax:
  1571.  
  1572.      MADA
  1573.  
  1574. Description:
  1575.  
  1576.      Delete all memory access ranges.
  1577.  
  1578. Example:
  1579.  
  1580.       o mada
  1581.  
  1582. -----------------------------------------------------------------------------
  1583.  
  1584. Syntax:
  1585.  
  1586.      MAKEDIR <Path>
  1587.  
  1588.      MKDIR <Path>
  1589.  
  1590. Description:
  1591.  
  1592.      Creates a directory with for given <Path>.
  1593.  
  1594. Example:
  1595.  
  1596.       o makedir "hd1:tk/tk.dir"
  1597.  
  1598. -----------------------------------------------------------------------------
  1599.  
  1600. Syntax:
  1601.  
  1602.      MAS <Start> <End>
  1603.  
  1604. Description:
  1605.  
  1606.      Set memory access range to area from <Start> to <End>.
  1607.  
  1608. Example:
  1609.  
  1610.       o mas dff000 dff200
  1611.  
  1612. -----------------------------------------------------------------------------
  1613.  
  1614. Syntax:
  1615.  
  1616.      MD <Address>
  1617.  
  1618. Description:
  1619.  
  1620.      Delete memory watch point at <Address>.
  1621.  
  1622. Example:
  1623.  
  1624.       o md 80000
  1625.  
  1626. -----------------------------------------------------------------------------
  1627.  
  1628. Syntax:
  1629.  
  1630.      MDA
  1631.  
  1632. Description:
  1633.  
  1634.      Delete all memory watch points.
  1635.  
  1636. Example:
  1637.  
  1638.       o mda
  1639.  
  1640. -----------------------------------------------------------------------------
  1641.  
  1642. Syntax:
  1643.  
  1644.      MFMC <Start> <End> <Destination>
  1645.  
  1646. Description:
  1647.  
  1648.      Code data from <Start> to <End> into mfm-data stored at <Destination>.
  1649.      Each read long is coded into two mfm-longs (odd/even). This means that
  1650.      <End>-<Start> must be a multiple of four.
  1651.  
  1652. Example:
  1653.  
  1654.       o mfmc 80000 82000 84000
  1655.  
  1656. -----------------------------------------------------------------------------
  1657.  
  1658. Syntax:
  1659.  
  1660.      MFMD <Start> <End> <Destination>
  1661.  
  1662. Description:
  1663.  
  1664.      Decode mfm-data from <Start> to <End> to normal data stored at
  1665.      <Destination>. Each two read long (odd/even) are decoded into one long.
  1666.      This means that <End>-<Start> must be a multiple of eight.
  1667.  
  1668. Example:
  1669.  
  1670.       o mfmd 84000 88000 90000
  1671.  
  1672. -----------------------------------------------------------------------------
  1673.  
  1674. Syntax:
  1675.  
  1676.      MFMR [#<Unit>] [INDEX] [SYNC=<Sync>] <Track> <DMA-Length> <Destination>
  1677.  
  1678. Description:
  1679.  
  1680.      Read <DMA-Length> words of mfm-data from track <Track> of disk in unit
  1681.      <Unit> to memory at <Destination>. The default <Unit> is the
  1682.      current-device-unit. By default data will not be read on index or sync.
  1683.      Using keywords 'INDEX' or 'SYNC=<SYNC>' will enable these functions.
  1684.      Mfm-data is read directly by DMA. <Destination> may only be in
  1685.      chip-memory.
  1686.  
  1687. Example:
  1688.  
  1689.       o mfmr #0 index sync=4489 0 2000 100000 ; will read $2000 words=$4000
  1690.         bytes !!
  1691.  
  1692. -----------------------------------------------------------------------------
  1693.  
  1694. Syntax:
  1695.  
  1696.      MFMSL <Start> <End> <Destination> <BitShift>
  1697.  
  1698. Description:
  1699.  
  1700.      Shift data from <Start> to <End> by <Bitshift> bits left and store it at
  1701.      <Destination>. Of course, this command can also be used for normal data.
  1702.      <Bitshift> must be lower than 16.
  1703.  
  1704. Example:
  1705.  
  1706.       o mfmsl 84000 88000 90000 3
  1707.  
  1708. -----------------------------------------------------------------------------
  1709.  
  1710. Syntax:
  1711.  
  1712.      MFMSR <Start> <End> <Destination> <BitShift>
  1713.  
  1714. Description:
  1715.  
  1716.      Shift data from <Start> to <End> by <Bitshift> bits right and store it
  1717.      at <Destination>. Of course, this command can also be used for normal
  1718.      data. <Bitshift> must be lower than 16.
  1719.  
  1720. Example:
  1721.  
  1722.       o mfmsr 84000 88000 90000 3
  1723.  
  1724. -----------------------------------------------------------------------------
  1725.  
  1726. Syntax:
  1727.  
  1728.      MFMSS <Start> <End> <Destination> <Sync>
  1729.  
  1730. Description:
  1731.  
  1732.      Search word <Sync> in data from <Start> to <End>. If <Sync> is found all
  1733.      following data are copied to <Destination>, including the found sync.
  1734.      This command is very usefull for 'sync-read-by-hand'.
  1735.  
  1736. Example:
  1737.  
  1738.       o mfmr 0 2000 80000
  1739.       o mfmss 80000 84000 90000 4489
  1740.  
  1741. -----------------------------------------------------------------------------
  1742.  
  1743. Syntax:
  1744.  
  1745.      MFMW [#<Unit>] [INDEX] <Track> <DMA-Length> <Source>
  1746.  
  1747. Description:
  1748.  
  1749.      Write <DMA-Length> words of mfm-data to track <Track> of disk in unit
  1750.      <Unit> with memory at <Source>. The default <Unit> is the
  1751.      current-device-unit. By default data will not be written on index. Using
  1752.      keyword 'INDEX' will enable this function. Mfm-data is written directly
  1753.      by DMA. <Source> may only be in chip-memory.
  1754.  
  1755. Example:
  1756.  
  1757.       o mfmw #0 index 0 2000 100000 ; will write $2000 words=$4000 bytes !!
  1758.  
  1759. -----------------------------------------------------------------------------
  1760.  
  1761. Syntax:
  1762.  
  1763.      MMUD <Start> <End>
  1764.  
  1765. Description:
  1766.  
  1767.      Delete mmu catchlist from <Start> to <End>.
  1768.  
  1769. Example:
  1770.  
  1771.       o mmud 81234 81235
  1772.  
  1773. -----------------------------------------------------------------------------
  1774.  
  1775. Syntax:
  1776.  
  1777.      MMUDA
  1778.  
  1779. Description:
  1780.  
  1781.      Delete all mmu catchlists.
  1782.  
  1783. Example:
  1784.  
  1785.       o mmuda
  1786.  
  1787. -----------------------------------------------------------------------------
  1788.  
  1789. Syntax:
  1790.  
  1791.      MMUS <Start> <End>
  1792.  
  1793. Description:
  1794.  
  1795.      Add memory from <Start> to <End> to mmu catchlist. The specified memory
  1796.      is added as read/write catch.
  1797.  
  1798. Example:
  1799.  
  1800.       o mmus 81234 81235
  1801.  
  1802. -----------------------------------------------------------------------------
  1803.  
  1804. Syntax:
  1805.  
  1806.      MMUSW <Start> <End>
  1807.  
  1808. Description:
  1809.  
  1810.      Add memory from <Start> to <End> to mmu catchlist. The specified memory
  1811.      is added as write catch.
  1812.  
  1813. Example:
  1814.  
  1815.       o mmusw 81234 81235
  1816.  
  1817. -----------------------------------------------------------------------------
  1818.  
  1819. Syntax:
  1820.  
  1821.      MMUV
  1822.  
  1823. Description:
  1824.  
  1825.      Show current mmu catchlist.
  1826.  
  1827. Example:
  1828.  
  1829.       o mmuv
  1830.  
  1831. -----------------------------------------------------------------------------
  1832.  
  1833. Syntax:
  1834.  
  1835.      MP
  1836.  
  1837. Description:
  1838.  
  1839.      Start the memory-peeker. This tools allows you to scan through the
  1840.      memory and 'browse around'. Its also possible to view non-chipmem. Use
  1841.      the modulo feature to adjust the srceensize (eg. for finding images).
  1842.  
  1843.      The following keys functions are available:
  1844.  
  1845.       o <CURSOR-DOWN>: Scroll one line down
  1846.       o <CURSOR-UP>: Scroll one line up
  1847.       o <CURSOR-DOWN>+<SHIFT>: Scroll a 3/4 screen down
  1848.       o <CURSOR-UP>+<SHIFT>: Scroll a 3/4 screen up
  1849.       o <CURSOR-LEFT>: Scroll 32 bit left/down
  1850.       o <CURSOR-RIGHT>: Scroll 32 bit right/up
  1851.       o <ESC>: Back to TK
  1852.       o <TAB>: Cycle to next memory-page
  1853.       o <DEL>: Reset modulo to zero
  1854.       o <DEL>: Decrease modulo by 2
  1855.       o <HELP>: Increase modulo by 2
  1856.  
  1857. Example:
  1858.  
  1859.       o mp
  1860.  
  1861. -----------------------------------------------------------------------------
  1862.  
  1863. Syntax:
  1864.  
  1865.      MS [.<B|W|L] <Address>
  1866.  
  1867. Description:
  1868.  
  1869.      Set memory watch point to byte/word/long at <Address>. Default size is
  1870.      byte.
  1871.  
  1872. Example:
  1873.  
  1874.       o ms.l 80000
  1875.       o ms 60000
  1876.  
  1877. -----------------------------------------------------------------------------
  1878.  
  1879. Syntax:
  1880.  
  1881.      MV
  1882.  
  1883. Description:
  1884.  
  1885.      View all current memory watch points.
  1886.  
  1887. Example:
  1888.  
  1889.       o mv
  1890.  
  1891. -----------------------------------------------------------------------------
  1892.  
  1893. Syntax:
  1894.  
  1895.      N [#<Entries per row>] <Address>
  1896.  
  1897. Description:
  1898.  
  1899.      Display memory at <Address> as line of <Entries per row> ascii-codes.The
  1900.      command uses the byte offset defined by the Y command. Using optional
  1901.      paramters will define the default paramter. The optinal parameter can be
  1902.      reseted by illegal values or just be using '#'.
  1903.  
  1904. Example:
  1905.  
  1906.       o n #$10 $80000
  1907.         $0080000 "ABCDEFGHIJKLMNOP"
  1908.  
  1909. -----------------------------------------------------------------------------
  1910.  
  1911. Syntax:
  1912.  
  1913.      NO <Offset>
  1914.  
  1915. Description:
  1916.  
  1917.      Set the ascii-offset for the M/N command. The offset is added to every
  1918.      read byte and subtracted from every written byte. Only the low byte of
  1919.      <Offset> is used!
  1920.  
  1921. Example:
  1922.  
  1923.       o n $80000
  1924.         $0080000 "ABC"
  1925.       o no 1
  1926.       o n $80000
  1927.         $0080000 "BCD"
  1928.  
  1929. -----------------------------------------------------------------------------
  1930.  
  1931. Syntax:
  1932.  
  1933.      O <Bytes>,<Start> <End>
  1934.  
  1935. Description:
  1936.  
  1937.      Fill memory from <Start> to <End> with given pattern <Bytes>.
  1938.  
  1939. Example:
  1940.  
  1941.       o o "Mok" 0 "!" !10 0,0 20000
  1942.  
  1943. -----------------------------------------------------------------------------
  1944.  
  1945. Syntax:
  1946.  
  1947.      OR <Bytes>,<Start> <End>
  1948.  
  1949. Description:
  1950.  
  1951.      Or bytewise memory from <Start> to <End> with given pattern <Bytes>.
  1952.  
  1953. Example:
  1954.  
  1955.       o or "Mok",80000 90000
  1956.  
  1957. -----------------------------------------------------------------------------
  1958.  
  1959. Syntax:
  1960.  
  1961.      PORTS
  1962.  
  1963. Description:
  1964.  
  1965.      Lists all currently available ports and its owner tasks.
  1966.  
  1967. Example:
  1968.  
  1969.       o ports
  1970.  
  1971. -----------------------------------------------------------------------------
  1972.  
  1973. Syntax:
  1974.  
  1975.      Q <Start> <End> <Destination>
  1976.  
  1977.      COMP <Start> <End> <Destination>
  1978.  
  1979. Description:
  1980.  
  1981.      Compare memory from <Start> to <End> with memory at <Destination>.
  1982.  
  1983. Example:
  1984.  
  1985.       o q f80000 f90000 80000
  1986.  
  1987. -----------------------------------------------------------------------------
  1988.  
  1989. Syntax:
  1990.  
  1991.      R [<CPU-REG> <Value>]
  1992.  
  1993. Description:
  1994.  
  1995.      If arguments are not given the current registers will be shown. If
  1996.      arguments are used the cpu-register <CPU-REG> can be set to value
  1997.      <Value>. If you want to change MMU/FPU registers take a look at the
  1998.      RM/RF command.
  1999.  
  2000.      The following registers are available:
  2001.  
  2002.       o 68000: d0-d7,a0-a7,sr,pc,ssp,usp
  2003.       o 68010: d0-d7,a0-a7,sr,pc,ssp,usp,vbr,sfc,dfc
  2004.       o 68020: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,caar,cacr
  2005.       o 68030: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,caar,cacr
  2006.       o 68040: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,cacr
  2007.       o 68060: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,cacr
  2008.  
  2009. Example:
  2010.  
  2011.       o r ssp \ssp+4
  2012.       o r d0 44894489
  2013.  
  2014. -----------------------------------------------------------------------------
  2015.  
  2016. Syntax:
  2017.  
  2018.      RD [#<Unit>] <DiskOffset> <Length> <Destination>
  2019.  
  2020. Description:
  2021.  
  2022.      Read <Length> bytes from diskoffset <DiskOffset> of disk in unit <Unit>
  2023.      to memory at <Destination>. The default <Unit> is the
  2024.      current-device-unit. <DiskOffset> can also be odd.
  2025.  
  2026. Example:
  2027.  
  2028.       o rd #0 !880*200 4 80000 ; read first 4 bytes to $80000 from sector
  2029.         !880
  2030.  
  2031. -----------------------------------------------------------------------------
  2032.  
  2033. Syntax:
  2034.  
  2035.      RES
  2036.  
  2037.      RESOURCES
  2038.  
  2039. Description:
  2040.  
  2041.      Lists all currently available resources.
  2042.  
  2043. Example:
  2044.  
  2045.       o res
  2046.  
  2047. -----------------------------------------------------------------------------
  2048.  
  2049. Syntax:
  2050.  
  2051.      RESET
  2052.  
  2053. Description:
  2054.  
  2055.      The function will immediatly perform a reset.
  2056.  
  2057. Example:
  2058.  
  2059.       o reset
  2060.  
  2061. -----------------------------------------------------------------------------
  2062. Syntax:
  2063.  
  2064.      RF [<FPU-REG> <Value>]
  2065.  
  2066. Description:
  2067.  
  2068.      If arguments are not given the current registers will be shown. If
  2069.      arguments are used the fpu-register <FPU-REG> can be set to value
  2070.      <Value>.
  2071.  
  2072.      The following registers are available:
  2073.  
  2074.       o 68881/68882/68040: fp0-fp7,fpsr,fpcr,fpiar (Currently they can not be
  2075.         modifed!)
  2076.  
  2077. Example:
  2078.  
  2079.       o rf
  2080.  
  2081. -----------------------------------------------------------------------------
  2082.  
  2083. Syntax:
  2084.  
  2085.      RM [<MMU-REG> <Value>]
  2086.  
  2087. Description:
  2088.  
  2089.      If arguments are not given the current registers will be shown. If
  2090.      arguments are used the mmu-register <MMU-REG> can be set to value
  2091.      <Value>.
  2092.  
  2093.      The following registers are available:
  2094.  
  2095.       o 68000/68010: none
  2096.       o 68851/68030: tt0,tt1,srp (lower long),srp.0 (lower long), srp.1
  2097.         (upper long),crp (lower long),crp.0 (lower long), crp.1 (upper
  2098.         long),sr,tc
  2099.       o 68040/68060: itt0,itt1,dtt0,dtt1,srp,urp,tc,sr
  2100.  
  2101. Example:
  2102.  
  2103.       o rm tc 81235678
  2104.       o rm dtt0 0
  2105.  
  2106. -----------------------------------------------------------------------------
  2107.  
  2108. Syntax:
  2109.  
  2110.      RS [#<Unit>] <Sector> <SectorAmount> <Destination>
  2111.  
  2112. Description:
  2113.  
  2114.      Read <SectorAmount> sectors from sector <Sector> and following of unit
  2115.      <Unit> to memory at <Destination>. The default <Unit> is the
  2116.      current-device-unit.
  2117.  
  2118. Example:
  2119.  
  2120.       o rs !880 1 80000
  2121.  
  2122. -----------------------------------------------------------------------------
  2123.  
  2124. Syntax:
  2125.  
  2126.      RT [#<Unit>] <Track> <TrackAmount> <Destination>
  2127.  
  2128. Description:
  2129.  
  2130.      Read <TrackAmount> tracks from track <Track> and following of disk in
  2131.      unit <Unit> to memory at <Destination>.The default <Unit> is the
  2132.      current-device-unit.
  2133.  
  2134. Example:
  2135.  
  2136.       o rt !80 1 80000
  2137.  
  2138. -----------------------------------------------------------------------------
  2139.  
  2140. Syntax:
  2141.  
  2142.      SA <Start> [<End>]
  2143.  
  2144. Description:
  2145.  
  2146.      Save current programm to memory starting from <Start>. <End> is the
  2147.      upper boundary for the programm data. If not given it will use as much
  2148.      memory as needed. Freezed programm-data can be reloaded using the LA
  2149.      command.
  2150.  
  2151. Example:
  2152.  
  2153.       o sa 7c00000 7fa0000
  2154.  
  2155. -----------------------------------------------------------------------------
  2156.  
  2157. Syntax:
  2158.  
  2159.      SE <Filename>
  2160.  
  2161. Description:
  2162.  
  2163.      Save envirement to given file <Filename>. The settings can be loaded
  2164.      using the LE command.
  2165.  
  2166. Example:
  2167.  
  2168.       o se "hd1:tk/tk.prefs"
  2169.  
  2170. -----------------------------------------------------------------------------
  2171.  
  2172. Syntax:
  2173.  
  2174.      SETX
  2175.  
  2176.      SETEXCEPTIONS
  2177.  
  2178. Description:
  2179.  
  2180.      This command will install a exception-'handler' into the actual
  2181.      programm. If the programm should crash now it will come back into TK.
  2182.      You can check out what happend and maybe solve the 'bug'. The following
  2183.      vectors are patched:
  2184.  
  2185.       o +$08: BUS-ERROR exception
  2186.       o +$0c: ADDRESS-ERROR exception
  2187.       o +$10: ILLEGAL-COMMAND exception
  2188.       o +$14: DIVISION BY ZERO exception
  2189.       o +$24: TRACE exception
  2190.       o +$28: LINA-A exception
  2191.       o +$2c: LINE-F exception (no fpu/mmu?)
  2192.  
  2193. Example:
  2194.  
  2195.       o SETX
  2196.  
  2197. -----------------------------------------------------------------------------
  2198.  
  2199. Syntax:
  2200.  
  2201.      SHOWSTACKFRAME
  2202.  
  2203. Description:
  2204.  
  2205.      Show the stackframe of the freezed program.
  2206.  
  2207. Example:
  2208.  
  2209.       o showstackframe
  2210.  
  2211. -----------------------------------------------------------------------------
  2212.  
  2213. Syntax:
  2214.  
  2215.      SI [<Count>]
  2216.  
  2217. Description:
  2218.  
  2219.      Skip <Count> command (eg jsr/bsr is one command). The default value for
  2220.      <Count> is one. Note that the disassembly is used to calculate the new
  2221.      address.
  2222.  
  2223. Example:
  2224.  
  2225.       o si 5
  2226.  
  2227. -----------------------------------------------------------------------------
  2228.  
  2229. Syntax:
  2230.  
  2231.      SIM [<Rawkey>]
  2232.  
  2233. Description:
  2234.  
  2235.      The function will install a faked NMI-simulator into the system by
  2236.      patching directly the +$68 keyboard interrupt vector. If the user now
  2237.      presses the selected key it will simulate a NMI. This will only work if
  2238.      the interrupt is not disabled and the vector is not changed. The
  2239.      specfied key must be given as a rawkey code. Check out the GETKEY
  2240.      function. If no argument is given and the simulator is not installed the
  2241.      patch is added with the default rawkey $5d ('*' on the keypad). If no
  2242.      argument is given and the simulator is installed the patch will be
  2243.      removed. In the other cases the rawkey will be redefined.
  2244.  
  2245. Example:
  2246.  
  2247.       o sim
  2248.  
  2249. -----------------------------------------------------------------------------
  2250.  
  2251. Syntax:
  2252.  
  2253.      SM <Filename>,<Start> <End>
  2254.  
  2255.      WB <Filename>,<Start> <End>
  2256.  
  2257. Description:
  2258.  
  2259.      Save memory from <Start> to <End> to data-file <Filename>. If you
  2260.      overwrite a file the old filename is not changed! (eg. old 'AbCd', save
  2261.      'ABCD', result 'AbCd')
  2262.  
  2263. Example:
  2264.  
  2265.       o sm "hd1:tk/tk.exe",100000 120000
  2266.  
  2267. -----------------------------------------------------------------------------
  2268.  
  2269. Syntax:
  2270.  
  2271.      ST [<Count>]
  2272.  
  2273. Description:
  2274.  
  2275.      Exit and execute <Count> command. Programm is traced step by step (eg
  2276.      trace into jsr/bsr). The default value for <Count> is one.
  2277.  
  2278. Example:
  2279.  
  2280.       o st
  2281.       o st !100000
  2282.  
  2283. -----------------------------------------------------------------------------
  2284.  
  2285. Syntax:
  2286.  
  2287.      T <Value>
  2288.  
  2289. Description:
  2290.  
  2291.      Remove all address in buffer for training which do not hold <Value>.
  2292.      Then continue collecting all address which hold <Value>. Scanned memory
  2293.      was set by the TS command. Multiple use is possible. The command can
  2294.      only be used in byte-value-trainer-mode.
  2295.  
  2296. Example:
  2297.  
  2298.       o ts 5,780000 7c00000
  2299.       o x
  2300.       o t 4
  2301.  
  2302. -----------------------------------------------------------------------------
  2303.  
  2304. Syntax:
  2305.  
  2306.      TASKS
  2307.  
  2308. Description:
  2309.  
  2310.      Lists all currently available tasks. The tasks are listed in 3
  2311.      categories : ready,waiting,running. A 'P' indicates a process and a 'T'
  2312.      a task. The first value is pointer to the task/process structure, the
  2313.      second one is a pointer to the stack of the process (the first long at
  2314.      this address points to the routine that will be executed when the task
  2315.      is running again (must be in the wait-list for that))
  2316.  
  2317. Example:
  2318.  
  2319.       o tasks
  2320.         ..
  2321.         P: $07989c88 $0798fd94 MagicWB-Demon {C:MagicWB-Demon}
  2322.         ; a process, task node at $7989c88, first call to *798fd94, name
  2323.         'Magic..', Process command 'C:Magic..)
  2324.  
  2325. -----------------------------------------------------------------------------
  2326.  
  2327. Syntax:
  2328.  
  2329.      TB <Start> <End>
  2330.  
  2331. Description:
  2332.  
  2333.      Set location of buffer for training to memory from <Start> to <End>.
  2334.  
  2335. Example:
  2336.  
  2337.       o tb 7c00000 7f80000
  2338.  
  2339. -----------------------------------------------------------------------------
  2340.  
  2341. Syntax:
  2342.  
  2343.      TBD
  2344.  
  2345. Description:
  2346.  
  2347.      Reset location of buffer for training to default. The internal reserved
  2348.      memory is used.
  2349.  
  2350. Example:
  2351.  
  2352.       o tbd
  2353.  
  2354. -----------------------------------------------------------------------------
  2355.  
  2356. Syntax:
  2357.  
  2358.      TBV
  2359.  
  2360. Description:
  2361.  
  2362.      View current location of buffer for training.
  2363.  
  2364. Example:
  2365.  
  2366.       o tbv
  2367.  
  2368. -----------------------------------------------------------------------------
  2369.  
  2370. Syntax:
  2371.  
  2372.      TDC
  2373.  
  2374. Description:
  2375.  
  2376.      If the deep-trainer-mode is already active all stored address are
  2377.      compared to their current value. If the value has changed the address is
  2378.      kept in the buffer, so only address that have changed are kept in the
  2379.      buffer. As usual the command tries to continue scanning the given
  2380.      [Range] . See also the TDS command. The command can only be used in the
  2381.      deep-trainer-mode.
  2382.  
  2383. Example:
  2384.  
  2385.       o tdc
  2386.  
  2387. -----------------------------------------------------------------------------
  2388.  
  2389. Syntax:
  2390.  
  2391.      TDS [Range]
  2392.  
  2393. Description:
  2394.  
  2395.      If deep-trainer-mode is not active, it will be enabled now. All address
  2396.      in [Range] are stored in the buffer for training. If [Range] can not be
  2397.      scanned in one pass you can repeat the operation by using the TDS/TDC
  2398.      command. If the deep-trainer-mode is already active all stored address
  2399.      are compared to their current value. If the value has changed the
  2400.      address is removed, so only address that have not changed are kept in
  2401.      the buffer. As usual the command tries to continue scanning the given
  2402.      [Range] . Note that eg 'TDS 80000 90000' will not restart the
  2403.      deep-trainer if it was already active, in this case the [Range] paramter
  2404.      is ignored!. Using the command the first time will enable the
  2405.      deep-trainer-mode. This function needs around three bytes per stored
  2406.      address.
  2407.  
  2408. Example:
  2409.  
  2410.       o tds 780000 7c00000
  2411.       o tds
  2412.  
  2413. -----------------------------------------------------------------------------
  2414.  
  2415. Syntax:
  2416.  
  2417.      TDV
  2418.  
  2419. Description:
  2420.  
  2421.      View all address in the buffer for training. See also the
  2422.      TDS/TDCcommand. The command can only be used in the deep-trainer-mode.
  2423.  
  2424. Example:
  2425.  
  2426.       o tdv
  2427.  
  2428. -----------------------------------------------------------------------------
  2429.  
  2430. Syntax:
  2431.  
  2432.      TDX
  2433.  
  2434. Description:
  2435.  
  2436.      Free buffer for training, so that it can be used for
  2437.      byte-value-trainer-mode. All address in the deep-trainer-mode are lost.
  2438.      The command can only be used in deep-trainer-mode.
  2439.  
  2440. Example:
  2441.  
  2442.       o tdx
  2443.  
  2444. -----------------------------------------------------------------------------
  2445.  
  2446. Syntax:
  2447.  
  2448.      TR [<Count>]
  2449.  
  2450. Description:
  2451.  
  2452.      Exit and execute <Count> command. Programm is traced command by command
  2453.      (eg no trace into jsr/bsr). The default value for <Count> is one.
  2454.  
  2455. Example:
  2456.  
  2457.       o tr
  2458.       o tr 5
  2459.  
  2460. -----------------------------------------------------------------------------
  2461.  
  2462. Syntax:
  2463.  
  2464.      TRACKER [<Start>]
  2465.  
  2466. Description:
  2467.  
  2468.      Start the module-ripper. The memory is scanned for known modules.
  2469.      Currently the usual 31-sample noise/protracker, prorunner v2 and the
  2470.      player6.1a is included. If <Start> is specfied the scan is started at
  2471.      the given address (only chipmem!)
  2472.  
  2473. Example:
  2474.  
  2475.       o tracker
  2476.  
  2477. -----------------------------------------------------------------------------
  2478. Syntax:
  2479.  
  2480.      TRANS <Start> <End> <Destination>
  2481.  
  2482. Description:
  2483.  
  2484.      Copy memory from <Start> to <End> to memory at <Destination>.
  2485.  
  2486. Example:
  2487.  
  2488.       o trans f80000 f90000 80000
  2489.  
  2490. -----------------------------------------------------------------------------
  2491.  
  2492. Syntax:
  2493.  
  2494.      TS <Value> [,Range]
  2495.  
  2496. Description:
  2497.  
  2498.      Init buffer for training and collect all address in [Range] which hold
  2499.      the byte <Value>. If [Range] can not be scanned in one pass you can
  2500.      repeat the operation by using the T command. The command enables the
  2501.      byte-value-trainer-mode. This function needs around 2 bytes per stored
  2502.      address.
  2503.  
  2504. Example:
  2505.  
  2506.       o ts 5,780000 7c00000
  2507.  
  2508. -----------------------------------------------------------------------------
  2509.  
  2510. Syntax:
  2511.  
  2512.      TV
  2513.  
  2514. Description:
  2515.  
  2516.      View all address in buffer for training. The command can only be used in
  2517.      the byte-value-trainer-mode.
  2518.  
  2519. Example:
  2520.  
  2521.       o ts 5,780000 7c00000
  2522.       o x
  2523.       o t 4
  2524.  
  2525. -----------------------------------------------------------------------------
  2526.  
  2527. Syntax:
  2528.  
  2529.      TX
  2530.  
  2531. Description:
  2532.  
  2533.      Free buffer for training, so that it can be used for the
  2534.      deep-trainer-mode. All address in the byte-value-trainer-mode are lost.
  2535.      The command can only be used in byte-value-trainer-mode.
  2536.  
  2537. Example:
  2538.  
  2539.       o ts 99
  2540.       o tx
  2541.       o tds
  2542.  
  2543. -----------------------------------------------------------------------------
  2544.  
  2545. Syntax:
  2546.  
  2547.      TYPE <Filename>
  2548.  
  2549.      LESS <Filename>
  2550.  
  2551.      MORE<Filename>
  2552.  
  2553. Description:
  2554.  
  2555.      Type text-file <Filename> to screen.
  2556.  
  2557. Example:
  2558.  
  2559.       o type "df0:s/startup-sequence"
  2560.  
  2561. -----------------------------------------------------------------------------
  2562.  
  2563. Syntax:
  2564.  
  2565.      USEBLIT
  2566.  
  2567. Description:
  2568.  
  2569.      Use the blitter for scrolling. On slow machines(68000) this method
  2570.      allows realtime scrolling on small screens. The major disadvantage is
  2571.      the loss of the blitter custom-regs, so use with care!
  2572.  
  2573. Example:
  2574.  
  2575.       o useblit
  2576.  
  2577. -----------------------------------------------------------------------------
  2578. Syntax:
  2579.  
  2580.      USECPU
  2581.  
  2582. Description:
  2583.  
  2584.      Use the processor for scrolling. On faster machines(68020++) this method
  2585.      allows realtime scrolling on big screens, too. Also the blitter
  2586.      custom-regs are not touched.
  2587.  
  2588. Example:
  2589.  
  2590.       o usecpu
  2591.  
  2592. -----------------------------------------------------------------------------
  2593. Syntax:
  2594.  
  2595.      VERSION
  2596.  
  2597. Description:
  2598.  
  2599.      The current version number is shown.
  2600.  
  2601. Example:
  2602.  
  2603.       o version
  2604.  
  2605. -----------------------------------------------------------------------------
  2606.  
  2607. Syntax:
  2608.  
  2609.      W [<CIA-REG>]
  2610.  
  2611. Description:
  2612.  
  2613.      If no paramter is specified it will show the first CIA register. The
  2614.      output can be edited (hit return to accept new values). Usually there
  2615.      are just $10 regs per CIA but they are multiplexed; so there are some
  2616.      more. The following flags exist:
  2617.  
  2618.       o '*': reg has been backuped correctly and will be written back
  2619.       o '?': reg has not been fully backuped and will not be written back;
  2620.  
  2621. Example:
  2622.  
  2623.       o w 7 ; show/edit TimerB-High
  2624.  
  2625. -----------------------------------------------------------------------------
  2626.  
  2627. Syntax:
  2628.  
  2629.      WD [#<Unit>] <DiskOffset> <Length> <Source>
  2630.  
  2631. Description:
  2632.  
  2633.      Write <Length> bytes to diskoffset <DiskOffset> of disk in unit <Unit>
  2634.      with memory at <Source>. The default <Unit> is the current-device-unit.
  2635.      <DiskOffset> can also be odd.
  2636.  
  2637. Example:
  2638.  
  2639.       o wd #0 !880*200 1 80000
  2640.  
  2641. -----------------------------------------------------------------------------
  2642.  
  2643. Syntax:
  2644.  
  2645.      WN [<Count>]
  2646.  
  2647. Description:
  2648.  
  2649.      Exit and return when the <Count>-th command after current position is
  2650.      executed.Note that the disassembly is used to calculate the ned address.
  2651.      Programm is not traced, instead a temporary breakpoint is set. The
  2652.      default value for <Count> is one.
  2653.  
  2654. Example:
  2655.  
  2656.       o wn 5
  2657.  
  2658. -----------------------------------------------------------------------------
  2659.  
  2660. Syntax:
  2661.  
  2662.      WPC <Address>
  2663.  
  2664. Description:
  2665.  
  2666.      Exit and return when command at <Address> is executed. Programm is
  2667.      traced and works also in ROM area.
  2668.  
  2669. Example:
  2670.  
  2671.       o wpc f800d2
  2672.  
  2673. -----------------------------------------------------------------------------
  2674.  
  2675. Syntax:
  2676.  
  2677.      WS [#<Unit>] <Sector> <SectorAmount> <Source>
  2678.  
  2679. Description:
  2680.  
  2681.      Write <SectorAmount> sectors to sector <Sector> and following of disk in
  2682.      unit <Unit> with memory at <Source>. The default <Unit> is the
  2683.      current-device-unit.
  2684.  
  2685. Example:
  2686.  
  2687.       o ws !880 1 80000
  2688.  
  2689. -----------------------------------------------------------------------------
  2690.  
  2691. Syntax:
  2692.  
  2693.      WT [#<Unit>] <Track> <TrackAmount> <Source>
  2694.  
  2695. Description:
  2696.  
  2697.      Write <TrackAmount> tracks to track <Track> and following of disk in
  2698.      unit <Unit> with memory at <Source>. The default <Unit> is the
  2699.      current-device-unit.
  2700.  
  2701. Example:
  2702.  
  2703.       o wt !80 1 80000
  2704.  
  2705. -----------------------------------------------------------------------------
  2706.  
  2707. Syntax:
  2708.  
  2709.      X
  2710.  
  2711. Description:
  2712.  
  2713.      Exit freezer programm and continue the freezed programm.
  2714.  
  2715. Example:
  2716.  
  2717.       o x
  2718.  
  2719. -----------------------------------------------------------------------------
  2720.  
  2721. Syntax:
  2722.  
  2723.      Y [#<Entries per row>] <Address>
  2724.  
  2725. Description:
  2726.  
  2727.      Display memory at <Address> as <Entries per row> binary bytes. Using
  2728.      optional paramters will define the default. The optinal parameter can be
  2729.      reseted by illegal values or just be using '#'.
  2730.  
  2731. Example:
  2732.  
  2733.       o y #1 80000
  2734.         $0080000 %01011111
  2735.  
  2736. -----------------------------------------------------------------------------
  2737.  
  2738. Thrill Kill - Argument description
  2739. -----------------------------------------------------------------------------
  2740.  
  2741.    o <Value>, <Count>, <Offset>, <Entries per row>, <TrapNumber>,
  2742.      ;4m<BreakpointNumber>, <Length>, <SectorAmount>, <TrackAmount>, <Sync>,
  2743.      ;4m<DMA-Length>,<BitShift>,<Rawkey>
  2744.    o <Address>, <Start>, <End>, <Destination>, <Source>
  2745.    o <String>,<Labelname>
  2746.    o <StringPattern>
  2747.    o <Bytes>
  2748.    o <PBytes>
  2749.    o <Range>
  2750.    o <DisassmeblyPattern>
  2751.    o <Path>
  2752.    o <Filename>
  2753.    o <Unit>
  2754.    o <DiskOffset>
  2755.    o <Sector>
  2756.    o <Track>
  2757.  
  2758. -----------------------------------------------------------------------------
  2759. Argument:
  2760.  
  2761.      <Value>, <Count>, <Offset>, <Entries per row>, <TrapNumber>,
  2762.      <BreakpointNumber>, <Length>, <SectorAmount>, <TrackAmount>, <Sync>,
  2763.      <DMA-Length>,<BitShift>,<Rawkey>
  2764.  
  2765. Description:
  2766.  
  2767.      These arguments are the base for almost every other argument. The
  2768.      argument parser supports many operators (listed below). The operator
  2769.      priority is 'left-assigned' or is defined by the used operator (see
  2770.      prefs setting). The base for any input is 10(dec) or 16(hex) (see prefs
  2771.      setting).
  2772.  
  2773.    o Simple values:
  2774.       o '!' <digits> : Parse digits following in dec-mode(base 10) (eg.
  2775.         '!123456789', '!10'='$a')
  2776.       o '$' <digits> : Parse digts following in hex-mode (base 16) (eg.
  2777.         '$44899521', '$10'='!16')
  2778.       o '%' <digits> : Parse digts following in bin-mode (base 2);dots are
  2779.         skipped for a better overview (eg. '%1111'='$f',
  2780.         '%00001111.11110000.00000000.11111111'='$0ff000ff')
  2781.       o '\<CPU-REG>' : The value of the specfied register is returned. The
  2782.         '\' is necessary if specified in the preferences. See the R command
  2783.         for available cpu-register.
  2784.       o '"<ascii-digits>"' : The value of the ascii-string is returend (eg.
  2785.         "A"='$41',"ABCD"='$41424344')
  2786.       o <labelname> : The value of the label is returned
  2787.    o Unary operators:
  2788.       o '~' <Value> : Exor following value (eg. '~$ff'='$ffffff00')
  2789.       o '+' <Value> :Do not negate following value, dummy operator (eg.
  2790.         '+$100'='$100')
  2791.       o '-' <Value> : Negate following value (eg '-1'='$fffffffe')
  2792.       o '{' <Value>, '*' <Value>: Dereference following value. The longword
  2793.         at <Value> is fetched. (eg. '*4'=*execbase)
  2794.    o Unary end operators:
  2795.       o <Value> '.B' : Extend <Value> from byte to longword (signed
  2796.         operation) (eg. '$80.b='$ffffff80')
  2797.       o <Value> '.W' : Extend <Value> from word to longword (signed
  2798.         operation) (eg. '$8000.w'='$ffff8000')
  2799.       o <Value> '.L' : Extend <Value> from longword to longword (dummy
  2800.         operation)
  2801.    o Binary operators (first operator in list has the lowest priority, the
  2802.      last one has the highest)
  2803.       o <Value1> = <Value2>, <Value1> == <Value2> : If <Value1> is the same
  2804.         as <Value2> result is 1 (true), else 0(false) (eg. '!10==$10' is
  2805.         false, '!10==$a' is true)
  2806.       o <Value1> != <Value2> : If <Value1> is the not the same as <Value2>
  2807.         result is 1 (true), else 0(false) (eg. '!10!=$10' is true, '!10!=$a'
  2808.         is false)
  2809.       o <Value1> < <Value2> : If <Value1> is less (signed) than <Value2>
  2810.         result is 1 (true), else 0(false) (eg. '!10<$10' is true)
  2811.       o <Value1> <= <Value2> : If <Value1> is less same (signed) than
  2812.         <Value2> result is 1 (true), else 0(false) (eg. '!10<=$10' is true)
  2813.       o <Value1> > <Value2> : If <Value1> is greater (signed) than <Value2>
  2814.         result is 1 (true), else 0(false) (eg. '$10>!10' is true)
  2815.       o <Value1> >= <Value2> : If <Value1> is greater same (signed) than
  2816.         <Value2> result is 1 (true), else 0(false) (eg. '$a>=!10' is true)
  2817.       o <Value1> && <Value2> : If <Value1> and <Value2> are true the result
  2818.         is 1 (true), else 0(false) (eg. '0&&1' is false)
  2819.       o <Value1> || <Value2> : If <Value1> or <Value2> is true the result is
  2820.         1 (true), else 0(false) (eg. '1||0' is true)
  2821.       o <Value1> & <Value2> : The result is <Value1> (bitwise) and <Value2>
  2822.         (eg. '$101&$ff'='1')
  2823.       o <Value1> ! <Value2> : The result is <Value1> (bitwise) or <Value2>
  2824.         (eg. '$101!$ff'='$1ff')
  2825.       o <Value1> ~ <Value2> : The result is <Value1> (bitwise) xor <Value2>
  2826.         (eg. '$101~$ff'='$1ff')
  2827.       o <Value1> + <Value2> : The result is <Value1> plus <Value2> (eg.
  2828.         '2+4'='6')
  2829.       o <Value1> - <Value2> : The result is <Value1> minus <Value2> (eg.
  2830.         '2-4'='-2')
  2831.       o <Value1> * <Value2> : The result is <Value1> multiplied with <Value2>
  2832.         (eg. '2*4'='8')
  2833.       o <Value1> / <Value2> : The result is <Value1> divided by <Value2> (eg.
  2834.         '5/2'='2')
  2835.       o <Value1> % <Value2> : The result is the rest of <Value1> diveded by
  2836.         <Value2> (eg. '5%2'='1')
  2837.       o <Value1> << <Value2> : The result is <Value1> shifted by <Value2>
  2838.         bits left (eg. '1<<!31'='$80000000')
  2839.       o <Value1> >> <Value2> : The result is <Value1> shifted by <Value2>
  2840.         bits right (eg. '$80000000>>!31'='1')
  2841.       o <Value1> ^ <Value2> : The result is <Value1> to the power of <Value2>
  2842.         (eg. '2^!31'='$80000000')
  2843.  
  2844. Example:
  2845.  
  2846.       o *4 ; address of execbase
  2847.       o *((*(*4+$9c)+$17c)+$28) ; cuurent beamcon0
  2848.       o (2+3*4==2+(3*4)) ; is true if operator priority is enabled
  2849.  
  2850. -----------------------------------------------------------------------------
  2851.  
  2852. Argument:
  2853.  
  2854.      <Address>, <Start>, <End>, <Destination>, <Source>
  2855.  
  2856. Description:
  2857.  
  2858.      These arguments are parsed the same like <Value>. The received address
  2859.      is then validated. If the address conflicts with the the current
  2860.      memory-mode (see prefs setting) it will report an error. If eg. <Start>
  2861.      and <End> is used then <End> must be higher than <Start> and both must
  2862.      be in a continous memory-block. (eg not from $1f0000 to $f80000 -
  2863.      depends on the mmeory-mode!)
  2864.  
  2865. Example:
  2866.  
  2867.       o $10000+4*100
  2868.  
  2869. -----------------------------------------------------------------------------
  2870. Argument:
  2871.  
  2872.      <String>,<Labelname>
  2873.  
  2874. Description:
  2875.  
  2876.      A plain string can be started either with " or a ' and must of course
  2877.      end with it. However, if you do not use ",' the string will be
  2878.      uppercased and will terminate at the first space or tab.
  2879.  
  2880. Example:
  2881.  
  2882.       o "amiga"
  2883.       o "amiga'
  2884.       o amiga ; identicall to "AMIGA"
  2885.  
  2886. -----------------------------------------------------------------------------
  2887. Argument:
  2888.  
  2889.      <StringPattern>
  2890.  
  2891. Description:
  2892.  
  2893.      The argument <StringPattern> is just a <String> which holds some special
  2894.      symbols. The following wildcards are available: '?' (single wild-char)
  2895.      and '*','#?' (multiple wild-chars). The pattern is incasesensitive.
  2896.  
  2897. Example:
  2898.  
  2899.       o '*dir'
  2900.  
  2901. -----------------------------------------------------------------------------
  2902.  
  2903. Argument:
  2904.  
  2905.      <Bytes>
  2906.  
  2907. Description:
  2908.  
  2909.      The argument is usually use for searching mutliple bytes. <Bytes> is
  2910.      build up of multiple <Value> or <strings> seperated by a space. The
  2911.      value must be given is hex-mode! Only the low bytes of a value is used.
  2912.      However, strings will be converted to multiple bytes.
  2913.  
  2914. Example:
  2915.  
  2916.       o $45 45 ; same as 45 45
  2917.       o 45 890 45 ; same as 45 90 45
  2918.       o "password" 00
  2919.       o "diskname" 0 "sync" $0a $00 ; searches what it means!
  2920.  
  2921. -----------------------------------------------------------------------------
  2922.  
  2923. Argument:
  2924.  
  2925.      <PBytes>
  2926.  
  2927. Description:
  2928.  
  2929.      The argument is given in the same ways as in argument <Bytes>. If the
  2930.      parsed value (byte sized) included a '?' the upper/lower nibble is
  2931.      marked as a wildcard.
  2932.  
  2933. Example:
  2934.  
  2935.       o ?? 00; same as if you would search just $00
  2936.       o "d" ?? ?? ".library" ; will find eg 'dos.library'
  2937.       o 8? ?? ?? ?8 "SXI!"
  2938.       o "diskname" ?? "sync" $?? $00 ; searches what it means!
  2939.  
  2940. -----------------------------------------------------------------------------
  2941.  
  2942. Argument:
  2943.  
  2944.      <Range>
  2945.  
  2946. Description:
  2947.  
  2948.      The argument <Range> is build up of a list of <Address>. If the argument
  2949.      <Range> is not used all available memory pages are scanned. A single
  2950.      address as argument means that the scan will start at the specfied
  2951.      address (instead of $00000000). A additional (second) address is used to
  2952.      determinate when to stop. (check out the memory setting)
  2953.  
  2954. Example:
  2955.  
  2956.       o <no arg> ; scan all available pages
  2957.       o $80000 ; scan all available pages starting at $80000
  2958.       o $1f8000 $7880000 ; may scan $1f8000-$200000,$7800000-$7880000
  2959.  
  2960. -----------------------------------------------------------------------------
  2961.  
  2962. Argument:
  2963.  
  2964.      <DisassmeblyPattern>
  2965.  
  2966. Description:
  2967.  
  2968.      The argument <DisassemblyPattern> is just a <String> which holds some
  2969.      special symbols. The following wildcards are available: '?' (single
  2970.      wild-char) and '*','#?' (multiple wild-chars). The pattern is
  2971.      incasesensitive. A space is extended to a '*' wildcard. If the parser
  2972.      encounters a '\' it will use the pattern for the next command.
  2973.  
  2974. Example:
  2975.  
  2976.       o "movec ,vbr","MOVEC*,vbr*" ; same pattern
  2977.       o "move.l ,?0" ; finds eg "movea.l $7c.w,a0" but not "movea.l $7c.w,a0"
  2978.         (check out if destination is a address reg!)
  2979.       o "cmp*.l #$????????,*\b*\" ; find eg "cmp.l #$12345678,-$10(a7)\beq.l
  2980.         $80000"
  2981.  
  2982. -----------------------------------------------------------------------------
  2983.  
  2984. Argument:
  2985.  
  2986.      <Path>
  2987.  
  2988. Description:
  2989.  
  2990.      The argument <Path> is just a <String> which holds the device path. If
  2991.      no absolute path is used it is appended to the current path. The path my
  2992.      not point to a file!
  2993.  
  2994. Example:
  2995.  
  2996.       o "df0:tk/","df0:tk" ; absolute path
  2997.       o "tk" ; relative to the current path
  2998.  
  2999. -----------------------------------------------------------------------------
  3000.  
  3001. Argument:
  3002.  
  3003.      <Filename>
  3004.  
  3005. Description:
  3006.  
  3007.      The argument <Filename> is just a <String> which holds the filename. If
  3008.      no absolute path is used it is appended to the current path. The
  3009.      filename may not point to a directory!
  3010.  
  3011. Example:
  3012.  
  3013.       o "df0:tk.exe" ; absolute path
  3014.       o "tk.exe" ; relative to the current path
  3015.  
  3016. -----------------------------------------------------------------------------
  3017.  
  3018. Argument:
  3019.  
  3020.      <DiskOffset>
  3021.  
  3022. Description:
  3023.  
  3024.      The argument <DiskOffset> is just a <Value> which addresses the diskdata
  3025.      as one continous memory block. It must be lower than $dc0000
  3026.      (DD-Disk)/$1b8000(HD-Disk).
  3027.  
  3028. Example:
  3029.  
  3030.       o !880*200 ; root block (DD)
  3031.       o $c ; eg read data from diskoffset !12 (bootblock code)
  3032.  
  3033. -----------------------------------------------------------------------------
  3034.  
  3035. Argument:
  3036.  
  3037.      <Unit>
  3038.  
  3039. Description:
  3040.  
  3041.      The argument <Unit> is just a <Value> which determinats the drive to be
  3042.      used. <Unit> can only be 0(DF0),1(DF1),2(DF2),3(DF3).
  3043.  
  3044. Example:
  3045.  
  3046.       o 0 ; "df0:" (what to say else??)
  3047.  
  3048. -----------------------------------------------------------------------------
  3049.  
  3050. Argument:
  3051.  
  3052.      <Sector>
  3053.  
  3054. Description:
  3055.  
  3056.      The argument <Sector> is just a <Value> which addresses data on a disk.
  3057.      It must be lower than 1760(DD-Disk)/3520(HD-Disk). A sector has a size
  3058.      of $200 bytes.
  3059.  
  3060. Example:
  3061.  
  3062.       o !880 ; root.-block
  3063.  
  3064. -----------------------------------------------------------------------------
  3065.  
  3066. Argument:
  3067.  
  3068.      <Track>
  3069.  
  3070. Description:
  3071.  
  3072.      The argument <Track> is just a <Value> which addresses data on disk. It
  3073.      must be lower than 80(DD/HD-Disk). A track consists of
  3074.      11(DD-Disk)/22(HD-Disk) sectors. So a track has a length of $2c00/$5800
  3075.      bytes.
  3076.  
  3077. Example:
  3078.  
  3079.       o !80 ; track with root-block (DD)
  3080.  
  3081. -----------------------------------------------------------------------------
  3082.  
  3083. Thrill Kill - How to make a NMI-button
  3084. -----------------------------------------------------------------------------
  3085.  
  3086. If you want to use TK you must have a NMI-button, else you will not be able
  3087. to enter TK at any point, because the software patches are usually eliminated
  3088. by eg NDOS-programms. If you have never soldered anything try to find someone
  3089. who can do it for you, though its very easy (in my opinion..) You need the
  3090. following stuff:
  3091.  
  3092.    o 1 x button (on/off)
  3093.    o 3 x diodes (no special type required, (at least 10V/100mA, i think) eg
  3094.      1N4148, 1N4001-7 or any universial diode)
  3095.    o some wires and the usual equipment to solder
  3096.  
  3097. You must connect a ground signal to one pin of the button and the other
  3098. button pin to every cathode of thediodes and from their anodes to the IPL0,
  3099. IPL1, IPL2 signal, so quite easy. (If the instruction for your computer is
  3100. missing do it yourself or find someone...). Make sure that the black ring of
  3101. the diodes point to the button and not to the ipl lines. It should look like
  3102. this
  3103.  
  3104.    o IPL0 ----------------------- |>| ----\
  3105.    o IPL1 ----------------------- |>| ------------ BUTTON ----- GROUND
  3106.    o IPL2 ----------------------- |>| ----/
  3107.  
  3108. Note: '..--|>|--..is a diode which anode is left and cathode is right!
  3109.  
  3110. LAST WARNING! NO WARRANTY FOR ANY INSTRUCTION LISTED BELOW!! LAST WARNING!
  3111.  
  3112. A1200:
  3113.  
  3114.    o I would advise to use the internal 150-pin expansion connector.The
  3115.      ipl-lines are at pin 81, 82, 83 and the ground is eg at pin 79 (take a
  3116.      look at your A1200 manual for verification). If you have a cpu-card
  3117.      installed try so solder on the connector of it.
  3118.      The expansion connector looks like this:
  3119.  
  3120.                                  ...|IPL1|...
  3121.                                       |
  3122.      (upper half) |2|4|6|8|..........|82|......|148|150|
  3123.      (lower half) |1|3|5|7|.......|79|81|83|...|147|149|
  3124.                                    /   |   \
  3125.                             ...|GROUND|IPL0|IPL2|...
  3126.  
  3127.      (PIN 81) IPL0 ------- |>| ----\
  3128.      (PIN 82) IPL1 ------- |>| ------- BUTTON --- GROUND (PIN 79)
  3129.      (PIN 83) IPL2 ------- |>| ----/
  3130.  
  3131. A4000 (and maybe A3000):
  3132.  
  3133.      I would advise to use the internal 200-pin expansion connector of the
  3134.      cpu-card, because all other connectors do not support the ipl-signals
  3135.      (including the Zorro2/3 slots!!). Unfortunatly, i have not found a
  3136.      description where all signals are described with correct pin numbers, so
  3137.      i will just give a exact pin-location. If you have a manual where the
  3138.      pins are described try to contact me. You should solder on the upper
  3139.      side (the one where the connector pins are soldered to the card). The
  3140.      following instructions were tested on a A4000 with a 68030 and 68040
  3141.      original cpu card. It should also work with the cyberstorm cards! (not
  3142.      tested yet!, no warranty!)
  3143.      The expansion connector looks like this:
  3144.  
  3145.      /--------------------------------------------------------------\
  3146.      |                                                              |
  3147.      |   x x x x ... x x x x x x x x x       x x x x ... x x x x    |
  3148.      |    x x x x ... x x I J K x x x x       x x x x ... x x x x   |
  3149.      | O x x x x ... x x x x x x x x x       x x x x ... x x x x  O |
  3150.      |    x x x x ... x x x x x x x x         x x x x ... x x x G   |
  3151.      |                                                              |
  3152.      | ()                                                        () |
  3153.      .                                                              .
  3154.      .                                                              .
  3155.      | ()                                                        () |
  3156.      \--------------------------------------------------------------/
  3157.  
  3158.      I,J,K: IPL signals, G:GROUND signal
  3159.  
  3160.      I(IPL) ------- |>| ----\
  3161.      J(IPL) ------- |>| ------- BUTTON --- G (GROUND)
  3162.      K(IPL) ------- |>| ----/
  3163.  
  3164.      BTW: I use this hardware patch!
  3165.  
  3166. A500/A2000:
  3167.  
  3168.    o I would advise to use the external 86-pin expansion connector.The
  3169.      ipl-lines are at pin 40, 42, 44 and the ground is eg at pin 37 (take a
  3170.      look at your A500 manual for verification).
  3171.      The expansion connector looks like this:
  3172.  
  3173.                             ...|IPL0|IPL1|IPL2|...
  3174.                                    \  |   /
  3175.      (upper half) |2|4|6|8|.......|40|42|44|.....|84|86|
  3176.      (lower half) |1|3|5|7|....|37|..............|84|85|
  3177.                                 |
  3178.                           ...|GROUND|...
  3179.  
  3180.      (PIN 40) IPL0 ------- |>| ----\
  3181.      (PIN 42) IPL1 ------- |>| ------- BUTTON --- GROUND (PIN 37)
  3182.      (PIN 44) IPL2 ------- |>| ----/
  3183.    o The internal 86-pin-MMU-connector of the A2000 has the same pin
  3184.      assignment as the A500 86-pin connector. However if want to use a
  3185.      Zorro2-slot then you need just to connect the EINT7-signal (pin 40)
  3186.      directly via a button to a ground signal (eg pin 37). Take a look at
  3187.      your A2000 manual for verification.
  3188.  
  3189. -----------------------------------------------------------------------------
  3190.  
  3191. Thrill Kill - Registration/Demo limits/How to order
  3192. -----------------------------------------------------------------------------
  3193.  
  3194. If you run the demo version the following restrictions are active:
  3195.  
  3196.    o No write operations are possible (SM,MFMW,SE,SA,WT,WS,WD,..)
  3197.    o No external trainer buffer! (TB,TBD)
  3198.    o No deep-trainer! (TDS/TDC)
  3199.    o Assembling is not possible! (A)
  3200.    o The demo version is basically a crippled standard version of TK
  3201.    o Max 10 entries into TK, then TK will lock you system. You will have to
  3202.      do a reset to get out!
  3203.  
  3204. If you register you can decide between two versions available, the standard
  3205. and the professional. The professional versions includes some commands which
  3206. are used very seldom or need special equipment (eg a working mmu). The
  3207. following commands are only available in the professional version:
  3208.  
  3209.    o All mmu functions (MMUV,MMUS,MMUSW,MMUD,MMUDA)
  3210.    o A dis-/assembler for special code (A,D)
  3211.    o Commands for direct-ram-freezing (LA,SA)
  3212.    o Any programm launched from system can be catched before execution
  3213.      ;4m(CATCHFILE)
  3214.    o Find disassembly allows multiple line matching (FD)
  3215.    o Probably find special code (FC) (but not with my lib!)
  3216.  
  3217. Notice the following rules:
  3218.  
  3219.    o The money can only be send to my bank-account (no mail-queues etc..)
  3220.    o You pay in advance, then you get the software
  3221.    o You should contact me before sending the money
  3222.    o I prefer sending the software via e-mail/internet or via modem (the
  3223.      fastest method)
  3224.    o Its not impossible to send TK via snail (ask'n'hope)
  3225.    o If you order from outside germany make sure that the correct amount of
  3226.      german marks will be transfered by your bank
  3227.    o NO WARRANTY FOR ANY DATA LOST BY USING TK !
  3228.  
  3229. If you order please include a short description about your
  3230. system-configuration (not necessary)
  3231.  
  3232.    o cpu
  3233.    o mmu
  3234.    o fpu
  3235.    o memory + its location
  3236.    o amiga model
  3237.  
  3238. The standard version costs 200-DM. Yet i am not sure about the price for the
  3239. professional version, just ask!
  3240. Finally if you want to order contact me (or Goldman) and leave a message with
  3241. your wish. You will receive a bank-account nr to send the money to.
  3242. -----------------------------------------------------------------------------
  3243. Thrill Kill - Yet known bugs
  3244. -----------------------------------------------------------------------------
  3245.  
  3246. The following bugs are yet known:
  3247.  
  3248.   1. No support for graphics-cards, and other kewl equipment. Tk can not
  3249.      support every available hardware.
  3250.   2. TK does not like programms who also use the MMU, especially on 68040++.
  3251.   3. Strange things happen if you access memory higher $0ffffff on some A4000
  3252.      (but not mine :)).. all custom regs are gone and much more. TK gives its
  3253.      best to restore the custom regs, but however its not a magican. (you
  3254.      have to generate an own setting which does not do a memory detect for
  3255.      $1dc00000++)
  3256.   4. TK can not debug programms who misuse the stackpoiner (a general problem
  3257.      of all freezers!)
  3258.   5. The simple NMI-button cause multiple instances of NMIs. They may blow up
  3259.      the internal/external stack.
  3260.  
  3261. -----------------------------------------------------------------------------
  3262.  
  3263. Thrill Kill - History
  3264. -----------------------------------------------------------------------------
  3265.  
  3266.    o Version 1.04:
  3267.       o first real public release
  3268.  
  3269. -----------------------------------------------------------------------------
  3270.  
  3271. Thrill Kill - Contact
  3272. -----------------------------------------------------------------------------
  3273.  
  3274. Information about registration, bug reports, new featues or anything else
  3275. available can be obtained via
  3276.  
  3277.    o e-mail: Leave a message to 'ajunk@uni-paderborn.de' with subject 'TK'
  3278.      and your question. (be very patient...)
  3279.    o WWW: (will be soon available..be patient)
  3280.    o BBS: Call 'Straight Hate' and use the 'c' command to leave me(ferox) or
  3281.      goldman a message (use login:'customer', password:'kill')
  3282.    o IRC: You may find me in one of the following channels: 'AmiElite',
  3283.      'AmigaSCNE', 'Amiga', 'AmigaGER' (my nick is 'ferox')
  3284.      I will try to setup a channel named 'ThrillKill' for TK-support.
  3285.  
  3286. Leave a message to 'Goldman' (my beta-tester NR 1) on a scene bbs (especially
  3287. the Sunflex Inc. boards).
  3288. You may also try to post a message to 'ferox' on some bbs (be warned! i do
  3289. not visit them often).
  3290.  
  3291. -----------------------------------------------------------------------------
  3292.  
  3293. Thrill Kill - Future
  3294. -----------------------------------------------------------------------------
  3295.  
  3296. The following things are (not) planned:
  3297.  
  3298.   1. Improved freezer ability (there are still some games which could be
  3299.      freezed 100%)
  3300.   2. More compatibility (just how..)
  3301.   3. Better OS-filesystem support (to less fun..)
  3302.   4. A better NMI-button hardware (the easy NMI-button has major
  3303.      disadvantages, tough its very easy to implement)
  3304.   5. A amigaguide documentation (Has anyone a html-to-amigaguide converter
  3305.      ??)
  3306.   6. A PPC dis- and assembler (not even started yet)
  3307.   7. A PPC version (not even started yet)
  3308.   8. Maybe a hardware version (but not for the 680x0 versions)
  3309.   9. No picture saver (For what ? Only if really many many would request
  3310.      it...)
  3311.  
  3312. -----------------------------------------------------------------------------
  3313.  
  3314.