2010-03-21 17:10:17 +00:00
|
|
|
SYMBOLS {
|
2010-11-12 14:17:35 +00:00
|
|
|
__STACKSIZE__: type = weak, value = $0300; # 3 pages stack
|
2010-03-21 17:10:17 +00:00
|
|
|
}
|
2000-10-31 18:08:25 +00:00
|
|
|
MEMORY {
|
2010-11-12 19:59:02 +00:00
|
|
|
ZP: file = "", start = $0002, size = $001A, type = rw, define = yes;
|
2003-05-02 13:47:43 +00:00
|
|
|
|
|
|
|
# INES Cartridge Header
|
2010-11-12 19:59:02 +00:00
|
|
|
HEADER: file = %O, start = $0000, size = $0010, fill = yes;
|
2003-05-02 13:47:43 +00:00
|
|
|
|
|
|
|
# 2 16K ROM Banks
|
|
|
|
# - startup
|
|
|
|
# - code
|
|
|
|
# - rodata
|
|
|
|
# - data (load)
|
2010-11-12 19:59:02 +00:00
|
|
|
ROM0: file = %O, start = $8000, size = $7FF4, fill = yes, define = yes;
|
2003-05-02 13:47:43 +00:00
|
|
|
|
|
|
|
# Hardware Vectors at End of 2nd 8K ROM
|
2010-11-12 19:59:02 +00:00
|
|
|
ROMV: file = %O, start = $FFF6, size = $000C, fill = yes;
|
2003-05-02 13:47:43 +00:00
|
|
|
|
|
|
|
# 1 8k CHR Bank
|
2010-11-12 19:59:02 +00:00
|
|
|
ROM2: file = %O, start = $0000, size = $2000, fill = yes;
|
2003-05-02 13:47:43 +00:00
|
|
|
|
|
|
|
# standard 2k SRAM (-zeropage)
|
|
|
|
# $0100-$0200 cpu stack
|
|
|
|
# $0200-$0500 3 pages for ppu memory write buffer
|
|
|
|
# $0500-$0800 3 pages for cc65 parameter stack
|
2010-11-12 19:59:02 +00:00
|
|
|
SRAM: file = "", start = $0500, size = __STACKSIZE__, define = yes;
|
2003-05-02 13:47:43 +00:00
|
|
|
|
|
|
|
# additional 8K SRAM Bank
|
|
|
|
# - data (run)
|
|
|
|
# - bss
|
|
|
|
# - heap
|
2013-02-12 20:55:19 +00:00
|
|
|
RAM: file = "", start = $6000, size = $2000, define = yes;
|
2000-10-31 18:08:25 +00:00
|
|
|
}
|
|
|
|
SEGMENTS {
|
2016-03-06 21:26:22 +01:00
|
|
|
ZEROPAGE: load = ZP, type = zp;
|
2005-01-08 21:08:04 +00:00
|
|
|
HEADER: load = HEADER, type = ro;
|
2016-03-17 21:31:43 +01:00
|
|
|
STARTUP: load = ROM0, type = ro, define = yes;
|
|
|
|
LOWCODE: load = ROM0, type = ro, optional = yes;
|
|
|
|
ONCE: load = ROM0, type = ro, optional = yes;
|
|
|
|
CODE: load = ROM0, type = ro, define = yes;
|
|
|
|
RODATA: load = ROM0, type = ro, define = yes;
|
|
|
|
DATA: load = ROM0, run = RAM, type = rw, define = yes;
|
2003-05-02 13:47:43 +00:00
|
|
|
VECTORS: load = ROMV, type = rw;
|
|
|
|
CHARS: load = ROM2, type = rw;
|
2016-03-17 21:31:43 +01:00
|
|
|
BSS: load = RAM, type = bss, define = yes;
|
2000-10-31 18:08:25 +00:00
|
|
|
}
|
2000-11-20 23:04:30 +00:00
|
|
|
FEATURES {
|
2013-02-12 20:55:19 +00:00
|
|
|
CONDES: type = constructor,
|
|
|
|
label = __CONSTRUCTOR_TABLE__,
|
|
|
|
count = __CONSTRUCTOR_COUNT__,
|
2016-03-06 21:26:22 +01:00
|
|
|
segment = ONCE;
|
2013-02-12 20:55:19 +00:00
|
|
|
CONDES: type = destructor,
|
|
|
|
label = __DESTRUCTOR_TABLE__,
|
|
|
|
count = __DESTRUCTOR_COUNT__,
|
|
|
|
segment = RODATA;
|
|
|
|
CONDES: type = interruptor,
|
|
|
|
label = __INTERRUPTOR_TABLE__,
|
|
|
|
count = __INTERRUPTOR_COUNT__,
|
|
|
|
segment = RODATA,
|
2012-11-03 21:59:15 +00:00
|
|
|
import = __CALLIRQ__;
|
2001-03-10 14:24:58 +00:00
|
|
|
}
|