Code cleanup from last patch, also, version bump for same. :-)
[rmac] / rmac.h
diff --git a/rmac.h b/rmac.h
index 2b71ac7cdfce1c7d7259f53138a50bc243c4bc72..30880a30ee24717ad59c61e5d058b4dc657693f7 100644 (file)
--- a/rmac.h
+++ b/rmac.h
 #define LONG         uint32_t
 #define VOID         void
 
-#define ERROR        (-1)                      // Generic error return
-#define EOS          '\0'                      // End of string
-#define SPACE        ' '                       // ASCII space
+#define ERROR        (-1)              // Generic error return
+#define EOS          '\0'              // End of string
+#define SPACE        ' '               // ASCII space
 #define SLASHCHAR    '/'
 #define SLASHSTRING  "/"
-#define VALUE        uint32_t          // Assembler value
-#define TOKEN        uint32_t          // Assembler token
-#define FNSIZ        128                       // Maximum size of a filename
-#define OK           0                         // OK return
-#define DEBUG        if (debug)                // Debug conditional
-#define MAXARGV      100                       // Maximum number of commandline args
-#define STDOUT       1                         // Standard output
-#define ERROUT       2                         // Error output
+#define VALUE        uint32_t  // Assembler value
+#define TOKEN        uint32_t  // Assembler token
+#define FNSIZ        128               // Maximum size of a filename
+#define OK           0                 // OK return
+#define DEBUG        if (debug)        // Debug conditional
+#define MAXARGV      100               // Maximum number of commandline args
+#define STDOUT       1                 // Standard output
+#define ERROUT       2                 // Error output
 #define CREATMASK    0
 
 // (Normally) non-printable tokens
-#define COLON        ':'                       // : (grumble: GNUmacs hates ':')
-#define CONST        'a'                       // CONST <value>
-#define ACONST       'A'                       // ACONST <value> <attrib>
-#define STRING       'b'                       // STRING <address>
-#define STRINGA8     'S'                       // Atari 800 internal STRING <address>
-#define SYMBOL       'c'                       // SYMBOL <address>
-#define EOL          'e'                       // End of line
-#define TKEOF        'f'                       // End of file (or macro)
-#define DEQUALS      'g'                       // ==
-#define SET          149                       // set
-#define REG          'R'                       // reg
-#define EQUREG       148                       // equreg
-#define CCDEF        183                       // ccdef
-#define DCOLON       'h'                       // ::
-#define GE           'i'                       // >=
-#define LE           'j'                       // <=
-#define NE           'k'                       // <> or !=
-#define SHR          'l'                       // >>
-#define SHL          'm'                       // <<
-#define UNMINUS      'n'                       // Unary '-'
-#define DOTB         'B'                       // .b or .B or .s or .S
-#define DOTW         'W'                       // .w or .W
-#define DOTL         'L'                       // .l or .L
-#define DOTI         'I'                       // .i or .I
-#define DOTD         'D'            // .d or .D
-#define DOTS         'S'                       // .s or .S (FPU Single)
-#define DOTQ         'Q'                       // .q oe .Q (FPU Quad)
-#define DOTX         'X'                       // .x or .X (FPU Extended)
-#define DOTP         'P'                       // .p or .P (FPU Packed)
-#define ENDEXPR      'E'                       // End of expression
+#define COLON        ':'               // : (grumble: GNUmacs hates ':')
+#define CONST        'a'               // CONST <value>
+#define ACONST       'A'               // ACONST <value> <attrib>
+#define STRING       'b'               // STRING <address>
+#define STRINGA8     'S'               // Atari 800 internal STRING <address>
+#define SYMBOL       'c'               // SYMBOL <address>
+#define EOL          'e'               // End of line
+#define TKEOF        'f'               // End of file (or macro)
+#define DEQUALS      'g'               // ==
+#define SET          149               // set
+#define REG          'R'               // reg
+#define EQUREG       148               // equreg
+#define CCDEF        183               // ccdef
+#define DCOLON       'h'               // ::
+#define GE           'i'               // >=
+#define LE           'j'               // <=
+#define NE           'k'               // <> or !=
+#define SHR          'l'               // >>
+#define SHL          'm'               // <<
+#define UNMINUS      'n'               // Unary '-'
+#define DOTB         'B'               // .b or .B or .s or .S
+#define DOTW         'W'               // .w or .W
+#define DOTL         'L'               // .l or .L
+#define DOTI         'I'               // .i or .I
+#define DOTD         'D'               // .d or .D
+#define DOTS         'S'               // .s or .S (FPU Single)
+#define DOTQ         'Q'               // .q oe .Q (FPU Quad)
+#define DOTX         'X'               // .x or .X (FPU Extended)
+#define DOTP         'P'               // .p or .P (FPU Packed)
+#define ENDEXPR      'E'               // End of expression
 
 // Object code formats
-#define ALCYON       0                         // Alcyon/DRI C object format
-#define MWC          1                         // Mark Williams object format
-#define BSD          2                         // BSD object format
-#define ELF          3                         // ELF object format
-#define XEX          4                         // COM/EXE/XEX/whatever a8 object format
+#define ALCYON       0                 // Alcyon/DRI C object format
+#define MWC          1                 // Mark Williams object format
+#define BSD          2                 // BSD object format
+#define ELF          3                 // ELF object format
+#define XEX          4                 // COM/EXE/XEX/whatever a8 object format
 
 // Pointer type that can point to (almost) anything
 #define PTR union _ptr
 PTR
 {
-   uint8_t * cp;                                       // Char
-   uint16_t * wp;                                      // WORD
-   uint32_t * lp;                                      // LONG
-   uint32_t lw;                                                // LONG
-   SYM ** sy;                                          // SYM
-   TOKEN * tk;                                         // TOKEN
+       uint8_t * cp;                           // Char
+       uint16_t * wp;                          // WORD
+       uint32_t * lp;                          // LONG
+       uint32_t lw;                            // LONG
+       SYM ** sy;                                      // SYM
+       TOKEN * tk;                                     // TOKEN
 };
 
 // Symbol spaces
-#define LABEL        0                         // User-defined symbol
-#define MACRO        1                         // Macro definition
-#define MACARG       2                         // Macro argument
-#define SY_UNDEF     -1                                // Undefined (lookup never matches it)
+#define LABEL        0                 // User-defined symbol
+#define MACRO        1                 // Macro definition
+#define MACARG       2                 // Macro argument
+#define SY_UNDEF     -1                        // Undefined (lookup never matches it)
 
 // Symbol and expression attributes
-#define DEFINED      0x8000                    // Symbol has been defined
-#define GLOBAL       0x4000                    // Symbol has been .GLOBL'd
-#define COMMON       0x2000                    // Symbol has been .COMM'd
-#define REFERENCED   0x1000                    // Symbol has been referenced
-#define EQUATED      0x0800                    // Symbol was equated
-#define SDECLLIST    0x0400                    // Symbol is on 'sdecl'-order list
+#define DEFINED      0x8000            // Symbol has been defined
+#define GLOBAL       0x4000            // Symbol has been .GLOBL'd
+#define COMMON       0x2000            // Symbol has been .COMM'd
+#define REFERENCED   0x1000            // Symbol has been referenced
+#define EQUATED      0x0800            // Symbol was equated
+#define SDECLLIST    0x0400            // Symbol is on 'sdecl'-order list
 
 // Expression spaces, ORed with symbol and expression attributes above
-#define ABS          0x0000                    // In absolute space
-#define TEXT         0x0001                    // Relative to text
-#define DATA         0x0002                    // Relative to data
-#define BSS          0x0004                    // Relative to BSS
-#define M6502        0x0008                    // 6502/microprocessor (absolute)
+#define ABS          0x0000            // In absolute space
+#define TEXT         0x0001            // Relative to text
+#define DATA         0x0002            // Relative to data
+#define BSS          0x0004            // Relative to BSS
+#define M6502        0x0008            // 6502/microprocessor (absolute)
 #define TDB          (TEXT|DATA|BSS)   // Mask for text+data+bss
 
 // Sizes
-#define SIZB         0x0001                    // .b
-#define SIZW         0x0002                    // .w
-#define SIZL         0x0004                    // .l
-#define SIZN         0x0008                    // no .(size) specifier
-#define SIZD         0x0010         // .d (quad word or FPU double precision real)
-#define SIZS            0x0020                 // .s (FPU single precision real)
-#define SIZX         0x0040         // .x (FPU extended precision real)
-#define SIZP            0x0080             // .p (FPU pakced decimal real)
+#define SIZB         0x0001            // .b
+#define SIZW         0x0002            // .w
+#define SIZL         0x0004            // .l
+#define SIZN         0x0008            // no .(size) specifier
+#define SIZD         0x0010            // .d (quad word or FPU double precision real)
+#define SIZS         0x0020            // .s (FPU single precision real)
+#define SIZX         0x0040            // .x (FPU extended precision real)
+#define SIZP         0x0080            // .p (FPU pakced decimal real)
 #define SIZQ         SIZD
 
 // RISC register bank definitions (used in extended symbol attributes also)
-#define BANK_N       0x0000                    // No register bank specified
-#define BANK_0       0x0001                    // Register bank zero specified
-#define BANK_1       0x0002                    // Register bank one specified
-#define EQUATEDREG   0x0008                    // Equated register symbol
+#define BANK_N       0x0000            // No register bank specified
+#define BANK_0       0x0001            // Register bank zero specified
+#define BANK_1       0x0002            // Register bank one specified
+#define EQUATEDREG   0x0008            // Equated register symbol
 #define UNDEF_EQUR   0x0010
 #define EQUATEDCC    0x0020
 #define UNDEF_CC     0x0040
@@ -286,8 +286,8 @@ enum
        OPT_MOVEL_MOVEQ   = 1,
        OPT_BSR_BCC_S     = 2,
        OPT_INDIRECT_DISP = 3,
-    OPT_LEA_ADDQ        = 4,
-    OPT_BASE_DISP       = 5,
+       OPT_LEA_ADDQ      = 4,
+       OPT_BASE_DISP     = 5,
        OPT_COUNT   // Dummy, used to count number of optimisation switches
 };
 
@@ -313,6 +313,8 @@ extern int legacy_flag;
 extern int prg_flag;   // 1 = write ".PRG" relocatable executable
 extern LONG PRGFLAGS;
 extern int optim_flags[OPT_COUNT];
+extern int activecpu;
+extern int activefpu;
 
 // Exported functions
 char * fext(char *, char *, int);