mirror of
https://github.com/cc65/cc65.git
synced 2025-01-11 11:30:13 +00:00
d8c31cf1d3
The name RAM doesn't make much sense in general for a memeory area because i.e. the zero page is for sure RAM but is not part of the memory area named RAM. For disk based targets it makes sense to put the disk file more into focus and here MAIN means the main part of the file - in contrast to some header. Only for ROM based targets the name RAM is kept as it makes sense to focus on the difference between RAM and ROM.
26 lines
1022 B
INI
26 lines
1022 B
INI
FEATURES {
|
|
STARTADDRESS: default = $0200;
|
|
}
|
|
SYMBOLS {
|
|
# If you want ld65 to output a loadable-format file by default, then uncomment
|
|
# the next line. (Then, "-u __BOOT__" wouldn't be needed on the command line.)
|
|
# __BOOT__: type = import;
|
|
__STACKSIZE__: type = weak, value = $0400; # 1 kB stack
|
|
__HIMEM__: type = weak, value = $8000; # 32 kB RAM
|
|
}
|
|
MEMORY {
|
|
# for size of ZP, see runtime/zeropage.s and c1p/extzp.s
|
|
ZP: file = "", define = yes, start = $0002, size = $001A + $0006;
|
|
HEAD: file = %O, start = $0000, size = $00B6;
|
|
MAIN: file = %O, define = yes, start = %S, size = __HIMEM__ - __STACKSIZE__ - %S;
|
|
}
|
|
SEGMENTS {
|
|
ZEROPAGE: load = ZP, type = zp;
|
|
BOOT: load = HEAD, type = ro, optional = yes;
|
|
ONCE: load = MAIN, type = ro, define = yes, optional = yes;
|
|
CODE: load = MAIN, type = rw;
|
|
RODATA: load = MAIN, type = rw;
|
|
DATA: load = MAIN, type = rw;
|
|
BSS: load = MAIN, type = bss, define = yes;
|
|
}
|