## **B1700 HARDWARE SPECIFICATIONS** #### DISTRIBUTION #### DETROIT D. Kosinski - CPM R. Stackhouse - CPM D. Bookwalter - CPM C. Chamberlain - Tech Pub J. Raker - Int'1 T. Allison - Int'1 (2) R. Gould - Int'1 H. Hayde - Int'1 J. Holton - Int'1 C. Nash - Int'1 E. Seif - Int'1 H. Nelson - BM&SS J. Shifman - CSG E. Rindels - BMG W. Cunningham - BMG E. Paulsen - TIO ## PLYMOUTH D. Calkins ### **DOWNINGTOWN** J. Berta ## PAOLI G. Smolnik ### McLEAN L. Guell A. Kosla ## **PASADENA** D. Gale J. Malson ## MISSION VIEJO T. Gibson ## WESTLAKE H. Smith J. Dowling ## LIEGE J. Wery A. Beaujean ### **GENNEVIELIERS** A. Isola ## **MIDDLESEX** W. Marshall ### CUMBERNAULD D. Wright J. Jeanty ## SANTA BARBARA R. Bunker Manufacturing (2) Quality Assurance SENEFFE TIO (2) Software (30) W. Keenan (5) Hardware - J. Vigil J. Trost S. Bhagwan (2) GLENROTHES ## B. Slattery ## F. E. TRAINING DEV. GROUP M. McCoy 3374 Rio Hondo Avenue El Monte, California 91731 ## PATENT ATTORNEY Mr. D. Bruce Prout Christie, Parker & Hale 201 South Lake Avenue Pasadena, California 91101 #### TIREMAN F. Williams ## Burroughs Corporation BUSINESS MACHINES GROUP SMALL SYSTEMS PLANT #### M-MEMORY PROCESSOR ## PRODUCT SPECIFICATION #### REVISIONS | M 1-8-76 Preface: Added Processor-2 Rel. Spec: Added Control Panel References Sec 1: Add * note stating CD bit indicates both'S and M-Memory Parity errors. Table 1: Added PERR Table 3: Added variants to Read/Write MSM. Sec 2: Added M-Processor-2, M-Processor Adapters-1 & -2, M-Memory Adapter-2. Sec 3.2: Added PERR. Sec 3.3.10: Added address modulo 16 of micro-op must be zero for Processor-2. Sec 3.3.12: Added M-Memory-2 with parity. Sec 3.3.15: Added "data not accepted in time will be lost and U-Register may not be addressed after Cassette STOP. Sec 3.3.16: Added M-Memory-2 parity error and listed conditions which set Memory Parity Error bit | REV<br>LTR | REVISION<br>ISSUE DATE | PAGES REVISED ADDED DELETED OR<br>CHANGE OF CLASSIFICATION | PREPARED BY | APPROVED BY | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------| | Sec 3.4.1 & 3.4.2: Added U excluded as source in STEP mode. Sec 3.4.6: Added note 2 on M as a destination register. Sec 3.4.17: Added G/B H/F and S/N variants. Sec 3.4.23 & 24 & 25: Added reference to Sec 3.3.16. Sec 3.4.29: Generalized purpose of dispatch operation. Changed processor must gain control of interrupt system to should gain Described lockout operations when using the direct connect processor adapter. Sec 3.5: Specified concurrent operations for Processor-1 only. Sec 3.6: Corrected times for operations with A out-of-bounds. Deleted time for Move 24-bit to MSM. Sec 3.7: Added times for Processor-2. | M | 1-8-76 | Rel. Spec: Added Control Panel References Sec 1: Add * note stating CD bit indicates both'S and M-Memory Parity errors. Table 1: Added PERR Table 3: Added variants to Read/Write MSM. Sec 2: Added M-Processor-2, M-Processor Adapters-1 & -2, M-Memory Adapter-2. Sec 3.2: Added PERR. Sec 3.3.10: Added address modulo 16 of micro-op must be zero for Processor-2. Sec 3.3.12: Added M-Memory-2 with parity. Sec 3.3.15: Added "data not accepted in time will be lost and U-Register may not be addressed after Cassette STOP. Sec 3.3.16: Added M-Memory-2 parity error and listed conditions which set Memory Parity Error bit. Sec 3.4.1 & 3.4.2: Added U excluded as source in STEP mode. Sec 3.4.6: Added note 2 on M as a destination register. Sec 3.4.17: Added G/B H/F and S/N variants. Sec 3.4.23 & 24 & 25: Added reference to Sec 3.3.16. Sec 3.4.29: Generalized purpose of dispatch operation. Changed processor must gain control of interrupt system to should gain Described lockout operations when using the direct connect processor adapter. Sec 3.5: Specified concurrent operations for Processor-1 only. Sec 3.6: Corrected times for operations with A out-of-bounds. Deleted time for Move 24-bit to MSM. | | | "THE INFORMATION CONTAINED IN THIS DOCUMENT IS CONFIDENTIAL AND PROPRIETARY TO BURROUGHS CORPORATION AND IS NOT TO BE DISCLOSED TO ANYONE OUTSIDE OF BURROUGHS CORPORATION WITHOUT THE PRIOR WRITTEN RELEASE FROM THE PATENT DIVISION OF BURROUGHS CORPORATION" ## Burroughs Corporation BUSINESS MACHINES GROUP SMALL SYSTEMS PLANT M-MEMORY PROCESSOR # PRODUCT SPECIFICATION #### REVISIONS | REV | REVISION | PAGES REVISED ADDE | D DELETED OR | DDEDADED BY | APPROVED BY | |------|-----------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------|-------------| | LTR | ISSUE DATE | CHANGE OF CLAS | | PREPARED BY | APPROVED BY | | M1 . | 1-8-76<br>Cont. | Reorganized, copy-edited<br>Product Specification data<br>tion sequence is as followabove are indicated by a | ta base. New sec-<br>ows-revisions noted | AAN | | | | · | WAS<br>Preface | IS<br>1.0* | | | | | | New<br>2.<br>Un-numbered<br>1. | 1.1*<br>1.2*<br>1.3*<br>2.0* | | | | | · | 3.0<br>New<br>3.3.11<br>3.3.12 | 3.0<br>3.1<br>3.1.1<br>3.1.2* | | | | | | 3.3.10<br>3.3.9<br>3.3.8<br>3.3.1 | 3.1.3*<br>3.1.4<br>3.1.5<br>3.1.6 | | | | | | 3.3.2<br>3.3.3<br>3.3.4<br>3.3.5 | 3.1.7<br>3.1.8<br>3.1.9<br>3.1.10 | | | | | | 3.3.6<br>3.1.9<br>3.3.7<br>3.3.16 | 3.1.11<br>3.1.12<br>3.1.13<br>3.1.14* | | | | | | New New 3.3.13, 3.3.14 3.3.15 | 3.1.14.1<br>3.1.14.2<br>3.1.15<br>3.1.16* | | | | | | 3.3.17<br>3.3.18<br>3.3.19<br>3.3.20 | 3.1.17<br>3.1.18<br>3.1.19<br>3.1.20 | | | | | | 3.3.21<br>3.1<br>3.1.1<br>3.1.2<br>3.1.3 | 3.1.21<br>3.2<br>3.2.1<br>3.2.2<br>3.2.3 | | | "THE INFORMATION CONTAINED IN THIS DOCUMENT IS CONFIDENTIAL AND PROPRIETARY TO BURROUGHS CORPORATION AND IS NOT TO BE DISCLOSED TO ANYONE OUTSIDE OF BURROUGHS CORPORATION WITHOUT THE PRIOR WRITTEN RELEASE FROM THE PATENT DIVISION OF BURROUGHS CORPORATION" # Burroughs Corporation BUSINESS MACHINES GROUP SMALL SYSTEMS PLANT M-MEMORY PROCESSOR # PRODUCT SPECIFICATION #### REVISIONS | REV | REVISION | PAGES REVISED ADDED DELETED OR | PREPARED BY | APPROVED BY | |-------|----------|---------------------------------------------------------------------------------------------------|-------------|-------------| | LTR . | 1-8-76 | CHANGE OF CLASSIFICATION WAS IS | | | | 27! | Cont. | 3.1.4 3.2.4<br>3.1.5 3.2.5<br>3.1.6 3.2.6 | | | | | | 3.1.7 3.2.7 3.1.8 3.2.8 3.1.9 3.2.9 3.1.10 3.2.10 | | | | | | 3.2 Numbering of Sections 3.4, 3.5, and 3.6 is unchanged. Section 3.7 is new. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | · | | | | | | | | | | | | | | | | | | | | | | "THE INFORMATION CONTAINED IN THIS DOCUMENT IS CONFIDENTIAL AND PROPRIETARY TO BURROUGHS CORPORATION AND IS NOT TO BE DISCLOSED TO ANYONE OUTSIDE OF BURROUGHS CORPORATION WITHOUT THE PRIOR WRITTEN RELEASE FROM THE PATENT DIVISION OF BURROUGHS CORPORATION" M-MEMDRY PROCESSOR PRODUCT SPECIFICATION # 1913 1747 # TABLE OF CONTENTS: | 1.0 | INTRODUCTION | 1 | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----| | 1.1 | PURPOSE | 1 | | | | 2 | | 1.2 | PRODUCT IDENTIFICATION | 2 | | 1.3 | RELATED SPECIFICATIONS | 3 | | 2.0 | GENERAL DESCRIPTION | | | 3.0 | PRODUCT DESCRIPTION | 8 | | | PROCESSOR REGISTERS | 8 | | 3.1 | | 8 | | 3-1-1 | M | 8 | | 3.1.2 | MSM | | | 3.1.3 | A, MBR AND TOPM REGISTERS | 9 | | 3-1-4 | A STACK | 10 | | | TAS | 10 | | 3.1.5 | | 11 | | 3.1.6 | X AND Y | 11 | | 3-1-7 | L Commence of the | | | 3.1.8 | T | 12 | | 3.1.9 | FA | 12 | | 3-1-10 | FB | 13 | | | | 14 | | 3-1-11 | SCRATCHPAD | 14 | | 3.1.12 | FLCN | | | 3.1.13 | BR AND LR | 14 | | 3-1-14 | С | 15 | | 3.1.14.1 | CP (CYF, CPU, CPL) | 15 | | | CA, CB, CC, CD | 15 | | 3.1.14.2 | · | 18 | | 3.1.15 | MAXS. MAXM | 18 | | 3.1.16 | U- | 18 | | 3.1.17 | DATA | | | 3.1.18 | CMND | 19 | | 3.1.19 | NULL | 19 | | 3.1.20 | READ | 19 | | | | 19 | | 3 - 1 - 21 | WRIT | 20 | | 3.2 | 24-BIT FUNCTION BOX | 21 | | 3.2.1 | SUM | | | 3.2.2 | DIFF | 21 | | 3.2.3 | XANY. XORY. XEOY | 22 | | 3.2.4 | CHPX. CMPY | 22 | | | | 22 | | 3.2.5 | MSKX+MSKY | 22 | | 3.2.6 | BICN | 23 | | 3.2.7 | XYCN | | | 3.2.8 | XYST | 24 | | 3.2.9 | INCN | 25 | | 3.2.10 | PERR | 25 | | | | 26 | | 3.3 | 4-BIT FUNCTION BOX | 27 | | 3.4 | M-INSTRUCTIONS | 27 | | 3-4-1 | REGISTER MOVE | | | 3-4-2 | SCRATCHPAD MOVE | 28 | | 3.4.3 | SWAP F WITH DOUBLEPAD WORD | 29 | | | STORE F INTO DOUBLEPAD WORD | 29 | | 3.4.4 | LOAD F FROM DOUBLEPAD WORD | 29 | | 3.4.5 | | 30 | | 3.4.6 | MOVE 8-BIT LITERAL | 30 | | 3.4.7 | HOVE 24-BIT LITERAL | 50 | | | | | | 3.4.8 | SWAP MEMORY | 31 | |--------|-------------------------------------------------|-----| | 3.4.9 | READ/WRITE MEMORY | 31 | | 3.4.10 | COUNT FA/FL | 32 | | 3.4.11 | SCRATCHPAD RELATE FA | 33 | | 3.4.12 | EXTRACT FROM REGISTER T | 33 | | 3.4.13 | SHIFT/ROTATE REGISTER T LEFT | 34 | | 3.4.14 | SHIFT/ROTATE REGISTER X/Y LEFT/RIGHT | 35 | | 3.4.15 | SHIFT/ROTATE REGISTERS XY LEFT/RIGHT | 35 | | 3.4.16 | NORMALIZE X | 35 | | 3.4.17 | READ/WRITE MSM | 36 | | 3.4.18 | CALL | 37 | | 3.4.19 | BRANCH | 38 | | 3.4.20 | BIAS | 38 | | 3.4.21 | SET CYF | 39 | | 3.4.22 | 4-BIT MANIPULATE | 39 | | 3.4.23 | BIT TEST BRANCH FALSE | 40 | | 3.4.24 | BIT TEST BRANCH TRUE | 40 | | 3.4.25 | SKIP WHEN | 41 | | 3.4.26 | CLEAR REGISTERS | 42 | | 3.4.27 | BIND | 42 | | 3.4.28 | OVERLAY M-MEMORY | 43 | | 3.4.29 | DISPATCH | 43 | | | CASSETTE CONTROL | 45 | | 3.4.30 | | 45 | | 3.4.31 | HALT<br>No operation | 46 | | 3-4-32 | | 46 | | 3.4.33 | MONITOR CONCURRENT OPERATION (Processor-1 only) | 46 | | 3.5 | | 52 | | 3.6 | M-INSTRUCTION (Processor-1) | 55 | | 3.7 | M-INSTRUCTION TIMING (Processor-2) | , , | COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 ## 1.0 INTRODUCTION ## 1.1 PURPOSE This specification defines the functional requirements of two M-Memory Processors intended for general purpose data processing. Environmental conditions, safety conditions, reliability parameters, power requirements, etc., are specified in P.S. #1913 1739, B1700 CENTRAL SYSTEMS. Both processors have I/O bus interfaces for communication with the I/O subsystem and control panel interfaces for communication with the control panel. M-Processor-1 has a Port Adapter-Port Device Interface and requires the use of Port Adapter-1 in Port Interchange-1. Port Interchange-1 provides the communication paths to the system's main memory and to other port devices such as the B1700 Multiline Control. M-Processor-2 has a Processor Adapter Interface that provides for acceptance of either Processor Adapter-1 or -2. Processor Adapter-1 provides a direct interface to main memory. No port interchange is used. Processor Adapter-2 provides a direct interface to Port Interchange-2 (no port adapter is used) which, in turn, provides the communication paths to main memory and to other port devices such as the Multiline Control. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 ## 1.2 PRODUCT IDENTIFICATION ``` M-MEMORY PROCESSOR-1 2204 8839 M-MEMORY PROCESSOR-2 2212 8318 M-PROCESSOR ADAPTER-1 (Direct Connect) * 2212 8326 M-PROCESSOR ADAPTER-2 (Port Connect) * 2212 8334 M-MEMORY ADAPTER-1 2KB ** 2204 8847 M-MEMORY ADAPTER-2 8KB *** 2212 1982 M-MEMORY ADAPTER-2 6KB *** 2212 1990 2212 2006 M-MEMORY ADAPTER-2 4KB *** M-MEMORY ADAPTER-2 2KB *** 2212 2014 M-MEMORY EXP KIT-2 2KB *** 2212 2022 ``` - \* Used with M-Processor-2 - \*\* Used with M-Processor-1 - \*\*\* Used with M-Processor-1 or -2 ## 1.3 RELATED SPECIFICATIONS | P.S. | # | NAME | | | |-----------|------|--------|----------------------------|-----------| | | | 24.700 | CHETCH THOCH | | | 1904 | 5681 | | SYSTEM INDEX | | | 1913 | 1739 | B1700 | CENTRAL SYSTEM | | | 2204 | 8623 | B1700 | I/O BUS SUBSYSTEM | | | 1913 | 1754 | B1700 | MEMORY SUBSYSTEM | | | 1913 | 1788 | B1700 | PORT INTERCHANGE | | | 2209 | 7968 | B1700 | CONTROL PANEL | | | S • D • i | S. # | NAME | | | | | | | | | | 2200 | 2083 | B1700 | PORT ADAPTER - PORT DEVICE | INTERFACE | | | 0143 | B1700 | CONTROL PANEL INTERFACE | | COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 ## 2.0 GENERAL DESCRIPTION The M-Memory Processor (or M-Processor) provides the combinatorial and arithmetic portion of the system along with other registers and hard storage that are appropriate for efficient operation. The M-processor provides hardware sensitivity to a set of low-level micro-functions which are used in a program string to fetch and execute instructions. This micro-program is contained in either a local high-speed Read-Write M-Memory or in the somewhat slower but larger main memory (81700 S-Memory) or in both. M-Memory is modular in increments of 2K bytes up to a maximum of 8K bytes. Included in the M-Processor are registers and pseudo registers which are addressable by the individual micro-operators. The registers are normally addressed by a 4-bit group (row) number and a 2-bit select (column) number as shown in Table 1. Some of the registers listed, such as the Pseudo Sum Register, can serve only as source registers while others are capable of serving both as source and destination registers. Also, some of the registers listed are actually subregisters—which, although parts of larger—registers, can be individually addressed and manipulated. Table 2 summarizes the various conditions available by addressing particular pseudo source registers and actual registers; Figure 1 lists the micro-instructions and their variants; and Figure 2 is a diagram of the major registers. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 TABLE 1: M-PROCESSOR REGISTER SELECTION | | | | 0 | SELECT NUMBE | :R<br>2 | 3 | |--------|--------|---|----|--------------|---------|------| | | 0 | 1 | TA | FU | Х | SUM | | | 1 | i | TB | FT ' | Y | CMPX | | | | 1 | TC | FLC | T | CMPY | | | 2<br>3 | i | TO | FLO | L | XANY | | | | 1 | | | | | | ÷ | 4 | • | TΕ | FLE | A | XEOY | | | 5 | i | TF | FLF | M | MSKX | | | 6 | 1 | CA | BICN | BR | MSKY | | | 7 | 1 | 63 | FLCN | LR | XORY | | | | 1 | | | | | | GROUP | 8 | 1 | LA | TOPM | FA | DIFF | | NUMBER | 9 | 1 | LB | UNASSIGNED | FB . | MAXS | | | 10 | 1 | LC | UNASSIGNED | FL | MAXM | | | 11 | 1 | LD | PERR | TAS | Ü | | | | 1 | | | | | | | 12 | 1 | LE | XYCN | CP | MBR | | | 13 | 1 | LF | XYST | MSM | DATA | | | 14 | 4 | CC | INCN | READ | CMND | | | 15 | 1 | 03 | CPU | WRIT | NULL | | | | | | | | | COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 # TABLE 2: SUMMARY OF REGISTER CONDITIONS | BICN: | 1 LSUY 1 CYF I CYD 1 CYL 1 | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | XYCN: | 1 MSBX I X=Y I X <y i="" x="">Y I</y> | | XYST: | I LSUX I INT I Y neq 0 I X neq 0 I | | FLCN: | I FL=SFL I FL>SFL I FL neq 0 I | | INCN: | 1 PORT 1 PORT 1 PORT 1<br>1 DEVICE MISSING 1 HI PRIORITY 1 INTERRUPT 1 LOCKOUT 1 | | cc: I | CONTROL PANEL 1 TIMER 1 I/O BUS 1 CONTROL PNL 1 STATE LAMP 1 INTERRUPT 1 INTERRUPT 1 FLIP-FLOP 1 1 | | CD: 1 R | MEMORY & I MEMORY I MEMORY I MEMORY I READ DATA I WRT/SWAP ADDR I READ ADDR I WRT/SWAP ADDR I PAR. ERR. I OUT OF BOUNDS I OUT OF BOUNDS I INTERRUPT I INTERRUPT I | <sup>\*</sup> Both S-Memory and M-Memory (See Section 3.3.16 for details) | | | | | | | | | | | | | | _ | | | | | | | 1 | | | | | | | | | | | | | | | | | |------------|-----------------------------|----------|-----------|--------------|----------------|------------------|-------|----------------|-------------|-------------|--------|-------------|------------|-------|------------------|-------------|-------------|----------------|------------|-----------------|-----|--------------|-----------------------------------------------|----------------|--------------|--------------|--------------|--------------|--------------------------------------------------|-----------|---------------|--------|------------------------------|--------------|-----------------|------| | 1 | MICRO NAME | 15 | . M( | C 13 | , 12 | 11 | . 10 | MD<br>: | 9 ', ( | 6 | 7 . | 6 . | 5 | 4 | 3 | • | 2 | 1 | 0 | VARIAN' | rs | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | 7 | | | | | | | | г | REGISTER MOVE | - | 0 | 0 | 1 | RE | G 1 | GROU | P | | REG | 1 | REC | ECT | 511 | REG<br>NK F | 2 G<br>REGI | ROUP<br>ST E R | | | | | | | | | <u> </u> | i | | | <b>-</b> . | | GISTER S | SELECT | | | | 10 | | 0 | 0 | | 0 | RE | GIST! | ER GF | | | RE | G<br>CT | MOV | DPW | DO | UBLE | PAD | WOR | D | MOV DIR | | P←R<br>LEFT | | : | | | | <u> </u> | | GROU | STER O | | <u> </u> | SUM | _ | | | 1 | SCRATCHPAD MOVE | | 0 | | | REC | SISTE | OR 5 | ROUP, | R | EG | MAN | PULA | TE | 4 | BIT | | IIP. | | MANI | P. | SET | AND | OR | EOR | INC | TEST | DEC | DEC | - 1 | 0 TA | 5 F | T Y | CMPX | 1 | | | 3 C | MANIPULATE | - | | 0 | 0 | | | OR & | SNK | - 15 | F.G | VAR<br>TEST | BIT | DSP | R | RELA | TIVE | BRAN | JCH | DSP SIG | | + | _ | | | | | | | 1 | 4 75 | E F | LE A | XEOY<br>MSK) | | | | 4C | BIT TEST REL BRANCH FALSE | | <u>'.</u> | 0 | <del>-</del> - | 4 | BIT | SOUF | | 5<br>5 R | FG : | TEST | BIT | DSP | RE | LAT | IVE | ENT N | ICHI | DSP SIG | N: | + | _ | | <del> </del> | | | i | | 1 | 6 07 | A B | ICN BR | MSKY | į. | | | 5C | BIT TEST REL<br>BRANCH TRUE | ° | | | | 4 | BIT | SOUF | RCE | S | | NUM | | | | | | ENT MA | | SKIP T | EST | ANY | ALL | EQL | ALL | ANY | ALL / | EQL / | ALL | 7 | B L 6 | | OPM FA | DIFF | 3 | | | 6C | SKIP WHEN | ° | | 1 | | 4 1 | SIT 5 | OR & | SNK<br>FA/F | 5 | EL | | RIAN | r 5 | DA | TA | TRA | NSFE | R | R/W VAI | ₹: | CLR/<br>READ | WRT | CLR | | FA | FA | CCIN 7 | FAI | 1 | H LC | ٠ ، | TAS | | | | | 7C | READ/WRITE<br>MEMORY | ° | 1 | | | VA. | R | VARIA | MTS | | CO | DE : | SGN | | /IDT | TH M | AGN | ITUD | | CNT VAI | - 1 | NØP | FAT | F | FA | FL 1 | 101 | FLI | FLI | 1 | 12 LE | F X | YEN EP<br>YET ME<br>NEN REA | MA DATA | Ò | | | 80 | MOVE B BIT | <u> </u> | 0 | 0 | 0 | RI | EG SE | L 15 2 | | | ENII | | | T 5IG | | | | | <u> </u> | TW SIG | ÿ: | <u>*</u> | <del>-</del> | <del> </del> - | - | - | - | <del>!</del> | <del> </del> | - | 15 C | 0 C | PU WR | IT NUL | L | | | 90 | MOVE 24 BIT | 1 | 0 | ٥ | ı | 1 | | | GROUF | | | F | ULL | 24 1 | BIT | LITE | RAL | | | 5/R VA | | SHFT | POT | - | | | 1 | 1 | - | - | | | | | | | | 10 C | SHIFT/ROTATE | 1 | 0 | . 1 | 0 | | | REGIS<br>GROUI | STER<br>P | | 5ELE | REG<br>LCT | VAR | | | , CO | UNT | | | 1 | | | ļ | - | ļ | | 1 | <del>!</del> | - | - | | | | | | | | IIC | EXTRACT FROM | 1 | 0 | T | ı | FC | RE | T BI | T POI | NTE<br>N FL | | 5NK<br>CO | REG<br>DE | E | XT | RACT | DTH | FIEL | | SINK RI<br>CODE | | x | Y | Т | <u> </u> | <del> </del> | <del> </del> | <del>-</del> | <del> </del> | | | | SITS OF | | | | | 123C | BRANCH | | 1 | 0 | DS<br>SG | | | | RELA | TIVE | DIS | SPLA | CEM | EN" | TN | <b>JAG</b> | NIT | UDE | | DSP 51 | 3N: | + | <u> </u> | - | ļ | - | | - | - | ME | ANING | | AVE SE | | | | | 145C | RELATIVE | - | 1 | 1 | D51 | | | REL | ATIV | | | | | | | | | | | DSP SI | GN: | + | <u> - </u> | | | ļ | <del> </del> | <u>.i</u> | <u>:</u> | NOT<br>BI | TS ARE | เทบเ | MBERE | D HERI | E | | | | SWAP MEMORY | 10 | 0 | 0 | | | • | 0 | 1 | 0 0 | DATA F | EG<br>DE | TW | DAT | TA T | TRAN | ISFE | R WI | DTH | REG CO | | +<br>X | Ÿ | Т | L | <u> </u> | | <u> </u> | | co | ONVEN | 101TL | | | AKE.<br>7 | | | 2 D | CLEAR | 0 | 0 | 0 | 0 | +- | 0 | 0 | 1 | <b>-</b> | 1 | + | Y | X | S R | FA<br>EG F | FL | FU<br>REG | CP<br>REG | | | | | | | <u> </u> | | | <u> </u> | _ 3 | 0.3 | 0.3 | 03 0,3 | 0,3 ( | | | | 3 D | REGISTERS SHIFT/ROTATE | 0 | 0 | 0 | 0 | <del>- -</del> - | 0 | ı | 0 | ~ 1 | 1/D | חום | Y/Y | IFF | TO | R RIC | SHT. | X O F | \ Y | X/Y V | | | SFT- | - ROT- | ROT - | | | ļ | <u> </u> | | SB | | <u>L</u> | L 5 E | | | | '4 D | X OR Y<br>SHIFT/ROTATE | - | C | 0 | 0 | +- | 0 | 1 | 0 | | 5/R, | DIR | L | EFT | · OR | RIG | HT > | CAND | Ÿ | 5/R, D<br>VARIA | R | 5FT- | 5FT- | ROT - | ROT- | - | 1 | ! | | _ | # BICK | 7 X | YCH XY | ST FLC | N | | | <b>5</b> D | X AND Y | - | 0 | | 0 | - | 0 | 7 | <del></del> | 0 | COUL | NT F | A/FL | Ī | CO | UNT | SC | ALAR | | COUNT<br>FL VA | FA/ | NØP | FAT | FL+ | FA 1 | FA | | FL | FA | | CAD | ×< | | 0 FL4 | SFL. | | | 6 D | COUNT FA/FL | - | 0 | | | | 0 | <del></del> | - | - | | SINK | DP | ~ | Т | 50 | URC | E DP | ~ | 1 | | | | 1 | 1 | | | | | 3 | LSUY | MS | Y INT<br>58X LSL<br>' 1 OR N | | SFL | | | 7 D | EXCHANGE DPW | <u> </u> | | | | | | 0 | 0 | 0 | | ADDI | RESS | 051 | | IFF. | | UF P | | 05P 5I | GN: | + | - | | | | | | | CC | ,0 CCI | CCZI | CDO CD3 | INCN I | INCH 3 | | | <b>6</b> D | SCRATCHPAD<br>RELATE FA | 0 | | | | | | | | _} | | ·<br> | <u>L</u> _ | | | | | DURE | | | | | - | + | + | + | | + . | | ٦. | INC. | DISPAT | TCH LOC | KOUT | | | | <b>9</b> D | MONITOR | • | 0 | | | ' | 1 | | ٥ | | | | | | | | PATO | ENTI | SKP | 5KP FL | ÁG. | FAIL | 5UC | <u>.</u> | | <del></del> | - | | | | PORT I | HI PRI | TCH INT | ISPATCH | I INTERM | JPT. | | ١E | DISPATCH | 0 | 0 | | 1 | ) | 0 | 0 | 0 | 0 | 0 | | 0 | | | VA | RIAN | T5 | FLG | DISP V | AR: | LOCK | WRTL | O REAL | NUNDE | FUND | I ABSN | FSTOP | NUND | EF | INTERR | ZUPT | FOR MISS | ING POR | • | | | 2 E | CASSETTE | 0 | 0 | | ) | 0 | 0 | 0 | . 0 | 0 | 0 | 0 | 1 | 0 | 2 | ASSE | VAR | CIANTS | | MAN | IP: | TAPE | GAP | X + \ | - | | | X=1 | - | CC | & CD<br>CONSC | OLE SK | OFT HALT | INTER | RUPT. | | | 3 E | CONTROL | 0 | 0 | | ) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | | RIAN | T5 | FLG | TEST F | | UNIT | TEST<br>F | 5 | FS | NØ | PFC | NØ | > NØ | | REAL | TIME | CLOCK (IC | 00 MS) IN | STERPT. | | | | STORE FINTO | 0 | - | ) 1 | ) | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | • | , | Α | DDF | DPW | | ] | | | - | | | | | | - | CDC | MEM | ORY N | WRITE / | SWAP . | ADDRES<br>Rupt. | 55 | | 4 E | LOAD F FROM | 0 | | , ( | ) | 0 | 0 | 0 | • | 0 | ٥ | , | 0 | | 1 | | | E DP | W | | | 1 | | | | | | | | co | 1 MEM | ORY | READ A | NOORESS | OUT OF | | | 5£ | DPW<br>CARRY FF | - | | <del>)</del> | , | 0 | 0 | 0 | 0 | ٥ | 0 | 1 | 1 | | | CYF | | CYF | CYF | | | | | | | | | | | CDS | OF BC | OUND | WRITE/<br>S OVERF | RIDE FL | AG . | ıΤ | | 6E | MANIPULATE<br>EXERCISE | 1 | | 0 | , | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | | 1 | 0 | | , 0 | R/W<br>VAR | R/W V | AR | READ | WRI | Τ . | | | | | i . | CD. | ERRO | ORY IN | TERRUI | PT. | A, 1 Y | | | 7E | MSM(L) | ∤} | | 0 ( | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | . ( | <del>- </del> - | 0 | ٥ | ٥ | 1 | | | | | | | | | | | | | | | | | | | IF | HALT | 0 | | | | , | • | | - | 0 | 0 | • | | | 0 | 0 | 0 | 1 | 0 | H | | | | | | | | | | | | | | | | | | 2 F | OVERLAY<br>M-STRING | 11 | | | | σ | 0 | | • | 0 | 0 | 0 | - ( | , | • | 0 | 0 | 1 | | | | | | | | | | | | | | | | | | | | 3 F | NORMALIZE X | H^ | | 0 | | c | 0 | - | - | 0 | 0 | - 0 | | , | 0 | 0 | | 0 | 0 | | | | | | | | | | | | | | | | | | | 4F | BIND<br>A. TOPM, MBR | ° | | | | 0 | | | | 0 | 0 | 0 | - | | • | 0 | 0 | • | 0 | 1 | | | | | | | | | | | | | | | | σ | | ZERO | NO OPERATION | 11 ° | | 0 | 0 | | | | | | | | | | | | | | | <u> </u> | | | | | | | | | | | | | | | | _ | FIGURE 1 M-PROCESSOR MICRO-INSTRUCTIONS AND VARIANTS FIGURE 2 M-PROCESSOR REGISTERS COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 - 3.0 PRODUCT DESCRIPTION - 3.1 PROCESSOR REGISTERS - 3.1.1 M The M Register (micro-register) is a 16-bit register used to hold the active micro-instruction (M-instruction or micro-operator or M-op). The state of this register is decoded to enable the different control signals within the processor to perform the operations called for by the M-Op. The M Register is broken into 4 fields for decoding that are structured such that 60 distinct M-ops can be decoded. The M Register is addressable as a source and as a sink (destination). When used as a sink register, the source is bit-ORed with the upcoming M-op. Exception: In TAPE mode, the source is not bit-ORed with the upcoming M-op. 3.1.2 MSM The MSM (micro-string memory or M-Memory) Register is a pseudo register that is addressable as a source when the control panel shows HALT, or as a sink when the control panel is switched to TAPE mode. As a source, MSM contains the micro-instruction that is pointed to by the A Register (See Section 3.1.3). It is addressable as a sink by the micro-instructions MOVE 24-BIT LITERAL and REGISTER MOVE in the TAPE mode. (See Section 3.4.1, REGISTER MOVE.) M-Memory is a high-speed memory used to hold the sequences of micro-instructions that perform the macro-operations called for by S-language operators. The S-op's are normally located in main memory (B1700 S-Memory). M-Memory is available in increments of 1024 16-bit words up to a maximum of 4096 16-bit words. Any excess strings of micro-instructions which do not fit into the installed M-Memory are located in main memory. Normal micro-programming should order micro-instruction sequences so that the fastest execution speed possible is achieved regardless of the actual size of the installed M-Memory. Significant improvements in throughput are COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 achieved when more and more of the important sequences of M-instructions are located in the M-Memory, since the M-Memory is at least five times faster than main memory. The N-Processor is capable of overlap operations with main memory. M-Memory is addressable as a source and as a sink. The location accessed is usually determined by the contents of the A Register, which normally point to the next micro-operator. However, the micro-operator READ/WRITE MSM accesses the word determined by the contents of the L Register as does the MOVE SMEM TO MMEM (overlay) micro-operator. M-Processor-2 provides an additional parity bit used to check parity. "Odd" denotes good parity. ## 3.1.3 A, MBR AND TOPM REGISTERS The A Register is a 14-bit micro-program address register capable of addressing 16,384 micro-operators located in M-Memory and/or main memory. The A Register is capable of having binary increments from 0 through 4095 added to or subtracted from it. A high-speed carry adder facilitates micro-program branching. The A Register is automatically incremented during RUN mode. Wrap-around can occur and is permitted. The A Register can be addressed as a source and as a sink. When used as a source, the contents of the A Register are multiplied by 16. When used as a destination, the rightmost 4 bits of the source are lost. Associated with the A Register is a 4-bit TOPM (Top of M-Memory) Register. This register, multiplied by 512, is compared with the A Register to determine from which memory (M-Memory or main memory) the micro-operator is addressed. If the address in the A Register is equal to or is greater than the address denoted by (512) $\times$ (TOPM), the micro-operator is obtained from main memory, otherwise, it is obtained from the M-Memory. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 To obtain the micro-operator from main memory, the A Address is multiplied by 16 and added to a 24-bit MBR (Micro-Instruction Base Register) to yield a bit address pointing to the micro-operator. (In S-Memory Processor-2, the Bit Address Modulo 16 must equal zero). Both the TOPM and MBR Registers are addressable as sources and as sinks. The TOPM Register is cleared to the binary value 1000 by the system clear signal. The MBR, A, and TOPM Registers are addressed as destination registers by the micro-operator "BIND". ### 3.1.4 A STACK The A Stack is 32 words deep by 24 bits wide, does not have automatic hard overflow, and operates as a push-down stack with a last-in, first-out type of structure. Using this stack, the microcoded routines operate in the normal software call-return type of programming. This allows for a highly shared microcode structure and reduces the associated memory requirements. Although the A Stack is not intended to be used as an operand stack, it has purposely been made 24 bits wide to allow limited capabilities for operand storage. Wrap around of the TAS pointer is provided. That is, 32 consecutive pops or 32 consecutive pushes will cause the TAS pointer to contain its original contents. #### 3.1.5 TAS The TAS (Top of Stack) Register is a 24-bit register which is the top of the A Stack. The TAS Register is addressable as a source and as a sink. References to TAS result in the stack being automatically pushed or popped. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 3.1.6 X AND Y The X Register and the Y Register are 24-bit general purpose registers used primarily to hold and to act as a source for the two operands of the arithmetic and combinatorial unit. Each register is addressable as a source and as a sink. Both registers, along with the L Register and the T Register, are capable of read/write operations with main memory. Both registers are capable of all SHIFT/ROTATE operations. The X Register is capable of the NORMALIZE and the READ/WRITE MSM operations. 3.1.7 L The L Register is a 24-bit general purpose register used typically to hold logical flags for the micro-program code. The L Register, as well as each 4-bit group of L (denoted as LA, LB, LC, LD, LE, and LF), is addressable as a source and as a sink. DISPATCH operations use the L Register as the source or sink for a 24-bit message (usually an address) which is stored in/fetched from S-Memory Location zero. OVERLAY M-MEMORY operations use the L Register as the source of the starting M-Memory address to be used in the M-Memory overlay operation. The BIND operator uses the L Register as the source of the 24-bit value to be moved to the MBR. Since the L Register is addressable in 4-bit groups, its contents are available for analysis and alteration via the 4-bit function box. MANIPULATE, SKIP and BIT-TEST-BRANCH instructions can operate on L data. The L Register is one of 4 registers (X, Y, L, and T) capable of read/write operations with main memory. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 The READ/WRITE MSM operator uses the L Register as the source of the M-Memory address to be used in the operation. 3.1.8 T The T Register is a 24-bit general purpose register used primarily for the interpretation of S-Language instructions. The T Register, as well as each 4-bit group of T (denoted as TA, TB, TC, TD, TE, and TF), is addressable as a source and as a sink. DISPATCH operations use the least significant seven bits of T as the source or sink for the port and channel information associated with the DISPATCH operation. The BIND operator uses the T Register as the source of the 4-bit value to be moved to the TOPM Register and as the source of the 14-bit value to be moved to the A Register. The value to be moved to TOPM is contained in the rightmost (LSB) 4 bits of T while the value to be moved to A is contained in the leftmost (MSB) 20 positions of T. Note that when data is moved to A, it will be truncated on the left. Since the T Register is addressable in 4-bit groups, its contents are available for analysis and alteration via the 4-bit function box. MANIPULATE, SKIP and BIT-TEST-BRANCH instructions can operate on T data. The T Register is one of 4 registers (X, Y, L, and T) capable of read/write operations with main memory. The T Register is also capable of the SHIFT/ROTATE and EXTRACT operations. 3.1.9 FA The FA Register (Field Address) is a 24-bit register used primarily to hold an absolute bit address for main memory. It has the capability of directly addressing any bit in the memory starting at any point. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 The FA Register is addressable as a source and as a sink. The FA Register is capable of being counted up or down by a literal in a micro-instruction or by the value contained in CPL in order to facilitate iteration through a memory field. It can be incremented or decremented by a value in a left scratchpad word. It also has the capability of being loaded, stored, or swapped along with F3 into a double scratchpad word. Neither overflow nor underflow of FA is detected. The value of FA may go through its maximum value or its minimum value and wrap around. ## 3.1.10 FB The FB Register is a 24-bit register which can be functionally divided into three portions: a 4-bit FU (Field Unit) register, a 4-bit FT (Field Type) register, and a 16-bit FL (Field Length) register. The FB Register, as well as each 4-bit portion of FB denoted as FU, FT, FLC, FLD, FLE, and FLF is addressable as a source and as a sink. In addition, the 16-bit portion comprised of FLC, FLD, FLE, and FLF and denoted as FL is also addressable as source and as a sink. The FU Register holds the length of the unit which makes up a field in memory. The FT Register holds field type information while the FL Register holds the total length of the field. FL is capable of describing fields up to 65,636 bits and can be adjusted up or down by a literal in a micro-instruction or by the value contained in CPL in order to facilitate iteration through a memory field. Note: Overflow of FL is not detected. The value of FL will go through its maximum value and wrap around. Underflow of FL is detected and will not wrap around. The value of zero is left in FL. Since the FB Register is addressable in 4-bit groups, its contents are available for analysis and alteration via the 4-bit function box. MANIPULATE, SKIP and BIT-TEST-BRANCH instructions can operate on FB data. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 FB has the capability of being loaded, stored, or swapped along with FA into a double scratchpad memory word. FU and FL along with corresponding portions of the first cell of scratchpad are used to set the various conditions of FLCN (see Section 3.1.12, FLCN) and the various conditions of the CP register (see Section 3.4.20, BIAS). ## 3.1.11 SCRATCHPAD A scratchpad memory of sixteen 48-bit words is provided to hold field descriptors during the iteration of operands. Some cells may be used to hold S-Language stack pointers and other processor registers which are under constant manipulation. The FU and FL portion of the FB Register and like portions of the first cell of the scratchpad are used to set the various conditions of FLCN (see Section 3-1-12, FLCN) and the various conditions of the CP register (see Section 3-4-20, BIAS). ## 3.1.12 FLCN FLCN (field length condition) is a 4-bit pseudo register that holds the result of a static comparison of the FL portion of the FB register and the corresponding portion of the first scratchpad word. It is addressable as a source only. FLCN: | FL=SFL | FL>SFL | FL<SFL | FL neq 0 | #### 3-1-13 BR AND LR The LR and BR Registers are both 24-bit registers and are used for memory protection and for base relative addressing. Memory protection is provided by checking the memory address in FA with the BR (Base Register) and the LR (Limit Register) for all memory cycles. Any address outside these bounds is flagged in the CD Register. A memory READ operation is always allowed whether inside or COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 outside the boundary, but WRITE or SWAP operations are allowed outside the boundary only if the override bit of the CD register is true. A memory address equal to the BR or LR is considered in bounds. Note: The memory protection is provided only on the initial pointer and does not provide protection on those memory bits accessed when the field Length is greater than one. The COUNT operation specified by the count variants will take place regardless of whether or not the memory cycle takes place. Each register is addressable as a source and as a sink. 3.1.14 C The C (control) Register is a 24-bit register which is not addressable is an entity but which is functionally divided into one 8-bit section and four 4-bit sections. 3.1.14.1 CP (CYF, CPU, CPL) The 8-bit section, addressed as CP, is comprised of the arithmetic unit carry flip-flop (CYF), the 2-bit unit control for the arithmetic unit (CPU) and the 5-bit variable data length control (CPL). CPU is also addressable as a source and as a sink and when so addressed can be treated as if it were a 4-bit register whose leftmost 2 bits are always equal to zero. 3.1.14.2 CA, CB, CC, CD The remaining 16-bits of the C Register are addressable in 4-bit groups as CA, CB, CC and CD. Their contents are available for analysis and alteration via the 4-bit function box. MANIPULATE, SKIP and BIT-TEST-BRANCH instructions are applicable. LSB BURROUGHS CORPORATION COMPUTER SYSTEMS GROUP SANTA BARBARA PLANT COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 The 4-bit groups designated as CA and CB have no special functional assignment and are available as general purpose 4-bit storage registers. The two 4-bit registers designated as CC and CD are used for the storage of various processor states and conditions as shown below: | CC: 4 STATE LAMP INTERRUPT INTERRUPT PNL FLIP-FLOP INTERRUPT LSB 1 MEMORY MEMORY ADDR MEMORY ADDR MEMORY ADDR PAR ERROR OUT OF BOUNDS OUT OF BNDS INTERRUPT OVERRIDE CNT INTERRUPT OVERRIDE CNT INTERRUPT INTERRU | | - | | | | | | | | | | | | | | | | - | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---|------|------|------|----|-----|-----|---------|------|-----|-----|------|-----|------|-------|-----|------|-----| | I FLIP-FLOP I I INTERRUPT I / I LSB I MEMORY I MEMORY ADDR I MEMORY ADDR I MEMORY ADDR I CD: 4 READ DATA I WRITE/SWAP I READ I WRITE/SWAP I I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I | cc: | - | | | | | | | | • | | | | - | CO | | L | 1 | | | I MEMORY I MEMORY ADDR I MEMORY ADDR I MEMORY ADDR I CD: 4 READ DATA I WRITE/SWAP I READ I WRITE/SWAP I I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I | 00. | - | | | | • | • | | • • • • | | | | | | TAIT | CODII | O T | 4 | | | LSB I MEMORY I MEMORY ADDR I MEMORY ADDR I MEMORY ADDR I CD: 4 READ DATA I WRITE/SWAP I READ I WRITE/SWAP I I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I | | ł | FLIP | -1 L | JP | 1 | | | | • | | | | 4 | TMI | בתתט | r i | • | | | LSB I MEMORY I MEMORY ADDR I MEMORY ADDR I MEMORY ADDR I CD: 4 READ DATA I WRITE/SWAP I READ I WRITE/SWAP I I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I | | - | | | | | | | | | | | | | | | | - | | | I MEMORY I MEMORY ADDR I MEMORY ADDR I MEMORY ADDR I CD: 4 READ DATA I WRITE/SWAP I READ I WRITE/SWAP I I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I | | | | | | | | | | | | | | | | | / | 11 | | | I MEMORY I MEMORY ADDR I MEMORY ADDR I MEMORY ADDR I CD: 4 READ DATA I WRITE/SWAP I READ I WRITE/SWAP I I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I | | | | | | | | | | | | | | | | | | 1 | | | I MEMORY I MEMORY ADDR I MEMORY ADDR I MEMORY ADDR I CD: 4 READ DATA I WRITE/SWAP I READ I WRITE/SWAP I I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I | | | | | | | | | | | | | | | | | 1 | c a | | | CD: 4 READ DATA & WRITE/SWAP READ 1 WRITE/SWAP 1 PAR ERROR OUT OF BOUNDS OUT OF BNDS OUT OF BNDS | | | | | | | | | | | | | | | | | L | 30 | | | CD: 4 READ DATA & WRITE/SWAP READ 1 WRITE/SWAP 1 PAR ERROR OUT OF BOUNDS OUT OF BNDS OUT OF BNDS | | | | | | | | | | | | | | | | | | | | | CD: 4 READ DATA & WRITE/SWAP READ 1 WRITE/SWAP 1 PAR ERROR OUT OF BOUNDS OUT OF BNDS OUT OF BNDS | | - | | | | | - | | | | | | | | | | | | | | I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I OUT OF BNDS I | | 1 | MEMO | RY | 1 | M | EM | ORY | ΑE | ODR | 1 | MEM | ORY | ADI | )R I | MEM | ORY | ADDF | 1 1 | | I PAR ERROR I OUT OF BOUNDS I OUT OF BNDS I OUT OF BNDS I | nn: | ā | READ | DA. | TA I | 14 | RI | TF/ | SW | A P | 1 | REA | D | | 1 | WRI | TE/ | SWAP | 1 | | THE ENGLY I GOT OF BUSINESS TO STORY | CD | | | | | | - | | | | | | _ | ANI | 15 | DILT | OF | RNDS | . 1 | | | | 1 | | | | | | | | | | | | | | | | | • | | 1 INTERRUPT 1 OVERRIDE CNTL 1 INTERRUPT 1 INTERRUPT 1 | | 1 | INTE | RRU | PT ( | 0 | VE: | RRI | DE | CNTL | . 1 | INT | ERRU | 171 | | INI | EKH | UPI | ŧ | | | | - | | | | | | | | | | | | | | | | | | | //\ | | | | | | | | | | | | | | | | | | | 711 | | 1 | | | | | | | | | | | | | | | | | | | 4 | The control panel state lamp flip-flop when true will cause the STATE lamp to light. The timer interrupt signal is developed from the primary power frequency, field adjustable for either 50Hz or 60Hz. The interrupt signal is received and is used to set the appropriate CC bit once every 100 milliseconds. The I/O Bus interrupt level is derived from the various I/O controls connected to the processor's I/O Bus. The level is the result of a service request by one or more controls and is used to set the interrupt bit every clock time. The control panel interrupt level is derived from the on position of the control panel's INTERRUPT switch. The level from the switch is used to set the interrupt bit every clock time. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 The memory read data parity error interrupt is set as a result of a parity error detected during: - (1) console READ of S-Memory by M-Processor-1, - (2) READ/SWAP/DISPATCH overlay from S-Memory. - (3) Micro-op fetch from M-Memory if H/F flip-flop = 1 (no halt), - (4) MOVE MSM TO REGISTER if H/F flip-flop = 1 (no halt), - (5) micro-op fetch from S-Memory by Processor-1 (program halts) The S-Memory (main memory) parity error signal is received from the Port Interchange via the port-processor interface, or in the case of direct connection, from main memory. The M-Memory parity error signal is developed from logic in the processor. The memory address out-of-bounds signals are derived from logic which compares the contents of the FA Register with the contents of the Base (BR) and Limit (LR) Registers on all memory accesses. The state of the out-of-bounds override control bit does not affect the setting of out-of-bounds interrupt bits but does affect the occurrence of the subsequent write operation. (See Section 3.3.7, Base and Limit Registers.) No reaction occurs as a result of any interrupt until the micro-program tests the interrupt bit. A micro-instruction or the control panel CLEAR pushbutton is capable of resetting a bit in the C Register. The bit being reset will be false for at least one clock period following the reset regardless of the continued existence of the condition to set the bit (e.g., control panel or service request interrupts). Any test micro-operator executed in this clock period will find the bit false. If the condition does not continue to exist beyond the reset time, a failure to set the bit may occur (e.g., timer interrupt). COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 ## 3.1.15 MAXS, MAXM MAXS and MAXM are both 24-bit pseudo registers that can be field-adjusted to give the actual size of the memories installed in the system. Both are addressable as sources only. MAXS, for main (S) memory, has 4K-byte resolution (least significant 15 bits are always zeroes). MAXM, for control (M) memory has a 1K-word resolution (least significant 10 bits are always zeroes). #### 3.1.16 U The U Register is a 16-bit register used primarily to accumulate the bit-by-bit input from the control panel's tape cassette. The U Register is addressable as a source register only. In RUN mode, if data is not yet available in the register, the micro-operator will be delayed. Data not accepted in time will be lost. In TAPE mode, the register's contents are automatically moved to the M Register for execution except when executing micro-operators that reference the U Register as a source. In these cases the source data is moved directly from the U Register to the destination and will not be treated as an instruction to be executed. The next instruction from the tape will follow this data. For MOVE 24-BIT LITERAL, the 8 bits of the literal in the M Register are also moved to the destination. For CONDITIONAL BRANCH, the A Register may be changed but the next micro-operator read from the tape will also be executed. Note: In RUN mode, the U Register may not be addressed after the issuance of a CASSETTE STOP micro. ## 3.1.17 DATA DATA is a 24-bit pseudo register that can act as a source or as a destination. It is used to transfer data to and from the I/O Bus. When it is used as a source, the processor generates the RC (RESPONSE COMPLETE) signal to COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 the interface and accepts the 24-bits of data from the bus. When used as a destination, the processor generates the RC signal to the interface and the data from the designated source to the bus. 3.1.18 CMND CMND (Command) is a 24-bit pseudo register that can act as a destination only. It is used to transfer commands to devices on the I/O Bus. The processor generates the CA signal to the interface and moves the data (or the command) from the designated source to the bus. 3.1.19 NULL NULL is a 24-bit pseudo register that can act as a source and as a destination. When addressed as a source, all zeros are supplied to the destination. When addressed as a destination, the source data is not accepted. However, NULL is useful as a destination in order to pop the TAS Register without affecting other registers. 3.1.20 READ READ is a 24-bit pseudo register that can act as a source only. When addressed as a source, information on the positions of the control panel switches is supplied to the destination. 3.1.21 WRIT WRIT is not permitted to be addressed as a source or as a destination, but is used in conjunction with a memory WRITE operation from the control panel. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 #### 3.2 24-BIT FUNCTION BOX The 24-bit "function box" is composed of a 24-bit arithmetic unit and a 24-bit combinatorial unit. It has as data inputs the contents of the X and Y Registers and the carry flip-flop (CYF). It also uses CPU (control for the arithmetic unit) and CPL (the 5-bit variable operand length) from the CP portion of the C Register. All results from the combinatorial section are generated immediately and are continuously available to the micro-programmer. A move to one of the input registers or an alteration of a value in the CP portion of the CR egister immediately generates a new result. The results are available to the next micro-instruction and are accessed by moving the contents of a result register to a destination register or by testing one of the 4-bit condition registers. The results are most of the commonly used functions between two operands. These include the And. Or. Exclusive-Or. sum. carry-out. difference. and borrow functions and the set of equal-to. greater-than, and less-than relationals. The results of the unary operations of complementation and masking are also available. The results of the arithmetic unit are under control of the CPU and the CPL Registers as follows. | CPU | UNIT TYPE | POSSIBLE CPL VALUES | DATA TYPE | |-----|----------------|---------------------|--------------| | 00 | 1-bit operands | 1 to 24 | Binary | | 00 | 4-bit operands | 4,8,12,16,20,or 24 | 4-bit binary | | 10 | Undefined | | | | 11 | 8-bit operands | 8, 16, 24 | EBCDIC | For valid arithmetic operations, the operand length (as specified by CPL) must be an exact multiple of the length of the unit specified by CPU. The contents of each of the registers described in the following subsections are immediately available to the micro-programmer. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 3.2.1 SUM SUM is a pseudo register equal to the sum of the X, Y, and CYF Registers (X + Y + CYF). Zero bits in the more significant bit positions of the 24-bit result are produced when the length as determined by CPL (5-bit variable data length control) is less than 24. Results are not defined for CPL values 25 through 31. The carry-out level is generated from the bit position of the output specified by CPL. If CPL = 0, the carry-out level is equal to CYF. If CPL = 1, the carry-out level is generated from the rightmost bit of X, Y and CYF. See Section 3-1-14-1, CP (CYF, CPU, CPL). If CPU (2-bit arithmetic unit control) = 00, the binary sum is produced. See Section 3.1.14.1, CP (CYF, CPU, CPL). If CPU = 01, the decimal sum is produced by considering the X and Y inputs to be comprised of six 4-bit units. Results are not defined for non-Binary Coded Decimal (BCD) units. CPL must be a multiple of four. If CPU = 10 or 11, the sum is undefined. 3.2.2 DIFF DIFF is a pseudo register equal to the difference of the X, Y, and CYF Registers (X - Y - CYF). Zero bits appear in the more significant bit positions of the 24-bit result when the length as determined by CPL is less than 24. Results are not defined for CPL values 25 through 31. The borrow-out level, generated from the static comparison of all 24-bits of X & Y, is true if X < Y or if X = Y and CYF is true. If CPU = 00, the binary difference is produced. If CPU = 01, the decimal difference is produced by considering the X & Y inputs to be comprised of six 4-bit units. Results are not defined for non-BCO units. CPL must be a multiple of four. If CPU = 10 or 11, the difference is undefined. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 A negative result is in 2's complement form in the binary case and in 10's complement form in the decimal case. ## 3.2.3 XANY, XORY, XEDY XANY (X and Y), XORY (X or Y), and XEOY (X exclusive-or Y) are 24-bit pseudo registers that hold the results of the specified logical functions. Zero bits are produced in the more significant bit positions of the 24-bit result when the length as determined by CPL is less than 24. Results for the CPL values 25 through 31 are not defined. ## 3.2.4 CMPX CMPY CMPX (complement of X) and CMPY (complement of Y) are 24-bit pseudo registers that hold the 1°s complements of the specified registers. Zero bits are produced in the more significant positions of the 24-bit result when the length as determined by CPL is less than 24. CPL values 25 through 31 have undefined results. ## 3.2.5 MSKX, MSKY MSKX, (mask of X) and MSKY (mask of Y) are 24-bit pseudo registers that hold the mask of the appropriate register (X or Y). Beginning with LSB of X or Y, the number of bit positions included in the mask is determined by the value of CPL. Zero bits are produced in the more significant bit positions of the 24-bit result when the length as determined by CPL is less that 24. Results are not defined for CPL values 25 through 31. #### 3.2.6 BICN BICN (binary conditions) is a 4-bit pseudo register that holds the following binary conditions, considered as a 4-bit group, and addressable as a source only: COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 NOTE: CYF is also addressed by the SET CYF M-Instruction as well as being available in the (8-bit) group addressed as CP. BICN: 1 LSUY 1 CYF 1 CYD 1 CYL 1 I I Carry Out Level I Borrow-Out Level Carry Flip-Flop Least Significant Unit of Y The carry-out level is a function of X, Y, CPL, and CPU. See Section 3.2.1. The borrow-out level is a function of X, Y, and CYF. See Section 3.2.2, DIFF. LSUY is true if the least significant unit of Y is equal to 1 and CPU = 00 or 10, or if the least significant unit of Y is equal to 1001 and CPU = 01 or 11. ## 3.2.7 XYCN XYCN (XY condition) is a 4-bit pseudo register that holds the following relational conditions, considered as a 4-bit group and addressable as a source only: XYCN: 1 MSBX 1 X=Y 1 X<Y 1 X>Y 1 MSBX is true if the bit in X referenced by CPL is 1. CPL = 1 references the rightmost bit of X while CPL = 24 references the leftmost bit. MSBX = 0 if CPL = 0. The relational results are based on the binary value of all 24-bits of X and Y. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 #### 3.2.8 XYST XYST (XY states) is a 4-bit pseudo register that holds the following relational conditions, considered as a 4-bit group and addressable as a source only: XYST: | LSUX 1 INT | Y neq 0 | X neq 0 | LSUX is true when the least significant unit of X is equal to 1 and CPU = 00 or 10, or when the least significant unit of X is equal to 1001 and CPU = 01 or 11. The relational results are based on the binary value of all 24 bits of X or Y. INT is true if any of the following conditions as reflected in INCN, CC, and CD are true. (See Section 3-1-10, INCN and 3-1-14-2, CA, CB, CC, CD.) - 1. Missing Port Device - Port Interrupt - 3. Timer Interrupt - 4. Bus I/O Interrupt - 5. Control Panel Interrupt - 6. Memory Parity Error Interrupt - 7. Memory Write/Swap Address Out of Bounds Interrupt COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 ## 3.2.9 INCN INCN (interrupt conditions) is a 4-bit pseudo register, source only, that reflects the state of certain interface lines between the processor and the port interchange. | INCN: | MISSING DEVICE | PORT HI PRIORITY INTERRUPT | 1 INTERRUPT | 1 FOCKOUL I | |-------|----------------|----------------------------|-------------|-------------| | | | | | | ## 3.2.10 PERR PERR (parity error) is a 4-bit register, source only, that reflects error conditions as follows: | | | | | - | | | | | |---|------------|---|----------|---|----------|---|---------|-----| | 4 | NO | • | M-MEMORY | 1 | S-MEMORY | 1 | CASSETI | E 1 | | 4 | ASSIGNMENT | 1 | PARITY | ı | PARITY | 1 | PARITY | 4 | | i | | | | 1 | ERROR | 1 | ERROR | 1 | | _ | | | | | | - | | | The true state of any bit causes a console lamp to be illuminated and a processor halt. The PERR Register is cleared by: - (1) a general CLEAR - (2) control panel START pushbutton depressed. - (3) console READ of S-Memory or M-Memory i.e., READ/WRITE or INC pushbutton depressed. The M-Memory parity error bit is set if a parity error is detected during: - (1) console READ of the MSM Register, i.e., READ/WRITE or INC pushbutton depressed, - (2) fetch of a micro-operator from MSM if halt/flag (H/F flip flop) = 0 (HALT). - (3) REGISTER MOVE of MSM if halt flag = 0. - (4) SCRATCHPAD MOVE of MSM is halt flag = 0. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 The S-Memory parity error bit is set if a parity error is detected during: - (1) console READ of S-Memory, i.e., READ pushbutton depressed, - (2) fetch of a micro-operator from S-Memory. The cassette parity error bit is set if a parity error is detected during a CASSETTE READ. PERR is present in M-Processor-2 only. If addressed as a source by a M-Processor-1, zero bits are returned. #### 3.3 4-BIT FUNCTION BOX The 4-bit function box (4-bit arithmetic and combinatorial section of the processor) can accept, as one of its inputs, the contents of any of the following 4-bit registers and pseudo registers. The second input is obtained from the M-Instruction itself. | TA | TB | TC | TD | TE | TF | |------|------|------|------|------|------| | LA | LB | LC | LD | LE | LF | | FU | FT | FLC | FLD | FLE | FLF | | CA | CB | CC | CO | TOPM | CPU | | BICN | XYCN | XYST | FLCN | INCN | PERR | Outputs include the result of most of the commonly used functions between two operands; for example: set, and, or, exclusive—or, and binary sum and difference (both modulo 16). Outputs are directed back to the source register. The sum and difference output can be tested for overflow and underflow respectively and, based on the test, a skip of one instruction can be made. The 4-bit function box also provides for the selective testing of one of the bits of a four-bit group and relative branching based on the result of the test. A skip of one instruction based on the result of testing on a combination of up to four bits in the group is also provided. BICN, XYCN, XYST, FLCN, and INCN are not actually registers but can be sourced as if they were. They can be changed COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 only as a result of changing the condition which they reflect. CPU is actually a 2-bit register but can be addressed as if it were a 4-bit register whose leftmost 2 bits are always equal to zero. 3.4 M-INSTRUCTIONS 3.4.1 REGISTER MOVE FORMAT: 1 CODE 1 REGISTER GROUP # 1 SELECT # 1 GROUP # 1 1 0 -15 1 0 -- 3 1 0 -- 3 1 0 -- 15 1 Move the contents of the source register to the destination register. If the source register is smaller than the destination register, data are right justified with left (most significant) zero bits supplied. If the source register is larger than the destination register, data are truncated from the left. The contents of the source register are unchanged unless it is also the destination register. # Exceptions: - 1. When M is used as a destination register in RUN or STEP mode, the operation is changed to a bit-OR which modifies the next micro-operation. It does not modify the instruction as stored in the memory. In TAPE mode, no bit-OR takes place. - 2. WRIT and CMND are excluded as source registers. - 3. BICN, FLCN, XYCN, XYST, INCN, READ, WRIT, SUM, CMPX, CMPY, XANY, XEOY, MSKX, MSKY, XORY, DIFF, MAXS, MAXM, and U are excluded as destination registers. - 4. When DATA is designated as a source, CMND and DATA are excluded as destinations. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 - 5. When U or DATA is designated as a source and when the next micro is to be obtained from main memory, M is excluded as a destination. - 6. U is excluded as a source in STEP mode. #### 3.4.2 SCRATCHPAD MOVE FORMAT: 1 CODE 1 GRP # 1 SLCT# 1 O TO SCRTCHPD 1 WORD 1 WORD 1 WORD 1 O-15 1 O-..3 1 1 FROM 1 O-LFT WRD 1 ADDRESS 1 1 SCRTCHPD 1 1-RT WRD 1 O-..15 1 Move the contents of the register (SCRATCHPAD) to SCRATCHPAD (register). If the move is between registers of unequal lengths, the data is right justified with left (most significant) zero bits supplied or with data truncated from the left, whichever is appropriate. The contents of the source register are unchanged. # Exceptions: - 1. When M is used as a destination register, the operation is changed to a bit-or which modifies the next micro-operation. It does not modify the instruction as stored in the memory. - WRIT and CMND are excluded as source registers. - 3. BICN, FLCN, XYCN, XYST, INCN, READ, WRIT, SUM, CMPX, CMPY, XANY, XORY, XEOY, MSKX, MSKY, DIFF, MAXS, MAXM and U are excluded as destination registers. - 4. U is excluded as a source in STEP mode. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P-S- #1913 1747 ## 3.4.3 SWAP F WITH DOUBLEPAD WORD Move the contents of the FA and FB registers to a holding register. Move the contents of the left and right word of the source scratchpad word to the FA and FB register respectively. Move the contents of the holding register to the left and right word of the destination scratchpad word. ## 3.4.4 STORE F INTO DOUBLEPAD WORD # OP # SCRATCHPAD # FORMAT: | CODE | WORD ADDRESS | 1 0000 0000 0100 | 0 -- 15 | 1 Move the contents of the FA and FB register to the left and right word respectively of the designated scratchpad word. The contents of the source registers are unchanged. #### 3.4.5 LOAD F FROM DOUBLEPAD WORD # OP # SCRATCHPAD | 1 FORMAT: 1 CODE | 1 WORD ADDRESS | 1 0000 0000 0101 | 0---15 | 1 Move the contents of the left and right word of the designated scratchpad word to the FA and FB register respectively. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 The contents of the source registers are unchanged. ## 3.4.6 MOVE 8-BIT LITERAL Move the 8-bit literal given in the instruction to the destination register. If the move is between registers of unequal lengths, the data is right justified with left (most significant) zero bits supplied. The register select number is assumed to be 2. # Exceptions: - 1) READ and WRIT are excluded as destination registers. - When M is used as a destination register, the operation is changed to a bit-or which modifies the next micro instruction. It does not modify the instruction as stored in the memory. # 3.4.7 MOVE 24-BIT LITERAL Move the 24-bit literal given in the instruction to the destination register. If the move is between registers of unequal lengths, the literal is truncated from the left. The register select number is assumed to be 2. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 # Exceptions: 1) READ, WRIT, M and MSM (except in TAPE mode) are excluded as destination registers. #### 3-4-8 SWAP MEMORY | • | | 0 P | | ŧ | REC | 15 | TER | # | • | FIE | LD | 1 | MEMORY | 1 | |---------|---|------|------|---|-----|----|-----|---|---|------|----------|----|--------|---| | FORMAT: | 4 | CODE | | 1 | 00 | = | X | | 1 | DIRE | ECTION | -1 | FIELD | 1 | | | 1 | 0000 | 0010 | 1 | 01 | = | Y | | 1 | 0 - | POSITIVE | ŧ | LENGTH | 1 | | | 1 | | | 1 | 10 | = | T | | 1 | 1 - | NEGATIVE | 1 | 0 24 | 1 | | | 1 | | | 1 | 11 | = | L | | 1 | | | 1 | | 1 | | | _ | | | | | | | | | | | | | | Swap data from main memory with the data in the specified register. If the value of the memory field is less than 24, the data from memory is right justified with left (most significant) zero bits supplied while the data from the register is truncated from the left. Register FA contains the bit address of the memory field while the field direction sign and field length is given in the instruction. If the value of the memory field length as given in the instruction is zero, the value given in CPL is used. ## 3-4-9 READ/WRITE MEMORY | | | | | | | | | | | | FIELD | | | | | |---------|---|------|---|------|--------|---|-------|---|--------|---|--------------|---|--------|---|--| | FORMAT: | 1 | CODE | 4 | 0 to | RGSTR | ı | VRNTS | 1 | 00 = X | 1 | DIRECTION | 1 | FIELD | 1 | | | | 1 | 0111 | 1 | 1 TO | MEMORY | 1 | 0 7 | 1 | 01 = Y | 1 | 0 - POSITIVE | 1 | LENGTH | 1 | | | | 1 | | 1 | | | ı | | 1 | 10 = T | ı | 1 - NEGATIVE | ı | 026 | 1 | | | | 1 | | 1 | | | į | | 1 | 11 = L | 1 | | i | | 1 | | | | | | | | | | | | | | | | | | | Move the register's (memory's) contents to the memory (register). If the value of the memory field length is less than 24, the data from memory is right justified with left (most significant) zero bits supplied while the data COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 from the register is truncated from the left. The contents of the source is unchanged. Register FA contains the bit address of the memory field while the memory field direction sign and memory field length is given in the instruction. If the value of the memory field length as given in the instruction is zero, the value in CPL is used. Memory field length values (or CPL values if MFL = 0) of 25 and 26 are truncated to the value 24. When used on a WRITE operation, the value 25 and 26 cause odd and even parity respectively to be written into memory regardless of the parity of the read data. For a description of the count variants, see Section 3.4.10, COUNT FA/FL. #### 3.4.10 #### COUNT FA/FL | | - | | | | | | | - | |---------|---|------|------|---|----------|---|---------|---| | | 1 | 0 P | | 1 | COUNT | 1 | LITERAL | ı | | FORMAT: | 1 | CODE | | 1 | VARIANTS | 1 | 0 31 | i | | | 1 | 0000 | 0110 | i | 0 7 | 1 | | 1 | | | | | | | | | | | Increment (decrement) binarily the designated register(s) by the value of the literal contained in the instruction or by the value of CPL if the value of the literal is zero. Neither overflow nor underflow of FA is detected. The value of FA may go through its maximum value or its minimum value and wrap around. Overflow of FL is not detected. The value of FL will go through its maximum value and wrap around. Underflow of FL is detected and will not wrap around. The value of zero is left in FL. Literal values (or CPL values if LIT = 0) of 25 through 31 are truncated to the value 24. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 ## Count variants are as follows: V = 000 No count 001 Count FA Up 010 Count FL Up 011 Count FA Up and FL Down 100 Count FA Down and FL Up 101 Count FA Down 110 Count FL Down 111 Count FA Down and FL Down ### 3.4.11 SCRATCHPAD RELATE FA | | - | | | | | | | | | | | |---------|---|------|------|---|----------|---|------|--------|---|----------------|-----| | | 1 | 0 P | | 1 | RESERVED | 1 | SIGN | OFF | 1 | LEFT SCRATCHPA | D 1 | | FORMAT: | 1 | CODE | | 1 | | - | | | | WORD ADDRESS | 1 | | | 1 | 0000 | 1000 | 1 | 000 | 1 | 0-P0 | SITIVE | ĺ | 015 | 1 | | | i | | | 1 | | 1 | 1-NE | GATIVE | 1 | | 1 | | | | | | | | | | | | | | Replace the contents of the FA Register by the binary sum of the FA Register and specified scratchpad register. Neither overflow nor underflow of FA is detected. The value of FA may go through its maximum value or its minimum value and wrap around. #### 3.4.12 EXTRACT FROM REGISTER T | OP | REGISTER<br>1 00 - X<br>1 01 - Y | 1 BIT COUNT | 1 | |----|----------------------------------|-------------|---| |----|----------------------------------|-------------|---| Rotate register T left by the number of bits specified and then extract from the right the number of bits specified. Move this result to the destination register supplying left most (most significant) zero bits if the extract count is less than 24. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 The contents of the source register are unchanged unless it is also the destination register. A rotate value of 24 is equivalent to 0. ## 3.4.13 SHIFT/ROTATE REGISTER T LEFT FORMAT: 1 CODE 1 REGISTR 1 REGISTR 1 0 - SHIFT 1 BIT COUNT 1 1 1010 1 GROUP # 1 SELECT# 1 1 - ROTATE 1 0---24 1 1 0---15 1 0---3 1 SHIFT (ROTATE) Register T left by the number of bits specified and then move the 24-bit result to the destination register. If the move is between registers of equal lengths, the data is right justified with data truncated from the left. The contents of the source register are unchanged unless the source register is also the destination register. Zero fill on the right and truncation on the left occurs for the SHIFT operation. If the value of the SHIFT/ROTATE count as given in the instruction is zero, the value given in CPL is used. # Exceptions: - 1. When M is used as a destination register, the operation is changed to a bit-or which modifies the next micro-operation. It does not modify the instruction as stored in the memory. - 2. BICN, FLCN, XYCN, XYST, INCN, READ, WRIT, SUM, CMPX, CMPY, XANY, XEQY, MSKX, MSKY, XQRY, DIFF, MAXS, MAXM, and U are excluded as destination registers. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 #### 3-4-14 # SHIFT/ROTATE REGISTER X/Y LEFT/RIGHT | | - | | | • • | | - | | - | | | | | |---------|---|------|-------|-----|----------|---|---------|---|---------|---|-------|---| | | 1 | ΩP | | ı | S/R | 1 | L/R | 1 | X/Y | 1 | S/R | ı | | FORMAT: | i | CODE | | 1 | VARIANT | 1 | VARIANT | 1 | VARIANT | 1 | BIT | 1 | | TORMAT | i | 0000 | 01 00 | 1 | 0-SHIFT | 1 | O-LEFT | 1 | 0-X REG | 1 | COUNT | ı | | | 4 | | | i | 1-ROTATE | i | 1-RIGHT | ŧ | 1-Y REG | 1 | 0 24 | 1 | | | - | | | | | | | | | | | | SHIFT (ROTATE) Register X or Register Y left (right) by the number of bits specified. Zero fill on the right and truncation on the left occurs for the left shift. Zero fill on the left and truncation on the right occurs for the right shift. #### 3.4.15 # SHIFT/ROTATE REGISTERS XY LEFT/RIGHT | | | | | | | - | | | | | |---------|---|------|------|---|----------|---|---------|---|------|---| | | 1 | 0P | | 1 | S/R | ı | L/R | 1 | S/R | • | | FORMAT: | 1 | CODE | | 1 | VARIANT | 1 | VARIANT | 1 | BIT | 1 | | | 1 | 0000 | 0101 | | O-SHIFT | | | | | | | | • | • | | 1 | 1-ROTATE | 1 | 1-RIGHT | ŧ | 0 48 | 1 | | | - | | | | | | | | | | SHIFT (ROTATE) Register X and Y left (right) by the number of bits specified. The register X is the leftmost (more significant) half of the concatenated 48-bit XY register. Zero fill on the right and truncation on the left occurs for the left shift. Zero fill on the left and truncation on the right occurs for the right shift. #### 3.4.16 # NORMALIZE X | | 1 | 0P | | | | 1 | |---------|---|------|------|------|------|---| | FORMAT: | 1 | CODE | | | | 1 | | | 1 | 0000 | 0000 | 0000 | 0011 | 1 | COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 SHIFT the X Register left while counting FL down, until FL=0 or until the bit in X referenced by CPL = 1. Zeros are shifted into the rightmost end of X. CPL = 1 references the rightmost bit of X while CPL = 24 references the leftmost bit of X. CPL is undefined. ## 3.4.17 READ/WRITE MSM | | | | <br> | | - | | | <br> | | | | | | |---------|---------|----|------|---|------|-------|-----|------|---|----|-----|-------|---| | FORMAT: | 1 0P CC | DE | 1 | V | / AF | RIANI | r s | 1 | R | /W | VAF | RIANT | ı | | | 1 0000 | | | | | | | | | | | | | | | 1 | | 1 | | • | | ŧ | 1 | 1 | FR | MO | X | 1 | | | | | | | | | | <br> | | | | | | Move the contents of the X Register to the M-Memory word specified by the address contained in the L Register if the R/W variant bit = 1. The data is truncated from the left. Move the contents of the M-Memory word specified by the address contained in the L Register to the X Register if the R/W variant bit = 0. The data is right justified with left (most significant) zero bits supplied. The lower 4 bits and the upper 8 bits of the address in Lare ignored. READ/WRITE MSM causes the A register to be moved to the TAS Register and the L Register to be moved to the A Register before the instruction is executed. The TAS is restored to A after the READ/WRITE MSM operation is completed. The S Variant is used to enable the set/reset of the G/B and the H/F flip flops. If S=1, the G/B and H/F flip flops are set/reset by the G/B and H/F variants. If S=0, no change is made in the G/B and H/F flip flops. If the G/B flip flop is true, all READ/WRITE MSM operations will force bad parity in the addressed word. If the G/B flip flop is false, all READ/WRITE MSM operations will force good parity in the addressed word. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 If the H/F flip flop is true, the processor upon reading an M-Memory word containing a parity error will flag the error condition by setting a CD bit true. It will not halt. If the H/F flip flop is false, the processor upon detection of a parity error in reading an M-Memory word will flag the error condition by setting PERR bit 1 true and then halt. Reading an M-Memory word occurs when fetching a M-op from M-Memory or when moving an M-Memory word to any destination. The H/F and G/B flip flops are cleared to zero (false) with the CLEAR signal. If S=1, the G/B and H/F flip flops are set/reset prior to the execution of the READ/WRITE MSM portion of the operation. 3-4-18 CALL Push the address of the next in-line micro-instruction into the A Stack and then fetch the next micro-instruction from the location obtained by adding the signed displacement value given in the instruction to the address of the next in-line micro-instruction. A displacement value indicates the number of 16-bit words. Note: When the A Address is stored in the A Stack, it is multiplied by 16 and stored as a bit address. Note: Exit is accomplished by employing the REGISTER MOVE instruction with the TAS as the source register and A as the destination register. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 3-4-19 BRANCH FORMAT: | CODE | SIGN | VALUE | 1 110 | 0=POSITIVE | 0---4095 | 1 | 1=NEGATIVE | Fetch the next micro-instruction from the location obtained by adding the signed displacement value given in the instruction to the address of the micro-instruction next-in-line. A displacement value indicates the number of 16-bit words. 3-4-20 BIAS Set CPU to the value 1 if the value of FU is 4 or 8 and to 0 otherwise, unless V=2. If V=2, the CPU value is determined by SFU in lieu of FU. Set the value of CPL to the smallest of the values denoted on each line in the following table. | ٧ | VALUES | |---|-------------------| | - | | | 0 | FU | | 1 | 24 and FL | | 2 | 24 and SFL | | 3 | 24 and FL and SFL | | 4 | CPL | | 5 | 24 and CPL and FL | | 6 | CPL | | 7 | CPL | COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 If test flag equals 1 and final value of CPL is not zero, the next 16-bit micro-instruction is skipped. #### 3.4.21 SET CYF | | - | | | | | | | |---------|---|------|------|------|---|---------|----| | | 1 | 0 P | | | 1 | VARIANT | SI | | FORMAT: | 1 | CODE | | | 1 | | 1 | | | 1 | 0000 | 0000 | 0110 | 1 | 1.2.4.8 | ŧ | | | | | | | | | | Set the carry flip-flop as specified by the variants. - V = 1 Set CYF to 0 - 2 Set CYF to 1 - 4 Set CYF to CYL - 8 Set CYF to CYD Note CYD = (X<Y) + (X=Y)CYF. ### 3.4.22 4-BIT MANIPULATE | | | | | | | REGISTER | | | | | | |---------|---|------|---|---------|---|----------|---|-----|---|-----|---| | FORMAT: | 1 | CODE | 1 | GROUP # | 1 | SELECT # | 1 | | ı | | 1 | | | ŧ | 0011 | 1 | 015 | 1 | 0 1 | 1 | 0 7 | 1 | 015 | 1 | | | - | | | | | | - | | | | | Perform the operation specified by the variants on the designated register. - V = 0 Set the register to the value of the literal. - 1 Set the register to the logical And of the register and literal. - 2 Set the register to the logical Or of the register and literal. - 3 Set the register to the logical Exclusive-Or of the register and literal. - 4 Set the register to the binary sum (modulo 16) of the register and literal. - 5 Set the register to the binary sum (modulo 16) of the register and literal, and skip the next M-Instruction if a carry is produced. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 - 6 Set the register to the binary difference (modulo 16) of the register and literal. - 7 Set the register to the binary difference (modulo 16) of the register and literal, and skip the next M-Instruction if a borrow is produced. #### Exception \_\_\_\_\_ BICN, FLCN, XYCN, XYST, and INCN, when specified as operand registers, are not changed as a result of this operation. However, the carry and borrow outputs are produced and a skip can result. 3-4-23 BIT TEST BRANCH FALSE 1 OP 1 REG 1 REGISTER 1 REG 1 DSPLCMNT 1 DSPLCMNT 1 FORMAT: 1 CODE 1 GROUP # 1 SELECT # 1 BIT # 1 SIGN 1 VALUE 1 1 0101 1 0 -- 15 1 0 -- 1 1 0 -- 3 1 0 -POS 1 0 - - - 15 1 1-NEG 1 Test the designated bit within the specified register and branch relative to the next instruction by the signed displacement value if the bit is zero. If the bit is one, a displacement value of zero is assumed and control passes to the next in-line M-instruction. A displacement value indicates the number of 16-bit words from the next in-line instruction. See Section 3.1.14 for information on the reset of bits in the C Register. 3-4-24 BIT TEST BRANCH TRUE FORMAT: | 1 OP 1 RGSTR<br>1 CODE 1 GROUP<br>1 0101 1 01 | # 1<br>5 1 | SELECT # 0 • • • 1 | 1 | BIT # | i | SIGN<br>O-POSITIVE | 1 | VALUE<br>015 | 1 | |-----------------------------------------------|------------|--------------------|---|-------|---|--------------------|---|--------------|---| |-----------------------------------------------|------------|--------------------|---|-------|---|--------------------|---|--------------|---| ----- Test the designated bit within the specified register and branch relative to the next instruction by the signed COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 displacement value if the bit is one. If the bit is zero, a displacement value of zero is assumed and control passes to the next in-line M-instruction. A displacement value indicates the number of 16-bit words from the next in-line instruction. See Section 3.1.14.2, CA, CB, CC, CD, for information on the reset of bits in the C Register. #### 3.4.25 SKIP WHEN | - | | | | | | | | | | |---|------|---|----------|---|------------|----------|---|------|---| | 1 | OP | 4 | REGISTER | 1 | REGISTER 1 | VARIANTS | 1 | MASK | i | | | | | | | SELECT # 1 | | | | | | ı | 0110 | 1 | 015 | 1 | 01 | | 1 | | ł | | | | | | | | | | | | Test only the bits in the register that are referenced by the "1" bits in the mask, ignoring all others unless V=2 or V=6. If so, compare all bits for an equal condition. Then perform the action as specified below. - V = 0 If any of the referenced bits is a "1", skip the next M-instruction. - 1 If all of the referenced bits are "1", skip the next M-instruction. - 2 If the register is equal to the mask, skip the next M-instruction. - 3 Same as V = 1, but also clear the referenced bits to zero without affecting the non-referenced bits. - 4 If any of the referenced bits is a "1", do not skip the next M-instruction. - 5 If all of the referenced bits are "1" do not skip the next M-instruction. - 6 If the register is equal to the mask, do not skip the next instruction. - 7 Same as V = 4, but also clear the referenced bits to zero without affecting the non-referenced bits. Note: If the mask equals 0000, the "ANY" result is false. The skip is not made for V=0 and is made for V=4. If the mask equals 0000, the "ALL" result is true. The skip is made for V=1 and V=3 and is not made for V=5 and V=7. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 # Exceptions: - 1. BICN, FLCN, XYCN, XYST, and INCN cannot be cleared with V = 3 or 7. However, they can be tested. - 2. See Section 3.1.14 related to the reset of bits in the C Register. # 3.4.26 CLEAR REGISTERS | | - | | | | | | | | | | | | | | | | | | | | |---------|---|------|------|---|---|---|---|---|----|-----|---|----|-----|----|-----|---|---|---|---|---| | | 1 | UP | | 1 | | | | | RI | EG: | S | TE | R I | FL | AGS | S | | | | 1 | | FORMAT: | 1 | CODE | | 1 | | | | | | | 8 | В | IT. | S | | | | | | • | | | ı | 0000 | 0011 | 1 | L | 1 | T | 1 | Υ | 1 | X | 1 | F | 1 | F | ŧ | F | ŧ | £ | 1 | | | 1 | | | ŧ | | 1 | | 1 | | ŧ | | ŧ | A | ŧ | L | ł | U | ŧ | Ρ | 1 | | | | | | | | | | | | | | | | | | | | | | | Clear the specified register(s) to zero if the respective flag bit is a one. 3.4.27 BIND FORMAT: 1 DP CODE 1 0000 0000 0100 1 Move the 24-bit value from the L Register to the MBR Register. Move the least significant 4 bits from the T Register to the TOPM Register. Move the most significant 20 bits from the T Register to the A Register truncating the left most 6 bits of the source. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 #### 3 - 4 - 28 OVERLAY M-MEMORY FORMAT: 1 DP CODE 1 0000 0000 0010 1 Overlay M-Memory from main memory. The starting addresses of both M-Memory and the main memory are taken from the L Register and the FA Register respectively. The length of the data overlay in bits is taken from the FL Register. The execution of the instruction proceeds as follows: - 1. A is moved to TAS with a stack push. - 2. L is moved to A. - 3. The first 16 bits are read from main memory and stored in the M-Memory. Register FL is decremented and FA and A are incremented. - 4. Step three is repeated until FL = 0 at which point the process terminates with a move of TAS to A. #### 3.4.29 DISPATCH | FORMAT: | OP<br>CODE<br>0000 0000 0001 | I VARIANTS I 000-LOCKOUT I 001-WRITE LOW I 010-READ I 011-READ & CLEAR I 100-WRITE HIGH I 101-PORT ABSENT | • • • | |---------|------------------------------|-----------------------------------------------------------------------------------------------------------|-------| |---------|------------------------------|-----------------------------------------------------------------------------------------------------------|-------| Dispatch operations are used to send/receive interrupt and interrupt information to/from other ports. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 Since the interrupt system is shared by all ports, the processor should gain control of the interrupt system by successfully completing a LOCKOUT prior to a DISPATCH WRITE. LOCKOUT sets the lockout bit in the DISPATCH Register and allows, via the skip variant, skipping or not skipping the next 16-bit instruction based upon success or failure (already set) of the LOCKOUT. WRITE (High or Low) DISPATCH sets the Lockout and Interrupt flip flops in the port interchange. It also stores the contents of the L Register into memory 0 through 23 and the contents of the least significant 7 bits of the T Register (designating the destination port # and channel #) into the appropriate port interchange register. In addition, it sets (Write High) or resets (Write Low) the high Interrupt flip flop in the port interchange. READ DISPATCH stores the contents of memory locations 0 through 23 into the L Register and the contents of the Port Channel register into the least significant 7 bits of the T Register. The other 17 bits of the T Register are unaffected. READ AND CLEAR DISPATCH in addition to performing the READ DISPATCH operation clears the lockout flip flop, the two interrupt flip flops and the Port Device Absent flip flop in the port interchange. It does not clear any memory locations. PORT ABSENT is executed by the processor when necessary to return a Port Device Absent level signal to another port indicating the absence of the designated channel. Dispatch operations in the case of Processor-2 and Processor Adapter-1 (direct connect to memory) are limited to the following: - 1. LOCKOUT + SKIP-IF-NOT-ALREADY-LOCKED: always skips. - 2. WRITE LOW: Always sets Port Device Absent level true (true indicates absence). - 3. READ & CLEAR: Always sets the Port Device Absent Level false (false indicates present). COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 No changes occur in the T and L Registers. In the INCN Register only the Port Device Absent bit can change. The Lockout, the Interrupt, and High Priority bits will always be false. No other dispatch operations are defined. ### 3.4.30 CASSETTE CONTROL FORMAT: 1 OP CODE | VARIANTS | RESERVED | 1 0000 0000 0010 | 0...7 | | FLAG BIT | 1 0...1 | | Perform the indicated operation on the tape cassette. V = 0 Start Tape - 1 Stop Tape (The processor also halts if it is in TAPE mode.) - 2 Stop Tape if X neq Y (The processor also halts if it is in TAPE mode.) - 3 Reserved - 4 Reserved - 5 Reserved - Stop Tape is X = Y (The processor also halts it it is in TAPE mode.) - 7 Reserved Note: All Stop Tape variants cause the tape to halt in the next available gap. #### 3-4-31 HALT FORMAT: 1 3P CODE 1 0000 0000 0001 1 Stop execution of the micro-instructions. In RUN mode the next micro to be executed is fetched and stored in the MR egister and the AR egister points to the next following micro. In TAPE mode the next micro is not fetched and stored in the MR egister but the HALT micro is left in the MR egister. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 3.4.32 NO OPERATION FORMAT: | OP CODE | 1 | 0000 0000 0000 | 1 Skip to the next sequential instruction. 3.4.33 MONITOR FORMAT: 1 OP CODE 1 VARIANTS 1 1 0000 1001 1 7 1 6 1 5 1 4 1 3 1 2 1 0 1 Skip to the next sequential instruction. During the time this micro-operator is executing the operator and the last two bits (0 and 1) are decoded, AND-ed with the system clock and are present in the backplane as follows: MONITOR 0 True for the OP Code MONITOR 00R0 True if last two bits are 00 MONITOR 01R0 True if last two bits are 01 MONITOR 02R0 True if last two bits are 10 MONITOR 03R0 True if last two bits are 11 At the backplane, the monitors are one-half clock from leading edge to trailing edge. 3.5 CONCURRENT OPERATION (Processor-1 only) In order to achieve maximum utilization of the processor during processor memory cycles, the micro-instructions are classified into two classes — a concurrent set and a non-concurrent set. The non-concurrent set is that set which must wait until the memory cycle is completed (data has been accepted or released) before proceeding with its execution. The concurrent set is that set which can overlap its execution with memory cycle. The overlap starts with the clock period following Address Accept and COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 can extend up to and beyond the time data is accepted. For a WRITE operation, the processor presents data during the clock period immediately following Address Accept and is released for a non-concurrent operation during the very next clock period. For a READ operation, the processor accepts data during the first clock period in which data is present and is released for a non-concurrent operation during the clock period immediately following this acceptance. The M-instructions comprising the concurrent set are: READ MEMORY\* COUNT FA/FL\*\* SCRATCHPAD RELATE FA WRITE MEMORY\* BIAS\*\* SWAP F WITH DOUBLEPAD WORD\*\* SWAP MEMORY\* MONITOR\*\* STORE F INTO DOUBLEPAD WORD\*\* BRANCH\*\* STORE F FROM DOUBLEPAD WORD\*\* - \* A memory cycle operation overlaps with another only during that portion of the cycle comprising the base-limit checking. The actual memory request is made during the clock period following acceptance of data. - \*\* A 1-clock concurrent micro-operator and the 2-clock branch micro-operator has a 1-clock NOP (no operation) placed after it by the hardware. Timing diagrams showing execution times for consecutive processor M-instructions are shown below. The diagrams assume that the instructions are obtained from M-Memory and that the processor receives the memory cycle immediately after requesting it. COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 | | M-op Execution | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------| | | I M-op Execution | | | | | | | • | | | | MEMORY CYCLE | I Base-Limit Ch | eck | | M-OP EXECUTION | 1 | | | | 1 1 Mem Req. | | | | Tom Kode | | | | 1 | | | | I Addr Accept | | | | | • • • • • • • • • • • • • • • • • • • • | | | | Concurrent M-op<br>Execution After | | (processor execution of> | i i write Data i | WRITE Starts Here | | WRITE terminates here) | 1 | | | | 1 1 1 | 1 Non-Concurrent | | | 1 1 | 1 M-op Execution | | | 1 1 | 1 After WRITE | | (Doctor of the continuous t | 1 Read Data 1 | 1 Starts Here | | (Processor execution of> READ terminates here.) | , | 1 | | ALAD Cerminates neres | i | | | | i | 1 Non-Concurrent | | | 1 | 1 M-op Execution | | | | 1 After READ | | | 1 | i Starts Here | | | V | ٧ | EXAMPLE ONE (General) COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 | | 1 M-op | Execution | | |------------------------------------------------|--------|----------------------|----------------------------------------------| | | I M-op | Execution | | | | 1 | 1 Base-Limit | Ch ec k | | Memory Cycle M-op Execution (WRITE) or (READ) | 1 1 | i Mem Req | | | (processor> execution of WRITE | 1 | A Write Data | / M-op Execution | | terminates here) | 1 1 1 | I<br><br>I Read Data | <pre>1 M-op Execution 1 M-op Execution</pre> | | (processor> execution of READ terminates here) | | • • • • | | # EXAMPLE THO (Concurrent M-op's overlapped with WRITE or READ Cycle) COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 | | <br>1 M-op | Execution | | | |----------------|------------|-----------------|-------------|--------------------| | | | | | | | | | | | | | | 1 M-op | Execution | | | | | - | | | | | | 1 | 1 Base-Limit C | heck | | | | 1 | •••• | | | | Memory Cycle | 4 | 1 Mem Req | | | | M-op Execution | 1 | | | | | (WRITE) | <b>1</b> | 1 Addr Accept | | | | | i | | | | | | 1 | I WRITE Data | I Second | I Base-Limit Check | | | . 1 | | 1 Memory | | | | | | 1 Cycle | | | | | 1 | # M-op | 1 Mem Req | | • | | | 1 Execution | 1 | | | | | 1 | 1 | | | | 1 | 1 | 1 | | | | | 1 | 1 | | | | | 1 | 1 | | | | 1 | 1 | 4 | | | | 400 400 400 400 | 1 | | | | | | ŧ | | | | | 1 | 1 | l Addr Accept | | • | | | 4 | | | | | | 1 | | | | | | 1 | 1 | | | | | 1 | | | | | | <b>i</b> | | | | | | V | 1 | EXAMPLE THREE (2nd Memory Cycle overlapped with WRITE Cycle) COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 | | 1 M-op | Execution | | | |--------------------------------|---------|--------------|-------------|--------------------| | | ~ ~ ~ ~ | | | | | | | | | | | | 1 M-op | Execution | | | | • | | | | | | | 4 | 1 Base-Limit | Check | | | | i | | | | | | i | 1 Mem Req | | | | | 1 | | | | | Memory Cycle<br>M-op Execution | 1 | 1 Addr Accep | t | | | (READ) | 1 | 40 40 40 m | | | | | . 4 | 1 | 1 Second | l Wait | | | 1 | | 1 Memory | -000 000 100 100 | | | 1 | | 1 Cycle | | | | 1 " | i | 1 M-op | l Wait | | | 1 | | 1 Execution | | | | 1 | | 1 | *** | | | 1 | 1 Read Data | 1 | I Base-Limit Check | | | *** | | 1 | | | · | | , | <b>t</b> | | | | | | 1 | 1 Mem Req | | | | | 1 | | | | | | )<br>1 | 1 Addr Accept | | | | | v | I Addr Accept | EXAMPLE FOUR (2nd Memory Cycle overlapped with Read Cycle) COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 ### 3.6 H-INSTRUCTION (Processor-1) The following instruction times (execute plus fetch of next M-Instruction) are given for the case where the next M-Instruction is contained in M-Memory. In general, five clocks are added to the basic time if the M-instruction is fetched from S-Memory (main, memory). | M-Instruction | Clocks | |----------------------------------------------|------------| | 46 46 46 46 46 46 46 46 46 46 46 46 46 4 | | | REGISTER MOVE | 1 * | | (MSM, SUM, DIFF as source) | 2* | | (DATA as source) | 3* | | (U as source) | <b>U</b> ★ | | (M as destination with A out-of-bounds | 1 | | *Add one additional clock if MSM, TOPM, A is | | | destination of if MBR is destination with | | | A out-of-bounds. Add two if DATA, CMND is | | | destination. | | | SCRATCHPAD MOVE | 1* | | (MSM, SUM, DIFF as source) | 2 | | (Data as source) | 3 | | (U as source) | u | | (MSM, TOPM, A as destination) | 2* | | (DATA, CMND as destination) | 3∗ | | (MBR as destination with A out-of-bounds) | 2* | | (M as destination with A out-of-bounds) | 1* | | *Add one additional clock if previous op was | _ | | WRITE INTO SCRATCHPAD | | | SWAP F WITH DOUBLEPAD WORD | 1 | | STORE F INTO DOUBLE WORD | ī | | LOAD F FROM DOUBLEPAD WORD | ī | | MOVE 8-BIT LITERAL | ī | | (A, MSM as destination) | 2 | | MOVE 24-BIT LITERAL | 3 | | (TAS as destination with A out-of-bounds) | 8 | | (Others as destination with A out-of-bounds) | 7 | | (TAPE mode) | u+1 | | | U+1 | | SHAP MEMORY | 10 | | (Followed by Non-concurrent N-op) | 9 | | (Followed by Memory Cycle) | 3 | | (Followed by 7 concurrent M-op*s) | 3 | | M-Instruction | | | | Clock | s | | | |----------------------------------|----------|------------|------|-------|---------|-------|--| | | | | | | - | | | | WRITE MEMORY | | | | | | | | | (Followed by non-concurrent M-op | ) | | | 4 | | | | | (Followed by Memory Cycle) | | | | 5 | | | | | (Followed by 1 concurrent M-op) | | | | 3 | | | | | (If outside base-limit & inhibit | ed) | | | 1 | | | | | READ MEMORY | | | | | | | | | (Followed by non-concurrent M-op | ) | | | 6 | | | | | (Followed by Memory cycle) | | | | 5 | | | | | (Followed by 3 concurrent M-op's | ) | | | 3 | | | | | DISPATCH LOCKOUT | Same | as | READ | MEMO | RY + | 1 | | | (Skip taken) | Same | as | READ | MEMO | RY + | 2 | | | DISPATCH WRITE | Same | | | E MEM | | | | | DISPATCH READ | | | | MEMO | | 1 | | | DISPATCH READ AND CLEAR | Same | as | READ | MEMO | RY + | 1 | | | DISPATCH PORT ABSENT | | | | 1 | | | | | COUNT FA/FL | | | | 1 | | | | | SCRATCHPAD RELATE FA | | | | 2 | | | | | EXTRACT FROM REGISTER T | | | • | 1 | | | | | SHIFT/ROTATE REGISTER T LEFT | | | | 1 | | | | | (A, TOPM, MSM as destinations) | | | | 2 | | | | | (DATA, CMND as destinations) | | | | 3 | | | | | (MBR as destination with A out-o | f-bounds | <b>;</b> ) | | 2 | | | | | SHIFT/ROTATE REGISTER X/Y L/R | | | plus | S/R | coun | t | | | SHIFT/ROTATE REGISTER XY L/R | | | • | S/R | | | | | NORMALIZE | 1 01: | | • | bits | | | | | READ/WRITE MSM | 1 000 | | | 6 | 311 1 1 | · e u | | | CALL | | | | 2 | | | | | BRANCH | | | | 2 | | | | | BIAS | | | | 1 | | | | | (Skip taken) | | | | 5 | | | | | SET CYF | | | | 1 | | | | | 4-BIT MANIPULATE | | | | 1 | | | | | (Skip taken) | | | | 2 | | | | | (BICN, FLCN, XYCN, XYST) | | | | 2 | | | | | | | ) | | ۲., | | | | # COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 | M-Instruction | Clocks | |-----------------------------------------|-----------------| | | ***** | | BIT TEST BRANCH FALSE | 1 | | (Branch taken) | 2 | | BIT TEST BRANCH TRUE | 1 | | (Branch taken) | 2 | | SKIP WHEN | 1 | | (Skip taken) | 2 | | (BICN, FLCN, XYCN, XYST) | 2 | | (BICN, FLCN, XYCN, XYST and SKIP taken) | 3 | | CLEAR REGISTER | 1 | | BIND | 3 | | Overlay M-Memory 4+(6)(# | of words moved) | | (FL = 0 initially) | 1 | | CASSETTE CONTROL | 1 | | HALT | 1 | | NO OPERATION | 1 | | Monitor | 1 | COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 #### 3.7 M-INSTRUCTION TIMING (Processor-2) The following instruction times (execute plus fetch of next M-Instruction) are given for the case where the next M-Instruction is contained in M-Memory. In general, five or six clocks are added to the basic time if the next M-Instruction is fetched from S-Memory; five clocks for the direct-connect to S-Memory case and six clocks for the port-connect case. When consecutive M-Instructions are fetched from two contiguous S-Memory locations and the second location is located on an odd 16-bit boundary, one clock is added, for the second fetch, to the five (or six) required for the first fetch. | M-Instruction | Clocks | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------| | REGISTER MOVE (MSM. SUM. DIFF as source) | 1 *<br>2 * | | (DATA as source) | 3* | | (U as source) | U* | | <pre>(M as destination with A out-of-bounds) *Add one additional clock if MSM, TOPM, A, is destination or if MBR is destination with A out-of-bounds. Add two if DATA, CMND is destination.</pre> | 1 | | SCRATCHPAD MOVE | 1* | | (MSM, SUM, DIFF as source) | 2 | | (DATA as source) | 3 | | (U as source) | u | | (MSM, TOPM, A as destination) | 2* | | (DATA+ CMND as destination) | 3* | | (MBR as destination and A out-of-bounds) | 2* | | (M as destination and A out-of-bounds) | 1 | | *Add one additional clock if previous op was WRITE into SCRATCHPAD | | | SWAP F WITH DOUBLEPAD WORD | 1 | | STORE F INTO DOUBLEPAD WORD | 1 | | LOAD F FROM DOUBLEPAD WORD | 1 | | MOVE 8-BIT LITERAL | 1 | | (A, MSM as destination) | 2 . | | M-Instruction | Clocks | |----------------------------------------------|--------------| | | | | MOVE 24-BIT LITERAL | 3 | | (TAS as destination with A out-of-bounds) | 3+ (5 or 6) | | (Others as destination with A out-of-bounds) | 2+ (5 or 6) | | (TAPE mode) | U+1 | | (First portion of instruction aligned on | | | even 16-bit S-Memory boundary) | 3 | | (First portion of instruction aligned on | | | odd 16-bit S-Memory boundary) | 2+ (5 or 6) | | SWAP (DIRECT CONNECT) | 8 * * | | SWAP (PORT CONNECT) | 9** | | WRITE (DIRECT CONNECT) | 3 ★ | | WRITE (PORT CONNECT) | 4 * | | READ (DIRECT CONNECT) | 7 | | READ (PORT CONNECT) | 8 | | *Add 4 clocks if next op is a memory cycle | | | **Add 6 clocks if next op is a memory cycle | | | COUNT FA/FL | i | | SCRATCHPAD RELATE FA | 2 | | EXTRACT FROM REGISTER T | 1 | | SHIFT/ROTATE REGISTER T LEFT | 1 | | (A, TOPM, MSM as destinations) | 2 | | (DATA, CMND as destinations) | 3 | | (MBR as destination with A out-of-bounds) | 2 | | SHIFT/ROTATE REGISTER X/Y L/R 1 plu | s S/R count | | SHIFT/ROTATE REGISTER XY L/R 1 ptu | s S/R count | | | bits shifted | | READ/WRITE MSM | . 6 | | CALL | 2 | | BRANCH | 2 | | BIAS | 1 | | (Skip taken) | 2 | | SET CYF | 1 | | 4-BIT MANIPULATE | 1 | | (Skip taken) | 2<br>2 | | (BICN, FLCN, XYCN, XYST) | | | (BICN, FLCN, XYCN, XYST and SKIP taken) | 3 | # COMPANY CONFIDENTIAL M-MEMORY PROCESSOR P.S. #1913 1747 | M-Instruction | Clocks | |-----------------------------------------|-------------------| | | | | BIT TEST BRANCH FALSE | 1 | | (Branch taken) | 2 | | BIT TEST BRANCH TRUE | 1 | | (Branch taken) | 2 | | SKIP WHEN | 1 | | (Skip taken) | 2 | | (BICN, FLCN, XYCN, XYST) | 2 | | (BICN, FLCN, XYCN, XYST and SKIP taken) | 3 | | CLEAR REGISTERS | 1 | | BIND | 3 | | OVERLAY M-MEMORY (DIRECT CONNECT) | 4+4 (# of words | | | moved)* | | OVERLAY M-MEMORY (PORT CONNECT) | 4+4.5 (# of words | | | moved)** | | (FL = 0 initially) | 1 | | *Add 2 if # of words is odd | | | **Add 2.5 if # of words is odd | | | CASSETTE CONTROL | 1 | | HALT | 1 | | NO OPERATION | 1 | | MONITOR | 1 |