Trailing-Edge
-
PDP-10 Archives
-
BB-X140B-BB_1986
-
10,7/703anf/dncddq.p11
There are 3 other files named dncddq.p11 in the archive. Click here to see a list.
.SBTTL DNCDDQ - DQ11 SYNCHRONOUS LINE INTERFACE 28 MAR 79
;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
; OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.
;
;COPYRIGHT (C) 1976,1977,1978.1979,1980,1981,1984 BY DIGITAL EQUIPMENT CORP., MAYNARD, MASS.
VRCDDQ=005 ;FILE EDIT NUMBER
.IF NE DQN ;IF SYNCHRONOUS LINES PRESENT, AND THEY HAVE DQ11S
.IF NE FTDQ11
;HERE TO INITIALIZE A DQ11 LINE
;HERE TO RESET THE DQ11 LINE
DQDINI:
; MOV LB.SLA(J),DQ ;GET DQ11 HDW ADR
DQREGS MSC ;SELECT MISC REGISTER
MOV #DQ.MC,6(DQ) ;MASTER CLEAR THE DQ11
DQREGS MSC ;SELECT MISC REGISTER
MOV #DQ.MC,6(DQ) ;MASTER CLEAR THE DQ11
;DQREGS SRC ;SECONDARY RECEIVE COUNT
;CLR 6(DQ) ;CLEAR BYTE COUNT
DQREGS MSC ;SELECT MISC REGISTER
MOV #10*400,6(DQ) ;SET 8 BIT CHARS
DQREGS SYN ;SELECT SYNC REGISTER
MOV #SYN*401,6(DQ)
MOV #DQ.RIE,@DQ ;SET INTERRUPT ENABLES
DQ.IDL=2 ;FLAG TO MAKE XMITTER IDLE SYNCHS
DQ.BIE=DQ.EIE+DQ.DIE+DQ.XIE ;FLAGS TO ENABLE VECTOR B INTERRUPTS
MOV #DQ.BIE+DQ.DTR+DQ.IDL,2(DQ)
TRACE DQ
RTS PC
;HERE TO ENABLE DQ11 RECEIVER
DQRBEG: BIS #LS..RG,@J ;FLAG RECEIVER HAS BEEN ENABLED
MOV LB.SLA(J),DQ ;GET DQ11 HDW ADR
MOV LB.IPT(J),R0 ;GET RELATIVE INPUT BUFFER ADDRESS
ADD J,R0 ;MAKE INPUT BUFFER ADR ABS
; SLR (DQ)
; SLR R0
; SLR #52525
BIT #DQ.SEC,@DQ ;PRIMARY/2NDARY NEXT ?
BNE 20$ ;BRANCH FOR 2NDARY
DQREGS PRA ;SELECT PRIMARY RCV ADR REG
BR 22$
20$: DQREGS SRA ;SELECT 2NDARY RCV ADR REG
22$: MOV R0,6(DQ)
INCB 5(DQ) ;ADVANCE TO COUNT REG
MOV #-4,6(DQ) ;SET LENGTH
BITB #4,5(DQ) ;PRIMARY/2NDARY ?
BEQ 30$
DQREGS PRA ;SELECT PRIMARY RCV ADR REG
BR 32$
30$: DQREGS SRA ;SELECT 2NDARY RCV ADR REG
32$: ADD #4,R0 ;POINT TO 2ND HALF OF HEADER
MOV R0,6(DQ)
INCB 5(DQ) ;SELECT COUNT REG
MOV #-4,6(DQ) ;SET LENGTH
MOV #DDRJNK,LB.RDN(J) ;WHERE TO GO WHEN HAVE RECEIVED MSG
BIC #DQ.RAC!DQ.RGO,(DQ) ;BE SURE THE RECEIVER IS STOPPED
BIS #DQ.RGO,@DQ ;SET RECEIVER GOING
BIC #LS.SSY,(J) ;RESET REQUEST STRIP SYNCH FLAG
RTS PC
;HERE TO ENABLE TRANSMITTER
; MUST BE CALLED WITH INTERRUPTS DISABLED
; CALL: MOV <BLK ADR>,J
; JSR PC,DQXBEG
DQXBEG: MOV LB.SLA(J),DQ ;GET DQ11 HDW ADR
TRACE DQ ;FOR THOSE WHO FOLLOW HDW
ASSERT #4*40 SET IN PS ;CHECK PROCESSOR LEVEL
ASSERT #DQ.XGO CLEAR IN 2(DQ) ;IS DQ ALREADY RUNNING ?
;DQ11 NOT GOING SO START BY JAMING OUT SOME SYNCHS
30$: BIT #DQ.SEC,2(DQ) ;CHECK PRIMARY/2NDARY BIT
BEQ 40$ ;BRANCH TO SET UP PRIMARY
DQREGS STA ;ADDRESS 2NDARY TRANS ADR REG
BR 45$
40$: DQREGS PTA ;ADDRESS PRIMARY TRANS ADR REG
45$: MOV #SYNCHS,6(DQ) ;SET PRIMARY TRANSMIT ADDRESS
INCB 5(DQ) ;ADDRESS TRANS COUNT REG
MOV #-FTNSYN,6(DQ) ;SET TRANSMIT COUNT
JSR PC,@LB.XDN(J) ;GET WHAT TO SEND NEXT
TRACE DQ
BIT #DQ.SEC,2(DQ) ;CHECK PRIMARY/2NDARY BIT AGAIN
BEQ 50$
DQREGS PTA ;ADDRESS PRIMARY TRANS ADR REG
BR 55$
50$: DQREGS STA ;ADDRESS 2NDARY TRANS ADR REG
55$: MOV R0,6(DQ) ;SET ADDRESS OF BUFFER
INCB 5(DQ) ;ADDRESS BYTE COUNT REG
MOV R1,6(DQ) ;SET BUFFER LENGTH
BIS #DQ.DTR+DQ.RTS+DQ.IDL,2(DQ) ;ENABLE TRANSMITTER
BIT #DQ.CTS,2(DQ) ;IF MODEM SAYS CLEAR TO SEND
BEQ .+10
BIS #DQ.XGO,2(DQ) ;START THE XMISSION
BIS #LS..XG,@J ;SET FLAG XMITTER IS GOING
RTS PC
.MACRO X Q
DQVA'Q:
DQA.'Q: SAVE <J>
MOV #FLBDQ+<LB.SIZ*'Q>,J
.ENDM X
Z=DQN-1
.REPT DQN
X \Z
.IIF NE Z,BR DQAINT
Z=Z-1
.ENDR
;DQ11 VECTOR A INTERRUPT - RECEIVER
DQAINT: SAVE <DQ,R0,R1,R2>
MOV LB.SLA(J),DQ ;GET DQ11 HDW ADR
; SLR @DQ
; SLR @J
; SLR LB.RDN(J)
; BIC #DQ.SSY,@DQ ;IF SOMETHING HAPPENED,
;BETTER STOP STRIPPING SYNCHS
;SHOULDN'T HAVE BEEN SET IN THE FIRST
;PLACE - WE'RE NOT IN TRANSPARENT MODE
DQA.I0:
BIT #DQ.RDP+DQ.RDS,@DQ ;IF NO END OF BUF, TEST DSR
BEQ 20$
BIT #LS.SSY,@J ;WANT TO STRIP SYNCH AGAIN ?
BEQ 5$
BIC #DQ.RAC,@DQ ;STOP STUFFING BUFFER, AND
BIS #DQ.RGO,@DQ ;TO STRIP SYNCHS AGAIN, BE SURE TO SET GO
BIC #LS.SSY,@J ;CLEAR FLAG
5$: MOV @DQ,R0 ;GET RECEIVER STATUS REGISTER
ROLB R0
BCS 10$ ;BRANCH IF PRIMARY FINISHED
DQREGS SRA ;ADDRESS 2NDARY BUFFER
BR 12$
10$: BMI 16$ ;STOP RECEIVER IF BOTH FINISHED
DQREGS PRA ;ADDRESS PRIMARY RCV BUF ADR REG
12$: JSR PC,@LB.RDN(J) ;DISPATCH TO RIGHT ROUTINE
; SLR @DQ
; SLR R1
; SLR R0
TRACE DQ
MOV R0,6(DQ) ;SET RCV BUF ADR REG
BIS #<DQ.MBM+1>*400,4(DQ) ;ADVANCE TO COUNT REG
MOV R1,6(DQ) ;SET COUNT REG
BEQ 16$ ;IF COUNT IS ZERO HALT RECEIVER
MOV #DQ.RDP,R0 ;BIT TO CLEAR FLAG
BIT #4*400,4(DQ) ;WAS THAT PRIMARY/2NDARY
BEQ 14$
ASR R0 ;BIT TO CLEAR 2NDARY FLAG
14$: BIC R0,@DQ ;CLEAR FLAG
BIT #DQ.RGO,@DQ ;RECEIVER STILL RUNNING ?
BEQ 15$
BR DQA.I0 ;IF STILL RUNNING, SEE IF WE
;CAN STILL BE OF SERVICE
15$:
TWIDDLE ;COUNT TIMES GO DROPPED
;HERE BECAUSE NEED TO STOP RECEIVER
16$:
; SLR @DQ
; SLR R1
; SLR #0
BIC #DQ.RKL!DQ.RDP!DQ.RDS,@DQ ;STOP RECEIVER
BIC #LS..RG,@J ;CLEAR RECEIVE ACTIVE FLAG
QUEPUT QI 89$
JSR PC,DDCIGO
51$: RESTORE <R2,R1,R0,DQ,J>
RTI
;HERE WHEN HAVE CLEARED ALL INTERRUPTING CONDITIONS
20$: BIT #DQ.DSR,2(DQ) ;IF NOT DATA SET READY,
BNE 51$ ;BETTER STOP THE RECEIVER
BR 16$
;DQ11 VECTOR B INTERRUPT PROCESSING
.MACRO X Q
DQVB'Q:
DQB.'Q: SAVE <J>
MOV #FLBDQ+<LB.SIZ*'Q>,J
.ENDM X
Z=DQN-1
.REPT DQN
X \Z
.IIF NE Z,BR DQBINT
Z=Z-1
.ENDR
;VECTOR B INTERRUPT FOR DQ11 - TRANSMIT OR DATASET CONTROL
DQBINT: SAVE <DQ,R0,R1,R2>
MOV LB.SLA(J),DQ ;GET DQ11 HDW ADR
DQB.I0: TRACE DQ
MOV @DQ,R0
MOV 2(DQ),R1 ;GET TRANSMIT STATUS WORD
TST 4(DQ) ;CHECK FOR ERROR BIT
BMI 40$
BIT #DQ.XDP+DQ.XDS,R1 ;CHECK FOR TRANSMIT DONE
BEQ 20$ ;BRANCH IF NOT XMT-DONE
BIT #DQ.XDP,R1 ;JUST FIN PRIMARY TRANS BUF ?
BEQ 10$ ; BRANCH ON 2NDARY
BIT #DQ.XDS,R1
BNE 17$ ;IF BOTH WENT OFF STOP TRANSMITTER
DQREGS PTA ;ADDRESS PRIMARY TRANS BUF ADR REG
BR 12$
10$: DQREGS STA ;ADDRESS 2NDARY TRANS BUF ADR REG
12$:
.IF NE 0 ;NOT READY TO TRY THIS NOW
CMP #DDCI20,LB.XDN(J) ;IF IDLING, USE HDW IDLE FEATURE
BNE 13$
BIS #DQ.IDL,2(DQ)
BR 18$
.ENDC
13$:
JSR PC,@LB.XDN(J) ;GET WHAT TO PUT IN THE OTHER BUFFER
TRACE DQ
MOV R0,6(DQ) ;SET UP ADR REG
INCB 5(DQ) ;ADVANCE TO COUNT REG
MOV R1,6(DQ) ;SET COUNT REGISTER
BEQ 17$ ;IN CASE NEED TO STOP IT
MOV #DQ.XDP,R0 ;BIT TO CLEAR FLAG
BITB #4,5(DQ) ;WERE WE SETTING PRIMARY ?
BEQ 15$ ;AND BRANCH IF SO
MOV #DQ.XDS,R0 ;BIT TO CLEAR FLAG
15$: BIC R0,2(DQ) ;CLEAR FLAG
BIT #DQ.XGO,2(DQ) ;WERE WE TOO SLOW FOR TRANSMITER ?
BNE DQB.I0 ;CHECK FOR MORE THINGS TO DO
BR 17$ ;EXECUTE STOP ROUTINE
;HERE BECAUSE NOT TRANSMIT DONE INTERRUPT
20$: BIT #DQ.DSF,R1 ;DID WE WIN A DATASET FLAG ?
BNE 30$ ;BRANCH IF SO
25$: RESTORE <R2,R1,R0,DQ,J>
RTI
;HERE ON A DATASET INTERRUPT
30$: BIC #DQ.DSF,2(DQ) ;CLEAR DATASET FLAG
BIT #DQ.CTS,2(DQ) ;DID CLEAR TO SEND COME UP ?
BEQ 31$
BIT #LS..XG,(J) ;IF BUFFERS INITIALIZED
BEQ .+10
BIS #DQ.XGO,2(DQ) ;START TRANSMITTER
BR DQB.I0 ;CHECK FOR MORE INTERESTING THINGS
31$: BIT #LS..XG,(J) ;IF XMMITTER WAS GOING
BNE 17$ ;ITS STOPPED NOW
BR DQB.I0 ;CHECK FOR MORE INTERESTING THINGS
;HERE ON AN ERROR INTERRUPT
40$:
.IIF EQ FT.SLB, INC LB.SLE(J) ;COUNT ERROR INTERRUPTS
MOV 4(DQ),R0 ;GET ERROR STATUS
.IIF EQ FT.SLB, MOV R0,LB.SLE+2(J) ;SAVE ERROR BITS
BIT #DQ.RNX!DQ.XNX,R0 ;NON EX MEM ?
BEQ .+4
STOPCD NXM
BIT #DQ.RCL!DQ.RLE!DQ.RNX,R0 ;RECEIVER ERROR ?
BEQ 42$
BIC #DQ.RDS!DQ.RDP!DQ.RKL,@DQ ;STOP RECEIVER
BIC #DQ.RCL!DQ.RLE!DQ.RNX,4(DQ) ;CLEAR FLAG
BIC #LS..RG,@J ;CLEAR RECEIVER ACTIVE FLAG
QUEPUT QI 87$
BR DQB.I0
42$:
.IF NE FTASRT
BIT #DQ.XCL!DQ.XLE!DQ.XNX,R0 ;WAS IT A TRANSMIT ERROR ?
ASSERT NE ;ZAPPED IF NOT
.ENDC
;HERE TO STOP THE DQ11 TRANSMITTER
17$:
; BIC #DQ.RTS,2(DQ) ;CLEAR REQUEST TO SEND
18$: BIC #DQ.XDP+DQ.XDS+DQ.XGO,2(DQ) ;CLEAR & STOP XMITTER
BIC #DQ.XCL!DQ.XLE!DQ.XNX,4(DQ) ;CLEAR ERRORS IF ANY
BIC #LS.XCT!LS.XDT!LS..XG,@J ;FLAG WE STOPPED THE TRANSMITTER
QUEPUT QO 86$
JMP DQB.I0
.ENDC ;.IF NE FTDQ11
.ENDC ;.IF NE DQN