Added missing fixup & removed wait loop from poll.
This commit is contained in:
parent
2d7d1b123d
commit
ae1a875881
1 changed files with 44 additions and 36 deletions
|
@ -79,6 +79,7 @@ fixup: .byte fixup02-fixup01, fixup03-fixup02, fixup04-fixup03
|
||||||
.byte fixup17-fixup16, fixup18-fixup17, fixup19-fixup18
|
.byte fixup17-fixup16, fixup18-fixup17, fixup19-fixup18
|
||||||
.byte fixup20-fixup19, fixup21-fixup20, fixup22-fixup21
|
.byte fixup20-fixup19, fixup21-fixup20, fixup22-fixup21
|
||||||
.byte fixup23-fixup22, fixup24-fixup23, fixup25-fixup24
|
.byte fixup23-fixup22, fixup24-fixup23, fixup25-fixup24
|
||||||
|
.byte fixup26-fixup25, fixup27-fixup26
|
||||||
|
|
||||||
fixups = * - fixup
|
fixups = * - fixup
|
||||||
|
|
||||||
|
@ -169,26 +170,33 @@ fixup08:sta data
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
|
|
||||||
poll:
|
poll:
|
||||||
|
; Check for completion of previous command
|
||||||
|
; Socket 0 Command Register: = 0 ?
|
||||||
|
jsr set_addrcmdreg0
|
||||||
|
fixup09:lda data
|
||||||
|
beq :++
|
||||||
|
|
||||||
|
; No data available
|
||||||
|
lda #$00
|
||||||
|
: tax
|
||||||
|
rts
|
||||||
|
|
||||||
|
; Socket RX Received Size Register: != 0 ?
|
||||||
|
: ldy #$26 ; Socket RX Received Size Register
|
||||||
|
jsr set_addrsocket0
|
||||||
|
fixup10:lda data ; Hibyte
|
||||||
|
fixup11:ora data ; Lobyte
|
||||||
|
beq :--
|
||||||
|
|
||||||
|
; Process the incoming data
|
||||||
|
; -------------------------
|
||||||
|
|
||||||
; Set parameters for receiving data
|
; Set parameters for receiving data
|
||||||
lda #>$6000 ; Socket 0 RX Base Address
|
lda #>$6000 ; Socket 0 RX Base Address
|
||||||
ldx #$00 ; Read
|
ldx #$00 ; Read
|
||||||
jsr set_parameters
|
jsr set_parameters
|
||||||
|
|
||||||
; Socket RX Received Size Register: != 0 ?
|
; ldy #$28 ; Socket RX Read Pointer Register
|
||||||
ldy #$26 ; Socket RX Received Size Register
|
|
||||||
jsr set_addrsocket0
|
|
||||||
fixup09:lda data ; Hibyte
|
|
||||||
fixup10:ora data ; Lobyte
|
|
||||||
bne :+
|
|
||||||
|
|
||||||
; No data available
|
|
||||||
tax
|
|
||||||
rts
|
|
||||||
|
|
||||||
; Process the incoming data
|
|
||||||
; -------------------------
|
|
||||||
|
|
||||||
: ; ldy #$28 ; Socket RX Read Pointer Register
|
|
||||||
; jsr set_addrsocket0
|
; jsr set_addrsocket0
|
||||||
|
|
||||||
; Calculate and set pyhsical address
|
; Calculate and set pyhsical address
|
||||||
|
@ -239,13 +247,13 @@ common: jsr set_addrsocket0
|
||||||
tax
|
tax
|
||||||
lda reg+1
|
lda reg+1
|
||||||
adc adv+1
|
adc adv+1
|
||||||
fixup11:sta data ; Hibyte
|
fixup12:sta data ; Hibyte
|
||||||
fixup12:stx data ; Lobyte
|
fixup13:stx data ; Lobyte
|
||||||
|
|
||||||
; Set command register
|
; Set command register
|
||||||
tya ; Restore command
|
tya ; Restore command
|
||||||
jsr set_addrcmdreg0
|
jsr set_addrcmdreg0
|
||||||
fixup13:sta data
|
fixup14:sta data
|
||||||
|
|
||||||
; Return data length (will be ignored for send)
|
; Return data length (will be ignored for send)
|
||||||
lda len
|
lda len
|
||||||
|
@ -268,11 +276,17 @@ send:
|
||||||
ldx #$01 ; Write
|
ldx #$01 ; Write
|
||||||
jsr set_parameters
|
jsr set_parameters
|
||||||
|
|
||||||
|
; Wait for completion of previous command
|
||||||
|
; Socket 0 Command Register: = 0 ?
|
||||||
|
: jsr set_addrcmdreg0
|
||||||
|
fixup15:lda data
|
||||||
|
bne :-
|
||||||
|
|
||||||
; Socket 0 TX Free Size Register: < length ?
|
; Socket 0 TX Free Size Register: < length ?
|
||||||
: ldy #$20
|
: ldy #$20
|
||||||
jsr set_addrsocket0
|
jsr set_addrsocket0
|
||||||
fixup14:lda data ; Hibyte
|
fixup16:lda data ; Hibyte
|
||||||
fixup15:ldx data ; Lobyte
|
fixup17:ldx data ; Lobyte
|
||||||
cpx len
|
cpx len
|
||||||
sbc len+1
|
sbc len+1
|
||||||
bcc :-
|
bcc :-
|
||||||
|
@ -302,16 +316,16 @@ exit:
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
|
|
||||||
set_addrphysical:
|
set_addrphysical:
|
||||||
fixup16:lda data ; Hibyte
|
fixup18:lda data ; Hibyte
|
||||||
fixup17:ldy data ; Lobyte
|
fixup19:ldy data ; Lobyte
|
||||||
sta reg+1
|
sta reg+1
|
||||||
sty reg
|
sty reg
|
||||||
and #>$1FFF ; Socket Mask Address (hibyte)
|
and #>$1FFF ; Socket Mask Address (hibyte)
|
||||||
ora bas ; Socket Base Address (hibyte)
|
ora bas ; Socket Base Address (hibyte)
|
||||||
tax
|
tax
|
||||||
set_addr:
|
set_addr:
|
||||||
fixup18:stx addr ; Hibyte
|
fixup20:stx addr ; Hibyte
|
||||||
fixup19:sty addr+1 ; Lobyte
|
fixup21:sty addr+1 ; Lobyte
|
||||||
rts
|
rts
|
||||||
|
|
||||||
set_addrcmdreg0:
|
set_addrcmdreg0:
|
||||||
|
@ -326,8 +340,8 @@ set_addrbase:
|
||||||
beq set_addr ; Always
|
beq set_addr ; Always
|
||||||
|
|
||||||
get_datacheckaddr:
|
get_datacheckaddr:
|
||||||
fixup20:lda data
|
fixup22:lda data
|
||||||
ldx addr ; Hibyte
|
fixup23:ldx addr ; Hibyte
|
||||||
cpx lim ; Socket memory limit (hibyte)
|
cpx lim ; Socket memory limit (hibyte)
|
||||||
bcs set_addrbase
|
bcs set_addrbase
|
||||||
rts
|
rts
|
||||||
|
@ -347,12 +361,6 @@ set_parameters:
|
||||||
ldx bufaddr+1
|
ldx bufaddr+1
|
||||||
sta ptr
|
sta ptr
|
||||||
stx ptr+1
|
stx ptr+1
|
||||||
|
|
||||||
; Wait for previous command to complete
|
|
||||||
; Socket 0 Command Register: = 0 ?
|
|
||||||
: jsr set_addrcmdreg0
|
|
||||||
fixup21:lda data
|
|
||||||
bne :-
|
|
||||||
rts
|
rts
|
||||||
|
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
|
@ -372,10 +380,10 @@ mov_data:
|
||||||
; R/W without address wraparound possible because
|
; R/W without address wraparound possible because
|
||||||
; highest R/W address > actual R/W address ?
|
; highest R/W address > actual R/W address ?
|
||||||
; sec
|
; sec
|
||||||
fixup22:sbc addr+1 ; Lobyte
|
fixup24:sbc addr+1 ; Lobyte
|
||||||
tay
|
tay
|
||||||
txa
|
txa
|
||||||
fixup23:sbc addr ; Hibyte
|
fixup25:sbc addr ; Hibyte
|
||||||
tax
|
tax
|
||||||
tya
|
tya
|
||||||
bcs :+
|
bcs :+
|
||||||
|
@ -436,7 +444,7 @@ rw_data:eor #$FF ; Two's complement part 1
|
||||||
|
|
||||||
; Read data
|
; Read data
|
||||||
:
|
:
|
||||||
fixup24:lda data
|
fixup26:lda data
|
||||||
sta (ptr),y
|
sta (ptr),y
|
||||||
iny
|
iny
|
||||||
bne :-
|
bne :-
|
||||||
|
@ -447,7 +455,7 @@ fixup24:lda data
|
||||||
|
|
||||||
; Write data
|
; Write data
|
||||||
: lda (ptr),y
|
: lda (ptr),y
|
||||||
fixup25:sta data
|
fixup27:sta data
|
||||||
iny
|
iny
|
||||||
bne :-
|
bne :-
|
||||||
inc ptr+1
|
inc ptr+1
|
||||||
|
|
Loading…
Add table
Reference in a new issue