mirror of
https://github.com/cc65/cc65.git
synced 2025-01-11 11:30:13 +00:00
0ee9b2e446
So far the INIT segment was run from the later heap+stack. Now the INIT segment is run from the later BSS. The background is that so far the INIT segment was pretty small (from $80 to $180 bytes). But upcoming changes will increase the INIT segment in certain scenarios up to ~ $1000 bytes. So programs with very limited heap+stack might just not been able to move the INIT segment to its run location. But moving the INIT segment to the later BSS allows it to occupy the later BSS+heap+stack. In order to allow that the constructors are _NOT_ allowed anymore to access the BSS. Rather they must use the DATA segment or the new INITBSS segment. The latter isn't cleared at any point so the constructors may use it to expose values to the main program. However they must make sure to always write the values as they are not pre-initialized.
46 lines
1.4 KiB
ArmAsm
46 lines
1.4 KiB
ArmAsm
;
|
|
; 2015-10-07, Greg King
|
|
;
|
|
|
|
.export moveinit
|
|
|
|
.import __INIT_LOAD__, __INIT_RUN__, __INIT_SIZE__ ; Linker-generated
|
|
|
|
.macpack cpu
|
|
.macpack generic
|
|
|
|
|
|
; Put this in the DATA segment because it is self-modifying code.
|
|
|
|
.data
|
|
|
|
; Move the INIT segment from where it was loaded (over the bss segments)
|
|
; into where it must be run (over the BSS segment). The two areas might overlap;
|
|
; and, the segment is moved upwards. Therefore, this code starts at the highest
|
|
; address, and decrements to the lowest address. The low bytes of the starting
|
|
; pointers are not sums. The high bytes are sums; but, they do not include the
|
|
; carry. Both the low-byte sums and the carries will be done when the pointers
|
|
; are indexed by the .Y register.
|
|
|
|
moveinit:
|
|
|
|
; First, move the last, partial page.
|
|
; Then, move all of the full pages.
|
|
|
|
ldy #<__INIT_SIZE__ ; size of partial page
|
|
ldx #>__INIT_SIZE__ + (<__INIT_SIZE__ <> 0) ; number of pages, including partial
|
|
|
|
L1: dey
|
|
init_load:
|
|
lda __INIT_LOAD__ + (__INIT_SIZE__ & $FF00) - $0100 * (<__INIT_SIZE__ = 0),y
|
|
init_run:
|
|
sta __INIT_RUN__ + (__INIT_SIZE__ & $FF00) - $0100 * (<__INIT_SIZE__ = 0),y
|
|
tya
|
|
bnz L1 ; page not finished
|
|
|
|
dec init_load+2
|
|
dec init_run+2
|
|
dex
|
|
bnz L1 ; move next page
|
|
rts
|