mirror of
https://github.com/cc65/cc65.git
synced 2025-01-11 11:30:13 +00:00
419eb700b5
The way we want to use the INITBSS segment - and especially the fact that it won't have the type bss on all ROM based targets - means that the name INITBSS is misleading. After all INIT is the best name from my perspective as it serves several purposes and therefore needs a rather generic name. Unfortunately this means that the current INIT segment needs to be renamed too. Looking for a short (ideally 4 letter) name I came up with ONCE as it contains all code (and data) accessed only once during initialization.
31 lines
1.3 KiB
INI
31 lines
1.3 KiB
INI
# supervision 64kbyte cartridge with bankswitching
|
|
# for assembler
|
|
|
|
# ld65 config file
|
|
# ld65 --config supervision.cfg -o <prog>.bin <prog>.o
|
|
|
|
SYMBOLS {
|
|
__STACKSIZE__: type = weak, value = $0100; # 1 page stack
|
|
}
|
|
MEMORY {
|
|
RAM: file = "", start = $0000, size = $2000 - __STACKSIZE__;
|
|
VRAM: file = "", start = $4000, size = $2000;
|
|
BANKROM1: file = %O, start = $8000, size = $4000, fill = yes, fillval = $FF;
|
|
BANKROM2: file = %O, start = $8000, size = $4000, fill = yes, fillval = $FF;
|
|
BANKROM3: file = %O, start = $8000, size = $4000, fill = yes, fillval = $FF;
|
|
ROM: file = %O, start = $C000, size = $4000, fill = yes, fillval = $FF;
|
|
}
|
|
SEGMENTS {
|
|
LOWCODE: load = ROM, type = ro, optional = yes;
|
|
ONCE: load = ROM, type = ro, define = yes, optional = yes;
|
|
CODE: load = ROM, type = ro;
|
|
RODATA: load = ROM, type = ro;
|
|
BANK1: load = BANKROM1, type = ro;
|
|
BANK2: load = BANKROM2, type = ro;
|
|
BANK3: load = BANKROM3, type = ro;
|
|
ZEROPAGE: load = RAM, type = bss, define = yes;
|
|
DATA: load = RAM, type = bss, define = yes, offset = $0200;
|
|
BSS: load = RAM, type = bss, define = yes;
|
|
VECTOR: load = ROM, type = ro, offset = $3FFA;
|
|
}
|