4 * Copyright (C) 1998-2009 Alan R. Baldwin
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
24 * This Assembler Ported by
25 * John L. Hartman (JLH)
26 * jhartman at compuserve dot com
27 * noice at noicedebugger dot com
44 { NULL
, "CON", S_ATYP
, 0, A_CON
},
45 { NULL
, "OVR", S_ATYP
, 0, A_OVR
},
46 { NULL
, "REL", S_ATYP
, 0, A_REL
},
47 { NULL
, "ABS", S_ATYP
, 0, A_ABS
},
48 { NULL
, "NOPAG", S_ATYP
, 0, A_NOPAG
},
49 { NULL
, "PAG", S_ATYP
, 0, A_PAG
},
51 { NULL
, "CODE", S_ATYP
, 0, A_CODE
},
52 { NULL
, "DATA", S_ATYP
, 0, A_DATA
},
53 { NULL
, "XDATA", S_ATYP
, 0, A_XDATA
},
54 { NULL
, "BIT", S_ATYP
, 0, A_BIT
},
56 { NULL
, ".page", S_PAGE
, 0, 0 },
57 { NULL
, ".title", S_HEADER
, 0, O_TITLE
},
58 { NULL
, ".sbttl", S_HEADER
, 0, O_SBTTL
},
59 { NULL
, ".module", S_MODUL
, 0, 0 },
60 { NULL
, ".include", S_INCL
, 0, I_CODE
},
61 { NULL
, ".incbin", S_INCL
, 0, I_BNRY
},
62 { NULL
, ".area", S_AREA
, 0, 0 },
63 { NULL
, ".org", S_ORG
, 0, 0 },
64 { NULL
, ".radix", S_RADIX
, 0, 0 },
65 { NULL
, ".globl", S_GLOBL
, 0, 0 },
66 { NULL
, ".local", S_LOCAL
, 0, 0 },
67 { NULL
, ".if", S_CONDITIONAL
, 0, O_IF
},
68 { NULL
, ".iff", S_CONDITIONAL
, 0, O_IFF
},
69 { NULL
, ".ift", S_CONDITIONAL
, 0, O_IFT
},
70 { NULL
, ".iftf", S_CONDITIONAL
, 0, O_IFTF
},
71 { NULL
, ".ifdef", S_CONDITIONAL
, 0, O_IFDEF
},
72 { NULL
, ".ifndef", S_CONDITIONAL
, 0, O_IFNDEF
},
73 { NULL
, ".ifgt", S_CONDITIONAL
, 0, O_IFGT
},
74 { NULL
, ".iflt", S_CONDITIONAL
, 0, O_IFLT
},
75 { NULL
, ".ifge", S_CONDITIONAL
, 0, O_IFGE
},
76 { NULL
, ".ifle", S_CONDITIONAL
, 0, O_IFLE
},
77 { NULL
, ".ifeq", S_CONDITIONAL
, 0, O_IFEQ
},
78 { NULL
, ".ifne", S_CONDITIONAL
, 0, O_IFNE
},
79 { NULL
, ".ifb", S_CONDITIONAL
, 0, O_IFB
},
80 { NULL
, ".ifnb", S_CONDITIONAL
, 0, O_IFNB
},
81 { NULL
, ".ifidn", S_CONDITIONAL
, 0, O_IFIDN
},
82 { NULL
, ".ifdif", S_CONDITIONAL
, 0, O_IFDIF
},
83 { NULL
, ".iif", S_CONDITIONAL
, 0, O_IIF
},
84 { NULL
, ".iiff", S_CONDITIONAL
, 0, O_IIFF
},
85 { NULL
, ".iift", S_CONDITIONAL
, 0, O_IIFT
},
86 { NULL
, ".iiftf", S_CONDITIONAL
, 0, O_IIFTF
},
87 { NULL
, ".iifdef", S_CONDITIONAL
, 0, O_IIFDEF
},
88 { NULL
, ".iifndef", S_CONDITIONAL
, 0, O_IIFNDEF
},
89 { NULL
, ".iifgt", S_CONDITIONAL
, 0, O_IIFGT
},
90 { NULL
, ".iiflt", S_CONDITIONAL
, 0, O_IIFLT
},
91 { NULL
, ".iifge", S_CONDITIONAL
, 0, O_IIFGE
},
92 { NULL
, ".iifle", S_CONDITIONAL
, 0, O_IIFLE
},
93 { NULL
, ".iifeq", S_CONDITIONAL
, 0, O_IIFEQ
},
94 { NULL
, ".iifne", S_CONDITIONAL
, 0, O_IIFNE
},
95 { NULL
, ".iifb", S_CONDITIONAL
, 0, O_IIFB
},
96 { NULL
, ".iifnb", S_CONDITIONAL
, 0, O_IIFNB
},
97 { NULL
, ".iifidn", S_CONDITIONAL
, 0, O_IIFIDN
},
98 { NULL
, ".iifdif", S_CONDITIONAL
, 0, O_IIFDIF
},
99 { NULL
, ".else", S_CONDITIONAL
, 0, O_ELSE
},
100 { NULL
, ".endif", S_CONDITIONAL
, 0, O_ENDIF
},
101 { NULL
, ".list", S_LISTING
, 0, O_LIST
},
102 { NULL
, ".nlist", S_LISTING
, 0, O_NLIST
},
103 { NULL
, ".equ", S_EQU
, 0, O_EQU
},
104 { NULL
, ".gblequ", S_EQU
, 0, O_GBLEQU
},
105 { NULL
, ".lclequ", S_EQU
, 0, O_LCLEQU
},
107 { NULL
, ".optsdcc", S_OPTSDCC
, 0, 0 },
108 /* end sdas specific */
109 { NULL
, ".byte", S_DATA
, 0, O_1BYTE
},
110 { NULL
, ".db", S_DATA
, 0, O_1BYTE
},
111 { NULL
, ".fcb", S_DATA
, 0, O_1BYTE
},
112 { NULL
, ".word", S_DATA
, 0, O_2BYTE
},
113 { NULL
, ".dw", S_DATA
, 0, O_2BYTE
},
114 { NULL
, ".fdb", S_DATA
, 0, O_2BYTE
},
115 /* { NULL, ".3byte", S_DATA, 0, O_3BYTE }, */
116 /* { NULL, ".triple", S_DATA, 0, O_3BYTE }, */
117 /* { NULL, ".4byte", S_DATA, 0, O_4BYTE }, */
118 /* { NULL, ".quad", S_DATA, 0, O_4BYTE }, */
119 { NULL
, ".blkb", S_BLK
, 0, O_1BYTE
},
120 { NULL
, ".ds", S_BLK
, 0, O_1BYTE
},
121 { NULL
, ".rmb", S_BLK
, 0, O_1BYTE
},
122 { NULL
, ".rs", S_BLK
, 0, O_1BYTE
},
123 { NULL
, ".blkw", S_BLK
, 0, O_2BYTE
},
124 /* { NULL, ".blk3", S_BLK, 0, O_3BYTE }, */
125 /* { NULL, ".blk4", S_BLK, 0, O_4BYTE }, */
126 { NULL
, ".ascii", S_ASCIX
, 0, O_ASCII
},
127 { NULL
, ".ascis", S_ASCIX
, 0, O_ASCIS
},
128 { NULL
, ".asciz", S_ASCIX
, 0, O_ASCIZ
},
129 { NULL
, ".str", S_ASCIX
, 0, O_ASCII
},
130 { NULL
, ".strs", S_ASCIX
, 0, O_ASCIS
},
131 { NULL
, ".strz", S_ASCIX
, 0, O_ASCIZ
},
132 { NULL
, ".fcc", S_ASCIX
, 0, O_ASCII
},
133 { NULL
, ".define", S_DEFINE
, 0, O_DEF
},
134 { NULL
, ".undefine", S_DEFINE
, 0, O_UNDEF
},
135 { NULL
, ".even", S_BOUNDARY
, 0, O_EVEN
},
136 { NULL
, ".odd", S_BOUNDARY
, 0, O_ODD
},
137 { NULL
, ".bndry", S_BOUNDARY
, 0, O_BNDRY
},
138 { NULL
, ".msg" , S_MSG
, 0, 0 },
139 { NULL
, ".assume", S_ERROR
, 0, O_ASSUME
},
140 { NULL
, ".error", S_ERROR
, 0, O_ERROR
},
142 /* Macro Processor */
144 { NULL
, ".macro", S_MACRO
, 0, O_MACRO
},
145 { NULL
, ".endm", S_MACRO
, 0, O_ENDM
},
146 { NULL
, ".mexit", S_MACRO
, 0, O_MEXIT
},
148 { NULL
, ".narg", S_MACRO
, 0, O_NARG
},
149 { NULL
, ".nchr", S_MACRO
, 0, O_NCHR
},
150 { NULL
, ".ntyp", S_MACRO
, 0, O_NTYP
},
152 { NULL
, ".irp", S_MACRO
, 0, O_IRP
},
153 { NULL
, ".irpc", S_MACRO
, 0, O_IRPC
},
154 { NULL
, ".rept", S_MACRO
, 0, O_REPT
},
156 { NULL
, ".nval", S_MACRO
, 0, O_NVAL
},
158 { NULL
, ".mdelete", S_MACRO
, 0, O_MDEL
},
162 { NULL
, "a", S_A
, 0, A
},
163 { NULL
, "ab", S_AB
, 0, 0 },
164 { NULL
, "dptr", S_DPTR
, 0, DPTR
},
165 { NULL
, "pc", S_PC
, 0, PC
},
166 { NULL
, "r0", S_REG
, 0, R0
},
167 { NULL
, "r1", S_REG
, 0, R1
},
168 { NULL
, "r2", S_REG
, 0, R2
},
169 { NULL
, "r3", S_REG
, 0, R3
},
170 { NULL
, "r4", S_REG
, 0, R4
},
171 { NULL
, "r5", S_REG
, 0, R5
},
172 { NULL
, "r6", S_REG
, 0, R6
},
173 { NULL
, "r7", S_REG
, 0, R7
},
175 { NULL
, "nop", S_INH
, 0, 0x00 },
176 { NULL
, "ret", S_INH
, 0, 0x22 },
177 { NULL
, "reti", S_INH
, 0, 0x32 },
179 { NULL
, "ajmp", S_JMP11
, 0, 0x01 },
180 { NULL
, "acall", S_JMP11
, 0, 0x11 },
181 { NULL
, "ljmp", S_JMP16
, 0, 0x02 },
182 { NULL
, "lcall", S_JMP16
, 0, 0x12 },
184 { NULL
, "rr", S_ACC
, 0, 0x03 },
185 { NULL
, "rrc", S_ACC
, 0, 0x13 },
186 { NULL
, "rl", S_ACC
, 0, 0x23 },
187 { NULL
, "rlc", S_ACC
, 0, 0x33 },
188 { NULL
, "swap", S_ACC
, 0, 0xC4 },
189 { NULL
, "da", S_ACC
, 0, 0xD4 },
191 { NULL
, "inc", S_TYP1
, 0, 0x00 },
192 { NULL
, "dec", S_TYP1
, 0, 0x10 },
194 { NULL
, "add", S_TYP2
, 0, 0x20 },
195 { NULL
, "addc", S_TYP2
, 0, 0x30 },
196 { NULL
, "subb", S_TYP2
, 0, 0x90 },
198 { NULL
, "orl", S_TYP3
, 0, 0x40 },
199 { NULL
, "anl", S_TYP3
, 0, 0x50 },
200 { NULL
, "xrl", S_TYP3
, 0, 0x60 },
202 { NULL
, "xch", S_TYP4
, 0, 0xC0 },
204 { NULL
, "mov", S_MOV
, 0, 0x00 },
206 { NULL
, "jbc", S_BITBR
, 0, 0x10 },
207 { NULL
, "jb", S_BITBR
, 0, 0x20 },
208 { NULL
, "jnb", S_BITBR
, 0, 0x30 },
210 { NULL
, "jc", S_BR
, 0, 0x40 },
211 { NULL
, "jnc", S_BR
, 0, 0x50 },
212 { NULL
, "jz", S_BR
, 0, 0x60 },
213 { NULL
, "jnz", S_BR
, 0, 0x70 },
214 { NULL
, "sjmp", S_BR
, 0, 0x80 },
216 { NULL
, "cjne", S_CJNE
, 0, 0xB0 },
217 { NULL
, "djnz", S_DJNZ
, 0, 0xD0 },
218 { NULL
, "jmp", S_JMP
, 0, 0x73 },
219 { NULL
, "movc", S_MOVC
, 0, 0x83 },
220 { NULL
, "movx", S_MOVX
, 0, 0x00 },
221 { NULL
, "div", S_AB
, 0, 0x84 },
222 { NULL
, "mul", S_AB
, 0, 0xA4 },
223 { NULL
, "clr", S_ACBIT
, 0, 0xC2 },
224 { NULL
, "cpl", S_ACBIT
, 0, 0xB2 },
225 { NULL
, "setb", S_SETB
, 0, 0xD2 },
226 { NULL
, "push", S_DIRECT
, 0, 0xC0 },
227 { NULL
, "pop", S_DIRECT
, 0, 0xD0 },
228 { NULL
, "xchd", S_XCHD
, S_EOL
, 0xD6 }
231 struct PreDef preDef
[] = {
351 { "RCAP2H", 0x00CB },
352 { "RCAP2L", 0x00CA },
361 { "SCON.0", 0x0098 },
362 { "SCON.1", 0x0099 },
363 { "SCON.2", 0x009A },
364 { "SCON.3", 0x009B },
365 { "SCON.4", 0x009C },
366 { "SCON.5", 0x009D },
367 { "SCON.6", 0x009E },
368 { "SCON.7", 0x009F },
374 { "T2CON.0", 0x00C8 },
375 { "T2CON.1", 0x00C9 },
376 { "T2CON.2", 0x00CA },
377 { "T2CON.3", 0x00CB },
378 { "T2CON.4", 0x00CC },
379 { "T2CON.5", 0x00CD },
380 { "T2CON.6", 0x00CE },
381 { "T2CON.7", 0x00CF },
385 { "TCON.0", 0x0088 },
386 { "TCON.1", 0x0089 },
387 { "TCON.2", 0x008A },
388 { "TCON.3", 0x008B },
389 { "TCON.4", 0x008C },
390 { "TCON.5", 0x008D },
391 { "TCON.6", 0x008E },
392 { "TCON.7", 0x008F },