Difference between revisions of "RK11 disk controller"
|  (→Disk ''n'') |  (→RKV11-D:  adding picture of RKV11-D and H780 removed from mounting box, description of mounting) | ||
| (50 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| − | + | The '''RK11''' and '''RKV11''' series of controllers for the [[UNIBUS]] and [[QBUS]] are for the earlier RK moving-[[head]] [[magnetic storage|magnetic]] [[disk]] [[drive]]s ([[RK02/03 disk drive|RK02]]-[[RK05 disk drive|RK05]]), all based on the [[IBM 2315]] drive and pack. | |
| − | The '''RK11'''  | ||
| − | == | + | (The later [[RK06/07 disk drive|RK06 and RK07]], and their controller, the [[RK611]], are a different and entirely incompatible  drive and pack.) | 
| − | + | ||
| + | There are several models of the RK11, which are basically identical in their programming interface; differences between them are discussed in the sections on the individual models (below). | ||
| + | |||
| + | The UNIBUS RK11's all connect to the RK drive(s) through a [[bus]] carried over a [[BC11A]] cable, the standard UNIBUS cable. | ||
| + | |||
| + | ==Early RK11 version== | ||
| + | |||
| + | Although the [[RK11-C disk controller|RK11-C]] (below) is the earliest documented version, there are a few clues which indicate that there was an earlier version (one for which no documentation remains). | ||
| + | |||
| + | First, there is an image of a [[DEC indicator panel]] (image [http://ana-3.lcs.mit.edu/~jnc/tech/pdp11/jpg/panels/RK11B.jpg here]) which seems to be from a pre-RK11-C; it clearly seems to be an RK11 panel of some sort, but the pinout of the RK11-C indicator panel connector (engineering drawing "RK11-C Indicator Connectors: RK11-C-23") has differences with this one. | ||
| + | |||
| + | In particular, on the panel in the image, the lower right line of lights on the panel shows 3 bits of Major State; on the RK11-C prints (on connector B32) there are 5 individual bits (Postamble, Checksum, Data, Header, Preamble). To explore this further, on the "Major States" RK11-C drawing (RK11-C-04), in the upper left corner, there is a row of 6 flops, each labeled with one of those states (plus one for 'Idle'), arranged in a chain - the output of each driving an individual light. However, the 3 bits for 'Major State' on the display panel imply it is binary coded - likely implemented with a counter. | ||
| + | |||
| + | Also, the signal "COUNT MSR" (likely 'Major State Register') is exactly what one would expect to see if the major state had previously been held in a counter, not a string of flops. It makes no sense to expend the effort synthesize that signal (on the next page, RK11-C-05, "MSR Control") when the individual signals which go into it could have been used, as is, to clock each flop in the chain. | ||
| + | |||
| + | A reasonable ''guess'', in light of these facts, is that in some previous version, a counter had been used, but had had a problem of some sort, and had therefore been replaced by the string of flops. (The reason is unknown, but perhaps it was a binary counter, not [[Gray code]], and the decoding into states was producing glitches.) | ||
| + | |||
| + | A plausible scenario is that such an earlier version was produced in very small numbers - perhaps as prototypes, only internal to DEC. (If there had been problems discovered with glitches in the major state counter, they would not have wanted to release it as a product.) Or if it was released as a product, perhaps they were all recalled and replaced with RK11-C's. | ||
| + | |||
| + | In this regard, it is interesting to note the DEC ''Spare Module Handbook'', lists only the RK11-C and -D, but '''does''' list the [[KT11-B]], a ''rara avis'' indeed. This argues that the predecessor did not exist 'in the wild'. | ||
| + | |||
| + | ==RK11-C== | ||
| + | |||
| + | {{Main article | RK11-C disk controller}} | ||
| + | |||
| + | Like many of the earlier large peripheral controllers for the [[PDP-11]], the RK11-C was a large custom [[wire-wrap]]ped [[backplane]] which bolts into the front or back of a 19 inch rack, such as an [[H960 rack|H960]]; into it were plugged about 40 small M-Series [[FLIP CHIP]]s. | ||
| + | |||
| + | The RK11-C supports up to 4 drives per device bus (it uses 4 different 'select' lines on the bus, one of which is asserted at a time), and has two device busses. | ||
| + | |||
| + | ==RK11-D== | ||
| + | |||
| + | The RK11-D was a re-implementation of the RK11-C on four [[DEC card form factor|quad]] cards (M7254-7), which plugged into a custom-wired 4 slot hex-high [[system unit]] [[backplane]], for a [[BA11 mounting boxes|BA11]] slide-out mounting box. | ||
| + | |||
| + | It was [[program compatible]] with the RK11-C, except that the RK11-D did not contain the Maintenance Register of the earlier controller. In the RK11-D, the bus location of the MR responds, but according to the engineering drawings, it reads as zero, and written data is ignored. | ||
| + | |||
| + | The RK11-D supports up to 8 drives per device bus (it uses 3 'select' lines on the bus, with the drive number encoded in binary), and has only one device bus. | ||
| + | |||
| + | The RK11-D also has a 6-word [[First-In First-Out buffer|FIFO buffer]] between the disk and the bus (see sheet 7 of the M7256 engineering drawings). The original RK11-C had only one word of buffering, which was probably not enough, and likely the reason for the [[RK11-C disk controller#Double Buffered RK11-C|double-buffered RK11-C version]]. | ||
| + | |||
| + | ==RK11-E== | ||
| + | |||
| + | The RK11-E (sometimes called the RK15) was a variant of the RK11-D which supported 18-bit data; it was used with the [[PDP-15]]. It used the same cards as the RK11-D, with a jumper selection for 18-bit operation, and a different clock crystal. | ||
| + | |||
| + | It was used with the [[UNICHANNEL 15 System|UC15 Unichannel]], which used a PDP-11 (usually a [[PDP-11/05]]) acting as a slave to the PDP-15; the RK11-E was plugged into the UNIBUS on the PDP-11. | ||
| + | |||
| + | It used the two [[UNIBUS parity]] lines for the two extra data bits on the 18-bit PDP-15. The two extra bits were not used by the PDP-11 or its memory, but went straight through the [[MX15-B Memory Multiplexer]], directly to the PDP-15's [[main memory]]. | ||
| + | |||
| + | ==RKV11-D== | ||
| + | |||
| + | [[Image:RKV11-D.jpg|200px|thumb|right|RKV11-D card cage and [[H780]] power supply]] | ||
| + | |||
| + | The RKV11-D is a variant of the RK11-D for the QBUS (the others are all UNIBUS). | ||
| + | |||
| + | It uses three of the four quad cards of the RK11-D (M7254-6), along with a replacement fourth card (M7268), in a different custom 4 slot quad-high system unit backplane. The M7268 is connected via two pairs of [[flat cable]]s to two dual cards, one of which (M7269) plugs into a QBUS backplane slot, and the other (M993-YA) into the first RK05 drive. The RKV11-D is mounted in a [[BA11-M]] style mounting box with [[H780]] power supply. The [[BA11-M]] front panel is replaced with an expansion box front panel, with a single indicator for '''DCOK'''. | ||
| + | |||
| + | It is program compatible with the RK11-D, except that it only supports [[Q16]] QBUS mode when writing data. The two extended memory bits in the CSR have no effect; they may be read and written, but are not connected to anything. | ||
| ==Device registers== | ==Device registers== | ||
| Line 26: | Line 80: | ||
| |Data Buffer Register           || RKDB || 777416 | |Data Buffer Register           || RKDB || 777416 | ||
| |} | |} | ||
| + | |||
| ===777400: Drive Status Register (RKDS)=== | ===777400: Drive Status Register (RKDS)=== | ||
| {{16bit-header}} | {{16bit-header}} | ||
| − | | colspan=3 | Drive  | + | | colspan=3 | Drive ID || DPL || RK05 || DRU || SIN || SCOK || DRY || R/W/S Ready || WPS || SC=CA || colspan=4 | Sector Counter | 
| − | {{ | + | {{16bitoctal-bitout}} | 
| + | |||
| + | Note that in the '''''diagram''''' of this register in the 'peripherals handbook' (both 1975 and 1976 editions), bits 7 and 6 are labelled incorrectly; the ''table'' which lists the bits has them correctly. | ||
| + | |||
| + | (To confirm this, consult the RK11-D print set, M7254 page 3; the dual 4->1 muxes which fill this page are the source of the RKDS, RKER, etc registers.) | ||
| + | |||
| + | The name of bit 6 has changed slightly from the RK11-C to the -D ("Access Ready" to "R/W/S Ready"), but it seems to be basically the same functionality. | ||
| ===777402: Error Register (RKER)=== | ===777402: Error Register (RKER)=== | ||
| Line 37: | Line 98: | ||
| {{16bit-header}} | {{16bit-header}} | ||
| | DRE || OVR || WLO || SKE || PGE || NXM || DLT || RTE || NXD || NXC || NXS || colspan=3 | || CSE || WCE | | DRE || OVR || WLO || SKE || PGE || NXM || DLT || RTE || NXD || NXC || NXS || colspan=3 | || CSE || WCE | ||
| − | {{ | + | {{16bitoctal-bitout}} | 
| ===777404: Control Status Register (RKCS)=== | ===777404: Control Status Register (RKCS)=== | ||
| {{16bit-header}} | {{16bit-header}} | ||
| | ERR || H.E. || SCP || M || IBA || FMT || R/WA || SSE || RDY || IDE || colspan=2 | EX. MEM || colspan=3 | FUNCTION || GO | | ERR || H.E. || SCP || M || IBA || FMT || R/WA || SSE || RDY || IDE || colspan=2 | EX. MEM || colspan=3 | FUNCTION || GO | ||
| − | {{ | + | {{16bitoctal-bitout}} | 
| + | |||
| + | Bit 9 is"Read/Write All" in the RK11-C, and unused in the -D; bit 12 is "Maint" in the -C, and unused in the -D. | ||
| + | |||
| + | {| class="wikitable" | ||
| + | ! Command !! Code || In CSR | ||
| + | |- | ||
| + | | Reset Controller || 0 || 0 | ||
| + | |- | ||
| + | | Write || 1 || 02 | ||
| + | |- | ||
| + | | Read || 2 || 04 | ||
| + | |- | ||
| + | | Write Check || 3 || 06 | ||
| + | |- | ||
| + | | Seek || 4 || 010 | ||
| + | |- | ||
| + | | Read Check || 5 || 012 | ||
| + | |- | ||
| + | | Reset Drive || 6 || 014 | ||
| + | |- | ||
| + | | Write Lock || 7 || 016 | ||
| + | |} | ||
| ===777406: Word Count Register (RKWC)=== | ===777406: Word Count Register (RKWC)=== | ||
| {{16bit-header}} | {{16bit-header}} | ||
| | colspan=16 | WC15 <---> WC00 | | colspan=16 | WC15 <---> WC00 | ||
| − | {{ | + | {{16bitoctal-bitout}} | 
| ===777410: Current Bus Address Register (RKBA)=== | ===777410: Current Bus Address Register (RKBA)=== | ||
| {{16bit-header}} | {{16bit-header}} | ||
| − | | colspan= | + | | colspan=15 | BA15 <---> BA01 || Unused | 
| − | {{ | + | {{16bitoctal-bitout}} | 
| ===777412: Disk Address Register (RKDA)=== | ===777412: Disk Address Register (RKDA)=== | ||
| {{16bit-header}} | {{16bit-header}} | ||
| | colspan=3 | DRIVE SELECT || colspan=8 | CYLINDER ADDRESS || SUR || colspan=4 | SECTOR ADDRESS | | colspan=3 | DRIVE SELECT || colspan=8 | CYLINDER ADDRESS || SUR || colspan=4 | SECTOR ADDRESS | ||
| − | {{ | + | {{16bitoctal-bitout}} | 
| ===777414: Maintenance Register (RKMR)=== | ===777414: Maintenance Register (RKMR)=== | ||
| {{16bit-header}} | {{16bit-header}} | ||
| | M. RCP || M. RDP || M. SPS || M. ADA || M. LAI || colspan=3 | || M. DRY || M. R/W/S || colspan=2 | || colspan=4 | MAINT. SECTOR COUNTER | | M. RCP || M. RDP || M. SPS || M. ADA || M. LAI || colspan=3 | || M. DRY || M. R/W/S || colspan=2 | || colspan=4 | MAINT. SECTOR COUNTER | ||
| − | {{ | + | {{16bitoctal-bitout}} | 
| + | |||
| + | This register is not present in the RK11-D; it reads as 0, and writes to it are discarded. | ||
| ===777416: Data Buffer Register (RKDB)=== | ===777416: Data Buffer Register (RKDB)=== | ||
| {{16bit-header}} | {{16bit-header}} | ||
| | colspan=16 | DB15 <---> DB00 | | colspan=16 | DB15 <---> DB00 | ||
| − | {{ | + | {{16bitoctal-bitout}} | 
| ==PDP-11 bootstraps== | ==PDP-11 bootstraps== | ||
| Line 73: | Line 158: | ||
| ===Disk 0=== | ===Disk 0=== | ||
| − | |||
| {| border=1   | {| border=1   | ||
| ! Address !! Data !! Mnemonic !! Description | ! Address !! Data !! Mnemonic !! Description | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| − | |1000||012700||MOV #177406,R0           ||Move  | + | |1000||012700||MOV #177406,R0           ||Move the address of the Word Count register into R0 | 
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| |1002||177406||                         || (constant) | |1002||177406||                         || (constant) | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| − | |1004||012710||MOV #177400,(R0)         ||Move  | + | |1004||012710||MOV #177400,(R0)         ||Move block size (negative) into Word Count register | 
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| |1006||177400||                         || (constant) | |1006||177400||                         || (constant) | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| − | |1010||012740||MOV #5,-( | + | |1010||012740||MOV #5,-(R0)        ||Move 'Read Go' command into CSR | 
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| |1012||000005||                         || (constant) | |1012||000005||                         || (constant) | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| − | |1014||105710||TSTB (R0)                ||Test  | + | |1014||105710||TSTB (R0)                ||Test for 'Done' bit in CSR | 
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| − | |1016||100376||BPL 1014                  ||Jump backward if  | + | |1016||100376||BPL 1014                  ||Jump backward if not set | 
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| − | |1020||005007||CLR PC                   || | + | |1020||005007||CLR PC                   ||Start loaded bootstrap with jump to 0 | 
| |} | |} | ||
| + | |||
| + | Note that the INIT pulse caused by hitting the 'Start' button will clear the Bus Adddress register, so the loaded block will be placed at location 0. | ||
| ===Disk ''n''=== | ===Disk ''n''=== | ||
| Line 104: | Line 190: | ||
| {| border=1 | {| border=1 | ||
| ! Address       !! Data         !! Mnemonic                     !! Description | ! Address       !! Data         !! Mnemonic                     !! Description | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 1000          || 012700       || MOV #177406, R0              || Store the address of the Word Count register in r0 | | 1000          || 012700       || MOV #177406, R0              || Store the address of the Word Count register in r0 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 1002          || 177406       || (constant)                   || (Which is 177406) | | 1002          || 177406       || (constant)                   || (Which is 177406) | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 1004          || 012760       || MOV xxxxxx, 000004(R0)       || Store the disk ID number in the Disk Address register | | 1004          || 012760       || MOV xxxxxx, 000004(R0)       || Store the disk ID number in the Disk Address register | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 1006          || xxxxxx       || (disk ID number)             || The disk number goes here. | | 1006          || xxxxxx       || (disk ID number)             || The disk number goes here. | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 1010          || 000004       || (index)                      || | | 1010          || 000004       || (index)                      || | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 1012          || 012700       || MOV #177406, R0              || Store the addresss of the Word Count register in r0 | | 1012          || 012700       || MOV #177406, R0              || Store the addresss of the Word Count register in r0 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 1014          || 177406       || (constant)                   || (Which is 177406) | | 1014          || 177406       || (constant)                   || (Which is 177406) | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 1016          || 012710       || MOV #177400, (R0)            || Store 177400 into the Word Count register, | | 1016          || 012710       || MOV #177400, (R0)            || Store 177400 into the Word Count register, | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 1020          || 177400       || (constant)                   || meaning that octal 400 words are to be read. | | 1020          || 177400       || (constant)                   || meaning that octal 400 words are to be read. | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 1022          || 012740       || MOV #000005, -(R0)           || Store 5 into the Control Status register | | 1022          || 012740       || MOV #000005, -(R0)           || Store 5 into the Control Status register | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 1024          || 000005       || (constant)                   || selecting the function "read" with 4, and "go" with 1 | | 1024          || 000005       || (constant)                   || selecting the function "read" with 4, and "go" with 1 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 1026          || 105710       || TSTB (R0)                    || Test the Control Status Register (upper) byte | | 1026          || 105710       || TSTB (R0)                    || Test the Control Status Register (upper) byte | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 1030          || 100376       || BPL *-1                      || Repeat if it's positive, that is Control Ready is cleared | | 1030          || 100376       || BPL *-1                      || Repeat if it's positive, that is Control Ready is cleared | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 1032          || 005007       || CLR PC                       || If not, clear the Program Counter (essentially, jump to 0) | | 1032          || 005007       || CLR PC                       || If not, clear the Program Counter (essentially, jump to 0) | ||
| |} | |} | ||
| Line 137: | Line 223: | ||
| {| border=1 | {| border=1 | ||
| ! Value !! Unit   | ! Value !! Unit   | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 020000 || Unit 1 | | 020000 || Unit 1 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 040000 || Unit 2 | | 040000 || Unit 2 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 060000 || Unit 3 | | 060000 || Unit 3 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 100000 || Unit 4 | | 100000 || Unit 4 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 120000 || Unit 5 | | 120000 || Unit 5 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccff;" | 
| | 140000 || Unit 6 | | 140000 || Unit 6 | ||
| − | |- style="background-color: # | + | |- style="background-color: #ccccdd;" | 
| | 160000 || Unit 7 | | 160000 || Unit 7 | ||
| |} | |} | ||
| Line 156: | Line 242: | ||
| </table> | </table> | ||
| − | == | + | ==External links== | 
| − | [http:// | + | |
| + | * [http://www.bitsavers.org/www.computer.museum.uq.edu.au/pdf/DEC-11-HRKDA-B-D%20RK11D%20and%20RK11-E%20Moving%20Head%20Disk%20Drive%20Controller%20Manual.pdf RK11-D and RK11-E moving head disk drive controller manual] (DEC-11-HRKDA-B-D) | ||
| + | * [http://www.bitsavers.org/www.computer.museum.uq.edu.au/pdf/EK-RK11D-OP-001%20RK11-D%20and%20RK11-E%20Moving%20Head%20Disk%20Drive%20Controller%20User's%20Manual.pdf RK11-D and RK11-E moving head disk drive controller user's manual] (EK-RK11D-OP-001) | ||
| + | * [http://www.bitsavers.org/pdf/dec/unibus/EK-RK11D-MM-002.pdf RK11-D and RK11-E moving head disk drive controller manual] (EK-RK11D-MM-002) | ||
| + | * [http://www.bitsavers.org/pdf/dec/qbus/EK-RKV11-OP-001_RKV11-D_Disk_Drive_Controller_Users_Manual_Jul1977.pdf RKV11-D disk drive controller user's manual] (EK-RKV11-0P-001)  | ||
| + | * [http://www.bitsavers.org/pdf/dec/unibus/RK11-D_RevP_Engineering_Drawings_Oct75.pdf RK11-D disk drive controller engineering drawings] (Rev P, 10-1975) | ||
| + | * [http://www.bitsavers.org/pdf/dec/unibus/RK11-D_RevR_Engineering_Drawings_Oct76.pdf RK11-D Engineering Drawings] (Rev R, 10-1976) | ||
| + | * [http://www.bitsavers.org/pdf/dec/unibus/RK11-D_ECOs.pdf RK11-D ECOs] | ||
| + | |||
| + | ==Further reading== | ||
| − | + | * ''RKV11-D disk drive controller technical manual'' (not available online, but in fiche - EP-RKV11-TM-001)  | |
| + | * ''RKV11-D Field Maintenance Print Set (MP00223)'' (not available online) | ||
| − | [ | + | [[Category: UNIBUS Storage Controllers]] | 
| − | [[Category: | + | [[Category: QBUS Storage Controllers]] | 
| − | [[Category:DEC  | + | [[Category: DEC Documentation Errors]] | 
Latest revision as of 16:52, 26 September 2024
The RK11 and RKV11 series of controllers for the UNIBUS and QBUS are for the earlier RK moving-head magnetic disk drives (RK02-RK05), all based on the IBM 2315 drive and pack.
(The later RK06 and RK07, and their controller, the RK611, are a different and entirely incompatible drive and pack.)
There are several models of the RK11, which are basically identical in their programming interface; differences between them are discussed in the sections on the individual models (below).
The UNIBUS RK11's all connect to the RK drive(s) through a bus carried over a BC11A cable, the standard UNIBUS cable.
Contents
- 1 Early RK11 version
- 2 RK11-C
- 3 RK11-D
- 4 RK11-E
- 5 RKV11-D
- 6 Device registers
- 6.1 777400: Drive Status Register (RKDS)
- 6.2 777402: Error Register (RKER)
- 6.3 777404: Control Status Register (RKCS)
- 6.4 777406: Word Count Register (RKWC)
- 6.5 777410: Current Bus Address Register (RKBA)
- 6.6 777412: Disk Address Register (RKDA)
- 6.7 777414: Maintenance Register (RKMR)
- 6.8 777416: Data Buffer Register (RKDB)
 
- 7 PDP-11 bootstraps
- 8 External links
- 9 Further reading
Early RK11 version
Although the RK11-C (below) is the earliest documented version, there are a few clues which indicate that there was an earlier version (one for which no documentation remains).
First, there is an image of a DEC indicator panel (image here) which seems to be from a pre-RK11-C; it clearly seems to be an RK11 panel of some sort, but the pinout of the RK11-C indicator panel connector (engineering drawing "RK11-C Indicator Connectors: RK11-C-23") has differences with this one.
In particular, on the panel in the image, the lower right line of lights on the panel shows 3 bits of Major State; on the RK11-C prints (on connector B32) there are 5 individual bits (Postamble, Checksum, Data, Header, Preamble). To explore this further, on the "Major States" RK11-C drawing (RK11-C-04), in the upper left corner, there is a row of 6 flops, each labeled with one of those states (plus one for 'Idle'), arranged in a chain - the output of each driving an individual light. However, the 3 bits for 'Major State' on the display panel imply it is binary coded - likely implemented with a counter.
Also, the signal "COUNT MSR" (likely 'Major State Register') is exactly what one would expect to see if the major state had previously been held in a counter, not a string of flops. It makes no sense to expend the effort synthesize that signal (on the next page, RK11-C-05, "MSR Control") when the individual signals which go into it could have been used, as is, to clock each flop in the chain.
A reasonable guess, in light of these facts, is that in some previous version, a counter had been used, but had had a problem of some sort, and had therefore been replaced by the string of flops. (The reason is unknown, but perhaps it was a binary counter, not Gray code, and the decoding into states was producing glitches.)
A plausible scenario is that such an earlier version was produced in very small numbers - perhaps as prototypes, only internal to DEC. (If there had been problems discovered with glitches in the major state counter, they would not have wanted to release it as a product.) Or if it was released as a product, perhaps they were all recalled and replaced with RK11-C's.
In this regard, it is interesting to note the DEC Spare Module Handbook, lists only the RK11-C and -D, but does list the KT11-B, a rara avis indeed. This argues that the predecessor did not exist 'in the wild'.
RK11-C
Main article: RK11-C disk controller
Like many of the earlier large peripheral controllers for the PDP-11, the RK11-C was a large custom wire-wrapped backplane which bolts into the front or back of a 19 inch rack, such as an H960; into it were plugged about 40 small M-Series FLIP CHIPs.
The RK11-C supports up to 4 drives per device bus (it uses 4 different 'select' lines on the bus, one of which is asserted at a time), and has two device busses.
RK11-D
The RK11-D was a re-implementation of the RK11-C on four quad cards (M7254-7), which plugged into a custom-wired 4 slot hex-high system unit backplane, for a BA11 slide-out mounting box.
It was program compatible with the RK11-C, except that the RK11-D did not contain the Maintenance Register of the earlier controller. In the RK11-D, the bus location of the MR responds, but according to the engineering drawings, it reads as zero, and written data is ignored.
The RK11-D supports up to 8 drives per device bus (it uses 3 'select' lines on the bus, with the drive number encoded in binary), and has only one device bus.
The RK11-D also has a 6-word FIFO buffer between the disk and the bus (see sheet 7 of the M7256 engineering drawings). The original RK11-C had only one word of buffering, which was probably not enough, and likely the reason for the double-buffered RK11-C version.
RK11-E
The RK11-E (sometimes called the RK15) was a variant of the RK11-D which supported 18-bit data; it was used with the PDP-15. It used the same cards as the RK11-D, with a jumper selection for 18-bit operation, and a different clock crystal.
It was used with the UC15 Unichannel, which used a PDP-11 (usually a PDP-11/05) acting as a slave to the PDP-15; the RK11-E was plugged into the UNIBUS on the PDP-11.
It used the two UNIBUS parity lines for the two extra data bits on the 18-bit PDP-15. The two extra bits were not used by the PDP-11 or its memory, but went straight through the MX15-B Memory Multiplexer, directly to the PDP-15's main memory.
RKV11-D
 
  The RKV11-D is a variant of the RK11-D for the QBUS (the others are all UNIBUS).
It uses three of the four quad cards of the RK11-D (M7254-6), along with a replacement fourth card (M7268), in a different custom 4 slot quad-high system unit backplane. The M7268 is connected via two pairs of flat cables to two dual cards, one of which (M7269) plugs into a QBUS backplane slot, and the other (M993-YA) into the first RK05 drive. The RKV11-D is mounted in a BA11-M style mounting box with H780 power supply. The BA11-M front panel is replaced with an expansion box front panel, with a single indicator for DCOK.
It is program compatible with the RK11-D, except that it only supports Q16 QBUS mode when writing data. The two extended memory bits in the CSR have no effect; they may be read and written, but are not connected to anything.
Device registers
| Register | Abbreviation | Address | 
|---|---|---|
| Drive Status Register | RKDS | 777400 | 
| Error Register | RKER | 777402 | 
| Control Status Register | RKCS | 777404 | 
| Word Count Register | RKWC | 777406 | 
| Current Bus Address Register | RKBA | 777410 | 
| Disk Address Register | RKDA | 777412 | 
| Maintenance Register | RKMR | 777414 | 
| Data Buffer Register | RKDB | 777416 | 
777400: Drive Status Register (RKDS)
| Drive ID | DPL | RK05 | DRU | SIN | SCOK | DRY | R/W/S Ready | WPS | SC=CA | Sector Counter | |||||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
Note that in the diagram of this register in the 'peripherals handbook' (both 1975 and 1976 editions), bits 7 and 6 are labelled incorrectly; the table which lists the bits has them correctly.
(To confirm this, consult the RK11-D print set, M7254 page 3; the dual 4->1 muxes which fill this page are the source of the RKDS, RKER, etc registers.)
The name of bit 6 has changed slightly from the RK11-C to the -D ("Access Ready" to "R/W/S Ready"), but it seems to be basically the same functionality.
777402: Error Register (RKER)
| DRE | OVR | WLO | SKE | PGE | NXM | DLT | RTE | NXD | NXC | NXS | CSE | WCE | |||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
777404: Control Status Register (RKCS)
| ERR | H.E. | SCP | M | IBA | FMT | R/WA | SSE | RDY | IDE | EX. MEM | FUNCTION | GO | |||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
Bit 9 is"Read/Write All" in the RK11-C, and unused in the -D; bit 12 is "Maint" in the -C, and unused in the -D.
| Command | Code | In CSR | 
|---|---|---|
| Reset Controller | 0 | 0 | 
| Write | 1 | 02 | 
| Read | 2 | 04 | 
| Write Check | 3 | 06 | 
| Seek | 4 | 010 | 
| Read Check | 5 | 012 | 
| Reset Drive | 6 | 014 | 
| Write Lock | 7 | 016 | 
777406: Word Count Register (RKWC)
| WC15 <---> WC00 | |||||||||||||||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
777410: Current Bus Address Register (RKBA)
| BA15 <---> BA01 | Unused | ||||||||||||||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
777412: Disk Address Register (RKDA)
| DRIVE SELECT | CYLINDER ADDRESS | SUR | SECTOR ADDRESS | ||||||||||||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
777414: Maintenance Register (RKMR)
| M. RCP | M. RDP | M. SPS | M. ADA | M. LAI | M. DRY | M. R/W/S | MAINT. SECTOR COUNTER | ||||||||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
This register is not present in the RK11-D; it reads as 0, and writes to it are discarded.
777416: Data Buffer Register (RKDB)
| DB15 <---> DB00 | |||||||||||||||
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | 
PDP-11 bootstraps
Disk 0
| Address | Data | Mnemonic | Description | 
|---|---|---|---|
| 1000 | 012700 | MOV #177406,R0 | Move the address of the Word Count register into R0 | 
| 1002 | 177406 | (constant) | |
| 1004 | 012710 | MOV #177400,(R0) | Move block size (negative) into Word Count register | 
| 1006 | 177400 | (constant) | |
| 1010 | 012740 | MOV #5,-(R0) | Move 'Read Go' command into CSR | 
| 1012 | 000005 | (constant) | |
| 1014 | 105710 | TSTB (R0) | Test for 'Done' bit in CSR | 
| 1016 | 100376 | BPL 1014 | Jump backward if not set | 
| 1020 | 005007 | CLR PC | Start loaded bootstrap with jump to 0 | 
Note that the INIT pulse caused by hitting the 'Start' button will clear the Bus Adddress register, so the loaded block will be placed at location 0.
Disk n
This bootstrap will boot from any disk in a daisy-chained multi-drive configuration. Memory location octal 1006 contains the unit number, as follows:
| 
 | 
 | 
External links
- RK11-D and RK11-E moving head disk drive controller manual (DEC-11-HRKDA-B-D)
- RK11-D and RK11-E moving head disk drive controller user's manual (EK-RK11D-OP-001)
- RK11-D and RK11-E moving head disk drive controller manual (EK-RK11D-MM-002)
- RKV11-D disk drive controller user's manual (EK-RKV11-0P-001)
- RK11-D disk drive controller engineering drawings (Rev P, 10-1975)
- RK11-D Engineering Drawings (Rev R, 10-1976)
- RK11-D ECOs
Further reading
- RKV11-D disk drive controller technical manual (not available online, but in fiche - EP-RKV11-TM-001)
- RKV11-D Field Maintenance Print Set (MP00223) (not available online)

