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
996 B
ArmAsm
31 lines
996 B
ArmAsm
;
|
|
; Karri Kaksonen, 2011
|
|
;
|
|
; A default directory with just the main executable.
|
|
;
|
|
.include "lynx.inc"
|
|
.import __STARTOFDIRECTORY__
|
|
.import __RAM_START__
|
|
.import __CODE_SIZE__, __DATA_SIZE__, __RODATA_SIZE__
|
|
.import __STARTUP_SIZE__, __ONCE_SIZE__, __LOWCODE_SIZE__
|
|
.import __BLOCKSIZE__
|
|
.export __DEFDIR__: absolute = 1
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
; Lynx directory
|
|
.segment "DIRECTORY"
|
|
|
|
__DIRECTORY_START__:
|
|
off0 = __STARTOFDIRECTORY__ + (__DIRECTORY_END__ - __DIRECTORY_START__)
|
|
blocka = off0 / __BLOCKSIZE__
|
|
; Entry 0 - first executable
|
|
block0 = off0 / __BLOCKSIZE__
|
|
len0 = __STARTUP_SIZE__ + __ONCE_SIZE__ + __CODE_SIZE__ + __DATA_SIZE__ + __RODATA_SIZE__ + __LOWCODE_SIZE__
|
|
.byte <block0
|
|
.word off0 & (__BLOCKSIZE__ - 1)
|
|
.byte $88
|
|
.word __RAM_START__
|
|
.word len0
|
|
__DIRECTORY_END__:
|