]> git.sur5r.net Git - cc65/blobdiff - src/ld65/cfg/apple2.cfg
Better handling of imports in the ExprNode structure.
[cc65] / src / ld65 / cfg / apple2.cfg
index c0bf96435497a9034352f838469b5f671939acf3..68c76502e80f9356cdd2c64c437e238c857ab574 100644 (file)
@@ -1,26 +1,42 @@
+# Default configuration built into ld65 (allowing for 3KB of HIGHCODE)
+FEATURES {
+    STARTADDRESS: default = $0803;
+}
+SYMBOLS {
+    __STACKSIZE__: value = $0800, weak = yes; # 2k stack
+}
 MEMORY {
-    ZP: start = $00, size = $1A, type = rw, define = yes;
-    RAM: start = $800, size = $8E00, file = %O;
+    ZP:                define = yes, start = $0080, size = $001A;
+    HEADER: file = %O,               start = $0000, size = $0004;
+    RAM:    file = %O, define = yes, start = %S,    size = $9600 - __STACKSIZE__ - %S;
+    MOVE:   file = %O, define = yes, start = $0000, size = $FFFF;
+    LC:                define = yes, start = $D400, size = $0C00;
 }
 SEGMENTS {
-    CODE: load = RAM, type = ro;
-    RODATA: load = RAM, type = ro;
-    DATA: load = RAM, type = rw;
-    BSS: load = RAM, type = bss, define = yes;
-    ZEROPAGE: load = ZP, type = zp;
+    ZEROPAGE: load = ZP,              type = zp;
+    EXEHDR:   load = HEADER,          type = ro;
+    STARTUP:  load = RAM,             type = ro;
+    LOWCODE:  load = RAM,             type = ro;
+    CODE:     load = RAM,             type = ro;
+    RODATA:   load = RAM,             type = ro;
+    DATA:     load = RAM,             type = rw;
+    ZPSAVE:   load = RAM,             type = bss, define   = yes;
+    BSS:      load = RAM,             type = bss, define   = yes;
+    INIT:     load = MOVE, run = RAM, type = ro,  define   = yes;
+    HIGHCODE: load = MOVE, run = LC,  type = ro,  optional = yes;
 }
 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__;
 }
-
-