1
0
mirror of https://github.com/hsoft/collapseos.git synced 2025-01-05 11:48:06 +11:00
collapseos/recipes/rc2014/sdcard/glue.asm

71 lines
1.4 KiB
NASM
Raw Normal View History

2019-05-08 05:26:52 +10:00
; classic RC2014 setup (8K ROM + 32K RAM) and a stock Serial I/O module
; The RAM module is selected on A15, so it has the range 0x8000-0xffff
RAMSTART .equ 0x8000
RAMEND .equ 0xffff
ACIA_CTL .equ 0x80 ; Control and status. RS off.
ACIA_IO .equ 0x81 ; Transmit. RS on.
jp init
2019-05-08 05:26:52 +10:00
; *** JUMP TABLE ***
; Why not use this unused space between 0x03 and 0x38 for a jump table?
2019-05-08 05:26:52 +10:00
jp printstr
jp printHex
jp sdcInitialize
2019-05-08 05:26:52 +10:00
jp sdcSendRecv
jp sdcWaitResp
jp sdcCmd
jp sdcCmdR1
jp sdcCmdR7
jp sdcReadBlk
jp sdcSetBlkSize
2019-05-08 05:26:52 +10:00
; interrupt hook
.fill 0x38-$
jp aciaInt
#include "core.asm"
ACIA_RAMSTART .equ RAMSTART
#include "acia.asm"
.define STDIO_GETC call aciaGetC
.define STDIO_PUTC call aciaPutC
STDIO_RAMSTART .equ ACIA_RAMEND
#include "stdio.asm"
BLOCKDEV_RAMSTART .equ STDIO_RAMEND
BLOCKDEV_COUNT .equ 2
#include "blockdev.asm"
; List of devices
.dw aciaGetC, aciaPutC, 0, 0
.dw sdcGetC, 0, 0, 0
#include "blockdev_cmds.asm"
SHELL_RAMSTART .equ BLOCKDEV_RAMEND
.define SHELL_IO_GETC call blkGetCW
.define SHELL_IO_PUTC call blkPutC
SHELL_EXTRA_CMD_COUNT .equ 3
2019-05-08 05:26:52 +10:00
#include "shell.asm"
.dw sdcInitializeCmd, blkBselCmd, blkSeekCmd
2019-05-08 05:26:52 +10:00
.equ SDC_RAMSTART SHELL_RAMEND
2019-05-08 05:26:52 +10:00
.equ SDC_PORT_CSHIGH 6
.equ SDC_PORT_CSLOW 5
.equ SDC_PORT_SPI 4
#include "sdc.asm"
init:
di
; setup stack
ld hl, RAMEND
ld sp, hl
im 1
call aciaInit
xor a
ld de, BLOCKDEV_GETC
call blkSel
call shellInit
ei
jp shellLoop