mirror of
https://github.com/antoinevignau/source.git
synced 2025-01-06 01:31:57 +00:00
4d4fb6a665
Some old (WIP) disassemblies and my own source code now available online.
1 line
74 KiB
Plaintext
1 line
74 KiB
Plaintext
|
||
|
||
|
||
|
||
S-C ASSEMBLER II
|
||
Disk Version 3.2
|
||
|
||
for the
|
||
|
||
APPLE II Computer
|
||
|
||
|
||
|
||
|
||
|
||
Copyright 1979
|
||
S-C SOFTWA RE
|
||
P.O. Box 280300
|
||
Dallas, Texas 75228
|
||
(214) 324-2050
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
TABLE OF CONTENTS
|
||
|
||
1.0 Introduction and Feature List . . . . . . . . . . . 1
|
||
|
||
2.0 Commands . . . . . . . . . . . . . . . . . . . . . 3
|
||
2.1 Assembler Commands . . . . . . . . . . . . . . . . 3
|
||
2.1.1 Editing Commands . . . . . . . . . . . . . . . . 4
|
||
2.1.1.1 NEW Command . . . . . . . . . . . . . . . . . 4
|
||
2.1.1.2 RENUMBER Command . . . . . . . . . . . . . . . 4
|
||
2.1.1.3 DELETE Command . . . . . . . . . . . . . . . . 4
|
||
2.1.1.4 LIST Command . . . . . . . . . . . . . . . . . 4
|
||
2.1.1.5 FIND Command . . . . . . . . . . . . . . . . . 5
|
||
2.1.1.6 Screen Editing . . . . . . . . . . . . . . . . 5
|
||
2.1.2 Listing Control Commands . . . . . . . . . . . . 6
|
||
2.1.2.1 FAST Command . . . . . . . . . . . . . . . . . 6
|
||
2.1.2.2 SLOW Command . . . . . . . . . . . . . . . . . 6
|
||
2.1.2.3 PRT Command . . . . . . . . . . . . . . . . . . 6
|
||
2.1.3 Object Commands . . . . . . . . . . . . . . . . . 7
|
||
2.1.3.1 ASM Command . . . . . . . . . . . . . . . . . . 7
|
||
2.1.3.2 MGO Command . . . . . . . . . . . . . . . . . . 7
|
||
2.1.4 Tape Commands . . . . . . . . . . . . . . . . . . 8
|
||
2.1.4.1 LOAD Command . . . . . . . . . . . . . . . . . 8
|
||
2.1.4.2 SAVE Command . . . . . . . . . . . . . . . . . 8
|
||
2.1.4.3 JOIN Command . . . . . . . . . . . . . . . . . 8
|
||
2.2 DOS Commands . . . . . . . . . . . . . . . . . . . . 8
|
||
2.2.1 Housekeeping Commands . . . . . . . . . . . . . . 9
|
||
2.2.2 Source Maintenance Commands . . . . . . . . . . . 9
|
||
2.2.3 Object Maintenance Commands . . . . . . . . . . . 9
|
||
2.2.4 I/O Selection Commands . . . . . . . . . . . . . 9
|
||
2.2.5 BASIC Commands . . . . . . . . . . . . . . . . . 9
|
||
2.3 Monitor Commands . . . . . . . . . . . . . . . . . 10
|
||
|
||
3.0 Source Program Format . . . . . . . . . . . . . . . 11
|
||
3.1 Label Field . . . . . . . . . . . . . . . . . . . . 11
|
||
3.2 Opcode Field . . . . . . . . . . . . . . . . . . . 12
|
||
3.3 Operand Field . . . . . . . . . . . . . . . . . . . 12
|
||
3.4 Comment Field . . . . . . . . . . . . . . . . . . 12
|
||
3.5 Comment Lines . . . . . . . . . . . . . . . . . . . 12
|
||
3.6 Sample Source Program . . . . . . . . . . . . . . . 13
|
||
|
||
4.0 Assembler Directives . . . . . . . . . . . . . . . 15
|
||
4.1 .OR -- Origin . . . . . . . . . . . . . . . . . . 15
|
||
4.2 .TA -- Target Address . . . . . . . . . . . . . . . 15
|
||
4.3 .EN -- End of Program . . . . . . . . . . . . . . . 17
|
||
4.4 .EQ -- Equate . . . . . . . . . . . . . . . . . . . 18
|
||
4.5 .DA -- Data . . . . . . . . . . . . . . . . . . . . 18
|
||
4.6 .HS -- Hex String . . . . . . . . . . . . . . . . . 19
|
||
4.7 .AS -- ASCII String . . . . . . . . . . . . . . . . 19
|
||
|
||
5.0 Operand Expressions . . . . . . . . . . . . . . . . 21
|
||
5.1 Decimal Numbers . . . . . . . . . . . . . . . . . . 21
|
||
5.2 Hexadecimal Numbers . . . . . . . . . . . . . . . . 21
|
||
5.3 Labels . . . . . . . . . . . . . . . . . . . . . . 21
|
||
5.4 Asterisk (*) . . . . . . . . . . . . . . . . . . . 22
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
6.0 Addressing Modes . . . . . . . . . . . . . . . . . . 23
|
||
6.1 Implied Mode . . . . . . . . . . . . . . . <20> . . . 25
|
||
6.2 Relative Mode . . . . . . . . . . . . . . . . . . . 25
|
||
6.5 Other Modes . . . . . . . . . . . . . . . . . . . . 25
|
||
6.4 Chart of Other Modes . . . . . . . . . . . . . . . 26
|
||
|
||
7.0 SWEET-16 . . . . . . . . . . . . . . . . . . . . . 27
|
||
7.1 Sample SWEET-16 Program . . . . . . . . . . . . . . 28
|
||
|
||
Appendix . -- Operation and Memory Usage . . . . . . . A-1
|
||
A.1 Contents of the Disk . . . . . . . . . . . . . . A-1
|
||
A.2 Copying the Disk . . . . . . . . . . . . . . . . A-1
|
||
A.3 Memory Usage . . . . . . . . . . . . . . . . . . A-2
|
||
A 4 ROM Usage . . . . . . . . . . . . . . . . . . . . A-2
|
||
A.5 Description of Sample Source Programs . . . . . . A-4
|
||
A.6 Useful Information . . . . . . . . . . . . . . . A-4
|
||
A.7 Handy Patches . . . . . . . . . . . . . . . . . . A-5
|
||
|
||
Appendix B -- Error Messages . . . . . . . . . . . . . B-1
|
||
|
||
Appendix C -- Printer Software . . . . . . . . . . . . C-1
|
||
C.1 Listing of the PRT Subroutine . . . . . . . . . . C-2
|
||
|
||
Appendix D -- Bibliography . . . . . . . . . . . . . . D-1
|
||
D.1 Sources of Help for 6502 Programming . . . . . . . D-1
|
||
D.2 Sources of Help for SWEET-16 . . . . . . . . . . . D-2
|
||
|
||
Registration Form
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
INTRODUCTION
|
||
|
||
|
||
S-C ASSEMBLER II is a convenient and powerful tool for software
|
||
develcpment on the Apple II Computer. The assembler uses standard
|
||
6502 mnemonics and syntax, and includes many useful features for
|
||
creating, editing, assembling, and testing your assembly language
|
||
programs. Now assembly language programming is almost as easy as
|
||
prograinming in BASIC.
|
||
|
||
Here is a summary of the most exciting features:
|
||
* Operates as a subsystem under standard Apple DOS 3.2
|
||
* BASIC-like text editing (line numbers, LIST and DELETE commands)
|
||
* Full Apple II screen editing
|
||
* Tab stops for opcode, operand, and comment fields
|
||
* A fast RENUMBER command
|
||
* LOAD and SAVE commands to maintain your programs on disk or tape.
|
||
* Labels of from 1 to 6 characters
|
||
* Arithmetic expressions in operand field (using decimal, hexadecimal
|
||
numbers and labels)
|
||
* Comments, for built-in documentation
|
||
* English-language error messages
|
||
* FIND command, to search through source programs
|
||
* Ability to assemble standard syntax SWEET-16 opcodes
|
||
* All DOS commands usable from within S-C ASSEMBLER II
|
||
* All Apple Monitor commands usable from within S-C ASSEMBLER II
|
||
* Speed and suspension control over listing and assembly
|
||
* Built-in software for controlling the Practical Automation DMTP-6uP
|
||
Printer (easily replaceable with software for any other printer)
|
||
* Ability to use Apple parallel or serial printer interface cards to
|
||
any printer (PR#s command)
|
||
* Continuing development and support by S-C SOFTWARE to provide more
|
||
useful features and extensions with future releases
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
- 1 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
COMMANDS
|
||
|
||
|
||
There are three types of commands in S-C ASSEMBLER II:
|
||
|
||
Assembler Commands, DOS Commands, and Monitor Commands. The Assembler
|
||
Commands are used to control the editor and assembler. All of the
|
||
Apple Monitor and DOS Commands are recognized, although they are not
|
||
all of use from within S-C ASSEMBLER II. Commands are typed
|
||
immediately after the prompt symbol, which is a colon (:).
|
||
|
||
ASSEMBLER COMMANDS
|
||
|
||
There are thirteen assembler commands in S-C ASSEMBLER II. All
|
||
assembler commands may be abbreviated to the first three letters if
|
||
you so desire.
|
||
|
||
|
||
ASM Assemble source program, put object program
|
||
into memory, and produce assembly listing.
|
||
|
||
DELETE line# Delete specified line.
|
||
DELETE line#,line# Delete line range.
|
||
|
||
FAST Select normal listing speed, turn off printer
|
||
software.
|
||
|
||
FIND string List all lines containing the specified string.
|
||
|
||
JOIN Join a program from tape to one already in memory.
|
||
|
||
LIST List entire source program.
|
||
LIST line# List specified line.
|
||
LIST line#,line# List line range.
|
||
|
||
LOAD Load source program from tape.
|
||
|
||
MGO expression Execute object program, starting at address
|
||
specified by value of expression.
|
||
|
||
NEW Delete entire source program, start all over.
|
||
|
||
PRT Turn on printer software.
|
||
|
||
RENUMBER Renumber all lines of source program starting
|
||
with 1000, in steps of 10.
|
||
|
||
SAVE Save source program on tape.
|
||
|
||
SLOW Select slow listing speed, turn off printer
|
||
software.
|
||
|
||
|
||
|
||
|
||
- 3 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
The assembler commands can be conveniently grouped into editing
|
||
commands, listing control commands, object commands, and tape
|
||
commands.
|
||
|
||
Editing Commands
|
||
|
||
The editor in S-C ASSEMBLER II combines the powerful Apple screen
|
||
editing features with a BASIC-like line editor. Source programs are
|
||
entered and edited in almost exactly the same way you would enter and
|
||
edit an Integer BASIC program.
|
||
|
||
NEW Command: Deletes the current source program from memory, and
|
||
restarts S-C ASSEMBLER II just as though you re-entered it from the
|
||
monitor or DOS.
|
||
|
||
RENUMBER Command: Assigns new line numbers to every line in the
|
||
current source program. The first line will receive the number 1000,
|
||
and subsequent lines will be numbered with an increment of 10. (See
|
||
Appendix A for instructions for setting a different starting line
|
||
number or increment.)
|
||
|
||
DELETE Command: Deletes a line or a range of lines from your source
|
||
program, just as in BASIC. Another way to delete a single line is to
|
||
type its line number followed immediately by a carriage return.
|
||
(Warning: DELETE followed by a file name is a DOS command, and will
|
||
delete a file from your disk.)
|
||
|
||
LIST Command: Lists a single line, a range of lines, or your entire
|
||
program; it works just like the LIST command in BASIC. While a
|
||
program or a range of lines is listing, you can momentarily stop the
|
||
listing by hitting the space bar. Tapping the space bar again will
|
||
restart the listing. You can abort the listing by hitting the RETURN
|
||
Key. The SLOW and FAST commands allow you to control the listing
|
||
speed. If you list a single line, it is displayed on the screen in a
|
||
position which makes it easy to edit using the Apple II screen
|
||
editing tools.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
- 4 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
FIND Command: Search through your source program for a given text
|
||
string, and list all the lines which contain that string. You may
|
||
type FIN or FIND, followed by a space, followed by the text string
|
||
for which you are searching. Every character you type between the
|
||
space and the carriage return is part of the search key, so you can
|
||
prefix or append spaces to the key to perform label searches.
|
||
|
||
Screen Editing: The Apple II screen editing tools are quite powerful
|
||
and actually very easy to use. However, many owners do not use them
|
||
because of the very limited explanation in the original Apple
|
||
Documentation. Now it is described well in the A~nle II BASIC
|
||
Programming Nanual (pages 28-30 and 49-55), and the A~~lesoft II
|
||
BASIC Reference Manual (pages 54-55 and 110-114).
|
||
|
||
Briefly, the left arrow is a backspace, and deletes one character
|
||
from the input buffer each time it is used. The right arrow adds to
|
||
the input buffer the character from the screen that the cursor was
|
||
covering just before you type the arrow key. Four escape character
|
||
sequences allow you to move the cursor anywhere on the screen you
|
||
wish without affecting the input bufferi
|
||
|
||
escape A Right 1 (if at end of line, go to
|
||
beginning of next line)
|
||
escape B Left 1 (if at beginning of line, go
|
||
to end of previous line)
|
||
escape C Down 1 line
|
||
escape D Up 1 line
|
||
|
||
These escape character sequences can be a little clumsy, due to the
|
||
necessity of hitting the escape key and then a letter for each cursor
|
||
movement. S-C ASSEMBLER II allows you to substitute control-A for
|
||
escape-A, control-B for escape-B, and so on. The escape sequences
|
||
still work, but you can type faster using the control form. The
|
||
control form is especially nice when you need to repeat the same
|
||
motion a number of times.
|
||
|
||
You can edit a source line previously entered by listing it with the
|
||
LIST command, moving up to it by typing control-D, and then using the
|
||
arrows, control-A, and control-B to make
|
||
|
||
|
||
|
||
|
||
- 5 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
the desired changes. The right arrow will copy characters into the
|
||
new version of the line. Control-A will skip over characters you
|
||
wish to omit, and control-B will back up the cursor so you can insert
|
||
new characters. To change characters on a one-for-one basis, simply
|
||
type over the top of the old ones. When you are through, hit the
|
||
RETURN key.
|
||
|
||
Another way to edit a line is to re-type the entire line. The new
|
||
version will replace the old one with the same line number.
|
||
|
||
S-C ASSEMBLER II implements one additional editing feature,
|
||
tabulation. The control-I key will cause enough blanks to be entered
|
||
to tab over to the next tab stop. Tab stops are preset at columns
|
||
12, 16, and 26. (See Appendix A for instructions on changing the tab
|
||
stops to different values.)
|
||
|
||
|
||
Listing Control Commands
|
||
|
||
|
||
FAST Command: Sets the listing speed to the normal~toofast-to-read
|
||
speed. It also turns off the printer software if it was on. When
|
||
you first enter S-C ASSEMBI<42>R II, it is already in the FAST mode. If
|
||
you abort a listing or assembly by hitting the RETURN key, the system
|
||
returns to the FAST mode.
|
||
|
||
|
||
SLOW Command: Sets the listing speed slow enough that you can read it
|
||
as it goes by on your screen. It also turns off the printer software
|
||
if it was on.
|
||
|
||
|
||
PRT Command: Turns on the printer software. All output will be sent
|
||
to the printer as well as to the TV screen. S-C ASSEMBLER II
|
||
includes a printer driver for the Practical Automation DMTP-6uP
|
||
printer, connected through the game i/o connector. You can easily
|
||
substitute your own printer software in its place (See Appendix C for
|
||
details). If you have the Apple parallel or serial printer interface
|
||
boards, you use the PR#slOt command to turn on y~ur printer instead
|
||
of the PRT command.
|
||
|
||
|
||
|
||
|
||
|
||
- 6 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Object Commands
|
||
|
||
|
||
ASM Command: Initiates assembly of your source program. S-C ASSEMBLER
|
||
II is a two-pass assembler. During the first pass it builds a symbol
|
||
table with the definition of every label used in your program.
|
||
During the second pass the assembler stores object code into memory
|
||
and produces an assembly listing. At the end of the second pass a
|
||
list of all the labels and their definitions is produced. The
|
||
symbols are listed in the same order in which they were defined.
|
||
|
||
If any errors are detected during either pass, an error message will
|
||
be printed. The message will briefly explain the nature of the
|
||
error, and indicate the line number of the bad line. All of these
|
||
messages abort the assembly process, so that you can fix them
|
||
immediately and re-start the assembly.
|
||
|
||
The assembly listing can be momentarily interrupted and restarted by
|
||
using the space bar, just as with the LIST command. You can also
|
||
abort the assembly during pass two by hitting the RETURN key.
|
||
|
||
|
||
MGO Command: Begins execution of your object program. An expression
|
||
(see OPERAND EXPRESSIONS later in this manual) must follow the MGO
|
||
command to define the place to begin execution. For example, '1MGO
|
||
BEGIN" will cause execution to begin at the point in your program
|
||
where the label BEGIN is defined. Your program can return to S-C
|
||
ASSEMBLER II either by using an '1RTS" instruction, or by a "JMP
|
||
~1OO5." You may also abort your program by hitting the RESET key1 and
|
||
then use iOO3G in the monitor to return to the assembler system.
|
||
|
||
Note: A source program MUST be assembled using the ASM command before
|
||
it can be executed with the MGO command:
|
||
|
||
The MGO command is named "MGO" rather than "RUN" due to a naming
|
||
conflict with Apple DOS.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
- 7 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Tape Commands
|
||
|
||
Three commands are included in S-C ASSEMBLER II to allow you to
|
||
maintain source programs on cassette tape.
|
||
|
||
LOAD Command: Deletes the current source program, if any, and then
|
||
reads in a new one from cassette tape. It works exactly the same as
|
||
the LOAD command in BASIC.
|
||
|
||
SAVE Command: Writes the source program in memory on cassette tape.
|
||
It works exactly the same as the SAVE command in BASIC.
|
||
|
||
JOIN Command: Reads a program from cassette tape and positions it in
|
||
front Qf a program already in memory. The JOIN command allows you to
|
||
join two programs into one. JOIN does not renumber the lines, and
|
||
does not re-sort the lines of the combined program into line-number
|
||
order. After the JOIN is complete, you should first delete any excess
|
||
lines (such as the ".EN" from the newly-read portion), and then use
|
||
the RENUMBER command to assign new line numbers to all the lines.
|
||
|
||
The JOIN command is named "JOIN" rather than "APPEND" due to a naming
|
||
conflict with Apple DOS.
|
||
|
||
|
||
DOS COMMANDS
|
||
|
||
All the Apple DOS commands are valid, even though you are operating
|
||
from within S-C ASSEMBLER II. This feature allows you to maintain
|
||
your source and object programs on disk using the LOAD, SAVE, BLOAD,
|
||
and BSAVE commands. Source programs will be entered into the disk
|
||
catalog with a type code of "I", just as though they were Integer
|
||
BASIC programs.
|
||
|
||
Be sure to avoid typing the "RUN filename" command, because it will
|
||
be recognized by DOS as an attempt to load and execute an Integer
|
||
BASIC or Applesoft program. However, since the DOS links have been
|
||
set up for S-C ASSEMBLER II, the program will not execute. It will
|
||
just clobber any source program you may have had in memory!
|
||
|
||
|
||
|
||
|
||
|
||
- 8 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Housekeeping Commands: The Apple DOS housekeeping commands (INIT,
|
||
CATALOG, RENAME, DELETE, LOCK, UNLOCK, VERIFY, NON, NOMON, and
|
||
MAXFILES) can be used as you desire. They will function exactly the
|
||
same within S-C ASSEMBLER II as they do within BASIC.
|
||
|
||
Source Maintenance Commands: The LOAD and SAVE commands when used
|
||
with a file name will be interpreted by DOS. If no file name is
|
||
included, S-C ASSEMBLER II will interpret them as cassette tape
|
||
commands. As mentioned before, you should not use the RUN command
|
||
when you are inside S-C ASSEMBLER II, or you will just lose your
|
||
current source program. (Same thing goes for the CHAIN command.)
|
||
|
||
Object Maintenance Commands: The BSAVE, BLOAD, and BRUN commands may
|
||
be used to maintain object programs on the disk and to execute them.
|
||
Be careful when using BLOAD and BRUN that the program you are loading
|
||
does not load on top of anything you want to keep!
|
||
|
||
I/O Selection Commands: The PR#, IN#, and EXEC commands may be used
|
||
from within S-C ASSEMBLER II. PR# is used to turn on the standard
|
||
Apple parallel or serial printer interface cards. EXEC could be used
|
||
in many ways; one use might be to load a source program created by
|
||
some other editor as a text file (type code "T") on the disk. The
|
||
IN# command will virtually be ignored, because the line input routine
|
||
inside S-C ASSEMBLER II resets input to keyboard before every line is
|
||
read.
|
||
|
||
BASIC Commands: The INT and FP commands may be used to exit the S-C
|
||
ASSEMBLER II and enter Integer BASIC or Apple soft.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
- 9 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
MONITOR COMMANDS
|
||
|
||
All of the Apple II Monitor commands are available from within S-C
|
||
ASSEMBLER II. You use them by typing a dollar sign ($) after the
|
||
prompt symbol, followed by the monitor command you wish to use. This
|
||
is the same feature available in the Apple
|
||
|
||
II Mini-Assembler.
|
||
|
||
Apple II Monitor commands are explained on pages 68-71 of the red
|
||
Apple II Reference Manual. Withthem you may examine, change, move,
|
||
verify memory; read and write cassette tapes; dis-assemble machine
|
||
language programs; execute programs; call the mini-assembler and
|
||
assemble some 6502 code; perform hexadecimal arithmetic;~and monitor
|
||
program execution for debugging purposes. The fact that all these
|
||
commands may be used without leaving the S-C ASSEMBLER II system
|
||
greatly increases the facility with which you can develop and debug
|
||
assembly language programs.
|
||
|
||
:$4A.4D CA.CD
|
||
004A- 00 1D 00 96
|
||
00CA- 62 88 00 08
|
||
|
||
:$1000L
|
||
1000- 4C 1B 10 JMP $101B
|
||
1003- AD 81 C0 LDA $C081
|
||
1006- 20 0F 10 JSR $100F
|
||
1009- 4C 29 10 JMP $1029
|
||
100C- 20 AD E5 JSR $E5AD
|
||
100F- A9 1D LDA #$1D
|
||
1011- 85 4B STA $4B
|
||
1013- A9 00 LDA #$00
|
||
1015- 85 4A STA $4A
|
||
1017- AA TAX
|
||
1018- 81 4A STA ($4A,X)
|
||
101A- 60 RTS
|
||
101B- 20 D7 13 JSR $13D7
|
||
101E- 20 58 FC JSR $FC58
|
||
1021- 20 0C 10 JSR $100C
|
||
1024- A0 00 LDY #$00
|
||
1026- 20 F9 12 JSR $12F9
|
||
1029- A9 B2 LDA #$B2
|
||
102B- A0 1C LDY #$1C
|
||
102D- 20 D1 11 JSR $11D1
|
||
|
||
|
||
|
||
- 10 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
SOURCE PROGRAM FORMAT
|
||
|
||
|
||
Source programs are entered a line at a time, with a four-digit line
|
||
number identifying each line. The line numbers may run from 0000
|
||
through 9999, and leading zeroes on numbers less than 1000 must be
|
||
typed. Source program lines are kept sorted in line-number order;
|
||
the numbers are used for editing purposes, just as in BASIC. A blank
|
||
must always follow the line number. After the blank, there are four
|
||
fields of information: the label, opcode, operand, and comment
|
||
fields. Adjacent fields must be separated by at least one blank.
|
||
|
||
Although the fields are not restricted to begin in any particular
|
||
columns, it is convenient to enter them in this way for neatness.
|
||
Therefore tab stops are built in to the S-C ASSEMBLER II at columns
|
||
12, 16, and 26. When you type the control-I character, blanks will
|
||
be printed until the next tab stop is reached. If you are already at
|
||
the column right before a tab stop, the next tab stop will be skipped
|
||
over and blanks will be printed up to the second tab stop. For
|
||
information about changing the tab stops to different columns, see
|
||
Appendix A.
|
||
|
||
Label Field: May be left blank, or may contain a label of from one to
|
||
six characters. The first character of a label must be a letter;
|
||
remaining characters may be either letters or numbers. Labels are
|
||
used to name places in your program to which you will branch, as well
|
||
as constants and variables.
|
||
|
||
The standard tab settings leave enough room for only four-character
|
||
labels; however, you can go ahead and use six characters as long as
|
||
there is at least one space between the label and the opcode. If you
|
||
like, you may type labels on a separate line, with the opcode and
|
||
following fields left blank. The label will be defined as the
|
||
current value of the location counter. There aresome examples of
|
||
this in the file on the S-C ASSEMBLER II disk named "SAMPLE.SOURCE".
|
||
|
||
|
||
|
||
|
||
|
||
- 11 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Opcode Field: Contains a three-letter machine language mnemonic
|
||
opcode, an assembler directive, or a SWEET-16 mnemonic opcode. If
|
||
you are using the tab stops, the opcode field normally starts in
|
||
column 12. However, opcodes may begin in any column after at least
|
||
one blank from a label or two blanks from a line number.
|
||
|
||
S-C ASSEMBLER II uses the standard 6502 instruction mnemonics, which
|
||
are listed in the Apple II Reference Manual on pages 100-105.
|
||
Assembler directives and SWEET-16 opcodes are discussed later in this
|
||
manual.
|
||
|
||
Operand Field: Usually contains an operand expression of some sort.
|
||
Some of the 6502 instructions have no written operand, such as NOP,
|
||
BRK, DEX, and others. In these cases the comment field may be
|
||
started right after the opcode. Four of the opcodes (ROL, ROR, ASL,
|
||
and ASR) may be used both with and without an operand. If no operand
|
||
is present, you must type at least two blanks before a comment with
|
||
these four opcodes.
|
||
|
||
Comment Field: Comments are separated from the operand field by at
|
||
least one blank. For your convenience, a tab stop for comments is
|
||
set at column 26. In the assembly listing, they will start at column
|
||
~1, which is the beginning of the next line on your TV screen.
|
||
Actually comments may begin earlier or later on the line, just so at
|
||
least one blank separates them from the operand expression.
|
||
|
||
Comment Lines: Full lines of comments may be entered by typing an
|
||
asterisk (*) in the first column of the label field. This type of
|
||
comment is useful in separating various routines from each other, and
|
||
labeling their contents. It is analogous to the REM statement in
|
||
BASIC.
|
||
|
||
Lines which are completely blank are also treated as comments.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
- 12 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Samp1e Source Program
|
||
|
||
1000 *
|
||
1010 * MONITOR CALLS
|
||
1020 *
|
||
1030 DLAY .EQ $FCA8 DELAY SUBROUTINE
|
||
1040 COT1 .EQ $FDF0 CHARACTER OUTPUT
|
||
1050 SOFT .EQ $3D0 DOS SOFT RE-ENTRY
|
||
1060 IOHOOK .EQ $3EA DOS I/O HOOK ROUTINE
|
||
1070 *
|
||
1080 * I/O ADDRESSES
|
||
1090 *
|
||
1100 KEY .EQ $C000 KEYBOARD INPUT
|
||
1110 KEYS .EQ $C010 KEYBOARD STROBE
|
||
1120 *
|
||
1130 * SET UP SLOW-LIST
|
||
1140 *
|
||
1150 SLOW LDA #SLOLST PUT POINTER IN OUTPUT VECTOR
|
||
1160 STA $36
|
||
1170 LDA /SLOLST
|
||
1180 SLS1 STA $37
|
||
1190 JMP IOHOOK GET DOS TO HOOK IT IN
|
||
1200 *
|
||
1210 * SET UP FAST-LIST
|
||
1220 *
|
||
1230 FAST LDA #FSTLST
|
||
1240 STA $36
|
||
1250 LDA /FSTLST
|
||
1260 BNE SLS1
|
||
1270 *
|
||
1280 * SLOW-LIST ROUTINE
|
||
1290 *
|
||
1300 SLOLST
|
||
1310 CMP #$8D IS IT CR?
|
||
1320 BNE SLW4 NO, SO PRINT IT
|
||
1330 LDA #0 YES, SO SLOW DOWN
|
||
1340 JSR DLAY MONITOR DELAY ROUTINE
|
||
1350 SLW1 LDA KEY CHECK IF KEY TYPED
|
||
1360 BPL SLW3 NO, OUTPUT CR
|
||
1370 STA KEYS YES, CLEAR STROBE
|
||
1380 CMP #$8D IS IT CR?
|
||
1390 BEQ SLW5 YES, SO ABORT
|
||
1400 SLW2 LDA KEY NO, SO SUSPEND
|
||
1410 BPL SLW2 WAIT FOR KEY
|
||
1420 STA KEYS CLEAR STROBE
|
||
1430 CMP #$8D IS IT CR?
|
||
1440 BEQ SLW5 YES, SO ABORT
|
||
1450 SLW3 LDA #$8D OUTPUT CR
|
||
1460 SLW4 JMP COT1 MONITOR CHAR OUTPUT
|
||
1470 SLW5 JMP SOFT ...ABORT...
|
||
1480 *
|
||
1490 * FAST-LIST ROUTINE
|
||
1500 *
|
||
1510 FSTLST
|
||
1520 CMP #$8D IS IT CR?
|
||
1530 BNE SLW4 NO, SO KEEP LISTING
|
||
1540 BEQ SLW1 YES; SO CHECK FOR KEYS
|
||
1550 .EN
|
||
|
||
|
||
|
||
- 13 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
ASSEMBLER DIRECTIVES
|
||
|
||
|
||
Seven assembler directives are available in S-C ASSEMBLER II to
|
||
control the assembly process and to define data in your programs.
|
||
These are all indicated by a three-character mnemonic, in the form of
|
||
a period followed by two letters.
|
||
|
||
.OR ORigin
|
||
.TA Target Address
|
||
.EN ENd of program
|
||
.EQ EQuate
|
||
.DA DAta
|
||
.AS Ascii String
|
||
.HS Hex String
|
||
|
||
|
||
Origin: .OR expr
|
||
|
||
Sets the program origin and the target address to the value of the
|
||
expression. Program origin is the address at which the object
|
||
program will be executed. Target address is the memory address at
|
||
which the object program will be stored during the assembly. The .OR
|
||
directive sets both of these to the same value, which is the normal
|
||
way of operating. If you do not use the .OR directive, the assembler
|
||
will set both the program origin and the target address to $0800. If
|
||
the "expr" is not defined during pass one prior to its use in the .OR
|
||
directive, an error message is printed and assembly is aborted
|
||
(***UNDEF AT LINE ....).
|
||
|
||
|
||
Target Address: .TA expr
|
||
|
||
Sets the target address at which object code will be stored during
|
||
assembly. The target address is distinct from the program origin
|
||
(which is either set by the .OR directive, or is implicitly set to
|
||
$0800). The .OR directive sets both the origin and the target
|
||
address; the .TA directive sets only the target address. Object code
|
||
is produced ready to run at the program origin, but is stored
|
||
starting at the target address.
|
||
|
||
|
||
|
||
|
||
- 15 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
When you wish to assemble a program which will execute at an address
|
||
normally occupied by the assembler ($1000 through $1CFF)*, the symbol
|
||
table ($1D00 *up), or the source program text (bottom of DOS down),
|
||
you need to use the .TA and .OR directives. Set the origin first,
|
||
using the .OR directive; then set the target address to a safe value
|
||
using the <20>TA directive. It is always safe to start the target area
|
||
at $0800, providing your object code does not extend beyond $0FFF.
|
||
|
||
|
||
:ASM
|
||
|
||
1000 * SAMPLE PROGRAM TO ILLUSTRATE
|
||
1010 * THE ".TA" DIRECTIVE
|
||
1020 .OR $1000
|
||
1030 .TA $0800
|
||
1000- AD 0C 10 1040 DEMO LDA AVALUE
|
||
1003- AE 0D 10 1050 LDX XVALUE
|
||
1006- AD 0E 10 1060 LDY YVALUE
|
||
1009- 4C 00 10 1070 JMP DEMO
|
||
1080 *
|
||
100C- 0C 1090 AVALUE .DA #12
|
||
100D- 22 1090 XVALUE .DA #34
|
||
100E- 38 1090 YVALUE .DA #56
|
||
|
||
SYMBOL TABLE
|
||
|
||
DEMO 1000 AVALUE 100C XVALUE 100D
|
||
YVALUE 100E
|
||
|
||
As you can see in the example, the assembly listing looks as though
|
||
the program were stored at $1000. However, the object code is
|
||
actually stored at $0800, which is the target address set in the .TA
|
||
directive. If we dis-assemble memory starting at $0800, we see:
|
||
|
||
:$800L
|
||
|
||
0800- AD 0C 10 LDA $100C
|
||
0803- AE 0D 10 LDX $100D
|
||
0806- AC 0E 10 LDY $100E
|
||
0809- 4C 00 10 JMP $1000
|
||
080C- 0C ???
|
||
080D- 22 ???
|
||
080E- 38 SEC
|
||
|
||
|
||
* ASMDISK ends at $1CFF, symbols start at $1D00. ASMDISK (AUTOSTART)
|
||
ends at $1DFF, symbols start at $1E00. ASMDISK (APPLE II PLUS) ends
|
||
at $1FFF, symbols start at $2000.
|
||
|
||
- 16 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
After the assembly is complete, there are several ways to position
|
||
the code in memory where it really should be. You can save the
|
||
object code on cassette or disk from its current location, and
|
||
re-load it later at the correct location for execution. Be sure you
|
||
do not try to reload it while you are executing the assembler, or you
|
||
may clobber it!
|
||
|
||
Another method is to hit RESET and use the monitor memory move
|
||
command ( addrl addr2.addr3M ). This command will move the block of
|
||
memory from addr2 through addr3 to the area beginning at addri.
|
||
|
||
If you need a larger safe area than that given between $0800 and
|
||
$0FFF, you can patch the assembler at location $1010. This location
|
||
currently contains $1D, which is the page number of the start of the
|
||
assembler's symbol table. If you change this value to $30, for
|
||
example, the symbol table will start at $3000 instead of $1D00. This
|
||
will leave the area from $1D00 through $2FFF free for a target area.
|
||
To be effective, this change should be made before using the ASM
|
||
command. Be sure to leave enough room between the start of the
|
||
symbol table and the bottom of DOS for all of your source program as
|
||
well as the symbol table.
|
||
|
||
|
||
End of Program: .EN
|
||
|
||
Defines the end of the source program. You would normally make this
|
||
the last line, but you may place it earlier in order to assemble only
|
||
a portion of your source program. If no .EN is present anywhere in
|
||
your program, the assembler will assume you meant to put one after
|
||
the last line. (This is different from most assemblers, which for
|
||
some strange reason go completely crazy if the .EN directive is
|
||
missing!)
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
* These values are correct for ASMDISK. For ASMDISK (AUTOSTART) the
|
||
values are $1E and $1E00. For ASMDISK(APPLE II PLUS) the values are
|
||
$20 and $2000.
|
||
|
||
- 17 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Equate: label .EQ expr
|
||
|
||
Defines the label to have the value of the expressione If the
|
||
expression is not defined, an error message is printed (***UNDEF AT
|
||
LINE xxxx). If you neglect to use a label with an equate directive,
|
||
an error message is printed also (***NO LABEL AT LINE xxxx). In
|
||
either case, the assembly is aborted so that you can repair the
|
||
error. One common use for this directive is to define all the
|
||
page-zero variables your program uses.
|
||
|
||
|
||
1000 ACC .EQ $45
|
||
1010 IN .EQ $0200 INPUT BUFFER
|
||
1020 ACL .EQ $50
|
||
1030 ACH .EQ ACL+1
|
||
1040 PDL0 .EQ $C064 PADDLE 0
|
||
|
||
SYMBOL TABLE
|
||
|
||
ACC 0045 IN 0200 ACL 0050
|
||
ACH 0051 PDL0 C064
|
||
|
||
|
||
|
||
|
||
Data: label .DA expr (two bytes, LSB first)
|
||
label .DA #expr (one byte, LSB of expr)
|
||
label .DA /expr (one byte, MSB of expr)
|
||
|
||
Creates a constant or variable in your program. The value of the
|
||
expression, as one or two bytes, is stored at the current location.
|
||
If a label is present, it is defined as the address where the first
|
||
byte of data is stored. (If you use .DA to define a variable, it is
|
||
a good habit to use an expression like "*-*", which has a value of
|
||
zero. This weird expression will make your program more
|
||
self-explanatory when you look at it again next year.)
|
||
|
||
|
||
1000 IN .EQ $0200 INPUT BUFFER
|
||
0800- E8 03 1010 TEN3 .DA 1000
|
||
0802- 64 C0 1020 PDL0 .DA $C064 PADDLE 0 ADDRESS
|
||
0804- C1 1030 LTRA .DA #$C1 ASCII LETTER A
|
||
0805- 02 1040 BFPG .DA /IN BUFFER PAGE
|
||
|
||
SYMBOL TABLE
|
||
|
||
IN 0200 TEN3 0800 PDL0 0802
|
||
LTRA 0804 BFPG 0805
|
||
|
||
|
||
|
||
- 18 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Hex String: label .Hs hhh...h
|
||
|
||
Converts a string of hex digits (hhh...h) to binary, two digits per
|
||
byte, and stores them starting at the current location. If a label
|
||
is present, it is defined as the address where the first byte is
|
||
stored. If you do not have an even number of hexadecimal digits, the
|
||
assembler aborts with an error message (***BAD ADDRESS AT LINE xxxx).
|
||
|
||
NOTE: Unlike hexadecimal numbers used in operand expressions, you
|
||
must not use a dollar sign with the .HS directive.
|
||
|
||
A funny feature of this assembler is that the source line will print
|
||
together with the last line of bytes produced by the hex string
|
||
directive. Do not let this confuse you.
|
||
|
||
0800- F1 0900 .HS F1
|
||
0801- 23 AB 45 1000 STR .HS 23AB45
|
||
0804- 01 23 45
|
||
0807- 67 89 AB
|
||
080A- CD EF 1100 QT .HS 0123456789ABCDEF
|
||
|
||
SYMBOL TABLE
|
||
|
||
STR 0801 QT 0804
|
||
|
||
|
||
|
||
Ascii String: label .AS daaa...ad
|
||
|
||
Stores the binary form of the ASCII characters "aaa...a" in
|
||
sequential locations beginning at the current location. If a label
|
||
is present, it is defined as the address where the first character is
|
||
stored. The string "aaa...a" may contain any number of the printing
|
||
ASCII characters. You indicate the beginning and end of the string
|
||
by any delimiter !1d11 that you choose.
|
||
|
||
ASCII character codes are seven bit values. The .AS directive
|
||
normally sets the high-order, or 8th, bit to zero. Some people like
|
||
to use ascii codes with the high-order bit set to one, so S-C
|
||
ASSEMBLER II includes an option for this.
|
||
|
||
.AS daaa...d sets the high-order bits to 0
|
||
.AS -daaa...d sets the high-order bits to 1
|
||
|
||
This syntax restricts the choice of the delimiter slightlys it may be
|
||
any printing character other than space and minus.
|
||
|
||
|
||
|
||
- 19 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
|
||
|
||
0800- 53 54 52
|
||
0803- 49 4E 47 1000 STR .AS "STRING" DELIMITER IS "
|
||
0806- 22 22 22 1010 QT .AS /"""/ DELIMITER IS /
|
||
0809- C8 D5 C8
|
||
080C- BF 1020 HUH .AS -QHUH?Q DELIMITER IS ?
|
||
|
||
SYMBOL TABLE
|
||
|
||
STR 0800 QT 0806 HUH 0809
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
- 20 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
OPERAND EXPRESSIONS
|
||
|
||
|
||
Operand expressions are written using terms and operators. The valid
|
||
operators are + and -. Terms may be decimal numbers1 hexadecimal
|
||
numbers, labels, or an asterisk (*). The first term in an expression
|
||
may be preceded by a + or - sign.
|
||
|
||
Decimal Numbers: Any number in the range from 0 through 65535,
|
||
written in the normal way.
|
||
|
||
0800- A9 C8 1000 LDA #200
|
||
0802- A2 F6 1010 LDX #-10
|
||
0804- 6B 8B 1020 .DA 35691
|
||
1030 FLAG .EQ -1
|
||
|
||
|
||
Hexadecimal Numbers: Any number in the range from $0 through $FFFF.
|
||
Hexadecimal numbers are indicated by a preceding dollar sign, and may
|
||
have from one to four digits.
|
||
|
||
1050 .OR $880
|
||
0880- A9 2F 1060 LDA #$2F
|
||
0882- 85 CA 1070 STA $CA
|
||
0884- D0 1D 1080 BNE $8A3
|
||
0886- 20 2A E0 1090 JSR $E02A
|
||
1100 VALL .EQ $AB
|
||
1110 NUM .EQ $1278
|
||
1120 CONV .EQ $E59B
|
||
|
||
Beware of leaving out the dollar sign; the assembler may be quite
|
||
satisfied to think of your hexadecimal number as a decimal one if you
|
||
omit the $. In some cases even a number with letters in it, such as
|
||
23AB,may be acceptable; it may be interpreted as decimal 23 and a
|
||
comment "AB".
|
||
|
||
Labels: One to six characters; the first character must be a letter,
|
||
while the others may be either letters or digits. Labels must be
|
||
defined somewhere in the program if they are to be used in an
|
||
expression. In some cases they must be defined prior to use in
|
||
expressions to prevent an undefined or ambiguous location counter.
|
||
For example, if the expression in the operand field of an origin
|
||
(".OR") directive is not defined prior to use, the assembler will not
|
||
know how to define any subsequent labels.
|
||
|
||
|
||
|
||
|
||
|
||
- 21 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
A problem can occur if you postpone the definition of page-zero
|
||
variables until after their use in operand expressions. If these
|
||
labels are used with instructions which could assume both absolute
|
||
and zero-page address modes, a discrepancy in the location count will
|
||
occur between pass one and pass two of the assembler. (This
|
||
discrepancy cannot be detected by the present design of the
|
||
assembler, so make it a habit to always define your page-zero
|
||
variables at the beginning of your program.)
|
||
|
||
1000 VALL .EQ $AB
|
||
1010 NUM .EQ $1905
|
||
1020 CONV .EQ $E59B
|
||
0800- B5 A8 1030 LP LDA VALL-3,X
|
||
0802- 9D 05 19 1040 STA NUM,X
|
||
0805- 20 9B E5 1050 JSR CONV
|
||
0808- D0 F6 1060 BNE LP
|
||
|
||
|
||
Asterisk (*): Stands for the current value of the location counter.
|
||
This is useful for storing the length of a string as a constant in a
|
||
program. I also use it in the expression "*-*" to indicate that a
|
||
location is a variable rather than a constant.
|
||
|
||
080A- 0B 1070 QT .DA #QTSZ # BYTES IN MSG
|
||
080B- 41 4E 59
|
||
080E- 20 4D 45
|
||
0811- 53 53 41
|
||
0814- 47 45 1080 .AS /ANY MESSAGE/
|
||
1090 QTSZ .EQ *-QT-1 # OF BYTES IN MSG
|
||
0816- 00 00 1100 VARW .DA *-* 2-BYTE VARIABLE
|
||
0818- 00 1110 VARB .DA #*-* 1-BYTE VARIABLE
|
||
1120 HERE .EQ *
|
||
|
||
|
||
It is considered very poor programming practice to include branch
|
||
instructions in your program with operand expressions of the form
|
||
"*-5" or "*+7". Avoid them like the plague! They breed bugs that
|
||
can be very difficult to find. Don't be afraid to use another label
|
||
or two, no matter how silly the names might sound.
|
||
|
||
|
||
|
||
|
||
- 22 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
ADDRESSING MODES
|
||
|
||
|
||
The MOS Technology 6502 microprocessor used in the Apple II has many
|
||
great features; one of the greatest is its variety of addressing
|
||
modes. There are thirteen different modes in all, though no single
|
||
opcode can use every one of them. The charts in this chapter show
|
||
which modes can be used with each opcode. But first, here is a chart
|
||
showing an example of each mode and the way it is written in assembly
|
||
language. Except for one new kind, the syntax is the same as that
|
||
used by the Apple II mini-assembler.
|
||
|
||
Mode Example
|
||
|
||
Implied DEX \ At least two
|
||
Accumulator ROL / blanks before
|
||
comments begin.
|
||
Relative BNE expr
|
||
|
||
Immediate LDA #expr
|
||
LDA /expr
|
||
Zero Page LDA expr \
|
||
Absolute LDA expr | Assembler uses
|
||
| Zero Page form
|
||
ZeroPage,X LDA expr,X | if possible;
|
||
Absolute,X LDA expr,X | if not, it uses
|
||
Zero Page,Y LDA expr,Y | Absolute form.
|
||
Absolute,Y LDA expr,Y /
|
||
(Zero Page,X) LDA (expr,X)
|
||
(Zero Page),Y LDA (expr),Y
|
||
(Absolute) JMP (expr)
|
||
|
||
|
||
For a full explanation of the modes and how to use them, I refer you
|
||
to the MOS Technology Hardware and Programming Manuals, as well as
|
||
the other references mentioned in the bibliography in Appendix D.
|
||
|
||
S-C ASSEMBLER II has one syntactical addition over the Apple II
|
||
mini-assembler. The immediate mode may be indicated by either a
|
||
pound sign (#) or a slash (/). The "#" means that the least
|
||
significant byte of the 16-bit expression value should be used
|
||
(equivalent to "expr MOD 256" in BASIC).
|
||
|
||
|
||
|
||
- 23 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
The "/" means that the most significant byte should be used
|
||
(equivalent to "expr/256" in BASIC).
|
||
|
||
One use for this feature is in setting up the address of a subroutine
|
||
or a buffer in a pointer. (A pointer is a pair of bytes containing
|
||
an address which "points" at a subroutine or into a buffer.) For
|
||
example:
|
||
|
||
1000 SLOW .EQ $1C89
|
||
0800- A9 89 1010 LDA #SLOW
|
||
0802- 85 36 1020 STA $36
|
||
0804- A9 1C 1030 LDA /SLOW
|
||
0806- 85 37 1040 STA $37
|
||
|
||
|
||
is used inside S-C ASSEMBLER II to turn on the Slow-List feature when
|
||
you type the SLOW command.
|
||
|
||
Trying to comprehend and remember thirteen different addressing modes
|
||
can be very difficult; therefore it is convenient to try to group
|
||
them into categories. I use the following breakdown: implied mode,
|
||
relative mode, and other modes. "Other" modes now includes eleven
|
||
modes, so I break it down further: accumulator, immediate, direct,
|
||
and indirect modes. Each of direct and indirect modes may be either
|
||
indexed or not indexed, and either zero page or Absolute. The
|
||
following outline will give you a better idea of what I am describing.
|
||
|
||
|
||
I. Implied
|
||
|
||
II. Accumulator
|
||
|
||
III. Direct
|
||
A. Not Indexed
|
||
1. Zero Page
|
||
2. Absolute
|
||
B. Indexed by X-register
|
||
1. Zero Page,X
|
||
2. Absolute,X
|
||
C. Indexed by Y-register
|
||
1. Zero Page,Y
|
||
2. Absolute,Y
|
||
|
||
IV. Indirect
|
||
A. Not Indexed -- (Absolute)
|
||
B. Indexed by X-register (Zero Page,X)
|
||
C. Indexed by Y-register (Zero Page),Y
|
||
|
||
|
||
|
||
- 24 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Implied Mode: In this mode, the address is implied by the nature of
|
||
the instruction; the operand field is left blank. All of the opcodes
|
||
in this class are only one byte long. They are:
|
||
|
||
BRK DEX PHA RTS TAY
|
||
CLC DEY PHP SEC TSX
|
||
CLD INX PLA SED TXA
|
||
CLI INY PLP SEI TXS
|
||
CLV NOP RTI TAX TYA
|
||
|
||
|
||
Relative Mode: This mode is used only by the conditional branch
|
||
instructions. The expression is converted to a signed offset from
|
||
the location following the branch instruction. The result must be in
|
||
the range from -128 through +127 to be legal. All of these
|
||
instructions occupy two bytes. They are:
|
||
|
||
BCC BEQ BNE BVC
|
||
BCS BMI BPL BVS
|
||
|
||
|
||
Other Modes: Usage of the other eleven modes is much more complex.
|
||
The table on the next page shows which modes are defined for each of
|
||
the remaining opcodes. These instructions occupy one byte in the
|
||
accumulator mode, two bytes in any of the zero page modes, and three
|
||
bytes in any of the absolute modes. They are:
|
||
|
||
ADC AND ASL BIT CMP
|
||
CPX CPY DEC EOR INC
|
||
LDA LDX LDY LSR ORA
|
||
ROL ROR SBC STA STY
|
||
STX JMP JSR
|
||
|
||
You might notice especially that only four opcodes are usable in the
|
||
accumulator mode (ASL, LSR, ROL, ROR); that only two opcodes use the
|
||
"ZP,Y" mode (LDX and STX); and that only one opcode uses the
|
||
indirect absolute non-indexed mode (JMP).
|
||
|
||
|
||
|
||
|
||
|
||
|
||
- 25 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
|
||
ACCUM- IMMED- ---- D I R E C T ---- ---- I N D I R E C T ----
|
||
ULATOR IATE INDEXED INDEXED
|
||
blank #expr expr expr,X expr,Y (expr) (expr,X) (expr),Y
|
||
/expr ZP/ABS ZP/ABS ZP/ABS
|
||
|
||
ADC -- 69 65/6D 75/7D --/79 -- 61 71
|
||
AND -- 29 25/2D 35/3D --/39 -- 21 31
|
||
ASL 0A -- 06/0E 16/1E --/-- -- -- --
|
||
BIT -- -- 24/2C --/-- --/-- -- -- --
|
||
CMP -- C9 C5/CD D5/DD --/D9 -- C1 D1
|
||
CPX -- E0 E4/EC --/-- --/-- -- -- --
|
||
CPY -- C0 C4/CC --/-- --/-- -- -- --
|
||
DEC -- -- C6/CE D6/DE --/-- -- -- --
|
||
EOR -- 49 45/4D 55/5D --/59 -- 41 51
|
||
INC -- -- E6/EE F6/FE --/-- -- -- --
|
||
LDA -- A9 A5/AD B5/BD --/B9 -- A1 31
|
||
LDX -- A2 A6/AE --/-- B6/BE -- -- --
|
||
LDY -- AO A4/AC B4/BC --/-- -- -- --
|
||
LSR 4A -- 46/4E 56/5E --/-- -- -- --
|
||
ORA -- 09 05/0D 15/1D --/19 -- 01 11
|
||
ROL 2A -- 26/2E 36/3E --/-- -- -- --
|
||
ROR 6A -- 66/6E 76/7E --/-- -- -- --
|
||
SBC -- E9 E5/ED F5/FD --/F9 -- E1 F1
|
||
STA -- -- 85/8D 95/9D --/99 -- 81 91
|
||
STX -- -- 86/8E --/-- 96/-- -- -- --
|
||
STY -- -- 84/8C 94/-- --/-- -- -- --
|
||
|
||
JMP -- -- --/4C --/-- --/-- 6C -- --
|
||
JSR -- -- --/20 --/-- --/-- -- -- --
|
||
|
||
|
||
- 26 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
SWEET-16
|
||
|
||
|
||
SWEET-16 is the little 16-bit interpreter Steve Wozniak wrote, which
|
||
is hidden inside your Apple Integer BASIC ROM's. He described it
|
||
fully in BYTE Magazine, November, 1977, pages 150-159: "SWEET-16 --
|
||
The 6502 Dream Machine". The same article is available directly from
|
||
Apple, or in one of the many editions of the "WOZPAK".
|
||
|
||
Many people have begged me to include the ability to assemble code
|
||
for SWEET-16 in the S-C ASSEMBLER II, so I have now done so. (It is
|
||
included in versions 3.2 and later.) I have implemented the same
|
||
mnemonics and syntax which Steve Wozniak described in the article.
|
||
|
||
The beauty of SWEET-16 is in its ability to perform 16-bit arithmetic
|
||
and data moves using automatically updated address pointers. And to
|
||
add icing to the cake, most of the instructions are only one byte
|
||
long! You can write extremely compact code, if you are willing to
|
||
pay the price of slower execution. Portions of S-C ASSEMBLER II are
|
||
coded in SWEET-16; these include the RENUMBER command processor and
|
||
the opcode table search routine.
|
||
|
||
SWEET-16 is invoked by the instruction "J5R $F689", and the bytes
|
||
immediately after this instruction should contain opcodes for
|
||
SWEET-16 to process. If you are serious about wanting to learn to
|
||
use SWEET-16, locate the article and start studying.
|
||
|
||
1n lo hi SET n,addr 01 ea BR addr
|
||
2n LD n 02 ea BNC addr
|
||
3n ST n 03 ea BC addr
|
||
4n LD @n 04 ea BP addr
|
||
5n ST @n 05 ea BM addr
|
||
6n LDD @n 06 ea BZ addr
|
||
7n STD @n 07 ea BNZ addr
|
||
8n POP @n 08 ea BM1 addr
|
||
9n STP @n 09 ea BNM1 addr
|
||
An ADD n 0C ea BS addr
|
||
Bn SUB n
|
||
Cn POPD @n 00 RTN
|
||
Dn CPR n 0A BK
|
||
En INR n 0B RS
|
||
Fn DCR n
|
||
|
||
* This is the address of SWEET-16 in the Integer BASIC ROM. If you
|
||
are using ASMDISK (APPLE II PLUS), SWEET-16 begins at $1D89, inside
|
||
the assembler.
|
||
|
||
- 27 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
|
||
1000 .OR $11DE
|
||
1010 .TA $0800
|
||
1180 HIMM .EQ $4C TOP OF SOURCE
|
||
1410 SW16 .EQ $F689 SWEET-16
|
||
4080 *
|
||
4090 * RENUMBER COMMAND
|
||
4100 *
|
||
11DE- 20 89 F6 4110 REN JSR SW16 CALL SWEET-17
|
||
11E1- 11 CA 00 4120 SET 1,PP POINT AT PP
|
||
11E4- 61 4130 LDD @1 GET PP
|
||
11E5- 31 4140 ST 1 (R1)=PP
|
||
11E6- 12 0A 00 4150 SET 2,10 INCREMENT = 10
|
||
11E9- 13 4C 00 4160 SET 3,HIMEM POINT AT HIMEM
|
||
11EC- 63 4170 LDD @3 GET HIMEM
|
||
11ED- 33 4180 ST 3 (R3)=HIMEM
|
||
11EE- 14 DE 03 4190 SET 4,990 START=990
|
||
11F1- 21 4200 REN1 LD 1 TEST IF THRU
|
||
11F2- D3 4210 CPR 3
|
||
11F3- 03 0E 4220 BC REN2 FINISHED
|
||
11F5- 41 4230 LD @1 GET # BYTES
|
||
11F6- 35 4240 ST 5 SAVE FOR LATER
|
||
11F7- 24 4250 LD 4 GET SEQ. NO.
|
||
11F8- A2 4260 ADD 2 ADD INCREMENT
|
||
11F9- 34 4270 ST 4 STORE NEXT SEQ. NO.
|
||
11FA- 71 4280 STD @1 PUT SEQ: NO. IN
|
||
11FB- F1 4290 DCR 1 BACK UP POINTER
|
||
11FC- F1 4300 DCR 1
|
||
11FD- F1 4310 DCR 1
|
||
11FE- 21 4320 LD 1 MOVE TO NEXT
|
||
11FF- A5 4330 ADD 5
|
||
1200- 31 4340 ST 1
|
||
1201- 01 EE 4350 BR REN1
|
||
1203- 00 4360 REN2 RTN
|
||
1204- 60 4370 RTS
|
||
|
||
SYMBOL TABLE
|
||
|
||
HIMM 004C SW16 F689 REN 11DE
|
||
REN1 11F1 REN2 1203
|
||
|
||
|
||
|
||
|
||
|
||
- 28 -
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
APPENDIX A
|
||
|
||
|
||
Operation and Memory Usa~e
|
||
|
||
Version 3.2 of S-C ASSEMBLER II is a disk-based version, and is
|
||
supplied on an Apple DOS 3.2.1 Master Disk.
|
||
|
||
Contents of the Disk: The disk contains standard Apple DOS 3.2.1, and
|
||
seven files. When you boot the disk, if your Apple has Integer BASIC
|
||
ROMs, the following catalog will print:
|
||
|
||
S-C ASSEMBLER II -- DISK VERSION 3.2
|
||
COPYRIGHT JUNE #), 1979
|
||
|
||
DISK VOLUME 001
|
||
|
||
I 002 HELLO
|
||
B 015 ASMDISK
|
||
I 008 SAMPLE.SOURCE
|
||
I 011 APPLE-TALKER
|
||
I 003 USEFUL INFORMATION (BASIC)
|
||
B 016 ASMDISK (AUTOSTART)
|
||
B 018 ASMDISK (APPLE II PLUS)
|
||
|
||
(If your Apple does not have Integer BASIC in ROM, or in RAM with the
|
||
Pascal Language System, you will get the message "LANGUAGE NOT
|
||
AVAILABLE" instead of a catalog when you boot the disk. Don't worry
|
||
about this; just type the CATALOG command and you will get one. You
|
||
can change the HELLO program to an Applesoft version later.)
|
||
|
||
The three files with names containing "ASMDISK" are three versions of
|
||
the S-C ASSEMBLER II, for the three different configurations of Apple
|
||
II computers. If you have an Apple II with the standard monitor ROM
|
||
and with Integer BASIC, you can use the shortest version: ASMDISK.
|
||
If you have Integer BASIC either in ROM or in the Pascal System RAM
|
||
board, with the Autostart Monitor ROM, use the next version: ASMDISK
|
||
(AUTOSTART). If you do not have Integer BASIC at all, usethe version
|
||
called ASMDISK (APPLE II PLUS). SAMPLE.SOURCE and APPLE-TALKER are
|
||
not Integer BASIC programs. They are sample assembly language
|
||
programs, and are described on page A-4 in this appendix.
|
||
|
||
When you have decided which version of the assembler you are going
|
||
to use, simply BRUN the file. (ASMDISK (APPLE II PLUS) must be
|
||
BRUNned from Applesoft; the other two versions must be BRUNned from
|
||
Integer BASIC.)
|
||
|
||
>BRUN ASMDISK or >BRUN ASMDISK (AUTOSTART)
|
||
>BRUN ASMDISK (APPLE II PLUS)
|
||
|
||
A - 1
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Memory Usage: The S-C ASSEMBLER II program is 3328* bytes long, and
|
||
resides from $1000 through $1CFF* in memory. To operate, you need at
|
||
least a 24K Apple; remember that Apple DOS uses over 10K for itself.
|
||
|
||
Your source program is stored with the highest numbered line at the
|
||
high end of memory (right under DOS). The lines are kept in
|
||
numerical order, the same way as Apple BASIC does it. Locations $CA
|
||
and $CB contain the address of the beginning of the source program.
|
||
During assembly, a symbol table is built. It begins at $1D00 and
|
||
grows toward the source program. (If they meet you get *** MEM FULL
|
||
ERR.)
|
||
|
||
The assembler stores your object code wherever you direct it with the
|
||
".OR" or ".TA" directives. If you do not use either of these, the
|
||
object code will be stored starting at $0800. You should be careful
|
||
not to direct the object code on top of the assembler, your source
|
||
program, or the symbol table!
|
||
|
||
Many locations in page zero are used during editing and assembly.
|
||
The only ones which must be protected while you execute your object
|
||
program are $4A through $4D and $CA through $CD. The high end of
|
||
page one is used as a stack (6502 hardware feature). The low end of
|
||
page two is used as an input buffer (Apple Monitor input routine).
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
* The values are correct for ASMDISK. For ASMDISK (AUTOSTART) the
|
||
values are 3584, $1DFF, and $1E00. The values for ASMDISK (APPLE II
|
||
PLUS) are 4096, $1FFF, and $2000.
|
||
|
||
A - 2
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
ROM USAGE
|
||
|
||
Address Purpose
|
||
E02A * Get next byte through $E2,E3
|
||
E372 * Delete range of lines
|
||
E38A * Locate and delete source line
|
||
E3C4 * Print quote from page $EB00
|
||
E523 * Print line number
|
||
E56D,E576 * Locate source line
|
||
EED3 * Print error message
|
||
F115 * Print "ERR"
|
||
F11E,F12C * Set up for LOAD command (cassette)
|
||
F137 * Decrement limit
|
||
F140 * SAVE command (cassette)
|
||
F689 * SWEET-16 Interpreter
|
||
FB63 * 16-bit multiply
|
||
FC30 Handle screen-editing characters
|
||
FCA8 Delay
|
||
FC58 Clear screen
|
||
FD0C Character input
|
||
FD1B Keyboard input
|
||
FD67 Read input line
|
||
FD9E Print minus sign.
|
||
FDDA Print (A-register) in hexadecimal
|
||
FDED,FDF0 Character output
|
||
FE00 Display memory in hexadecimal
|
||
FEFD Cassette tape read
|
||
FF3A Ring bell
|
||
FFA7 Get hexadecimal number
|
||
FFBE Jump into monitor command processor
|
||
FFC7 Clear mode byte
|
||
FFCC Table of monitor commands
|
||
|
||
|
||
|
||
* These routines are not referenced by the Apple II Plus version of
|
||
S-C ASSEMBLER II. Also, the routine at FB63 is not referenced from
|
||
the Autostart ROM version.
|
||
|
||
|
||
|
||
|
||
A - 3
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Sample Source Programs: Two sample source programs have been included
|
||
on the S-C ASSEMBLER II disk. These are intended to illustrate a few
|
||
of the neat features of S-C ASSEMBLER II. However, they have
|
||
functional value as well.
|
||
|
||
APPLE-TALKER consists of three programs. The first, "RCRD", simply
|
||
echoes through the Apple speaker whatever it hears at the cassette
|
||
input port. If you play a tape that you have previously recorded you
|
||
voice on, and adjust the volume control until it sounds best, you can
|
||
hear the Apple's rendition of your voice. (It is interesting to try
|
||
this with other sounds as well, like music.) The second program,
|
||
"READ", is similar; however, it not only listens to the cassette
|
||
input port, but also stores the bits in a big buffer. The third
|
||
program, "TALK", plays back all the bits from the big buffer. You
|
||
can use the basic techniques out of these programs to build some
|
||
really fancy frills for your game and demo routines.
|
||
|
||
SAMPLE.SOURCE contains a subroutine similar to my "SLOWLIST" program,
|
||
which was published in MICRO (July, 1978). The difference is that
|
||
this version works with DOS 3.2. It is very similar to the speed and
|
||
suspension control I have included in S-C ASSEMBLER II.
|
||
|
||
Useful Information: The last file on the S-C ASSEMBLER II disk is
|
||
called "USEFUL INFORMATION (BASIC)". This is a BASIC program which
|
||
will BLOAD the assembler and look into certain locations to determine
|
||
the current values of the tab stops and the RENUMBER base and
|
||
increment. It will then print the data out in a nice little report.
|
||
If you make some changes to any of these parameters, this program
|
||
could keep you straight as to which version is which. Of course you
|
||
can also glean from the program just where these items of information
|
||
are kept inside the assembler.
|
||
|
||
A - 4
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Handy Patches: Many customers have requested patches for the tab
|
||
stops, and for the RENUMBER parameters. In the current release of
|
||
S-C ASSEMBLER II (Disk Version 3.2), the locations to change are as
|
||
follows:
|
||
|
||
11EF,11F0 (DE 03) base - increment (99010)
|
||
11E7,11E8 (0A 00) increment
|
||
13A1 (09) first tab stop \
|
||
13A5 (0D) second tab stop | column number
|
||
1394 (17) third tab stop / minus three
|
||
1390 (89) tab control character (Ic)
|
||
|
||
Some customers have complained about the disappearance of the
|
||
assembler's symbol table after RESET and soft re-entry. You can
|
||
re-establish all the assembled symbols except the first one by
|
||
patching a non-zero value at $1D00 after re-entry.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
A - 5
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
APPENDIX B
|
||
|
||
|
||
Error Messages
|
||
|
||
|
||
If you make a mistake, S-C ASSEMBLER II will probably catch you.
|
||
Here are the error messages you may see.
|
||
|
||
*** SYNTAX ERROR Misspelled command or bad line number.
|
||
|
||
*** MEM FULL ERR Either you do not have enough memory
|
||
for the source program, or for the
|
||
source plus the symbol table, or a
|
||
tape read error has occurred.
|
||
|
||
*** RANGE ERR AT LINE xxxx The relative offset for a branch
|
||
instruction was not between -128 and +127.
|
||
|
||
*** NO LABEL AT LINE xxxx There was no label with an equate (.EQ)
|
||
directive.
|
||
|
||
*** BAD OPCODE AT LINE xxxx The characters in the opcode field are
|
||
not a valid opcode or directive.
|
||
|
||
*** EXTRA DEF AT LINE xxxx The same label was defined more than
|
||
once.
|
||
|
||
*** UNDEF AT LINE xxxx A symbol in the operand field is not
|
||
defined.
|
||
|
||
*** BAD SYMBOL AT LINE xxxx A character in the label field is not
|
||
a legal character for a label.
|
||
|
||
*** BAD ADDRESS AT LINE xxxx This one is a catch-all for syntactical
|
||
errors in the operand expression, as well
|
||
as for use of a particular address mode
|
||
with an opcode that does not support that
|
||
mode.
|
||
|
||
The "xxxx" in the above error messages will be the line number of
|
||
the line with the error in it.
|
||
|
||
In all cases when an error is discovered during assembly, the error
|
||
message will be printed and then assembly will abort. You can then
|
||
list the indicated line, repair the problem, and try again.
|
||
|
||
|
||
|
||
|
||
|
||
B - 1
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
APPENDIX C
|
||
|
||
|
||
Printer Software
|
||
|
||
|
||
The PRT command turns on the self-contained printer software by
|
||
inserting its starting address at locations $36 and $37, and then
|
||
calling the IOHOOK routine in DOS at $03EA. If you have the Apple
|
||
parallel or serial printer interface boards, you will not use the PRT
|
||
command. Instead, you should use the DOS command PR#n to activate
|
||
your printer.
|
||
|
||
The self-contained printer software inside S-C ASSEMBLER II is
|
||
written especially for the Practical Automation DMTP-6uP printer.
|
||
This printer costs less than $700 including power supply and
|
||
controller -- a real bargain. All it takes to interface their
|
||
controller to the Apple II is to run a twisted pair from their
|
||
controller to the game paddle connector inside the Apple II. The
|
||
software uses one of the TTL outputs at the game connector as a 300
|
||
baud serial interface.
|
||
|
||
Some features of the printer driver deserve explanation.
|
||
|
||
The printer normally begins printing 1/4 inch from the left edge of
|
||
the paper. PRT provides left margin control, and is set to actually
|
||
begin printing in column 11. PRT also keeps track of the number of
|
||
lines on the page, and pauses after 56 lines so that you can insert a
|
||
new sheet of paper. When the paper is ready, tap the space bar to
|
||
continue printing. PRT optimizes speed to minimize the additional
|
||
delay during a carriage return. At any time you wish to suspend or
|
||
abort printing, you use the space bar or RETURN key, just as in the
|
||
SLOW and FAST modes.
|
||
|
||
A complete listing of the PRT subroutine is included in this
|
||
Appendix. After studying it you should be able to create a similar
|
||
subroutine for any other printer you may have. Several customers have
|
||
written to me telling of their success with interfacing the Integral
|
||
Data, Heathkit, DIABLO, and Centronics printers. Others are using
|
||
Selectrics or Teletypes.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
C - 1
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Listing of the PRT subroutine
|
||
|
||
1000 .OR $1C00
|
||
1010 .TA $0800
|
||
1020 *
|
||
1030 * PAGE ZERO VARIABLES
|
||
1040 *
|
||
1050 CH .EQ $24 CURSOR HORIZONTAL POSITION
|
||
1060 OLDC .EQ $F0 # CHARS PREV LINE
|
||
1070 NEWC .EQ $F1 # CHARS THIS LINE
|
||
1080 LNCT .EQ $F4 # LINES THIS PAGE
|
||
1090 PRTX .EQ $F5 SAVE X
|
||
1100 PRTY .EQ $F6 SAVE Y
|
||
1110 *
|
||
1120 * ROM-BASED ROUTINES
|
||
1130 *
|
||
1140 DLAY .EQ $FCA8 DELAY SUBROUTINE
|
||
1150 COT1 .EQ $FDF0 COUT AFTER USER EXIT
|
||
1160 *
|
||
1170 * SOFT RETURN TO ASSEMBLER
|
||
1180 *
|
||
1190 SOFT .EQ $1003
|
||
1200 *
|
||
1210 * PRINTER DRIVER
|
||
1220 *
|
||
1C00- 84 F6 1230 PRNT STY PRTY SAVE X AND Y
|
||
1C02- 86 F5 1240 STX PRTX
|
||
1C04- C9 8D 1250 CMP #$8D IS IT CR?
|
||
1C06- D0 39 1260 BNE PRT5 NO
|
||
1C08- A4 F0 1270 LDY OLDC YES, GET # CHARS PREV LINE
|
||
1280 * WAS LONGER THAN THIS LINE
|
||
1C0A- C8 1290 INY
|
||
1C0B- A9 50 1300 PRT1 LDA #80 WAIT A WHILE
|
||
1C0D- 20 A8 FC 1310 JSR DLAY MONITOR DELAY
|
||
1C10- 88 1320 DEY
|
||
1C11- D0 F8 1330 BNE PRT1
|
||
1C13- A9 8D 1340 LDA #$8D OUTPUT CR
|
||
1C15- 20 66 1C 1350 JSR POUT
|
||
1C18- A5 F1 1360 LDA NEWC
|
||
1C1A- 85 F0 1370 STA OLDC
|
||
1C1C- A9 00 1380 LDA #0
|
||
1C1E- 85 F1 1390 STA NEWC
|
||
1C20- A2 0A 1400 LDX #10 LEFT MARGIN
|
||
1C22- A9 A0 1410 PRT2 LDA #$A0 TAB OVER MARGIN
|
||
1C24- 20 68 1C 1420 JSR POT0
|
||
1C27- CA 1430 DEX
|
||
1C28- D0 F8 1440 BNE PRT2
|
||
1C2A- A4 F6 1450 PRT3 LDY PRTY RESTORE X AND Y
|
||
1C2C- A6 F5 1460 LDX PRTX
|
||
1C2E- E6 F4 1470 INC LNCT COUNT THE LINE
|
||
1C30- A5 F4 1480 LDA LNCT SEE IF END OF PAGE
|
||
1C32- C9 38 1490 CMP #56 # LINES PER PAGE
|
||
1C34- 90 5C 1500 BCC SLW1 NOT END, JOIN FAST LIST
|
||
1C36- A9 8D 1510 LDA #$8D YES, OUTPUT CR
|
||
1C38- 20 F0 FD 1520 JSR COT1 MONITOR OUTPUT
|
||
|
||
|
||
C - 2
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
1C3B- A9 00 1530 LDA #0 CLEAR LINE COUNT
|
||
1C3D- 85 F4 1540 STA LNCT
|
||
1C3F- F0 5D 1550 BEQ SLW2 JOIN SUSPEND, WAIT FOR KEY
|
||
1560 *
|
||
1C41- A4 F0 1570 PRT5 LDY OLDC NOT END OF LINE YET
|
||
1C43- F0 02 1580 BEQ PRT6 PAST PREVIOUS LINE
|
||
1C45- C5 F0 1590 DEC OLDC
|
||
1C47- 48 1600 PRT6 PHA SAVE CHAR
|
||
1C48- A5 F1 1610 PRT9 LDA NEWC SEE IF LINE FULL
|
||
1C4A- C9 46 1620 CMP #70 80-CHAR LINE
|
||
1C4C- B0 10 1630 BCS PRT7 IGNORE IF EXCESS
|
||
1C4E- C5 24 1640 CMP CH SEE IF NEED TAB
|
||
1C50- B0 07 1650 BCS PRT8 NO
|
||
1C52- A9 A0 1660 LDA #$A0 SEND BLANKS
|
||
1C54- 20 66 1C 1670 JSR POUT TO CATCH UP TO TAB
|
||
1C57- F0 EF 1680 BEQ PRT9 ...ALWAYS
|
||
1C59- 68 1690 PRT8 PLA
|
||
1C5A- 48 1700 PHA
|
||
1C5B- 20 66 1C 1710 JSR POUT PRINT IT
|
||
1C5E- 68 1720 PRT7 PLA RESTORE CHAR
|
||
1C5F- A4 F6 1730 LDY PRTY RESTORE X AND Y
|
||
1C61- A6 F5 1740 LDX PRTX
|
||
1C63- 4C F0 FD 1750 JMP COT1 MONITOR OUTPUT
|
||
1760 *
|
||
1770 * PRINTER OUTPUT -- 300 BAUD
|
||
1780 *
|
||
1C66- E6 F1 1790 POUT INC NEWC COUNT THE CHAR
|
||
1C68- A0 0A 1800 POT0 LDY #10 # BITS TO SEND
|
||
1C6A- 18 1810 CLC SET UP FOR START BIT
|
||
1C6B- 48 1820 POT1 PHA SAVE CHAR
|
||
1C6C- B0 05 1830 BCS POT2 1-BIT, SEND MARK
|
||
1C6E- AD 59 C0 1840 LDA $C059 SPACE
|
||
1C71- 90 03 1850 BCC POT3
|
||
1C73- AD 58 C0 1860 POT2 LDA $C058 MARK
|
||
1C76- A9 4D 1870 POT3 LDA #77 TIMING LOOP FOR 300 BAUD
|
||
1C78- 48 1880 POT4 PHA
|
||
1C79- A9 20 1890 LDA #$20
|
||
1C7B- 4A 1900 POT5 LSR
|
||
1C7C- 90 FD 1910 BCC POT5
|
||
1C7E- 68 1920 PLA
|
||
1C7F- E9 01 1930 SBC #1
|
||
1C81- D0 F5 1940 BNE POT4
|
||
1C83- 68 1950 PLA GET CHAR (CARRY IS SET)
|
||
1C84- 6A 1960 ROR NEXT BIT INTO CARRY
|
||
1C85- 88 1970 DEY
|
||
1C86- D0 E3 1980 BNE POT1 SEND NEXT BIT
|
||
1C88- 60 1990 RTS
|
||
2000 *
|
||
2010 * SLOW-LIST ROUTINE
|
||
2020 *
|
||
1C89- C9 8D 2030 SLST CMP #$8D IS IT CR?
|
||
1C8B- D0 1F 2040 BNE SLW4 NO, SO PRINT IT
|
||
1C8D- A9 00 2050 LDA #0 YES, SO SLOW DOWN
|
||
1C8F- 20 A8 FC 2060 JSR DLAY MONITOR DELAY ROUTINE
|
||
1C92- AD 00 C0 2070 SLW1 LDA $C000 CHECK IF KEY TYPED
|
||
1C95- 10 13 2080 BPL SLW3 NO, OUTPUT CR
|
||
|
||
|
||
C - 3
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
1C97- 8D 10 C0 2090 STA $C010 YES, CLEAR STROBE
|
||
1C9A- C9 8D 2100 CMP #$8D IS IT CR?
|
||
1C9C- F0 11 2110 BEQ SLW5 YES, SO ABORT
|
||
1C9E- AD 00 C0 2120 SLW2 LDA $C000 NO, SO SUSPEND
|
||
1CA1- 10 FB 2130 BPL SLW2 WAIT FOR KEY
|
||
1CA3- 8D 10 C0 2140 STA $C010 CLEAR STROBE
|
||
1CA6- C9 8D 2150 CMP #$8D IS IT CR?
|
||
1CA8- F0 05 2160 BEQ SLW5 YES, SO ABORT
|
||
1CAA- A9 8D 2170 SLW3 LDA #$8D OUTPUT CR
|
||
1CAC- 4C F0 FD 2180 SLW4 JMP COT1 MONITOR OUTPUT
|
||
1CAF- 4C 03 10 2190 SLW5 JMP SOFT ...ABORT...
|
||
2200 *
|
||
2210 * FAST-LIST ROUTINE
|
||
2220 *
|
||
1CB2- C9 8D 2230 FLST CMP #$8D IS IT CR?
|
||
1CB4- D0 F6 2240 BNE SLW4 NO, SO KEEP LISTING
|
||
1CB6- F0 DA 2250 BEQ SLW1 YES, SO CHECK FOR KEYS
|
||
2260 .EN
|
||
|
||
|
||
SYMBOL TABLE
|
||
|
||
CH 0024 OLDC 00F0 NEWC 00F1
|
||
LNCT 00F4 PRTX 00F5 PRTY 00F6
|
||
DLAY FCA8 COT1 FDF0 SOFT 1003
|
||
PRNT 1C00 PRT1 1C0B PRT2 1C22
|
||
PRT3 1C2A PRT5 1C41 PRT6 1C47
|
||
PRT9 1C48 PRT8 1C59 PRT7 1C5E
|
||
POUT 1C66 POT0 1C68 POT1 1C6B
|
||
POT2 1C73 POT3 1C76 POT4 1C78
|
||
POT5 1C7B SLST 1C89 SLW1 1C92
|
||
SLW2 1C9E SLW3 1CAA SLW4 1CAC
|
||
SLW5 1CAF FLST 1CB2
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
C - 4
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
APPENDIX D
|
||
|
||
|
||
Sources of help with machine language programming are plentiful, but
|
||
most of them do not deal with the same microcomputer that is in the
|
||
Apple II. Here are some that I have found helpful.
|
||
|
||
1. MC56500 Microcomputer Family Programming Manual, MOS Technology,
|
||
Inc., 1976. This is "from the horse's mouth," so you should probably
|
||
get one from your computer store. The same book has been published
|
||
by Synertek and Rockwell, who are both second sources for the 6502
|
||
chip.
|
||
|
||
2. Programming the 6502, Rodnay Zaks, SYBEX, 1978.
|
||
|
||
3. 6502 Applications Book, Rodnay Zaks, SYBEX, 1979.
|
||
|
||
4. How to Program Microcomputers, William Barden, Jr., Howard W.
|
||
Sams & Co., 1977. This covers programming for the 8080, 6800, and
|
||
the 6502. It has many simple programs for all three types.
|
||
|
||
5. Programming a Microcomputer: 6502, Caxton C. Foster,
|
||
Addison-Wesley Publishing Company, 1978. Oriented toward the KIM-1,
|
||
but has very good explanations and examples of the machine language.
|
||
|
||
6. Apple-II Reference Manual, Apple Computer Company, 1978. You
|
||
already own this one! It has the complete listing of the Apple
|
||
ROM-based monitor, and several other ROM-based routines. This is a
|
||
gold mine!
|
||
|
||
7. MICRO -- The 6502 Journal. This is a monthly magazine dedicated
|
||
to the 6502 microprocessor. It is published by The COMPUTERIST, P.
|
||
0. Box 6502, Chelmsford, MA 01824. Subscriptions are currently $15.00
|
||
per year, or 12 issues.
|
||
|
||
8. Call-A.P.P.L.E., Apple Pugetsound Program Library Exchange.
|
||
Another magazine, dedicated strictly to the Apple II. Free to
|
||
members, and membership is $10; write to 8710 Salty Drive N.W.,
|
||
Olympia, WA 98502. Published nine times per year.
|
||
|
||
9. APPLE-GRAM, the newsletter of the Dallas, Texas, Apple Corps.
|
||
Subscription is $12/year from The Apple Corps, P. 0. Box 5537,
|
||
Richardson, TX 75080.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
D - 1
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
10. The Apple Assembly Line, a newsletter specifically for those who
|
||
are using assembly language with their Apple computer. Subscription
|
||
is $12/year from S-C SOFTWARE, P. 0. Box 5537, Richardson, TX 75080.
|
||
|
||
|
||
One of the best ways to learn assembly or machine language is to
|
||
examine carefully the work of others. I suggest you use the
|
||
dis-assembler which is in ROM in your Apple II to disassemble
|
||
everything in sight. Look at how Integer BASIC and Applesoft are
|
||
coded. Look inside S-C ASSEMBLER II and see how it works. You can
|
||
even try making some changes and add in the features you think I
|
||
should have included in the first place!
|
||
|
||
Sources of help with learning to use SWEET-16 are even more limited.
|
||
Here are the ones I have found:
|
||
|
||
1. "SWEET-16 -- The 6502 Dream Machine", BYTE, November, 1977, pages
|
||
150-159. This is the definitive article written by the creator of
|
||
SWEET-16, Steve Wozniak.
|
||
|
||
2. Apple II Reference Manual, pages 96-99. This is the assembly
|
||
listing of SWEET-16, as found in your Apple II.
|
||
|
||
3. Programmers Aid #1 Installation and Operating Manual.
|
||
This is the book that comes with the Programmers Aid #1 ROM. It
|
||
includes listings of programs coded in SWEET-16 language:
|
||
Renumber/Append, pages 76-79; and 6502 Relocation Subroutine, pages
|
||
80-81.
|
||
|
||
4. Occasional articles in Dr. Dobb's, MICRO, et cetera.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
D - 2
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Ads
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
Double Precision Floating Point for APPLESOFT
|
||
|
||
A Brand New Tool for Every Apple Owner!
|
||
|
||
* Apple II or Apple II Plus
|
||
|
||
* Applesoft ROM Card or Language System
|
||
|
||
* 21-digit precision with arithmetic, INPUT, and PRINT
|
||
|
||
* Subroutines for ABS, SQR, LOG, EXP, SIN, COS, and ATN
|
||
|
||
* Efficient and compact assembly language coding:
|
||
Only uses 2048 bytes of RAM
|
||
Speed comparable to normal Applesoft arithmetic
|
||
|
||
* Automatically loaded beneath your Applesoft program
|
||
|
||
* Nearly standard syntax, simple interface using "&"
|
||
feature of Applesoft language
|
||
|
||
* Disk includes nine sample programs
|
||
|
||
* Big 25-page Reference Manual
|
||
|
||
|
||
|
||
Just $50 at your local Apple Dealer!
|
||
Includes diskette with nine sample
|
||
programs and a 25-page reference
|
||
manual.
|
||
|
||
S-C SOFTWARE *
|
||
P.O. Box 5537 Apple and Applesoft are trademarks
|
||
Richardson,TX75080 of the Apple Computer Company.
|
||
(214) 324-2050
|
||
|
||
---------------------------------------------------------------------
|
||
|
||
S-C ASSEMBLER II Faster!
|
||
Version 4.0 Easier to use!
|
||
More Powerful!
|
||
|
||
New Editing Features
|
||
* Automatic line numbers, * Memory use display
|
||
with selectable increment.
|
||
* Escape IJKM cursor control
|
||
* Append programs from disk. with or without Autostart ROM.
|
||
|
||
* Renumber with selectable * Two user programmable system
|
||
base, increment, and start. commands.
|
||
|
||
* And MUCH MORE!
|
||
|
||
New Assembly Features
|
||
|
||
* FASTER! Up to 6000 lines * Up to 32-character labels.
|
||
per minute!
|
||
* Use ASCII literals in address
|
||
* Assembles from multiple expressions.
|
||
source files, using ".IN"
|
||
directive. * Local labels for more readable
|
||
modular programs.
|
||
* Stores object code directly
|
||
on binary file, using ".TF" * Alphabetized symbol table.
|
||
directive.
|
||
* User programmable directive.
|
||
|
||
* Listing control with PG * Improved error messages, with
|
||
(page eject), LIST OFF, automatic display of bad line
|
||
and LIST ON. to simplify correction.
|
||
|
||
* And MUCH MORE!
|
||
|
||
S-C ASSEMBLER II Version 4.0 is compatible with both the Apple II and
|
||
the Apple II Plus. At least 24K RAM is required, and at least one
|
||
disk drive.
|
||
|
||
S-C ASSEMBLER II Version 4.0 is
|
||
available now as an upgrade kit only.
|
||
The upgrade kit includes a documen- S-C SOFTWARE
|
||
tation packet and a new diskette, for
|
||
only $22.50. Proof of ownership of a P.O. Box 5537
|
||
previous disk version is required. Richardson, TX 75080
|
||
|
||
(Version 3.2 is still available for
|
||
only $35.00) (214) 324-2050
|
||
|
||
|
||
---------------------------------------------------------------------
|