## PDP-1 COMPUTER ELECTRICAL ENGINEERING DEPARTMENT M.I.T. CAMBRIDGE 39, MASSACHUSETTS ## PDP-26 NEW MODE SEQUENCE BREAK SYSTEM FOR TIME SHARING November 3, 1964 For use in time sharing, a modification of the standard one channel sequence break system for the PDP-1 Computer has been added, which can be optionally requested by the users. It was primarily designed to allow easy interaction between external equipment connected to the machine and a user's program. It will also be connected to the standard TO devices in the computer. The new SBS operates as follows: If the computer is in sequence break mode, and the new mode is ON, a break will occur if any of 16 possible status bits are ON, and the corresponding enable channel is also ON; if all the channels are disabled, no break will occur. channels, numbered from 0 to 178, are enabled or disabled by user instructions; the channel defines its priority. more than one break request occurs at the same time, the break with the lowest number will be served first. When a service request is completed, the corresponding status bit should be OFF, and the break should be dismissed with a jmp i 1 instruction, Then, another break may take place. Breaks cannot occur within Further, when a break occurs, the AC, PC, and IO are breaks. stored in registers 0, 1, and 2 respectively, and the number of the channel that caused the break is placed in the AC. feature permits the programmer to take appropriate action with respect to the requesting device. The programmer has effectively a 15 channel SBS, without worrying about possible breaks occurring during the time that a break is being serviced, because breaks will pile up and be automatically served in order of priority. It should be pointed out that it is much easier with this system for an IO device to signal the time sharing system that a user's program should be brought into core as soon as possible to service the device. The new SBS will be connected to the standard IO devices and also to a set of switches and knobs from the TS users to allow signaling to programs. Provision has also been made for the connection of external equipment to the two higher and the two lower priority channels. The four instructions associated with the one channel sequence break system of the PDP-1 time sharing system at MIT are supplemented by six additional instructions for using the new sequence break system. These latter enable the user to turn on and off the new 16 channel sequence break system and to enable or disable the sixteen channels; the sixth instruction is used by the executive routine to reactivate a program if a break is waiting to be serviced. The new instructions are: | | Mnemonic Code | Octal Code | Operation | |----|--------------------|------------|-----------------------------------------| | 1. | nmn* [new mode on] | 725377 | sets the SBS to new 16-channel mode. | | 2. | nmf [new mode off] | 725477 | sets the SBS to old 1-<br>channel mode. | | | Mnemonic Code | Octal Code | <u>Operation</u> | | | |----|-----------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 3. | dsc N×100 [deactivate sequence channel N] | 720050+(N×100) | turns off channel N in the new SBS. | | | | 4. | asc N×100 [activate sequence break channel N] | (720051)+(N×100) | turn on channel N in the new sequence break system. | | | | 5• | cac [clear all channels] | 720053 | turns off all sixteen channels. | | | | 6. | sbr [skip on break request] | 722577 | skips the next instruction if a break has been requested and is waiting to be serviced. | | | | | The other sequence break instructions are: | | | | | | 1. | esm* [enter sequence break mode] | 720055 | turns on the Sequence Break<br>System, allowing automatic<br>interrupts to the main<br>sequence to occur. | | | | 2. | lsm [leave sequence<br>break mode] | 720054 | turns off the Sequence Break<br>System, thus preventing<br>interrupts to the main<br>sequence. Should interrupt<br>requests occur while the<br>system is off, the status<br>bits will, nevertheless,<br>continue to be set. | | | | 3. | cbs [clear sequence<br>break system] | 720056 | clears certain flip-flops<br>in SES thus nullifying the<br>effect of any interrupt<br>requests just granted or<br>about to be granted (i.e.,<br>just prior to the transfer<br>of the C(AC) to location<br>zero.) | | | | 4. | isb [initiate sequence break] | 720052 | initiates a sequence break; if new mode is on, then generates a break for the highest channel activated. | | | <sup>\*</sup>NOTE: To turn on the new 16 channel SBS, the nmn instruction must be executed before esm. The channels and their corresponding IO devices in the order of their priority are: | <u>Channel</u> | <u>Device</u> | |----------------|---------------------------------------------| | 0 }<br>1 } | high priority for user's external equipment | | Ţŧ | buttons | | 5 | light pen | | 6 | type-in | | 7 | type-out | | 10 | punch | | 11 | drum | | 12 | reader | | 16?<br>17) | low priority for user's external equipment | The following instructions provide an example of how the user turns on the New Sequence Break System; these allow the buttons and light pen to cause service breaks: cbs nmn cac asc 400 asc 500 esm