home *** CD-ROM | disk | FTP | other *** search
Text File | 1996-12-14 | 110.4 KB | 3,315 lines |
- Title: Thrill Kill - The documentation
-
-
- -----------------------------------------------------------------------------
- Thrill Kill - Documentation
- -----------------------------------------------------------------------------
-
- o Disclaimer
- o Read first/Introduction
- o Requirements
- o General usage
- o The preferences
- o The editor
- o Command description - alphabetically
- o Command description - sorted by groups
- o Argument description
- o How to make a NMI-button
- o Registration/Demo limits/How to order
- o Yet known bugs
- o History
- o Contact
- o Future
-
- -----------------------------------------------------------------------------
-
- Disclaimer
- -----------------------------------------------------------------------------
-
- THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE
- LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDER AND/OR
- OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND,
- EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
- ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.
- SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY
- SERVICING, REPAIR OR CORRECTION.
-
- IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL
- ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY REDISTRIBUTE THE PROGRAM AS
- PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL,
- SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR
- INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR
- DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR
- A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH
- HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
-
- -----------------------------------------------------------------------------
- Thrill Kill - Read first/Introduction
- -----------------------------------------------------------------------------
-
- If you do not know what a debugger, freezer is or if you have never
- programmed in assembler - forget it - i do not think that TK is something for
- you -(except if you just want to train some games..)
-
- You probaly know the famous action replay. It was cool! However it was slow,
- partly bugged and missed major commands. When aga came out there was no toy
- for those machines. No real update came out - the software version of the
- action replay was buggy like... . TK is a freezer like the action replay, a
- lot commands have the same syntax. If you were used to ar then you will find
- usage very easy. TK supports a maximum of freezer possibility, if you take
- the time to check out all available functions/settings. This means you have
- to have major knowledge of your amiga-hardware. If you do not have it then i
- doubt that you can use the real power of this toy! Of course, TK can not
- offer such kind of invisibility like the ar as it does not need a 'special'
- hardware (beside a NMI-button). If you enjoy the demo version, think its
- useful and do not want to register do not wait for a cracked version. Every
- registrated version of TK has its own personal id. Any misuse of a registered
- version will be punished (!!!).
-
- Just a last note! TK patches nearly the whole system! It can not be
- compatible with any hardware configuration available (eg gfxcards..). I give
- no warranty for any damage caused by TK! You use it on your own risk!
-
- BTW: The html-documentation is best viewed with NETSCAPE3.0, else read the
- text version!
-
- Enough said...check out the demo..
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - Requirements
- -----------------------------------------------------------------------------
-
- TK was designed to run on a system with a mmu, but it also works on non-mmu
- system. I use tk on a A4000 with 68030/25/68882 (with mmu) and 2 meg chip and
- 8 meg fast memory. I personally think it works very stable. However even some
- A4000 have strange behaviour when acessing non existing memory. (eg Goldmans'
- machine: accessing memory higher $0fffffff will cause not a bus-error (set to
- dsack) but it kicks around with the custom-regs - they are defintly lost.) As
- you are a talented user you can change the settings to suit for your
- configuration (eg disable the memory detection for the $1dc00000++ memory)
- and load them before TK is initialized!
-
- TK was tested on:
-
- o A4000/30.25.mmu/68882/2mb-chip/8mb-fast at $7800000++
- o A4000/30.25.mmu/2mb-chip/16mb-fast at $7000000++
- o A1200/30.50.mmu/2mb-chip/8mb-fast at $1dc00000++ (blizzard3, however
- Icarus reported trouble with the blizzard2..i will check this )
- o A1200/30.50.mmu/2mb-chip/4mb-fast at $200000++ (mtec)
- o A500/00.7.nommu/1mb-chip/1.5mb-'fast' at $c00000
- o A4000/40.25.mmu/2mb-chip/8mb-fast at $7800000++ (thanx to apollo for
- lending me his card, i hope it stills runs on 040 as i patched a lot of
- stuff since then)
-
- I can not promise that TK will run immediatly on your system. However if you
- have problems contact me, i will try to fix any incompatibility! So if the
- demo-version runs on your computer then the registered version will also work
- fine.
-
- Before i forget it you need kickstart 3.0++ to use all functions (especially
- the ones to privatize memory). It works also fine with kick 2.04 (some
- functions will not work), but i do not think it will run suitable on
- kickstarts less 2.04! TK does not like programms that use the mmu (like vmm
- programms) TK does not support gfx-cards!
-
- I hope it will also run on a 68060...not checked yet (also i think it should
- if it works on 68040..)
-
- -----------------------------------------------------------------------------
- Thrill Kill - General usage
- -----------------------------------------------------------------------------
-
- Here is a list of some (maybe) interesting topics:
-
- o Breakpoints(=brp) can be manipulated by B, BS, BD, BDA. Breakpoints can
- be marked with illegal or trap codes (see preferences). Whenever you
- enter TK all breakpoints are removed, when you leave TK they are set
- again. Do not forget that the breakpoints run via the +$10/$80..$bc
- vectors.
- o MemoryAccessRanges(=mar) can be used to get out which command did a
- read/write access to the selected memory. The programm will be trace
- step-by-step and the commands will be analyzed.It will return to TK
- before the specified memory is accessed. MARs are very slow and will not
- catch interrups. (If you want to catch interrupts than eg set a
- breakpoint to the first command of the interrupt code..) Check
- MAV,MAS,MAD,MADA.
- o MemoryWatchPoints(=mwp) can be used to get out which command modified
- the selected memory. The programm will be traced step-by-step to
- determinate all manipulations. It will return to TK after the specified
- memory has benn modfied. (so check the previous command) MWPs are slow
- and will not catch interrupt routines. (If you want to catch interrupts
- than eg set a breakpoint to the first command of the interrupt code..)
- Check MV, MS, MD, MDA.
- o The VBR-Faker installs a own vbr who simulates the origional. This will
- allow you to enter programms who manipulate the vectors at $0 and do not
- change the vbr. If the programm should change the vbr, loacte the
- command, set a breakpoint and adjust the vbr manually, skip the command
- and leave - all should be fine. (In AR4,HRTMON this is default, but not
- in TK!) Do this also if the programm move the vbr anywhere else. (see
- ;4mpreferences)
- o MMU-Catchlists can be changed by MMUV, MMUS, MMUSW, MMUD, MMUDA and
- check the preferences. The function allows you a quick and reliable way
- to get out all commands which access a certain memory range. This slows
- the system just a bit down. Interrupt code is also checked. Make sure
- that the +$8 (bus-error) vector is not destroyed by the programm. The
- functions are only available in to professional version and require a
- MMU!
- o The ByteValueTrainer(=bvt) allows to search single byte values. The
- trainer is started with the TS command. Whenever the watched value
- changes run the Tcommand.(also if you think this would eliminate some
- address) This will eleminate all invalid address and scan yet not
- checked address. You must increase the size of the trainer-buffer if you
- would like to scan the whole memory in one pass. Check TS, T, TX, TV,
- TB,TBD, TBV. Each stored address needs about 2 bytes.
- o The DeepTrainer(=dt) allows you to search staying/changing byte values.
- The trainer is started with the TDS command. Whenever the watched value
- changes run the TDC command to eliminate all address which have not
- changed. Use the TDS command to elimnate all address which have changed.
- After TDS/TDS the yet unchecked memory is checked. Each stored address
- needs about 3 bytes. This trainer mode needs a lot of memory. In general
- its advised to use an external trainer buffer (TB, TBV, TBD) Check also
- ;4mTDS, TDC, TDX, TDV
- o The usage of a external TrainerBuffer is recommended whenever you want
- to scan a memory range in a few passes, especially for the deep-trainer.
- Its not unusual to have buffers with a size of 4MB or more..
- o Privatizing is a preference option which allows you to remove memory
- from the system. This memory can be used for trainer-buffer, to freeze
- the programm or for other purpose. Check also INFO.
- o MMU-CustomBackup is a option which simulates a mirror ram for
- $dff000-$dff200. By this way we do not need an external hardware which
- does exactly this. The only disadvantage is that the system is slowed
- down and the +$8(bus-error) vector is used.
- o Labels are just a little short-cut for often used address, etc. They can
- be easily in any expression. Check LAB, DLAB ,DLABA.
- o FileSystemManagement is supported for DD/HD-disks and also
- IDE-harddisk-partitions. Only DOS\0, DOS\1, DOS\2, DOS\3 are supported.
- However also DOS\4, DOS\5 can be read. Soft-/Hardlinks are not
- supported. Check CD, DIR, DELETE, MAKEDIR, TYPE, LM, SM.
- o The programm 'TK.REV' allows you to load TK to the end of the available
- memory. This needs kickstart 3.0++. The effect is that TK will not lay
- somewhere in the middle of a memory page (especiilly if you privatize
- memory). Make sure 'TK.EXE' is in the same path.
- o 'TK.EXE' will not do dynamic allocation of memory. This means you can
- relocate the code eg to $7f00000 and load its binary image to this
- address.
-
- -----------------------------------------------------------------------------
- Thrill Kill - The preferences
-
- -----------------------------------------------------------------------------
-
- The preferences can be loaded and saved by the LE and SE commands
- In the TK-surface you have to press <F3> to enter the preference menu
- If you launch TK from shell and use as argument '-<your-prefs-file-any-path>'
- the selected prefs will be loaded before TK is started. This allows you to
- disable/enable functions which may cause conflicts.
- In the prefs-menu you can manipulate the following commands:
-
- o Freezer preferences:
-
- o Custom-backup:
- o Minimum: Only custom-register that are destroyed by TK are
- backuped and restored. This will work with games like soccer-kid.
- (check out the copper faker)
- o Maximum: Most custom-register are backuped and restored, including
- register that are not destroyed by TK. This is necessary for
- saving a complete programm. If you do not have a mmu/hadrware you
- must adjust the register manually by the E command. If you want to
- save a freezed programm the option should be enabled. Make sure
- that you have enabled mmu-custom-backup or something equal.
- o CIA-backup:
- o Fast: The CIA-register are backuped in a fast way (eg the disksync
- interrupt bit in the ICR will not be backuped)
- o Most: This will try to backup most register. However, not all
- register can be backuped without an immense time consumption (like
- the ALARM regs). You can manully manipulate the CIA-register with
- the W command.
- o DrivesOn:
- o Selected: When you enter TK and some disk-drives where on, only
- drives selected in PRB/CIA-B will be enabled again.
- o All: All drives will be turned on. (but not selected)
- o Brp-Entrance:
- o Illegal: Sets the breakpoint-code to illegal (dc.w $4afc) and
- vector +$10. This may conflict with other running debuggers (eg
- monam)
- o Trap #x: Sets the breakpoint-code to trap#x (dc.w $4e4x) and
- vector +$80+4*x. Make sure that the traps are not used be the
- programm you debug.
- o ExecValid:
- o Yes: Make the asumption that system is running and exec,etc.. is
- available. If system is not available this may cause major errors
- (loops...etc). Set only if you want to use a system-command,you
- know system is alive and TK thinks its not available.
- o no: Make the asumption that system is not running. All
- ;4msystem-command are not available.
- o check: This will try to determinate if system is running or not.
- o MemAccess:
- o RAM: Your can read/write/access only the memory that was detected
- by TK, check the INFO command.
- o RAM+ROM: Your can read/write/access only memory that was detected
- by TK plus the ROM-area.
- o ALL: You can read/write/access the whole memory.Make sure you
- access only memory that will not let your machine crash.
- o VBRFaker:
- o YES: This will exchange the freezed-programm-vbr with an own
- vbr-simulator. This will allow you to enter programms which modify
- the NMI-vector. However if you programm changes the vbr itself you
- will not be able to enter TK again (in general). If you find such
- a command set a breakpoint there, then adjust the vbr manually and
- skip the command - works fine.
- o NO: If the vbr-simulator was active it will be removed, else
- nothing happens. (default)
- o ROM-Avoid(NMI):
- o YES: This disables entries via NMI if the freezed programm is
- currently in a ROM memory.
- o NO: You can enter TK via NMI at any time.
- o TK-Memaccess:
- o YES: This allows you to read/write/access the TK memory.
- o NO: You can not read/write/acess the TK memory.
-
- o Editor preferences:
- o Scrolling:
- o BLITTER: The blitter will be used to scroll. If you want real-time
- scrolling on 68000 then enable this option. The disadvantage is
- that the blitter register will be destroyed! The blitter register
- can be modified manually by the E command.
- o CPU: The cpu will be used to scroll. This is faster than blitter
- on 68020++. Also if you want to scroll in real-time on bigger
- screen this option must be enabled.
- o Insert-Mode:
- o YES: If you hit a key the chars left from the current cursor
- location will be shifted left before the new char is inserted. The
- last char in the row is lost.
- o NO: If you hit a key the char at the current cursor loaction is
- replaced with the hit key. Use <TAB> to force a insert.
- o Show-Page:
- o If enabled and you jump to a new page, the page number will be
- written to the right-top corner of the screen.
- o Cursor-Type:
- o LINE: The cursor will have the form of a line
- o DOUBLE: The cursor will have the form of a thick line
- o BLOCK: The cursor will have the form of a block
- o Keyboard:
- o GERMAN: The german keymap will be active.
- o US: The us keymap will be active.
- o BackGroundColor:
- o The default background color of the TK-surface can be set in
- 12-bit-RGB format
- o CharColor:
- o The default char color of the TK-surface can be set in 12-bit-RGB
- format
- o CharColor2:
- o The default char color for the MP command.
- o WaitingColor:
- o The default background color in hold-mode for the TK-surface can
- be set in 12-bit-RGB format
- o BlinkColor1:
- o The first cursor color (alternating) of the TK-surface can be set
- in 12-bit-RGB format
- o BlinkColor2:
- o The second cursor color (alternating) of the TK-surface can be set
- in 12-bit-RGB format.
- o BlinkTime:
- o Amount of frames between alternating the cursor color (swap
- between BlinkColor1 and BlinkColor2)
- o KeyRepeatDelay:
- o Amount of frames before a key is repeated
- o KeyRepeatSpeed:
- o Amount of frames between each key repeat
-
- o Screenmode preferences:
- o Screenmode:
- o NTSC: A NTSC screen (640x200,60Hz) will be used
- o PAL: A PAL screen (640x256,50Hz) will be used
- o CUSTOM: The register in the CUSTOM area will be used to set up
- screen
- o EURO72: A EURO72 screen (640x400,70Hz) will be used
- o DBLPAL: A DBLPAL screen (640x512,50Hz) will be used
- o CUSTOM2: The register in the CUSTOM2 area will be used to set up
- screen
- o ScreenBlank:
- o If enabled and you use a aga-screen mode then the border-color
- will be black, else the border has the same color as the
- background
- o If you know how to setup a screen by hardware then you can optimize
- your screen. This is not described here, check out ecs/aga
- documentation. NO WARRANTY FOR ANY DAMAGE!
- o Reset preferences:
- o Screenmode:
- o PAL: The boot-picture will be shown on a PAL-screen
- o NTSC: The boot -picture will be shown on a NTSC-screen
- o MemorySequence:
- o SKIP: No special operation is done.
- o TEST: The detected memory is checked for any ram-failure.
- o CLEAR: The detected memory is filled with the clear-pattern.
- o TEST&CLEAR: The detected memory is checked and filled with the
- clear-pattern.
- o ClearPattern:
- o The pattern used to fill memory. Usefull to find a suitable place
- for patch-routines.
- o External-BusTimeoutMode:
- o IGNORE: If you have not a A4000 then this option should be
- enabled.
- o DSACK: If you access not-available memory on a A4000 usually a
- bus-error is generated (and a long delay). With this option you
- can set it to DSACK which results in no bus-errors and short
- delays.
- o BUSERR: This is the system-default TimeoutMode for the A4000
- o KickStartPatch:
- o This will enable all patches done when the kickstart is launched.
- If this option is disabled all private-functions are disabled.
- o ChipMemStart:
- o Defines the location where the chip-memory starts (eg at
- $100000-). Unused memory will be privatized.
- o ChipMemEnd:
- o Defines the location where the chip-memory ends. Unused memory
- will be privatized.
- o ExpansionMemoryX-Private:
- o This option allows you to deactivate memory used by the system.
- Unused memory will be privatized.
- o ClearBreakpoints:
- o All breakpoints will be cleared on reset.
- o ClearMemoryWatchpoints:
- o All memory-watchpoints will be cleared on reset.
- o ClearMemoryAccessranges:
- o All memory-accessranges will be clear on reset.
- o DetectChipmem:
- o Specifies the memory-range TK searches for chip-memory.
- o DetectExpansionMemoryX:
- o Specifies the memory-range TK searches for fast-memory. If your
- memory is not detected by default then you can add your memory
- manually. Also usefull if you get conflicts raised by illegal
- memory accesses.
-
- o Misc preferences:
- o AutoVerify:
- o If enabled all disk-write operations will be verified.
- o Support HD-disks:
- o If enabled you can read/write high-density disks. This needs more
- internal memory. Disable if you want eg a larger internal
- trainer-buffer.
- o Internal-TimeoutBusMode:
- o IGNORE: If you have not a A4000 then this option should be
- enabled.
- o DSACK: This option should be enabled if you have a A4000, else the
- memory detection will hang up your system.
- o BUSERR: This is the system-default TimeoutMode for the A4000
- o HighestTrack:
- o Here you can overwrite the upper tracklimit, so that you can also
- read/write tracks 80-85.
- NO WARRARNTY FOR ANY DAMAGE CAUSED BY TK!!
- o Add EjectTask:
- o Add a Eject-Task to system which will do a automatic 'diskchange'
- to any media modified in TK.
- o CustomFrom:
- o USER: The user has to adjust the custom-register before he leaves
- TK.
- o SYSTEM: Some destroyed custom-register are read from system. Only
- possible if system is intact.
- o HARDWARE: If you have hardware installed it will be used to
- restore the custom-register.
- o MMU: The MMU will be used to restore the custom-register. Make
- sure the PrivateMMU option is enabled
- o CustomMMU-Flicker:
- o If enabled, the freezed programm will do a little flicker whenever
- a write operation to a custom register is done.
- o Default Valuemode:
- o HEX: The default value base is 16. Like in the action-replay
- o DEC: The default value base is 10. Like in asm-one.
- o ParseCpuReg:
- o TRY: The parser tries to match a valid cpu-register in every
- expression. (eg 'd d0' will not disassemble at $d0)
- o SLASH: If you want to use cpu-register in expressions just by a
- leading '\' you have to enable this.
- o ParsePriority:
- o OPERATOR: Each operator has a specific priority, which is used to
- calculate a expression. (eg '2+3*4'='14')
- o LEFT-ASSIGNED: The 'left' operator has always a greater priority.
- (eg '2+3*4'='24')
- o CatchCustomBootBlock:
- o Whenever the system tries to boot from a non-default
- disk-bootblock it will enter TK before execution. The pc will
- point to the first command of the bootblock.
- o PrivateMMU:
- o If enabled a own mmu-pagetable is set up. Must be enabled to use
- the CustomMMU function. Do no enable if you run a VMM programm.
- o ALT-FX:
- o Here you can define the fast-macros. Multiple command are
- possible.
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - The editor
- -----------------------------------------------------------------------------
-
- The basic surface for TK is the so called editor. Its like a system-shell
- with special commands and functions. The keyboard type can be changed by the
- preferences. Beside the usual keys the following functions are
- available:
-
- o <F1> : Clear screen
- o <F2> : Toogle Insert-/Overwritemode
- o <F3> : Enter preferences
- o <F4> : Repeat last command
- o <F5> : Enter 'debugger'
- o <F6> : Jump to page 1
- o <F7> : Jump to page 2
- o <F8> : Jump to page 3
- o <F9> : Jump to page 4
- o <F10> : Jump to page 5
- o <SHIFT>+<F6> : Copy actual page to page 1
- o <SHIFT>+<F7> : Copy actual page to page 2
- o <SHIFT>+<F8> : Copy actual page to page 3
- o <SHIFT>+<F9> : Copy actual page to page 4
- o <SHIFT>+<F10> : Copy actual page to page 5
- o <ALT>+<FX> : Execute fast macro x, (macros can be modified in in the
- ;4mpreferences)
- o <AMIGA>+<F5> : Make snapshot and save it
- o <ESC> : Abort/Cancel current running commands (if supported)
- o <TAB> : Insert space at current position
- o <HELP> : Show internal help
- o <SHIFT> : Hold/Pause current command (if supported)
- o <AMIGA>+<SHIFT>+<ESC> : Emergency exit!! This command allows you to
- leave TK any any time. This can be useful to return when a command
- (should) hang up. BE WARNED! You can abort the write-commands, too, this
- can cause major damage to your harddisk etc..
-
- Some commands support 'fast signs'. This means that if you scroll up/down and
- in the top/bottom line is a 'fast sign' the programm will automatically
- generate the previous/next line. Eg. you can easily disassemblel
- up/down.(check out)
- -----------------------------------------------------------------------------
- Thrill Kill - Command description
- -----------------------------------------------------------------------------
-
- Command index - alphabetically
-
- o ? <Value>
- o A <Address>
- o ADD <Bytes>,<Start> <End>
- o AND <Bytes>,<Start> <End>
- o AVAIL
- o B
- o BOOTCHK <Address>
- o BD <Address>
- o BD #<BreakpointNumber>
- o BDA
- o BITCHK <Address>
- o BLKCHK <Address>
- o BS [#<BreakpointNumber>] <Address>
- o BT #<TrapNumber>
- o BTI
- o CATCHFILE <StringPattern>
- o CD [Path]
- o COMP <Start> <End> <Destination>
- o D [#<Mode>]<Address>
- o DELETE <Filename>
- o DEVS
- o DEVICES
- o DIR [Path]
- o DISKLEN [#Unit] [LOW <Track>] [HIGH <Track>]
- o DLAB <Labelname>
- o DLABA
- o E[<CUSTOM-REG>]
- o EOR <Bytes>,<Start> <End>
- o F <Bytes> [,Range]
- o FA <Address> [,Range]
- o FAQ <Address> [,Range]
- o FAR <Start> <End> [,Range]
- o FARQ <Start> <End> [,Range]
- o FC [Range]
- o FCQ [Range]
- o FD <DisassemblyPattern> [,Range]
- o FDQ <DisassemblyPattern> [,Range]M[.<B|W|L] [#<Entries per row>]
- ;4m<Address>
- o FP <PBytes> [,Range]
- o FR <Bytes> [,Range]
- o FS <Bytes> [,Range]
- o G <Address>
- o GETKEY
- o HELP
- o INFO
- o INTS
- o INTERRUPTS
- o LA <Address>
- o LAB <Labelname>=<Value>
- o LABS
- o LABELS
- o LE <Filename>
- o LESS <Filename>
- o LIBS
- o LIBRARIES
- o LM <Filename>,<Start> [<End>]
- o LS [Path]
- o M[.<B|W|L] [#<Entries per row>] <Address>
- o MA
- o MAD <Start> <End>
- o MADA
- o MAKEDIR <Path>
- o MAS <Start> <End>
- o MD <Address>
- o MDA
- o MEM
- o MFMC <Start> <End> <Destination>
- o MFMD <Start> <End> <Destination>
- o MFMR [#<Unit>] [INDEX] [SYNC=<SYNC>] <Track> <DMA-Length> <Destination>
- o MFMSL <Start> <End> <Destination> <BitShift>
- o MFMSR <Start> <End> <Destination> <BitShift>
- o MFMSS <Start> <End> <Destination> <Sync>
- o MFMW [#<Unit>] [INDEX] <Track> <DMA-Length> <Source>
- o MKDIR <Path>
- o MMUD <Start> <End>
- o MMUDA
- o MMUS <Start> <End>
- o MMUSW <Start> <End>
- o MMUV
- o MORE <Filename>
- o MP
- o MS [.<B|W|L] <Address>
- o MV
- o N [#<Entries per row>] <Address>
- o NO <Offset>
- o O <Bytes>,<Start> <End>
- o OR <Bytes>,<Start> <End>
- o PORTS
- o Q <Start> <End> <Destination>
- o R [<CPU-REG> <Value>]
- o RB <Filename>,<Start> [<End>]
- o RD [#<Unit>] <DiskOffset> <Length> <Destination>
- o RESET
- o RES
- o RESOURCES
- o RF [<FPU-REG> <Value>]
- o RM [<MMU-REG> <Value>]
- o RS [#<Unit>] <Sector> <SectorAmount> <Destination>
- o RT [#<Unit>] <Track> <TrackAmount> <Destination>
- o SA <Start> [<End>]
- o SE <Filename>
- o SETX
- o SETEXCEPTIONS
- o SHOWSTACKFRAME
- o SI [<Count>]
- o SIM <Rawkey>
- o SM <Filename>,<Start> <End>
- o ST [<Count>]
- o T <Value>
- o TASKS
- o TB <Start> <End>
- o TBD
- o TBV
- o TDC
- o TDS [Range]
- o TDV
- o TDX
- o TR [<Count>]
- o TRACKER [<START>]
- o TRANS <Start> <End> <Destination>
- o TS <Value> [,Range]
- o TV
- o TX
- o TYPE <Filename>
- o USEBLIT
- o USECPU
- o VERSION
- o W [<CIA-REG>]
- o WB <Filename>,<Start> <End>
- o WD [#<Unit>] <DiskOffset> <Length> <Source>
- o WN [<Count>]
- o WPC <Address>
- o WS [#<Unit>] <Sector> <SectorAmount> <Source>
- o WT [#<Unit>] <Track> <TrackAmount> <Source>
- o X
- o Y [#<Entries per row>] <Address>
-
- -----------------------------------------------------------------------------
-
- Command index - sorted by command groups
-
- o Commands for manipulation
- o Commands for searching data
- o Commands for manipulating breakpoints
- o Commands for 'Trace' actions
- o Commands for MMU manipulation
- o Commands for 'Training' actions
- o Commands for io-access
- o Commands for diskio-access only
- o Commands for mfm manipulation
- o Commands for misc usage
- o Commands for sys usage
-
- -----------------------------------------------------------------------------
- Commands for manipulation
-
- o A <Address>
- o ADD <Bytes>,<Start> <End>
- o AND <Bytes>,<Start> <End>
- o CATCHFILE <StringPattern>
- o COMP <Start> <End> <Destination>
- o D [#<Mode>]<Address>
- o E[<CUSTOM-REG>]
- o EOR <Bytes>,<Start> <End>
- o G <Address>
- o M[.<B|W|L] [#<Entries per row>] <Address>
- o N [#<Entries per row>] <Address>
- o NO <Offset>
- o LA <Address>
- o O <Bytes>,<Start> <End>
- o OR <Bytes>,<Start> <End>
- o Q <Start> <End> <Destination>
- o R [<CPU-REG> <Value>]
- o RF [<FPU-REG> <Value>]
- o RM [<MMU-REG> <Value>]
- o SA <Start> [<End>]
- o SETEXCEPTIONS
- o SETX
- o SIM <Rawkey>
- o TRANS <Start> <End> <Destination>
- o W [<CIA-REG>]
- o X
- o Y [#<Entries per row>] <Address>
-
- Commands for searching data
-
- o F <Bytes> [,Range]
- o FA <Address> [,Range]
- o FAQ <Address> [,Range]
- o FAR <Start> <End> [,Range]
- o FARQ <Start> <End> [,Range]
- o FC [Range]
- o FCQ [Range]
- o FD <DisassemblyPattern> [,Range]
- o FDQ <DisassemblyPattern> [,Range]
- o FP <PBytes> [,Range]
- o FR <Bytes> [,Range]
- o FS <Bytes> [,Range]
-
- Commands for manipulating breakpoints
-
- o B
- o BD <Address>
- o BD #<BreakpointNumber>
- o BDA
- o BT #<TrapNumber>
- o BTI
- o BS [#<BreakpointNumber>] <Address>
-
- Commands for 'Trace' actions
-
- o MA
- o MAD <Start> <End>
- o MADA
- o MAS <Start> <End>
- o MD <Address>
- o MDA
- o MS [.<B|W|L] <Address>
- o MV
- o SI [<Count>]
- o ST [<Count>]
- o TR [<Count>]
- o WN [<Count>]
- o WPC <Address>
-
- Commands for MMU manipulation
-
- o MMUD <Start> <End>
- o MMUDA
- o MMUS <Start> <End>
- o MMUSW <Start> <End>
- o MMUV
- o RM [<MMU-REG> <Value>]
-
- Commands for 'Training' actions
-
- o T <Value>
- o TB <Start> <End>
- o TBD
- o TBV
- o TDC
- o TDS [Range]
- o TDV
- o TDX
- o TS <Value> [,Range]
- o TV
- o TX
-
- Commands for io-access
-
- o CD [Path]
- o DELETE <Filename>
- o DIR [Path]
- o LESS <Filename>
- o LM <Filename>,<Start> [<End>]
- o LS [Path]
- o MAKEDIR <Path>
- o MORE <Filename>
- o RB <Filename>,<Start> [<End>]
- o SM <Filename>,<Start> <End>
- o TYPE <Filename>
- o WB <Filename>,<Start> <End>
-
- Commands for diskio-access only
-
- o BITCHK <Address>
- o BLKCHK <Address>
- o BOOTCHK <Address>
- o RD [#<Unit>] <DiskOffset> <Length> <Destination>
- o RS [#<Unit>] <Sector> <SectorAmount> <Destination>
- o RT [#<Unit>] <Track> <TrackAmount> <Destination>
- o WD [#<Unit>] <DiskOffset> <Length> <Source>
- o WS [#<Unit>] <Sector> <SectorAmount> <Source>
- o WT [#<Unit>] <Track> <TrackAmount> <Source>
-
- Commands for mfm manipulation
-
- o DISKLEN [#Unit] [LOW <Track>] [HIGH <Track>]
- o MFMR [#<Unit>] [INDEX] [SYNC=<SYNC>] <Track> <DMA-Length> <Destination>
- o MFMW [#<Unit>] [INDEX] <Track> <DMA-Length> <Source>
- o MFMC <Start> <End> <Destination>
- o MFMD <Start> <End> <Destination>
- o MFMSL <Start> <End> <Destination> <BitShift>
- o MFMSR <Start> <End> <Destination> <BitShift>
- o MFMSS <Start> <End> <Destination> <Sync>
-
- Commands for misc usage
-
- o ? <Value>
- o DLAB <Labelname>
- o DLABA
- o GETKEY
- o HELP
- o INFO
- o LAB <Labelname>=<Value>
- o LABS
- o LABELS
- o LE <Filename>
- o MP
- o RESET
- o SE <Filename>
- o SHOWSTACKFRAME
- o TRACKER [<START>]
- o USEBLIT
- o USECPU
- o VERSION
-
- Commands for system usage
-
- o AVAIL
- o DEVS
- o DEVICES
- o INTS
- o INTERRUPTS
- o MEM
- o LIBS
- o LIBRARIES
- o PORTS
- o RES
- o RESOURCES
- o TASKS
-
- -----------------------------------------------------------------------------
-
- Commands description - no order
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- ? <Value>
-
- Description:
-
- Print value <Value> in differnt bases. This function can be used as a
- simple calculator.
-
- Example:
-
- o ? (!123*345%4|234)<<3
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- A <Address>
-
- Description:
-
- Start assembly at <Address>. The command uses the dis/assembler
- specified with the D command.
-
- Example:
-
- o a 100000
- ^$00100000 movec vbr,d0
- ^$00100004 btst #6,$bfe001
- ^$0010000c bne 100004
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- ADD <Bytes>,<Start> <End>
-
- Description:
-
- Add given pattern <Bytes> bytewise to memory from <Start> to <End>.
-
- Example:
-
- o add "Mok",80000 90000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- AND <Bytes>,<Start> <End>
-
- Description:
-
- And given pattern <Bytes> bytewise to memory from <Start> to <End>.
-
- Example:
-
- o and "Samir",80000 90000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- AVAIL
-
- MEM
-
- Description:
-
- Lists all currently available memory nodes and total memory usage.
-
- Example:
-
- o avail
-
- -----------------------------------------------------------------------------
- Syntax:
-
- B
-
- Description:
-
- Display all current breakpoints and breakpoint method.
-
- Example:
-
- o b
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BD #<BreakpointNumber>
-
- BD <Address>
-
- Description:
-
- Either delete breakpoint at <Address> or breakpoint with specified
- <BreakpointNumber>. The value of <BreakpointNumber> must be one of
- [0..31[.
-
- Example:
-
- o bd pc
- o bd 80000
- o bd #!31
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BDA
-
- Description:
-
- Delete all breakpoints.
-
- Example:
-
- o bda
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BITCHK <Address>
-
- Description:
-
- Correct bitmapblock-checksum for bitmapblock at <Address>.
-
- Example:
-
- o bitchk 10000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BLKCHK <Address>
-
- Description:
-
- Correct datablock-checksum for datablock at <Address>.
-
- Example:
-
- o blkchk 10000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BOOTCHK <Address>
-
- Description:
-
- Correct bootblock-checksum for bootblock at <Address>.
-
- Example:
-
- o bootchk 10000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BS [#<BreakpointNumber>] <Address>
-
- Description:
-
- Set breakpoint at <Address>. If <BreapointNumber> is not given the next
- free breakpoint is used. The value of <BreakpointNumber> must be one of
- [0..31[.
-
- Example:
-
- o bs 80000
- o bs #!31 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BT #<TrapNumber>
-
- Description:
-
- Set breakpoint method to 'trap #<TrapNumber>' (dc.w $4e4<TrapNumber>).
- The value of <Trapnumber> must be one of [0..15[.
-
- Example:
-
- o bt #f
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- BTI
-
- Description:
-
- Set breakpoint method to 'illegal' (dc.w $4afc) opcode.
-
- Example:
-
- o bti
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- CATCHFILE <StringPattern>
-
- Description:
-
- The function will patch the current LoadSeg() function from the the
- dos-library. If the system now tries to load a executable with the
- specified pattern/name TK will return before the executable is started.
- The patch is removed and the pc will point to the first instruction of
- the executable.
-
- Example:
-
- o catchfile *tk.exe ; this will catch all executables, including eg
- 'C:tk.exe'
- o catchfile tk.exe ; this will not catch eg 'C:tk.exe' !!
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- CD [Path]
-
- Description:
-
- The command will try to set the current-directory to given path. If
- [Path] is not given it will just show the current path.
-
- Example:
-
- o cd
- o cd hd1:tk/
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- D [#<Mode>]<Address>
-
- Description:
-
- Disassembly memory at <Address>. If address is zero the current pc is
- used. (like in the AR). The <Mode> argument allows you to use different
- dis- and assembler; default mode is zero.
-
- o 0 : usual 680x0 dis/assembler
- o 1 : RNC mode 1 (old)
- o 2 : RNC mode 2
-
- Example:
-
- o d f800d2
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- DELETE <Filename>
-
- Description:
-
- Delete file <Filename>.
-
- Example:
-
- o delete "hd1:tk/tk.exe"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- DEVS
-
- DEVICES
-
- Description:
-
- Lists all currently available devices.
-
- Example:
-
- o devs
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- DIR [Path]
-
- LS [Path]
-
- Description:
-
- The command will display the directory for given [Path]. If [Path] is
- not given it will use the current path.
-
- Example:
-
- o dir hd1:tk/
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- DISKLEN [#<Unit>] [LOW <Track>] [HIGH <Track>]
-
- Description:
-
- The function will determinate the disk-speed. Note that the data on the
- disk is lost (so use a empty one).
-
- Example:
-
- o disklen
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- DLAB <Labelname>
-
- Description:
-
- Delete label <Labelname>.
-
- Example:
-
- o dlab mfmload
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- DLABA
-
- Description:
-
- Delete all labels.
-
- Example:
-
- o dlaba
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- E [<CUSTOM-REG>]
-
- Description:
-
- If no paramter is specified it will show the first CUSTOM register. The
- output can be edited (hit return to accept new values). The following
- flags exist:
-
- o 'R': a read only register; just for information; no change possible
- o '-': reg has not been touched by TK; its kept at its original value;
- can be changed to '*'
- o '*': reg has been backuped correctly and will be written back
- o '?': reg has not been fully backuped but will be written back.
- (probably the reg was used by TK, too) It may be necessary to adjust
- it manually! (eg set $1dc to $20/$1bb8 for a PAL/MULTISCAN screen)
-
- Example:
-
- o e 1dc ; show/edit beamcon0
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- EOR <Bytes>,<Start> <End>
-
- Description:
-
- Eor bytewise memory from <Start> to <End> with given pattern <Bytes>.
-
- Example:
-
- o eor "Mok",80000 90000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- F <Bytes> [,Range]
-
- Description:
-
- Find all locations in [Range] where <Bytes> occures.
-
- Example:
-
- o f 4e 7b 00 f8 00 00
- o f "Hello" ; will find 'Hello' but not 'HELLO','hello'
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- FA <Address> [,Range]
-
- FAQ <Address> [,Range]
-
- Description:
-
- Find all commands in [Range] which refer to <Address>. This code is
- analyzed and all commands accessing <Address> are reported. Note that
- the current registers are used for scanning. If quick mode is used then
- the range-pointer is always increased by the command-size instead of 2.
- This means that you may loose valid locations.
-
- Example:
-
- o fa f800d2
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- FAR <Start> <End> [,Range]
-
- FARQ <Start> <End> [,Range]
-
- Description:
-
- Find all commands in [Range] which refer to memory from <Start> to
- <End>. This code is analyzed and all commands accessing specified memory
- are reported. Note that the current registers are used for scanning,
- too. If quick mode is used then the range-pointer is always increased by
- the command-size instead of 2. This means that you may loose valid
- locations.
-
- Example:
-
- o far dff09a dff09c,f80000 f90000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- FC [Range]
-
- FCQ [Range]
-
- Description:
-
- Find all commands in [Range] which match to the internal library.
-
- Example:
-
- o fcq
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- FD <DisassemblyPattern> [,Range]
-
- FDQ <DisassemblyPattern> [,Range]
-
- Description:
-
- Find all commands in [Range] which match to given pattern. The output of
- the disassmbler is check for given pattern. Note that you can also
- search for multiple commands. If quick mode is used then the
- range-pointer is always increased by the command-size instead of 2. This
- means that you may loose valid locations.
-
- Example:
-
- o fdq "\move.l $*,(a?)\\tst.l #?"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- FP <PBytes> [,Range]
-
- Description:
-
- Find all locations in [Range] where pattern <PBytes> occures.
-
- Example:
-
- o fp 4e ?? 00 ?8 00 0? ; will find eg $4e $4e $00 $f8 $00 $0f
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- FR <Bytes> [,Range]
-
- Description:
-
- Find all locations in [Range] where relative <Bytes> occures. This means
- that only a 'differnce-pattern' is searched. The given offset can be
- used for the NO command.
-
- Example:
-
- o f r "Hello" ; will find eg 'Hello','Ifmmp',..
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- FS <Bytes> [,Range]
-
- Description:
-
- Find all locations in [Range] where uppercased <Bytes> occures. This
- means that eg 'f' and 'F' is treated as same.
-
- Example:
-
- o fs "HeLLo" 0,80000 90000 ; will find eg 'HELLO','hello'
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- G <Address>
-
- Description:
-
- Exit freezer programm and continue the freezed programm at <Address>.
-
- Example:
-
- o r sr 2700
- o g f800d2
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- GETKEY
-
- Description:
-
- The function will output the rawkey-code of every pressed key. (No need
- to look into a book)
-
- Example:
-
- o getkey
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- HELP
-
- Description:
-
- Show help-page. Press the <Help> key for the same effect.
-
- Example:
-
- o help
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- INFO
-
- Description:
-
- Show global system-information like available mem, privatized mem, cpu,
- fpu, mmu, current trackpos of drives, head pos, available devices, to be
- ejected devices and much more (check out).
-
- Example:
-
- o info
-
- -----------------------------------------------------------------------------
- Syntax:
-
- INTS
-
- INTERRUPTS
-
- Description:
-
- Lists all currently available interrupts. The first value is a pointer
- to the interrupt node and the second one is a pointer to the interrupt
- code.
-
- Example:
-
- o ints
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- LA <Address>
-
- Description:
-
- Load frozen programm-data from memory at <Address>. A programm can be
- saved using the SA command.
-
- Example:
-
- o la 7c00000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- LAB <Labelname>=<Value>
-
- Description:
-
- Define label <Labelname> and set it to value <Value>. If the label
- already exists it will be redefined.
-
- Example:
-
- o lab sync=$9521
- o lab mfmload=824
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- LABS
-
- LABELS
-
- Description:
-
- Show all current defined labels.
-
- Example:
-
- o labs
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- LE <Filename>
-
- Description:
-
- Load envirement from given file <Filename>. Only settings that have been
- saved with the current programm version can be used. Settings can be
- genereated by the SE command.
-
- Example:
-
- o le "hd1:tk/tk.prefs"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- LIBS
-
- LIBRARIES
-
- Description:
-
- Lists all currently available libraries.
-
- Example:
-
- o libs
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- LM <Filename>,<Start> [<End>]
-
- RB <Filename>,<Start> [<End>]
-
- Description:
-
- Load data-file <Filename> to memory starting at <Start>. If <End> is
- given, data will only be loaded upto <End>.
-
- Example:
-
- o lm "hd1:tk/tk.exe",100000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- M[.<B|W|L] [#<Entries per row>] <Address>
-
- Description:
-
- Display memory at <Address> as <Entries per row> byte/word/long
- depending on the [.<B|W|L] parameter. The command uses the byte offset
- defined by the Y command. Using optional paramters will define the
- default paramter. The optinal parameter can be reseted by illegal values
- or just be using '#'.
-
- Example:
-
- o m.b #5 80000
- $0080000 $41 $42 $43 $44 $45 "ABCDE"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MA
-
- Description:
-
- View all current memory access ranges.
-
- Example:
-
- o ma
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MAD <Start> <End>
-
- Description:
-
- Delete memory access range at area from <Start> to <End>.
-
- Example:
-
- o mad dff000 dff200
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MADA
-
- Description:
-
- Delete all memory access ranges.
-
- Example:
-
- o mada
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MAKEDIR <Path>
-
- MKDIR <Path>
-
- Description:
-
- Creates a directory with for given <Path>.
-
- Example:
-
- o makedir "hd1:tk/tk.dir"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MAS <Start> <End>
-
- Description:
-
- Set memory access range to area from <Start> to <End>.
-
- Example:
-
- o mas dff000 dff200
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MD <Address>
-
- Description:
-
- Delete memory watch point at <Address>.
-
- Example:
-
- o md 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MDA
-
- Description:
-
- Delete all memory watch points.
-
- Example:
-
- o mda
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MFMC <Start> <End> <Destination>
-
- Description:
-
- Code data from <Start> to <End> into mfm-data stored at <Destination>.
- Each read long is coded into two mfm-longs (odd/even). This means that
- <End>-<Start> must be a multiple of four.
-
- Example:
-
- o mfmc 80000 82000 84000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MFMD <Start> <End> <Destination>
-
- Description:
-
- Decode mfm-data from <Start> to <End> to normal data stored at
- <Destination>. Each two read long (odd/even) are decoded into one long.
- This means that <End>-<Start> must be a multiple of eight.
-
- Example:
-
- o mfmd 84000 88000 90000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MFMR [#<Unit>] [INDEX] [SYNC=<Sync>] <Track> <DMA-Length> <Destination>
-
- Description:
-
- Read <DMA-Length> words of mfm-data from track <Track> of disk in unit
- <Unit> to memory at <Destination>. The default <Unit> is the
- current-device-unit. By default data will not be read on index or sync.
- Using keywords 'INDEX' or 'SYNC=<SYNC>' will enable these functions.
- Mfm-data is read directly by DMA. <Destination> may only be in
- chip-memory.
-
- Example:
-
- o mfmr #0 index sync=4489 0 2000 100000 ; will read $2000 words=$4000
- bytes !!
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MFMSL <Start> <End> <Destination> <BitShift>
-
- Description:
-
- Shift data from <Start> to <End> by <Bitshift> bits left and store it at
- <Destination>. Of course, this command can also be used for normal data.
- <Bitshift> must be lower than 16.
-
- Example:
-
- o mfmsl 84000 88000 90000 3
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MFMSR <Start> <End> <Destination> <BitShift>
-
- Description:
-
- Shift data from <Start> to <End> by <Bitshift> bits right and store it
- at <Destination>. Of course, this command can also be used for normal
- data. <Bitshift> must be lower than 16.
-
- Example:
-
- o mfmsr 84000 88000 90000 3
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MFMSS <Start> <End> <Destination> <Sync>
-
- Description:
-
- Search word <Sync> in data from <Start> to <End>. If <Sync> is found all
- following data are copied to <Destination>, including the found sync.
- This command is very usefull for 'sync-read-by-hand'.
-
- Example:
-
- o mfmr 0 2000 80000
- o mfmss 80000 84000 90000 4489
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MFMW [#<Unit>] [INDEX] <Track> <DMA-Length> <Source>
-
- Description:
-
- Write <DMA-Length> words of mfm-data to track <Track> of disk in unit
- <Unit> with memory at <Source>. The default <Unit> is the
- current-device-unit. By default data will not be written on index. Using
- keyword 'INDEX' will enable this function. Mfm-data is written directly
- by DMA. <Source> may only be in chip-memory.
-
- Example:
-
- o mfmw #0 index 0 2000 100000 ; will write $2000 words=$4000 bytes !!
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MMUD <Start> <End>
-
- Description:
-
- Delete mmu catchlist from <Start> to <End>.
-
- Example:
-
- o mmud 81234 81235
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MMUDA
-
- Description:
-
- Delete all mmu catchlists.
-
- Example:
-
- o mmuda
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MMUS <Start> <End>
-
- Description:
-
- Add memory from <Start> to <End> to mmu catchlist. The specified memory
- is added as read/write catch.
-
- Example:
-
- o mmus 81234 81235
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MMUSW <Start> <End>
-
- Description:
-
- Add memory from <Start> to <End> to mmu catchlist. The specified memory
- is added as write catch.
-
- Example:
-
- o mmusw 81234 81235
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MMUV
-
- Description:
-
- Show current mmu catchlist.
-
- Example:
-
- o mmuv
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MP
-
- Description:
-
- Start the memory-peeker. This tools allows you to scan through the
- memory and 'browse around'. Its also possible to view non-chipmem. Use
- the modulo feature to adjust the srceensize (eg. for finding images).
-
- The following keys functions are available:
-
- o <CURSOR-DOWN>: Scroll one line down
- o <CURSOR-UP>: Scroll one line up
- o <CURSOR-DOWN>+<SHIFT>: Scroll a 3/4 screen down
- o <CURSOR-UP>+<SHIFT>: Scroll a 3/4 screen up
- o <CURSOR-LEFT>: Scroll 32 bit left/down
- o <CURSOR-RIGHT>: Scroll 32 bit right/up
- o <ESC>: Back to TK
- o <TAB>: Cycle to next memory-page
- o <DEL>: Reset modulo to zero
- o <DEL>: Decrease modulo by 2
- o <HELP>: Increase modulo by 2
-
- Example:
-
- o mp
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MS [.<B|W|L] <Address>
-
- Description:
-
- Set memory watch point to byte/word/long at <Address>. Default size is
- byte.
-
- Example:
-
- o ms.l 80000
- o ms 60000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- MV
-
- Description:
-
- View all current memory watch points.
-
- Example:
-
- o mv
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- N [#<Entries per row>] <Address>
-
- Description:
-
- Display memory at <Address> as line of <Entries per row> ascii-codes.The
- command uses the byte offset defined by the Y command. Using optional
- paramters will define the default paramter. The optinal parameter can be
- reseted by illegal values or just be using '#'.
-
- Example:
-
- o n #$10 $80000
- $0080000 "ABCDEFGHIJKLMNOP"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- NO <Offset>
-
- Description:
-
- Set the ascii-offset for the M/N command. The offset is added to every
- read byte and subtracted from every written byte. Only the low byte of
- <Offset> is used!
-
- Example:
-
- o n $80000
- $0080000 "ABC"
- o no 1
- o n $80000
- $0080000 "BCD"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- O <Bytes>,<Start> <End>
-
- Description:
-
- Fill memory from <Start> to <End> with given pattern <Bytes>.
-
- Example:
-
- o o "Mok" 0 "!" !10 0,0 20000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- OR <Bytes>,<Start> <End>
-
- Description:
-
- Or bytewise memory from <Start> to <End> with given pattern <Bytes>.
-
- Example:
-
- o or "Mok",80000 90000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- PORTS
-
- Description:
-
- Lists all currently available ports and its owner tasks.
-
- Example:
-
- o ports
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- Q <Start> <End> <Destination>
-
- COMP <Start> <End> <Destination>
-
- Description:
-
- Compare memory from <Start> to <End> with memory at <Destination>.
-
- Example:
-
- o q f80000 f90000 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- R [<CPU-REG> <Value>]
-
- Description:
-
- If arguments are not given the current registers will be shown. If
- arguments are used the cpu-register <CPU-REG> can be set to value
- <Value>. If you want to change MMU/FPU registers take a look at the
- RM/RF command.
-
- The following registers are available:
-
- o 68000: d0-d7,a0-a7,sr,pc,ssp,usp
- o 68010: d0-d7,a0-a7,sr,pc,ssp,usp,vbr,sfc,dfc
- o 68020: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,caar,cacr
- o 68030: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,caar,cacr
- o 68040: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,cacr
- o 68060: d0-d7,a0-a7,sr,pc,isp,usp,msp,vbr,sfc,dfc,cacr
-
- Example:
-
- o r ssp \ssp+4
- o r d0 44894489
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- RD [#<Unit>] <DiskOffset> <Length> <Destination>
-
- Description:
-
- Read <Length> bytes from diskoffset <DiskOffset> of disk in unit <Unit>
- to memory at <Destination>. The default <Unit> is the
- current-device-unit. <DiskOffset> can also be odd.
-
- Example:
-
- o rd #0 !880*200 4 80000 ; read first 4 bytes to $80000 from sector
- !880
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- RES
-
- RESOURCES
-
- Description:
-
- Lists all currently available resources.
-
- Example:
-
- o res
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- RESET
-
- Description:
-
- The function will immediatly perform a reset.
-
- Example:
-
- o reset
-
- -----------------------------------------------------------------------------
- Syntax:
-
- RF [<FPU-REG> <Value>]
-
- Description:
-
- If arguments are not given the current registers will be shown. If
- arguments are used the fpu-register <FPU-REG> can be set to value
- <Value>.
-
- The following registers are available:
-
- o 68881/68882/68040: fp0-fp7,fpsr,fpcr,fpiar (Currently they can not be
- modifed!)
-
- Example:
-
- o rf
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- RM [<MMU-REG> <Value>]
-
- Description:
-
- If arguments are not given the current registers will be shown. If
- arguments are used the mmu-register <MMU-REG> can be set to value
- <Value>.
-
- The following registers are available:
-
- o 68000/68010: none
- o 68851/68030: tt0,tt1,srp (lower long),srp.0 (lower long), srp.1
- (upper long),crp (lower long),crp.0 (lower long), crp.1 (upper
- long),sr,tc
- o 68040/68060: itt0,itt1,dtt0,dtt1,srp,urp,tc,sr
-
- Example:
-
- o rm tc 81235678
- o rm dtt0 0
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- RS [#<Unit>] <Sector> <SectorAmount> <Destination>
-
- Description:
-
- Read <SectorAmount> sectors from sector <Sector> and following of unit
- <Unit> to memory at <Destination>. The default <Unit> is the
- current-device-unit.
-
- Example:
-
- o rs !880 1 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- RT [#<Unit>] <Track> <TrackAmount> <Destination>
-
- Description:
-
- Read <TrackAmount> tracks from track <Track> and following of disk in
- unit <Unit> to memory at <Destination>.The default <Unit> is the
- current-device-unit.
-
- Example:
-
- o rt !80 1 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- SA <Start> [<End>]
-
- Description:
-
- Save current programm to memory starting from <Start>. <End> is the
- upper boundary for the programm data. If not given it will use as much
- memory as needed. Freezed programm-data can be reloaded using the LA
- command.
-
- Example:
-
- o sa 7c00000 7fa0000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- SE <Filename>
-
- Description:
-
- Save envirement to given file <Filename>. The settings can be loaded
- using the LE command.
-
- Example:
-
- o se "hd1:tk/tk.prefs"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- SETX
-
- SETEXCEPTIONS
-
- Description:
-
- This command will install a exception-'handler' into the actual
- programm. If the programm should crash now it will come back into TK.
- You can check out what happend and maybe solve the 'bug'. The following
- vectors are patched:
-
- o +$08: BUS-ERROR exception
- o +$0c: ADDRESS-ERROR exception
- o +$10: ILLEGAL-COMMAND exception
- o +$14: DIVISION BY ZERO exception
- o +$24: TRACE exception
- o +$28: LINA-A exception
- o +$2c: LINE-F exception (no fpu/mmu?)
-
- Example:
-
- o SETX
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- SHOWSTACKFRAME
-
- Description:
-
- Show the stackframe of the freezed program.
-
- Example:
-
- o showstackframe
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- SI [<Count>]
-
- Description:
-
- Skip <Count> command (eg jsr/bsr is one command). The default value for
- <Count> is one. Note that the disassembly is used to calculate the new
- address.
-
- Example:
-
- o si 5
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- SIM [<Rawkey>]
-
- Description:
-
- The function will install a faked NMI-simulator into the system by
- patching directly the +$68 keyboard interrupt vector. If the user now
- presses the selected key it will simulate a NMI. This will only work if
- the interrupt is not disabled and the vector is not changed. The
- specfied key must be given as a rawkey code. Check out the GETKEY
- function. If no argument is given and the simulator is not installed the
- patch is added with the default rawkey $5d ('*' on the keypad). If no
- argument is given and the simulator is installed the patch will be
- removed. In the other cases the rawkey will be redefined.
-
- Example:
-
- o sim
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- SM <Filename>,<Start> <End>
-
- WB <Filename>,<Start> <End>
-
- Description:
-
- Save memory from <Start> to <End> to data-file <Filename>. If you
- overwrite a file the old filename is not changed! (eg. old 'AbCd', save
- 'ABCD', result 'AbCd')
-
- Example:
-
- o sm "hd1:tk/tk.exe",100000 120000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- ST [<Count>]
-
- Description:
-
- Exit and execute <Count> command. Programm is traced step by step (eg
- trace into jsr/bsr). The default value for <Count> is one.
-
- Example:
-
- o st
- o st !100000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- T <Value>
-
- Description:
-
- Remove all address in buffer for training which do not hold <Value>.
- Then continue collecting all address which hold <Value>. Scanned memory
- was set by the TS command. Multiple use is possible. The command can
- only be used in byte-value-trainer-mode.
-
- Example:
-
- o ts 5,780000 7c00000
- o x
- o t 4
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TASKS
-
- Description:
-
- Lists all currently available tasks. The tasks are listed in 3
- categories : ready,waiting,running. A 'P' indicates a process and a 'T'
- a task. The first value is pointer to the task/process structure, the
- second one is a pointer to the stack of the process (the first long at
- this address points to the routine that will be executed when the task
- is running again (must be in the wait-list for that))
-
- Example:
-
- o tasks
- ..
- P: $07989c88 $0798fd94 MagicWB-Demon {C:MagicWB-Demon}
- ; a process, task node at $7989c88, first call to *798fd94, name
- 'Magic..', Process command 'C:Magic..)
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TB <Start> <End>
-
- Description:
-
- Set location of buffer for training to memory from <Start> to <End>.
-
- Example:
-
- o tb 7c00000 7f80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TBD
-
- Description:
-
- Reset location of buffer for training to default. The internal reserved
- memory is used.
-
- Example:
-
- o tbd
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TBV
-
- Description:
-
- View current location of buffer for training.
-
- Example:
-
- o tbv
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TDC
-
- Description:
-
- If the deep-trainer-mode is already active all stored address are
- compared to their current value. If the value has changed the address is
- kept in the buffer, so only address that have changed are kept in the
- buffer. As usual the command tries to continue scanning the given
- [Range] . See also the TDS command. The command can only be used in the
- deep-trainer-mode.
-
- Example:
-
- o tdc
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TDS [Range]
-
- Description:
-
- If deep-trainer-mode is not active, it will be enabled now. All address
- in [Range] are stored in the buffer for training. If [Range] can not be
- scanned in one pass you can repeat the operation by using the TDS/TDC
- command. If the deep-trainer-mode is already active all stored address
- are compared to their current value. If the value has changed the
- address is removed, so only address that have not changed are kept in
- the buffer. As usual the command tries to continue scanning the given
- [Range] . Note that eg 'TDS 80000 90000' will not restart the
- deep-trainer if it was already active, in this case the [Range] paramter
- is ignored!. Using the command the first time will enable the
- deep-trainer-mode. This function needs around three bytes per stored
- address.
-
- Example:
-
- o tds 780000 7c00000
- o tds
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TDV
-
- Description:
-
- View all address in the buffer for training. See also the
- TDS/TDCcommand. The command can only be used in the deep-trainer-mode.
-
- Example:
-
- o tdv
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TDX
-
- Description:
-
- Free buffer for training, so that it can be used for
- byte-value-trainer-mode. All address in the deep-trainer-mode are lost.
- The command can only be used in deep-trainer-mode.
-
- Example:
-
- o tdx
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TR [<Count>]
-
- Description:
-
- Exit and execute <Count> command. Programm is traced command by command
- (eg no trace into jsr/bsr). The default value for <Count> is one.
-
- Example:
-
- o tr
- o tr 5
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TRACKER [<Start>]
-
- Description:
-
- Start the module-ripper. The memory is scanned for known modules.
- Currently the usual 31-sample noise/protracker, prorunner v2 and the
- player6.1a is included. If <Start> is specfied the scan is started at
- the given address (only chipmem!)
-
- Example:
-
- o tracker
-
- -----------------------------------------------------------------------------
- Syntax:
-
- TRANS <Start> <End> <Destination>
-
- Description:
-
- Copy memory from <Start> to <End> to memory at <Destination>.
-
- Example:
-
- o trans f80000 f90000 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TS <Value> [,Range]
-
- Description:
-
- Init buffer for training and collect all address in [Range] which hold
- the byte <Value>. If [Range] can not be scanned in one pass you can
- repeat the operation by using the T command. The command enables the
- byte-value-trainer-mode. This function needs around 2 bytes per stored
- address.
-
- Example:
-
- o ts 5,780000 7c00000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TV
-
- Description:
-
- View all address in buffer for training. The command can only be used in
- the byte-value-trainer-mode.
-
- Example:
-
- o ts 5,780000 7c00000
- o x
- o t 4
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TX
-
- Description:
-
- Free buffer for training, so that it can be used for the
- deep-trainer-mode. All address in the byte-value-trainer-mode are lost.
- The command can only be used in byte-value-trainer-mode.
-
- Example:
-
- o ts 99
- o tx
- o tds
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- TYPE <Filename>
-
- LESS <Filename>
-
- MORE<Filename>
-
- Description:
-
- Type text-file <Filename> to screen.
-
- Example:
-
- o type "df0:s/startup-sequence"
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- USEBLIT
-
- Description:
-
- Use the blitter for scrolling. On slow machines(68000) this method
- allows realtime scrolling on small screens. The major disadvantage is
- the loss of the blitter custom-regs, so use with care!
-
- Example:
-
- o useblit
-
- -----------------------------------------------------------------------------
- Syntax:
-
- USECPU
-
- Description:
-
- Use the processor for scrolling. On faster machines(68020++) this method
- allows realtime scrolling on big screens, too. Also the blitter
- custom-regs are not touched.
-
- Example:
-
- o usecpu
-
- -----------------------------------------------------------------------------
- Syntax:
-
- VERSION
-
- Description:
-
- The current version number is shown.
-
- Example:
-
- o version
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- W [<CIA-REG>]
-
- Description:
-
- If no paramter is specified it will show the first CIA register. The
- output can be edited (hit return to accept new values). Usually there
- are just $10 regs per CIA but they are multiplexed; so there are some
- more. The following flags exist:
-
- o '*': reg has been backuped correctly and will be written back
- o '?': reg has not been fully backuped and will not be written back;
-
- Example:
-
- o w 7 ; show/edit TimerB-High
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- WD [#<Unit>] <DiskOffset> <Length> <Source>
-
- Description:
-
- Write <Length> bytes to diskoffset <DiskOffset> of disk in unit <Unit>
- with memory at <Source>. The default <Unit> is the current-device-unit.
- <DiskOffset> can also be odd.
-
- Example:
-
- o wd #0 !880*200 1 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- WN [<Count>]
-
- Description:
-
- Exit and return when the <Count>-th command after current position is
- executed.Note that the disassembly is used to calculate the ned address.
- Programm is not traced, instead a temporary breakpoint is set. The
- default value for <Count> is one.
-
- Example:
-
- o wn 5
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- WPC <Address>
-
- Description:
-
- Exit and return when command at <Address> is executed. Programm is
- traced and works also in ROM area.
-
- Example:
-
- o wpc f800d2
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- WS [#<Unit>] <Sector> <SectorAmount> <Source>
-
- Description:
-
- Write <SectorAmount> sectors to sector <Sector> and following of disk in
- unit <Unit> with memory at <Source>. The default <Unit> is the
- current-device-unit.
-
- Example:
-
- o ws !880 1 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- WT [#<Unit>] <Track> <TrackAmount> <Source>
-
- Description:
-
- Write <TrackAmount> tracks to track <Track> and following of disk in
- unit <Unit> with memory at <Source>. The default <Unit> is the
- current-device-unit.
-
- Example:
-
- o wt !80 1 80000
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- X
-
- Description:
-
- Exit freezer programm and continue the freezed programm.
-
- Example:
-
- o x
-
- -----------------------------------------------------------------------------
-
- Syntax:
-
- Y [#<Entries per row>] <Address>
-
- Description:
-
- Display memory at <Address> as <Entries per row> binary bytes. Using
- optional paramters will define the default. The optinal parameter can be
- reseted by illegal values or just be using '#'.
-
- Example:
-
- o y #1 80000
- $0080000 %01011111
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - Argument description
- -----------------------------------------------------------------------------
-
- o <Value>, <Count>, <Offset>, <Entries per row>, <TrapNumber>,
- ;4m<BreakpointNumber>, <Length>, <SectorAmount>, <TrackAmount>, <Sync>,
- ;4m<DMA-Length>,<BitShift>,<Rawkey>
- o <Address>, <Start>, <End>, <Destination>, <Source>
- o <String>,<Labelname>
- o <StringPattern>
- o <Bytes>
- o <PBytes>
- o <Range>
- o <DisassmeblyPattern>
- o <Path>
- o <Filename>
- o <Unit>
- o <DiskOffset>
- o <Sector>
- o <Track>
-
- -----------------------------------------------------------------------------
- Argument:
-
- <Value>, <Count>, <Offset>, <Entries per row>, <TrapNumber>,
- <BreakpointNumber>, <Length>, <SectorAmount>, <TrackAmount>, <Sync>,
- <DMA-Length>,<BitShift>,<Rawkey>
-
- Description:
-
- These arguments are the base for almost every other argument. The
- argument parser supports many operators (listed below). The operator
- priority is 'left-assigned' or is defined by the used operator (see
- prefs setting). The base for any input is 10(dec) or 16(hex) (see prefs
- setting).
-
- o Simple values:
- o '!' <digits> : Parse digits following in dec-mode(base 10) (eg.
- '!123456789', '!10'='$a')
- o '$' <digits> : Parse digts following in hex-mode (base 16) (eg.
- '$44899521', '$10'='!16')
- o '%' <digits> : Parse digts following in bin-mode (base 2);dots are
- skipped for a better overview (eg. '%1111'='$f',
- '%00001111.11110000.00000000.11111111'='$0ff000ff')
- o '\<CPU-REG>' : The value of the specfied register is returned. The
- '\' is necessary if specified in the preferences. See the R command
- for available cpu-register.
- o '"<ascii-digits>"' : The value of the ascii-string is returend (eg.
- "A"='$41',"ABCD"='$41424344')
- o <labelname> : The value of the label is returned
- o Unary operators:
- o '~' <Value> : Exor following value (eg. '~$ff'='$ffffff00')
- o '+' <Value> :Do not negate following value, dummy operator (eg.
- '+$100'='$100')
- o '-' <Value> : Negate following value (eg '-1'='$fffffffe')
- o '{' <Value>, '*' <Value>: Dereference following value. The longword
- at <Value> is fetched. (eg. '*4'=*execbase)
- o Unary end operators:
- o <Value> '.B' : Extend <Value> from byte to longword (signed
- operation) (eg. '$80.b='$ffffff80')
- o <Value> '.W' : Extend <Value> from word to longword (signed
- operation) (eg. '$8000.w'='$ffff8000')
- o <Value> '.L' : Extend <Value> from longword to longword (dummy
- operation)
- o Binary operators (first operator in list has the lowest priority, the
- last one has the highest)
- o <Value1> = <Value2>, <Value1> == <Value2> : If <Value1> is the same
- as <Value2> result is 1 (true), else 0(false) (eg. '!10==$10' is
- false, '!10==$a' is true)
- o <Value1> != <Value2> : If <Value1> is the not the same as <Value2>
- result is 1 (true), else 0(false) (eg. '!10!=$10' is true, '!10!=$a'
- is false)
- o <Value1> < <Value2> : If <Value1> is less (signed) than <Value2>
- result is 1 (true), else 0(false) (eg. '!10<$10' is true)
- o <Value1> <= <Value2> : If <Value1> is less same (signed) than
- <Value2> result is 1 (true), else 0(false) (eg. '!10<=$10' is true)
- o <Value1> > <Value2> : If <Value1> is greater (signed) than <Value2>
- result is 1 (true), else 0(false) (eg. '$10>!10' is true)
- o <Value1> >= <Value2> : If <Value1> is greater same (signed) than
- <Value2> result is 1 (true), else 0(false) (eg. '$a>=!10' is true)
- o <Value1> && <Value2> : If <Value1> and <Value2> are true the result
- is 1 (true), else 0(false) (eg. '0&&1' is false)
- o <Value1> || <Value2> : If <Value1> or <Value2> is true the result is
- 1 (true), else 0(false) (eg. '1||0' is true)
- o <Value1> & <Value2> : The result is <Value1> (bitwise) and <Value2>
- (eg. '$101&$ff'='1')
- o <Value1> ! <Value2> : The result is <Value1> (bitwise) or <Value2>
- (eg. '$101!$ff'='$1ff')
- o <Value1> ~ <Value2> : The result is <Value1> (bitwise) xor <Value2>
- (eg. '$101~$ff'='$1ff')
- o <Value1> + <Value2> : The result is <Value1> plus <Value2> (eg.
- '2+4'='6')
- o <Value1> - <Value2> : The result is <Value1> minus <Value2> (eg.
- '2-4'='-2')
- o <Value1> * <Value2> : The result is <Value1> multiplied with <Value2>
- (eg. '2*4'='8')
- o <Value1> / <Value2> : The result is <Value1> divided by <Value2> (eg.
- '5/2'='2')
- o <Value1> % <Value2> : The result is the rest of <Value1> diveded by
- <Value2> (eg. '5%2'='1')
- o <Value1> << <Value2> : The result is <Value1> shifted by <Value2>
- bits left (eg. '1<<!31'='$80000000')
- o <Value1> >> <Value2> : The result is <Value1> shifted by <Value2>
- bits right (eg. '$80000000>>!31'='1')
- o <Value1> ^ <Value2> : The result is <Value1> to the power of <Value2>
- (eg. '2^!31'='$80000000')
-
- Example:
-
- o *4 ; address of execbase
- o *((*(*4+$9c)+$17c)+$28) ; cuurent beamcon0
- o (2+3*4==2+(3*4)) ; is true if operator priority is enabled
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Address>, <Start>, <End>, <Destination>, <Source>
-
- Description:
-
- These arguments are parsed the same like <Value>. The received address
- is then validated. If the address conflicts with the the current
- memory-mode (see prefs setting) it will report an error. If eg. <Start>
- and <End> is used then <End> must be higher than <Start> and both must
- be in a continous memory-block. (eg not from $1f0000 to $f80000 -
- depends on the mmeory-mode!)
-
- Example:
-
- o $10000+4*100
-
- -----------------------------------------------------------------------------
- Argument:
-
- <String>,<Labelname>
-
- Description:
-
- A plain string can be started either with " or a ' and must of course
- end with it. However, if you do not use ",' the string will be
- uppercased and will terminate at the first space or tab.
-
- Example:
-
- o "amiga"
- o "amiga'
- o amiga ; identicall to "AMIGA"
-
- -----------------------------------------------------------------------------
- Argument:
-
- <StringPattern>
-
- Description:
-
- The argument <StringPattern> is just a <String> which holds some special
- symbols. The following wildcards are available: '?' (single wild-char)
- and '*','#?' (multiple wild-chars). The pattern is incasesensitive.
-
- Example:
-
- o '*dir'
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Bytes>
-
- Description:
-
- The argument is usually use for searching mutliple bytes. <Bytes> is
- build up of multiple <Value> or <strings> seperated by a space. The
- value must be given is hex-mode! Only the low bytes of a value is used.
- However, strings will be converted to multiple bytes.
-
- Example:
-
- o $45 45 ; same as 45 45
- o 45 890 45 ; same as 45 90 45
- o "password" 00
- o "diskname" 0 "sync" $0a $00 ; searches what it means!
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <PBytes>
-
- Description:
-
- The argument is given in the same ways as in argument <Bytes>. If the
- parsed value (byte sized) included a '?' the upper/lower nibble is
- marked as a wildcard.
-
- Example:
-
- o ?? 00; same as if you would search just $00
- o "d" ?? ?? ".library" ; will find eg 'dos.library'
- o 8? ?? ?? ?8 "SXI!"
- o "diskname" ?? "sync" $?? $00 ; searches what it means!
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Range>
-
- Description:
-
- The argument <Range> is build up of a list of <Address>. If the argument
- <Range> is not used all available memory pages are scanned. A single
- address as argument means that the scan will start at the specfied
- address (instead of $00000000). A additional (second) address is used to
- determinate when to stop. (check out the memory setting)
-
- Example:
-
- o <no arg> ; scan all available pages
- o $80000 ; scan all available pages starting at $80000
- o $1f8000 $7880000 ; may scan $1f8000-$200000,$7800000-$7880000
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <DisassmeblyPattern>
-
- Description:
-
- The argument <DisassemblyPattern> is just a <String> which holds some
- special symbols. The following wildcards are available: '?' (single
- wild-char) and '*','#?' (multiple wild-chars). The pattern is
- incasesensitive. A space is extended to a '*' wildcard. If the parser
- encounters a '\' it will use the pattern for the next command.
-
- Example:
-
- o "movec ,vbr","MOVEC*,vbr*" ; same pattern
- o "move.l ,?0" ; finds eg "movea.l $7c.w,a0" but not "movea.l $7c.w,a0"
- (check out if destination is a address reg!)
- o "cmp*.l #$????????,*\b*\" ; find eg "cmp.l #$12345678,-$10(a7)\beq.l
- $80000"
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Path>
-
- Description:
-
- The argument <Path> is just a <String> which holds the device path. If
- no absolute path is used it is appended to the current path. The path my
- not point to a file!
-
- Example:
-
- o "df0:tk/","df0:tk" ; absolute path
- o "tk" ; relative to the current path
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Filename>
-
- Description:
-
- The argument <Filename> is just a <String> which holds the filename. If
- no absolute path is used it is appended to the current path. The
- filename may not point to a directory!
-
- Example:
-
- o "df0:tk.exe" ; absolute path
- o "tk.exe" ; relative to the current path
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <DiskOffset>
-
- Description:
-
- The argument <DiskOffset> is just a <Value> which addresses the diskdata
- as one continous memory block. It must be lower than $dc0000
- (DD-Disk)/$1b8000(HD-Disk).
-
- Example:
-
- o !880*200 ; root block (DD)
- o $c ; eg read data from diskoffset !12 (bootblock code)
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Unit>
-
- Description:
-
- The argument <Unit> is just a <Value> which determinats the drive to be
- used. <Unit> can only be 0(DF0),1(DF1),2(DF2),3(DF3).
-
- Example:
-
- o 0 ; "df0:" (what to say else??)
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Sector>
-
- Description:
-
- The argument <Sector> is just a <Value> which addresses data on a disk.
- It must be lower than 1760(DD-Disk)/3520(HD-Disk). A sector has a size
- of $200 bytes.
-
- Example:
-
- o !880 ; root.-block
-
- -----------------------------------------------------------------------------
-
- Argument:
-
- <Track>
-
- Description:
-
- The argument <Track> is just a <Value> which addresses data on disk. It
- must be lower than 80(DD/HD-Disk). A track consists of
- 11(DD-Disk)/22(HD-Disk) sectors. So a track has a length of $2c00/$5800
- bytes.
-
- Example:
-
- o !80 ; track with root-block (DD)
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - How to make a NMI-button
- -----------------------------------------------------------------------------
-
- If you want to use TK you must have a NMI-button, else you will not be able
- to enter TK at any point, because the software patches are usually eliminated
- by eg NDOS-programms. If you have never soldered anything try to find someone
- who can do it for you, though its very easy (in my opinion..) You need the
- following stuff:
-
- o 1 x button (on/off)
- o 3 x diodes (no special type required, (at least 10V/100mA, i think) eg
- 1N4148, 1N4001-7 or any universial diode)
- o some wires and the usual equipment to solder
-
- You must connect a ground signal to one pin of the button and the other
- button pin to every cathode of thediodes and from their anodes to the IPL0,
- IPL1, IPL2 signal, so quite easy. (If the instruction for your computer is
- missing do it yourself or find someone...). Make sure that the black ring of
- the diodes point to the button and not to the ipl lines. It should look like
- this
-
- o IPL0 ----------------------- |>| ----\
- o IPL1 ----------------------- |>| ------------ BUTTON ----- GROUND
- o IPL2 ----------------------- |>| ----/
-
- Note: '..--|>|--..' is a diode which anode is left and cathode is right!
-
- LAST WARNING! NO WARRANTY FOR ANY INSTRUCTION LISTED BELOW!! LAST WARNING!
-
- A1200:
-
- o I would advise to use the internal 150-pin expansion connector.The
- ipl-lines are at pin 81, 82, 83 and the ground is eg at pin 79 (take a
- look at your A1200 manual for verification). If you have a cpu-card
- installed try so solder on the connector of it.
- The expansion connector looks like this:
-
- ...|IPL1|...
- |
- (upper half) |2|4|6|8|..........|82|......|148|150|
- (lower half) |1|3|5|7|.......|79|81|83|...|147|149|
- / | \
- ...|GROUND|IPL0|IPL2|...
-
- (PIN 81) IPL0 ------- |>| ----\
- (PIN 82) IPL1 ------- |>| ------- BUTTON --- GROUND (PIN 79)
- (PIN 83) IPL2 ------- |>| ----/
-
- A4000 (and maybe A3000):
-
- I would advise to use the internal 200-pin expansion connector of the
- cpu-card, because all other connectors do not support the ipl-signals
- (including the Zorro2/3 slots!!). Unfortunatly, i have not found a
- description where all signals are described with correct pin numbers, so
- i will just give a exact pin-location. If you have a manual where the
- pins are described try to contact me. You should solder on the upper
- side (the one where the connector pins are soldered to the card). The
- following instructions were tested on a A4000 with a 68030 and 68040
- original cpu card. It should also work with the cyberstorm cards! (not
- tested yet!, no warranty!)
- The expansion connector looks like this:
-
- /--------------------------------------------------------------\
- | |
- | x x x x ... x x x x x x x x x x x x x ... x x x x |
- | x x x x ... x x I J K x x x x x x x x ... x x x x |
- | O x x x x ... x x x x x x x x x x x x x ... x x x x O |
- | x x x x ... x x x x x x x x x x x x ... x x x G |
- | |
- | () () |
- . .
- . .
- | () () |
- \--------------------------------------------------------------/
-
- I,J,K: IPL signals, G:GROUND signal
-
- I(IPL) ------- |>| ----\
- J(IPL) ------- |>| ------- BUTTON --- G (GROUND)
- K(IPL) ------- |>| ----/
-
- BTW: I use this hardware patch!
-
- A500/A2000:
-
- o I would advise to use the external 86-pin expansion connector.The
- ipl-lines are at pin 40, 42, 44 and the ground is eg at pin 37 (take a
- look at your A500 manual for verification).
- The expansion connector looks like this:
-
- ...|IPL0|IPL1|IPL2|...
- \ | /
- (upper half) |2|4|6|8|.......|40|42|44|.....|84|86|
- (lower half) |1|3|5|7|....|37|..............|84|85|
- |
- ...|GROUND|...
-
- (PIN 40) IPL0 ------- |>| ----\
- (PIN 42) IPL1 ------- |>| ------- BUTTON --- GROUND (PIN 37)
- (PIN 44) IPL2 ------- |>| ----/
- o The internal 86-pin-MMU-connector of the A2000 has the same pin
- assignment as the A500 86-pin connector. However if want to use a
- Zorro2-slot then you need just to connect the EINT7-signal (pin 40)
- directly via a button to a ground signal (eg pin 37). Take a look at
- your A2000 manual for verification.
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - Registration/Demo limits/How to order
- -----------------------------------------------------------------------------
-
- If you run the demo version the following restrictions are active:
-
- o No write operations are possible (SM,MFMW,SE,SA,WT,WS,WD,..)
- o No external trainer buffer! (TB,TBD)
- o No deep-trainer! (TDS/TDC)
- o Assembling is not possible! (A)
- o The demo version is basically a crippled standard version of TK
- o Max 10 entries into TK, then TK will lock you system. You will have to
- do a reset to get out!
-
- If you register you can decide between two versions available, the standard
- and the professional. The professional versions includes some commands which
- are used very seldom or need special equipment (eg a working mmu). The
- following commands are only available in the professional version:
-
- o All mmu functions (MMUV,MMUS,MMUSW,MMUD,MMUDA)
- o A dis-/assembler for special code (A,D)
- o Commands for direct-ram-freezing (LA,SA)
- o Any programm launched from system can be catched before execution
- ;4m(CATCHFILE)
- o Find disassembly allows multiple line matching (FD)
- o Probably find special code (FC) (but not with my lib!)
-
- Notice the following rules:
-
- o The money can only be send to my bank-account (no mail-queues etc..)
- o You pay in advance, then you get the software
- o You should contact me before sending the money
- o I prefer sending the software via e-mail/internet or via modem (the
- fastest method)
- o Its not impossible to send TK via snail (ask'n'hope)
- o If you order from outside germany make sure that the correct amount of
- german marks will be transfered by your bank
- o NO WARRANTY FOR ANY DATA LOST BY USING TK !
-
- If you order please include a short description about your
- system-configuration (not necessary)
-
- o cpu
- o mmu
- o fpu
- o memory + its location
- o amiga model
-
- The standard version costs 200-DM. Yet i am not sure about the price for the
- professional version, just ask!
- Finally if you want to order contact me (or Goldman) and leave a message with
- your wish. You will receive a bank-account nr to send the money to.
- -----------------------------------------------------------------------------
- Thrill Kill - Yet known bugs
- -----------------------------------------------------------------------------
-
- The following bugs are yet known:
-
- 1. No support for graphics-cards, and other kewl equipment. Tk can not
- support every available hardware.
- 2. TK does not like programms who also use the MMU, especially on 68040++.
- 3. Strange things happen if you access memory higher $0ffffff on some A4000
- (but not mine :)).. all custom regs are gone and much more. TK gives its
- best to restore the custom regs, but however its not a magican. (you
- have to generate an own setting which does not do a memory detect for
- $1dc00000++)
- 4. TK can not debug programms who misuse the stackpoiner (a general problem
- of all freezers!)
- 5. The simple NMI-button cause multiple instances of NMIs. They may blow up
- the internal/external stack.
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - History
- -----------------------------------------------------------------------------
-
- o Version 1.04:
- o first real public release
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - Contact
- -----------------------------------------------------------------------------
-
- Information about registration, bug reports, new featues or anything else
- available can be obtained via
-
- o e-mail: Leave a message to 'ajunk@uni-paderborn.de' with subject 'TK'
- and your question. (be very patient...)
- o WWW: (will be soon available..be patient)
- o BBS: Call 'Straight Hate' and use the 'c' command to leave me(ferox) or
- goldman a message (use login:'customer', password:'kill')
- o IRC: You may find me in one of the following channels: 'AmiElite',
- 'AmigaSCNE', 'Amiga', 'AmigaGER' (my nick is 'ferox')
- I will try to setup a channel named 'ThrillKill' for TK-support.
-
- Leave a message to 'Goldman' (my beta-tester NR 1) on a scene bbs (especially
- the Sunflex Inc. boards).
- You may also try to post a message to 'ferox' on some bbs (be warned! i do
- not visit them often).
-
- -----------------------------------------------------------------------------
-
- Thrill Kill - Future
- -----------------------------------------------------------------------------
-
- The following things are (not) planned:
-
- 1. Improved freezer ability (there are still some games which could be
- freezed 100%)
- 2. More compatibility (just how..)
- 3. Better OS-filesystem support (to less fun..)
- 4. A better NMI-button hardware (the easy NMI-button has major
- disadvantages, tough its very easy to implement)
- 5. A amigaguide documentation (Has anyone a html-to-amigaguide converter
- ??)
- 6. A PPC dis- and assembler (not even started yet)
- 7. A PPC version (not even started yet)
- 8. Maybe a hardware version (but not for the 680x0 versions)
- 9. No picture saver (For what ? Only if really many many would request
- it...)
-
- -----------------------------------------------------------------------------
-
-