Trailing-Edge
-
PDP-10 Archives
-
BB-F494Z-DD_1986
-
10,7/rnxtrc.mac
There are 4 other files named rnxtrc.mac in the archive. Click here to see a list.
TITLE RNXTRC - TRACE RP20 OPERATIONS
SUBTTL G.M. UHLER/GMU
;THIS PROGRAM INSERTS SNOOP. BREAKPOINTS INTO THE RP20 DISK DRIVER
;(RNXKON) AT SELECTED POINTS TO GATHER DATA ON THE PERFORMANCE
;OF THE RP20. IT IS ALSO VERY USEFUL IN DEBUGGING INTERMITANT BUGS
;SINCE IT GIVES A RECORD OF WHAT HAPPENED. RNXTRC HAS TWO MODES,
;CONTINUOUS LOGGING, AND TERMINATION LOGGING. CONTINUOUS LOGGING
;LOGS ALL OPERATIONS FROM THE TIME THE BREAKPOINTS ARE INSERTED UNTIL
;THE PROGRAM IS TERMINATED. TERMINATION LOGGING ONLY LOGS THE LAST
;N EVENTS THAT OCCURRED PRIOR TO PROGRAM TERMINATION. IT SHOULD BE
;NOTED THAT CONTINUOUS LOGGING CAUSES MASSIVE AMOUNTS OF DATA TO BE
;WRITTEN TO THE LOGGING DEVICE SO CARE SHOULD BE TAKEN. IN EITHER
;MODE, THE RAW BINARY OUTPUT DATA IS WRITTEN TO RNXTRC:RNXTRC.BIN[-].
;A POSTPROCESSOR, RNXPRT, MUST THEN BE RUN TO FORMAT THE DATA INTO
;A FORM READABLE BY HUMANS.
;
;TO RUN RNXTRC, SIMPLY ASSIGN LOGICAL DEVICE RNXTRC AS YOUR FAVORITE
;PHYSICAL DEVICE, RUN THE PROGRAM AND FOLLOW THE DIRECTIONS.
SEARCH JOBDAT,MACTEN,UUOSYM,SNUP
.REQUIRE SNUP
SALL
;COPYRIGHT (C) 1980,1981,1982,1983 BY
;DIGITAL EQUIPMENT CORPORATION, MAYNARD, MASS.
;
;
;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.
RNTVER==1 ;MAJOR VERSION
RNTMIN==0 ;MINOR VERSION
RNTEDT==5 ;EDIT
RNTWHO==0 ;WHO LAST EDITED
LOC .JBVER
VRSN. (RNT)
RELOC
SUBTTL BREAKPOINT ENTRY FORMATS
ENTLEN==0 ;INITIALIZE MAXIMUM ENTRY SIZE
BPNUM==0 ;AND BREAKPOINT COUNT
;EACH ENTRY IN THE BUFFER CONTAINS THREE COMMON WORDS FOLLOWED BY
;N WORDS SPECIFIC TO EACH BREAKPOINT. ALL ENTRIES ARE THE LENGTH
;OF THE LONGEST ENTRY AND SHORTER ENTRIES SIMPLY IGNORE THE UNUSED
;WORDS. THE COMMON WORDS ARE AS FOLLOWS:
; !=======================================================!
; ! ENTRY TYPE ! SEQUENCE NUMBER !
; !-------------------------------------------------------!
; ! RDTIME VALUE IN MICROSECONDS !
; !-------------------------------------------------------!
; ! CPU NUMBER ! KONTROLLER NUMBER !
; !-------------------------------------------------------!
PHASE 0
BPNTYP:! BLOCK 1 ;TYPE OF ENTRY,,SEQUENCE NUMBER
BPNTIM:! BLOCK 1 ;RDTIME VALUE IN MICROSECONDS
BPNCKU:! BLOCK 1 ;CPU NUMBER,,KONTROLLER NUMBER
BPNHLN:! ;LENGTH OF THE HEADER
DEPHASE
;ENTRY OFFSETS SPECIFIC TO BREAKPOINT 1 ARE AS FOLLOWS:
; !-------------------------------------------------------!
; ! DATAO TO CONTROL REGISTER OR STCR !
; !-------------------------------------------------------!
; ! BLOCK ON UNIT !
; !-------------------------------------------------------!
; ! PHYSICAL UNIT NUMBER !
; !=======================================================!
PHASE BPNHLN
BP1DTO:! BLOCK 1 ;DATAO TO THE CONTROL REGISTER OR STCR
BP1BLK:! BLOCK 1 ;BLOCK ON UNIT
BP1UNI:! BLOCK 1 ;PHYSICAL UNIT NUMBER
IFG .-ENTLEN,<ENTLEN==.> ;FIND LARGEST ENTRY
BPNUM==BPNUM+1 ;AND COUNT BREAKPOINTS
DEPHASE
;ENTRY OFFSETS SPECIFIC TO BREAKPOINT 2 ARE AS FOLLOWS:
; !-------------------------------------------------------!
; ! ASYNCHRONOUS STATUS REGISTER !
; !-------------------------------------------------------!
; ! ENDING STATUS REGISTER ! ERROR REGISTER !
; !-------------------------------------------------------!
; ! CHANNEL STATUS ! CONI !
; !-------------------------------------------------------!
; ! RNXKON FLAGS WORD (P1) !
; !=======================================================!
PHASE BPNHLN
BP2ASY:! BLOCK 1 ;ASYNCHRONOUS STATUS REGISTER
BP2ERG:! BLOCK 1 ;ENDING STATUS,,ERROR REGISTERS
BP2CNI:! BLOCK 1 ;CHANNEL STATUS,,CONI
BP2FLG:! BLOCK 1 ;RNXKON FLAGS WORD (P1)
IFG .-ENTLEN,<ENTLEN==.> ;FIND LARGEST ENTRY
BPNUM==BPNUM+1 ;AND COUNT BREAKPOINTS
DEPHASE
;ENTRY OFFSETS SPECIFIC TO BREAKPOINT 3 ARE AS FOLLOWS:
; !-------------------------------------------------------!
; ! RNXKON/FILIO COMMUNICATIONS WORD !
; !-------------------------------------------------------!
; ! RNXKON FLAGS WORD (P1) !
; !-------------------------------------------------------!
; ! ENDING STATUS REGISTER ! ERROR REGISTER !
; !-------------------------------------------------------!
; ! CHANNEL STATUS ! CONI !
; !=======================================================!
PHASE BPNHLN
BP3COM:! BLOCK 1 ;RNXKON/FILIO COMMUNICATION WORD (T1)
BP3FLG:! BLOCK 1 ;RNXKON FLAGS WORD (P1)
BP3ERG:! BLOCK 1 ;ENDING STATUS,,ERROR REGISTERS
BP3CNI:! BLOCK 1 ;CHANNEL STATUS,,CONI
IFG .-ENTLEN,<ENTLEN==.> ;FIND LARGEST ENTRY
BPNUM==BPNUM+1 ;AND COUNT BREAKPOINTS
DEPHASE
;ENTRY OFFSETS SPECIFIC TO BREAKPOINT 4 ARE AS FOLLOWS:
; !-------------------------------------------------------!
; ! FUCTION FOR CURRENT OPERATION !
; !-------------------------------------------------------!
; ! RNXKON FLAGS WORD FOR OPERATION IN PROGRESS !
; !-------------------------------------------------------!
; ! PHYSICAL UNIT NUMBER FOR OPERATION TO BE STARTED !
; !=======================================================!
PHASE BPNHLN
BP4COP:! BLOCK 1 ;FUNCTION FOR CURRENT OPERATION
BP4PFL:! BLOCK 1 ;RNXKON FLAGS WORD FOR OPERATION IN PROGRESS
BP4UNI:! BLOCK 1 ;PHYSICAL UNIT NUMBER
IFG .-ENTLEN,<ENTLEN==.> ;FIND LARGEST ENTRY
BPNUM==BPNUM+1 ;AND COUNT BREAKPOINTS
DEPHASE
;ENTRY OFFSETS SPECIFIC TO BREAKPOINT 5 ARE AS FOLLOWS:
; !-------------------------------------------------------!
; ! ERROR BITS (KOP???) !
; !-------------------------------------------------------!
; ! CONI !
; !-------------------------------------------------------!
; ! ENDING STATUS REGISTER ! ERROR REGISTER !
; !-------------------------------------------------------!
; ! PHYSICAL UNIT NUMBER !
; !=======================================================!
PHASE BPNHLN
BP5ERB:! BLOCK 1 ;ERROR BITS (KOP???)
BP5CNI:! BLOCK 1 ;CONI
BP5ERG:! BLOCK 1 ;ENDING STATUS REGISTER,,ERROR REGISTER
BP5UNI:! BLOCK 1 ;PHYSICAL UNIT NUMBER
IFG .-ENTLEN,<ENTLEN==.> ;FIND LARGEST ENTRY
BPNUM==BPNUM+1 ;AND COUNT BREAKPOINTS
DEPHASE
;ENTRY OFFSETS SPECIFIC TO BREAKPOINT 6 ARE AS FOLLOWS:
; !-------------------------------------------------------!
; ! CONI !
; !=======================================================!
PHASE BPNHLN
BP6CNI:! BLOCK 1 ;CONI
IFG .-ENTLEN,<ENTLEN==.> ;FIND LARGEST ENTRY
BPNUM==BPNUM+1 ;AND COUNT BREAKPOINTS
DEPHASE
RELOC 0 ;DON'T WASTE THE PHASED SPACE
SUBTTL PARAMETER DEFINITIONS
OPDEF RDTIME[DATAI 020,]
D==1 ;DISK OUTPUT CHANNEL
PDLLEN==20 ;LENGTH OF PDL
BUFLEN==1500*ENTLEN ;LENGTH OF BUFFER
;TABLE GIVING DESCRIPTIONS OF EACH BREAKPOINT
EVDSCP: [ASCIZ/operation initiation at RNXGO/]
[ASCIZ/asynchronous status detected by CHKATN/]
[ASCIZ/interrupt exit in CALFIO/]
[ASCIZ/CONECT calls to CMDWAT/]
[ASCIZ/operation initiation errors at RNXDWN/]
[ASCIZ/hung transfer timeouts at RNXSTP/]
IFN <.-EVDSCP-BPNUM>,<PRINTX ?EVDSCP table length wrong>
;DEFINE REFERENCED SYMBOLS AND BREAKPOINTS
MONREF UNYPUN ;BYTE POINTER TO PHYSICAL UNIT
MONREF UNIBLK ;OFFSET OF BLOCK NUMBER IN UDB
MONREF .CPCPN ;CPU NUMBER ON WHICH WE'RE RUNNING
MONREF KOYKNM ;KONTROLLER NUMBER OF THIS KONTROLLER
;********** DO NOT CHANGE THE ORDER OF THE FOLLOWING LINES **********
DEFINE DEFNBP(N),<
BRKPNT RNXBP'N,BP'N
>
.ZZ==1
REPEAT BPNUM,<
DEFNBP (\.ZZ)
.ZZ==.ZZ+1
>
BRKPNT RNXBPX,BPX
;********** END OF ORDER DEPENDENT CODE **********
SUBTTL MACRO DEFINITIONS
;MACRO TO DO ALL THE SETUP NECESSARY WHEN A SNOOP LEVEL BREAKPOINT
;IS ENTERED. NOTE THAT BREAKPOINT NUMBER ^D99 IS THE SPECIAL SNOOP.
;LEVEL EXIT REQUEST BREAKPOINT.
;INVOCATION: ENTRBP (BREAKPOINT-NUMBER)
;LEAVES %T2 AT -1(%P) AND %T3 AT 0(%P) AND SETS UP %T2 TO POINT TO
;THE BASE OF THE BUFFER ENTRY TO USE.
DEFINE ENTRBP(NUMBER),<
PUSH %P,%T2 ;;SAVE T2
XLIST
PUSH %P,%T3 ;; AND T3
MOVSI %T2,NUMBER ;;TYPE IS INPUT ARGUMENT
IFN NUMBER-^D99,<
SKIPE EVFLAG+NUMBER-1(%R) ;;WANT TO LOG THIS EVENT?
>
PUSHJ %P,SETUP(%R) ;;DO INITIALIZATION
JRST BPRET(%R) ;;DON'T LOG THIS EVENT
LIST
>
;MACRO TO EXIT A SNOOP LEVEL BREAKPOINT.
;INVOCATION: EXITBP
DEFINE EXITBP,<
JRST BPEXIT(%R)
>
SUBTTL PROGRAM SETUP
RNXTRC: JFCL ;NO CCL ENTRY
RESET ;RESET EVERYTHING
MOVE P,[IOWD PDLLEN,PDL] ;SETUP A PDL
OPEN D,[EXP .IOIMG,'RNXTRC',<OBUF,,0>] ;OPEN CHANNEL
JRST NOOPEN ;FAILED
ENTER D,[EXP 'RNXTRC','BIN ',0,0] ;ENTER OUTPUT FILE
JRST NOENTR ;FAILED
OUTBUF D,4 ;SETUP 4 OUTPUT BUFFERS
MTREW. D, ;REWIND POSSIBLE TAPE
MTWAT. D, ;WAIT FOR IT TO FINISH
PUSHJ P,STRTUP ;ASK STARTUP QUESTIONS
MOVEI T1,0 ;GET ARG FOR TRPSET
TRPSET T1, ;GET USRIOT
JRST NOTRPS ;FAILED
MOVEI T1,1 ;SET FOR HPQ 1
HPQ T1, ;MAKE SURE WE RUN
JFCL ;SHOULDN'T HAPPEN
PUSHJ P,GETINF## ;DEFINE THE BREAKPOINTS
SETZM CNT ;ZERO THE SEQUENCE NUMBER
MOVEI T1,BUFLEN ;SETUP INITIAL BUFFER POINTER SO SNOOP
MOVEM T1,BUFPTR ; ROUTINES START AT THE START
CLRBFI ;DON'T ALLOW TYPEAHEAD TO ABORT US
OUTSTR [ASCIZ/
[Type an altmode to exit]
/]
RDTIME STIME ;READ BASE TIME
PUSHJ P,XWRSNP## ;INSERT THE BREAKPOINTS
MOVEI P1,0 ;INITIALIZE BACKGROUND ENTRY COUNT
MOVEI P2,BUFLEN ; AND BUFFER POINTER
SKIPN WINDOW ;WANT CONTINUOUS LOGGING?
JRST WATCH ;NO
;; JRST FOLLOW ;YES, FALL INTO FOLLOW
SUBTTL BACKGROUND TASK -- CONTINUOUS LOGGING
;HERE TO FOLLOW THE SNOOP LEVEL ROUTINE AROUND THE BUFFER, WRITING
;THE DATA TO THE OUTPUT FILE CONTINUOUSLY.
FOLLOW: INCHSL T1 ;GET CHARACTER FROM TTY, SKIP IF GOT ONE
JRST FOLLO1 ;NONE, CHECK BUFFER
CAIE T1,.CHESC ;ESCAPE?
JRST FOLLOW ;NO, TRY AGAIN
CLOSE D, ;CLOSE OUTPUT FILE
REMBRK ;REMOVE BREAKPOINTS
UNDBRK ;UNDEFINE THEM
EXIT ;EXIT
;HERE TO CHECK THE BUFFER TO SEE IF WE SHOULD WRITE ANYTHING TO THE
;OUTPUT FILE.
FOLLO1: CAMGE P1,CNT ;DID WE CATCH UP TO THE MONITOR?
JRST FOLLO2 ;NO, WRITE SOME DATA
MOVEI T1,1 ;HIBER FOR
HIBER T1, ; A TICK
JFCL ;SHOULDN'T HAPPEN
JRST FOLLOW ;AND CHECK CHARACTERS
;HERE WHEN THE MONITOR IS AHEAD OF US TO TRY TO CATCH UP BY WRITING
;DATA TO THE OUTPUT FILE.
FOLLO2: MOVEI T2,ENTLEN ;GET LENGTH OF ENTRY
FOLLO3: PUSHJ P,NXTWRD ;GET NEXT WORD FROM BUFFER
PUSHJ P,WRTWRD ;WRITE IT TO FILE
SOJG T2,FOLLO3 ;LOOP FOR ALL
AOJA P1,FOLLO1 ;INCREMENT COUNT AND GO FOR NEXT
SUBTTL BACKGROUND TASK -- TERMINATION LOGGING
;HERE TO LOG ONLY ON EXIT. THIS MEANS THAT THE MONITOR CONTINUOUSLY
;FILLS THE BUFFER BUT WE DO NOTHING UNTIL THE USER TYPES A CRLF OR
;THE SNOOP. LEVEL EXIT REQUEST BREAKPOINT IS EXECUTED. AT THAT POINT,
;WE WRITE THE CURRENT BUFFER TO THE OUTPUT FILE.
WATCH: SKIPE XITREQ ;HAVE SNOOP. LEVEL EXIT ENABLED?
JRST WATCH2 ;YES, DO IT DIFFERENTLY
WATCH1: INCHWL T1 ;WAIT FOR CHARACTER
CAIE T1,.CHESC ;ESCAPE?
JRST WATCH1 ;NO, WAIT FOR IT
JRST WATCH4 ;GO DO THE EXIT
WATCH2: MOVEI T1,100 ;SLEEP FOR
HIBER T1, ; 100 TICKS
JFCL ;DON'T CARE IF IT FAILED
INCHSL T1 ;CHARACTER AVAILABLE?
SKIPL T1,XITREQ ;NO, DID SNOOP. LEVEL REQUEST EXIT?
CAIN T1,.CHESC ;WAS CHARACTER AN ESCAPE?
CAIA ;YES, TO ONE
JRST WATCH2 ;NO, TRY AGAIN
MOVE T1,XITCNT ;GET ADDITIONAL ENTRIES TO BE SAVED
MOVEM T1,MAXCNT ;STORE FOR SNOOP. LEVEL
WATCH3: SKIPG MAXCNT ;DONE THEM ALL YET?
JRST WATCH4 ;YES
MOVEI T1,5 ;SLEEP FOR 5
HIBER T1, ; TICKS TO LET SNOOP. LEVEL FILL THEM
JFCL ;DON'T CARE
JRST WATCH3 ;CONTINUE WATCHING
WATCH4: REMBRK ;REMOVE BREAKPOINTS
UNDBRK ;UNDEFINE THEM
MOVE P1,CNT ;GET COUNT OF ENTRIES STORED IN BUFFER
JUMPE P1,WATCH6 ;QUIT NOW IF NONE
IMULI P1,ENTLEN ;CONVERT TO WORD COUNT
CAIL P1,BUFLEN ;MORE THAN 1 BUFFER FULL?
MOVEI P1,BUFLEN ;YES, MAKE IT JUST 1 BUFFER
MOVE P2,BUFPTR ;GET MONITOR BUFFER POINTER
SUBI P2,1-ENTLEN(P1) ;BACKUP BY NUMBER OF WORDS WRITTEN
SKIPGE P2 ;OFF THE BEGINNING OF THE BUFFER?
ADDI P2,BUFLEN ;YES, WRAP AROUND TO THE END
WATCH5: PUSHJ P,NXTWRD ;GET NEXT WORD
PUSHJ P,WRTWRD ;WRITE IT TO OUTPUT FILE
SOJG P1,WATCH5 ;DO THEM ALL
WATCH6: CLOSE D, ;CLOSE FILE
EXIT ;AND EXIT
SUBTTL INITIALIZATION ERROR PROCESSING CODE
NOOPEN: OUTSTR [ASCIZ/
?Can't OPEN output channel. Have you assigned logical device RNXTRC?
/]
EXIT
NOENTR: OUTSTR [ASCIZ/
?Can't ENTER output file RNXTRC.BIN[-]
/]
EXIT
NOTRPS: OUTSTR [ASCIZ/
?TRPSET failed. Are you privileged?
/]
EXIT
OUTERR: OUTSTR [ASCIZ/
?Output error writing file
/]
EXIT
SUBTTL SUPPORT SUBROUTINES
;ROUTINE TO UPDATE THE BUFFER TAKER POINTER TO THE NEXT WORD IN THE
;BUFFER AND RETURN THAT WORD TO THE CALLER.
;CALL: P2/CURRENT BUFFER POINTER
; PUSHJ P,NXTWRD
;RETURN+1 ALWAYS WITH:
; P2/UPDATED BUFFER POINTER
; T1/CONTENTS OF BUFFER WORD
NXTWRD: AOS P2 ;INCREMENT BUFFER POINTER
CAIL P2,BUFLEN ;OFF THE END?
MOVEI P2,0 ;YES, RESET IT
MOVE T1,BUFFER(P2) ;GET CONTENTS OF THAT WORD
CPOPJ: POPJ P, ;RETURN
;ROUTINE TO WRITE ONE WORD TO THE OUTPUT FILE.
;CALL: T1/WORD TO WRITE
; PUSHJ P,WRTWRD
;RETURN+1 ALWAYS
WRTWRD: SOSGE OBUF+.BFCTR ;ROOM IN THE BUFFER?
JRST WRTWR1 ;NO, FLUSH IT
IDPB T1,OBUF+.BFPTR ;STORE THE WORD IN THE BUFFER
POPJ P, ;RETURN
WRTWR1: OUT D, ;FLUSH THE BUFFER
JRST WRTWRD ;SUCCESSFUL, WRITE THE WORD
CLOSE D, ;CLOSE THE FILE
JRST OUTERR ;TELL OF ERROR
SUBTTL STARTUP OPTION SELECTION
;ROUTINE TO ASK THE USER FOR THE STARTUP OPTIONS FOR THE PROGRAM AND
;INITIALIZE THE VARIABLES USED BY THE SNOOP LEVEL ROUTINES.
;CALL: PUSHJ P,STRTUP
;RETURN+1 ALWAYS
STRTUP: SETOM BGNONE ;INITIALIZE FIRST VARIABLE
MOVE T1,[BGNONE,,BGNONE+1] ;SETUP FOR BLT
BLT T1,ENDONE ;DEFAULT THEM ALL
OUTSTR [ASCIZ/
RP20 trace program
/]
STRTU1: OUTSTR [ASCIZ/
Select output mode (Termination,Continuous): /]
MOVE T1,[IOWD 2,[EXP 'TERMIN','CONTIN']] ;SETUP LEGAL VALUES
PUSHJ P,GETSIX ;GET HIS ANSWER
JRST STRTU1 ;IT WAS ILLEGAL
MOVEM T1,WINDOW ;STORE
STRTU2: OUTSTR [ASCIZ/Use defaults (Yes,No)? /]
MOVE T1,[IOWD 2,[EXP 'YES ','NO ']] ;SETUP LEGAL VALUES
PUSHJ P,GETSIX ;GET HIS ANSWER
JRST STRTU2 ;IT WAS ILLEGAL
JUMPE T1,STRTU6 ;GO IF HE WANTS TO USE THE DEFAULTS
STRTU3: OUTSTR [ASCIZ/CPU number: /]
PUSHJ P,GETNUM ;GET AN OCTAL NUMBER
JRST STRTU3 ;IT WAS ILLEGAL
MOVEM T1,CPUNUM ;STORE IT
STRTU4: OUTSTR [ASCIZ/Kontroller number: /]
PUSHJ P,GETNUM ;GET AN OCTAL NUMBER
JRST STRTU4 ;IT WAS ILLEGAL
MOVEM T1,KONNUM ;STORE IT
PUSH P,P1 ;SAVE P1
MOVSI P1,-BPNUM ;MAKE AOBJN POINTER TO BREAKPOINT TABLES
STRTU5: OUTSTR [ASCIZ/Log /] ;START OF QUESTION
OUTSTR @EVDSCP(P1) ;TELL WHAT THIS BREAKPOINT IS
OUTSTR [ASCIZ/ (Yes,No)? /] ;WELL?
MOVE T1,[IOWD 2,[EXP 'YES ','NO ']] ;SETUP LEGAL VALUES
PUSHJ P,GETSIX ;GET THE ANSWER
JRST STRTU5 ;GO IF ILLEGAL
SKIPE T1 ;NO TO THIS ONE?
SETZM EVFLAG(P1) ;YES, DISALLOW LOGGING
AOBJN P1,STRTU5 ;LOOP FOR ALL
POP P,P1 ;RESTORE P1
STRTU6: SKIPE WINDOW ;TERMINATION LOGIGNG?
JRST CPOPJ ;NO, DON'T DO RNXBPX BREAKPOINT STUFF
STRTU7: OUTSTR [ASCIZ/Insert SNOOP. level exit breakpoint (No,Yes)? /]
MOVE T1,[IOWD 2,[EXP 'NO ','YES ']] ;SETUP LEGAL VALUES
PUSHJ P,GETSIX ;GET THE ANSWER
JRST STRTU7 ;ILLEGAL
SKIPN T1 ;IF NO,
SOS BRKBEG ; DON'T INSERT RNXBPX BREAKPOINT
JUMPE T1,CPOPJ ;IF YES,
AOS XITREQ ;SET XITREQ TO 1 AS A FLAG
STRTU8: OUTSTR [ASCIZ/Number of additionl entries to record after SNOOP.
level exit request has been detected: /]
PUSHJ P,GETNUM ;GET THE VALUE
JRST STRTU8 ;ILLEGAL
MOVEM T1,XITCNT ;STORE FOR LATER
POPJ P, ;RETURN
;ROUTINE TO READ A SIXBIT ATOM FROM THE COMMAND STRING.
;CALL: T1/IOWD N,ADDR OF VALID SIXBIT ARGS
; PUSHJ P,GETSIX
;RETURN+1 IF ERROR
;RETURN+2 IF VALID ARG TYPED WITH:
; T1/OFFSET IN TABLE OF ANSWER
GETSIX: PUSH P,T1 ;SAVE IOWD TO LEGAL ANSWERS
SETZB T1,T2 ;CLEAR RESULT AND FLAGS
MOVE T4,[POINT 6,T2] ;SETUP BYTE POINTER TO RESULT
GETSI1: PUSHJ P,GETCHR ;GET CHARACTER
JRST GETSI2 ;SAW END OF LINE
CAIL T3," " ;MUST BE A LEGAL
CAILE T3,"_" ; SIXBIT CHARACTER
PJRST GETSI5 ;FLUSH TYPEAHEAD AND RETURN
SUBI T3,"A"-'A' ;CONVERT TO SIXBIT
TLNE T4,(77B5) ;ROOM IN WORD?
IDPB T3,T4 ;YES, STORE IT
SKIPN T1 ;SEEN ANY CHARACTERS YET?
TLOA T1,(77B5) ;NO, SETUP INITIAL MASK WORD
ASH T1,-6 ;SHIFT MASK OVER 6
JRST GETSI1 ;AND LOOP
GETSI2: JUMPE T1,GETSI4 ;GO IF JUST END OF LINE SEEN
MOVE T4,0(P) ;PUT IOWD TO TABLE IN T4
GETSI3: MOVE T3,1(T4) ;GET NEXT LEGAL ARGUMENT
AND T3,T1 ;MASK ONLY THOSE CHARACTERS TYPED
CAME T3,T2 ;MATCH?
AOBJN T4,GETSI3 ;NO, LOOP
JUMPGE T4,GETSI5 ;GO IF NO MATCH FOUND
SUB T4,0(P) ;COMPUTE OFFSET IN TABLE OF MATCH
MOVEI T1,(T4) ;RETURN RESULT IN T1
GETSI4: AOSA -1(P) ;GIVE SKIP RETURN
GETSI5: PUSHJ P,FLSLIN ;CLEAR TYPE AHEAD
POP P,(P) ;FLUSH STACK
POPJ P, ;RETURN
;ROUTINE TO READ AN OCTAL NUMBER FROM THE TERMINAL.
;CALL: PUSHJ P,GETNUM
;RETURN+1 IF ERROR
;RETURN+2 WITH NUMBER WITH:
; T1/NUMBER
GETNUM: SETZB T1,T2 ;T1=RESULT, T2=FLAG
GETNU1: PUSHJ P,GETCHR ;GET NEXT CHARACTER
JRST GETNU2 ;SAW END OF LINE
CAIL T3,"0" ;INSURE THAT IT
CAILE T3,"7" ; IS OCTAL
PJRST FLSLIN ;NOT, CLEAR TYPEAHEAD AND RETURN ERROR
SETOM T2 ;FLAG A CHARACTER SEEN
LSH T1,3 ;MAKE ROOM FOR DIGIT
IORI T1,-"0"(T3) ;INSERT THE NEW DIGIT
JRST GETNU1 ;LOOP FOR MORE
GETNU2: SKIPN T2 ;SEE ANY NUMBERS AT ALL?
SETOM T1 ;NO, SET TO DEFAULT OF -1
CPOPJ1: AOS (P) ;GIVE SKIP RETURN
POPJ P, ;RETURN
;ROUTINE TO CLEAR TYPEAHEAD WHEN AN ERROR IS DETECTED.
;CALL: PUSHJ P,FLSLIN
;RETURN+1 ALWAYS
FLSLIN: CLRBFI ;CLEAR TYPEAHEAD
POPJ P, ;RETURN
;ROUTINE TO READ ONE CHARACTER FROM THE COMMAND STRING. IGNORES
;SPACES, TABS, NULLS, AND CARRIAGE RETURNS. CONVERTS LOWER TO UPPER
;CASE.
;CALL: PUSHJ P,GETCHR
;RETURN+1 IF END OF LINE CHARACTER SEEN
;RETURN+2 WITH CHARACTER WITH:
; T3/CHARACTER
GETCHR: INCHWL T3 ;GET CHARACTER
JUMPE T3,GETCHR ;IGNORE NULLS,
CAIE T3,.CHCRT ; CARRIAGE RETURNS,
CAIN T3," " ; SPACES
JRST GETCHR
CAIN T3,.CHTAB ; AND TABS
JRST GETCHR
CAIL T3,"a" ;LOWER CASE
CAILE T3,"z" ; LETTER?
CAIA ;NO
SUBI T3,"a"-"A" ;YES, CONVERT TO UPPER
PUSH P,T3 ;SAVE THE CHARACTER
MOVEI T3,1 ;GET A BIT TO SHIFT
LSH T3,@0(P) ;SHIFT BY VALUE OF CHARACTER
TDNN T3,BRKMSK ;IS IT A BREAK CHARACTER?
AOS -1(P) ;YES, SET FOR SKIP RETURN
POP P,T3 ;RETORE CHARACTER TO T3
POPJ P, ;RETURN
BRKMSK: 1_.CHBEL!1_.CHLFD!1_.CHVTB!1_.CHFFD!1_.CHESC
SUBTTL SNOOP LEVEL ROUTINES
;HERE JUST BEFORE DOING THE DATAO TO START THINGS UP AT RNXGO.
BP1: ENTRBP (1) ;DO BREAKPOINT SETUP
MOVEM %T1,BUFFER+BP1DTO(%T2) ;STORE DATAO WORD IN BUFFER
HRRZ %T3,%U ;GET UDB ADDRESS
ADD %T3,UNIBLK(%R) ;ADD OFFSET TO UNIBLK
MOVE %T3,(%T3) ;GET BLOCK NUMBER
MOVEM %T3,BUFFER+BP1BLK(%T2) ;STORE IN BUFFER
LDB %T3,@UNYPUN(%R) ;GET PHYSICAL UNIT NUMBER FROM UDB
MOVEM %T3,BUFFER+BP1UNI(%T2) ;STORE IN BUFFER
EXITBP ;EXIT THE BREAKPOINT
;HERE WHEN AN ASYNCHRONOUS EVENT WAS DETECTED IN CHKATN.
BP2: ENTRBP (2) ;DO BREAKPOINT SETUP
MOVE %T3,-1(%P) ;GET ASYNCHRONOUS STATUS REGISTER
MOVEM %T3,BUFFER+BP2ASY(%T2) ;STORE IN BUFFER
MOVSM %P2,BUFFER+BP2ERG(%T2) ;STORE ES,,ER IN BUFFER
MOVEM %P3,BUFFER+BP2CNI(%T2) ;STORE CS,,CI IN BUFFER
MOVEM %P1,BUFFER+BP2FLG(%T2) ;STORE FLAGS WORD IN BUFFER
EXITBP ;EXIT THE BREAKPOINT
;HERE AT INTERRUPT EXIT JUST BEFORE DISPATCHING TO FILIO
BP3: ENTRBP (3) ;DO BREAKPOINT SETUP
MOVEM %T1,BUFFER+BP3COM(%T2) ;STORE COMMUNICATION WORD
MOVEM %P1,BUFFER+BP3FLG(%T2) ;PLUS FLAGS WORD
MOVSM %P2,BUFFER+BP3ERG(%T2) ;PLUS ERROR REGISTERS
MOVEM %P3,BUFFER+BP3CNI(%T2) ;PLUS CONI
EXITBP ;EXIT THE BREAKPOINT
;HERE FROM CONECT WHEN AN OPERATION IS IN PROGRESS TO PROCESS IT
;BEFORE STARTING THE NEW ONE.
BP4: ENTRBP (4) ;DO BREAKPOINT SETUP
MOVEM %T1,BUFFER+BP4COP(%T2) ;STORE FUNCTION CODE IN BUFFER
MOVEM %T4,BUFFER+BP4PFL(%T2) ;STORE FLAGS FOR PREVIOUS OPERATION
LDB %T3,@UNYPUN(%R) ;GET UNIT NUMBER OF DRIVE
MOVEM %T3,BUFFER+BP4UNI(%T2) ;STORE IN BUFFER
EXITBP ;EXIT THE BREAKPOINT
;HERE WHEN CONECT DECLARES THE UNIT DOWN FOR ONE REASON OR ANOTHER.
BP5: ENTRBP (5) ;DO BREAKPOINT SETUP
MOVEM %T1,BUFFER+BP5ERB(%T2) ;STORE ERROR BITS IN BUFFER
MOVE %T3,-1(%P) ;GET CONI FROM STACK
MOVEM %T3,BUFFER+BP5CNI(%T2) ;STORE IN BUFFER
MOVE %T3,0(%P) ;GET ENDING STATUS,,ERROR REGISTER FROM STACK
MOVEM %T3,BUFFER+BP5ERG(%T2) ;STORE IN BUFFER
LDB %T3,@UNYPUN(%R) ;GET PHYSICAL UNIT NUMBER
MOVEM %T3,BUFFER+BP5UNI(%T2) ;STORE IN BUFFER
EXITBP ;EXIT THE BREAKPOINT
;HERE WHEN FILIO TIMES OUT A TRANSFER TO CAUSE AN INTERRUPT TO
;FORCE THE RH20 TO STOP.
BP6: ENTRBP (6) ;DO BREAKPOINT SETUP
MOVE %T3,-1(%P) ;GET CONI FROM STACK
MOVEM %T3,BUFFER+BP6CNI(%T2) ;STORE IN BUFFER
EXITBP ;EXIT THE BREAKPOINT
;HERE FROM THE SPECIAL SNOOP. LEVEL EXIT REQUEST BREAKPOINT. SET
;THE VARIABLE XITREQ TO -1 SO THAT THE BACKGROUND TASK WILL REMOVE
;THE BREAKPOINTS AND LOG THIS EVENT. NO DATA IS DEFINED FOR THIS
;EVENT (BUT MAY BE INSERTED), SO JUST ZERO THE REST OF THE BUFFER.
DEFINE ZROBUF(N),<
SETZM BUFFER+N(%T2)
>
BPX: SETOM XITREQ(%R) ;FLAG THE EXIT REQUEST
ENTRBP (^D99) ;DO BREAKPOINT SETUP FOR SPECIAL BREAKPOINT
.ZZ==BPNHLN
REPEAT <ENTLEN-BPNHLN>,<
ZROBUF (\.ZZ)
.ZZ=.ZZ+1
>
EXITBP ;EXIT THE BREAKPOINT
;HERE TO EXIT FROM ALL BREAKPOINTS (CALLED BY THE EXITBP MACRO)
BPEXIT: AOS %T3,CNT(%R) ;INCREMENT COUNT OF ENTRIES
HRRM %T3,BUFFER+BPNTYP(%T2) ;STORE IN RH OF 1ST WORD
BPRET: POP %P,%T3 ;RESTORE T3
POP %P,%T2 ;RESTORE T2
POPJ %P, ;RETURN
;ROUTINE TO PERFORM INITIALIZATION COMMON TO ALL BREAKPOINTS.
;CALL: %T2/TYPE,,0
; PUSHJ %P,SETUP(%R)
;RETURN+1 IF THIS EVENT SHOULD NOT BE LOGGED
;RETURN+2 TO LOG THIS EVENT WITH:
; %T2/RELOCATED BASE ADDRESS OF BUFFER ENTRY
SETUP: SOSL %T3,MAXCNT(%R) ;WANT TO CONTINUE LOGGING?
SKIPL %T3,CPUNUM(%R) ;USER SPECIFY A PARTICULAR CPU?
CAMN %T3,@.CPCPN(%R) ;YES, DOES IT MATCH THIS ONE?
CAIA ;YES, CONTINUE
POPJ %P, ;NO, GIVE NON-SKIP RETURN
LDB %T3,@KOYKNM(%R) ;GET KONTROLLER NUMBER FROM KDB
SKIPL KONNUM(%R) ;USER SPECIFY A PARTICULAR KONTROLLER?
CAMN %T3,KONNUM(%R) ;YES, DOES IT MATCH THIS ONE?
CAIA ;YES, CONTINUE
POPJ %P, ;NO, GIVE NON-SKIP RETURN
PUSH %P,%T2 ;SAVE TYPE,,LENGTH
RDTIME %T2 ;READ CURRENT TIMEBASE
DSUB %T2,STIME(%R) ;SUBTRACT BASE TIME
ASHC %T2,-^D12 ;RIGHT JUSTIFY
MOVEI %T2,ENTLEN ;GET LENGTH OF ENTRY
ADDB %T2,BUFPTR(%R) ;UPDATE BUFFER POINTER
CAIL %T2,BUFLEN ;OFF THE END?
SETZB %T2,BUFPTR(%R) ;YES, RESET TO THE BEGINNING
ADDI %T2,(%R) ;RELOCATE THE OFFSET
POP %P,BUFFER+BPNTYP(%T2) ;STORE TYPE IN BUFFER
MOVEM %T3,BUFFER+BPNTIM(%T2) ;ALONG WITH TIME
LDB %T3,@KOYKNM(%R) ;GET KONTROLLER NUMBER
HRL %T3,@.CPCPN(%R) ;PUT CPU NUMBER IN LH
MOVEM %T3,BUFFER+BPNCKU(%T2) ;STORE IN BUFFER
AOS 0(%P) ;GIVE SKIP RETURN
POPJ %P, ;RETURN
SUBTTL DATA LOCATIONS
XLIST ;LITERALS UNDER XLIST
LIT
LIST
BGNONE: ;FIRST WORD TO SET TO -1 FOR DEFAULT
; STARTUP OPTIONS
CPUNUM: BLOCK 1 ;CPU NUMBER OF CPU FOR WHICH DATA IS
; DESIRED. -1 IF NO PARTICULAR CPU
KONNUM: BLOCK 1 ;KONTROLLER NUMBER OF KONTROLLER FOR
; WHICH DATA IS DESIRED. -1 IF NO
; PARTICULAR KONTROLLER
EVFLAG: BLOCK BPNUM ;BLOCK OF FLAGS INDICATING WHETHER OR
; NOT TO LOG EACH BREAKPOINT. -1 TO LOG
; IT, 0 TO IGNORE IT.
ENDONE==.-1 ;LAST WORD TO SET TO -1 FOR DEFAULT
; STARTUP OPTIONS
WINDOW: EXP 0 ;SET TO ZERO TO NOT WRITE ANYTHING TO
;THE OUTPUT FILE UNTIL THE CRLF IS
;TYPED. THEN WRITE JUST THE CURRENT
;BUFFER
MAXCNT: XWD 377777,777777 ;NUMBER OF ENTRIES TO RECORD IN BUFFER
XITREQ: EXP 0 ;0 IF RNXBPX BREAKPOINT NOT INSERTED
;1 IF INSERTED BUT NOT YET REACHED
;-1 IF INSERTED AND REACHED
XITCNT: EXP -1 ;NUMBER OF ADDITIONALY ENTRIES TO LOG
;AFTER RNXBPX EXIT REQUEST
PDL: BLOCK PDLLEN ;PUSH DOWN LIST
OBUF: BLOCK 3 ;OUTPUT FILE BUFFER HEADER
STIME: BLOCK 2 ;BASE FOR RDTIME
CNT: BLOCK 1 ;SEQUENCE NUMBER/COUNT OF BUFFER ENTRIES
BUFPTR: BLOCK 1 ;POINTER TO CURRENT BUFFER LOCATION
BLOCK 20 ;ABJECT PARANOIA
BUFFER: BLOCK BUFLEN ;THE BUFFER
BLOCK 20 ;MORE PARANOIA
END RNXTRC