From 3cb0cce00d689818657a1c2e4d058be7b3f2dc42 Mon Sep 17 00:00:00 2001
From: "ol.sc"
Date: Sun, 3 Jun 2012 16:16:11 +0000
Subject: [PATCH] Added secondary linker config for C64 overlays (incl. demo
program).
git-svn-id: svn://svn.cc65.org/cc65/trunk@5679 b7a2c559-68d2-44c3-8de9-860c34a00d81
---
samples/Makefile | 3 ++
samples/overlaydemo.c | 86 ++++++++++++++++++++++++++++++++++++
src/ld65/cfg/c64-overlay.cfg | 57 ++++++++++++++++++++++++
3 files changed, 146 insertions(+)
create mode 100644 samples/overlaydemo.c
create mode 100644 src/ld65/cfg/c64-overlay.cfg
diff --git a/samples/Makefile b/samples/Makefile
index a5bf9acef..746de79a7 100644
--- a/samples/Makefile
+++ b/samples/Makefile
@@ -122,6 +122,9 @@ endif
nachtm: nachtm.o
+overlaydemo: overlaydemo.o
+ @$(LD) -t $(SYS) -m $(basename $@).map -C $(SYS)-overlay.cfg -o $@ $^ $(CLIB)
+
plasma: plasma.o
sieve: sieve.o
diff --git a/samples/overlaydemo.c b/samples/overlaydemo.c
new file mode 100644
index 000000000..02451a28a
--- /dev/null
+++ b/samples/overlaydemo.c
@@ -0,0 +1,86 @@
+/*
+ * Minimalistic overlay demo program.
+ *
+ * 2009-10-02, Oliver Schmidt (ol.sc@web.de)
+ *
+ */
+
+
+
+#include
+#include
+#include
+
+
+extern void _OVERLAY1_LOAD__, _OVERLAY1_SIZE__;
+extern void _OVERLAY2_LOAD__, _OVERLAY2_SIZE__;
+extern void _OVERLAY3_LOAD__, _OVERLAY3_SIZE__;
+
+
+void log (char *msg)
+{
+ printf ("Log: %s\n", msg);
+}
+
+
+#pragma code-name (push, "OVERLAY1");
+
+void foo (void)
+{
+ log ("Calling main from overlay 1");
+}
+
+#pragma code-name (pop);
+
+
+#pragma code-name (push, "OVERLAY2");
+
+void bar (void)
+{
+ log ("Calling main from overlay 2");
+}
+
+#pragma code-name (pop);
+
+
+#pragma code-name (push, "OVERLAY3");
+
+void foobar (void)
+{
+ log ("Calling main from overlay 3");
+}
+
+#pragma code-name(pop);
+
+
+unsigned char loadfile (char *name, void *addr, void *size)
+{
+ int file = open (name, O_RDONLY);
+ if (file == -1) {
+ log ("Opening overlay file failed");
+ return 0;
+ }
+
+ read (file, addr, (unsigned) size);
+ close (file);
+ return 1;
+}
+
+
+void main (void)
+{
+ log ("Calling overlay 1 from main");
+ if (loadfile ("overlaydemo.1", &_OVERLAY1_LOAD__, &_OVERLAY1_SIZE__)) {
+ foo ();
+ }
+
+ log ("Calling overlay 2 from main");
+ if (loadfile ("overlaydemo.2", &_OVERLAY2_LOAD__, &_OVERLAY2_SIZE__)) {
+ bar ();
+ }
+
+ log ("Calling overlay 3 from main");
+ if (loadfile ("overlaydemo.3", &_OVERLAY3_LOAD__, &_OVERLAY3_SIZE__)) {
+ foobar ();
+ }
+}
diff --git a/src/ld65/cfg/c64-overlay.cfg b/src/ld65/cfg/c64-overlay.cfg
new file mode 100644
index 000000000..5995ce28a
--- /dev/null
+++ b/src/ld65/cfg/c64-overlay.cfg
@@ -0,0 +1,57 @@
+SYMBOLS {
+ __LOADADDR__: type = import;
+ __EXEHDR__: type = import;
+ __STACKSIZE__: type = weak, value = $0800; # 2k stack
+ __OVERLAYSIZE__: type = weak, value = $1000; # 4k overlay
+}
+MEMORY {
+ ZP: file = "", define = yes, start = $0002, size = $001A;
+ LOADADDR: file = %O, start = $07FF, size = $0002;
+ HEADER: file = %O, start = $0801, size = $000C;
+ RAM: file = %O, define = yes, start = $080D, size = $C7F3 - __OVERLAYSIZE__ - __STACKSIZE__;
+ OVL1: file = "%O.1", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL2: file = "%O.2", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL3: file = "%O.3", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL4: file = "%O.4", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL5: file = "%O.5", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL6: file = "%O.6", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL7: file = "%O.7", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL8: file = "%O.8", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+ OVL9: file = "%O.9", start = $D000 - __OVERLAYSIZE__, size = __OVERLAYSIZE__;
+}
+SEGMENTS {
+ LOADADDR: load = LOADADDR, type = ro;
+ EXEHDR: load = HEADER, type = ro;
+ STARTUP: load = RAM, type = ro;
+ LOWCODE: load = RAM, type = ro, optional = yes;
+ INIT: load = RAM, type = ro, define = yes, optional = yes;
+ CODE: load = RAM, type = ro;
+ RODATA: load = RAM, type = ro;
+ DATA: load = RAM, type = rw;
+ ZPSAVE: load = RAM, type = bss;
+ BSS: load = RAM, type = bss, define = yes;
+ ZEROPAGE: load = ZP, type = zp;
+ OVERLAY1: load = OVL1, type = ro, define = yes, optional = yes;
+ OVERLAY2: load = OVL2, type = ro, define = yes, optional = yes;
+ OVERLAY3: load = OVL3, type = ro, define = yes, optional = yes;
+ OVERLAY4: load = OVL4, type = ro, define = yes, optional = yes;
+ OVERLAY5: load = OVL5, type = ro, define = yes, optional = yes;
+ OVERLAY6: load = OVL6, type = ro, define = yes, optional = yes;
+ OVERLAY7: load = OVL7, type = ro, define = yes, optional = yes;
+ OVERLAY8: load = OVL8, type = ro, define = yes, optional = yes;
+ OVERLAY9: load = OVL9, type = ro, define = yes, optional = yes;
+}
+FEATURES {
+ CONDES: segment = INIT,
+ type = constructor,
+ label = __CONSTRUCTOR_TABLE__,
+ count = __CONSTRUCTOR_COUNT__;
+ CONDES: segment = RODATA,
+ type = destructor,
+ label = __DESTRUCTOR_TABLE__,
+ count = __DESTRUCTOR_COUNT__;
+ CONDES: segment = RODATA,
+ type = interruptor,
+ label = __INTERRUPTOR_TABLE__,
+ count = __INTERRUPTOR_COUNT__;
+}