-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
73 lines (56 loc) · 3.27 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
CREDITS
-------
http://www.telegraphics.com.au/sw/info/dpa.html
This file is part of The Didactic PDP-8 Assembler
Copyright (C) 2002-5 Toby Thain, [email protected]
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
README
------
This program is intended to be a basic example of an assembler for a simple
architecture, written with the aid of flex and bison. Being small, the
assembler may lend itself to learning, extension and modification by
interested parties. While I do not own a PDP-8 (more's the pity), this
architecture was chosen partly for its similarity to another DeCastro design,
the DG Nova 3. The project was mainly inspired by my friend Emil Sarlija
( http://www.chookfest.net/ ) who owns two Nova 3 computers and needed an assembler.
PDP-8
The PDP-8 assembler ("p8a") input syntax is compatible with the assembler
described in the "PAL III Symbolic Assembler PDP-8 Programming Manual,"
Digital Equipment Corporation publication DEC-08-ASAC-D
(see http://www.pdp8.net/pdp8cgi/query_docs/view.pl?id=31
or http://highgate.comm.sfu.ca/~djg/htdocs/cgi-bin/tifftopdf.cgi/dec-08-asac-d.pdf?loc=newstuff
or http://www.pdp8.net/pdp8cgi/query_docs/tifftopdf.pl/pdp8docs/dec-08-asac-d.pdf )
Binary object output is in RIM or BIN format. Some of the output routines
are based on parts of Douglas Jones' PDP-8 assembler
( ftp://ftp.cs.uiowa.edu/pub/jones/pdp8/pal.c.Z ).
The "verbose" mode (-v) includes a disassembler with a "diagrammatic" output
format designed to show each instruction's physical layout (in particular
the microcoded instructions).
DG NOVA
An assembler for DG Nova architecture is also included. This follows the
User's Manual (Programmer's Reference) for the DG Nova range of computers.
The instruction set, addressing modes and syntax are complete, but
the Nova native object file format (RB) is only partially implemented.
(An RB format file dump utility, dumprb, is included in the Nova directory.)
Nova bootstrap format is also supported with the -b flag;
this is program of up to 191 words assembled at an absolute origin of 0100
(see Nova Programmer's Reference, page VI-7, for more details).
Notes on building
This program has been built and tested under NetBSD 1.5/SPARC,
Linux/Alpha (Debian 2.2), OS X 10.2,3,4 (PowerPC G4), NEXTSTEP 3.3/HPPA.
1. GNU make is required
2. flex ( http://www.gnu.org/directory/flex.html ) is required,
as the lexical analysers use features not available in traditional UNIX lex.
Please contact the author with any bug reports, suggestions or comments.
The latest version is always available from the Subversion repository at
http://www.telegraphics.com.au/svn/dpa/trunk/