diff --git a/libsrc/c128/crt0.s b/libsrc/c128/crt0.s index 247fdb743..3e3576a21 100644 --- a/libsrc/c128/crt0.s +++ b/libsrc/c128/crt0.s @@ -50,11 +50,6 @@ Head: .word @Next lda #14 jsr BSOUT -; Set the bank for the file name our execution bank - - lda #0 - sta FNAM_BANK - ; Before doing anything else, we have to setup our banking configuration. ; Otherwise just the lowest 16K are actually RAM. Writing through the ROM ; to the underlying RAM works, but it is bad style. @@ -93,6 +88,13 @@ L1: lda sp,x jsr initlib +; Set the bank for the file name to our execution bank. We must do this, +; *after* calling constructors, because some of them may depend on the +; original value of this register. + + lda #0 + sta FNAM_BANK + ; If we have IRQ functions, chain our stub into the IRQ vector lda #<__IRQFUNC_COUNT__