Atari 8 bits code setup
Contents
Introduction
Just a small quick-start / reminder to low-level (6502
assembly) programming for the Atari 8 bits computers.
Focus is on Atari 800 XL but should works for other
models.
See this for other
Atari 8 bits codegolf resources and
AtariAge board.
This video is very helpful as well.
Also see this for a
course on Atari 8 bits graphics and this or this for a
course on assembly language for Atari computers (this is
also handy as a 6502 reference), there is plenty other resources on
Atari archives or
Atari mania.
I like the De Re manual also
"All About Atari" which can be found here.
The way to go to generally learn this platform is to get a
reference of the memory map (available on links above), try to make
sens of it and poke it.
Note :
- Emulator setup is Linux focused, i use Atari800 which provide host based
storage through the H1 device on the Atari.
- The assembler shown here run on the Atari since i prefer to code on the machine itself for small programs, there is assembler that works on Linux too such as MADS
- BASIC can also be done with good results for code golf
stuff.
Quick-start tooling
Download an emulator such as Atari800 and the assembler, i
personally like
ATMAS II (the file can be found in the list of that link),
ATMAS pretty much act like a regular text editor and it doesn't
have line
numbering.
Put the downloaded assembler .atr file into e.g.
~/atari
and also create ~/atari/data
which will store the binaries produced by the assembler or saved
sources.Here is a quick command that i use to launch the assembler
(note that it uses XL and the above setup, see this
for the emulator usage) :
atari800 -xl -no-bilinear-filter
-H1 ~/atari/data -hreadwrite -ntsc -nobasic "~/atari/Atmas II
Macroassembler A.atr"
ATMAS II with the demo program loaded
Disassembler
ATMAS II has an easy disassembler but the load binary +
disassemble can be tedious so i prefer
a disassembler which run in the browser, it support easy drag
and drop of multiple Atari 8 bits binary files. (doesn't have
undocumented instructions though)
ATMAS Quick-start
ATMAS II is a straightforward and powerful macro assembler for
the Atari 8 bits computer.
ATMAS II manual can be found here or just translate
the German
manual. (the reference card at the end of the manual might be
handy to get a quick grasp)
Assemble and run the demo program
This is a quick way to get all the clues needed to assemble
and run a program (taken from the manual, where <esc> means
pressing escape key, <start> means F5) :
<esc>RD:DEMO<esc><esc>
(load demo program)
<ctrl>-Y (assemble program)
<esc> (back to the editor)
<esc>U<esc><esc> (start program)
<start> (end program)
Save program binary
Example saving a program from A800 to A8F9 (so 256 bytes
program, see this
for a description of the Atari 8 bits executable format)
<ctrl>-P (go to monitor screen)
<s> (SAVE)
A800
A8F9
<enter>
H1:mybinary.xex
<e> (quit monitor screen)
With the above tooling setup the H1 device will point to e.g.
~/atari/data
folder so the saved executable
file MYBINARY.XEX
will be located in this
folder.Save/load source code
Save a text buffer content to
MYSOURCE.SRC
,
replace WH1 by RH1 to load a file instead, if you load a new file
you might need to delete current buffer content by doing :
<esc>k<esc><esc>Note : Don't forget to <ctrl>-E before
saving!
<ctrl>-E (this put the cursor
position at the beginning, required before saving since saving is
from the current cursor position)
<esc>WH1:mysource<esc><esc>
Source code can be created / edited from Linux as well then
loaded up from the Atari. (to some extents)
ATMAS sample code
Here are some sample code which are actually taken from the
demo routines in the ATMAS manual but stripped of the macros. (not
optimized, this can be shorter)
Plot to screen
An example of changing screen mode
and plotting an orange pixel at 0,0.
ICCOM EQU $342
ICBAL EQU $344
ICBAH EQU $345
ICBLL EQU $348
ICBLH EQU $349
ICAX1 EQU $34A
ICAX2 EQU $34B
CIOV EQU $E456
COPEN EQU 3
CCLSE EQU 12
CPBIN EQU 11
ATACHR EQU $2FB
ROWCRS EQU $54
COLCRS EQU $55
ORG $A800
* SET SCREEN MODE
LDX #$60
LDA #CCLSE
STA ICCOM,X
JSR CIOV
LDA #7 * SCREEN MODE (here mode 7 160x80)
STA ICAX2,X
AND #$F0
EOR #$10
ORA #$0C
STA ICAX1,X
LDA #COPEN
STA ICCOM,X
LDA #DEV@
STA ICBAL,X
LDA #DEV@/256
STA ICBAH,X
JSR CIOV
* SET COLOR
LDA #1 * orange
STA ATACHR
* SET CURSOR POSITION
LDA #0 * X
STA COLCRS
LDA #0/256 * X
STA COLCRS+1
LDA #0 * Y
STA ROWCRS
* PLOT
LDX #$60
LDA #CPBIN
STA ICCOM,X
LDA #0
STA ICBLL,X
STA ICBLH,X
LDA ATACHR
JSR CIOV
LOOP@ JMP LOOP@
DEV@ ASC 'S:'
Text output
ICCOM EQU $342
ICBAL EQU $344
ICBAH EQU $345
ICBLL EQU $348
ICBLH EQU $349
ICAX1 EQU $34A
ICAX2 EQU $34B
CIOV EQU $E456
COPEN EQU 3
CCLSE EQU 12
CPTXT EQU 9
CPBIN EQU 11
ATACHR EQU $2FB
ROWCRS EQU $54
COLCRS EQU $55
ORG $A800
* SET CANAL
LDA #0 * CANAL
ASL
ASL
ASL
ASL
TAX
* PRINT STRING
LDA #CPTXT
STA ICCOM,X
LDA #STRING
STA ICBAL,X
LDA #STRING/256
STA ICBAH,X
LDA #4 * STRING LENGTH
STA ICBLL,X
LDA #0
STA ICBLH,X
JSR CIOV
STRING ASC "TEST"
ATASCII control
characters can be sent to move the cursor, clear the screen
etc.
back to top