]> git.sur5r.net Git - cc65/blobdiff - src/ld65/cfg/atari.cfg
Better handling of imports in the ExprNode structure.
[cc65] / src / ld65 / cfg / atari.cfg
index ba8dcfde6b22dd247fa5c47a11a5bfc6bec48b1f..88757512c16db3555a35f9b3f3653cd23313bd8a 100644 (file)
@@ -1,27 +1,41 @@
+FEATURES {
+    STARTADDRESS: default = $2E00;
+}
+SYMBOLS {
+    __STACKSIZE__:       value = $0800, weak = yes; # 2k stack
+    __RESERVED_MEMORY__: value = $0000, weak = yes;
+}
 MEMORY {
-    ZP: start = $82, size = $7E, type = rw, define = yes;
-    HEADER: start = $0000, size = $6, file = %O;
-    RAM: start = $2E00, size = $8E20, file = %O;    # $8E20: matches upper bound $BC1F
+    ZP:      define = yes, start = $0082, size = $007E;
+    HEADER:  file = %O,    start = $0000, size = $0006;
+    RAM:     file = %O,    start = %S,    size = $BC20 - __STACKSIZE__ - %S;
+    TRAILER: file = %O,    start = $0000, size = $0006;
 }
 SEGMENTS {
-    EXEHDR: load = HEADER, type = ro;
-    CODE: load = RAM, type = ro, define = yes;
-    RODATA: load = RAM, type = ro;
-    DATA: load = RAM, type = rw;
-    BSS: load = RAM, type = bss, define = yes;
-    ZEROPAGE: load = ZP, type = zp;
-    AUTOSTRT: load = RAM, type = ro;
+    EXEHDR:   load = HEADER,  type = ro;
+    STARTUP:  load = RAM,     type = ro,  define = yes;
+    LOWCODE:  load = RAM,     type = ro,  define = yes, optional = yes;
+    INIT:     load = RAM,     type = ro,                optional = yes;
+    CODE:     load = RAM,     type = ro,  define = yes;
+    RODATA:   load = RAM,     type = ro;
+    DATA:     load = RAM,     type = rw;
+    ZPSAVE:   load = RAM,     type = bss, define = yes;
+    BSS:      load = RAM,     type = bss, define = yes;
+    ZEROPAGE: load = ZP,      type = zp;
+    EXTZP:    load = ZP,      type = zp,                optional = yes;
+    AUTOSTRT: load = TRAILER, type = ro;
 }
 FEATURES {
+    CONDES: segment = INIT,
+           type    = constructor,
+           label   = __CONSTRUCTOR_TABLE__,
+           count   = __CONSTRUCTOR_COUNT__;
     CONDES: segment = RODATA,
-           type = constructor,
-           label = __CONSTRUCTOR_TABLE__,
-           count = __CONSTRUCTOR_COUNT__;
+           type    = destructor,
+           label   = __DESTRUCTOR_TABLE__,
+           count   = __DESTRUCTOR_COUNT__;
     CONDES: segment = RODATA,
-           type = destructor,
-           label = __DESTRUCTOR_TABLE__,
-           count = __DESTRUCTOR_COUNT__;
-}
-SYMBOLS {
-    __STACKSIZE__ = $800;      # 2K stack
+           type    = interruptor,
+           label   = __INTERRUPTOR_TABLE__,
+           count   = __INTERRUPTOR_COUNT__;
 }