# Linker config. to produce a NEC PC-Engine 8K, 16K, or 32K image (.bin)
SYMBOLS {
    __CARTSIZE__:  type = weak, value = $2000; # $2000, $4000, or $8000
    __STACKSIZE__: type = weak, value = $0300; # 3 pages stack
}
MEMORY {
    ZP:   file = "", start =  $0000, define = yes,  size = $0100;
    # RAM bank
    MAIN: file = "", start =  $2200, define = yes,  size = $1E00 - __STACKSIZE__;
    # ROM banks, before swapping, and after mapping
    ROM:  file = %O, start = $10000 - __CARTSIZE__, size = __CARTSIZE__, fill = yes, fillval = $FF;
}
SEGMENTS {
    ZEROPAGE: load = ZP,              type = zp;
    EXTZP:    load = ZP,              type = zp,  optional = yes;
    APPZP:    load = ZP,              type = zp,  optional = yes;
    DATA:     load = ROM, run = MAIN, type = rw,                  define = yes;
    INIT:     load = MAIN,            type = bss, optional = yes;
    BSS:      load = MAIN,            type = bss,                 define = yes;
    RODATA:   load = ROM,             type = ro;
    CODE:     load = ROM,             type = ro;
    LOWCODE:  load = ROM,             type = ro,  optional = yes;
    ONCE:     load = ROM,             type = ro,  optional = yes;
    STARTUP:  load = ROM,             type = ro,  start = $FFF6 - $0066;
    VECTORS:  load = ROM,             type = ro,  start = $FFF6;
}
FEATURES {
    CONDES: type    = constructor,
            label   = __CONSTRUCTOR_TABLE__,
            count   = __CONSTRUCTOR_COUNT__,
            segment = ONCE;
    CONDES: type    = destructor,
            label   = __DESTRUCTOR_TABLE__,
            count   = __DESTRUCTOR_COUNT__,
            segment = RODATA;
    CONDES: type    = interruptor,
            label   = __INTERRUPTOR_TABLE__,
            count   = __INTERRUPTOR_COUNT__,
            segment = RODATA,
            import  = __CALLIRQ__;
}