1
0
mirror of https://github.com/mgcaret/of816.git synced 2024-06-07 21:29:27 +00:00
of816/platforms/Neon816/Neon816.s
2019-12-01 00:41:06 -08:00

80 lines
2.1 KiB
ArmAsm

.p816
.a16
.i16
.include "macros.inc"
.include "./Neon816-hw.inc"
.import _Forth_initialize
.import _Forth_ui
.import _system_interface
; Bank Map from FB posting by Lenore:
; 00 Bank Mapper (16 blocks of 4k each, configured via MMU)
; 08-0F Bus Controller Peripherals
; - 08 0000-003F MMU
; -- 00: 0-3 Unused, 4-7: Upper RAM bits
; -- 01: Bank
; - 09 FDC
; 10-1F Internal Bus Bridge
; 20-27 Flash ROM
; 28-3F Reserved for Flash
; 30-3F Reserved for Expansion Flash
; 40-47 Video RAM
; 48-7F Reserved for VRAM
; 80-87 RAM 1
; 88-8F RAM 2
; 90-FF Reserved for RAM
.pushseg
.segment "FStartup"
.proc startup
clc
xce
rep #SHORT_A|SHORT_I
.a16
.i16
; MMU setup, maybe. Found at page $FF in Neon bank 0
ldx #$001C
lda #$8000
: sta f:NeonMMU,x
dex
dex
bpl :-
; NeonFORTH does this, presumably to initialize the serial port
sep #SHORT_A ; not necessary unless we were already native & long
.a8
lda #$8D
sta f:SERctrlA
lda #$06
sta f:SERctrlB
lda #$00
sta f:SERctrlC
rep #SHORT_A|SHORT_I
.a16
.i16
lda #$0000 ; direct page for Forth
tcd
lda #.hiword($0A0000) ; top of dictionary memory
pha
lda #.loword($0A0000)
pha
lda #.hiword($090000) ; bottom of dictionary
pha
lda #.loword($090000)
pha
lda #$0200 ; first usable stack cell (relative to direct page)
pha
lda #$0100 ; last usable stack cell+1 (relative to direct page)
pha
lda #$03FF ; return stack first usable byte
pha
lda #.hiword(_system_interface)
pha
lda #.loword(_system_interface)
pha
jsl _Forth_initialize
jsl _Forth_ui
brk
.byte $00
.endproc
.popseg