2e85421e4d71e1c6a64c46fab69bcadc8cef2925
[fw/sdcc] / src / mcs51 / main.c
1 /** @file main.c
2     mcs51 specific general functions.
3
4     Note that mlh prepended _mcs51_ on the static functions.  Makes
5     it easier to set a breakpoint using the debugger.
6 */
7 #include "common.h"
8 #include "main.h"
9 #include "ralloc.h"
10 #include "gen.h"
11
12 static char _defaultRules[] =
13 {
14 #include "peeph.rul"
15 };
16
17 /* list of key words used by msc51 */
18 static char *_mcs51_keywords[] =
19 {
20   "at",
21   "bit",
22   "code",
23   "critical",
24   "data",
25   "far",
26   "idata",
27   "interrupt",
28   "near",
29   "pdata",
30   "reentrant",
31   "sfr",
32   "sbit",
33   "using",
34   "xdata",
35   "_data",
36   "_code",
37   "_generic",
38   "_near",
39   "_xdata",
40   "_pdata",
41   "_idata",
42   NULL
43 };
44
45
46 void mcs51_assignRegisters (eBBlock ** ebbs, int count);
47
48 static int regParmFlg = 0;      /* determine if we can register a parameter */
49
50 static void
51 _mcs51_init (void)
52 {
53   asm_addTree (&asm_asxxxx_mapping);
54 }
55
56 static void
57 _mcs51_reset_regparm ()
58 {
59   regParmFlg = 0;
60 }
61
62 static int
63 _mcs51_regparm (sym_link * l)
64 {
65   /* for this processor it is simple
66      can pass only the first parameter in a register */
67   if (regParmFlg)
68     return 0;
69
70   regParmFlg = 1;
71   return 1;
72 }
73
74 static bool
75 _mcs51_parseOptions (int *pargc, char **argv, int *i)
76 {
77   /* TODO: allow port-specific command line options to specify
78    * segment names here.
79    */
80   return FALSE;
81 }
82
83 static void
84 _mcs51_finaliseOptions (void)
85 {
86   if (options.model == MODEL_LARGE)
87     {
88       port->mem.default_local_map = xdata;
89       port->mem.default_globl_map = xdata;
90     }
91   else
92     {
93       port->mem.default_local_map = data;
94       port->mem.default_globl_map = data;
95     }
96 }
97
98 static void
99 _mcs51_setDefaultOptions (void)
100 {
101 }
102
103 static const char *
104 _mcs51_getRegName (struct regs *reg)
105 {
106   if (reg)
107     return reg->name;
108   return "err";
109 }
110
111 static void
112 _mcs51_genAssemblerPreamble (FILE * of)
113 {
114 }
115
116 /* Generate interrupt vector table. */
117 static int
118 _mcs51_genIVT (FILE * of, symbol ** interrupts, int maxInterrupts)
119 {
120   return FALSE;
121 }
122
123 /** $1 is always the basename.
124     $2 is always the output file.
125     $3 varies
126     $l is the list of extra options that should be there somewhere...
127     MUST be terminated with a NULL.
128 */
129 static const char *_linkCmd[] =
130 {
131   "aslink", "-nf", "$1", NULL
132 };
133
134 static const char *_asmCmd[] =
135 {
136   "asx8051", "-plosgffc", "$1.asm", NULL
137 };
138
139 /* Globals */
140 PORT mcs51_port =
141 {
142   TARGET_ID_MCS51,
143   "mcs51",
144   "MCU 8051",                   /* Target name */
145   {
146     TRUE,                       /* Emit glue around main */
147     MODEL_SMALL | MODEL_LARGE,
148     MODEL_SMALL
149   },
150   {
151     _asmCmd,
152     "-plosgffc",                /* Options with debug */
153     "-plosgff",                 /* Options without debug */
154     0
155   },
156   {
157     _linkCmd,
158     NULL,
159     ".rel"
160   },
161   {
162     _defaultRules
163   },
164   {
165         /* Sizes: char, short, int, long, ptr, fptr, gptr, bit, float, max */
166     1, 1, 2, 4, 1, 2, 3, 1, 4, 4
167   },
168   {
169     "XSEG    (XDATA)",
170     "STACK   (DATA)",
171     "CSEG    (CODE)",
172     "DSEG    (DATA)",
173     "ISEG    (DATA)",
174     "XSEG    (XDATA)",
175     "BSEG    (BIT)",
176     "RSEG    (DATA)",
177     "GSINIT  (CODE)",
178     "OSEG    (OVR,DATA)",
179     "GSFINAL (CODE)",
180     "HOME        (CODE)",
181     NULL,
182     NULL,
183     1
184   },
185   {
186     +1, 1, 4, 1, 1, 0
187   },
188     /* mcs51 has an 8 bit mul */
189   {
190     1, 0
191   },
192   "_",
193   _mcs51_init,
194   _mcs51_parseOptions,
195   _mcs51_finaliseOptions,
196   _mcs51_setDefaultOptions,
197   mcs51_assignRegisters,
198   _mcs51_getRegName,
199   _mcs51_keywords,
200   _mcs51_genAssemblerPreamble,
201   _mcs51_genIVT,
202   _mcs51_reset_regparm,
203   _mcs51_regparm,
204   NULL,
205   FALSE,
206   0,                            /* leave lt */
207   0,                            /* leave gt */
208   1,                            /* transform <= to ! > */
209   1,                            /* transform >= to ! < */
210   1,                            /* transform != to !(a == b) */
211   0,                            /* leave == */
212   PORT_MAGIC
213 };