PROJECT MAC April 8, 1974 Computer Systems Research Division ASYNCHRONOUS BIT SERIAL INTERFACE -- FUNCTIONAL SPECIFICATION by Richard H. Gumpertz and Kenneth T. Pogran ## 1. INTRODUCTION ### 1.1 Scope of this Document This document is the functional specification for the Asynchronous Bit Serial Interface (ABSI) designed and built by the first author to connect a Honeywell 6180 Multics system to an ARPA Network Interface Message Processor (IMP). It is intended to provide sufficient information to a programmer writing the Device Control Module software for the ABSI. In addition, it describes briefly the interface specifications which the ABSI meets, and the ABSI's deviations from those standards. A brief description of the physical characteristics of the prototype ABSI is also included. This document is <u>not</u> intended to provide a description of the design and operation of the ABSI, nor is it intended to provide detailed maintenance and trouble-shooting information. Persons desiring further information about the ABSI should contact: Kenneth T. Pogran M.I.T., Project MAC 545 Technology Square Cambridge, MA 02139 (617) 253-6012 Persons with access to the ARPA Network may send mail to Pogran at MIT-Multics. #### 1.2 General Description The Asynchronous Bit Serial Interface connects as a peripheral device to two Input/Output Multiplexor (IOM) Common Peripheral Interface (CPI) channels as defined in Honeywell document number 43A130524 (Revision H1), and to an ARPA Network IMP, as defined in Bolt. Beranek and Newman report #1822. Two CPI channels are required for full duplex operation, one for write operations (HOST to IMP), and the other for read operations (IMP to HOST). It uses the "two-way handshake" procedure (See BBN-1822) for communicating with the IMP. The ABSI will operate as either a Local or Distant Host allowing a theoretical maximum transfer rate of about 800,000 bits/sec. in each direction. The ABSI attempts to meet as closely as possible the CPI specifications; all known exceptions are summarized in section 6 below. It is expected that the interface will operate with any Honeywell 6000 series IOM Common Peripheral Channel. It has not been tested with a DataNet 355,600 IOC, or 645 GIOC channel. The following description assumes that the reader is familiar with BBN-1822 and the Common Peripheral Interface specifications and operation. No attempt is made to duplicate the information contained therein. #### 2. OPERATION The table below summarizes the commands accepted by the ABSI on each of the two Common Peripheral Channels to which it is connected. | OPCODE | (Octal) | CHANNEL | MEANING | |--------|---------|-------------|-----------------------------| | 00 | | Read, Write | REQUEST STATUS | | 01 | | Read | READ (Start input from IMP) | | 11 | | Write | WRITE (Start output to IMP) | | 20 | | Write | HOST DOWN | | 40 | | Read, Write | RESET STATUS | | 60 | | Write | HOST UP | The device code sent as part of the command sequence is ignored although its parity is checked. #### 2.1 Request Status This command returns the same status as the previous command on the same channel. Previous COMMAND REJECT status, however, will be ignored, so that if COMMAND REJECT status is received in reply to REQUEST STATUS, it indicates that there was an error in the transmission of the REQUEST STATUS command itself. Note that the status remembered from the previous command may indicate the substatus IMP DOWN even if the IMP has since come up. To correctly obtain the current IMP up/down status, RESET STATUS (section 2.5) should be used. (A similar situation exists for the substatus HOST DOWN.) Note also that the status returned by this command may be garbage if it is the first command given after initialization of the ABSI (see section 3 below). # 2.2 Read (01 on the read channel only) This command will start reading a message from the IMP. It will terminate under any of the following conditions: - The LAST IMP BIT line is raised by the IMP along with a data bit. - 2. The host up/down relay is changed to the down state by either of the following: - (a) the manual HOST DOWN pushbutton on the interface - (b) the HOST DOWN command on the write channel - 3. The IMP goes down (according to its up/down relay) - 4. The channel decides to terminate the command. Note that termination will not actually occur until just after a complete character (6 bits) has been transmitted to the channel. Possible reasons for termination by the channel are: ## 2.2 Continued - (a) The storage buffer indicated in the DATA DCW has been filled and there are no additional DATA DCW's. - (b) The channel is "masked" by the software (see the IOM specifications). - (c) Some other condition occurs which causes masking, such as a second "connect" to the channel before the first DCW list has been completed. - 5. An "initialize" signal is received (see section 3 below). Note that all transmissions are aborted immediately and no status is stored. When the "initialize" level is removed, the channel will be ready to accept a new command no matter what its previous state was. The "initialize" condition also forces the host up/down relay to open (i.e., indicate "host down". In normal operation, only cases 1 (COMPLETE MESSAGE, no errors) and 4a (INCOMPLETE MESSAGE, no errors) should occur. If the latter occurs, the termination status will be READY with substatus INCOMPLETE MESSAGE. The complete message may be constructed by appending the data read by the next READ command to the end of the data read by the present READ command. The ABSI does not raise the READY FOR NEXT IMP BIT line until a READ command is issued. Thus, there is no way to determine that the IMP has a message waiting unless a READ command is issued. It is expected that the software will normally keep a READ command pending whenever the system is in operation. The expected method for aborting such a read command is to issue a HOST DOWN command on the write channel. As mentioned above, pushing the HOST DOWN pushbutton or initializing the ABSI will also abort a READ command. ## 2.3 Write (11 on the write channel only) This command starts writing a message to the IMP. Normally termination will occur only on end of message condition in the buffer. Note, however, that any of the conditions listed in section 2.2 above for aborting the READ COMMAND also apply (except, obviously, 1 and 2b). The LAST HOST BIT level will be raised with the last bit transmitted only if termination is caused by the channel rather than by the ABSI. Also note that termination under conditions 4b and 4c (the channel becoming masked) will take place only after the next character (6 bits) has been sent to the IMP. #### 2.4 <u>Host Down</u> (20 on the write channel only) This command will open the relay closed by the HOST UP command. If a READ operation is taking place on the other channel, it will be aborted by the ABSI when the relay opens. It is possible that the HOST DOWN command will not take effect if followed too closely by a HOST UP command (i.e., the relay doesn't have time to open completely). Whenever the relay is open (or opening), READ and WRITE commands will be rejected with the status COMMAND REJECT and the substatus HOST DOWN. The HOST DOWN command may be simulated at any time with the manual HOST DOWN pushbutton. ## 2.5 Reset Status (40) This command is identical to REQUEST STATUS, except that any resettable status condition from the previous command will be reset. Resettable status is defined as: - 1. Any DATA ALERT condition - 2. INCOMPLETE MESSAGE substatus - 3. IMP DOWN substatus if the IMP is no longer down - 4. HOST DOWN substatus if a HOST UP command has subsequently been given. # 2.6 <u>Host Up</u> (60 on the write channel Only) This command causes the HOST MASTER READY line to be connected to the HOST READY TEST line by closure of a relay. The software must make sure that no READ or WRITE command is issued to either channel until the relay has had a chance to settle. The delay time is not specified here, as relay characteristics may vary. The relay in the prototype ABSI takes about 500 $\mu$ sec, but the programmer should probably allow 100 msec. to be safe. This command may be simulated at any time by pushing the manual HOST UP button. #### 3. INITIALIZATION Initialization of the ABSI resets it to a state in which it is ready to receive commands from both channels. Any operations in progress will be aborted without returning status. An "initialize" signal can be generated by any of the following: - 1. The manual "initialize" button is pushed. - 2. Either IOM channel opens a relay ("POX" line) which is used by the peripheral to check that the IOM channel is connected and has power applied. Note that this relay is opened by the "SYSTEM INITIALIZE" button on the IOM or the bootload console. The same effect is obtained if either of the channel cables is disconnected\*. (Note that if either side of the ABSI is set to the "offline" position (by the manual switch), all signals, including "initialize", from the corresponding channel will be ignored.) <sup>\*</sup> Note that if the IOM-ABSI cables are routed through a "Peripheral Switch" one may use these switches to initialize the ABSI. If this is done, the switches for both the read and the write sides should be "cycled" to make sure that both IOM channels are also reset. #### 4. SPECIAL INTERRUPTS When the IMP comes up (closes its IMP READY relay) a "special interrupt" will be signalled on the READ channel. Note that bounce in the relay contacts may cause several interrupts to be sent to the software; the software must be prepared to handle this. It is suggested that the software delay at least 100 msec. after receiving the first interrupt to allow the relay to settle. During this time the extra interrupts should be ignored. A somewhat more complex but safer alternative would be to restart the 100 msec. timer on each interrupt and not consider the IMP up until this interval has passed with no further interrupts. 5. STATUS The following status codes are defined for the ABSI: | Major Status | <u>Substatus</u> | <u>Meaning</u> | |--------------|------------------|-----------------------------------| | 0000 | • | Ready | | | xx1 xxx | IMP Down | | | x1x xxx | HOST Down | | | 1xx xxx | Incomplete Message | | 0011 | | Data Alert | | | xxx 1xx | Parity Error | | | xx1 xxx | IMP Down | | | x1x xxx | HOST Down | | * | 1xx xxx | Incomplete Message | | 0101 | | Command Reject | | | xxx xx1 | Invalid Operation Code | | | xxx 1xx | Parity Error in Command Sequence | | | xx1 xxx | IMP Down | | | x1x xxx | HOST Down | | | 1xx xxx | Incomplete Message | | 1000 | | Channel/Peripheral Subsystem Busy | Any combination of substatus conditions listed under the same major status may occur simultaneously. In this case, the substatus returned will have more than one bit set to the 1 state. # 5.1 Ready Status READY major status indicates that the ABSI is ready to accept a command on that channel, and that no (unreset) errors occurred in the previous command on that channel. # 5.1.1 <u>IMP Down Substatus</u> (READY) IMP DOWN substatus indicates that the IMP READY relay is open (i.e., the IMP READY TEST line is not connected to the IMP MASTER READY line). Once this bit comes on (i.e., the IMP goes down) it stays on until it is reset by a command other than REQUEST STATUS (e.g., REST STATUS). This relay, like the host up/down relay, is subject to bounce and so it is desirable to wait for the relay to settle before rechecking the status. One could also wait for the special interrupt which says the IMP is up (see section 4 above), but this may be unreliable if race conditions are not carefully considered (The software may receive the special interrupt before the IMP DOWN status). A "timeout" on waiting for the interrupt is suggested. #### 5.1.2 Host Down Substatus (READY) HOST DOWN substatus indicates in a similar manner that host up/down relay has been, is, or is becoming open. ## 5.1.3 <u>Incomplete Message Substatus (READY)</u> INCOMPLETE MESSAGE substatus may occur only on the READ channel. It indicates that termination occurred <u>before</u> the LAST IMP BIT level was raised by the IMP. Since no bits are lost when this occurs, the entire message may be constructed by appending the data read by the next READ command to that read by the present READ command. ## 5.2 <u>Data Alert Status</u> DATA ALERT major status is returned if an error occurred during the transfer of data in the appropriate direction. Any error will cause the channel to abort the current operation immediately. ## 5.2.1 Parity Error Substatus (DATA ALERT) PARITY ERROR substatus can occur only on the WRITE channel; the IOM will indicate a READ channel parity error in the channel status rather than the peripheral status field, since the error is detected by the channel rather than by the ABSI. Parity error substatus indicates that a character has been received from the IOM channel with bad parity. The WRITE command is aborted and the LAST HOST BIT level is not sent to the IMP. Thus the software could indicate to the IMP that this message should be ignored by flashing the HOST UP line (waiting appropriate times for relay opening/closure) and then exchanging a reset sequence with the IMP. (Note that this error recovery procedure will abort any pending read operations when the HOST DOWN command is executed. Since all Network communication is aborted, this is not a recommended method of error recovery.) A much less drastic way to cause the IMP to discard the message in error would be to immediately WRITE a second message whose length is greater than the maximum legal message length (256 words, for instance, is greater than the current maximum length of 8096 bits). Since the previous WRITE did not raise the LAST HOST BIT level, this second message will be appended to the first, causing the IMP to discard it. The original message may then be transmitted as though nothing had happened (assuming no further PARITY ERRORs occur). It should be noted that PARITY ERROR substatus usually will be returned only if a logic element fails and so it may actually be reasonable to consider such an error fatal. #### 5.2.2 IMP DOWN Substatus (DATA ALERT) IMP DOWN substatus indicates that the IMP went down at some time during the Read/Write operation. Data may have been lost. ## 5.2.3 <u>HOST DOWN Substatus</u> (DATA ALERT) HOST DOWN substatus indicates that the host up/down relay became open (e.g., the HOST DOWN pushbutton was pushed) during the Read/Write operation. Data may have been lost. # 5.2.4 <u>Incomplete Message Substatus (DATA ALERT)</u> INCOMPLETE MESSAGE substatus with DATA ALERT major status is solely an indication that the LAST IMP BIT level was not raised by the IMP before the READ operation terminated. This information is actually of little use since data may have been lost due to the error which caused the DATA ALERT major status. INCOMPLETE MESSAGE substatus will usually occur in conjunction with either HOST DOWN or IMP DOWN when the major status is DATA ALERT. ## 5.3 Command Reject Status COMMAND REJECT major status indicates that the command could not be accepted for the reason indicated by the substatus. ### 5.3.1 Invalid Operation Code Substatus (COMMAND REJECT) INVALID OPERATION CODE substatus indicates that the command code received by the ABSI was not one of the legal commands for that channel. #### 5.3.2 Parity Error in Command Sequence Substatus (COMMAND REJECT) PARITY ERROR IN COMMAND SEQUENCE indicates that either the device code (which is otherwise ignored) or the command code received by the ABSI had bad parity. The operation is not performed even if the command code would otherwise be legal. #### 5.3.3 IMP Down Substatus (COMMAND REJECT) For all operations except READ and WRITE, IMP DOWN substatus can occur only in conjunction with one of the above two command transmission errors. In this case this status is as described in section 5.1.1 above. For READ and WRITE operations, this substatus (without IN-VALID OPERATION CODE or PARITY ERROR IN COMMAND SEQUENCE substatus) indicates that the command could not be <u>initiated</u> because the IMP READY relay is open. # 5.3.4 <u>Host Down Substatus</u> (COMMAND REJECT) HOST DOWN substatus is analogus to IMP DOWN substatus described in section 5.3.3 above. # 5.3.5 Incomplete Message (COMMAND REJECT) INCOMPLETE MESSAGE substatus only occurs in conjunction with one of the two command transmission errors described in section 5.3.1 and 5.3.2 above. It is otherwise analogous to the substatus of the same name, described in section 5.2.4 above (and is likewise nearly useless). Note that in this case it refers to the previous READ/WRITE operation, not the rejected one. # 5.4 <u>Channel/Peripheral</u> <u>Subsystem</u> <u>Busy</u> This major status indicates that a READ/WRITE command was properly received and is currently being executed. BUSY major status returned by the ABSI to the Common Peripheral Channel is seldom seen by the system software, as the 6000 series IOM does not signal an interrupt when BUSY major status is returned. # 6. EXCEPTIONS AND ASSUMPTIONS This section describes all the known assumptions concerning the interfaces with the CPI type channels and with the IMP. Also noted are any exceptions to the specifications. # 6.1 Restriction on EDT Transmission on the Write Channel The WRITE channel portion of the ABSI must know when it is writing the last bit to the IMP so that it can assert the LAST HOST BIT level. In order to avoid extra buffering and a large increase in complexity, it is required that the EDT strobe arrive no more than 4 $\mu$ sec. after the WRITE CLOCK TO PERIPHERAL strobe. This is despite the section on Write Command Termination (section 4.3.3, sheet 32) of 43A130524. Honeywell document 43A177715 (the IOM specification) section A 2.3.4.3 states, however, that the IOM CPC sends the EDT .5 $\mu$ sec. after the WRITE CLOCK TO PERIPHERAL strobe. Since the ABSI is intended for use only with the 6000 IOM, no problems are foreseen. ## 6.2 <u>Restriction on EDT Transmission on the Read Channel</u> The READ channel must know whether the most recent character sent to the channel is to be the last character <u>before</u> it can read the first bit of the next character from the IMP. As defined in 43A130524, the EDT strobe may arrive at any time after the READ CLOCK TO PERIPHERAL strobe. Clearly, the ABSI must place some restriction on how long it waits before accepting the next character from the IMP. The ABSI there waits a maximum of 1 $\mu$ sec. The current IOM Common Peripheral Channel violates the standard in 43A130524, as it sends the EDT <u>instead</u> of the last READ CLOCK TO PERIPHERAL, rather than after it. (43A177715, section A 2.3.4) The ABSI works equally well with this convention. It is the opinion of the ABSI designer that the present method of indicating termination makes more sense. ## 6.3 <u>Lack of Transfer Timing Error Detection</u> The completely asynchronous nature of data transfer between the ABSI and the IMP eliminates the possibility of TRANSFER TIMING errors. Therefore, no provision is made for their detection, despite section 6.2 (sheet 52) of 43A130524. #### 6.4 Minimum Initialization Time It is assumed that an "initialize" signal given to the ABSI (e.g., an opening of the Peripheral Reset Line)will remain asserted for at least 50 µsec. If it is of lesser duration, the ABSI may not reset completely. In practice, the IOM RESET signal is of a much greater duration and no problem is expected. Similarly, it is assumed that the RESET pushbutton will be held down for at least this amount of time. #### 6.5 Initial Power-on and Initial On-line Status Section 6.3 of 43A130524 does not specify what the initial status returned by the peripheral should be. It is therefore assumed that garbage may be returned until a command other than Request Status is sent. ## 6.6 <u>Minimum</u> <u>Buffering</u> <u>Requirements</u> Section 6.5 of 43A130524 specifies a minimum buffering capability of two characters for the WRITE channel. Only one is provided. Since the ABSI is asynchronous, no problem other than a very slight speed loss should be encountered. ## 6.7 Definition of Data Transmission Time In many places 43A130524 specifies times as "sufficient time...to set... receivers." The design of the ABSI assumes that 0.75 $\mu$ sec. is more than sufficient to cover all skew and settling time considerations. ## 6.8 Skew in the IMP Connection The IMP currently delays 500 ns. (see BBN-1822 section 4.5) to avoid errors due to skew in the IMP connection. The ABSI makes no further (intentional) provision for such skew. If problems due to this are detected, it is expected that the delay times in the IMP can be increased to compensate. ## 6.9 Voltage Levels for the Distant Interface BBN-1822 specifies ±0.5 volt signals for the distant interface connections; the drivers used are closer to ±0.75 volt. BBN indicates that this should cause no problem (and, in fact, is probably desirable). #### 6.10 Maximum Pulse Width 43A130524 1.1 (sheet 5) states that no maximum width is specified for the pulses used in the common peripheral interface. The ABSI requires that the WRITE CLOCK TO PERIPHERAL pulses have a maximum width of 120ns. for the write side and 180ns. for the read side. The 6000 IOM sends 50ns. pulses, so no problem should be encountered. It is expected that this restriction will be removed in production versions of the ABSI. # 6.11 <u>Maintenance Requirements</u> Section 6.6 of 43A130524 is not met in that neither a Running Hour Clock nor full off-line test facilities have been provided. A Running Hour Clock is considered unnecessary because the ABSI does not have its own power supply. A minimal maintenance panel has been provided for the prototype. Connection points for further off-line test facilities have been provided in the ABSI but are currently unused. ## 6.12 Initialization When the ABSI is manually initialized (via the "initialize" pushbutton) it will also open the "CP CHN POX" lines to both channels. This will cause each channel to reset, as though the ABSI had been disconnected. (This condition lasts only as long as the "initialize" signal is present.) This behavior seems like the only reasonable way to inform the software and the channels that the ABSI has been manually initialized. Although the feature is allowed by 43A130524, it is not believed to be present in any other peripheral and so it has been included in this section on exceptions. ## 7. PHYSICAL CHARACTERISTICS The prototype ABSI is implemented on a single 12" x 12" Honeywell MQX type circuit board. Connection to the two CPI channels is made through the two free-edge connectors (one channel on each connector). Communication with the IMP is via the backpanel, using slip-over connectors on the backpanel wire-wrap pins. It is required that -5v. be provided to the board through the backpanel, in addition to the +5v. and ground normally provided. -5v. is not normally connected to the backpanel although it is available in the power supply. A standard wire exists for making the connection. It is expected that the ABSI will work in any slot providing such power and backpanel connections. In particular, it may be mounted in either a 6000 IOM or a DataNet 355 payload slot. ## 7. <u>Continued</u> The logic used is Honeywell 500 series (similar to Sylvania SUHL II) with the exception of the distant interface drivers and receivers which are 400 series logic and are similar to the TI SN75107-110 group of integrated circuits.\* Although 400 series logic is generally deemed preferable to 500 series logic, the difference is not critical for this application. The decision to use the latter was made on the basis of the availability of an MQX prototype board, which has +5v. (Vcc) and ground prewired to pins 4 and 10 of the chip positions (thereby matching 500 series chips). <sup>\*</sup> Due to poor common mode rejection in the 407 (SN75107) receiver, one dual receiver in the prototype has been replaced by a National DM8820A dual receiver which has better common mode noise rejection characteristics. .