Trailing-Edge
-
PDP-10 Archives
-
bb-bt99r-bb
-
nebanf.x24
There are no other files named nebanf.x24 in the archive.
TITLE NEBANF - ANF-10 I/O driver for the Network Queue Controller
SUBTTL D. P. Mastrovito & Joseph A. Dziedzic /DPM/JAD
;
;
; COPYRIGHT (c) DIGITAL EQUIPMENT CORPORATION
; 1986.
; ALL RIGHTS RESERVED.
;
;
; THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED
; AND COPIED ONLY IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE
; AND WITH THE INCLUSION OF THE ABOVE COPYRIGHT NOTICE. THIS
; SOFTWARE OR ANY OTHER COPIES THEREOF MAY NOT BE PROVIDED OR
; OTHERWISE MADE AVAILABLE TO ANY OTHER PERSON. NO TITLE TO
; AND OWNERSHIP OF THE SOFTWARE IS HEREBY TRANSFERRED.
;
; THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE
; WITHOUT NOTICE AND SHOULD NOT BE CONSTRUED AS A COMMITMENT
; BY DIGITAL EQUIPMENT CORPORATION.
;
; DIGITAL ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY
; OF ITS SOFTWARE ON EQUIPMENT WHICH IS NOT SUPPLIED BY
; DIGITAL.
SEARCH NEBPRM
MODULE (NEBANF)
IOVEC (ANF,<ANF-10>)
SUBTTL ANF-10 I/O driver -- Definitions and parameters
ANFLVL==0 ;INTERRUPT PRIORITY LEVEL
NPDLEN==10 ;LENGTH OF AN NPD
SUBTTL ANF-10 I/O driver -- ANFINI - Initialization
ANFINI: JRST .POPJ1 ;RETURN
SUBTTL ANF-10 I/O driver -- ANFINF - Return information about a node
ANFINF: MOVEI S2,2 ;TWO WORD ARGUMENT BLOCK
EXCH S1,S2 ;SWAP
MOVE TF,[.NDRNN,,S1] ;SET UP UUO AC
NODE. TF, ;SEE IF NODE IS ONLINE
POPJ P, ;NON-EXISTANT OR OFFLINE
JRST .POPJ1 ;RETURN
SUBTTL ANF-10 I/O driver -- ANFOPN - Open connection
ANFOPN: MOVE S1,[FO.ASC+.FOSIO] ;ASSIGN CHANNEL, OPEN FOR I/O
MOVEM S1,.JNARG+.FOFNC(R)
MOVE S1,[UU.PHS!UU.AIO+.IOBYT] ;PHYSICAL, ASYNCH + BYTE MODE
MOVEM S1,.JNARG+.FOIOS(R)
MOVSI S1,'TSK' ;DEVICE NAME
MOVEM S1,.JNARG+.FODEV(R)
MOVSI S1,.JIOBR(R) ;RING HEADER FOR OUTPUT
HRRI S1,.JIIBR(R) ;RING HEADER FOR INPUT
MOVEM S1,.JNARG+.FOBRH(R)
SETZM .JNARG+.FONBF(R) ;WILL BUILD OUR OWN BUFFERS
MOVSI S1,.FONBF+1 ;WORD COUNT
HRRI S1,.JNARG(R) ;ARG BLOCK
FILOP. S1, ;OPEN DEVICE
HALT .
LDB S1,[POINTR (.JNARG+.FOFNC(R),FO.CHN)] ;GET CHANNEL NUMBER
MOVEM S1,.JNIOC(R) ;SAVE
MOVEM S1,.JNARG+.PSECN(R) ;SAVE AS PSI CONDITION
PUSHJ P,PSIAVJ## ;ALLOCATE PSI VECTOR
JSP S2,VECERR ;NONE AVAILABLE
MOVEM S1,.JBPSI(R) ;SAVE ADDRESS
PUSH P,S2 ;SAVE OFFSET
MOVEI S2,ANFINT ;INTERRUPTS WILL GO HERE
HRRM S2,.JBPSR+2(R)
MOVEM S2,.PSVNP(S1) ;POINT MONITOR IN RIGHT DIRECTION
POP P,S2 ;RESTORE OFFSET
HRRI S2,PS.RID!PS.ROD!PS.RIE!PS.ROE!PS.ROL ;LOTS OF GOOD BITS
MOVEM S2,.JNARG+.PSEOR(R) ;SAVE OFFSET,,REASON BITS
MOVSI S1,ANFLVL ;INTERRUPT PRIORITY LEVEL
MOVEM S1,.JNARG+.PSEPR(R) ;SAVE
MOVX S1,PS.FAC ;BIT TO ADD CONDITION
HRRI S1,.JNARG(R) ;ADDRESS OF ARGUMENT BLOCK
PISYS. S1, ;PUT CHANNEL ON PSI SYSTEM
JSP S2,ANFOPE ;FAILED
MOVEI S1,ANFOPA ;ASSUME ACTIVE TASK
MOVE S2,.JBNOD(R) ;GET NODE NAME/NUMBER
CAMN S2,[SIXBIT/*/] ;PASSIVE CONNECT?
MOVEI S1,ANFOPP ;YES
PUSHJ P,(S1) ;DO SPECIFIC SETUP
MOVEI S1,.TKFEA ;FUNCTION CODE
MOVEM S1,.JNARG+.TKAFN(R)
MOVE S1,.JNIOC(R) ;I/O CHANNEL
MOVEM S1,.JNARG+.TKACH(R)
MOVE S1,[NPDLEN,,NPDLCL] ;LOCAL NPD
MOVEM S1,.JNARG+.TKAA1(R)
MOVE S1,[NPDLEN,,NPDRMT] ;REMOTE NPD
MOVEM S1,.JNARG+.TKAA2(R)
MOVSI S1,4 ;ARGUMENT BLOCK LENGTH
HRRI S1,.JNARG(R) ;ARGUMENT BLOCK ADDRESS
TSK. S1, ;SEND/WAIT FOR CONNECT INITIATE
JSP S2,.+2 ;FAILED
JRST .POPJ1 ;RETURN
PUSHJ P,TSKERR ;REPORT ERROR
PJRST ANFZAP ;CLEAN UP AND RETURN
;SETUP ACTIVE TASK
ANFOPA: MOVEI S1,NPDLCL ;SELECT LOCAL NPD
PUSHJ P,NPDINI ;INIT STORAGE
$TEXT (NPDBYT,<^W/G$PGM/-^D/.JQOBJ+OBJ.UN(R)/^A>)
MOVEI S1,NPDRMT ;SELECT REMOTE NPD
PUSHJ P,NPDINI ;INIT STORAGE
$TEXT (NPDBYT,<^T/G$NAM/^A>)
MOVE S1,.JBNOD(R) ;REMOTE NODE NAME/NUMBER
MOVEM S1,NPDRMT+.TKNND
POPJ P, ;RETURN
;SETUP PASSIVE TASK
ANFOPP: MOVEI NPDLCL ;SELECT LOCAL NPD
PUSHJ P,NPDINI ;INIT STORAGE
SETZM NPDLCL+.TKNND ;IGNORE LOCAL NPD
MOVEI S1,NPDRMT ;SELECT REMOTE NPD
PUSHJ P,NPDINI ;INIT STORAGE
$TEXT (NPDBYT,<^T/G$NAM/^A>)
POPJ P, ;RETURN
ANFOPE: PUSHJ P,UUOERR## ;REPORT UUO ERROR
ANFZAP: MOVE S1,.JNIOC(R) ;CHANNEL NUMBER
RESDV. S1, ;RESET IT (REALLY SAME AS RELEASE)
JFCL ;IGNORE ERRORS
SETZB S1,.JNIOC(R) ;ZERO OUT CHANNEL
EXCH S1,.JBPSI(R) ;FETCH AND CLEAR OUT PSI VECTOR ADDRESS
SKIPN S1 ;HAVE A VECTOR?
SETZM (S1) ;RECYCLE
POPJ P, ;RETURN
SUBTTL ANF-10 I/O driver -- ANFCLS - Close connection
ANFCLS: HALT .
SUBTTL ANF-10 I/O driver -- ANFINP - Input a buffer
ANFINP: MOVEI S1,.TKFIN ;FUNCTION CODE
MOVEM S1,.JNARG+.TKAFN(R)
MOVE S1,.JNIOC(R) ;CHANNEL NUMBER
MOVEM S1,.JNARG+.TKACH(R)
SETZM .JNARG+.TKAA1(R) ;INCASE OF ERROR RETURN
MOVSI S1,3 ;WORD COUNT
HRRI S1,.JNARG(R) ;ARG BLOCK
SETZ S2, ;ASSUME NO ERRORS WILL HAPPEN
SCDSET (.WSINP,0) ;SET SCHEDULER PARAMETERS
TSK. S1, ;INPUT DATA
MOVEI S2,.+1 ;SETUP FOR ERROR REPORTING
PUSHJ P,RDSTAT ;READ STATUS
JUMPE S2,ANFIN2 ;CHECK FOR ERRORS
CAIN S1,TKUDW% ;I/O ERROR?
JRST ANFIN1 ;YES
PUSHJ P,TSKERR ;REPORT UUO ERROR
PJRST ANFABO ;GO ABORT THE LINK
ANFIN1: MOVE S1,.JNIOS(R) ;GET I/O STATUS
TRNE S1,IO.EOF ;UNEXPECTED EOF?
HALT .
TRNE S1,IO.ERR ;ANY ERROR BITS ON?
JRST ANFIN3 ;YES
PUSHJ P,WSCHED## ;WAIT FOR OUTPUT TO COMPLETE
ANFIN2: AOS (P) ;SET FOR SKIP RETURN
PJRST INIOBF## ;RE-INITIALIZE OUTPUT BUFFER
ANFIN3: SCDSET (.WSRUN,0) ;UNDO THE DAMAGE
TRC S1,IO.ERR ;REAL I/O ERROR
TRCN S1,IO.ERR ;ALL ERROR BITS LIT?
PJRST ANFABO ;YES--GO ABORT THE LINK
MOVEI S1,IO.ERR ;MASK OF ALL ERROR BITS
ANDCAM S1,.JNIOS(R) ;CLEAR THEM
PUSHJ P,WTSTAT ;WRITE NEW CHANNEL STATUS
JRST ANFINP ;GO RETRY THE INPUT
SUBTTL ANF-10 I/O driver -- ANFOUT - Output a buffer
ANFOUT: MOVEI S1,.TKFOT ;FUNCTION CODE
MOVEM S1,.JNARG+.TKAFN(R)
MOVE S1,.JNIOC(R) ;CHANNEL NUMBER
MOVEM S1,.JNARG+.TKACH(R)
SETZM .JNARG+.TKAA1(R) ;INCASE OF ERROR RETURN
MOVSI S1,3 ;WORD COUNT
HRRI S1,.JNARG(R) ;ARG BLOCK
SETZ S2, ;ASSUME NO ERRORS WILL HAPPEN
SCDSET (.WSOUT,0) ;SET SCHEDULER PARAMETERS
TSK. S1, ;OUTPUT DATA
MOVEI S2,.+1 ;SETUP FOR ERROR REPORTING
PUSHJ P,RDSTAT ;READ STATUS
JUMPE S2,ANFOU2 ;CHECK FOR ERRORS
CAIN S1,TKUDW% ;I/O ERROR?
JRST ANFOU1 ;YES
PUSHJ P,TSKERR ;REPORT UUO ERROR
PJRST ANFABO ;GO ABORT THE LINK
ANFOU1: MOVE S1,.JNIOS(R) ;GET I/O STATUS
TRNN S1,IO.EOF ;OUTPUT BUFFERS FULL?
JRST ANFOU3 ;NO
PUSHJ P,WSCHED## ;WAIT FOR OUTPUT TO COMPLETE
ANFOU2: AOS (P) ;SET FOR SKIP RETURN
PJRST INIOBF## ;RE-INITIALIZE OUTPUT BUFFER
ANFOU3: SCDSET (.WSRUN,0) ;UNDO THE DAMAGE
TRC S1,IO.ERR ;REAL I/O ERROR
TRCN S1,IO.ERR ;ALL ERROR BITS LIT?
PJRST ANFABO ;YES--GO ABORT THE LINK
MOVEI S1,IO.ERR ;MASK OF ALL ERROR BITS
ANDCAM S1,.JNIOS(R) ;CLEAR THEM
PUSHJ P,WTSTAT ;WRITE NEW CHANNEL STATUS
JRST ANFOUT ;GO RETRY THE OUTPUT
SUBTTL ANF-10 I/O driver -- Abort a link
ANFABO: PUSHJ P,RDSTAT ;READ LINK STATUS
HLRZS S1 ;WAIT ONLY LINK STATUS
CAIN S1,.TKSID ;IDLE?
POPJ P, ;DONE
CAIE S1,.TKSCC ;WAITING FOR CONNECT CONFIRM?
CAIN S1,.TKSDC ;WAITING FOR DISCONNECT CONFIRM?
HALT .
CAIE S1,.TKSCI ;WAITING FOR CONNECT INITIATE?
CAIN S1,.TKSOK ;LINK RUNNING?
SKIPA
HALT .
MOVEI S1,.TKFEI ;FUNCTION CODE
MOVEM S1,.JNARG+.TKAFN(R)
MOVE S1,.JNIOC(R) ;CHANNEL NUMBER
MOVEM S1,.JNARG+.TKACH(R)
MOVSI S1,2 ;WORD COUNT
HRRI S1,.JNARG(R) ;ARG BLOCK
TSK. S1, ;FORCE LINK INTO IDLE STATE
JSP S2,TSKERR ;FAILED
POPJ P, ;RETURN
SUBTTL ANF-10 I/O driver -- ANFSIA - Skip if input data available
ANFSIA: HALT . ;NOT YET
SUBTTL ANF-10 I/O driver -- ANFUUE - UUO error translation table
ANFUUE: UUO (<TSK.>,TSKL,TSKT)
EXP 0 ;TERMINATE TABLE
TSKT: TKTNL%,,[ASCIZ /task to task not supported/]
TKATS%,,[ASCIZ /Argument list too short/]
TKUNP%,,[ASCIZ /User is not privileged/]
TKILF%,,[ASCIZ /Illegal function/]
TKILC%,,[ASCIZ /Illegal channel/]
TKILN%,,[ASCIZ /Illegal NPD/]
TKNTS%,,[ASCIZ /NPD too short/]
TKILS%,,[ASCIZ /Function is illegal in this state/]
TKNFC%,,[ASCIZ /Not enough monitor free-core/]
TKNFL%,,[ASCIZ /No free links/]
TKNXN%,,[ASCIZ / non-existant node/]
TKUDW%,,[ASCIZ /IN or OUT UUO (.TKFOT OR .TKFIN) didn't skip/]
TSKL==.-TSKT
SUBTTL Subroutines -- ANF-10 software interrupt
ANFINT: MOVE P1,.JBPSI(R) ;POINT TO VECTOR
MOVE S1,.PSVIS(P1) ;GET INTERRUPT STATUS WORD
HRRM S1,.JNIOS(R) ;SAVE FOR POSTERITY
PUSHJ P,RDLINK ;READ LINK STATUS
MOVE S1,.JNIOS(R) ;GET STATUS
MOVE S2,.JBWSC(R) ;GET STREAM WAIT STATE CODE
PUSHJ P,@WSCHK(S2) ;DO SOMETHING
MOVEM S2,.JBWSC(R) ;UPDATE WAIT STATE
$DEBRK ;DISMISS INTERRUPT
DEFINE X (NAM,TXT),<IFIW NAM'CHK>
WSCHK: WSTATE
;WAITING FOR CONNECT CONFIRM
WCCCHK: PUSHJ P,RUNCHK ;CHECK FOR LINK GOING DOWN
CAIN S1,.TKSOK ;LINK CONNECTED?
PJRST RUNJOB ;MAKE RUNNABLE
POPJ P, ;RETURN
;WAITING FOR REMOTE CONNECT
WRCCHK: PUSHJ P,RUNCHK ;CHECK FOR LINK GOING DOWN
CAIN S1,.TKSOK ;LINK CONNECTED?
PJRST RUNJOB ;MAKE RUNNABLE
POPJ P, ;RETURN
;WAITING FOR DISCONNECT CONFIRM
WDCCHK: CAIN S1,.TKSID ;IDLE?
PJRST RUNJOB ;MAKE RUNNABLE
POPJ P, ;RETURN
;WAITING FOR OUTPUT DONE
OUTCHK: TRNN S1,PS.ROD ;OUTPUT DONE?
;WAITING FOR INPUT DONE
INPCHK: TRNE S1,PS.RID ;INPUT DONE?
MOVEI S2,.WSRUN ;MAKE RUNNABLE
;STREAM RUNNING
RUNCHK: HLRZ S1,.JNIOS(R) ;GET LINK STATUS
CAIN S1,.TKSID ;LINK IDLE?
PJRST RUNABO ;NO, ERROR
POPJ P, ;NO PROBLEMS
;STREAM IDLE
IDLCHK: ;FALL INTO RUNABO
;STREAM PAUSED
PAUCHK: ;FALL INTO RUNABO
RUNABO: PUSHJ P,ABORTJ## ;QUEUE UP ABORT
RUNJOB: MOVEI S2,.WSRUN ;MAKE RUNNABLE
POPJ P, ;RETURN
SUBTTL Miscellaneous routines -- RDSTAT - Read link status
RDSTAT: PUSH P,S1 ;SAVE S1
PUSH P,S2 ;SAVE S2
MOVE S1,[1,,S2] ;SET UP UUO AC
HRLZ S2,.JNIOC(R) ;CHANNEL NUMBER
HRRI S2,.FOGET ;FUNCTION CODE
FILOP. S1, ;READ CHANNEL STATUS
HALT .
HRRM S1,.JNIOS(R) ;SAVE
PUSHJ P,RDLINK ;READ LINK STATUS
POP P,S2 ;RESTORE S2
POP P,S1 ;RESTORE S1
POPJ P, ;RETURN
RDLINK: MOVEI S1,.TKFRS ;FUNCTION CODE
MOVEM S1,.JNARG+.TKAFN(R)
MOVE S1,.JNIOC(R) ;CHANNEL NUMBER
MOVEM S1,.JNARG+.TKACH(R)
SETOM .JNARG+.TKAA1(R) ;NO MEANINGFUL DATA YET
MOVSI S1,3 ;WORD COUNT
HRRI S1,.JNARG(R) ;ARG BLOCK
MOVEI S2,.+2 ;INCASE OF ERROR
TSK. S1, ;READ LINK STATUS
PUSHJ P,TSKERR ;REPORT ERROR
MOVE S1,.JNARG+.TKAA1(R) ;GET LINK STATUS
HRLM S1,.JNIOS(R) ;SAVE
POPJ P, ;RETURN
SUBTTL Miscellaneous routines -- WTSTAT - Write channel status
WTSTAT: PUSH P,S1 ;SAVE S1
HRLZ S1,.JNIOC(R) ;CHANNEL NUMBER
HRRI S1,.FOSET ;FUNCTION CODE
MOVEM S1,.JNARG+.FOFNC(R)
MOVEI S1,IO.ERR ;MASK OF ALL ERROR BITS
ANDCAM S1,.JNIOS(R) ;CLEAR ERRORS, FETCH ALL BITS
HRRZM S1,.JNARG+.FOIOS(R)
MOVSI S1,2 ;WORD COUNT
HRRI S1,.JNARG(R) ;ARG BLOCK
FILOP. S1, ;SET CHANNEL STATUS
HALT .
POP P,S1 ;RESTORE S1
POPJ P, ;RETURN
SUBTTL ANF-10 I/O driver -- Error processing
VECERR: SUBI S2,2 ;POINT TO ACTUAL UUO
HRRZS S2 ;STRIP OFF PC FLAGS
PUSHJ P,JOBIDN## ;GENERATE IDENTIFYING TEXT
MOVE S1,.JNIOC(R) ;GET CHANNEL NUMBER
$WTO (<^T/G$NAM/ error>,<^T/.JBIDN(R)/^I/VECETX/>,.JQOBJ(R))
PJRST ANFZAP ;GO CLEANUP
VECETX: ITEXT (<No free PSI vectors for channel ^O/S1/ at PC ^O6R0/S2/>)
;TSK. UUO ERROS
TSKERR: PUSHJ P,UUOERR## ;GENERATE UUO ERROR TEXT
MOVE S2,.JNARG+.TKAFN(R) ;GET FUNCTION WORD
$WTO (<^T/G$NAM/ error>,<^T/.JBIDN(R)/^T/(S1)/^I/TSKETX/>,.JQOBJ(R))
POPJ P, ;RETURN
TSKETX: ITEXT (<UUO function word: ^O6R0/S2,LHMASK/,,^O6R0/S2,RHMASK/>)
NPDINI: MOVSI S2,0(S1) ;START ADDRESS
HRRI S2,1(S1) ;MAKE A BLT POINTER
SETZM (S1) ;CLEAR FIRST WORD
BLT S2,NPDLEN-1(S1) ;CLEAR ENTIRE NPD
SETOM .TKNND(S1) ;SET TO -1 SO CAN CONNECT TO ANY NODE
MOVEI S2,.TKNLN(S1) ;OFFSET OF BYTE COUNT
MOVEM S2,NPDCTR ;SAVE
ADDI S1,.TKNPN ;OFFSET TO START OF PROCESS NAME
HRLI S1,(POINT 7,) ;7-BIT BYTES
MOVEM S1,NPDPTR ;SAVE
POPJ P, ;RETURN
NPDBYT: IDPB S1,NPDPTR ;STORE THE BYTE
AOS @NPDCTR ;COUNT THE BYTE
$RETT ;RETURN
NPDPTR: BLOCK 1 ;BYTE POINTER TO PROCESS NAME STORAGE
NPDCTR: BLOCK 1 ;ADDR OF BYTE COUNT
NPDLCL: BLOCK NPDLEN ;LOCAL NPD
NPDRMT: BLOCK NPDLEN ;REMOTE NPD
END