From 9caf7cefd8327082ed1eda1c1421b040e0e278ee Mon Sep 17 00:00:00 2001 From: Karri Kaksonen Date: Tue, 5 Apr 2022 11:13:38 +0300 Subject: [PATCH] Allocate own zp pointer for conio implementation --- cfg/atari7800.cfg | 1 + libsrc/atari7800/cputc.s | 8 ++++---- libsrc/atari7800/setcursor.s | 17 +++++++++-------- 3 files changed, 14 insertions(+), 12 deletions(-) diff --git a/cfg/atari7800.cfg b/cfg/atari7800.cfg index 72922e52e..04216f3bd 100644 --- a/cfg/atari7800.cfg +++ b/cfg/atari7800.cfg @@ -39,6 +39,7 @@ MEMORY { SEGMENTS { ZEROPAGE: load = ZP, type = zp; + EXTZP: load = ZP, type = zp; EXEHDR: load = HEADER, type = ro, optional = yes; STARTUP: load = ROMS, type = ro, define = yes; ONCE: load = ROMS, type = ro, define = yes; diff --git a/libsrc/atari7800/cputc.s b/libsrc/atari7800/cputc.s index 3cf8e9de1..f7614e528 100644 --- a/libsrc/atari7800/cputc.s +++ b/libsrc/atari7800/cputc.s @@ -10,10 +10,10 @@ .import _gotoxy, _gotox, _gotoy, tosaddax, tosumula0, pusha0 .import pushax .import _screen - .importzp ptr3 .import CURS_X, CURS_Y .include "atari7800.inc" + .include "extzp.inc" .data ;----------------------------------------------------------------------------- @@ -132,12 +132,12 @@ txtcolor: lda #<(_screen) ldx #>(_screen) jsr tosaddax - sta ptr3 - stx ptr3+1 + sta ptr7800 + stx ptr7800+1 pla ldy #0 - sta (ptr3),y + sta (ptr7800),y rts .endproc diff --git a/libsrc/atari7800/setcursor.s b/libsrc/atari7800/setcursor.s index b283fdff0..4400798c3 100644 --- a/libsrc/atari7800/setcursor.s +++ b/libsrc/atari7800/setcursor.s @@ -28,10 +28,11 @@ .export CURS_X, CURS_Y .constructor init_cursor - .importzp ptr3, sp + .importzp sp .import _zones .import pusha, incsp1, pusha0, pushax, popax, tosumula0, incax5 .include "atari7800.inc" + .include "extzp.inc" .macpack generic @@ -81,11 +82,11 @@ _cursorzone: clc adc #<_zones sta _cursorzone ; calculate new cursorzone - sta ptr3 + sta ptr7800 txa adc #>_zones sta _cursorzone+1 - sta ptr3+1 + sta ptr7800+1 rts .endproc @@ -112,7 +113,7 @@ _cursorzone: jsr calccursorzone ldy #1 lda #0 - sta (ptr3),y ; disable cursor + sta (ptr7800),y ; disable cursor pla sta CURS_Y jsr calccursorzone @@ -120,7 +121,7 @@ _cursorzone: beq @L1 lda #30 ; enable cursor @L1: ldy #1 - sta (ptr3),y + sta (ptr7800),y rts .endproc @@ -136,15 +137,15 @@ _cursorzone: tay lda _cursorzone ldx _cursorzone+1 - sta ptr3 - stx ptr3+1 + sta ptr7800 + stx ptr7800+1 tya ldy #3 clc rol rol rol - sta (ptr3),y + sta (ptr7800),y rts .endproc