Trailing-Edge
-
PDP-10 Archives
-
cuspbinsrc_1of2_bb-x128c-sb
-
10,7/galaxy/operat/oprqsr.mac
There are 40 other files named oprqsr.mac in the archive. Click here to see a list.
TITLE OPRQSR ORION MODULE TO PROCESS QUASAR MESSAGES
SUBTTL Murray Berkowitz/PJT/LWS 12-SEP-85
;
;
;COPYRIGHT (c) DIGITAL EQUIPMENT CORPORATION 1975,1976,1977,1978,1979,
;1980,1981,1982,1983,1984,1986,1987. 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 GLXMAC,ORNMAC,QSRMAC,ACTSYM
PROLOG(OPRQSR)
ERRSET ;INITIALIZE ERROR TABLES
PARSET ;SETUP PARSER ENTRIES
EXTERNAL G$NOW ;TIME OF DAY
EXTERNAL G$ARG1 ;ARGUMENT 1
EXTERNAL G$ARG2 ;ARGUMENT 2
EXTERNAL G$ARG3 ;ARGUMENT 3
EXTERNAL G$OPRA ;OPR ADDRESS
EXTERNAL G$HOST ;HOST NODE NAME
EXTERNAL G$ERR ;ERROR FLAG WORD
EXTERNAL SNDQSR ;SEND TO QUASAR
TOPS10< EXTERNAL SNDACT> ;SEND TO ACTDAE
EXTERNAL GETPAG ;ROUTINE TO SETUP MO
EXTERNAL OPRENB ;OPR ENABLED
EXTERNAL MOVARG ;MOVE AN ARGUMENT
EXTERNAL MOVAR2 ;MOVE TWO WORD ARGUMENT
OPRVRS==:OPRVRS ;LET LINK CATCH VERSION SKEWS
%%.OPR==:%%.OPR
ENTRY BLDOBJ ;BUILD OBJECT BLOCK
ENTRY ARGRTN ;SETUP ARGUMENT IN MESSAGE
ENTRY CMDEND ;COMMAND END PROCESSING
SUBTTL Table of Contents
; TABLE OF CONTENTS FOR OPRQSR
;
;
; SECTION PAGE
; 1. Table of Contents......................................... 2
; 2. Q$SHUT Process SHUTDOWN command.......................... 3
; 3. Q$CONT Process CONTINUE command.......................... 3
; 4. Q$STAR Process START command............................. 3
; 5. Q$PAUS Process the PAUSE command......................... 3
; 6. ARGRTN Setup an argument header.......................... 4
; 7. CMDEND Process end of command and send the message....... 5
; 8. BLDOBJ Build an object block............................. 6
; 9. FINOBJ Finish object block after type field.............. 6
; 10. Q$FSPA Process FORWARDSPACE command...................... 7
; 11. Q$BSPA Process BACKSPACE command......................... 7
; 12. LPTOBJ Setup printer object block........................ 7
; 13. Q$ALGN Process ALIGN command............................. 8
; 14. Q$SUPP Process suppress command.......................... 9
; 15. Q$ABOR Process ABORT command............................. 10
; 16. PREQNM Process /REQUEST switch........................... 11
; 17. PREASN Process /REASON switch............................ 11
; 18. PUSER Process USER block................................ 11
; 19. Q$REQU Process REQUEUE command........................... 12
; 20. Q$ROUT Process ROUTE command............................. 13
; 21. Q$RELE Process RELEASE command........................... 15
; 22. Q$HOLD Process HOLD command.............................. 15
; 23. PQTYPE Process QUEUE type field.......................... 15
; 24. PNODSW Process /NODE switch.............................. 16
; 25. CNODSW Validate a /NODE switch........................... 16
; 26. GNODSW Get /NODE argument if present..................... 16
; 27. Q$CANC Process CANCEL command............................ 17
; 28. CHKRMT Check for remote node input....................... 18
; 29. Q$MODI Process MODIFY command............................ 19
; 30. Q$SET Process the SET command........................... 20
; 31. SETUSG Process SET USAGE command......................... 21
; 32. SETJOB Set operator values for a job..................... 22
; 33. SETxxx Process SET PARAMETERS............................ 23
; 34. SETONL Process SET ONLINE command (TOPS20)............... 24
; 35. SETSCH Process SET SCHEDULER command (TOPS20)............ 25
; 36. SCHED Do the SKED% JSYS (TOPS20)........................ 25
; 37. SCHBAT Process SET SCHEDULER BATCH command (TOPS20)...... 26
; 38. SCHCLS Process SET SCHEDULER CLASS command (TOPS20)...... 27
; 39. SETNOD Process SET NODE command (DN60)................... 28
; 40. SETDSK Process SET DISK command (TOPS20)................. 29
; 41. SETTAP Process SET TAPE command (TOPS20)................. 30
; 42. PSTAPE Process tape drive argument....................... 31
; 43. PSTRUC Process structure argument........................ 31
; 44. PVOLID Process volume-id argument........................ 31
; 45. PSDEVI Process a device argument......................... 31
; 46. SETINI Process SET TAPE INITIALIZE command............... 32
; 47. SETDEN Process /DENSITY switch........................... 33
; 48. SETLBT Process /LABEL switch............................. 33
; 49. SETOVR Process /OVERIDE switch........................... 33
; 50. SETOWN Process /OWNER switch............................. 34
; 51. SETPRO Process /PROTECTION switch........................ 34
; 52. SETCNT Process /COUNT switch............................. 34
; 53. SETINC Process /INCREMENT switch......................... 34
; 54. SETSVI Process /START switch............................. 34
; 55. SETTDP Process /TAPE-DISPOSITION switch.................. 34
; 56. SETVID Process /VOLUME-ID switch......................... 35
; 57. TABSRC Table search routine.............................. 36
; 58. GETDES Get device designator word........................ 37
; 59. GETTAP Get a tape device................................. 38
; 60. SETSTR Process SET STRUCTURE command (TOPS20)............ 39
; 61. Q$SHWS Process SHOW STATUS command....................... 40
; 62. Q$SHWP Process SHOW PARAMETERS command................... 40
; 63. PROSHW Process SHOW STATUS and SHOW PARAMETERS........... 41
; 64. SHWNOD Process node for SHOW STATUS/PARAMETERS command... 42
; 65. SHWTAP Process SHOW STATUS TAPE command.................. 43
; 66. SHWSTR Process SHOW STATUS STRUCTURES command............ 44
; 67. SHWDSK Process SHOW STATUS DISK command.................. 45
; 68. Q$SHWQ Process SHOW QUEUES command....................... 46
; 69. Q$SHWC Process SHOW CONTROL-FILE command................. 47
; 70. Q$DISM Process DISMOUNT command (TOPS20)................. 48
; 71. Q$RECO Process RECOGNIZE command (TOPS10)................ 48
; 72. Q$UNLO Process UNLOAD command............................ 48
; 73. Q$ESTR Process ENABLE AUTOMATIC-STRUCTURE-RECOGNITION.... 49
; 74. Q$ETAP Process ENABLE TAPE command....................... 50
; 75. Q$DTAP Process DISABLE TAPE command...................... 50
; 76. Q$LOCK Process LOCK command.............................. 51
; 77. Q$ULOC Process UNLOCK command............................ 51
; 78. Q$MOUN Process MOUNT TAPE and DISK command............... 52
; 79. Q$IDEN Process IDENTIFY command.......................... 53
; 80. Q$DEFI Process DEFINE command (DN60 or LAT).............. 54
; 81. Q$SWIT Process SWITCH command (TOPS20)................... 55
; 82. Q$MODS Process MODIFY SYSTEM-LISTS command (TOPS10)...... 56
; 83. Q$SLST Process SHOW SYSTEM-LISTS command (TOPS10)........ 57
; 84. Q$SALC Process SHOW ALLOCATION command (TOPS10).......... 58
SUBTTL Q$SHUT Process SHUTDOWN command
;THIS ROUTINE WILL SEND THE APPROPRIATE OBJECT BLOCK TO QUASAR
;FOR THE DESIRED FUNCTION..
;THE ROUTINE IS CALLED WITH S1 CONTAINING THE MESSAGE TYPE
Q$SHUT:: $CALL BLDOBJ ;BUILD THE OBJECT
JUMPT CMDEND ;FINISH OFF COMMAND
$CALL P$KEYW ;CHECK FOR KEYWORD
JUMPF E$IFC ;ERROR..RETURN
CAIE S1,.KYNOD ;WAS IT A NODE
$RETF ;BAD COMMAND
$CALL CNODSW ;YES, TACK IT ON
$RETIF ;CAN'T
PJRST CMDEND ;END THE COMMAND
SUBTTL Q$CONT Process CONTINUE command
Q$CONT:: $CALL BLDOBJ ;BUILD AN OBJECT BLOCK
$RETIF ;RETURN FALSE BACK UP
PJRST CMDEND ;CHECK FOR END AND SEND MESSAGE
SUBTTL Q$STAR Process START command
;THE START COMMAND IS THE SAME AS THE SHUTDOWN, CONTINUE
; COMMANDS EXCEPT THAT THE START COMMAND FOR PRINTERS
;CAN HAVE AN OPTIONAL DEVICE FIELD.
Q$STAR:: $CALL Q$SHUTDN ;PROCESS THE!FIRST PART
$RETIT ;O.K..COMMAND FINISHED
MOVE S1,ARG.DA+.OHDRS+OBJ.TY(MO) ;GET THE OBJECT TYPE
CAIE S1,.OTLPT ;IS IT A PRINTER?
$RETF ;NO..INVALID MESSAGE
$CALL P$SWIT ;IS THERE A SWITCH?
$RETIF ;NO..INVALID COMMAND
CAIE S1,.SWDEV ;WAS IT DEVICE?
$RETF ;NO..ERROR
LOAD S1,OBJ.UN+ARG.DA+.OHDRS(MO),OU.HRG ;GET HIGH RANGE
SKIPE S1 ;CHECK IF THERE IS ONE
PJRST E$RNA ;RANGE NOT ALLOWED IN START /DEVICE
$CALL PSDEVI ;PROCESS DEVICE BLOCK
$RETIF ;RETURN ON ERROR
;**;[76] Change EDIT 75. Would cause to much grief. 2-Nov-83
TXNN S1,DV.DSK ;[75][76] DISK ON /DEVICE: ?
PJRST CMDEND ;NO,,CHECK FOR END AND RETURN
PJRST E$IDS ;[75] YES,,INVALID DEVICE SPECIFIED
SUBTTL Q$PAUS Process the PAUSE command
Q$PAUS:: $CALL BLDOBJ ;BUILD AN OBJECT BLOCK
$RETIF ;RETURN FALSE BACK UP
$CALL P$KEYW ;DO WE HAVE A KEYWORD ???
JUMPF STOP.1 ;NO,,DEFAULT TO IMMEDIATE
CAXN S1,.KYIMM ;IS IT IMMEDIATELY ???
JRST STOP.1 ;YES,,SAY SO
CAXE S1,.KYAFT ;NOT IMMEDIATE,,MUST BE AFTER !!!
$RETF ;NO,,RETURN AN ERROR
$CALL P$KEYW ;GET THE NEXT KEYWORD
$RETIF ;NOT THERE,,THATS AN ERROR
MOVX S2,ST.ACR ;DEFAULT TO CURRENT REQUEST
CAXN S1,.KYAER ;UNLESS IT IS EVERY REQUEST
MOVX S2,ST.AER ;THEN MAKE IT EVERY REQUEST
SKIPA ;SKIP OVER IMMEDIATE STATUS
STOP.1: MOVX S2,ST.IMM ;GET IMMEDIATE STATUS BIT
MOVEM S2,.OFLAG(MO) ;SAVE FLAG BITS
PJRST CMDEND ;CHECK FOR END AND SEND MESSAGE
SUBTTL Q$NEXT - NEXT COMMAND PROCESSOR
Q$NEXT:: $CALL BLDOBJ ;[NXT] BUILD AN OBJECT BLOCK
$RETIF ;[NXT] RETURN FALSE BACK UP
$CALL P$KEYW ;[NXT] DO WE HAVE A KEYWORD ???
$RETIF ;[NXT] ERROR..RETURN
CAXE S1,.KYRQN ;[NXT] MUST BE REQUEST-ID !!!
$RETF ;[NXT] NO,,THATS AN ERROR
$CALL PREQNM ;[NXT] PROCESS REQUEST NUMBER
$RETIF ;[NXT] ERROR..RETURN
PJRST CMDEND ;[NXT] FINISH OFF COMMAND
SUBTTL ARGRTN Setup an argument header
;THIS ROUTINE WILL SETUP THE ARGUMENT HEADER FROM THE
;TYPE IN S1 AND THE LENGTH IN S2. IT WILL ALSO ADVANCE P3 TO NEXT
;LOCATION IN MESSAGE AND BUMP ARGUMENT COUNT FOR MESSAGE
ARGRTN: STORE S1,ARG.HD(P3),AR.TYP ;SAVE THE TYPE FIELD
STORE S2,ARG.HD(P3),AR.LEN ;SAVE THE LENGTH
AOS .OARGC(MO) ;BUMP ARGUMENT COUNT
ADD P3,S2 ;BUMP TO NEXT FREE LOCATION
$RETT ;O.K...RETURN TRUE
SUBTTL CMDEND Process end of command and send the message
;THIS ROUTINE WILL CHECK FOR END OF COMMAND AND IF O.K
;PREPARE MESSAGE TO BE SENT TO QUASAR
CMDEND: $CALL P$CFM ;CHECK FOR CONFIRM
$RETIF ;NO..INVALID MESSAGE
ANDI P3,777 ;GET MESSAGE LENGTH
STORE P3,.MSTYP(MO),MS.CNT ;SAVE MESSAGE SIZE IN MESSAGE
PJRST SNDQSR ;SEND THE MESSAGE TO QUASAR
SUBTTL Event queuing -- EVTMSG - Build message
; This routine will build the appropriate Event Queue request
; by parsing the OPR data. Note that the only switches handled
; here are switches defined in EVTSWT in OPRCMD. Event dependent
; switches should be defined to preceed the event independent
; switches in EVTSWT. The switch processor's address for the event
; dependent switches should be passed in S2. This event dependent
; switch processor should IORM any bit flags into EVTSWD or build
; the appropriate message blocks. If the event dependent switch
; processor fails to parse a switch encountered, P$PREV should be
; called before returning TRUE. Event dependent switches are parsed
; FIRST.
;
; "Generic" event command syntax:
;
; <command keywords> <date/time field> <dependent switches> <independent switches>
;
; EVTMSG should be called with the <date/time field> as the next field to
; parse, unless "flag" is lit. (see below)
;
; Call: MOVE S1, Flag,,Event type code (.EVxxx)
; MOVE S2, event dependent switch processor address or zero
; PUSHJ P,EVTMSG
;
; Where "Flag" (the sign bit) is set to indicate an auto file
; parse is being done.
EVTMSG::SETZM EVTSWD ;CLEAR TEMP SWITCH STORAGE
SETZM EVTSWI
MOVEM S1,G$ARG1 ;SAVE EVENT TYPE CODE
MOVEM S2,G$ARG2 ;SAVE OPTIONAL SWITCH PROCESSOR ADDRESS
MOVE S1,G$HOST ;GET HOST NAME
PUSHJ P,OPRENB ;CHECK OPR PRIVS
JUMPF .POPJ ;GIVE UP
MOVEI S1,.QOCQE ;MESSAGE TYPE IS SHORT CREATE
STORE S1,.MSTYP(MO),MS.TYP ;STORE IT
MOVX S1,MF.ACK ;GET THE ACK BIT
IORM S1,.MSFLG(MO) ;WANT A RESPONSE FROM QUASAR
; Queue type
MOVEI S1,.OTEVT ;OBJECT TYPE "EVENT"
MOVEM S1,ARG.DA(P3) ;SAVE
MOVEI S1,.QCQUE ;BLOCK TYPE
MOVEI S2,ARG.SZ ;BLOCK SIZE
PUSHJ P,ARGRTN ;WRITE BLOCK HEADER
; Event type
HRRZ S1,G$ARG1 ;GET EVENT TYPE CODE
MOVEM S1,ARG.DA(P3) ;SAVE
MOVEI S1,.QBEVT ;BLOCK TYPE
MOVEI S2,ARG.SZ ;BLOCK SIZE
PUSHJ P,ARGRTN ;WRITE BLOCK HEADER
; Possible auto file check
SKIPL G$ARG1 ;FLAG SET?
JRST EVTM.0 ;NO
PUSHJ P,EVTFIL ;PARSE FILESPEC
JUMPF .POPJ ;RETURN
; Time arguments
EVTM.0: PUSHJ P,EVTTIM ;PARSE ALL TIME RELATED ARGUMENTS
JUMPF .POPJ ;PROPAGATE ERRORS BACK
; Event dependent switches
EVTM.1: SKIPN G$ARG2 ;EVENT DEPENDENT SWITCH PROCESSOR?
JRST EVTM.2 ;NO, GO LOOK FOR INDEPENDENT SWITCHES
PUSHJ P,@G$ARG2 ;YES, CALL PROCESSOR
JUMPF .POPJ ;JUST RETURN IF PROBLEMS
; Event independent switches
EVTM.2: PUSHJ P,P$SWIT ;LOOK FOR INDEPENDENT SWITCHES
JUMPF EVTM.3 ;CONTINUE IF NONE FOUND
MOVEI S2,EVTSTB ;GET SWITCH TABLE ADDRESS
PUSHJ P,TABSRC ;LOOK FOR SWITCH PROCESSOR
JUMPF .POPJ ;RETURN IF NOT FOUND
PUSHJ P,(S2) ;PROCESS SWITCH
JUMPT EVTM.2 ;LOOK FOR MORE INDEPENDENT SWITCHES
EVTM.3: PUSHJ P,P$CURR ;SET PARSER STRAIGHT
SKIPE EVTSWD ;ANY SWITCHES SPECIFIED?
JRST EVTM.4 ;YES, PUT THEM IN MESSAGE
SKIPN EVTSWI
$RETT ;NO, ALL DONE
EVTM.4: DMOVE S1,EVTSWD ;GET SWITCHES (DEPENDENT AND INDEPENDENT)
DMOVEM S1,ARG.DA(P3) ;PUT IN MESSAGE
MOVEI S1,.QBESW ;GET BLOCK TYPE
MOVEI S2,ARG.SZ+.QBESI ;GET BLOCK SIZE
PUSHJ P,ARGRTN ;WRITE BLOCK HEADER
$RETT ;RETURN
INTERN EVTSWD ;MAKE IT GLOBAL
EVTSWD: BLOCK 1 ;EVENT DEPENDENT SWITCH STORAGE
EVTSWI: BLOCK 1 ;EVENT INDEPENDENT SWITCH STORAGE
EVTSTB: $STAB
.SWFIL,,EVTFIL ;FILESPEC PROCESSOR
.SWFSF,,EVTFSF ;FAILSOFT SWITCH PROCESSOR
.SWRSN,,EVTRSN ;REASON SWITCH PROCESSOR
$ETAB
SUBTTL Event queuing -- EVTTIM - Parse date/time
; Routine to parse:
; DAILY (AT) time
; EVERY weekday (AT) time
; NOW
; date/time
EVTTIM: SETZM G$ARG3 ;CLEAR REPEAT FLAGS
; EVERY weekday (AT) time
PUSHJ P,P$KEYW ;GET A KEYWORD
JUMPF EVTT.2 ;TRY FOR A DATE/TIME
CAIE S1,.KYWKY ;WAS IT SET KSYS "EVERY"
JRST EVTT.1 ;NO--TRY "DAILY"
PUSHJ P,P$KEYW ;GET DAY-OF-WEEK
JUMPF .POPJ ;RETURN IF DON'T HAVE IT
CAIL S1,0 ;RANGE CHECK
CAILE S1,6 ;..
$RETF ;BAD WEEKDAY INDEX
TXO S1,QB.WKY ;LITE "EVERY" FLAG
MOVEM S1,G$ARG3 ;SAVE TEMPORARILY
JRST EVTT.2 ;GO GET TIME
; DAILY (AT) time
EVTT.1: CAIE S1,.KYDLY ;WAS IT SET KSYS "DAILY"?
JRST EVTT.3 ;NO,,GO CHECK FOR "NOW"
MOVX S1,QB.DLY ;YES,,GET DAILY FLAG
MOVEM S1,G$ARG3 ;SAVE TEMPORARILY
; Parse time field used by EVERY and DAILY syntax
EVTT.2: PUSHJ P,P$TIME ;GET TIME
JUMPF .POPJ ;IT'S NOT THERE
JRST EVTT.4 ;GO FINISH UP
; NOW
EVTT.3: CAIE S1,.KYNOW ;IS IT "NOW"
$RETF ;NOPE
MOVX S1,QB.NOW ;YES,,GET NOW FLAG
MOVEM S1,G$ARG3 ;SAVE TEMPORARILY
MOVEI S1,-1 ;GET A RH -1
; Save expiration date/time
EVTT.4: MOVEM S1,ARG.DA(P3) ;SAVE
MOVEI S1,.QBAFT ;BLOCK TYPE
MOVEI S2,ARG.SZ ;BLOCK SIZE
PUSHJ P,ARGRTN ;WRITE BLOCK HEADER
; Save repeat flags
EVTT.5: MOVE S1,G$ARG3 ;GET REPEAT FLAGS
MOVEM S1,ARG.DA(P3) ;SAVE
MOVEI S1,.QBREP ;BLOCK TYPE
MOVEI S2,ARG.SZ ;BLOCK SIZE
PUSHJ P,ARGRTN ;WRITE BLOCK HEADER
$RETT ;AND RETURN
SUBTTL Event queuing -- Event independent switch parsing
; Here to parse /FILE
EVTFIL: PUSHJ P,P$IFIL ;GET INPUT FILESPEC
JUMPF .POPJ ;RETURN ON ERRORS
MOVEI TF,.QBFIL ;FILESPEC BLOCK
STORE TF,ARG.HD(S1),AR.TYP ;SAVE
PUSHJ P,MOVARG ;COPY FD INTO MESSAGE
MOVEI S1,.FPFAS ;ASCII FILE FORMAT
MOVEM S1,ARG.DA(P3) ;SAVE
MOVEI S1,.QBPTP ;BLOCK TYPE
MOVEI S2,ARG.SZ ;BLOCK SIZE
PUSHJ P,ARGRTN ;WRITE THE BLOCK HEADER
$RETT ;RETURN
; Here to process /REASON
EVTRSN: PUSHJ P,P$TEXT ;GET A TEXT
JUMPF .POPJ ;PROPAGATE ERRORS BACK
MOVEI T1,.QBMSG ;BLOCK TYPE
STORE T1,ARG.HD(S1),AR.TYP ;SAVE CORRECT TYPE IN HEADER
PUSHJ P,MOVARG ;COPY INTO MESSAGE
$RETT ;AND RETURN
; Here to process /FAILSOFT
EVTFSF: MOVX S1,QB.FSF ;GET FAILSOFT BIT
IORM S1,EVTSWI ;LITE IN TEMP FLAG WORD
$RETT ;RETURN
SUBTTL BLDOBJ Build an object block
SUBTTL FINOBJ Finish object block after type field
;THIS ROUTINE WILL BUILD AN OBJECT BLOCK FOR A MESSAGE TO AN
;OBJECT PROCESSOR AND PLACE IT IN THE MESSAGE POINTED TO BY
;MO
BLDOBJ: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;NOT A KEYWORD..INVALID..RETURN
CAILE S1,.OTMAX ;LESS THAN OR EQUAL VALID OBJECT
JRST BLDO.6 ;INVALID TYPE..RETURN
CAIE S1,.OTBAT ;WAS IT A BATCH BLOCK
JRST BLDO.1 ;NO..IGNORE CHECK
MOVE P1,S1 ;SAVE THE NUMBER
MOVE S1,G$HOST ;GET THE HOST NAME
$CALL OPRENB ;MUST BE SYSTEM OR LOCAL
JUMPF E$BNR ;BATCH COMMANDS MUST BE LOCAL
MOVE S1,P1 ;GET THE TYPE BACK
BLDO.1: STORE S1,ARG.DA+OBJ.TY(P3) ;SAVE THE TYPE
FINOBJ: SETZM ARG.DA+OBJ.UN(P3) ;ZERO THE UNIT NUMBER FIELDS
$CALL P$NUM ;GET A NUMBER
$RETIF ;RETURN FALSE..PASSING RETURN UP
TLNE S1,-1 ;Ligit number? (Fit in half word)
PJRST E$IRS ;No - fake user with illeg. range
STORE S1,ARG.DA+OBJ.UN(P3),OU.LRG ;SAVE AS LOW RANGE
MOVE P1,S1 ;SAVE THE LOW RANGE
$CALL P$TOK ;CHECK FOR TOKEN AND RANGE
JUMPF BLDO.2 ;NO..CHECK FOR NODE
;IGNORE TOKEN
$CALL P$NUM ;GET THE OTHER NUMBER
$RETIF ;INVALID FIELD..NUMBER NEEDED
CAML P1,S1 ;CHECK FOR VALID RANGE
PJRST E$IRS ;UNITS OUT OF RANGE
TLNE S1,-1 ;Ligit number? (Fit in half word)
PJRST E$IRS ;No - fake user with illeg. range
STORE S1,ARG.DA+OBJ.UN(P3),OU.HRG ;SAVE THE HIGH RANGE
BLDO.2: LOAD S1,ARG.DA+OBJ.UN(P3),OU.LRG ;GET LOW END OF RANGE
LOAD S2,ARG.DA+OBJ.UN(P3),OU.HRG ;GET HIGH END OF RANGE
SKIPN S2 ;IF NO HIGH END,
MOVE S2,S1 ;USE LOW END AS HIGH END
SUB S2,S1 ;GET NUMBER OF OBJECTS IN RANGE
CAXLE S2,MXUNIT ;WITHIN REASON?
PJRST E$IRS ;NO, GIVE AN ERROR
ZERO ARG.DA+OBJ.ND(P3) ;INITIALIZE NODE FIELD
$CALL P$SWIT ;GET A SWITCH
JUMPF BLDO.4 ;NOT A SWITCH,,CHECK CONFIRM
CAIE S1,.SWNOD ;WAS IT A NODE
JRST BLDO.3 ;NO..SETUP NODE VALUE IN BLOCK
$CALL P$NODE ;GET THE NODE
JUMPF BLDO.3 ;GET NODE FROM NODE ENTRY
MOVE P1,S1 ;SAVE THE NODE DATA
PJRST BLDO.5 ;SAVE NODE AND RETURN
BLDO.3: $CALL P$PREV ;POSITION TO THE PREVIOUS ONE
;ON INPUT
BLDO.4: MOVE T1,G$OPRA ;GET OPERATOR ENTRY ADDRESS
MOVE T1,OPR.ND(T1) ;GET NODE ADDRESS
MOVE P1,NOD.NX(T1) ;GET NODE NAME ON -20
BLDO.5: STORE P1,ARG.DA+OBJ.ND(P3) ;SAVE THE NODE NAME
MOVE S1,P1 ;Copy affected node
$CALL OPRENB ;See if ok for this OPR
$RETIF ;No..return the failure
MOVX S1,.OROBJ ;TYPE OF DATA ELEMENT..OBJ BLOCK
MOVX S2,.OBJLN ;SIZE OF THE BLOCK
PJRST ARGRTN ;SETUP HEADER,COUNT, POINTER..RETT
BLDO.6: $CALL P$PREV ;POSITION TO THE PREVIOUS ONE
$RETF ;RETURN FALSE
SUBTTL Q$FSPA Process FORWARDSPACE command
SUBTTL Q$BSPA Process BACKSPACE command
Q$FSPA::
Q$BSPA:: $CALL LPTOBJ ;LINE PRINTER OBJECT SETUP
$RETIF ;ERROR..RETURN
$CALL P$SWIT ;GET A SWITCH
$RETIF ;ILLEGALLY FORMATTED COMMAND
MOVEI S2,FSPDSP ;GET TABLE ADDRESS
$CALL TABSRC ;GET THE VALUE
$RETIF ;ERROR..RETURN
MOVE T2,S2 ;PLACE TYPE IN T2
$CALL P$NUM ;GET A NUMBER
JUMPF [CAIE T2,.SPFIL ;WAS THIS /FILE?
$RETF ;NO..THEN RETURN FAILURE
MOVEI S1,1 ;YES..THEN THE NUMBER IS 1
JRST .+1] ;CONTINUE
STORE S1,ARG.DA(P3) ;SAVE DATA IN MESSAGE
MOVE S1,T2 ;GET TYPE IN S1
MOVEI S2,ARG.SZ ;SIZE OF THE BLOCK
$CALL ARGRTN ;ARG HEADER,COUNT ROUTINE
PJRST CMDEND ;CHECK FOR END AND SEND MESSAGE
FSPDSP: $STAB
.SWPAG,,.SPPAG ;PAGES
.SWFIL,,.SPFIL ;FILES
.SWCPY,,.SPCPY ;COPIES
$ETAB
SUBTTL LPTOBJ Setup printer object block
;THIS ROUTINE WILL SETUP AN OBJECT BLOCK AND MAKE SURE
;THAT IT IS FOR A LINE PRINTER WITH ONLY ONE UNIT SPECIFIED.
;THE OBJECT BLOCK WILL BE BUILT IN THE OUTPUT MESSAGE
LPTOBJ: $CALL BLDOBJ ;AND AN OBJECT BLOCK
$RETIF ;ERROR..PASS CODE UP
MOVEI T1,.OHDRS+ARG.DA(MO) ;POINT TO OBJECT BLOCK
LOAD S1,OBJ.UN(T1),OU.HRG ;SEE IF WE HAVE A NON-ZERO HIGH UNIT
JUMPN S1,.RETF ;LOSE IF SO
LOAD S1,OBJ.TY(T1) ;GET MESSAGE TYPE
CAXE S1,.OTLPT ;PRINTER?
$RETF ;NO, LOSE
$RETT ;RETURN TRUE
SUBTTL Q$ALGN Process ALIGN command
;THIS ROUTINE WILL PROCESS AN ALIGN COMMAND FROM OPR
Q$ALGN:: $CALL LPTOBJ ;SETUP LINE PRINTER OBJECT BLOCK
$RETIF ;ERROR..RETURN
$CALL P$SWIT ;CHECK FOR A SWITCH
JUMPF ALIG.3 ;NO..CHECK FOR A FILE
CAIE S1,.SWSTP ;WAS IT A STOP
JRST ALIG.2 ;NO..TRY OTHER VALUES
MOVX S1,.ALSTP ;GET THE STOP ARGUMENT TYPE
MOVEI S2,1 ;SETUP FIELD LENGTH
$CALL ARGRTN ;SETUP ARGUMENT IN MESSAGE
PJRST CMDEND ;FINISH OFF THE COMMAND
ALIG.1: $CALL P$SWIT ;GET A SWITCH
JUMPF ALIG.3 ;CHECK FOR A FILE
ALIG.2: MOVEI S2,ALIDSP ;GET ALIGN TABLE
$CALL TABSRC ;CHECK THE TABLE
$RETIF ;ERROR..RETURN
MOVE T2,S2 ;SAVE THE VALUE
$CALL P$NUM ;GET A NUMBER
$RETIF ;ERROR..RETURN
STORE S1,ARG.DA(P3) ;SAVE NUMBER IN ARGUMENT BLOCK
MOVEI S2,ARG.SZ ;GET ARGUMENT SIZE
MOVE S1,T2 ;GET FUNCTION TYPE
$CALL ARGRTN ;SAVE THE ARGUMENT AND UPDATE COUNTERS
JRST ALIG.1 ;CHECK NEXT FIELD
ALIG.3: $CALL P$IFIL ;CHECK FOR INPUT FILE
JUMPF CMDEND ;NO..CHECK FOR END OF COMMAND
$CALL MOVARG ;YES..MOVE FD AND HEADER FOR OUTPUT
JRST ALIG.1 ;CHECK THE NEXT FIELD
ALIDSP: $STAB
.SWRPT,,.ALRPT ;REPEAT COUNT
.SWPAU,,.ALPAU ;PAUSE COUNT
$ETAB
SUBTTL Q$SUPP Process suppress command
Q$SUPP:: $CALL LPTOBJ ;SETUP LINE PRINTER OBJECT BLOCK
$RETIF ;ERROR..RETURN
$CALL P$SWIT ;CHECK FOR A SWITCH
MOVEI S2,SUPDSP ;ADDRESS OF THE TABLES
SKIPT ;SKIP IF O.K.
MOVEI S1,.SWJOB ;ASSUME JOB AS DEFAULT
$CALL TABSRC ;SEARCH THE TABLE
$RETIF ;ERROR..RETURN
MOVE S1,S2 ;PLACE TYPE IN S1
MOVEI S2,1 ;LENGTH OF ARGUMENT IN S2
$CALL ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH THE COMMAND
SUPDSP: $STAB
.SWFIL,,.SUPFL ;FILE
.SWJOB,,.SUPJB ;JOB
.SWSTP,,.SUPST ;STOP
$ETAB
SUBTTL Q$ABOR Process ABORT command
;THIS ROUTINE WILL PROCESS A ABORT COMMAND AND SEND THE
;APPROPRIATE MESSAGE TO QUASAR
Q$ABOR:: $CALL BLDOBJ ;GET AN OBJECT BLOCK SETUP
$RETIF ;NO..RETURN..BAD MESSAGE
MOVEI T1,.OHDRS+ARG.DA(MO) ;ADDRESS OF ARGUMENT BLOCK
LOAD S1,OBJ.UN(T1),OU.HRG ;GET HIGH RANGE
JUMPN S1,.RETF ;NON-ZERO..RETURN FALSE
ABOR.1: $CALL P$SWIT ;GET A SWITCH IF ANY
JUMPF CMDEND ;NO..CHECK FOR CONFIRM AND SEND
CAIE S1,.SWREQ ;/REQUEST NUMER SWITCH
JRST ABOR.3 ;PROCESS SEQUENCE SWITCH
$CALL PREQNM ;PROCESS REQUEST NUMBER
$RETIF ;ERROR RETURN
ABOR.2: $CALL P$SWIT ;CHECK FOR SWITCH
JUMPF CMDEND ;ERROR..CHECK FOR END
ABOR.3: MOVEI S2,ABODSP ;ABORT TABLE ADDRESS
$CALL TABSRC ;SEARCH THE TABLE
JUMPT ABOR.4 ;O.K..CONTINUE ON
CAIN S1,.SWRSN ;/REASON SWITCH
JRST ABOR.5 ;PROCESS REASON SWITCH
$RETF ;INVALID COMMAND
ABOR.4: MOVEM S2,ARG.DA(P3) ;SAVE THE DATA FIELD
MOVX S1,.CANTY ;GET ABORT TYPE
MOVX S2,ARG.SZ ;GET ARGUMENT SIZE
$CALL ARGRTN ;SETUP ARGUMENT HEADER AND COUNTS
JRST ABOR.2 ;GET NEXT FIELD
ABOR.5: $CALL PREASN ;PROCESS THE REASON SWITCH
$RETIF ;NO...ERROR..RETURN
PJRST CMDEND ;CHECK FOR COMMAND END AND RETURN
ABODSP: $STAB
.SWPUR,,.CNPRG ;/PURGE
.SWERR,,.CNERR ;/ERROR
.SWNER,,.CNNER ;/NOERROR
$ETAB
SUBTTL PREQNM Process /REQUEST switch
;PROCESS /REQUEST SWITCH
PREQNM: $CALL P$NUM ;GET A NUMBER
$RETIF ;NO..RETURN FALSE
PREQ.1: STORE S1,ARG.DA(P3) ;SAVE THE NAME IN MESSAGE
MOVX S1,.ORREQ ;GET JOBNAME TYPE
MOVX S2,ARG.SZ ;SIZE OF THE ARGUMENT
PJRST ARGRTN ;SETUP ARGUMENT HEADER AND COUNTS
SUBTTL PREASN Process /REASON switch
;PROCESS /REASON TEXT DATA
PREASN: $CALL P$TEXT ;GET A TEXT ARGUMENT
$RETIF ;NO..RETURN
MOVX T1,.ORREA ;GET REASON TYPE
STORE T1,ARG.HD(S1),AR.TYP ;SAVE CORRECT TYPE IN HEADER
$CALL MOVARG ;BUILD TEXT ARGUMENT AND UPDATE COUNTS
$RETT ;RETURN TRUE
SUBTTL PUSER/PUSERS Process USER block/switch
PUSER: MOVX S1,.CMUSR ;Get user block
SKIPA ;Skip other entry point
PUSERS: MOVX S1,.LSUSR ;List user switch
PUSH P,S1 ;Save it a sec
;Common work
$CALL P$USER ;GET USER DATA
JUMPF [POP P,(P) ;ERROR,,PHASE STACK
$RETF ] ;AND RETURN
MOVEM S1,ARG.DA(P3) ;SAVE THE DATA
POP P,S1 ;GET USER TYPE
MOVX S2,ARG.SZ ;SIZE OF THE ARGUMENT
PJRST ARGRTN ;SAVE THE ARGUMENT
SUBTTL Q$REQU Process REQUEUE command
;THIS ROUTINE WILL ANALYSZE A REQUEUE COMMAND AND SEND THE
;APPROPRIATE MESSAGE TO QUASAR
Q$REQU:: $CALL BLDOBJ ;SETUP OBJECT BLOCK
$RETIF ;ERROR IF NOT SETUP..RETURN
MOVEI T1,.OHDRS+ARG.DA(MO) ;GET THE ARGUMENT BLOCK
LOAD S1,OBJ.UN(T1),OU.HRG ;GET HIGH VALUE
JUMPN S1,.RETF ;RANGE NOT ALLOWED
MOVE P1,OBJ.TY(T1) ;GET THE TYPE FIELD
REQU.1: $CALL P$SWIT ;GET A SWITCH
JUMPF REQU.5 ;NO..CHECK FOR OTHER FIELDS
CAIE S1,.SWREQ ;CHECK FOR REQUEST
JRST REQU.3 ;YES..PROCESS JOBNAME
$CALL PREQNM ;PROCESS REQUEST NUMBER
$RETIF ;ERROR RETURN
REQU.2: $CALL P$SWIT ;CHECK FOR SWITCH
JUMPF REQU.5 ;CHECK OTHER FIELDS
REQU.3: CAIN S1,.SWRSN ;CHECK FOR REASON
JRST REQU.4 ;PROCESS REASON SWITCH
$RETF ;INVALID COMMAND..RETURN
REQU.4: $CALL PREASN ;PROCESS THE REASON FLAG
$RETIF ;ERROR..RETURN
JRST REQU.7 ;CHECK FOR A CONFIRM
REQU.5: CAIN P1,.OTBAT ;CHECK FOR BATCH
JRST REQU.7 ;YES..CHECK FOR A CONFIRM
$CALL P$KEYW ;PRINTER..CHECK FOR KEYWORD
SETOM T1 ;SETUP FLAG FOR SWITCHES
JUMPF REQU.8 ;CHECK FOR END OF MESSAGE
CAIE S1,.KYBEG ;BEGINNING-OF KEYWORD
JRST REQU.6 ;CHECK FOR CURRENT POSITION
$CALL P$KEYW ;GET BEGINNING OPRION
$RETIF ;NOT..KEYWORD..ERROR
CAIN S1,.KYCPY ;IS IT COPY
MOVEI T1,.RQBCP ;BEGINNING OF COPY
CAIN S1,.KYJOB ;IS IT JOB
MOVEI T1,.RQBJB ;BEGINNING OF JOB
CAIN S1,.KYFIL ;IS IT FILE
MOVEI T1,.RQBFL ;BEGINNING OF FILE
REQU.6: CAIN S1,.KYCUR ;CURRENT-POSITION
MOVEI T1,.RQCUR ;CURRENT POSITION
JUMPL T1,.RETF ;INVALID KEYWORD
STORE T1,ARG.DA(P3) ;SAVE VALUE IN MESSAGE
MOVX S1,.REQTY ;KEY ARGUMNET BLOCK TYPE
MOVX S2,ARG.SZ ;GET ARGUMENT SIZE
$CALL ARGRTN ;SETUP ARGUMENT AND COUNTS
$CALL P$SWIT ;GET A SWITCH
JUMPF REQU.7 ;CHECK FOR CONFIRM
CAIE S1,.SWRSN ;IS IT REASON
$RETF ;RETURN FALSE
JRST REQU.4 ;PROCESS THE REASON SWITCH
REQU.7: PJRST CMDEND ;FINISH THE COMMAND
REQU.8: CAIE S1,.CMCFM ;CHECK IF AT END OF COMMAND
$RETF ;NO..RETURN FALSE
MOVEI S1,.KYCUR ;SET DEFAULT FOR CURRENT POSITION
JRST REQU.6 ;FINISH COMMAND
SUBTTL Q$ROUT Process ROUTE command
INTERN Q$ROUTE ;MAKE IT GLOBAL
Q$ROUT: STKVAR (OBJDEV) ;CREATE SPACE FOR THE DEVICE TYPE
$CALL P$KEYW ;GET A KEYWORD !!!
$RETIF ;NOT THERE,,THATS AN ERROR
CAXE S1,.KYALL ;DID HE SPECIFY ALL DEVICES ???
CAXG S1,.OTMAX ;NO,,IS IT A VALID OBJECT TYPE ???
SKIPA ;YES TO EITHER,,SKIP
$RETF ;NO,,RETURN
CAXN S1,.KYALL ;DID HE SPECIFY ALL ???
SETOM S1 ;YES,,SET IT
MOVEM S1,ARG.DA+OBJ.TY(P3) ;SAVE IT IN THE SOURCE OBJECT BLOCK
MOVEM S1,OBJDEV ;SAVE IT HERE FOR LATER
JUMPGE S1,ROUT.4 ;Go to process routing for specific dev.
;Process ALL-DEVICE command
SETOM ARG.DA+OBJ.UN(P3) ;Set object block to all units
$CALL P$NODE ;Get the source node
JUMPT ROUT.1 ;Go process the node name
;Maybe ALL-NODES was specified!
$CALL P$KEYW ;Try for th keyword
$RETIF ;Must be there!
CAXE S1,.KYALL ;Is it ALL?
$RETF ;No -- screwed up
SETOM S1 ;Say all nodes
ROUT.1: MOVEM S1,ARG.DA+OBJ.ND(P3) ;Save source node info
$CALL OPRENB ;Check OPR's privs
$RETIF ;NO,,RETURN
MOVX S1,.RTEFM ;GET THE BLOCK TYPE
MOVX S2,OBJ.SZ+1 ;AND THE BLOCK LENGTH
$CALL ARGRTN ;AND UPDATE THE MESSAGE
$CALL P$NODE ;GET THE DESTINATION NODE NAME
JUMPF ROUT.3 ;NOT THERE,,MIGHT BE 'DELETE' FUNCTION
SETOM ARG.DA+OBJ.UN(P3) ;Save all unit types
;Common completion code
ROUT.2: MOVEM S1,ARG.DA+OBJ.ND(P3) ;SAVE IT IN THE OBJECT BLOCK
$CALL OPRENB ;Check OPR's privs
$RETIF ;NO,,RETURN
MOVE S1,OBJDEV ;Get the source device type
MOVEM S1,ARG.DA+OBJ.TY(P3) ;Save the object types
MOVX S1,.RTETO ;GET THE BLOCK TYPE
MOVX S2,OBJ.SZ+1 ;GET THE BLOCK LENGTH
$CALL ARGRTN ;UPDATE THE MESSAGE
ROUT.3: $CALL CMDEND ;Send it off
$RET ;Return preserving previous return
;Process a route command for a specific device
ROUT.4: $CALL P$NUM ;GET THE UNIT NUMBER
JUMPF ROUT.5 ;NOT THERE,,MIGHT HAVE SAID 'ALL'
CAXLE S1,77 ;IS IT VALID ???
$RETF ;NO,,RETURN
JRST ROUT.6 ;YES,,CONTINUE
ROUT.5: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;NOT THERE,,THATS AN ERROR
CAXE S1,.KYALL ;IS IT 'ALL' ???
$RETF ;NO,,THATS AN ERROR
SETOM S1 ;Make this all units
ROUT.6: MOVEM S1,ARG.DA+OBJ.UN(P3) ;SAVE IT IN THE OBJECT BLOCK
$CALL P$SWIT ;Get the node switch
JUMPF ROUT.7 ;No switch- thats ok
CAIE S1,.SWNOD ;It must be a node switch however.
$RETF ;It isn't!
$CALL P$NODE ;GET THE SOURCE NODE if any
JUMPT ROUT.8 ;Go to set node name
;Since no node was specified, get the OPR's node
ROUT.7: MOVE S1,G$OPRA ;Get the operator's address
MOVE S1,OPR.ND(S1) ;The the address of the node info
MOVE S1,NOD.NM(S1) ;Get the node name
ROUT.8: MOVEM S1,ARG.DA+OBJ.ND(P3) ;AND SAVE THE SOURCE NODE
$CALL OPRENB ;Check OPR's privs
$RETIF ;NO,,RETURN
MOVX S1,.RTEFM ;GET THE BLOCK TYPE
MOVX S2,OBJ.SZ+1 ;AND THE BLOCK LENGTH
$CALL ARGRTN ;AND UPDATE THE MESSAGE
;Get destination information
$CALL P$NUM ;Get the destination unit number
JUMPF [$CALL P$KEYW ;Try to get a keyword
JUMPF ROUT.3 ;None -- check for delete function
CAXE S1,.KYALL ;Is it "ALL"?
$RETF ;No - return bad
SETOM S1 ;Make it all units
JRST ROUT.A] ;Continue
ROUT.A: CAXLE S1,77 ;VALIDATE IT
$RETF ;NOT VALID,,RETURN AN ERROR
MOVEM S1,ARG.DA+OBJ.UN(P3) ;Save the unit number
$CALL P$SWIT ;Get the node switch
JUMPF ROUT.9 ;No switch- thats ok
CAIE S1,.SWNOD ;It must be a node switch however.
$RETF ;It isn't!
$CALL P$NODE ;GET THE DESTINATION NODE NAME
JUMPT ROUT.2 ;Go join the common code for
; processng the destination node info
;Since no node was specified, get the OPR's node
ROUT.9: MOVE S1,G$OPRA ;Get the operator's address
MOVE S1,OPR.ND(S1) ;The the address of the node info
MOVE S1,NOD.NM(S1) ;Get the node name
JRST ROUT.2 ;Go join the common code for completion
SUBTTL Q$RELE Process RELEASE command
SUBTTL Q$HOLD Process HOLD command
Q$RELE::
Q$HOLD:: $CALL CHKRMT ;CHECK IF FROM REMOTE AND ADD
; NODE BLOCK IF REMOTE OR LOCAL
$CALL OPRENB ;Check OPR Privs
$RETIF ;Return on error
$CALL P$KEYW ;GET THE KEYWORD
$RETIF ;NO..ERROR...RETURN
HOLD.1: $CALL PQTYPE ;PROCESS QUEUE TYPE
JUMPF E$IOT ;ERROR..INVALID QUEUE TYPE
HOLD.2: $CALL PREQNM ;PROCESS REQUEST NUMBER
JUMPF HOLD.3 ;ERROR..TRY USER FIELD
PJRST CMDEND ;CHECK FOR THE END
HOLD.3: $CALL PUSER ;PROCESS USER FIELD
JUMPF HOLD.4 ;CHECK OUT * OR /NODE
PJRST CMDEND ;END THE MESSAGE
HOLD.4: $CALL P$TOK ;GET A TOKEN
$RETIF ;ERROR ..RETURN
SETOM S1 ;YES..ASSUME * -1 FOR REQUEST
$CALL PREQ.1 ;SAVE ARGUMENT
$CALL PNODSW ;GET NODE SWITCH
$RETIF ;ERROR .. RETURN
PJRST CMDEND ;FINISH OFF COMMAND
SUBTTL PQTYPE Process QUEUE type field
;CALLED WITH S1 CONTAINING THE QUEUE TYPE
PQTYPE: MOVEM S1,G$ARG1 ;SAVE THE OBJECT TYPE
SKIPLE S1 ;CHECK FOR VALID OBJECT TYPE
CAILE S1,.OTMAX
$RETF ;NOT AN OBJECT TYPE
MOVEM S1,ARG.DA(P3) ;SAVE THE OBJECT TYPE IN MESSAGE
MOVX S1,.ORTYP ;GET OBJECT TYPE
MOVX S2,ARG.SZ ;GET ARGUMENT SIZE
PJRST ARGRTN ;SAVE ARGUMENT AND RETURN
SUBTTL PNODSW Process /NODE switch
SUBTTL CNODSW Validate a /NODE switch
PNODSW: $CALL P$SWIT ;CHECK FOR A SWITCH
JUMPF .RETT ;RETURN O.K..CHECK NEXT FIELD
CAIE S1,.SWNOD ;WAS IT A NODE
$RETF ;NO..RETURN FALSE
CNODSW: $CALL P$NODE ;GET THE NODE FIELD
$RETIF ;ERROR..RETURN
MOVE P1,S1 ;SAVE VALUE OF NODE
$CALL OPRENB ;IS OPR ENABLED FOR NODE
$RETIF ;ERROR...RETURN
MOVE S1,P1 ;PLACE IN S1
SAVNOD: MOVEM S1,ARG.DA(P3) ;SAVE THE VALUE
MOVX S1,.ORNOD ;GET THE NODE BLOCK TYPE
MOVX S2,ARG.SZ ;AND BLOCK SIZE
PJRST ARGRTN ;SAVE ARGUMENT AND RETURN
SUBTTL GNODSW Get /NODE argument if present
;THIS ROUTINE WILL GET NODE SWITCH IF PRESENT AND RETURN VALUE
;IN S1 OR RETURN FALSE IF NOT THERE
GNODSW: $CALL P$SWIT ;CHECK FOR A SWITCH
$RETIF ;NOT..RETURN FALSE
CAIE S1,.SWNOD ;WAS IT A NODE
$RETF ;NO..RETURN FALSE
$CALL P$NODE ;GET THE NODE FIELD
$RET ;RETURN..PASSING CODE OR VALUE
SUBTTL Q$CANC Process CANCEL command
Q$CANC:: $CALL CHKRMT ;CHECK IF FROM REMOTE AND ADD
; NODE BLOCK IF LOCAL OR REMOTE
$CALL OPRENB ;Check OPR privs
$RETIF ;Return on error
$CALL P$KEYW ;GET THE QUEUE TYPE
$RETIF ;ERROR...RETURN
CAIN S1,.KYMNT ;WAS IT A MOUNT REQUEST
JRST CANC.1 ;PROCESS CANCEL OF MOUNT REQUESTS
SETZM P1 ;SET FLAG FOR ALL DATA
PJRST HOLD.1 ;FINISH OFF COMMAND
CANC.1: MOVX S1,.ODDMT ;SET CANCEL MOUNT REQUEST TYPE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE IN HEADER
$CALL PREQNM ;WAS IT A REQUEST NUMBER
JUMPT CANC.2 ;PROCESS THE REASON IF PRESENT
$CALL PSTRUC ;GET THE STRUCTURE NAME
JUMPT CANC.2 ;WIN,,CHECK FOR REASON
$CALL P$TOK ;GET A TOKEN
$RETIF ;ERROR ..RETURN
SETOM S1 ;YES..ASSUME * -1 FOR ALL REQUESTS
$CALL PREQ.1 ;SAVE ARGUMENT
CANC.2: $CALL P$SWIT ;WAS THERE A SWITCH
JUMPF CMDEND ;NO..CHECK END OF COMMAND
CAIE S1,.SWRSN ;WAS IT /REASON: ??
$RETF ;NO..RETURN FALSE
$CALL PREASN ;PROCESS THE REASON
JUMPT CMDEND ;O.K FINISH OFF MESSAGE
$RET ;OTHERWISE PASS ERROR BACK
SUBTTL CHKRMT Check for remote node input
;THIS ROUTINE WILL CHECK IF FROM REMOTE SITE AND ADD A .CMNOD
;BLOCK IF OPR IS REMOTE SO QUASAR CAN VALIDATE THE REQUEST
;Returns S1/ Node Name
CHKRMT: SETOM S1 ;System OPR?
$CALL OPRENB
JUMPT [MOVE S1,G$HOST ;Yes..return host name
JRST CHKR.2]
SETZM G$ERR ;Ignore errors
MOVE S1,G$HOST ;Local OPR?
$CALL OPRENB
JUMPT [MOVE S1,G$HOST ;Yes..add central site block
JRST CHKR.1]
SETZM G$ERR ;Ignore errors
MOVE S2,OPR.ND(S1) ;GET NODE ENTRY ADDRESS
MOVE S1,NOD.NX(S2) ;GET THE NAME
CHKR.1: $SAVE <S1> ;Preserve node
$CALL SAVNOD ;Include the node block
CHKR.2: $RETT
SUBTTL Q$MODI Process MODIFY command
;THIS COMMAND WILL MODIFY AN ENTRY IN QUASARS QUEUES
Q$MODI:: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;ERROR..RETURN
$CALL PQTYPE ;PROCESS QUEUE TYPE
JUMPF Q$MODS ;NOT A QUEUE TYPE, MAYBE A SYSTEM LIST
$CALL CHKRMT ;CHECK IF FROM REMOTE AND ADD
; NODE BLOCK IF REMOTE OR LOCAL
$CALL OPRENB ;Check OPR privs
$RETIF ;Return on failure
$CALL PREQNM ;PROCESS REQUEST NUMBER
JUMPT MODI.1 ;O.K. PROCESS MODIFY OPTION
$CALL PUSER ;TRY USER FIELD
JUMPT MODI.1 ;O.K.. PROCESS THE FIELDS
$CALL P$TOK ;WAS THERE A TOKEN
SETZM G$ERR ;Ignore errors
$RETIF ;NO..ERROR..RETURN
SETOM S1 ;SET FOR ALL REQUESTS
$CALL PREQ.1 ;SAVE REQUEST NUMBER
$CALL PNODSW ;WAS THERE A NODE SWITCH
$RETIF ;ERROR..RETURN
MODI.1: $CALL P$KEYW ;PROCESS A KEYWORD
$RETIF ;BAD COMMAND
CAIE S1,.KYPRI ;IS IT PRIORITY
$RETF ;BAD COMMAND
$CALL P$NUM ;GET THE NUMBER
$RETIF ;ERROR..RETURN
MOVEM S1,ARG.DA(P3) ;SAVE THE VALUE
MOVX S1,.MOPRI ;GET BLOCK TYPE
MOVX S2,ARG.SZ ;BLOCK SIZE
$CALL ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH OFF COMMAND
SUBTTL Q$SET Process the SET command
;THIS ROUTINE WILL SEND THE APPROPRIATE SET MESSAGE TO
;QUASAR FOR PRINTERS, BATCH-STREAMS, AND PRIORITY. ALL OTHER
;SET TYPES WILL BE PROCESSED BY ORION
NOFLAG: BLOCK 1 ;NON-ZERO IF "NO" KEYWORD
Q$SET:: SETZM NOFLAG ;HAVEN'T SEE "NO" YET
$CALL P$KEYW ;GET A KEYWORD
$RETIF ;ILLEGALLY FORMATTED COMMAND
MOVSI S2,-SETTX1 ;PREPARE AOBJN POINTER
SET.1: HLRZ T1,SETDSP(S2)
CAME T1,S1 ;MATCH?
AOBJN S2,SET.1 ;CHECK THE REST IF ANY
JUMPGE S2,.RETF ;LOSE!
MOVE P2,SETDSP(S2) ;SAVE ENTRY DATA
MOVEI T1,SETDSP(S2) ;ADDRESS OF THE ENTRY
CAILE T1,SETOBJ ;SET FOR BAT OR LPT
JRST SET.3 ;NO..GO PROCESS
$CALL P$PREV ;POSITION TO PREVIOUS BLOCK
$CALL BLDOBJ ;GET THE OBJECT BLOCK
$RETIF ;RETURN
PUSHJ P,P$KEYW## ;GET A KEYWORD
$RETIF ;RETURN ON ERRORS
CAIE S1,.KYNO ;"NO"?
JRST SET.1A ;NO
SETOM NOFLAG ;REMEMBER FOR LATER
PUSHJ P,P$KEYW## ;GET A KEYWORD
$RETIF ;RETURN ON ERRORS
SET.1A: HRRZ S2,P2 ;GET THE PROPER TABLE ADDRESS
MOVE S2,(S2) ;GET DISPATCH POINTER
SET.2: HLRZ T1,(S2) ;GET THE FIELD TO CHECK
CAME T1,S1 ;CHECK FOR MATCH??
AOBJN S2,SET.2 ;NO..KEEP CHECKING
JUMPGE S2,.RETF ;NO MATCH..FAILED
HRRZ T1,(S2) ;GET ADDRESS OF HEADER
HLRZ T2,(T1) ;PLACE ADDRESS IN T1
MOVE T2,(T2) ;GET HEADER IN T1
MOVEM T2,ARG.HD(P3) ;SAVE THE ENTRY
SET.3: HRRZ S2,(T1) ;GET THE ROUTINE ADDRESS
JRST (S2) ;GO TO PROPER ROUTINE
;SET COMMAND DISPATCH TABLE
SETDSP: XWD .KYBAT,[-BATCNT,,BATDSP] ;BATCH
XWD .KYLPT,[-LPTCNT,,LPTDSP] ;LPT
XWD .KYCDP,[-CDPCNT,,CDPDSP] ;CDP
XWD .KYPTP,[-PTPCNT,,PTPDSP] ;PAPAR-TAPE-PUNCH
XWD .KYPLT,[-PLTCNT,,PLTDSP] ;PLT
XWD .KYNQC,[-NQCCNT,,NQCDSP] ;NETWORK-QUEUE-CONTROLLER
SETOBJ: XWD .KYFAL,[-FALCNT,,FALDSP] ;FAL-STREAM
XWD .KYJOB,SETJOB ;PROCESS JOB SETTING OPTIONS
XWD .KYTAP,SETTAP ;SET TAPE COMMAND
TOPS10< XWD .KYKSY,SETKSY ;SET KSYS COMMAND
XWD .KYUSG,SETUSG ;SET USAGE
XWD .KYSYS,SETSYS ;SET SYSTEM PARAMETER (LOGMAX, ETC.)
>;END TOPS10
TOPS20 <
XWD .KYSCH,SETSCH ;SET BIAS COMMAND
XWD .KYDSK,SETDSK ;SET DISK COMMAND
XWD .KYSTR,SETSTR ;SET STRUCTURE COMMAND
XWD .KYONL,SETONL ;SET ONLINE COMMAND
>;END TOPS20
IFN FTDN60,<
XWD .KYNOD,SETNOD ;SET NODE COMMAND
>;END FTDN60
SETTX1==.-SETDSP
;BATCH DISPATCH TABLE
BATDSP: XWD .KYATR,[[ARG.SZ+1,,.STATR],,SETATR] ;ATTRIBUTE
XWD .KYMEM,[[ARG.SZ+1,,.STMEM],,SETMEM] ;MEMORY LIMITS
XWD .KYPRL,[[ARG.SZ+1,,.STPRI],,SETPRI] ;PRIORITY-LIMITS
XWD .KYNOI,[[1,,.STNOI],,SETNOI] ;NOOPR-INTERVENTION
XWD .KYOIA,[[1,,.STOIA],,SETOIA] ;OPR-INTERVENTION
XWD .KYSOI,[[1,,.STSOI],,SETSOI] ;SYSTEM-OPR-INTERVENTION
XWD .KYTIM,[[ARG.SZ+1,,.STTIM],,SETTIM] ;SET TIME LIMITS
BATCNT==.-BATDSP
CDPDSP:!
LPTDSP:!
PLTDSP:!
PTPDSP:!
OUTDSP: XWD .KYFOT,[[ARG.SZ,,.STFRM],,SETFRM] ;FORMS-TYPE
XWD .KYLEA,[[ARG.SZ,,.STLEA],,SETLEA] ;LIMIT-EXCEED-ACTION
XWD .KYLP2,[[ARG.SZ+1,,.STLP2],,SETLP2] ;LP20-SIMULATION
XWD .KYMTA,[[ARG.SZ,,.STMTA],,SETMTA] ;MAGTAPE
XWD .KYOPL,[[ARG.SZ+1,,.STOPL],,SETOPL] ;OUTPUT-LIMITS
XWD .KYPGL,[[ARG.SZ+1,,.STPGL],,SETPGL] ;PAGE-LIMITS
XWD .KYPRL,[[ARG.SZ+1,,.STPRI],,SETPRI] ;PRIORITY-LIMITS
XWD .KYUTY,[[ARG.SZ+1,,.STUTY],,SETUTY] ;UNIT-TYPE
CDPCNT==.-CDPDSP
LPTCNT==.-LPTDSP
PLTCNT==.-PLTDSP
PTPCNT==.-PTPDSP
;FAL-STREAM Dispatch Table
FALDSP: XWD .KYNET,[[ARG.SZ,,.STNTY],,SETNTY] ;NETWORK-TYPE
FALCNT==.-FALDSP
;NETWORK-QUEUE-CONTROLLER dispatch table
NQCDSP: XWD .KYATR,[[ARG.SZ+1,,.STATR],,SETNQX] ;ATTRIBUTE
NQCCNT==.-NQCDSP
SUBTTL Q$CLOSE Process the CLOSE LOG command
;THIS ROUTINE WILL PROCESS THE CLOSE COMMAND AND CLOSE THE LOG FILE
Q$CLOSE::
MOVX S1,FWMASK ;POINT TO ALL NODES
$CALL OPRENB ;MUST BE SYSTEM OPR
$RETIF
PUSHJ P,P$NEXT ;POINT PAST 'LOG' KEYWORD
MOVEI S1,.EVOPR ;GET LOG FILE CLOSURE EVENT CODE
SETZM S2 ;NO SWITCH PROCESSOR
PUSHJ P,EVTMSG ;GO BUILD THE EVENT MESSAGE
JUMPF .POPJ ;RETURN IF PROBLEMS
PJRST CMDEND ;SEND MESSAGE TO QUASAR
SUBTTL SETUSG Process SET USAGE command
TOPS10 <
SETUSG: SETOM S1 ;Get ALL nodes
$CALL OPRENB ;Check OPR privs
$RETIF ;Return on failure
$CALL P$KEYW
JUMPF E$IFC
MOVEI S2,USGTBL ;POINT TO KEY TABLE
$CALL TABSRC ;FIND THE KEYWORD
JUMPF E$IFC ;BAD FORMAT
MOVE S1,S2 ;COPY EVENT TYPE TO S1
SETZM S2 ;ASSUME BILLING CLOSURE
CAIE S1,.EVBIL ;WAS IT?
MOVEI S2,USGSWT ;NO, NEED DEPENDENT SWITCH PROCESSOR
PUSHJ P,EVTMSG ;CALL EVENT MESSAGE ROUTINE
JUMPF .POPJ ;RETURN IF PROBLEMS
PJRST CMDEND ;ELSE PARSE CONFIRM AND TELL QUASAR
USGSWT: $CALL P$SWITCH ;LOOK FOR A SWITCH
JUMPF .RETT ;NONE,,MIGHT STILL BE OK
CAXE S1,.SWNOS ;IS IT /NO-SESSION-ENTRIES ???
JRST [PUSHJ P,P$PREV ;NO, BACKUP PARSER AND RETURN
$RETT]
MOVX S1,US.NOS ;YES, NO SESSION ENTRY FLAG
IORM S1,EVTSWD ; AND LIGHT IT
$RETT ;RETURN
USGTBL: $STAB
.KYUBC,,.EVBIL ;BILLING-CLOSURE
.KYUFC,,.EVUSG ;FILE-CLOSURE
$ETAB
SUBTTL SETKSY Set KSYS command to stop timesharing
SETKSY: MOVEI S1,.EVKSY ;EVENT TYPE IS KSYS
MOVEI S2,KSYSWT ;SPECIAL SWITCH PROCESSOR
PUSHJ P,EVTMSG ;BUILD AN EVENT CREATE MESSAGE
JUMPF .POPJ ;FAILED
PJRST CMDEND ;CONFRM SEND SEND MESSAGE TO QUASAR
KSYSWT: PUSHJ P,P$SWIT ;GET A SWITCH
JUMPF .RETT ;IF NOT GIVE UP
MOVEI S2,KSWTAB ;GET ADDRESS OF CANNED STRING TABLE
PUSHJ P,TABSRC ;LOOK FOR CANNED REASON STRINGS
JUMPF [PUSHJ P,P$PREV ;BACKUP PARSER FOR EVENT SWITCH PARSER
$RETT] ;RETURN
MOVE S1,S2 ;GET ADDRESS OF FAKE TEXT BLOCK
HLRZ S2,(S2) ;GET LENGTH OF FAKE TEXT BLOCK
PUSHJ P,MOVARG ;COPY REASON TEXT TO MESSAGE
$RETT ;AND RETURN
;Canned reason switch text table
KSWTAB: $STAB
.SWCM,,[XWD 7,.QBMSG
ASCIZ\Corrective system maintenance\]
.SWNEW,,[XWD 5,.QBMSG
ASCIZ\New monitor\]
.SWPM,,[XWD 7,.QBMSG
ASCIZ\Preventive system maintenance\]
.SWSA,,[XWD 7,.QBMSG
ASCIZ\System will be stand alone\]
.SWSCH,,[XWD ^D8,.QBMSG
ASCIZ\Scheduled system shutdown\]
$ETAB
SUBTTL SET SYSTEM PARAMETER COMMAND
SETSYS: PUSHJ P,P$KEYW ;GET NEXT KEYWORD
JUMPF E$IFC ;BOMB IF NO KEYWORD FOUND
MOVEI S2,SETTAB ;GET TABLE TO SEARCH
PUSHJ P,TABSRC ;LOOK FOR PROCESSING ROUTINE
JUMPF E$IFC ;COMPLAIN IF NOT FOUND
PJRST (S2) ;JUMP TO PROCESSING ROUTINE
SETTAB: $STAB
.KYBMX,,SETBMX ;SET SYSTEM BATMAX
.KYBMN,,SETBMN ;SET SYSTEM BATMIN
.KYCMX,,SETCMX ;SET SYSTEM CORMAX
.KYCMN,,SETCMN ;SET SYSTEM CORMIN
.KYDAT,,SETDAT ;SET SYSTEM DATE
.KYDAY,,SETDAY ;SET SYSTEM DAYTIME
.KYLMX,,SETLMX ;SET SYSTEM LOGMAX
.KYSCD,,SETSCD ;SET SYSTEM SCHEDULE
.KYCSZ,,SETCSZ ;SET SYSTEM DISK-CACHE-SIZE
$ETAB
SUBTTL SET BATMAX, BATMIN, and LOGMAX Commands
;Process SET BATMAX
SETBMX: PUSHJ P,SETCOM ;EXECUTE SOME COMMON CODE
$RETIF ;SOME PROBLEMS
MOVE T1,S2 ;SAVE JOBMAX
MOVEI S2,[ASCIZ\BATMAX\] ;GET SOME TEXT FOR TYPEOUT
PUSHJ P,BATCOM ;DO COMMON RANGE CHECK
JUMPF .RETT ;JUS RETURN IT ERROR
CAILE S1,(T1) ;GREATER THAN JOBMAX??
JRST [MOVEI S2,SETIBN ;BATMAX TOO BIG
JRST SETX.1]
HRLI S1,.STBMX ;NO, BUILD AC FOR UUO
PJRST SETXCT ;GO DO THE SETUUO
;Process SET BATMIN
SETBMN: PUSHJ P,SETCOM ;EXECUTE THE COMMON CODE
$RETIF ;RETURN IF PROBLEMS
MOVE T1,S2 ;SAVE JOBMAX
MOVEI S2,[ASCIZ\BATMIN\] ;GET SOME TEXT FOR TYPEOUT
PUSHJ P,BATCOM ;DO COMMON RANGE CHECK
JUMPF .RETT ;RETURN IF ERROR
CAILE S1,-1(S2) ;MUST BE LESS THAN JOBMAX-1
JRST [MOVEI S2,SETIBN ;INVALID BATMIN VALUE
JRST SETX.1]
HRLI S1,.STBMN ;GET SET BATMIN FUNCTION CODE
PJRST SETXCT ;GO DO THE SETUUO
SETIBN: ITEXT (< ^T/@G$ARG1##/ must be less than current JOBMAX of ^D/G$ARG3##/ ^0>)
;Common BATMAX, BATMIN code
BATCOM: MOVEM S2,G$ARG1## ;SAVE IT
CAIL S1,0 ;RANGE CHECK
CAIL S1,INPMAX ; QUASAR'S MAXIMUM
SKIPA S2,[SETIBV] ;GET ADDRESS OF ERROR ITEXT
$RETT
PUSHJ P,SETX.1 ;GO COMPLAIN
$RETF
SETIBV: ITEXT (< Specified ^T/@G$ARG1##/ value, ^D/G$ARG2##/, out of range 0:^D/[INPMAX-1]/ ^0>)
;Process SET LOGMAX
SETLMX: PUSHJ P,SETCOM ;EXECUTE THE COMMON CODE
$RETIF ;RETURN IF FALSE
MOVEI T1,[ASCIZ\LOGMAX\] ;GET SOME TEXT FOR TYPEOUT
MOVEM T1,G$ARG1## ;SAVE IT
CAIL S1,1 ;RANGE CHECK
CAILE S1,(S2)
JRST [MOVEI S2,SETLIR ;GET ITEXT ADDRESS
JRST SETX.1]
HRLI S1,.STLMX ;GET SET LOGMAX FUNCTION CODE
;FALL INTO CODE TO DO SETUUO
;Common code to do SETUUO for SET BATMAX, BATMIN, and LOGMAX commands.
SETXCT: SETUUO S1, ;DO THE SETUUO
SKIPA S2,SETERR(S1) ;GET ERROR ITEXT ADDRESS
MOVEI S2,SETAOK ;LOAD ADDRESS OF SET OK TEXT
SETX.1: MOVEI S1,^D50 ;50 WORDS ENOUGH FOR BUFFER
PJRST GENACK ;GO ACK THE OPR
SETLIR: ITEXT (< LOGMAX must be in range 1:^D/G$ARG3##/ (JOBMAX) ^0>)
;Common subroutine for SET BATMAX, BATMIN, and LOGMAX commands.
;
;RETURNS TRUE S1/ Command argument (integer)
; S2/ Number of jobs monitor built for (JOBN)
;RETURNS FALSE If invalid command format or OPR not priv'd
SETCOM: MOVE S1,G$HOST ;GET HOST NAME
PUSHJ P,OPRENB ;CHECK PRIVS
$RETIF ;TOO BAD
PUSHJ P,P$NUM ;GET THE ARGUMENT
JUMPF E$IFC ;COMPLAIN IF BAD COMMAND
MOVEM S1,G$ARG2## ;SAVE FOR TYPEOUT
PUSHJ P,P$CFM ;VALIDATE LAST PART OF COMMAND
JUMPF E$IFC ;COMPLAIN IF BAD COMMAND
MOVE S2,[EXP %CNSJN] ;GET MAXIMUM NUMBER OF JOBS
GETTAB S2,
PJRST E$IFC ;SHOULD NOT HAPPEN
MOVEI S2,-1(S2) ;KEEP RH ONLY (ONE LESS FOR NULL JOB)
MOVEM S2,G$ARG3## ;SAVE FOR TYPEOUT
MOVE S1,G$ARG2## ;GET COMMAND ARG BACK
$RETT ;RETURN TO CALLER
SUBTTL SETCMX/SETCMN - Process SET SYSTEM CORMAX and SET SYSTEM CORMIN Commands
SETCMX: SKIPA P1,[EXP .STCXP] ;GET SET CORMAX (PAGES) FUNCTION CODE
SETCMN: MOVEI P1,.STCNP ;GET SET CORMIN (PAGES) FUNCTION CODE
MOVE S1,G$HOST ;CHECK OPR PRIVS
PUSHJ P,OPRENB
$RETIF
PUSHJ P,CORWDS ;GET USER ARG IN NUMBER OF WORDS
JUMPF E$IFC ;COMPLAIN IF PROBLEMS
MOVEM S1,G$ARG2## ;SAVE
MOVEM S2,G$ARG3## ;SAVE "K" OR "P"
PUSHJ P,P$CFM ;SEE IF CONFIRMED
JUMPF E$IFC ;COMPLAIN IF NOT
CAIE P1,.STCXP ;SETTING CORMAX?
JRST SETC.1 ;NO, GO DO SOME CORMIN CHECKS
MOVEI S2,[ASCIZ\CORMAX\] ;GET TEXT FOR ERROR TYPEOUT
MOVEM S2,G$ARG1## ;SAVE IT
MOVE S2,[%VMRMC] ;ASK MONITOR FOR MAXIMUM VALUE
JRST SETC.2 ;JUMP TO COMMON CODE AGAIN
SETC.1: MOVEI S2,[ASCIZ\CORMIN\] ;GET TEXT FOR TYPEOUT
MOVEM S2,G$ARG1## ;SAVE IT
MOVE S2,[%NSCMX] ;CORMIN CAN'T BE GREATER THAN CORMAX
SETC.2: GETTAB S2, ;GET MAXMAX OR CORMAX
MOVE S2,[<^D512*^D512>-1] ;SIGH, USE A REASONABLE DEFAULT
MOVE S1,G$ARG2## ;GET VALUE OPR REQUESTED
CAMLE S1,S2 ;ASKING FOR TOO MUCH?
SOS S1,S2 ;YES, SET TOO MAXIMUM ALLOWED
ADR2PG S1 ;CONVERT FROM WORDS TO PAGES
CAIN P1,.STCXP ;SETTING CORMAX?
TRO S1,400000 ;WANT "SOFT" CORMAX
HRL S1,P1 ;SET UP AC FOR UUO
SETUUO S1, ;DO THE UUO
JRST SETC.3 ;MUST BE NO PRIVS
CAIE P1,.STCXP ;SET CORMAX?
SKIPA S1,[%NSCMN] ;NO, GET INDEX FOR CORMIN
MOVE S1,[%NSCMX] ;YES, GET INDEX FOR CORMAX
GETTAB S1, ;ASK THE MONITOR
MOVE S1,G$ARG2## ;ASSUME IT SET WHAT WAS ASKED FOR
MOVNI S2,^D9 ;GET WORDS TO PAGES LSH ARG
MOVEI TF,"P" ;ASSUME PAGES
CAME TF,G$ARG3## ;WAS IT?
SOS S2 ;NO, BETTER BE "K"
LSH S1,(S2) ;CONVERT TO SAME UNITS AS ENTERED
MOVEM S1,G$ARG2## ;SAVE CURRENT VALUE AGAIN
SKIPA S2,[[ITEXT(< Set accepted, ^T/@G$ARG1##/ is now ^D/G$ARG2##/^7/G$ARG3##/ ^0>)]]
MOVEI S2,NOPRVS
TRNA
SETC.3: MOVE S2,SETERR(S1) ;GET SETUUO ERROR CODE ITEXT ADDRESS
MOVEI S1,^D50 ;250 CHARS SHOULD BE ENOUGH FOR TEXT
PJRST GENACK ;GO SETUP ACK AND RETURN
SUBTTL CORWDS - Parse Core Argument in SET SYSTEM CORMAX/CORMIN Commands
;CORWDS - Routine used by SETCMX and SETCMN to parse OPR core argument
;specified in the SET SYSTEM CORMAX/CORMIN commands.
;
; Returns: S1/ amount of core in words
; S2/ "K" or "P" (for pretty typeout)
;
; Returns FALSE if parse fails
CORWDS: PUSHJ P,P$FLD ;GET ARG USER TYPED
$RETIF
AOS S1 ;BUMP PAST TEXT HEADER WORD
HRLI S1,(POINT 7,0) ;BUILD A BYTE POINTER
MOVEI S2,^D10 ;GET RADIX
PUSHJ P,S%NUMI ;READ THE NUMBER
$RETIF ;RETURN IF PROBLEMS
PUSHJ P,.SAVE1 ;SAVE P1
EXCH S1,S2 ;S1=NUMBER, S2=UPDATED BYTE POINTER
LDB TF,S2 ;GET CHAR THAT TERMINATED NUMBER SCAN
MOVEI P1,^D9 ;GET PAGES TO WORDS LSH ARG
JUMPE TF,CORW.1 ;IF JUST NUMBER, ASSUME ARG IS IN "K"
ILDB S2,S2 ;GET ANOTHER CHAR, IF THERE
JUMPN S2,.RETF ;ONLY 1 CHAR CAN FOLLOW NUMBER
CAIE TF,"P" ;CHECK FOR "P"AGES
CAIN TF,"p"
JRST CORW.2 ;HE DID SAY "P"
CAIE TF,"K" ;HOW 'BOUT "K"
CAIN TF,"k"
CORW.1: AOSA P1 ;HE SAID "K", NEED TO SHIFT ONE MORE
$RETF
CORW.2: LSH S1,(P1) ;CONVERT ARGUMENT TO WORDS
MOVE S2,TF ;GET "K" OR "P"
JUMPE S2,CORW.3 ;IF NONE, ASSUME "K"
CAILE S2,"P" ;UPPER CASE?
SUBI S2," " ;NO, MAKE IT UPPER CASE
$RETT ;RETURN
CORW.3: MOVEI S2,"K" ;ASSUME "K"
$RETT ;RETURN
SUBTTL SETDAT - Process SET SYSTEM DATE Command
SETDAT: PUSHJ P,P$TIME ;GET DATE IN UDT FORMAT
JUMPF E$IFC ;COMPLAIN IF PROBLEMS
MOVE P1,S1 ;SAVE UDT
PUSHJ P,P$CFM ;MAKE SURE CONFIRMED
JUMPF E$IFC
MOVEI S1,[ASCIZ\DATE\] ;GET TEXT FOR ERROR TYPEOUT
MOVEM S1,G$ARG1## ;SAVE IT
MOVE S1,P1 ;GET UDT BACK
PUSHJ P,S%U2DT ;GET DATE IN PROPER FORMAT
HRLI S2,.STDAT ;GET SET DATE CODE
SETUUO S2, ;SET THE DATE
SKIPA S2,SETERR(S2) ;GET ERROR TEXT
MOVEI S2,[ITEXT(< Set accepted, current date is now ^H9/[-1]/ ^0>)]
MOVEI S1,^D50 ;GET 50 WORDS FOR BUFFER
PJRST GENACK ;GENERATE ACK AND RETURN
SUBTTL SETDAY - Process SET SYSTEM DAYTIME Command
SETDAY: PUSHJ P,P$TIME ;GET UDT OF TIME
JUMPF E$IFC ;LEAVE IF NOT THERE
MOVE P1,S1 ;COPY UDT
PUSHJ P,P$CFM ;SEE IF CONFIRMED
JUMPF E$IFC
MOVEI S1,[ASCIZ\DAYTIME\] ;GET ADDRESS OF SOME TYPEOUT TEXT
MOVEM S1,G$ARG1## ;SAVE IT
HRRZ S1,P1 ;JUST GET TIME-PAST-MIDNIGHT
PUSHJ P,.UD2SC## ;CONVERT TO SECONDS
HRLI S1,.STTMS ;GET SET TIME PAST MIDNIGHT CODE
SETUUO S1, ;SET THE TIME
SKIPA S2,SETERR(S1) ;GET THE ERROR ITEXT
MOVEI S2,[ITEXT(< Set accepted, current time is now ^C/[-1]/ ^0>)]
MOVE P1,S1 ;COPY ERROR CODE, IF ONE AT ALL
MOVEI S1,^D50 ;GET 50 WORDS FOR BUFFER
PJRST GENACK ;GENERATE ACK FOR OPR AND RETURN
SUBTTL SETSCD - Process SET SYSTEM SCHEDULE Command
SETSCD: PUSHJ P,P$NUM ;GET SCHEDULE BITS FROM OPR
JUMPF E$IFC ;COMPLAIN IF PROBLEM
MOVE P1,S1 ;SAVE NUMBER
PUSHJ P,P$CFM ;LOOK FOR CONFIRM
JUMPF E$IFC
MOVEI S1,[ASCIZ\SCHEDULE\] ;GET TEXT ADDRESS FOR TYPEOUT
MOVEM S1,G$ARG1## ;SAVE IT
TDNE P1,[777777,,776060] ;LOOK FOR INVALID BITS
JRST SETS.1 ;THERE WERE, GO COMPLAIN
MOVE S1,P1 ;COPY ARG BACK
HRLI S1,.STSCH ;GET SET SCHEDULE CODE
SETUUO S1, ;SET SCHED
SKIPA S2,SETERR(S1) ;GET ITEXT ADDRESS FOR ERROR
MOVEI S2,[ITEXT(< Set accepted, SCHEDULE is now ^O6R0/P1/ ^0>)]
TRNA
SETS.1: MOVEI S2,[ITEXT(< Illegal SCHEDULE bits in ^O/P1/, command ignored ^0>)]
MOVEI S1,^D50 ;GET 50 WORDS FOR BUFFER
PJRST GENACK ;GENERATE ACK TEXT AND RETURN
SUBTTL SETCSZ - Process SET SYSTEM DISK-CACHE-SIZE Command
SETCSZ: PUSHJ P,P$CFM ;SEE IF CONFIRM
JUMPT [MOVX P1,%LDOCS ;<CR> HERE MEANS USE CONFIGURED SIZE
GETTAB P1, ;ASK MONITOR
JRST E$IFC ;HUH?
JRST SETCS1] ;CONTINUE
PUSHJ P,P$NUM ;GET NEW CACHE SIZE
JUMPF E$IFC ;COMPLAIN IF PROBLEM
MOVE P1,S1 ;SAVE NUMBER
PUSHJ P,P$CFM ;LOOK FOR CONFIRM
JUMPF E$IFC
SETCS1: MOVEI S1,[ASCIZ\DISK-CACHE-SIZE\] ;GET TEXT ADDRESS FOR TYPEOUT
MOVEM S1,G$ARG1## ;SAVE IT
MOVE S1,P1 ;COPY ARG BACK
HRLI S1,.STCSZ ;GET SET CACHE SIZE CODE
SETUUO S1, ;SET CACHE SIZE
SKIPA S2,SETERR(S1) ;GET ITEXT ADDRESS FOR ERROR
MOVEI S2,[ITEXT(< Set accepted, DISK-CACHE-SIZE is now ^D/P1/ blocks ^0>)]
MOVEI S1,^D50 ;GET 50 WORDS FOR BUFFER
PJRST GENACK ;GENERATE ACK TEXT AND RETURN
SUBTTL GENACK - Generate ACK Text for ORION Processed OPR Commands
;GENACK - Routine to copy generate ACK text to be sent to OPR using
;the new way, i.e. putting address of ASCIZ text in G$ERR and setting
;up G$APBF and G$APFG.
;
; Call: S1/ Number of words text will need (less than a page)
; S2/ Address of ITEXT for ACK text
GENACK: PUSH P,S2 ;SAVE ADDRESS OF ITEXT
PUSHJ P,M%GMEM ;ASK GLXMEM FOR MEMORY REQUESTED
HRLM S1,G$APBF## ;SAVE NUMBER OF WORDS TO BE RETURNED
HRRM S2,G$APBF## ;SAVE ADDRESS OF ABOVE WORDS
MOVEM S2,G$ERR## ;SAVE ADDRESS OF BUFFER
POP P,S1 ;GET ITEXT ADDRESS BACK
$TEXT (<-1,,(S2)>,<^I/(S1)/^A>) ;COPY ACK TEXT TO BUFFER
MOVEI S1,'ACK' ;A NONDESCRIPT SUFFIX
MOVEM S1,G$APFG## ;SET IT FOR SPECIAL PROCESSING
$RETT ;RETURN, ACKING THE OPR
;Error messages
SETAOK: ITEXT (< Set accepted, ^T/@G$ARG1##/ is now ^D/G$ARG2##/ ^0>)
SETERR: [ITEXT (< Insufficient privileges to set ^T/@G$ARG1##/ ^0>)]
NOPRVS: [ITEXT (< Insufficient privileges to set ^T/@G$ARG1##/ ^0>)]
[ITEXT (< This error, code 2, should not happen trying to set ^T/@G$ARG1##/ ^0>)]
[ITEXT (< Illegal time specified ^0>)]
>;END TOPS10
SUBTTL SETJOB Set operator values for a job
SETJOB: MOVE S1,G$HOST ;Get host name
$CALL OPRENB ;Check OPR privs
$RETIF
$CALL P$NUM ;GET A NUMBER
$RETIF ;NO..ERROR..RETURN
MOVE P1,S1 ;SAVE NUMBER IN P1
MOVEM P1,G$ARG1 ;SAVE THE JOB NUMBER
$CALL P$KEYW ;GET THE SETTING KEYWORD
$RETIF ;ERROR...RETURN
MOVE P2,S1 ;SAVE KEYWORD IN P2
$CALL P$CFM ;COMMAND HAVE CONFIRM?
JUMPF SETJ.1 ;TRY CLASS SETTING
SETO T2, ;SET A FLAG
CAIN P2,.KYNOI ;WAS IT NO OPERATOR INTERVENTION
MOVEI T2,.OBNWR ;SET NO OPR INTERVENTION
CAIN P2,.KYOIA ;OPR INTERVENTION ALLOWED
MOVEI T2,.OBALL ;YES SET OPR INTERVENTION ALLOWED
JUMPL T2,.RETF ;INVALID FIELD..RETURN
TOPS10 <
MOVE S2,P1 ;PLACE JOB NUMBER IN S2
MOVE S1,[2,,S2] ;SET UP THE BLOCK
HRLI T1,.STWTO ;SET WTO INFO FUNCTION
HRR T1,T2 ;PLACE VALUE IN T1
JBSET. S1, ;PERFORM THE FUNCTION
PJRST E$SJN ;SET JOB NOT IMPLEMENTED
>;END TOPS10
TOPS20 <
MOVE S1,P1 ;GET THE JOB NUMBER
MOVX S2,.SJBAT ;UPDATE BATCH DATA
SETZ T1, ;CLEAR THE DATA WORD
STORE T2,T1,OB%WTO ;SAVE THE DATA
SETJB ;SET THE INFO
ERJMP E$SJN ;NOTE THE ERROR
>;END TOPS20
PJRST E$SJM ;SET JOB MODIFIED
TOPS10 <
SETJ.1: $RETF ;ILLEGAL COMMAND
>;END TOPS10
TOPS20 <
SETJ.1: CAIE P2,.KYCLS ;WAS IT CLASS?
$RETF ;NO..INVALID COMMAND
$CALL P$NUM ;GET THE CLASS VALUE
$RETIF ;ERROR..RETURN
MOVE T3,S1 ;PLACE CLASS IN BLOCK
MOVEM T3,G$ARG2 ;SAVE THE CLASS
MOVEI S1,.SKSCJ ;GET THE FUNCTION
MOVEI S2,T1 ;BLOCK IN T1
MOVEI T1,3 ;SIZE OF BLOCK
MOVE T2,P1 ;GET THE JOB NUMBER
SKED% ;DO THE FUNCTION
ERJMP SETJ.2 ;TRAP ERROR
PJRST E$SSJ ;SET SCHEDULER JOB O.K.
SETJ.2: MOVE S1,[EXP -2] ;GET LAST -20 ERROR
MOVEM S1,G$ARG1 ;SAVE THE VALUE
PJRST E$SJF ;SET FAILED..RETURN
>;END TOPS20
SUBTTL SETxxx Process SET PARAMETERS
SETTIM:
SETPGL:
SETOPL:
SETMEM: $CALL P$RNGE ;GET RANGE
$RETIF ;ERROR..RETURN
SETM.1: DMOVEM S1,ARG.DA(P3) ;SAVE VALUES IN MESSAGE
ADDI P3,ARG.SZ+1 ;BUMP TO NEXT FREE LOCATION
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
PJRST CMDEND ;FINISH OFF COMMAND
SETPRI: $CALL P$RNGE ;GET RANGE
$RETIF ;ERROR..RETURN
MOVEM S2,G$ARG1 ;SAVE THE VALUE
CAILE S2,^D63 ;IS IT IN RANGE
PJRST E$SPI ;INVALID PRIORITY SPECIFIED
JRST SETM.1 ;FINISH OFF COMMAND
SETSOI:
SETNOI:
SETOIA: ADDI P3,1 ;BUMP TO NEXT LOCATION
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
PJRST CMDEND ;FINISH OFF COMMAND
SETLP2: MOVE S1,[.OFLNO,,.OFLYE] ;SET LP20 SIMULATION
SKIPE NOFLAG ;"NO" TYPED?
MOVSS S1 ;YES
HRRZM S1,ARG.DA(P3) ;SAVE SIMULATION TYPE IN MESSAGE
ADDI P3,ARG.SZ ;BUMP TO NEXT LOCATION
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
PJRST CMDEND ;END THE COMMAND
;HERE TO SET UNIT-TYPE
SETUTY:!
;HERE TO SET PRINTER PARAMETERS
SETFRM: $CALL P$SIXF ;GET A 6 BIT FIELD TYPE
$RETIF ;ERROR..RETURN
MOVEM S1,ARG.DA(P3) ;SAVE FORMS NAME IN MESSAGE
ADDI P3,ARG.SZ ;BUMP TO NEXT LOCATION
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
PJRST CMDEND ;END THE COMMAND
;HERE TO HANDLE THE PROCESSOR VERB
SETATR: $CALL P$KEYW ;GET THE KEYWORD
$RETIF ;ERROR..RETURN
MOVEI S2,PRODSP ;GET PROCESSOR TABLE
$RETIF ;ERROR..RETURN
PJRST SETL.1 ;HANDLE AS LIMITED EXCEEDED
;HERE TO HANDLE LIMIT-EXCEEDED-ACTION VERB
SETLEA: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;ERROR..RETURN
MOVEI S2,LEADSP ;GET LIMIT-EXCEED ACTION TABLE
SETL.1: $CALL TABSRC ;SEARCH THE TABLE
$RETIF ;ERROR..RETURN
MOVEM S2,ARG.DA(P3) ;SAVE IN THE MESSAGE
ADDI P3,ARG.SZ ;BUMP THE POINTER
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
PJRST CMDEND ;FINISH OFF COMMAND
LEADSP: $STAB
.KYCNC,,.STCAN ;CANCEL IT
.KYASK,,.STASK ;ASK
.KYIGN,,.STIGN ;IGNORE IT
$ETAB
PRODSP: $STAB
.KYBAT,,%GENRC ;SET BATCON PROCESSOR
.KYSIT,,%SITGO ;SET SITGO PROCESSOR
$ETAB
;Here to handle NETWORK-TYPE
SETNTY: PUSHJ P,P$KEYW ;GET THE KEYWORD
$RETIF
MOVEI S2,NTYTAB ;GET KEYWORD TABLE ADDRESS
PUSHJ P,TABSRC ;LOOK FOR KEYWORD
$RETIF
MOVEM S2,ARG.DA(P3) ;SAVE IN THE MESSAGE
ADDI P3,ARG.SZ ;BUMP THE POINTER
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
PJRST CMDEND ;FINISH OFF COMMAND
NTYTAB: $STAB
.KYANF,,ST.ANF ;FAL-STREAM TYPE
.KYDCN,,ST.DCN
$ETAB
;SET MAGTAPE PARAMETERS
SETMTA: ADDI P3,ARG.SZ ;ADVANCE TO FIRST SWITCH STORAGE
AOS .OARGC(MO) ;ACCOUNT FOR NULL BLOCK
SETMT1: PUSHJ P,P$SWIT## ;GET A SWITCH
JUMPF CMDEND ;PROBABLY EOL
MOVSI S2,-MTALEN ;AOBJN POINTER
SETMT2: HLRZ TF,MTATAB(S2) ;GET BLOCK TYPE
CAIN TF,(S1) ;MATCH?
JRST SETMT3 ;YES
AOBJN S2,SETMT2 ;LOOP
$RETF ;BAD MESSAGE
SETMT3: STORE S1,ARG.HD(P3),AR.TYP ;SAVE SWITCH BLOCK TYPE IN MESSAGE
MOVEI S1,ARG.SZ ;ASSUME STANDARD TWO WORD BLOCK
STORE S1,ARG.HD(P3),AR.LEN ;SAVE IN MESSAGE
HRRZ S1,MTATAB(S2) ;GET DISPATCH ADDRESS
PUSHJ P,(S1) ;PROCESS SWITCH
JUMPT SETMT1 ;LOOP BACK FOR ANOTHER
$RETF ;ELSE GIVE UP
MTATAB: .SWMDN,,MTAMDN ;/DENSITY
.SWMDI,,MTAMDI ;/DIRECTORY-FILE
.SWMLT,,MTAMLT ;/LABEL-TYPE
.SWMRL,,MTAMRL ;/MULTI-REEL
.SWMPR,,MTAMPR ;/PARITY
.SWMTK,,MTAMTK ;/TRACKS
.SWMVS,,MTAMVS ;/VOLUME-SET
MTALEN==.-MTATAB ;LENGTH OF TABLE
;DENSITY
MTAMDN: JSP S1,MTAXXX ;SET DENSITY
$STAB
.KYDFL,,.TFD00 ;DEFAULT
.KY800,,.TFD80 ;800
.KY200,,.TFD20 ;200
.KY556,,.TFD55 ;556
.KY800,,.TFD80 ;800
.KY160,,.TFD16 ;1600
.KY625,,.TFD62 ;6250
$ETAB
;DIRECTORY-FILE
MTAMDI: MOVEI S1,MTADNY ;SET DIRECTORY-FILE
PJRST MTAXXX ;ENTER COMMON CODE
;LABEL-TYPE
MTAMLT: JSP S1,MTAXXX ;SET LABEL TYPE
$STAB
.KYDFL,,-1 ;DEFAULT
.KYANS,,%TFANS ;ANSI LABELS
.KYEBC,,%TFEBC ;EBCDIC
.KYUNL,,%TFUNL ;UNLABELED TAPE
$ETAB
;MULTI-REEL
MTAMRL: MOVEI S1,MTADNY ;SET MULTI-REEL
PJRST MTAXXX ;ENTER COMMON CODE
;PARITY
MTAMPR: JSP S1,MTAXXX ;SET PARITY
$STAB
.KYDFL,,.OBMPD ;DEFAULT
.KYODD,,.OBMPO ;ODD
.KYEVN,,.OBMPE ;EVEN
$ETAB
;TRACKS
MTAMTK: JSP S1,MTAXXX ;SET TRACKS
$STAB
.KYDFL,,.TMDRD ;DEFAULT
.KY7TK,,%TRK7 ;7-TRACKS
.KY9TK,,%TRK9 ;9-TRACKS
$ETAB
;VOLUME-SET
MTAMVS: PUSHJ P,P$QSTR## ;GET A QUOTED STRING
SKIPT ;CHECK FOR ERRORS
PUSHJ P,P$FLD## ;MAYBE JUST A FIELD
$RETIF ;RETURN IF NO QUOTED STRING OR FIELD
MOVSI S2,ARG.DA(S1) ;START OF TEXT
HRRI S2,ARG.DA(P3) ;WHERE TO PUT IT
LOAD S1,ARG.HD(S1),AR.LEN ;GET BLOCK LENGTH
ADDI S1,ARG.DA ;PLUS OVERHEAD
STORE S1,ARG.HD(P3),AR.LEN ;SET BLOCK SIZE IN MESSAGE
ADDI S1,(P3) ;COMPUTE END OF BLT
BLT S2,-1(S1) ;COPY TEXT
AOS P3,S1 ;BUMP THE POINTER
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
$RETT ;RETURN
; COMMON MAGTAPE SET ROUTINE
MTAXXX: PUSH P,S1 ;SAVE TABLE ADDRESS
PUSHJ P,P$KEYW## ;FETCH KEYWORD
POP P,S2 ;GET TABLE ADDRESS BACK
$RETIF ;CHECK FOR ERRORS
PUSHJ P,TABSRC ;LOOK FOR KEYWORD
$RETIF
MOVEM S2,ARG.DA(P3) ;SAVE IN THE MESSAGE
ADDI P3,ARG.SZ ;BUMP THE POINTER
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
$RETT ;RETURN
;DEFAULT/NO/YES TABLE
MTADNY: $STAB
.KYDFL,,.OBMRD ;DEFAULT
.KYNO ,,.OBMRN ;NO
.KYYES,,.OBMRY ;YES
$ETAB
;SET NETWORK-QUEUE-CONTROLLER
SETNQX: PUSHJ P,P$KEYW ;GET THE KEYWORD
$RETIF
MOVEI S2,NQXTAB ;GET KEYWORD TABLE ADDRESS
PUSHJ P,TABSRC ;LOOK FOR KEYWORD
$RETIF
MOVEM S2,ARG.DA(P3) ;SAVE IN THE MESSAGE
ADDI P3,ARG.SZ ;BUMP THE POINTER
AOS .OARGC(MO) ;BUMP THE ARGUMENT COUNT
PJRST CMDEND ;FINISH OFF COMMAND
NQXTAB: $STAB
.KYNQI,,%NQINP ;INPUT-STREAM
.KYNQO,,%NQOUT ;OUTPUT-STREAM
$ETAB
SUBTTL SETONL Process SET ONLINE command (TOPS20)
;THIS COMMAND IS TO INFORM SYSTEM OF A DEVICE THAT HAS BECOME
;AVAILABLE.
TOPS20 <
SETONL: MOVE S1,G$HOST ;Get host name
$CALL OPRENB ;Check OPR privs
$RETIF
MOVE P3,MO ;GET OUTPUT POINTER
MOVEI S1,[ASCIZ//] ;NULL TEXT
MOVEM S1,G$ARG1 ;SAVE THE ARGUMENT
SETOM T4 ;SET THE FLAG
SETO.1: $CALL P$NUM ;GET A NUMBER
$RETIF ;BAD COMMAND
MOVEM S1,G$ARG2 ;SAVE THE ARGUMENT
SKIPGE S1 ;IS IT O.K.
PJRST E$SIC ;INVALID CHANNEL
CAILE S1,7 ;IS IT IN RANGE
PJRST E$SIC ;SET INVALID CHANNEL
AOS P3 ;BUMP THE FIELD
MOVEM S1,(P3) ;SAVE THE DATA
$CALL P$COMMA ;CHECK FOR A COMMA
$RETIF ;ERROR..RETURN
$CALL P$NUM ;GET THE DEVICE NUMBER
$RETIF ;ERROR..RETURN
MOVEM S1,G$ARG2 ;SAVE DEVICE NUMBER
SKIPGE S1 ;IS IT VALID?
PJRST E$SID ;INVALID DEVICE
AOS P3 ;BUMP POINTER
MOVEM S1,(P3) ;SAVE THE VALUE
$CALL P$CFM ;CHECK IF DONE
JUMPF SETO.2 ;TRY FOR COMMA
AOS P3 ;BUMP FIELD
SETOM (P3) ;NO CONTROLLER -1 USED
PJRST SETO.3 ;FINISH OFF COMMAND
SETO.2: $CALL P$COMMA ;WAS IT A COMMA?
$RETIF ;BAD COMMAND
$CALL P$NUM ;GET CONTROLLER IF PRESENT
$RETIF ;NO..ERROR..RETURN
MOVEM S1,G$ARG2 ;SAVE THE VALUE
;JSYS WILL VERIFY
AOS P3 ;BUMP POINTER
MOVEM S1,(P3) ;SAVE THE VALUE
$CALL P$CFM ;CONFIRMED??
JUMPT SETO.3 ;PROCESS IT
AOSE T4 ;CHECK FLAG
$RETF ;INVALID COMMAND
MOVEI S1,[ASCIZ/Alternate /] ;GET ALTERNATE
MOVEM S1,G$ARG1 ;SAVE THE VALUE
JRST SETO.1 ;GET ALTERNATE DATA
SETO.3: MOVX S1,.DGPDL ;GET FUNCTION CODE
MOVEM S1,(MO) ;SAVE IN BLOCK
HRRZ S1,MO ;ADDRESS IN RIGHT HALF
SUBI P3,-1(MO) ;GET LENGTH OF BLOCK
MOVN P3,P3 ;MAKE IT NEGATIVE
HRL S1,P3 ;PUT LENGTH IN LEFT HALF
DIAG ;DO THE JSYS
PJRST SETO.4 ;ERROR..CHECK IT OUT
PJRST E$SOA ;SET ONLINE ACCEPTED.. RELEASE THE PAGE
SETO.4: MOVEM S1,G$ARG1 ;SAVE THE ERROR CODE
PJRST E$DJF ;DIAG JSYS FAILED
>;END TOPS20
SUBTTL SETSCH Process SET SCHEDULER command (TOPS20)
;THIS COMMAND WILL DO THE SKED% JSYS TO AFFECT THE SCHEDULER CONTROLS
;AND INFORM OPERATOR OF THE ACTION
TOPS20 <
SETSCH: MOVE S1,G$HOST ;Get local host name
$CALL OPRENB ;Check OPR privs
$RETIF
$CALL P$KEYW ;GET A KEYWORD
$RETIF ;ERROR..RETURN
MOVEI S2,SCHDSP ;SCHEDULER DISPATCH TABLE
$CALL TABSRC ;SEARCH THE TABLE
$RETIF ;ERROR..RETURN
HLRZ P1,(S2) ;GET THE FUNCTION CODE
HRRZ S2,(S2) ;GET THE ROUTINE ADDRESS
PJRST (S2) ;PROCESS THE ROUTINE AND RETURN
SCHBIA: $CALL P$NUM ;GET THE NUMBER
$RETIF ;ERROR..RETURN
MOVEI T1,2 ;BLOCK OF 2 WORDS
MOVE T2,S1 ;GET THE NUMBER
PJRST SCHED ;DO THE FUCNTION AND RETURN
SUBTTL SCHED Do the SKED% JSYS (TOPS20)
;THIS ROUTINE WILL DO THE SCHEDULE FUNCTION WITH P1 CONTAINING THE
;FUNCTION CODE
SCHED: MOVEI T1,2 ;MINIMUM SIZE BLOCK
SCHED1: MOVE S1,P1 ;GET THE FUNCTION
MOVEI S2,T1 ;ADDRESS OF THE BLOCK
SKED% ;DO THE JSYS
ERJMP SCHED2 ;SHOW ERROR
PJRST E$SSS ;BIAS SET ..RETURN AND RELEASE PAGE
SCHED2: MOVE S2,[EXP -2] ;LAST -20 ERROR CODE
MOVEM S2,G$ARG1 ;SAVE THE CODE
PJRST E$SSF ;SET BIAS FAILED
SCHDSP: $STAB
.KYBAT,,[.SKBCS,,SCHBAT] ;SET SCHED BATCH
.KYBIA,,[.SKSBC,,SCHBIA] ;SET SCHED BIAS
.KYCLS,,[.SKSCS,,SCHCLS] ;SET SCHED CLASS
$ETAB
>;END TOPS20
SUBTTL SCHBAT Process SET SCHEDULER BATCH command (TOPS20)
TOPS20 <
SCHBAT: $CALL P$NUM ;GET THE BATCH CLASS
JUMPF SCHB.1 ;TRY KEYWORDS
MOVE T2,S1 ;GET THE CLASS NUMBER
PJRST SCHED ;DO THE SCHED JSYS
SCHB.1: $CALL P$KEYW ;IS IT A KEYWORD?
$RETIF ;ERROR..RETURN
CAIE S1,.KYNON ;NONE?
JRST SCHB.2 ;TRY BACKGROUND
SETOM T2 ;NON-ZERO VALUE
$CALL SCHED ;DO THE FUNCTION
MOVEI P1,.SKBBG ;CLEAR DREGS SETTING ALSO
SETZM T2 ;CLEAR THE VALUE
PJRST SCHED ;DO THE FUNCTION AND RETURN
SCHB.2: CAIE S1,.KYBCK ;WAS IT BACKGROUND
$RETF ;NO..RETURN FALSE
MOVEI P1,.SKBBG ;SET BACKGROUND
SETOM T2 ;NON-ZERO..BACKGROUND
PJRST SCHED ;DO THE FUNCTION
>;END TOPS20
SUBTTL SCHCLS Process SET SCHEDULER CLASS command (TOPS20)
TOPS20 <
SCHCLS: $CALL P$NUM ;GET THE CLASS NUMBER
$RETIF ;ERROR..RETURN
MOVE T2,S1 ;SAVE THE VALUE
$CALL P$NUM ;GET THE PERCENT
$RETIF ;ERROR..RETURN
FLTR S1,S1 ;FLOAT THE NUMBER
FDVRI S1,(100.) ;CONVERT TO NUMBER FROM PERCENT
MOVE T3,S1 ;SAVE THE SHARE
MOVEI T1,3 ;GET THE LENGTH
PJRST SCHED1 ;DO THE FUNCTION
>;END TOPS20
SUBTTL SETNOD Process SET NODE command (DN60)
;THIS COMMAND WILL PASS A PARTICULAR VALUE FOR A DN60 OPTION
IFN FTDN60,<
SETNOD: MOVE S1,G$HOST ;Get host name
$CALL OPRENB ;Check OPR privs
$RETIF
$CALL P$NODE ;BETTER HAVE NODE VALUE
$RETIF ;ERROR..RETURN
$CALL SAVNOD ;SAVE THE NODE
$CALL P$KEYW ;CHECK FOR A KEYWORD
$RETIF ;ERROR..RETURN
MOVEI S2,SETNDP ;GET TABLE ADDRESS
$CALL TABSRC ;SEARCH THE TABLE
$RETIF ;ERROR..RETURN
HLRZ P1,(S2) ;GET BLOCK VALUE IN P1
HRRZ S2,(S2) ;GET ROUTINE ADDRESS
PJRST (S2) ;PROCESS FUNCTION AND RETURN
SETNDP: $STAB
XWD .KYBPM,[.STBPM,,SETBPM] ;BYTES PER MESSAGE
XWD .KYCSD,[.STCSD,,SETCSD] ;CLEAR-SEND-DELAY
XWD .KYDTR,[.STDTR,,SETDTR] ;DATA TERMINAL READY
XWD .KYRPM,[.STRPM,,SETRPM] ;RECORDS PER MESSAGE
XWD .KYSWL,[.STSWL,,SETSWL] ;SILO WARNING LEVEL
XWD .KYTOU,[.STTOU,,SETTOU] ;TIMEOUT CATEGORY
XWD .KYTRA,[.STTRA,,SETTRA] ;TRANSPARANCY
$ETAB
;ALL ROUTINES CALLED WITH FUNCTION CODE IN P1
;SET CLEAR TO SEND DELAY
SETBPM:
SETRPM:
SETSWL:
SETCSD: $CALL P$NUM ;GET THE VALUE
$RETIF ;ERROR..RETURN
MOVEM S1,ARG.DA(P3) ;SAVE THE DATA
SETFIN: MOVE S1,P1 ;GET THE BLOCK TYPE
MOVX S2,ARG.SZ ;BLOCK SIZE
$CALL ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH AND SEND COMMAND
SETTRA:
SETDTR: $CALL P$KEYW ;GET THE KEYWORD
$RETIF ;ERROR..RETURN
SETZ T1, ;SET A FLAG
CAIN S1,.KYON ;WAS IT ON
MOVX T1,ST.ON ;SET ON
CAIN S1,.KYOFF ;WAS IT OFF
MOVX T1,ST.OFF ;SET OFF
JUMPE T1,.RETF ;NONE..ERROR..RETURN
MOVEM T1,ARG.DA(P3) ;SAVE THE VALUE
PJRST SETFIN ;FINISH SET COMMAND
SETTOU: $CALL P$KEYW ;GET THE KEYWORD
$RETIF ;ERROR..RETURN
SETZ T1, ;SET A FLAG
CAIN S1,.KYPRI ;WAS IT PRIMARY
MOVX T1,ST.PRI ;SET PRIMARY
CAIN S1,.KYSEC ;WAS IT SECONDARY
MOVX T1,ST.SEC ;SET SECONDARY
JUMPE T1,.RETF ;NONE..ERROR..RETURN
MOVEM T1,ARG.DA(P3) ;SAVE THE VALUE
PJRST SETFIN ;FINISH THE COMMAND
SETSON:
SETNSN: MOVE S1,P1 ;GET THE FUNCTION CODE
MOVEI S2,1 ;GET THE BLOCK SIZE
$CALL ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH AND SEND COMMAND
>;END FTDN60
SUBTTL SETDSK Process SET DISK command (TOPS20)
TOPS20 <
SETDSK: MOVE S1,G$HOST ;Get local host name
$CALL OPRENB ;Check OPR privs
$RETIF
MOVX S1,.ODSDK ;SET DISK COMMAND FOR -20
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE IN HEADER
$CALL P$KEYW ;GET A KEYWORD
$RETIF ;ERROR..RETURN
CAIE S1,.KYCHN ;WAS IT A CHANNEL
$RETF ;NO..RETURN
$CALL P$NUM ;GET THE NUMBER
$RETIF ;NO..ERROR
MOVEM S1,ARG.DA(P3) ;SAVE CHANNEL NUMBER
MOVEM S1,G$ARG1 ;SAVE NUMBER FOR POSSIBLE ERROR
SKIPGE S1 ;VALID CHANNEL NUMBER
PJRST E$ICN ;INVALID CHANNEL NUMBER
$CALL P$KEYW ;GET NEXT ITEM
$RETIF ;BETTER BE DRIVE NUMBER
CAIE S1,.KYDRV ;IS IT?
$RETF ;NO..RETURN FALSE
$CALL P$NUM ;GET DRIVE NUMBER
$RETIF ;NO..ERROR..RETURN
MOVEM S1,ARG.DA+1(P3) ;SAVE THE DRIVE NUMBER IN BLOCK
MOVEM S1,G$ARG1 ;SAVE NUMBER IN CASE OF ERROR
SKIPGE S1 ;IS IT VALID
PJRST E$DDI ;DISK DRIVE INVALID
MOVX S1,.DSKDV ;DISK DRIVE BLOCK
MOVEI S2,3 ;3 WORDS
$CALL ARGRTN ;SAVE THE ARGUMENT
$CALL SETAVL ;GET SET AVALIABLE FUNCTION
JUMPT CMDEND ;END THE COMMAND AND SEND TO QUASAR
$RET ;RETURN PASSING ERROR UP
>;END TOPS20
SETAVL: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;ERROR..RETURN
SETOM T1 ;FLAG FOR CHECKING VALUES
CAIN S1,.KYAVA ;AVAILABLE?
MOVX T1,.DVAVL ;SET DEVICE AVAILABLE BLOCK
CAIN S1,.KYUAV ;UNAVAILABLE?
MOVX T1,.DVUAV ;SET DEVICE UNAVAILABLE
SKIPGE T1 ;IS ONE SET
$RETF ;NO..ERROR..RETURN
MOVE S1,T1 ;BLOCK TYPE IN 1
MOVEI S2,1 ;BLOCK SIZE OF 1
$CALL ARGRTN ;SAVE THE BLOCK
CAIE T1,.DVUAV ;UNAVAILABLE??
$RETT ;NO..RETURN TRUE
$CALL PREASN ;PROCESS THE REASON
$RET ;PASS THE RETURN BACK
SUBTTL SETTAP Process SET TAPE command (TOPS20)
SETTAP: MOVE S1,G$HOST ;Get local host
$CALL OPRENB
$RETIF
MOVX S1,.ODSTP ;SET TAPE COMMAND FOR -20
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE IN HEADER
$CALL P$DEV ;GET DEVICE BLOCK
$RETIF ;RETURN FALSE
DMOVE T1,S1 ;SAVE THE ARGUMENTS
$CALL GETDES ;GET DEVICE DESIGNATOR
$RETIF ;RETURN IF NOT A DEVICE
TXNN S2,DV%DTA ;DECTAPE?
TXNE S2,DV%MTA ;MAGTAPE?
SKIPA ;LET EITHER THROUGH
PJRST E$ITD ;INVALID TAPE DRIVE
DMOVE S1,T1 ;RESTORE S1 AND S2
MOVX T1,.TAPDV ;TAPE DEVICE BLOCK
STORE T1,ARG.HD(S1),AR.TYP ;SAVE THE TYPE
PUSHJ P,MOVARG ;MOVE THE BLOCK AND DATA
$CALL SETAVL ;SETUP AVAILABLE,UNAVAILABLE BLOCK
JUMPT CMDEND ;O.K.. FINISH THE COMMAND
PJRST SETINI ;TRY INITIALIZE
SUBTTL PSTAPE Process tape drive argument
;THIS ROUTINE WILL CHECK FOR A DEVICE AND A TAPE DRIVE AND
;SAVE A .TAPDV BLOCK IN THE MESSAGE
PSTAPE: $CALL P$DEV ;GET DEVICE BLOCK
$RETIF ;RETURN FALSE
PSTA.1: SKIPN ARG.DA(S1) ;[77] DEVICE BETTER NOT BE ZERO!!!!
STOPCD (PBI,HALT,,<P$DEV blew it>) ;[77] (SIGH) SOME PARSER
$CALL GETTAP ;GET A TAPE DEVICE
$RETIF ;NO..ERROR..RETURN
MOVX T1,.TAPDV ;TAPE DEVICE BLOCK
STORE T1,ARG.HD(S1),AR.TYP ;SAVE THE TYPE
PJRST MOVARG ;MOVE THE BLOCK AND RETURN
SUBTTL PSTRUC Process structure argument
;THIS ROUTINE WILL SAVE A STRUCTURE BLOCK IN THE MESSAGE
PSTRUC: $CALL P$DEV ;GET THE DEVICE
$RETIF ;ERROR..RETURN
MOVX T1,.STRDV ;STRUCTURE TYPE
STORE T1,ARG.HD(S1),AR.TYP ;SAVE THE TYPE IN BLOCK
PJRST MOVARG ;MOVE THE BLOCK AND RETURN
SUBTTL PVOLID Process volume-id argument
;THIS ROUTINE WILL BUILD A VOLUME ID BLOCK
PVOLID: $CALL P$QSTR ;CHECK FOR QUOTED STRING
JUMPT PVOL.1 ;YES..PROCESS IT
$CALL P$FLD ;CHECK FOR FIELD
$RETIF ;ERROR..RETURN
PVOL.1: MOVX T1,.VOLID ;VOLUME ID
STORE T1,ARG.HD(S1),AR.TYP ;SAVE THE TYPE
PJRST MOVARG ;MOVE THE BLOCK AND RETURN
SUBTTL PSDEVI Process a device argument
PSDEVI: $CALL P$DEV ;GET DEVICE BLOCK
$RETIF ;RETURN FALSE
DMOVE T1,S1 ;SAVE THE ARGUMENTS
$CALL GETDES ;GET THE DEVICE DESIGNATOR
JUMPF E$IDS ;NO..ERROR..RETURN
MOVE S1,T1 ;[75] RESTORE ARGUMENTS AND SAVE
EXCH S2,T2 ;[75] DEVCHR BITS
MOVX T1,.CMDEV ;TAPE DEVICE BLOCK
STORE T1,ARG.HD(S1),AR.TYP ;SAVE THE TYPE
$CALL MOVARG ;[75] MOVE THE BLOCK
MOVE S1,T2 ;[75] GET DEVCHR BITS
$RET ;[75] RETURN
SUBTTL SETINI Process SET TAPE INITIALIZE command
;THIS COMMAND WILL BUILD A MESSAGE FOR THE TAPE PROCESSOR
;CONTAINING THE NECESSAY INFO FOR INITIALIZING TAPES
SETINI: CAIE S1,.KYINI ;WAS IT INITIALIZE
$RETF ;NO..RETURN FALSE
MOVEI S1,.DVINI ;DEVICE INITIALIZE
MOVEI S2,1 ;GET THE TYPE
$CALL ARGRTN ;SAVE THE ARGUMENT
SETI.1: $CALL P$SWITCH ;GET A SWITCH
JUMPF CMDEND ;END THE COMMAND
MOVEI S2,SETIDP ;ADDRESS OF THE TABLE
$CALL TABSRC ;SEARCH THE TABLE
$RETIF ;PASS ERROR UP
SETI.3: HLRZ P1,(S2) ;GET BLOCK TYPE
HRRZ S2,(S2) ;GET ROUTINE ADDRESS
JRST (S2) ;PROCESS ROUTINE
SETIDP: $STAB
TOPS10< .KYCNC,,[0,,SETABO] ;/ABORT >
.SWDEN,,[.SIDEN,,SETDEN] ;/DENSITY
.SWLBT,,[.SILBT,,SETLBT] ;/LABEL-TYPE
.SWOVR,,[.SIOVR,,SETOVR] ;/OVERIDE-EXPIRATION
.SWOWN,,[.SIOWN,,SETOWN] ;/OWNER
.SWPRO,,[.SIPRO,,SETPRO] ;/PROTECTION
.SWTDP,,[0,,SETTDP] ;/TAPE-DISPOSITION
.SWCNT,,[.SICTR,,SETCNT] ;/COUNT
.SWINC,,[.SIINC,,SETINC] ;/SET INCREMENT
.SWSVI,,[.SISVI,,SETSVI] ;/STARTING-VOLUME-ID
.SWVID,,[.VOLID,,SETVID] ;/VOLUME-ID
$ETAB
SUBTTL SETDEN Process /DENSITY switch
SETDEN: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;BAD COMMAND
MOVEI S2,DENTAB ;DENSITY TABLE
SETD.1: $CALL TABSRC ;SEARCH THE TABLE
$RETIF ;NO MATCH..ELSE VALUE IN S2
MOVEM S2,ARG.DA(P3) ;SAVE THE DATA
SETD.2: MOVE S1,P1 ;GET ARGUMENT TYPE
MOVX S2,ARG.SZ ;GET THE SIZE
$CALL ARGRTN ;SAVE THE ARGUMENT
JRST SETI.1 ;GET NEXT FIELD
DENTAB: $STAB
.KY160,,.TFD16 ;1600
.KY625,,.TFD62 ;6250
.KY800,,.TFD80 ;800
.KY556,,.TFD55 ;556
.KY200,,.TFD20 ;200
$ETAB
SUBTTL SETLBT Process /LABEL switch
SETLBT: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;BAD COMMAND
MOVEI S2,LBTTAB ;LABEL TYPE TABLE
JRST SETD.1 ;PROCESS ARGUMENT
LBTTAB: $STAB
.KYANS,,%TFANS ;ANSI LABELS
.KYEBC,,%TFEBC ;EBCDIC
TOPS20< .KYT20,,%TFT20> ;TOPS-20 LABELS
.KYUNL,,%TFUNL ;UNLABELED TAPE
$ETAB
SUBTTL SETOVR Process /OVERIDE switch
SETOVR: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;BAD COMMAND
MOVEI S2,OVRDSP ;OVERIDE TABLE
SETOV1: $CALL TABSRC ;SEARCH THE TABLE
$RETIF ;PASS ERROR UP
MOVE S1,S2 ;FUNCTION CODE
MOVEI S2,1 ;ARGUMENT TYPE
$CALL ARGRTN ;SAVE THE ARGUMENT
JRST SETI.1 ;GET THE NEXT ONE
OVRDSP: $STAB
.KYYES,,.SIOVR ;OVERIDE EXPIRATION
.KYNO,,.SINOV ;NO OVERIDE
$ETAB
SUBTTL SETOWN Process /OWNER switch
SETOWN: $CALL P$USER ;GET THE USER FIELD
$RETIF ;ERROR..RETURN
MOVEM S1,ARG.DA(P3) ;SAVE THE USER
JRST SETD.2 ;FINISH BLOCK AND CONTINUE
SUBTTL SETPRO Process /PROTECTION switch
SUBTTL SETCNT Process /COUNT switch
SUBTTL SETINC Process /INCREMENT switch
SUBTTL SETSVI Process /START switch
SETCNT:
SETINC:
SETSVI:
SETPRO: $CALL P$NUM ;GET THE NUMBER
$RETIF ;ERROR..RETURN
MOVEM S1,ARG.DA(P3) ;SAVE THE DATA
JRST SETD.2 ;FINISH BLOCK AND RETURN
SUBTTL SETTDP Process /TAPE-DISPOSITION switch
SETTDP: $CALL P$KEYW ;GET A KEYWORD
$RETIF ;BAD COMMAND
MOVEI S2,TDPDSP ;TAPE DISPOSITION TABLE
JRST SETOV1 ;FINISH IT OFF
TDPDSP: $STAB
.KYHLD,,.SIHLD ;HOLD TAPE
.KYUNL,,.SIUNL ;UNLOAD THE TAPE
$ETAB
TOPS10<
SETABO: MOVX S1,.SIABO ;GET /ABORT BLOCK
MOVEI S2,1 ;GET BLOCK LENGTH OF 1
PUSHJ P,ARGRTN ;SAVE THE BLOCK
JRST CMDEND ;FINISH AND SEND COMMAND OFF
> ;END TOPS10 CONDITIONAL
SUBTTL SETVID Process /VOLUME-ID switch
SETVID: $CALL PVOLID ;PROCESS VOLUME-ID
JUMPT SETI.1 ;O.K.. GET NEXT BLOCK
$RET ;PASS ERROR UP
SUBTTL TABSRC Table search routine
;THIS ROUTINE WILL SEARCH A TABLE FOR A SPECIFIED VALUE AND
;RETURN THE ASSOCIATED INFO
;THE TABLE ENTRIES SHOULD HAVE CODE IN LEFT HALF AND DATA IN RIGHT HALF
;AND USE $STAB TO START THE TABLE AND $ETAB TO END IT
;CALL S1/ ITEM TO LOOK FOR
; S2/ ADDRESS OF TABLE
;
;
;RETURN S1/ ITEM TO LOOK FOR
; S2/ ITEM FOUND IN TABLE
;WILL USE T1 AND T2 FOR SCRATCH
TABSRC:: HLLZ T1,(S2) ;GET THE NUMBER OF ENTRIES
MOVN T1,T1 ;MAKE IT NEGATIVE
HRRI T1,1(S2) ;ADDRESS OF THE TABLE
TABS.1: HLRZ T2,(T1) ;GET THE ENTRY
CAMN S1,T2 ;MATCH?
JRST TABS.2 ;YES..
AOBJN T1,TABS.1 ;TRY NEXT ONE
$RETF ;ERROR..RETURN
TABS.2: HRRZ S2,(T1) ;GET THE DATA
$RETT ;RETURN TRUE
SUBTTL GETDES Get device designator word
;THIS ROUTINE WILL RETURN THE DEVICE DESIGNATOR WORD FOR
;THE DEVICE BLOCK PASSED
;
;RETURN S1/ SIXBIT DEVICE NAME (TOPS10)
;RETURN S2/ DEVICE DESIGNATOR INFO
TOPS20 <
GETDES: HRROI S1,ARG.DA(S1) ;GET STRING ADDRESS
HRRZM S1,G$ARG1 ;SAVE THE POINTER
STDEV ;GET DESIGNATOR
$RETF ;RETURN FALSE
TRNE S2,400000 ;CHECK NOT MT DEVICE
PJRST E$ITD ;ERROR CODE
HLRZS S2 ;CLEAR RIGHT HALF AND PLACE IN RIGHT
SUBI S2,.DVDES ;GET TO DEVICE TYPE
$RETT ;RETURN DESIGNATOR IN S2
>;END TOPS20
TOPS10 <
INTERN GETDES
GETDES: HRROI S1,ARG.DA(S1) ;GET STRING ADDRESS
HRRZM S1,G$ARG1 ;SAVE STRING POINTER
$CALL S%SIXB ;CONVERT TO SIXBIT
MOVE S1,S2 ;COPY SIXBIT DEVICE NAME
DEVCHR S2, ;DO THE DEVCHR
SKIPN S2 ;ANY BITS
$RETF ;RETURN FALSE
$RETT ;RETURN TRUE
>;END TOPS10
SUBTTL GETTAP Get a tape device
;THIS ROUTINE WILL CHECK FOR A VALID TAPE DEVICE AND RETURN FALSE
;IF DEVICE IS NOT A TAPE DRIVE
;OTHERWISE
; S1/ ADDRESS OF BLOCK
; S2/ LENGTH OF BLOCK
GETTAP:
TOPS10 <$RETT> ;NOT NEEDED ON THE -10
TOPS20 <
DMOVE T1,S1 ;SAVE THE ARGUMENTS
$CALL GETDES ;GET THE DESIGNATOR
JUMPF E$ITD ;ERROR ..RETURN
CAIE S2,.DVMTA ;IS IT MTA
JRST GETT.1 ;SETUP ERROR RETURN
DMOVE S1,T1 ;RESTORE S1 AND S2 FROM P$DEV RETURN
$RETT ;RETURN TRUE
GETT.1: DMOVE S1,T1 ;RESTORE DEVICE DATA
$RETF ;RETURN FALSE
>;END TOPS20
SUBTTL SETSTR Process SET STRUCTURE command (TOPS20)
TOPS20 <
SETSTR: MOVE S1,G$HOST ;Get local host
$CALL OPRENB ;Check OPR privs
$RETIF
MOVX S1,.ODSST ;SET STRUCTURE COMMAND FOR -20
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE IN HEADER
$CALL PSTRUC ;PROCESS A STRUCTURE BLOCK
$RETIF ;ERROR..RETURN
$CALL P$KEYW ;GET THE OPTIONS
$RETIF ;ERROR..RETURN
MOVEI S2,STRDSP ;STRUCTURE DISPATCH TABLE
$CALL TABSRC ;SEARCH THE TABLE
$RETIF ;ERROR..RETURN
MOVEM S2,ARG.DA(P3) ;SAVE VALUE IN BLOCK
MOVX S1,.STCHR ;STRUCTURE CHARACTERISTICS
MOVEI S2,2 ;SIZE OF BLOCK
$CALL ARGRTN ;BUILD BLOCK
PJRST CMDEND ;CHECK FOR END AND SEND TO QUASAR
STRDSP: $STAB
.KYACK,,S.ACKN ;ACKNOWLEDGED
.KYAVA,,S.AVAL ;AVAILABLE
.KYDOM,,S.DOMS ;DOMESTIC
.KYFOR,,S.FORN ;FOREIGN
.KYREG,,S.REGU ;REGULATED
.KYUAV,,S.UAVL ;UNAVAILABLE
.KYURG,,S.UREG ;UNREGULATED
.KYIGN,,S.IGNO ;IGNORE
$ETAB
>;END TOPS20
SUBTTL Q$SHWS Process SHOW STATUS command
;THIS ROUTINE WILL SEND A SHOW STATUS MESSAGE TO QUASAR
Q$SHWS:: MOVX S1,.OMSHS ;GET THE SHOW STATUS CODE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE CODE
PJRST PROSHW ;PROCESS SHOW MESSAGE
SUBTTL Q$SHWP Process SHOW PARAMETERS command
;THIS ROUTINE WILL SEND A SHOW PARAMETERS MESSAGE TO QUASAR
Q$SHWP:: MOVX S1,.OMSHP ;GET SHOW PARAMTERS CODE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE TIE TYPE CODE
PJRST PROSHW ;PROCESS SHOW MESSAGE
SUBTTL PROSHW Process SHOW STATUS and SHOW PARAMETERS
;COMMON CODE FOR SHOW STATUS AND SHOW PARAMETERS
PROSHW: $CALL CHKRMT ;See if this is a remote OPR
SETOM ARG.DA+OBJ.TY(P3) ;DEFAULT TO ALL TYPES
SETOM ARG.DA+OBJ.UN(P3) ;DEFAULT FOR ALL UNITS
SETOM ARG.DA+OBJ.ND(P3) ;DEFAULT FOR ALL NODES
CAME S1,G$HOST ;Did CHKRMT find the node to be host?
MOVEM S1,ARG.DA+OBJ.ND(P3) ;Save the node info
$CALL P$CFM ;CHECK FOR CONFIRM
JUMPT PROS.5 ;SAVE BLOCK AND RETURN
$CALL P$KEYW ;GET A KEYWORD..(TYPE)
JUMPF PROS.2 ;TRY FOR A SWITCH
CAIG S1,.OTMAX ;VALID OBJECT TYPE
JRST PROS.1 ;YES..GOOD OBJECT
CAIN S1,.KYDSK ;WAS IT A DISK?
PJRST SHWDSK ;PROCESS THE DISKS
CAIN S1,.KYSTR ;WAS IT A STRUCTURE
PJRST SHWSTR ;PROCESS THE STRUCTURES
CAIN S1,.KYTAP ;ALL TAPES?
PJRST SHWTAP ;PROCESS THE TAPES
CAIN S1,.KYNOD ;CHECK FOR NETWORK NODE
PJRST SHWNOD ;SHOW NODE COMMAND
$RETF ;BAD COMMAND
PROS.1: MOVEM S1,ARG.DA+OBJ.TY(P3) ;SAVE THE OBJECT TYPE
$CALL P$CFM ;END OF COMMAND?
JUMPT PROS.5 ;FINISH OFF BLOCK
PROS.2: $CALL P$SWIT ;CHECK FOR A SWITCH
JUMPF PROS.4 ;NO..TRY OBJECT BLOCK REMAINDER
CAIE S1,.SWNOD ;NODE?
JRST [$CALL PROSHT ;PROCESS SHORT IF THERE
$RETIF ;ERROR..RETURN
PJRST PROS.5] ;FINISH OFF THE BLOCK
$CALL P$NODE ;GET THE NODE
$RETIF ;ERROR..RETURN
PROS.3: MOVEM S1,ARG.DA+OBJ.ND(P3) ;SAVE NODE IN BLOCK
$CALL P$SWIT ;CHECK FOR A SWITCH
JUMPF PROS.5 ;NO..JUST SAVE OBJECT BLOCK
CAIE S1,.SWSHT ;WAS IT SHORT
$RETF ;NO..RETURN FALSE
MOVX S1,LS.FST ;GET THE FLAGS
IORM S1,.OFLAG(MO) ;SAVE IN FLAG WORD
JRST PROS.5 ;SAVE THE BLOCK AND FINISH
PROS.4: $CALL FINOBJ ;FINISH OBJECT BLOCK
$RETIF ;NO..ERROR..RETURN
$CALL P$SWIT ;SWITCH THERE?
JUMPF CMDEND ;CHECK FOR THE END
$CALL PROSHT ;PROCESS /SHORT IF THERE
$RETIF ;ERROR...RETURN
PJRST CMDEND ;CHECK FOR END AND SEND IT
PROS.5: MOVX S1,.OROBJ ;BLOCK TYPE
MOVX S2,.OBJLN ;BLOCK SIZE
$CALL ARGRTN ;SAVE THE BLOCK
ANDI P3,777 ;GET LENGTH OF MESSAGE
STORE P3,.MSTYP(MO),MS.CNT ;SAVE THE COUNT
PJRST SNDQSR ;SEND THE COMMAND
PROSHT: CAIE S1,.SWSHT ;WAS IT SHORT
$RETF ;NO..RETURN FALSE
MOVX S1,LS.FST ;GET THE FLAGS
IORM S1,.OFLAG(MO) ;SAVE IN FLAG WORD
$RETT ;RETURN TRUE
Q$SHWR:: MOVX S1,.OMSHR ;SHOW ROUTE TABLES
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE MESSAGE TYPE
MOVEI S1,.OHDRS ;JUST THE HEADER
STORE S1,.MSTYP(MO),MS.CNT ;SAVE THE COUNT
PJRST SNDQSR ;SEND TO QUASAR
Q$SHQN::MOVX S1,.OMSQN ;SHOW QUEUE-NAMES
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE MESSAGE TYPE
MOVEI S1,.OHDRS ;JUST THE HEADER
STORE S1,.MSTYP(MO),MS.CNT ;SAVE THE COUNT
PJRST SNDQSR ;SEND TO QUASAR
SUBTTL SHWNOD Process node for SHOW STATUS/PARAMETERS command
;THIS ROUTINE WILL BUILD A NODE BLOCK FOR QUASAR TO IDENTIFY THE
;NODE TO BE EXAMINED.
;IF NO NODENAME IS SPECIFIED THE DEFAULT -1 WILL BE USED.
SHWNOD: MOVX S1,.OMSSN ;SHOW STATUS NODE
LOAD S2,.MSTYP(MO),MS.TYP ;GET THE TYPE BLOCK
CAIE S2,.OMSHS ;WAS IT SHOW STATUS
MOVX S1,.OMSPN ;NO..SHOW PARAMETERS NODE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE IN BLOCK
$CALL P$NODE ;GET THE NODE DATA
SKIPT ;O.K.. CONTINUE ON
SETOM S1 ;ASSUME ALL NODES
$CALL SAVNOD ;SAVE THE VALUE
PJRST CMDEND ;END THE COMMAND AND SEND IT
SUBTTL SHWTAP Process SHOW STATUS TAPE command
;THIS ROUTINE WILL SHOW THE STATUS OF THE TAPE DRIVE
SHWTAP: MOVEI S1,.ODSHT ;SHOW STATUS COMMAND
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE MESSAGE TYPE
$CALL P$DEV ;WAS IT A DEVICE
JUMPT SHWT.1 ;YES.. BUILD DEVICE BLOCK
MOVX S1,.ALTAP
MOVEI S2,1 ;BLOCK SIZE
$CALL ARGRTN ;SAVE THE BLOCK
JRST SHWT.2 ;FINISH OFF THE COMMAND
SHWT.1: $CALL PSTA.1 ;BUILD THE BLOCK
$RETIF ;FAIL..RETURN
SHWT.2: $CALL P$SWIT ;IS THERE A SWITCH?
JUMPF CMDEND ;NO..FINISH OFF COMMAND
MOVEI S2,TAPSWI ;TAPE SWITCHES
SHWTAB: $CALL TABSRC ;SEARCH THE TABLE
$RETIF ;ERROR..RETURN
MOVE S2,(S2) ;GET THE DATA
IORM S2,.OFLAG(MO) ;SAVE THE FLAGS
PJRST CMDEND ;END THE COMMAND
TAPSWI: $STAB
.SWALL,,[ST.ALL] ;ALL
.SWCHR,,[ST.CHR] ;CHARACTERISTICS
.SWFRE,,[ST.AVA] ;FREE(AVAILABLE)
$ETAB
SUBTTL SHWSTR Process SHOW STATUS STRUCTURES command
;THIS COMMAND WILL SHOW STATUS OF STRUCTURES
SHWSTR: MOVEI S1,.ODSTR ;GET MESSAGE TYPE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE
$CALL PSTRUC ;PROCESS THE STRUCTURE
$CALL P$SWIT ;IS THERE A SWITCH?
JUMPF CMDEND ;NO, BETTER BE CONFIRM
CAIE S1,.SWUSR ;IS IT /USER?
$RETF ;NO!?
MOVX S1,ST.USR ;YES, GET FLAG BIT
IORM S1,.OFLAG(MO) ;LIGHT IN MESSAGE TO QUASAR
PJRST CMDEND ;END THE COMMAND AND SEND TO QUASAR
SUBTTL SHWDSK Process SHOW STATUS DISK command
;THIS ROUTINE WILL DO SHOW STATUS OF DISK DRIVES
SHWDSK: MOVEI S1,.ODSHD ;SHOW STATUS COMMAND
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE MESSAGE TYPE
$CALL P$DEV ;CHECK FOR A DEVICE BLOCK
JUMPT SHWD.1 ;CHECK OUT THE STRUCTURE
MOVX S1,.ALDSK ;FOR ALL DISK DRIVES
MOVEI S2,1 ;ONE WORD
$CALL ARGRTN ;SAVE THE BLOCK
$CALL P$SWIT ;CHECK FOR A SWITCH
JUMPF CMDEND ;NO SWITCH CHECK IF END
MOVEI S2,DSKDSP ;GET DSK TABLE ADDRESS
JRST SHWTAB ;DO THE TABLE LOOKUP
SHWD.1: $CALL P$PREV ;BACKUP TO DEVICE AND GET DISK
$CALL PSTRUC ;CHECK FOR A STRUCTURE
PJRST CMDEND ;NOW TRY END AND RETURN
DSKDSP: $STAB
.SWALL,,[ST.ALL] ;ALL
.SWAVA,,[ST.AVA] ;AVAILABLE
.SWMNT,,[ST.MNT] ;MOUNTED
$ETAB
SUBTTL Q$SHWQ Process SHOW QUEUES command
;THIS ROUTINE WILL FORMAT MESSAGE TO QUASAR FOR SHOW QUEUES
LS.XXX==LS.FST!LS.ALL!LS.SUM ;Contradictory list control switches
Q$SHWQ:: STKVAR <NFLAG> ;Save a flag to indicate a node name
MOVX S1,.OMSHQ ;SHOW THE QUEUES
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE MESSAGE TYPE
$CALL P$KEYW ;GET A KEYWORD
JUMPF SHWQ.1 ;No keyword -- assume all
MOVEI S2,QUETYP ;Get the queue type table
$CALL TABSRC ;Search the table
JUMPT [MOVE S1,(S2) ;Get the data
JRST SHWQ.2] ;Continue at store
CAIE S1,.KYALL ;Was all specified?
PJRST E$IQS ;Invalid queue specified and return
SHWQ.1: SETOM S1 ;Set for all
SHWQ.2: STORE S1,.OHDRS+ARG.DA(MO) ;Save type of queue
MOVEI S1,.LSQUE ;Get argument type
MOVEI S2,ARG.SZ ; and size
$CALL ARGRTN ;Setup the argument
SETZM NFLAG ;We have no node name so far
; Loop on switches till confirm
SETZM .OFLAG(MO) ;Initialize flag
SHWQ.3: $CALL P$CFM ;Check for confirm / C.R.
JUMPT SHWQ.8 ;Go clean up.
$CALL P$SWIT ;Get a switch
$RETIF ;Since no confirm, no switch is error
CAIN S1,.SWNOD ;Node switch?
JRST SHWQ.4 ;Yes - go process node name
CAIN S1,.SWUSR ;User switch?
JRST SHWQ.5 ;Yes - go process user name
MOVEI S2,SHQSWT ;Point at switch table
$CALL TABSRC ;Check for a match
$RETIF ;If an error
MOVE S2,(S2) ;Get the bit for the switch
MOVX S1,LS.XXX ;Get the listing control bits
TDNE S2,S1 ;Did they specify a control switch?
TDNN S1,.OFLAG(MO) ;Yes, don't allow contradictions here
SKIPA ;All is goodness, skip
$RETF ;Contradictory switch, error
IORM S2,.OFLAG(MO) ;Light it
JRST SHWQ.3 ;Try for another switch
; Continued on next page
; Continued from previous page
; Process node name
SHWQ.4: $CALL P$NODE ;Check out the node name
$RETIF ;Quit if bad
$CALL SAVNOD ;Save the stuff in the message
SETOM NFLAG ;We now have a node name
JRST SHWQ.3 ;Try for another switch
; Process user name
SHWQ.5: $CALL PUSERS ;Try to process the user name switch
$RETIF ;Quit if none
JRST SHWQ.3 ;Try for another switch
; Finish off the command
SHWQ.8: SKIPN NFLAG ;Already have a node name?
$CALL CHKRMT ;No, do this here
ANDI P3,777 ;Get the message length
STORE P3,.MSTYP(MO),MS.CNT ;Save the count
$CALL SNDQSR ;Send the message
$RETT ;Return true
DEFINE X(TYP),<
.OT'TYP,,[LIQ'TYP] >
QUETYP: $STAB
DEVQUE
$ETAB
;Switches for the SHOW QUEUES command
SHQSWT: $STAB
.SWALL,,[LS.ALL] ;/ALL
.SWSHT,,[LS.FST] ;/SHORT
.SWSUM,,[LS.SUM] ;/SUMMARY
.SWRMT,,[LS.RMT] ;/REMOTE
$ETAB
SUBTTL Q$SHWC Process SHOW CONTROL-FILE command
;THIS ROUTINE DOES THE OLD BATCON EXAMINE FUNCTION FOR
;SHOWING THE OPERATOR LINES IN A BATCH CONTROL-FILE
Q$SHWC:: MOVX S1,.OMSHC ;SHOW CONTROL-FILE TYPE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE
$CALL BLDOBJ ;BUILD AN OBJECT BLOCK
$RETIF ;ERROR..RETURN
MOVEI T1,.OHDRS+ARG.DA(MO) ;POINT TO OBJECT BLOCK
LOAD S1,OBJ.UN(T1),OU.HRG ;GET THE HIGH VALUE
JUMPN S1,.RETF ;NON-ZERO..ERROR
LOAD S1,OBJ.TY(T1) ;GET THE TYPE FIELD
CAXE S1,.OTBAT ;BETTER BE BATCH
$RETF ;RETURN FALSE..ERROR
$CALL P$SWIT ;GET A SWITCH
JUMPF SHWC.2 ;NO..SETUP DEFAULT LINES
CAIE S1,.SWLNS ;IS IT LINES
$RETF ;INVALID COMMAND
MOVEI T2,.SHCLN ;YES..SETUP SHOW LINES TYPE
$CALL P$NUM ;GET A NUMBER
$RETIF ;ERROR..RETURN
SHWC.1: STORE S1,ARG.DA(P3) ;SAVE NUMBER IN BLOCK
MOVE S1,T2 ;GET THE ARGUMENT TYPE
MOVEI S2,ARG.SZ ;SIZE OF THE BLOCK
$CALL ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH OFF THE MESSAGE
SHWC.2: MOVEI S1,^D10 ;DEFAULT TO 10 LINES
MOVEI T2,.SHCLN ;SHOW CONTROL FILE LINES
JRST SHWC.1 ;FINISH OFF BLOCK AND MESSAGE
SUBTTL Q$DISM Process DISMOUNT command (TOPS20)
Q$DISM::
MOVE S1,G$HOST ;Get local host
$CALL OPRENB ;Check OPR privs
$RETIF
$CALL P$KEYW ;GET THE KEYWORD
$RETIF ;ERROR..RETURN
CAIE S1,.KYSTR ;IS IT A STRUCTURE
JRST DISM.1 ;NO..TRY TAPE
$CALL PSTRUC ;PROCESS THE STRUCTURE
$RETIF ;NOT A STR OR A TAPE, QUIT
DISM.0: $CALL P$SWIT ;TRY FOR A SWITCH
JUMPF CMDEND ;NO SWITCH, BETTER CONFIRM
SETZM S2 ;INDICATE NO SWITCH MATCH YET
CAIN S1,.SWREM ;IS IT /REMOVE?
MOVX S2,.DMRMV ;YES, SET THAT BIT
TOPS10< CAIN S1,.SWNCK ;IS IT /NOCHECK?
MOVX S2,.DMNCK ;YES, SET THAT BIT
>;END TOPS10
JUMPE S2,.RETF ;IF NO LEGAL SWITCH, ERROR
IORM S2,.OFLAG(MO) ;SAVE THE FLAG BITS
JRST DISM.0 ;TRY FOR ANOTHER SWITCH
DISM.1: CAIE S1,.KYTAP ;CHECK FOR A TAPE
$RETF ;NO..RETURN FALSE
MOVEI S1,.ODUNL ;GET THE UNLOAD TYPE
STORE S1,.MSTYP(MO),MS.TYP ;RESET THE MESSAGE TYPE
JRST UNLO.1 ;PROCESS THE UNLOAD
SUBTTL Q$RECO Process RECOGNIZE command (TOPS10)
SUBTTL Q$UNLO Process UNLOAD command
TOPS10 <
Q$RECO::
>;END TOPS10
Q$UNLO::MOVE S1,G$HOST ;Get local host name
$CALL OPRENB
$RETIF
UNLO.1: $CALL PSTAPE ;SAVE THE TAPE BLOCK
JUMPT CMDEND ;O.K... FINISH OFF COMMAND
$RET ;PASS THE ERROR BACK
SUBTTL Q$ESTR Process ENABLE AUTOMATIC-STRUCTURE-RECOGNITION
Q$ESTR::
MOVE S1,G$HOST ;Get local host
$CALL OPRENB ;Check OPR privs
$RETIF
MOVX S1,.ODENA ;GET ENABLE CODE
SKIPE P1 ;CHECK IF ENABLE OR DISABLE
MOVX S1,.ODDIS ;GET DISABLE CODE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE IN MESSAGE
MOVX S1,.ASREC ;GET ASR TYPE
MOVEI S2,1 ;GET THE LENGTH
$CALL ARGRTN ;ADD ARGUMENT TO MESSAGE
$CALL P$KEYW ;GET A KEYWORD
JUMPF CMDEND ;NO...CHECK END AND SEND
CAIN S1,.KYSTR ;WAS IT FOR ALL STRUCTURES
JRST ESTR.1 ;YES SETUP FOR ALL STRUCTURES
$CALL PSTRUC ;PROCESS A STRUCTURE BLOCK
JUMPT CMDEND ;O.K.. FINISH AND SEND
$RET ;ELSE RETURN WITH CURRENT FALSE STATE
ESTR.1: MOVX S1,.ALSTR ;ALL STRUCTURES
MOVEI S2,1 ;LENGTH OF BLOCK
$CALL ARGRTN ;BUILD THE ARGUMENT
PJRST CMDEND ;FINISH OFF COMMAND
SUBTTL Q$ETAP Process ENABLE TAPE command
SUBTTL Q$DTAP Process DISABLE TAPE command
;THIS ROUTINE WILL HANDLE ENABLE AND DISABLE TAPE COMMANDS
Q$DTAP::
Q$ETAP::MOVE S1,G$HOST ;Get local node
$CALL OPRENB ;Check OPR privs
$RETIF
MOVX S1,.ODENA ;GET ENABLE CODE
SKIPE P1 ;CHECK IF ENABLE OR DISABLE
MOVX S1,.ODDIS ;GET DISABLE CODE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE THE TYPE IN MESSAGE
MOVX S1,.AVREC ;GET AVR TYPE
MOVEI S2,1 ;GET THE LENGTH
$CALL ARGRTN ;ADD ARGUMENT TO MESSAGE
$CALL P$KEYW ;GET A KEYWORD
CAIN S1,.KYTAP ;WAS IT FOR ALL TAPES
JRST ETAP.1 ;YES SETUP FOR ALL TAPES
CAIN S1,.KYDSK ;ALL DISKS
JRST ETAP.3 ;YES.. ALL DISKS
$CALL PSTAPE ;PROCESS A TAPE BLOCK
JUMPT CMDEND ;O.K.. SEND AND RETURN
SETZM G$ERR ;CLEAR THE ERROR WORD
$CALL P$PREV ;POSITION TO PREVIOUS
$CALL PSTRUC ;PROCESS STRUCTURE BLOCK
JUMPT CMDEND ;O.K.. SEND AND RETURN
$RET ;PASS FALSE BACK
ETAP.1: MOVX S1,.ALTAP ;ALL TAPES
ETAP.2: MOVEI S2,1 ;LENGTH OF BLOCK
$CALL ARGRTN ;BUILD THE ARGUMENT
PJRST CMDEND ;FINISH OFF COMMAND
ETAP.3: MOVX S1,.ALDSK ;GET ALL STRUCTURES
PJRST ETAP.2 ;FINISH AND RETURN
SUBTTL Q$ETSR - ENABLE TIMESHARING
TOPS10 <
Q$ETSR::MOVE S1,G$HOST ;GET LOCAL HOST
PUSHJ P,OPRENB ;CHECK OPR PRIVS
JUMPF .POPJ ;GIVE UP
JUMPN P1,ETSR.1 ;JUMP IF DISABLE
MOVEI S1,.OMETS ;CODE FOR ENABLE TIMESHARING
STORE S1,.MSTYP(MO),MS.TYP ;SAVE IN MESSAGE
PJRST CMDEND ;SEND TO QUASAR AND RETURN
ETSR.1: MOVE S1,[XWD .STKSY,-1] ;TURN OF TIMESHARING
SETUUO S1,
TRNA
PJRST E$TSD
MOVEM S1,G$ARG1 ;SAVE ERROR CODE
PJRST E$DTF
> ;END TOPS-10 CONDITIONAL
SUBTTL Q$LOCK Process LOCK command
SUBTTL Q$ULOC Process UNLOCK command
;THIS COMMAND WILL LOCK A STRUCTURE FROM FURTHER ACCESS
;NOW OR OPTIONALLY AT A SPECIFIED TIME
;THE MESSAGE TYPE DISTINGUISHES LOCK FROM UNLOCK
Q$LOCK::
Q$ULOC::
MOVE S1,G$HOST ;Get local host
$CALL OPRENB ;Check OPR privs
$RETIF
$CALL PSTRUC ;GET THE STRUCTURE
$RETIF ;INVALID COMMAND
$CALL P$TIME ;GET THE TIME
MOVEM S1,ARG.DA(P3) ;SAVE THE UDT
MOVX S1,.ORTIM ;TIME BLOCK
MOVEI S2,ARG.SZ ;GET THE SIZE
$CALL ARGRTN ;SAVE THE ARGUMENT
$CALL P$SWIT ;GET OPTIONAL SWITCH
JUMPF CMDEND ;NONE,,END IT !!!
CAXE S1,.SWNUL ;WAS IT NO-UNLOAD ???
$RETF ;NO,,THATS AN ERROR
MOVX S1,LC.NUL ;GET THE NO UNLOAD STATUS
MOVEM S1,.OFLAG(MO) ;SAVE IT
PJRST CMDEND ;END THE MSG
SUBTTL Q$MOUN Process MOUNT TAPE and DISK command
;THIS COMMAND WILL BUILD MESSAGE FOR MOUNTING STRUCTURES
TOPS10<
Q$MOUNT::
MOVE S1,G$HOST ;Get local host name
$CALL OPRENB
$RETIF
$CALL P$KEYW ;CHECK FOR A KEYWORD
$RETIF ;NO..INVALID COMMAND
CAIE S1,.KYSTR ;IS IT A STRUCTURE
$RETF ;NO..INVALID COMMAND
$CALL PSTRUC ;PROCESS THE STRUCTURE
$RETIF ;ERROR..RETURN
$CALL P$DEV ;CHECK FOR ALIAS NAME
JUMPF MOUN.1 ;ISN'T ONE, TRY FOR A SWITCH
MOVX T1,.STALS ;STRUCTURE ALIAS
STORE T1,ARG.HD(S1),AR.TYP ;SAVE CODE IN BLOCK
$CALL MOVARG ;MOVE THE BLOCK
MOUN.1: PUSHJ P,P$SWIT ;TRY TO PARSE A SWITCH
JUMPF CMDEND ;CAN'T
SETZ S2, ;DEFAULT TO NO SWITCH
CAIN S1,.SWWLK ;WAS IT /WRITE-LOCKED?
MOVX S2,.MTWLK ;YES
CAIN S1,.SWOSN ;WAS IT /OVERRIDE-SET-NUMBER?
MOVX S2,.DMOSN ;YES
JUMPE S2,.RETF ;ERROR IF NO SWITCH SPECIFIED
IORM S2,.OFLAG(MO) ;SAVE THE FLAG BITS
JRST MOUN.1 ;TRY FOR MORE
>;END TOPS10
SUBTTL Q$IDEN Process IDENTIFY command
;THIS COMMAND WILL IDENTIFY A TAPE DRIVE WITH A PARTICULAR TAPE
;REQUEST OR TAPE VOLUME
Q$IDENTIFY::
MOVE S1,G$HOST ;Get local host
$CALL OPRENB ;Check OPR privs
$RETIF
$CALL PSDEVI ;SAVE THE DEVICE BLOCK
$RETIF ;ERROR..RETURN
$CALL P$KEYW ;CHECK FOR A KEYWORD
$RETIF ;NO..ERROR..RETURN
MOVEI S2,IDNDSP ;USE THE DISPATCH
$CALL TABSRC ;CHECK THE TABLE
$RETIF ;ERROR..RETURN
PJRST (S2) ;DO THE WORK
IDNDSP: $STAB
.KYRQN,,IDNRQN ;REQUEST NUMBER
.KYSCR,,IDNSCR ;SCRATCH TAPE
.KYVID,,IDNVID ;VOLUME-ID
$ETAB
; VOLUME-ID FOR IDENTIFY
IDNVID: $CALL PVOLID ;PROCESS VOLUME ID
JUMPT CMDEND ;O.K.. FINISH OFF MESSAGE
$RET ;ERROR.. PASS CODE UP
; REQUEST NUMBER FOR IDENTIFY
IDNRQN: $CALL PREQNM ;PROCESS REQUEST NUMBER
$RETIF ;ERROR..RETURN
PJRST CMDEND ;FINISH OFF COMMAND
; SCRATCH FOR IDENTIFY
IDNSCR: MOVEI S1,.SCRTP ;SCRATCH TAPE
MOVEI S2,1 ;ONE WORD BLOCK
$CALL ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH OFF THE COMMAND
SUBTTL Q$DEFI Process DEFINE command (DN60, DQS, or LAT)
;THIS COMMAND WILL DEFINE A DN60 NODE SO THAT PARAMETERS CAN BE SET
IFN FTUUOS!FTDN60!FTDQS,<
Q$DEFINE::
MOVE S1,G$HOST ;Get host name
$CALL OPRENB ;Check OPR privs
$RETIF
$CALL P$KEYW ;GET THE KEYWORD
$RETIF ;ERROR..RETURN
> ;END IFN FTUUOS!FTDN60!FTDQS
TOPS10 <
CAIN S1,.KYFAL ;IS IT DEFINE FILE-ACCESS?
JRST DEFFAL ;YES, GO DO THAT
CAIN S1,.KYQNM ;IS IT DEFINE QUEUE-NAME?
JRST DEFQNM ;YES, GO DO THAT
>
CAIE S1,.KYNOD ;BETTER BE NODE
$RETF ;NO..RETURN FALSE
$CALL P$NODE ;GET A NODE
$RETIF ;ERROR RETURN
$CALL SAVNOD ;SAVE THE NODE
$CALL P$KEYW ;GET A KEYWORD
$RETIF ;ERROR..RETURN
SETZ T1, ;SET A FLAG
CAIN S1,.KYLAT ;WAS IT LAT-SERVER?
MOVX T1,DF.LAT ;LAT
IFN FTDN60,<
CAIN S1,.KY278 ;WAS IT 2780
MOVX T1,DF.278 ;2780
CAIN S1,.KY378 ;WAS IT 3780
MOVX T1,DF.378 ;3780
CAIN S1,.KYHSP ;WAS IT HASP
MOVX T1,DF.HSP ;HASP
>; END IFN FTDN60
IFN FTDQS,<
CAIN S1,.KYSRV ;WAS IT SERVER?
MOVX T1,DF.SRV ;SERVER
>; END IFN FTDQS
JUMPE T1,.RETF ;ERROR..RETURN FALSE
STORE T1,DEF.TY(P3),DF.TPP ;Save the type
CAIE S1,.KYLAT ;Was is LAT-server?
JRST DEFI.1 ;No, keep checking
PUSHJ P,DEFLAT ;Process the LAT switches
JUMPT DEFI.2 ;No errors: finish message
$RET ;
DEFI.1: ;
IFN FTDN60,<
IFN FTDQS,<
CAIN S1,.KYSRV ;WAS IT SERVER?
JRST DEFI.2 ;YES, END OF MESSAGE
>; END IFN FTDQS
PUSHJ P,DEFD60 ;PROCESS DN60 SWITCHES
$RETIF ;ERROR..RETURN
>; END IFN FTDN60
DEFI.2: MOVX S1,.DFBLK ;DEFINE BLOCK
MOVEI S2,DEF.SZ ;DEFINE SIZE
$CALL ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH COMMAND AND SEND IT
; GET LAT SWITCHES
DEFLAT: $CALL .SAVE1 ;Save P1
DEFL.1: $CALL P$SWIT ;Look for a switch
JUMPF .RETT ;None: finished
MOVEI S2,LATDSP ;Address of table
$CALL TABSRC ;Search the table
$RETIF ;Error: return
ADD S2,P3 ;Convert offset to address
MOVEM S2,P1 ;
$CALL P$FLD ;Get the text string
$RETIF ;Error: return
HRLI S1,1(S1) ;Source,,0
HRR S1,P1 ;Source,,destination
ADD S2,P1 ;Calculate ending address
BLT S1,-2(S2) ;Copy the text string
JRST DEFL.1 ;Look for another switch
LATDSP: $STAB ;
.SWSVR,,DEF.LA+0 ;Server
.SWSVC,,DEF.LA+4 ;Service
.SWPOR,,DEF.LA+10 ;Port
$ETAB
; GET DN60 SWITCHES
IFN FTDN60,<
DEFD60: $CALL P$SWIT ;Get the switch for signon/no- required
SETZ T1, ;Start at none
JUMPF DEFD.1 ;And we have none
CAIN S1,.SWNSN ;Is no signon required?
MOVX T1,DF.NSN ;Yes, remember it
CAIN S1,.SWSON ;Is signon required?
MOVX T1,DF.SON ;Yes, remember it
DEFD.1: STORE T1,DEF.TY(P3),DF.FLG ;Save it in any case
$CALL P$KEYW ;GET MODE KEYWORD
$RETIF ;ERROR..RETURN
SETZ T1, ;SET THE FLAG
CAIN S1,.KYTRM ;WAS IT TERMINATION
MOVX T1,DF.TRM ;TERMINATION
CAIN S1,.KYEMU ;WAS IT EMULATION
MOVX T1,DF.EMU ;EMULATION
JUMPE T1,.RETF ;ZERO..ERROR..RETURN
MOVEM T1,DEF.MD(P3) ;SAVE THE MODE
$CALL P$KEYW ;SEE IF CPU KEYWORD
JUMPF DEFD.2 ;IF NOT, MUST BE OLD STYLE CMD
$CALL P$NUM ;GET CPU NUMBER
$RETIF ;IF NONE, BAD COMMAND
CAIL S1,0 ;RANGE CHECK
CAILE S1,5
$RETF ;BAD NUMBER
SETZM T4 ;INIT PORT ARGUMENT
STORE S1,T4,C1.1CN ;SAVE CPU NUMBER
$CALL P$KEYW ;GET PORT TYPE
$RETIF ;BAD COMMAND
MOVEI S2,PRTDSP ;PORT TYPE TABLE
$CALL TABSRC ;SEARCH THE TABLE
$RETIF ;PASS ERROR UP
STORE S2,T4,C1.1TY ;CONTINUE BUILDING PORT DESGINATION
$CALL P$NUM ;GET PORT NUMBER
$RETIF
CAIL S1,0 ;RANGE CHECK
CAILE S1,7
$RETF
STORE S1,T4,C1.1PN ;COMPLETE NEW STYLE PORT
HLRZM T4,DEF.PT(P3) ;STORE IN MESSAGE
$CALL P$KEYW ;GET LINE KEYWORD (BETTER BE THERE!)
$RETIF
JRST DEFD.4 ;JOIN COMMON CODE
PRTDSP: $STAB
.KYD10,,.C11DL ;DL-10 PORT TYPE
.KYD20,,.C11DT ;DTE-20
$ETAB
DEFD.2: $CALL P$NUM ;GET THE PORT NUMBER
$RETIF ;ERROR..RETURN
CAIG S1,7 ;DL10 PORT?
JRST [MOVEM S1,DEF.PT(P3) ;YES, STORE IT AND GET LINE NUMBER
JRST DEFD.4]
MOVS T4,S1 ;GET ARG IN LH FOR NEW TYPE ARG BUILD
ANDX T4,C1.1PN ;NO, KEEP ONLY DTE NUMBER
MOVX S1,.C11DT ;GET DTE PORT TYPE CODE
STORE S1,T4,C1.1TY ;STORE IT (CPU NUMBER IS ZERO)
HLRZM T4,DEF.PT(P3) ;SAVE THE PORT NUMBER
DEFD.4: $CALL P$NUM ;GET THE LINE NUMBER
$RETIF ;ERROR..RETURN
MOVEM S1,DEF.LN(P3) ;SAVE THE LINE NUMBER
$RETT ;NO..ERROR..RETURN
>; END IFN FTDN60
TOPS10 <
;PROCESS THE DEFINE FILE-ACCESS COMMAND
DEFFAL: MOVX S1,.OMODB ;GET THE OBJECT DATA MESSAGE TYPE
STORE S1,.MSTYP(MO),MS.TYP ;STORE IN THE MESSAGE HEADER
MOVX S1,.OTFAL ;GET THE OBJECT TYPE FOR FAL
MOVEM S1,ARG.DA(P3) ;STORE THE OBJECT TYPE
MOVX S1,.ORTYP ;GET THE OBJECT TYPE ARGUMENT BLOCK
MOVX S2,ARG.SZ ;GET THE LENGTH OF THE BLOCK
$CALL ARGRTN ;SAVE THE ARGUMENT
$CALL P$KEYW ;GET THE NEXT KEYWORD
$RETIF ;ERROR..RETURN
CAIN S1,.KYREJ ;REJECTION LIST?
JRST DEFFRJ ;YES, GO READ THAT
CAIE S1,.KYDPP ;NO, DEFAULT PPN?
$RETF ;NO. RETURN ERROR
$CALL P$USER ;GET THE DEFAULT PPN
$RETIF ;ERROR..RETURN
MOVEM S1,ARG.DA(P3) ;STORE IN THE DATA BLOCK
MOVX S1,.ORDPP ;GET THE BLOCK TYPE
MOVX S2,ARG.SZ ;GET THE LENGTH OF THE BLOCK
$CALL ARGRTN ;FINISH OFF THE BLOCK
PJRST CMDEND ;FINISH THE COMMAND AND SEND IT
DEFFRJ: MOVX T4,<<1000-.OHDRS-ARG.SZ-ARG.DA>/<REJ.SZ-ARG.DA>> ;NUMBER OF REJECTION SPECS
MOVE T3,P3 ;COPY THE STORAGE POINTER
;LOOP HERE FOR EACH REJECTION SPECIFICATION IN THE LIST
DEFRJ0: $CALL P$NODE ;GET THE NODE NAME
SKIPT ;DID WE GET ANYTHING?
SETZ S1, ;NO, DON'T SET ANYTHING THEN
MOVEM S1,REJ.ND(T3) ;STORE THE REJECTED NODE NAME
SETZM REJ.PP(T3) ;CLEAR THE
SETZM REJ.MK(T3) ; REJECTED PPN
$CALL P$USER ;GET THE REJECTED PPN
JUMPF DEFRJ1 ;NONE, SKIP THIS
MOVEM S1,REJ.PP(T3) ;STORE THE PPN WORD
MOVE S1,PFD.D2(S2) ;GET THE PPN MASK WORD
MOVEM S1,REJ.MK(T3) ;STORE IT TOO
DEFRJ1: MOVEI T3,REJ.SZ-ARG.DA(T3) ;POINT TO THE NEXT SUBBLOCK
$CALL P$CFM ;SEE IF END OF COMMAND YET
JUMPT DEFRJ2 ;YES, GO FINISH UP
$CALL P$COMMA ;NO, HOW ABOUT A COMMA?
$RETIF ;NO, JUST BLOW IT OFF
SOJG T4,DEFRJ0 ;YES, TRY ANOTHER ONE
PJRST E$IFC ;DONE TOO MANY. SAY BAD COMMAND
DEFRJ2: MOVE S2,T3 ;COPY THE STORAGE POINTER
SUBI S2,-ARG.DA(P3) ;COMPUTE BLOCK LENGTH
MOVX S1,.ORREJ ;GET THE BLOCK TYPE
$CALL ARGRTN ;SETUP THE ARG BLOCK
ANDI P3,777 ;GET LENGTH OF MESSAGE
STORE P3,.MSTYP(MO),MS.CNT ;SAVE THE COUNT
PJRST SNDQSR ;SEND THE COMMAND
DEFQNM: MOVX S1,.OMDQN ;GET THE DEFINE REMOTE QUEUE TYPE
STORE S1,.MSTYP(MO),MS.TYP ;STORE IN THE MESSAGE HEADER
$CALL P$FLD ;PROCESS QUEUE NAME
$RETIF
MOVSI S2,ARG.DA(S1) ;SOURCE
HRRI S2,DFQ.QN(P3) ;DESTINATION
LOAD S1,ARG.HD(S1),AR.LEN ;LENGTH OF BLOCK
SUBI S1,ARG.DA ;SUBTRACT LENGTH OF HEADER
CAILE S1,QNMLEN ;CHECK LENGTH
MOVEI S1,QNMLEN ;ADJUST
ADDI S1,(S2) ;COMPUTE END OF OF BLT
BLT S2,-1(S1) ;COPY THE QUEUE NAME STRING
$CALL P$CFM ;SEE IF DELETING DEFINITION
JUMPF DEFQN1 ;MUST BE (RE)DEFINING
$CALL P$PREV ;BACKUP SO COMMON CMD EXIT WORKS
JRST DEFQN4 ;FINISH UP
DEFQN1: $CALL P$KEYW ;GET THE QUEUE TYPE
$RETIF
MOVEM S1,DFQ.TY(P3) ;SAVE IT
$CALL P$NODE ;GET NODE NAME
$RETIF
MOVEM S1,DFQ.ND(P3) ;SAVE IT
$CALL P$KEYW ;GET THE OBJECT TYPE
$RETIF
MOVEM S1,DFQ.OT(P3) ;SAVE IT
$CALL P$CFM ;SEE IF ANY UNIT IS VALID
JUMPF DEFQN2 ;NO
SETOM DFQ.UN(P3) ;FLAG IT
$CALL P$PREV ;BACKUP SO COMMON CMD EXIT WORKS
JRST DEFQN4 ;FINISH UP
DEFQN2: $CALL P$NUM ;GET THE UNIT NUMBER
JUMPF DEFQN3 ;MAYBE NO UNIT NUMBER GIVEN
MOVEM S1,DFQ.UN(P3) ;SAVE UNIT NUMBER
JRST DEFQN4 ;ONWARD
DEFQN3: $CALL P$SIXF ;GET SIXBIT UNIT TYPE
$RETIF ;NEED EITHER UNIT NUMBER OR TYPE
MOVEM S1,DFQ.UT(P3) ;SAVE UNIT TYPE
DEFQN4: MOVX S1,.DFQNM ;BLOCK TYPE
MOVX S2,DFQ.SZ ;LENGTH OF THE MESSAGE
PUSHJ P,ARGRTN ;SAVE THE ARGUMENT
PJRST CMDEND ;FINISH UP AND SEND THE COMMAND
> ;END TOPS10
SUBTTL Q$SWIT Process SWITCH command (TOPS20)
;THIS COMMAND WILL SEND A MESSAGE TO MOUNTR (VIA QUASAR) TO
;SWITCH A GIVEN REQUEST TO ANOTHER VOLUME/DRIVE.
TOPS20 <
Q$SWITCH::
MOVE S1,G$HOST ;Get host name
$CALL OPRENB
$RETIF
$CALL PREQNM ;PROCESS A REQUEST NUMBER
$RETIF ;ERROR..RETURN
$CALL PVOLID ;PROCESS THE VOLUME ID
$RETIF ;ERROR..RETURN
$CALL PSTAPE ;PROCESS A TAPE BLOCK
PJRST CMDEND ;TRY TO FINISH COMMAND IN ANY CASE
>;END TOPS20
SUBTTL Q$MODS Process MODIFY SYSTEM-LISTS command (TOPS10)
;These routine are responsible for decoding the parse blocks
;Returned on a MODIFY <system-lists> command
;Call -
; S1/ Current keyword in parse
Q$MODS:
TOPS20< $RETF > ;ONLY FOR THE -10
TOPS10<
$CALL CNVLST ;CONVERT TO EXTERNAL FORM, ADD TO MESSAGE
$RETIF ;CAN'T, SO QUIT
MOVE S1,G$HOST ;Get local node
$CALL OPRENB ;Check OPrR privs
$RETIF
MOVX S1,.ODCSL ;NEW MESSAGE TYPE - CHANGE SYSTEM LISTS
STORE S1,.MSTYP(MO),MS.TYP ;SET IT
$CALL P$KEYW ;GET THE INCLUDE/EXCLUDE
JUMPF E$IFC ;CAN'T, SO QUIT
SETO S2, ;SAY NO MATCH SO FAR
CAIN S1,.KYINC ;IS IT INCLUDE?
SETZ S2, ;YES, CLEAR THE BIT
CAIN S1,.KYEXC ;IS IT EXCLUDE?
MOVEI S2,1 ;YES, GET ONE BIT
JUMPL S2,E$IFC ;BETTER BE ONE OF THOSE
STORE S2,.OFLAG(MO),AD.REM ;LITE BIT IF APPROP. IN FLAGS
$CALL PSTRUC ;GET THE DEVICE (STR OR UNI) NAME
$RETIF ;NOT A STR NEXT, STRANGE
PJRST CMDEND ;FINISH THE COMMAND
;THIS ROUTINE CONVERTS A LIST DESCRIPTOR KEYWORD INTO A
; BLOCK IN THE MESSAGE WITH THE EXTERNAL DESCRIPTOR
;CALL -
; S1/ .KYXXX KEYWORD SYMBOL
;RETURNS -
; TRUE, WITH A 2-WORD BLOCK TACKED ON TO THE MESSAGE
; FALSE - IF THE KEYWORD DIDN'T MATCH ANY KNOW KEYWORD
CNVLST: MOVEI S2,CLSTTB ;POINT TO THE MAPPING TABLE
$CALL TABSRC ;FIND THE CORRECT LIST HANDLE
JUMPF E$IFC ;VERY STRANGE
MOVEI S1,.SLSTY ;BLOCK TYPE - LIST DESCRIPTOR
MOVE TF,S2 ;COPY THE CONVERTED LIST TYPE
SETZ S2, ;CLEAR THE DATA WORD
STORE TF,S2,SL.TCD ;STASH IN PROPER PLACE
PJRST MOVAR2 ;ADD A 2-WORD ARG BLOCK
CLSTTB: $STAB
.KYSSL,,SL.SSL ;MAP FOR SYSTEM SEARCH LIST
.KYCDL,,SL.CDL ;MAP FOR SYSTEM DUMP LIST
.KYASL,,SL.ASL ;MAP FOR ACTIVE SWAP LIST
$ETAB
>;END TOPS10
SUBTTL Q$SLST Process SHOW SYSTEM-LISTS command (TOPS10)
;THIS ROUTINE PROCESSES THE SHOW SYSTEM LISTS OR SHOW SYSTEM PARAMETERS
;COMMANDS. SHOW SYSTEM LISTS IS FORWARDED TO QUASAR
TOPS10<
Q$SLST::
PUSHJ P,P$KEYW ;GET NEXT KEYWORD
JUMPF E$IFC ;BETTER BE THERE
MOVEI S2,SSYTAB ;GET TABLE ADDRESS
PUSHJ P,TABSRC ;GET PROCESSOR ADDRESS
JUMPF E$IFC ;COMPLAIN IF NOT FOUND
PJRST (S2) ;GO DO THE WORK
;Here for SHOW SYSTEM PARAMETERS
SHOPRM: PUSHJ P,.SAVET ;SAVE T1-T4
MOVX S1,.OMDSP ;OPR DISPLAY MESSAGE
STORE S1,.MSTYP(MO),MS.TYP ;PUT IT IN THE MESSAGE
MOVEI S1,PRMHDR ;GET ADDRESS OF HEADER TEXT BLOCK
PUSHJ P,SHWMTX## ;USE ROUTINE IN ORION TO COPY INTO MSG
PUSHJ P,OPRSPT## ;USE ROUTINE IN ORION TO SETUP POINTERS
;Display CPU schedulabilty
MOVE S1,[%CNCPU] ;GET NUMBER OF CPUS MONITOR BUILT FOR
GETTAB S1,
JRST SHOP.4 ;DON'T EVEN BOTHER GUESSING
MOVNI T1,(S1) ;GET NEGATIVE COUNT
SOJLE S1,SHOP.4 ;IF JUST ONE, DON'T BOTHER EITHER
HRLZS T1 ;MAKE AOBJN COUNTER
SHOP.1: $TEXT (SHWDEP,<CPU^O/T1,RHMASK/ is ^A>) ;1ST PART OF TYPEOUT
HRRZ S1,T1 ;GET CPU NUMBER TO CHECK
PUSHJ P,VALCPU## ;SEE IF CPU IS RUNNING
MOVE T2,S1 ;SAVE VALUE IN S1
MOVE S1,RUNTBL##(T1) ;GET GETTAB INDEX FOR THIS CPU
GETTAB S1, ;GET %CVRUN WORD FOR THIS CPU
TXO S1,CV%RUN ;ASSUME NOT SCHEDULABLE
JUMPT SHOP.2 ;IF CPU IS RUNNING, SKIP SOME CHECKS
SETZM S2
TXNE S1,CV%RMV ;CPU REMOVED?
MOVEI S2,[ITEXT(<removed>)] ;YES
TXNE S1,CV%DET ;CPU DETACHED?
MOVEI S2,[ITEXT(<detached>)] ;YES
TXNE S1,CV%SPD ;CPU SUSPENDED?
MOVEI S2,[ITEXT(<supended>)] ;YES
JUMPN S2,SHOP.3 ;IF WE FOUND A BIT, GO DEPOSIT TEXT
MOVEI S2,[ITEXT(<not running>)];ELSE CPU IS NOT RUNNING
JRST SHOP.3
SHOP.2: TXNE S1,CV%RUN ;SCHEDULABLE?
SKIPA S2,[[ITEXT (<running but not scheduling jobs>)]] ;NO
MOVEI S2,[ITEXT (<running and scheduling jobs>)] ;YES
SHOP.3: $TEXT (SHWDEP,<^I/(S2)/^M^J^A>) ;PUT TEXT IN BUFFER
AOBJN T1,SHOP.1 ;LOOP FOR ALL CPUS
MOVEI S1,.CHCRT ;GET CARRIAGE RETURN
PUSHJ P,SHWDEP ;PUT IT IN BUFFER
MOVEI S1,.CHLFD ;LINEFEED
PUSHJ P,SHWDEP
;Display LOGMAX
SHOP.4: MOVE S1,[%CNSJN] ;GET MAX NUMBER OF JOBS
GETTAB S1,
MOVEI S1,^D513 ;ASSUME BIG DEFAULT
MOVEI S1,-1(S1) ;GET RID OF NEGATIVE NUMBER OF HISEGS
;DON'T COUNT NULL JOB
MOVE S2,[%CNLMX] ;GET LOGMAX
GETTAB S2,
MOVEI S2,^D512
$TEXT (SHWDEP,<LOGMAX: ^D/S2/ jobs out of ^D/S1/^M^J^J^A>)
;Display SCHEDULE bits
MOVE S1,[%CNSTS] ;GET STATUS WORD FOR SCHED BITS
GETTAB S1,
SETZM S1
TLZ S1,777777 ;KEEP ONLY SCHED BITS
MOVE T1,S1 ;SAVE THEM
$TEXT (SHWDEP,<SCHEDULE: ^O6R0/S1/^M^J^A>)
SKIPN T1 ;ANY BITS SET?
$TEXT (SHWDEP,< No restrictions^M^J^A>) ;NO
JUMPE T1,SHOP.5 ;IF NO BITS SET, SKIP SOME STUFF
TXNE T1,ST%NDL ;NO DOWN-LINE LOADING?
$TEXT (SHWDEP,< No automatic network down-line loading^M^J^A>) ;YES
TXNE T1,ST%NOP ;OPERATOR ON BREAK?
$TEXT (SHWDEP,< No operator coverage^M^J^A>) ;YES, AREN'T THEY ALWAYS
TXNE T1,ST%NSP ;NON-PRIV'D UNSPOOLING ALLOWED?
$TEXT (SHWDEP,< Device unspooling allowed without privilege^M^J^A>) ;YES
TXNE T1,ST%ASS ;CAN USERS ASSIGN RESTRICTED DEVICES
$TEXT (SHWDEP,< Restricted devices can be assigned^M^J^A>) ;YES
TXNE T1,ST%NRT ;REMOTE TERMINALS DISALLOWED?
$TEXT (SHWDEP,< No remote terminals^M^J^A>) ;YES
TXNE T1,ST%BON ;CAN ONLY BATCH JOBS LOGIN?
$TEXT (SHWDEP,< Batch jobs only^M^J^A>) ;YES
TXNE T1,ST%NRL ;NO REMOTE LOGINS?
$TEXT (SHWDEP,< No remote logins^M^J^A>) ;YES
TXNE T1,ST%NLG ;ONLY LOGINS AT CTY?
$TEXT (SHWDEP,< Logins from CTY only^M^J^A>) ;YES
;Display BATMAX and CORMAX
SHOP.5: MOVE S1,[%CNBMX] ;GET BATMAX
GETTAB S1,
MOVEI S1,^D13
CAIN S1,1 ;PLURAL OR SINGULAR (0 IS PLURAL)
SKIPA S2,[BYTE (7) "j","o","b"," ",0]
MOVE S2,[BYTE (7) "j","o","b","s",0] ;MUST BE PRETTY
MOVE T1,[%NSCMX] ;GET CORMAX
GETTAB T1,
SKIPA T1,[^D512]
LSH T1,-^D9 ;CONVERT WORDS TO PAGES
$TEXT (SHWDEP,<^JBATMAX: ^D2R/S1/ ^T/S2/ CORMAX: ^D4R/T1/ pages^M^J^A>)
;Display BATMIN and CORMIN
MOVE S1,[%CNBMN] ;GET BATMIN
GETTAB S1,
SETZM S1
CAIN S1,1 ;PLURAL OR SINGULAR (0 IS PLURAL)
SKIPA T1,[BYTE (7) "j","o","b"," ",0]
MOVE T1,[BYTE (7) "j","o","b","s",0] ;MUST BE PRETTY
MOVE S2,[%NSCMN] ;GET CORMIN
GETTAB S2,
SKIPA S2,[^D512]
LSH S2,-^D9 ;CONVERT WORDS TO PAGES
$TEXT (SHWDEP,<BATMIN: ^D2R/S1/ ^T/T1/ CORMIN: ^D4R/S2/ pages^M^J^J^A>)
;Display disk cache size
MOVX S1,%LDCSZ ;ASK FOR CACHE SIZE
GETTAB S1,
SETZ S1, ;THAT'S ODD
MOVX S2,%LDOCS ;ASK FOR ORIGINAL (CONFIGURED) SIZE
GETTAB S2,
SETZ S2, ;THAT'S ALSO ODD
$TEXT (SHWDEP,<Disk cache size: ^D/S1/ blocks Configured size: ^D/S2/ blocks^M^J^J^A>)
;CUSTOMER ADDITIONS TO SHOW SYSTEM PARAMETERS MAY BE DONE HERE
MOVX S1,%NSKTM ;GET KSYS TIME
GETTAB S1, ; FROM MONTOR
SETZ S1, ;ODD
JUMPE S1,SHOP.6 ;JUMP IF NOT SET
SKIPG S1 ;TIMESHARING OVER ???
$TEXT (SHWDEP,<* Timesharing is over^M^J^J^A>)
JUMPL S1,SHOP.6 ;YES,,TELL OPR AND RETURN
IMULI S1,^D60 ;CONVERT TO SECONDS
CAIGE S1,^D24*^D60*^D60 ;WITHIN 24 HOURS?
PUSHJ P,EXPTIM ;YES, EXPAND TIME INTO READABLE TEXT
SHOP.6: SETZ S2, ;GET A ZERO
IDPB S2,WTOPTR## ;TERMINATE THE MESSAGE
HRRZ S2,WTOPTR## ;GET ENDING ADDRESS
SUBI S2,-1(P3) ;GET LENGTH OF TEXT BLOCK GENERATED
MOVX S1,.CMTXT ;GET BLOCK TYPE
PUSHJ P,ARGRTN ;COPY TEXT TO MESSAGE
PJRST FINSHW## ;GO LOG MSG AND THEN SEND IT TO OPR
PRMHDR: XWD PRMLEN,.ORDSP ;SIZE AND TYPE OF TEXT BLOCK
BLOCK 1 ;ROOM FOR TIME STAMP
ASCIZ\ -- System Parameters --
\
PRMLEN==.-PRMHDR ;SIZE OF THE BLOCK
SHWDEP: IDPB S1,WTOPTR## ;PUT BYTE IN BUFFER
POPJ P, ;RETURN
SUBTTL EXPTIM - Expand time
; Expand time from seconds to hours and minutes
; CALL: MOVE S1,time in seconds
; PUSHJ P,EXPTIM
;
; On return, some pretty text will be generated
;
EXPTIM: $SAVE <T1,T2,T3> ;SAVE SOME ACS
IDIVI S1,^D60*^D60 ;S1:= HOURS
IDIVI S2,^D60 ;S2:= MINUTES
CAIN S1,0 ;HOURS?
MOVEI T1,[ITEXT (<>)] ;NO
CAIN S1,1 ;1 HOUR?
MOVEI T1,[ITEXT (<^D/S1/ hour >)] ;YES
CAILE S1,1 ;MORE THAN ONE HOUR?
MOVEI T1,[ITEXT (<^D/S1/ hours >)] ;YES
SKIPE S1 ;HAVE HOURS?
SKIPN S2 ;HAVE MINUTES?
SKIPA T2,[[ASCIZ ||]] ;JUST ONE OR THE OTHER
MOVEI T2,[ASCIZ |and |] ;HAVE BOTH
CAIN S2,0 ;MINUTES?
MOVEI T3,[ITEXT (<>)] ;NO
CAIN S2,1 ;1 MINUTE?
MOVEI T3,[ITEXT (<^D/S2/ minute>)] ;YES
CAILE S2,1 ;MORE THAN 1 MINUTE?
MOVEI T3,[ITEXT (<^D/S2/ minutes>)] ;YES
$TEXT (SHWDEP,<* Timesharing will cease in ^I/(T1)/^T/(T2)/^I/(T3)/^M^J^J^A>)
POPJ P, ;RETURN
;Here for SHOW SYSTEM LISTS
SHOSSL: MOVEI S1,.ODSSL ;MESSAGE TYPE IS NOW SHOW SYS
STORE S1,.MSTYP(MO),MS.TYP ;CHANGE IT
SLST.1: $CALL P$KEYW ;IS THERE A KEYWORD?
JUMPF CMDEND ;NO, BETTER BE CONFIRM
$CALL CNVLST ;YES, CONVERT AND ADD TO MSG
JRST SLST.1 ;TRY FOR ANOTHER
SSYTAB: $STAB
.KYLST,,SHOSSL
.KYPRM,,SHOPRM
$ETAB
>;END TOPS10
SUBTTL Q$SALC Process SHOW ALLOCATION command (TOPS10)
TOPS10<
Q$SALC::
MOVEI S1,.ODSAL ;GET THE MESSAGE TYPE
STORE S1,.MSTYP(MO),MS.TYP ;SAVE IN THE OUTGOING MESSAGE
$SAVE <P1> ;SOME WORK SPACE
$CALL P$KEYW ;GET THE DESCRIPTOR
JUMPF E$IFC ;WHOOPS!
MOVX P1,.ORJNU ;ASSUME JOB NUMBER
CAIN S1,.KYBRQ ;IS IT ANYTHING OTHER THAN BATCH REQ?
MOVX P1,.ORREQ ;BATCH REQUEST. SAVE BLOCK TYPE
CAIN S1,.KYALL ;WAS IT 'ALL-REQUESTS'?
JRST SALC.1 ;AND DON'T EXPECT A NUMBER
$CALL P$NUM ;GET THE JOB OR REQUEST NUMBER
SKIPT ;WAS THERE A NUMBER?
SALC.1: SETOM S1 ;NO, SAY -1 FOR JOB NUMBER
MOVE S2,S1 ;DATA WORD - JOB OR REQUEST NUMBER
MOVE S1,P1 ;BLOCK TYPE - FROM KEYWORD
$CALL MOVAR2 ;ADD THE TWO WORDS
PJRST CMDEND ;AND FINISH UP
>;END TOPS10
END