💾 Archived View for gemini.spam.works › mirrors › textfiles › apple › DOCUMENTATION › x.mdmsend.s captured on 2020-10-31 at 20:49:12.

View Raw

More Information

-=-=-=-=-=-=-



 org $9e00           ;the freespace for use commands in Macos


  Getnxt equ $380    ;get next byte from the program
Goblcomm equ $386    ;engulf the comma
 Mdmslot equ $e00    ;where Macos keeps the modem slot*16
    ASnd equ $c088   ;the base of the ACTA send byte
    ARcv equ ASnd    ;the base of the ACTA recieve byte
   Stats equ $c089   ;the base of the SSC status byte
 IntPage equ $bf80   ;the interrupt vectors in ProDOS
     MLI equ $bf00   ;the ProDOS Machine Language Interface



SetInt ldx #$00      ;set-up offset into buffer and interrupt page
:loop lda IntPage,x  ;get the byte from the ProDOS page
 sta buffr1,x        ;put it right into the buffer
 inx                 ;up the pointer
 lda IntPage,x       ;get the next 1
 sta buffr1,x        ;and store it
:done jsr MLI        ;call the ProDOS MLI and ask it to...
:Deal_Int hex 41     ;deallocate interrupt
 da :parms           ;the address of the parameters is ':parms'
 JMP Send            ;yes, we can start sending to the modem
:parms hex 0101      ;1 parameter, ref. number 1
buffr1 ds 8          ;8 bytes to store the old interrupt vecotrs



Send jsr Goblcomm    ;who needs the comma?
 ldx Mdmslot         ;load with offset to slot number
:loop jsr Getnxt     ;get the next char. from the program
 sta ARcv,x          ;send the char. to the modem
 pha                 ;store off the char. that was sent
:subloop lda Stats,x ;get the status from the SSC
 and #%00010000      ;turn off all bits except bit 4 (value 8)
 bne :doneloop       ;if we're done, go on...
 beq :subloop        ;otherwise, keep checking
:doneloop pla        ;get the character sent
 ora #%10000000      ;turn on bit 7
 cmp #$8d            ;is it return?
 beq checkrsp        ;it is, start waiting for response from modem
 bne :loop           ;it's not, well kepp looping the chars.



checkrsp ldx #$0     ;set offset to zero
loop lda buffr2,x    ;get the last-known byte
 cmp #$8d            ;is it return?
 beq search          ;yes, whoopy! start the search
 bne loop            ;no, then keep checking always....
IntHndlr cld         ;yeah, we'll take the interrupt
 sei                 ;so we don't lose any interrupts
 ldx Mdmslot         ;load modem slot offset
 lda Stats,x         ;check to see if it was from the modem
 and #%00001000      ;kill everything except the 'sent' bit
 beq :not            ;if we don't have it, exit neatly...
 lda ARcv,x          ;get the byte sent by the modem
 ora #%10000000      ;turn the high-bit on...
 sta buffr2,x        ;store the byte in the buffer....
 inx
 cli                 ;it's been ushered off to the buffer
 clc                 ;there wasn't an error
 rts                 ;go into the middle of that loop.
:not sec             ;not our interrupt
 cli                 ;so interrupts are off
 rts                 ;and return
buffr2 ds 32         ;32 bytes of buffer space (more than adequate)



search jsr Deall     ;clear interrupt,so Macos doesn't maiss anything
 ldy #$00            ;set offset into the damn string
 sty $03             ;store the initial id as zero
 lda #>table         ;the high-byte of the start addr. of the table
 sta $00             ;the high byte is there, forever
 lda #<table         ;the low-byte of the start addr. of the table
 sta $01             ;the low-byte is there, forever
loop2 lda ($00),y    ;get the byte from the table
 pha                 ;put it on the stack
 lda buffr2,x        ;get the char. to compare
 sta $02             ;the place to compare
 pla                 ;get that last char. back
 cmp $02             ;compare it.....
 bne doneloop        ;no, than take care o' it...
:incrmnt lda ($00),y ;get the char. back
 ora #$00            ;run a generic operation to set flags
 bmi found           ;if it's MSB is 1, we got ourselves a winner...
 inx                 ;otherwise, we keep on checking
 jmp loop2
doneloop ldx #$00    ;reset the comparison counter to 0
:loop lda ($00),y    ;get the byte
 ora #$00            ;dummy flag-setter
 bmi setit           ;if it's negative, we found next adr.
 jsr upzer           ;otherwise, keep looking
 jmp :loop           ;go do the loop again
setit jsr upzer      ;up one more byte
 inc $03             ;up the id counter
 lda $03             ;make sure we're not done....
 cmp #$1c            ;is it done
 beq error           ;yes, we have a problem
 jmp loop2           ;otherwise, yall can continue looping
upzer inc $01        ;up the low-byte
 pha                 ;save the a-register
 lda $01             ;get that low-byte
 beq :uphi           ;if it's zero, go ahead and up the low-byte
 rts                 ;otherwise, go back young man..
:uphi inc $00        ;up the low-byte
 rts                 ;and return

error ldx #$08       ;Missing Data Error
 jmp $392            ;that's it..I'm outa here

found lda $03        ;get the id
 sta $0a             ;put in it's place
 rts                 ;I'm done
Deall lda buffr1     ;get the low-byte of the addr
 sta All:Parms+1     ;move it back...
 lda buffr1+1        ;get the high-byte
 sta All:Parms+2     ;store it back
 jsr $bf00           ;re-install the interrupt handler
 dfb $40             ;allocate interrupt
 da All:Parms        ;the address of All:Parms
 rts                 ;now, we're done
All:Parms dfb $01    ;1 paramter
 ds 3                ;the addr. of Macos's  routine, pluse 1 byte
 rts                 ;and I'm outa here
table dci 'OK'
 DCI 'CONNECT 300'
 DCI 'RING'
 DCI 'NO CARRIER'
 DCI 'ERROR'
 DCI 'CONNECT 1200'
 DCI 'NO DIALTONE'
 DCI 'BUSY'
 DCI 'NO ANSWER'
 DCI 'UNKOWN'
 DCI 'CONNECT 2400'
 DCI 'VOICE'
 DCI 'CONNECT 9600'
 DCI 'CONNECT 9600/ARQ'
 DCI 'CONNECT 1200/ARQ'
 DCI 'CONNECT 2400/ARQ'
 DCI 'CONNECT 9600/ARQ'
 DCI 'CONNECT 4800'
 DCI 'CONNECT 4800/ARQ'
 DCI 'CONNECT 7200'
 DCI 'CONNECT 12000'
 DCI 'CONNECT 7200/ARQ'
 DCI 'CONNECT 12000/ARQ'
 DCI 'CONNECT 14400'
 DCI 'CONNECT 14400/ARQ'
 DCI 'CONNECT 16800'
 DCI 'CONNECT 16800/ARQ'

 sav /blank/x.call