DL10 documentation
Phil Budne
phil at ultimate.com
Sat Jan 27 23:46:41 CST 2018
FWIW, Found these bits in the TOPS-10 7.04 sources:
http://pdp-10.trailing-edge.com/tops10_704_monitoranf_bb-x140c-sb/01/10,7/anf10/chk11.p11.html
Search for ";DETERMINE THE DL10 BASE ADDRESS"
Which tries setting the following bit pattern:
DL.CNX!DL.CPE!DL.CWC!DL.11C
Those bits and others can be found in:
http://pdp-10.trailing-edge.com/tops10_703_distr_bb-x140b-sb/02/10,7/703anf/s.p11.html
.SBTTL DL10 HARDWARE BITS
;
; DL10 - UNIBUS TO DECSYSTEM-10 MEMORY BUS INTERFACE
;
.IIF NDF DL.VEC,DL.VEC= 170 ; VECTOR ADR FOR DL10
DL.LVL= 4 ; CHANNEL FIVE
DL.11I= B15 ; BIT 15 - 11 INT(INTERRUPTS IF 11-INT-ENB SET)
DL.11C= B14 ; BIT 14 - CLEAR 11 INT
DL.10I= B13 ; BIT 13 - 10 INT
DL.10C= B12 ; BIT 12 - CLEAR 10 INT
DL.NXM= B11 ; BIT 11 - NXM(INTERRUPTS IF ERR ENB SET)
DL.CNX= B10 ; BIT 10 - CLEAR NXM
DL.PAR= B9 ; BIT 09 - PAR ERR(INTERRUPTS IF ERR ENB SET)
DL.CPE= B8 ; BIT 08 - CLEAR PAR ERR
DL.WCO= B7 ; BIT 07 - WCOV(INTERRUPTS IF ERR ENB SET)
DL.CWC= B6 ; BIT 06 - CLEAR WCOV
DL.PEN= B5 ; BIT 05 - PORT ENABLE
DLPENB= DL.PEN ;
DL.B04= B4 ; BIT 04 - (GUESS !)
DL.ERE= B3 ; BIT 03 - ERR ENABLE
DL.INE= B2 ; BIT 02 - 11 INT ENB
DL.B01= B1 ; BITS 00 & 01 - PIA
DL.B00= B0 ;
The (11 side) driver code for the DL10 is in:
http://pdp-10.trailing-edge.com/tops10_704_monitoranf_bb-x140c-sb/01/10,7/anf10/dndl10.p11.html
.SBTTL DNDL10 - PDP-10/PDP-11 INTERFACE 21 JUL 82
and defines a memory window (I'm assuming only the "STS" word contains
the above bits, and the rest is shared memory) using a window pointer
determinted by chk11 (see above):
.SBTTL DL10 WINDOW
BLOCK DL ;THIS IS THE DL-10 WINDOW
X STS ;DL10 STATUS REGISTER
X ,2 ;UNUSED
X NAM ;PROGRAM NAME BYTE POINTER (SIXBIT)
X ,1 ;NOT USED
X 11A ;PDP-11 ALIVE INDICATOR. INCREMENTED BY
; BY THE TEN ONCE/SECOND, SET TO 0 BY
; THE 11. IF <2 THEN 11 IS ALIVE.
X STP ;STOP CODE (FOR WHEN -11 DIES)
X DWN ;3 STATE SWITCH
; 1 => UP AND RUNNING
; 0 => DOWN, COMPLAIN TO THE OPERATOR
; -1 => DOWN BUT DON'T COMPLAIN
X UPT ;NOT USED?
X STA ;GLOBAL STATE WORD
DLS.DP=1 ;DEPOSIT 11 CORE
DLS.EX=2 ;EXAMIN 11 CORE
GBADDR=4 ; DL.ADR IS BAD
GHOLD=10 ; HOLD EVERYTHING
X ADR ;ADDRESS FOR EXAMINE/DEPOSITE IN 11 MEMORY
X DAT ;CONTENTS OF THE EXAMINE/DEPOSITE
X RLN ;MAXIMUM MESSAGE LENGTH 11 WILL ACCEPT
X MOD ;DL-10 MODIFICATION NUMBER
WINVER=1 ;WINDOW VERSION NUMVER
X 10A ;PDP-10 ALIVE INDICATOR. INCREMEMTED BY
; THE 11 ONCE/SECOND, SET -1 BY THE 10.
; IF <= 1, THE 10 IS ALIVE
X 10S ;STATUS OF THE 10
; 0 => INITIAL VALUE. NOTHING GOING ON
; 1 => STARTED INITIALIZATION
; -1 => UP AND RUNNING
X 11S ;STATUS OF THE 11.
; 0 => INITIAL VALUE. NOTHING GOING ON
; 1 => STARTED INITIALIZATION
; -1 => UP AND RUNNING
X IST ;INPUT STATUS FLABS
; B1 = FIRST PART
; B2 = SECOND PART
X ICT ;INPUT COUNT (10'S POINT OF VIEW)
X IDT ;INPUT DATA APPEARS HERE
X ,1 ;SECOND INPUT POINTER'S COUNT
X ,1 ;SECOND INPUT POINTER'S DATA
X OST ;OUTPUT FLAGS
; B0 SAYS OUTPUT READY TO TO
; B1-B4 SPECIFY THE CONVERSION
; 1 => LPT COMPRESSION
; 2 => BINARY (12 BIT) CONVERSION
X OCT ;FIRST OUTPUT BUFFER'S LENGTH
X ODT ;FIRST OUTPUT BUFFER'S DATA
X ,1 ;SECOND BUFFERS COUNT
X ,1 ;SECOND BUFFERS DATA
X ,1 ;THIRD BUFFERS LENGTH
X ,1 ;THIRD BUFFERS DATA
;END OF DL-10 WINDOW
A fun bit is:
;NOW TELL THE -10 THAT WE'RE UP TOO!
ADD #DL.NAM-DL.DAT,R2 ;RELOCATE R2 TO POINT TO THE NAME WORD
MOVB #'D-40,(R2) ;SEND OUR NAME TO THE -10
MOVB #'C-40,(R2)
MOVB #'7-40,(R2)
MOVB #'5-40,(R2)
In http://www.ultimate.com/phil/pdp10/10periphs I have:
DC75: sync (PDP-11/15 & DS11's via DL10) DN8x code base! (cf DAS85?)
so perhaps the front end that was progenitor of the ANF10 code?
In the above "DL10 WINDOW" definition, NAM is declared "PROGRAM NAME
BYTE POINTER (SIXBIT)", and as in SIXBIT, the values are ASCII - 40
(octal) but stored in to 8 bit locations in the '11, which suggests
that the entire "window" maps the low order six bits of PDP-11
locations in to 6 bits in a PDP-10 word!
Definitions for the '10 side are created with the MAP76 macro in
http://pdp-10.trailing-edge.com/tops10_704_monitoranf_bb-x140c-sb/01/10,7/mon/s.mac.html
The following follow the DLMAP macro (which expands the MAP76 macro):
;LINE PARAMETER CONTROL MESSAGES FOR THE DC76
XP LPCSPD,2 ;SET LINE SPEED (RECEIVE*10+TRANSMIT)
XP LPCABR,4 ;ENABLE AUTO BAUD RATE DETECT
XP LPCELE,6 ;SET TYPE ELEMENT
XP LPCAPL,10 ;SET/CLEAR APL MODE
XP LPCRVB,12 ;SET/CLEAR REVERSE BREAK
XP LPCUKB,14 ;UNLOCK KEYBOARD
XP LPCTDY,16 ;SET/CLEAR TIDY BIT
;TYPES OF DL-10 FRONT ENDS
XP TP.D76,1 ;FRONT END IS A DC76
XP TP.D44,2 ;FRONT END IS A DC44
XP TP.D47,3 ;FRONT END COMBINES DC44 AND DC76
XP TP.D75,4 ;OLD DECSYNC PROTOCOL
XP TP.D60,5 ;DN60 FRONT END
XP TP.D85,6 ;NEW DDCMP FRONT END
XP TP.D78,7 ;FRONT END IS A DAS78
;TYPES OF DTE-20 FRONT ENDS
XP DT.RSX,1 ;RSX20F
XP DT.ANF,2 ;ANF10
XP DT.IBM,3 ;IBM (DN60)
XP DT.DNT,4 ;DECNET
The '11 side DTE driver is:
http://pdp-10.trailing-edge.com/tops10_704_monitoranf_bb-x140c-sb/01/10,7/anf10/dndte.p11.html
.SBTTL DNDTE - KL10/PDP-11 INTERFACE 11 FEB 88
and for completeness, the '10 side driver for the DTE:
http://pdp-10.trailing-edge.com/tops10_704_monitoranf_bb-x140c-sb/01/10,7/mon/dteser.mac.html
DTE definitions:
http://pdp-10.trailing-edge.com/tops10_704_monitoranf_bb-x140c-sb/01/10,7/mon/dteprm.mac.html
More information about the cctalk
mailing list