From: ol.sc Date: Sat, 2 Oct 2010 10:20:00 +0000 (+0000) Subject: Exclude (small) stack from RAM memory area (like on most other targets) to make expli... X-Git-Tag: V2.13.3~633 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=aaf90c1252a09346deb1ccdab96546368afdbbdd;p=cc65 Exclude (small) stack from RAM memory area (like on most other targets) to make explicit that the linker may not use all RAM. If the cc65 parameter stack isn't used at all the __STACKSIZE__ symbol may be overridden on the linker command line with -D __STACKSIZE__=0. git-svn-id: svn://svn.cc65.org/cc65/trunk@4820 b7a2c559-68d2-44c3-8de9-860c34a00d81 --- diff --git a/libsrc/supervision/crt0.s b/libsrc/supervision/crt0.s index 6a3614476..bb82de3ee 100644 --- a/libsrc/supervision/crt0.s +++ b/libsrc/supervision/crt0.s @@ -9,6 +9,7 @@ .import initlib, donelib, copydata .import zerobss .import __RAM_START__, __RAM_SIZE__ ; Linker generated + .import __STACKSIZE__ ; Linker generated .include "zeropage.inc" .include "supervision.inc" @@ -30,9 +31,9 @@ reset: ; initialize data jsr copydata - lda #>(__RAM_START__ + __RAM_SIZE__) + lda #>(__RAM_START__ + __RAM_SIZE__ + __STACKSIZE__) sta sp+1 ; Set argument stack ptr - stz sp ; #<(__RAM_START__ + __RAM_SIZE__) + stz sp ; #<(__RAM_START__ + __RAM_SIZE__ + __STACKSIZE__) jsr initlib jsr _main _exit: jsr donelib diff --git a/src/ld65/cfg/supervision-128k.cfg b/src/ld65/cfg/supervision-128k.cfg index 7f3ee51cc..0c2d1b36b 100644 --- a/src/ld65/cfg/supervision-128k.cfg +++ b/src/ld65/cfg/supervision-128k.cfg @@ -4,8 +4,11 @@ # ld65 config file # ld65 --config supervision.cfg -o .bin .o +SYMBOLS { + __STACKSIZE__: value = $0100, weak = yes; # 1 page stack +} MEMORY { - RAM: start = $0000, size = $2000; + RAM: start = $0000, size = $2000 - __STACKSIZE__; VRAM: start = $4000, size = $2000; BANKROM1: start = $8000, size = $4000, fill = yes, fillval = $FF, file = %O; BANKROM2: start = $8000, size = $4000, fill = yes, fillval = $FF, file = %O; diff --git a/src/ld65/cfg/supervision-16k.cfg b/src/ld65/cfg/supervision-16k.cfg index 5ec5db54e..791133e7b 100644 --- a/src/ld65/cfg/supervision-16k.cfg +++ b/src/ld65/cfg/supervision-16k.cfg @@ -2,14 +2,17 @@ # ld65 config file # ld65 --config supervision16.cfg -o .bin .o + +SYMBOLS { + __STACKSIZE__: value = $0100, weak = yes; # 1 page stack +} MEMORY { ZP: start = $0000, size = $0100; CPUSTACK: start = $0100, size = $0100; - RAM: start = $0200, size = $1E00; + RAM: start = $0200, size = $1E00 - __STACKSIZE__; VRAM: start = $4000, size = $2000; ROM: start = $C000, size = $4000, fill = yes, fillval = $ff, file=%O, define=yes; } - SEGMENTS { LOWCODE: load = ROM, type = ro, optional = yes; INIT: load = ROM, type = ro, define = yes, optional = yes; diff --git a/src/ld65/cfg/supervision-64k.cfg b/src/ld65/cfg/supervision-64k.cfg index 4cafdecae..6ae587296 100644 --- a/src/ld65/cfg/supervision-64k.cfg +++ b/src/ld65/cfg/supervision-64k.cfg @@ -4,8 +4,11 @@ # ld65 config file # ld65 --config supervision.cfg -o .bin .o +SYMBOLS { + __STACKSIZE__: value = $0100, weak = yes; # 1 page stack +} MEMORY { - RAM: start = $0000, size = $2000; + RAM: start = $0000, size = $2000 - __STACKSIZE__; VRAM: start = $4000, size = $2000; BANKROM1: start = $8000, size = $4000, fill = yes, fillval = $FF, file = %O; BANKROM2: start = $8000, size = $4000, fill = yes, fillval = $FF, file = %O;