| , A C MODE | . I CPU REFERENCE MANUAL | MICPU/N-4.4 | |-------------------|--------------------------|--------------------------------------------------------------| | hours of the same | Charles Simonvil | Egginsel Calo and Calo Col Col Col Col Col Col Col Col Col C | | Tropied Min | events or image | Company Private 101 | # ALSTRACT and CONTENTS The Model I CPU is described at a level of detail sufficient for all programming. p/c-n.r poge MICPU/M-4.3 1 # TABLE OF CONTENTS | Page | |-----------------------------------| | INTRODUCTION | | GENERAL CHARACTERISTICS AND STATE | | ADDRESS SPACE AND MAP4 | | ADDRESSING FROM INSTRUCTIONS | | INDIRECT ADDRESSING22 | | USE OF ADDRESSES BY INSTRUCTIONS | | FUNCTION CALLS | | PROGRAMMED OPERATORS | | SYSTEM CALLS48 | | TRAPS49 | | CPU INTERRUPTABILITY51 | | ORDINARY INSTRUCTIONS56 | | FLOATING POINT | | APPENDIX87 | p/c-n,r page MICPU/M-4.3 2 ### Introduction This is the reference manual for the Model I (M1) central processor. It is intended to be a complete and self-contained description of the characteristics of the processor from the point of view of a machine language programmer (although it is hoped that few programmers will ever have occasion to descend to machine language). Omissions and inconsistencies should be drawn to the attention of the authors. Three considerations have dominated the design of the M1. They are stated here in the hope that they will make clearer the rationale for some of the machine's characteristics. - 1) The M1 will be implemented on a somewhat modified version of a BCC microprocessor. This implies that peculiar instructuon and addressing sequencing can be used freely. No attention has been paid to the requirements which might be imposed by alternative implementation. - 2) The MI will be programmed almost entirely in SPL or FORTRAN It is therefore essential that the common constructs of these languages have efficient hardware counterparts. Most notable among them are array referencing, function calls and returns, part-word field accessing and string processing. Furthermore, it is pointless to include features which cannot be used by the compilers we are likely to write. - 3) 'The MI must have a mode in which it is essentially compatible with the SDS 940. occ MICPU/M-4 3 Rege ## General Characteristics and State The M1 is a 24-bit word-oriented twos complement machine. It has 64 instructions and a variety of addressing modes. Bits are numbered Ø to 23 with bit Ø on the left (most significant) end of the word. Both single (48-bit) and double (96-bit) precision floating point arithmetic is implemented in hardware. The <u>state</u> of the machine, by which we mean the information which must be preserved, together with the contents of memory, to permit execution of a program to be continued without disturbance, consists of 12 words of information arranged as follows, together with a context block. | Word | Bits | Name | Contents | |------|------|-------|---------------------------------------------------------------------------------------------------| | ø | ø-5 | | unused | | ø | 6-23 | P . | Program counter | | 1 | Ø-23 | A | A register | | 2 | Ø-23 | В | B register | | 3 | Ø-23 | С | C register | | 4 | Ø-23 | D | D register. C and D are used as an extension of AB for double-precision floating point arithmetic | | 5 | Ø-11 | E | Floating point exponent | | 6 | Ø-23 | x | Index register | | 7 | Ø-23 | L | Local environment register | | 8 | Ø-23 | Ģ | Global environment register | | ā | 0-23 | SR | Status register | | 9 | 23 | INSTD | Instruction terminated bit | | 9 | 22 | ov | Overflow bit | | 9 | 21 | VOT | Temporary overflow bit | | 1 | | ľ | | | p/c-n.r | page | |-----|----|-------|---------|------------------|------------------|------| | DC | | i | | | MICPU/M-4.3 | 4 | | | 9 | 2Ø | CARRY | Carry bit | | | | | 9 | 19 | PDFLAG | Permanent double | e-precision flag | | | | 9 | 18 | TDFLAG | Temporary doub1 | e-precision flag | | | | 9 | 17 | YMONT | Monitor exit tr | ap flag | | | | 9 | 16 | XUTILT | Utility exit tr | ap flag | | | | 9 | 15 | SUF | soft underflow | flag | | | • | 9 | 14 | 940M | 940 mode | | | | | 9 | 12-13 | cc | Condition code | | | | | 9 | 9-11 | PRMOD . | Permanent round | ing mode . | | | | 9 | 6-8 | TRMOD | Temporary round | ing mode | | | | 9 | 5 | FDP | Full double pre | cision flag | | | | 10 | Ø-23 | CTC | Compute time c1 | ock | | | | 11 | Ø-23 | IT | Interval timer | | | | H-3 | | | _4 | | | | The context block contains in certain fixed locations the <u>map</u> for the currently running process. #### Address Space and Map The M1 considers itself at any particular time to be running a process which is defined by a context block, which is a 2048 word block of memory, in a way which we now proceed to describe. Each process has a 256K address space; i.e. the M1 processor uses 18-bit addresses to specify memory locations. The address space has two significant characteristics: 1) it is divided into three rings as follows: addresses Ø-377777B user ring (lowest) 403000B-577777B utility ring 400000B-402777B and 600000B-777777B monitor ring (highest) | Ì | | _ | | |-----|---|-----|--| | - | P | C | | | | C | 8 | | | 200 | ~ | · - | | | - | p/c-n.r | page | |---|-------------|------| | | MICPU/M-4.3 | 5 | The rings are protected from each other according to certain rules. Every memory reference is said to have a <u>source</u>. The source for any references generated by an instruction up to and including a fetch of an indirect word is, for example, the program counter; the source for any reference generated after a fetch of an indirect word up to and including a fetch of the next indirect word is the address of the first indirect word. Every reference also has a <u>target</u>, which is the address being referenced. The following matrix defines those combinations of source and targets which are legal. | | • | | Target | | |--------|---------|------|---------|---------| | | | User | utility | Monitor | | | User | Yes | No | No | | Source | Utility | Yes | Yes | No | | | Monitor | Yes | Yes | Yes | #### To summarize: - a) References from one ring to a higher one are forbidden. - b) If indirection leads to a lower ring, it is forbidden to return to the same or a higher ring during the same instruction. This fact makes it easy, for example, for menitor routines to enforce the user's protection rules when storing into a table provided by the user: they need only do their stores indirect through an address in the user ring, and the ring protection hardware will do the checking automatically. occ now be described. p/c-m.r MICPU/M-4.3 ре**де** 6 A forbidden reference causes trap MACC. The target is passed as a parameter to this trap. The reason for putting 400000B-402777B in the monitor ring is that the operating system is expected to leave the context block in the map at 4B5 and 6B5 so that both monitor and utility can use it for storage. The monitor will then have words $\emptyset$ - 2777B of the context block available to it and protected from the utility, and the utility will have 3000B-3777B. Since the last word of the context block is at 403777B in the utility ring, the utility can extend its section of the context block with additional contiguous storage. 2) The address space is organized into 2048 (2K) word pages, and the precise collection of pages which make up the address space is specified by the map. Pages are named in a manner independent of their location in core, and the mapping hardware uses this location - independent name, together with a table called the core hash table (CHT), to determine the physical core location of a page. The page number (the top 7 bits) of every memory reference thus requires two levels of translation: from page number to location - independent name from location - independent name to physical page address The various mechanisms for performing this translation will bcc P/c-n.s | Foge | MICPU/M-4.3 | 7 Locations 200B-277B in the context block contain the map. These 128 half-words specify the contents of the corresponding 128 pages of the address space of the process; the high order half-words corresponding to even indices. Each half-word is interpreted as follows: | Bit | Name | Contents | |------|-------|----------------------------------------------------------------------------------------------------------------| | ø | MAPRO | Read-only bit. This bit is merged with the RO bit in PMT to make the read-only bit interpreted by the hardware | | 1-3 | | unused | | 4-11 | PMTI | a PMT index | The private memory table (PMT) provides enough information about each page accessible to the process to permit the hardware and the memory management to access the page. The PMT starts at location 300B in the context block. Each entry is 4 words long; the address in the context block of PMT entry i is therefore 4(i-1) + 300B. A PMT entry has the form | | Word | Bits | Name | Contents | |-----|-------|----------|----------|-----------------------------------------------------------------------------------------| | | ø | Ø-23 | UNl | First 24 bits of unique name for the page | | | 1 | Ø-23 | UN2 | Second 24 bits of unique name for the page | | | 2 | 223 | DA | Disk address of the page | | | 3 | ø | PMTRO | Read-only bit | | | 3 | 1 | PREF | Page has been referenced | | | 3 | 12 | SF | Page is scheduled for the process (i.e., in core working set and the process is active) | | The | other | bits are | not used | by hardware | P/c-n,r Page MICPU/M-4.3 - 8 Note that there is no provision for execute-only pages, since this device by itself is not sufficient to protect propreitary programs. The sub-process structure of the monitor is supposed to be used for this purpose. The central processor contains a <u>physical map</u> (PM) which has 128 registers of 11 bits each. One of the registers has the form | Bits | Name | Contents | |------|------|---------------------------------------------------------------------------------------| | Ø | EF | Empty flag | | 1 | DB | Dirty bit, set if the page has<br>been stored into since it was<br>read from the drum | | 2 | PMRO | Read-only bit | | 3-10 | PA | Physical address of page in a real core of up to 512K. | When a new process starts to run on the processor, the empty flag is set in each PM entry. Every address generated by the program must be mapped to convert it from virtual to real so that an access can be made to the real core. This is done by taking the top 7 bits of the 18-bit address and using them to select one of the 128 PM entries. If the empty flag is off, the remainder of the entry is returned. The PA field is prefixed to the last 11 bits of the virtual address to make a real address. If the access is a store and PMRO=1, the store is aborted and the PRO trap is caused. If the access is a store, PMRO= $\emptyset$ and DB $\emptyset$ , the dirty bit in the CMT entry for the page is set and DB is set to 1. | | 6 | | | |----|---|----|--| | ,) | C | C, | | pic-n.r page MICPU/M-4.3 9 If the empty flag is on, the PM entry must be <u>loaded</u>. Let its index be i. First, entry i of the map (i.e. half-word 200B+i in the context block) is fetched. If FMTI is $\emptyset$ , trap PNIM occurs. If it is not $\emptyset$ , MAPRO [i] is saved. Then the PMT entry specified by PMTI [i] is fetched. Call it entry n. If $SF[n] = \emptyset$ , trap PNIC occurs. PMTRO is saved; if PREF $[n] = \emptyset$ , it is set to 1; the UN found in PMT [n] is then looked up in the core hash table. The core hash table contains a six-word entry for each page of real core. It starts at location 400B in real core and is organized as a chained hash table. Each entry has the form | Word | Bits | <u>Name</u> | Contents | |------|-------|-------------|--------------------------------------------------------------------------| | ø | Ø-23 | UN1 | First 24 bits of unique name | | 1 | Ø-23 | UN2 | Second 24 bits of unique name | | 2 , | 2-23 | DA | Disk address of page | | 3. | Ø. | DIRTY | Dirty bit | | 3. | Ŀ | U | Unavailable bit | | 3, | 2-4 | PST | Page status | | 3, | 5-12 | CPA | Core page address. This is also implied by the index of the entry in CHT | | 3, | 16-23 | SCHED | Number of occurrences of page in loaded working sets | | 4 | 6-23 | PCLP | Free core list pointer | | 5 | Ø-5 | PL | Page lock | | 5 | 6-23 | CLP | Collision PTR | P/F-n.e pngs MICPU/M-4.3 10 A page is found by hoshing the UN as described in Mil/W-1. If the page is found, CPA and DIPTY are copied into the PM and PMRD is het to MAPPED PMTRO [n]. If (U or PST) / Ø or the page is not in CRT, trap PMIC occurs. All the trops (PRO, PNIM, PNIC) which can be generated by the mapping operation are given the virtual address being mapped as a parameter. To make sure that a particular page is not being used by the CPU, an external processor may request a scan of the physical map. When such a request is received, the PA field of all non-empty registers in the physical map is matched against the contents of cell 2455B + CPU number \*4. If any of them matches the MAB trap occurs. The message cell is set to 4B7 upon completion of the scan, regardless of the outcome. # Addressing from Instructions The machine has a rather complex addressing structure. The address calculation is performed in the same way for every instruction, and it may yield either an operand OP or an effective address Q or both. To specify this calculation it is necessary to define the format of an instruction and of an indirect address word (IAW). For an instruction | Bit | Name | 940 Mode | ·Normal Mode | |-------|------|---------------|---------------| | ø | S | Syspop bit | Part of TAG | | 1 | x | Index bit | Part of TAG | | 2 | P | Pop bit | Part of TAG | | 3-8 | OPC | Opcode · | Opcode | | 9 | I | Indirect bit | Pop bit | | 1Ø-23 | W | Address field | Address field | An IAW format depends on the mode. In 940 mode it is exactly like an instruction, except that S, P, and OPC have no significance and are ignored. Otherwise it looks like this: | OCC | | 1, | 11. | |------|------|-----------------------------------------------------------|-----| | Ø-1 | IAT | Tag field which defines the meaning the rest of the word. | of. | | 2-23 | BODY | The meaning depends on tAT | г | Since the addressing is rather complex, it seems worthwhile to explain in some detail what the various features are for, before describing them precisely. There are a number of points which influenced the design: - 1) It is necessary to be able to conveniently address a 256K (18-bit) address space, even though an instruction has only a 14-bit address field. - 2) Programs are normally written in relatively small units, each of which references some private storage of its own and some global storage. - annoyance. - 4) References to fields which occupy whole words or parts P/c-n.r Pugo MICPU/M-4,3 12 of words relative to a pointer are also common, especially in system code. - 5) It is essential to have an efficient mechanism for handling strings of 8-bit characters. If other byte sizes can also be accommodated, so much the better. - 6) We want to leave most of the 93g addressing capability in, so that it will be easy to convert 93g programs to run in normal mode. All of these goals are achieved in a fairly economical way by the addressing system of the Model I. In particular, arrays, strings, and part-word fields are handled by indirect addressing, which allows an absolute 18-bit address to be supplied. The addressing modes available in an instruction allow for immediate operands, addressing relative to the instruction word for referencing the program, and addressing relative to two base registers which are intended to reference the local storage of the subroutine (called the local environment, L) and the global storage of the whole program (called the global environment, G). They also permit indexing to be specified from the X register or from the first few cells of the local or global environment. It should be obvious by now that the addressing system is designed to be used by programs which are organized in a very definite way, i.e. into a collection of subroutines or functions (of less than 4K words each), each with local storage (of less than 2K words for scalars), and all with bcc p/c-n.r pope MICFU/M-4.3 13 access to a single global storage and communications area (of less than 16K words). The first 128 words of the local and global environments are special; this is because there are 8-bit fields in certain addresses in which the top bit specifies L or G and the remaining 7 bits address one of the first 128 words. The first 32 words are even more special, because there are 6-bit fields which address these words. With this introduction, we proceed to describe the addressing in detail, together with comments on the intended use of each feature. A reader unfamiliar with this material will find it helpful to read the text following the description of each mode first. The 3-bit TAG field of an instruction determines one of 8 addressing modes. | These are | TAG | NAME | ADDRESSING MODE | |-----------|-----|---------|------------------------------------| | 1 | Ø | D | Direct | | | 1 | I | Indirect | | | 2 | х | Indexed | | | 3 | BX | Base-index | | | 4 | PD | Pointer-displacement | | | 5 . | I.bD | Indirect-pointer-<br>displacement | | | 6 | EXD | Base-index-displacement | | | 7 | REL | Relative. This one has 6 sub-cases | | | | IM, IMX | Immediate, ordinary and indexed | | | | LR, ILR | L-relative, direct and indirect | P/c-n.r Page MICPU/M-4.3 14 Source-relative, direct and indirect Most of the modes depend on the existence of an indexing register IR, and a source register R. The IR register is not to be confused with the index register X. In fact, it is not part of the state at all: i.e. its value does not have to be preserved from one instruction to the next. The IR is used to hold the 18-bit value which will be used when an indexing operation is called for by the addressing system. It is initialized from X at the beginning of each instruction. Thereafter, it may be loaded from a word specified by a BX or BXD mode or an array indirect word (see below). The source register is initialized to the address of the word from where the instruction has been fetched (normally P). SR, ISR some addressing modes (the ones which do not have indirect in the name or I in the abbreviation) compute Q directly from the information in the central registers, the instruction and possibly one memory word used for indexing. Others (the indirect modes) compute directly the location of an indirect address word, and the contents of this word then determines how the addressing computation is to proceed. If indirect addressing is specified, only the values of the IAW address and IR affect the subsequent address computation. We will therefore confine ourselves to specifying these values which describe instruction addressing, and leave the details of indirect addressing for later treatment. bcc p/c-n.r page M1CPU/M-4.3 15 CONTENTS (N) will be used to denote the contents of the memory location with address N. Ring checking is performed with R as a source and N as target. Direct (D) ; Q + W + G; OP + CONTENTS(Q); Note: W is the address field (bits 10 - 23) of the instruction. In direct mode, the effective address is given by the 14-bit address field relative to G. This permits direct addressing of the first 16K of the global environment. The notation is LDA G' [W] Indirect (I) : IA(W + G); In indirect mode, any of the first 16K words of the global environment can be used as an IAW. The statement IA (X) implied that the indirect addressing sequence is initiated: FUNCTION IA(X); IAW + CONTENTS (X); R + X; PROCEED TO PROCESS IAW By the time it is finished, it will set the value of Q or OP. The notation is LDA \$ G'[W] Indexed (X): $Q \leftarrow W + IR$ : OP $\leftarrow$ CONTENTS(Q) Since IR is initialized to X, the effective address is the (18-bit) sum of the index register and the address field. There are two ways to look at this addressing mode: 1 - X contains a pointer and W is a displacement relative to this pointer p/c-n.r page MICPU/M-4.3 16 2 - W is an address (in the first 16K) and X is a displacement. This interpretation is unsatisfactory for programs which exceed 16K in size, and is not expected to be much used. The way to code the 930's BRU +,2 so that it will work anywhere in the address space is with indirection (see below) through a normal IAW with source-relative indexed addressing. The notation is LDA X'[W] These are three of the four addressing modes available on the 93%. The fourth, indexing and indirection, is not available in normal mode on the M1, since it was judged less useful than any of the 5 new modes; it can be obtained with IPD mode (see below) if the offset relative to X lies between -40B and 37B. Pointer-displacement (PD): T + W [16, 23]; U ← IR IF T=0 ELSE CONTENTS ( G + T IF T<200B ELSE L + T - 200B); $T \leftarrow W [10, 15];$ V ← (T IF T(40B ELSE T - 100B) $0 \leftarrow U + V$ ; OP + CONTENTS (Q); First there is some new notation here. W [10, 15] means bits 10 to 15 of W (the address field of the instruction) considered as a 24-bit number (with 18 zeros on the left, in bcc p/c-n.r pcgs MICPU/M-4.3 17 this case); In this mode the address field is divided into an 8-bit pointer address (PA) and a 6-bit signed displacement. Similar arrangements are used in several other modes; they will be explained here in detail. The top bit of the 8-bit pointer address specifies the environment (1=local, Ø-global) and the remaining 7 bits address one of the first 128 words in the local or global environments. If PA is Ø, the contents of IR, rather than of word Ø in G, is specified. It is this decoding which is specified by the argument of CONTENTS. The calculation of V specified the conversion of a 6-bit number which is to be interpreted as twos-complement into a 24-bit twos-complement number. Finally, the effective address is the sum of the pointer specified by PA and the displacement. The typical use of this mode is in addressing the nth word of a table entry given a pointer to the start of the entry. If the pointer P is in the first 128 words of either environment, then the word is loaded into A, say, by LDA P[n] which is the notation for PD addressing with pointer address P and displacement n. Another way to use this mode is to reference non-local variables in a block-structure language. Assuming that p/c-n.r page 18 MICPU/M-4.3 each block requires no more than 64 words for its storage. we proceed as follows. When a new block is entered, set up in its local environment a pointer to word 32 of the storage area for the latest incarnation of each lexicographically enclosing block. Then, if X occupies word 4 in block F, whose storage is pointed to by local environment word 12, we reference X with LDA L'[12] [443] The displacement of 44B is -28 from the pointer, which addresses word 32 of the storage for F. So the word of F's storage actually addressed is 32-28=4, as required. If a block has more than 64 words of scalars, it can be assigned several pointer words in the local environment. ## Indirect-pointer-displacement (IPD): U and V are computed as for PD mode IA (U + V); This is just indirect addressing in PD mode. All of the direct addressing modes have indirect counterparts, for obvious reasons. Notation is LDA \$P[n] Base-index (BX) : T+W [16,23]; V←IR IF T=Ø ELSE G + T IF T(200B ELSE L + T - 200B; T+W [10, 15]; IR-IR IF T-Ø ELSE CONTENTS! G + T IF T<40B FLSE L + T - 40B); IA (V); (1) p/c-n.r page MICPU/M-4.3 19 This is the array accessing mode and is written LDA B [T] where B is the base and I the index. The 8-bit and 6-bit index are both treated as local or global environment addresses, exactly like the pointer address in PD mode. The index is put into IR and the base specifies an indirect word. If an array is being accessed, B will address an IAW which has the 18-bit base address of the array and specifies indexing. The contents of IR, which was loaded from I', will thus be added to the base address of the array to determine the final 18-bit address, which is just what we require for array referencing. This is not, however. the whole story; the rest will be told when we come to consider the indirect addressing type used for arrays. #### Base-index-displacement (BXD) : $T \leftarrow W[16,23]$ : + # IF T=# ELSE CONTENTS( G + T IF T<200B ELSE L + T - 200B); $T \leftarrow W[10, 15];$ V ← (T IF T<40B ELSE T - 100B); $T \leftarrow IR;$ IR <- U + V; IA (T): This mode is similar to BX. It assumes that the base is in the IR. The field thus freed is used to provide a displacement (anything from -32 to +31) of the index. Thus to load B [I + 5] we would write EAX LDA (\$X') [1 + 5]; occ p/c-n.r page MICPU/M-4.3 20 here I is the index, 5 the displacement. See the discussion of arrays below for more details. Relative (REL): There are 6 sub-cases, depending on the first three bits of W. Thus: | Name | w[10, 12] | Description | |--------------------------------|-----------|------------------------------------------------------------------------------------------------| | L-relative (LR) | ø | U ← W [13, 23];<br>Q ← L + U;<br>OP ← CONTENTS(Q); | | Indirect L-relative (ILR) | . 1 | Compute U as above, then: | | | | IA (L + U); | | Source-relative (SR) | 2, 3 | T + W [12, 23];<br>V + (T IF T<4000B);<br>ELSE T - 10000B);<br>Q + R + V;<br>OP + CONTENTS(Q); | | Indirect source-relative (ISR) | 4, 5 | Compute V as above, then: | | | | IA (R + V) | | Immediate, indexed (IMX) | 6 | Compute U as IM, then: | | | | OP ← U + IR; | | Immediate (IM) | 7 | T + W [13, 23]; | | | | U ← (T IF T<2000B<br>ELSE T - 4000B);<br>OP ← U; | | | | Note that Q is not defined by the IM or IMX addressing modes. | p/c-n.t page MICPU/M-4.3 21 The immediate mode permits signed constants in the range -2000B to 1777B to be provided as operands without an additional memory reference. For instructions which store or which expect an operand longer than 24 hits this mode is a mistake. The action taken if it is used erroneously is a TI trap. The notation is LDA I The b-relative mode permits locations in the range $\emptyset$ to 3777B relative to the local environment to be addressed. It comes in two flavors to permit direct or indirect addressing. The address computation is similar to that for source-relative addressing, except that the sign bit of the displacement is taken to be $\emptyset$ . This mode allows 2048 words of local environment to be addressed directly. This should be more than enough for all the scalar storage of a routine. It will not, of course, be enough for the arrays, but they are all expected to be addressed by indirection, so there is no problem. Notation is LDA L'[D] or LDA SL'[D] for indirect Finally, the source-relative (or R-relative) mode permits locations up to 4000B on either side of the instruction or indirect word to be addressed. This allows routines to be placed anywhere in memory without modification and to address themselves without difficulty, as long as they are not more page MicPU/M-4:3 22 than 2048 words long. The intended programming style is small functions connected to each other only by function calls, returns and error returns; all of which are taken care of by the BLL instruction described below. This limitation should therefore not prove to be a problem. Notation is LDA R'[D] or LDA \$R' [D] for indirect It was recognized that addressing relative to the start of the routine, rather than relative to the source R, would be better in some instances. This mode was not provided because it would have required another word in the state to record the start of the program, together with machinery for keeping it updated. ## Indirect Addressing: To prevent infinite loops of the indirect mechanism, a trap II.IM will occur if indirection through more than 16 levels is attempted. There are four <u>types</u> of indirect addressing: normal, field, string, and array. The type is selected by the first two bits of the word. The intended use of each type is suggested by its name and will now be explained in detail. Normal: the IAW has the form BITS NAME CONTENTS 0-1 TYPE Ø | bcc | | | <i>p/c-n.r</i> | |-----|--------------|------|----------------------------------------| | | 2 <b>−</b> 4 | TAG | interpreted exactly like an instruc- | | | 5 | TRAP | causes trap IATRP is set | | | 6 | RELX | causes indexing for the relative modes | | | 7-23 | LWR | long address for the relative modes | | | 6-23 | LW | long word address | if TRAP is set; the IATRP trap is caused, and R is passed as its argument. Otherwise, TAG and W are interpreted as in an instruction word, with three exceptions: word address - if TAG = D, I, or X, LW is used in place of W, and G is not added. In other words, an 18-bit absolute address is supplied. - 2) if TAG = REL, IR is added to the addresses computed by L and R-relative modes if RELX is set. I.e., indexing is possible with these modes. Also, the 3-bit subtag is found in bits 7-9, thus allowing the CR, ILR, SR, and ISR offsets to be 3 bits longer. - 3) if TAG = PD or IPD, the mode is <u>read-only direct</u> (ROD) or read-only X -relative (ROX) respectively. These behave exactly like D and X modes except that an attempt to store will cause the ROIA trap with R as parameter. Normal type permits any word in the address space to be P/4-n.r Page MICPU/M-4.3 24 addressed directly. It is generally used for pointers and for the addresses of arrays. Note that although the capabilities are almost identical to those provided by an instruction address, the format is quite different. It is not possible to use an instruction as an indirect word. It also permits indexing of a L-relative or source-relative address, so that arrays in the program or the local environment can be addressed conveniently. Field: the IAW has the form 0-1 TYPE 1 3-7 SIZE size of field in bits 8-12 FB address of first bit of the field 2 SE causes sign extension of the field if set 13-23 DISP 2's complement signed displacement FIELD: Q \(\times\) IR + DISPL; U \(\times\) CONTENTS(0); OP < U [FB. FB + SIZE - 1]; $OP \leftarrow OP - 2\uparrow (24-FB)$ IF SE = 1 AND OP [FE, FB] = 1; The field which is SIZE bits in length and which starts at bit FB in word DISP + IR is referenced. Both FB and FB + SIZE + 1 must be ∠23. If they are not a TI trap will occur. If SE is set, the leftmost bit of the field (bit FB at DISP + IR) will be extended into bits Ø through 22-SIZE of the resulting operand. DISP is taken as a 2's complement number, in the range -1024 to 1023. | bcc | |-----| |-----| P/c-n.r page MICPU/M-4,3 25 The idea here is that IR contains a pointer to a table entry, and that the field descriptor (the IAW) specifics a group of bits at some definite location in the entry. Typically, the pointer might be in PTR within 32 words of L and the field descriptor in F within 128 words of G. Suppose the contents of F is FIELD 3: 6, 12 or in octal DATA 23460003B then we might write LDA F [PTR] using base-index addressing. Since PTR appears in the index field, its centents is put into IR. Then F is taken as an LAW. Since it is of type field, it accesses the word at IR + 3, which is CONTENTS (PTR:3); i.e., the fourth word of the object pointed to by PTR. Bits 6 - 12 of this object will be loaded into A. If the word addressed was 01234567B, then A will contain 47B. The field can be used as an operand in any instruction which accesses a single-word operand, regardless or whether it is a load or store. Note that fields cannot cross word boundaries. String: the IAW has the form Ø-1 TYPE 2-3 CSIZE character size: $\emptyset = 6$ bits, 1=8, 2=12, 3=24 4-5 CPOS character position in word p/c-n.r page MICPU/M-4:3 26 6-23 WA word address The character at the indicated position in the word addressed by WA is referenced. The following table defines what bits are referenced by the 16 possible combination of CSIZE and CPOS. | CSIZE/CPOS | <u>ø</u> _ | _1 | 2 | 3 | |------------|------------|-------|-------|-------| | ø | Ø-5 | 6-11 | 12-17 | 18-23 | | 1 | Ø-7 | 8-15 | 16-23 | х | | 2 | Ø-11 | 12-23 | x | x | | 3 | Ø-23 | x | . x | x | Combinations marked X in the table will cause a TI trap. The bits referenced are treated exactly like the bits selected by a field IAW. This type of indirection allows one byte in a string to be referenced. The instruction ISD increments the descriptor to point to the next byte, which may then be referenced. It has the additional feature of setting the condition code depending on whether the descriptor is equal to the next word or not. The string type and this instruction are intended to be used with four-word string descriptors. The first word points just before the first byte allocated for the string. The second word (read pointer, RP) points to the first character of the string, the third word (write pointer, WP) to the last character. The fourth word points to the last OCC P/c-m.r page MICPU/M-4.3 27 byte allocated for the string. To read the first character, increment RP with ISD, then indirect through it. The case of no characters left can be detected by the abnormal CC setting. To write a character, increment WP with ISD and then store indirect through it. Overflow of available storage can be detected by the CC setting. Array: an array descriptor is two words long. Its form is: Ø: Ø-1 TYPE 3 Ø:2 LB lower bound for IR (Ø or 1) Ø:3 ATRAP array trap bit Ø:4 LEB large element bit $\emptyset:5-6$ MULT IF LEB = $\emptyset$ multiplier for IR $\emptyset:5-10$ MULT IF LEB = 1 $\emptyset:7-23$ UB IF LEB = $\emptyset$ upper bound for IR Ø:11-23 UB IF LEB = 1 If IR(LB or IR)UB, trap ABE occurs, with R as parameter. If ATRAP=1 in IAW and the instruction is not LAX, or ATRAP=0 and the instruction is LAX, trap IATRP occurs with R as parameter. otherwise, IR $\leftarrow$ (IR - LB) $\star$ (MULT + 1); T $\leftarrow$ R + 1; NORMALIA (T); This is the most complicated of the IAW types. It is intended to accomplish the following functions connected | p/e-n.r . | Page | |-------------|------| | MICPU/M-4.3 | 28 | with array accessing: - 1) Allow of or I as lower bound - 2) Perform a bounds check on the subscript - 3) Multiply the subscript by the size of the array element, allowing for sizes up to 63: - 4) Check'that the number of subscripts supplied is the number expected (see below) - 5) Provide an 18-bit absolute base address for the array. Arrays are intended to be stored with marginal indexing. Thus, the 2 x 3 Fortran integer array A would appear as follows: A = (The three 2-word descriptors are array indirect words) The LAX instruction works just like EAX, except that it merges an I tag into XR[2,4] (leaving a normal IAW which specifies indirection) and treats the TRAP bit in an array descriptor as though it were complemented. Then to do B $\leftarrow$ A[K, L] we would write LAX A[K (BX addressing) which leaves the address of the descriptor for the Kth bcc #cae MICPU/M-4.3 29 tow in x followed by ida (\$x')[L] (BXD addressing) rΔ В The second subscript can have a constant displacement without complicating things: B + A[K, L-4] becomes iax aiki tDA (\$x')[L-4] STA If the first subscript has a displacement, there is a complication, since there is not enough room for three operands in one instruction. B + A[K-1, L] becomes EAX I LAX (\$X')[K+1] LDA (\$X')[L] STA B A singly subscripted array can be accessed without any extra instructions at all provided the subscript is a variable which can be accessed with an I field. If M is a 10-element integer array, it is allocated thus: P/2-n.r Faye MICPU/M-4.3 30 M= 3111 M (1) M (2) M (1) M (4) M (5) N (6) M (7) M (8) M (9) M (10) and N + M[J] becomes LDA M[J] STA N If the array is integer (1 word items) and bounds checking is not required, the descriptors can be changed to normal indirect words which specify indexing, and no change is required in the instructions of the program. The purpose of the peculiar behavior of LAX in the case of traps is to check that the proper number of subscripts is provided to an array. The trap bit should be set in the array descriptors except at the last level (the descriptors which point directly to the data) and clear there. # bcc p/c-n.r paye MICPU/M-4.3 31 # Use of Addresses by Instructions All instructions compute an effective address Q and/or an operand OP as described above. The use of these quantities once they have been computed, and in particular the error conditions which may arise, depend on the address type of the instruction. There are four address types: - 1) Fetch type (F) These instructions will accept any kind of address. They make use only of the 24-bit OP value. - 2) <u>Effective-address</u> type (E) These instructions make use only of the effective address Q, ignoring OP. Immediate addressing causes a TI trap if used with these instructions. Q is ring-checked with R as a source before use; if the check fails a trap MACC will occur. - These instructions make use of the effective address Q and the operand OP. If the address calculation terminated with indirection through a field or string descriptor, the FB and SIZE (for a field) or CPOS and CSIZE (for a string) define a group of bits, say bits i to j. An S type instruction puts bits 23-j+i to 23 of the word to be stored into bits i to j of the word addressed by Q, leaving the rest of this word untouched. Immediate addressing causes a TI trap and indirection through a read-only direct or read-only indexed word causes a RO trap. - 4) <u>Double-store</u> type (D) These instructions make use only of the effective address Q. DCC Programme Micro/N. 4.3 Programme Micro/N. 4.3 They trap under the name conditions as S-type instructions. Note that they are not affected by field or string indirection. Legal combinations of instructions and addresses are summarized in the following table: | | F | Æ | s | ${f C}_{i}$ | |--------------------------------|----|-----|----|-------------| | Immediate | ok | LT | TI | TI | | Indirection through ROD or ROX | ok | ok | RO | RO | | Anything else . | ok | ,ok | 0k | ok | Instructions of types S or D will give a PRO trap if Q (or Q-i for instructions which reference double (i=1) or quadruple (i=1,2,3) words) addresses a read-only page. | 100 | b course a recommendation | roge | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------| | DGG | Micro M 4,3 | 11 | | where the same that t | and the second second second second | 1 | Punction Colly A rather elaborate mechanism for calling functions and returning from them is provided in the hardware of the machine. The purpose is to include all the capabilities required by the FORTRAN and SPL languages directly in the hardware, so as to make software interpretation unnecessary. This is considered extremely important, since programs are expected to be written in small modules, and functions calls and returns are consequently expected to be very frequent. The basic features of the call instruction BLL are as follows: - The old P-counter and local environment are saved and new ones picked up. - 2) The new local environment may occupy a fixed area, or it may be allocated space at the end of a stack defined by two locations in the global environment. There is a check for stack overflow. - 3) The caller provides a list of parameter addresses. The called function specifies for each parameter whether he wants the address, the value or both copied into his local environment. If he requests copying of the value, he specifies whether it is 1, 2 or 4 words. - 4) He also specifies whether or not a parameter is an array. The calling program tells whether it is passing a scalar variable, a scalar value (stores are not legal), an array or an array element (subscripted array). These distinctions permit all the checking for proper matches of | | _ 1 | |-------------|------| | P/c-n.r. | page | | MICPU/M-4.3 | 34 | arrays with scalars required by FORTRAN to be done automatically. The case of an actual parameter which is an array element corresponding to a formal parameter which is an array requires softward handling and is trapped so that this may be accomplished. - 5) The calling program may pass labels which are relative to the start of itself. The call automatically supplies the current value of this local environment to convert them into return descriptors, and records in each local environment the start of the program so that the relative address can be converted to absolute when they are used. - 6) Provision is made for an argument to be passed in the central registers. A number of these points are somewhat subtle and cannot be properly understood unless explained in complete detail, which we now proceed to do. The BLL instruction addresses a branch descriptor, which is a two-word object with the following form: | | | | • | |------|------|-------|-----------------------------------------------------------------------| | Word | Bit | Name | Meaning | | ø | Ø-23 | NEWPW | This word looks like a weak IAW. Its effective address is computed. | | ø | 4 | SREL | c.f. REL +SR in Normal 1AW | | ø | 5 | TRAP | Causes TRP if set | | ø | 9-23 | SRW | Signed displacement if SREL is set | | ø | 6-23 | LW | Long word addresses | | 1 | ø | CLL | Call bit. The old P and L are saved if the bit is set. | | 1 | 1 | STK | The local environment is allocated from the stack if this bit is set. | | | | | p/e-n.r p250 | | | | |----|------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | DC | C | | MICPU/M-4.4 35 | | | | | | | | | | | | | 1 | , | · , | | | | | | 1 | 2 | CPA | Arguments are copied if this bit is set. | | | | | 1 | 1 | 1 11 | the state of s | | | | | 1 | 3 | CPR IF | The CPA bit in the return descriptor | | | | | | | CLL=1 | is turned on if this bit is set. | | | | | | • | | | | | | | 1 | 3 | UWSTK IF<br>CLL=Ø | Unwind stack on return. | | | | | , | ı | 1 | i , , , | | | | | 1 | 5 | FTN | 1 FORTRAN type function | | | | | i | 6-23 | E | This number determines the new L; precisely how it does so depends on STK and REL. | | | | When the BLL is executed, the first step is to compute the effective address of NEMPW (which is iW if SREL is Ø, otherwise the sign-extended SRW + the address of the NEWPW). This 18-bit number is saved in a temporary register called NEWP; after undergoing further processing it will become the new P-counter. The following steps remain to be performed: - 1) Obtain new local environment. - 2) Copy arguments. - 3) Compute return descriptor (for CALL) and save it in first two words of new local environment. - 4) Transfer control. We treat them in the order written, which is also the order in which they are performed. In describing what happens, we shall make use of a number of temporary registers or variables (such as NEWP, which was introduced above). p/s-n.e pn MICPU/M-4.3 3 րոքո Մ as the new value of L, which we call NEWL. In this case, the function being called is said to have a <u>fixed</u> local environment. Such a function cannot be recursive, and space must be allocated for its local environment at all times. On the other hand, the contents of such a fixed environment is normally preserved between function calls. A FORTRAN function has a fixed environment, for example. Since a call (CLL=1) saves the current L in the E field of the return descriptor, the return (CLL=0) handles E exactly as the call of a fixed function does. If STK=1, space for the environment is allocated on a stack. Two words are required to describe the stack, which grows toward increasing memory addresses: SP, the address of the first unused word, kept in G'[2], the third word of the global environment. SL, the address of the last word allocated for the SL, the address of the last word allocated for the stack, kept in G'[3]. If the environment is stacked, different actions are required for calls and returns. Cn a call (CLL=1), we compute SP+E. If it is SL, the STKOV trap occurs. Otherwise, NEWL+SP and SP+SP+E. In other words, E locations are taken from the top of the bce p/c-n,r MICPU/M-4.3 3/ stack. The situation before and after is shown in figure 1. On a return (CLL=\$\beta\$) what ordinarily happens if STK is set is SP<-L; NEXL<E; in other words, the old L at the time of the call (which was saved in the E field of the return descriptor, as we will see) becomes the new L, and SP is reset to the value it had before the call, which is the current L. The before and after pictures of figure 1, looked at in the opposite order, should help to clarify this. With these rules, calls can be made freely from fixed environment functions to stacked environment ones and vice-versa. The industrious reader may check the four cases. Unfortunately, if the return is to a function which is not the one which called the current one, SP is not reset correctly. This is expected to happen only as the result of a branch to a label which has been passed as a parameter (i.e. an error return). When such a parameter is passed (see below) from function Fl with L=Ll to F2 with L=L2, and the descriptor for the call has STK set, the parameter appears in F2 as a BLL descriptor with STK set, UNSTK set and L2 in E (see figure 2). The return (BLL) sees CLL=Z, STK=1, UNSTK=1 and does $SP \leftarrow E$ ; NEWL = the E field of the descriptor addressed by E This trick allows both SP and L to be set correctly while carrying only one number in the descriptor. occ MICPU/M-4.3 Page It works regardless of whether F1 and Fn have fixed or stacked environments, but requires F2 to have a stacked environment. When a label is passed to a routing which has a fixed environment, therefore, E is set to L1 and STK, REL turned off. If additional space is allocated on the stack after the call, it will not be freed when a branch is made to this label. It is believed that this deficiency is not very serious. 2) If CPA=1, arguments are copied whenever a BLL is executed. If a function has multiple results, it can turn CPR on in its descriptor. This will cause CPA to be turned on in the return descriptor, and the multiple results will be returned by the arguments - copying process when the return is executed. If CPA=0, the BLLERR (2) trap occurs. A summary of all BLLERR traps and their parameters is given in the appendix. The BLLN instruction should be used if no arguments are being passed; in this case the trap will occur if CPA=1. The address of (actual) arguments to be copied are specified in the calling program in a list of <u>actual argument words</u> (AAWs) following the BLL instruction. These have a one-to-one correspondence with a list of <u>formal arguments words</u> (FAWs) which starts at NEWP. DCC p/e-n.r pege MICPU/M-4.3 41 An argument word is formatted like an instruction. The addressing is interpreted exactly like the addressing for an instruction, but the 7-bit orcode field is treated differently, as follows. | | Bits | Name | Contents | | | |---|------|--------|------------------------------------------------------------------------------------------------------------------------|--|--| | | 3-41 | STR | <pre>(actual argument only) struc- ture 1 = variable 3'= computed scalar 2 = array element Ø = array</pre> | | | | | 3, | CADDR' | <pre>(formal'argument only) copy value 1 = copy address of</pre> | | | | | 4 | FSTR | <pre>(formal argument only) 1 = scalar Ø = array</pre> | | | | 1 | 5-8 | TYPE | <pre>type Ø = jump (actual argu-</pre> | | | | | 9 | ENDF | <pre>end flag Ø = not last argument word</pre> | | | Argument copying proceeds as follows: two pointers are initialized: next formal argument word (NFW) initialized to NEWP next actual argument word (NAW) initialized to P+1 1 = last argument word DCC. micPu/M-4.4 ppg0 42 Then FAW + CONTENTS (NFW), and FAW is treated as an instruction word for the purpose of computing its effective address, which is put into FQ. Only D or LR addressing is permitted; anything else will cause the BLLERR trap with class 4. If ENDF (FAW) = $\emptyset$ NFW $\leftarrow$ NFW + 1 and copying continues. Otherwise, copying stops. If the instruction is BLL, the BLLERR(2) occurs. If it is BLLN go to step (3). We treat NAW as we treated NFW: AAW + CONTENTS (NAW), R\*NAW and its effective address is computed. The <u>address type</u> is F if TYPE = 1 (integer) otherwise E. BLLERR (5) will occur if the address type is not satisfied. If type (AAW) = $\emptyset$ the AAW is a <u>jump</u> and its address specifies the next actual argument. Repeat from AAW $\leftarrow$ CONTENTS (NAW+Q), etc. If the AAW specified G-relative addressing with an address of Ø it is taken to refer to the central registers. If CVAL # Ø then BLIERR(5) or if TYPE> 6 or STR = Ø then BLIERR(4) will occur. Next the types are checked. If TYPE(FAW) # TYPE(AAW), the BLLERR(3) trap occurs, unless one and only one of them is unknown. FSTR and STR are checked according to the following table: | FSTR | STR | 0 | 1 | 2 | 3 | |------|-----|-------|-----------|-------|-----------| | 0 | | ок | BLLERR(3) | FTNAT | BLLERR(3) | | 1 | | FTNAT | OK | OK | OK | FTNAT means that if FTN = $\emptyset$ , BLLERR(3) occurs, otherwise the occ p/c-m.r page MICPU/M-4.4 43 FTNAT bit is set, which will inhibit the skipping of one word in step (4). The idea here is that if A(I) appears as an actual argument in FORTRAN and the corresponding formal B is dimensioned, an array descriptor for B must be computed, or if A appears as an actual argument and the formal is a scalar, the first element of the array must be found. A software routine is supposed to do this. It needs access to the descriptor for A; the extra incrementing of NAW is to leave room for the address of the descriptor. Now copying takes place. If CADDR(FAW) = 1, Q is stored at FQ as an absolute IAW, or except in the following two cases: If the AAW supplied an immediate operand or if it is stored into FQ as an IM type Normal IAW, If Q is the result of ROP or ROX addressing or STR (AAW) = 3, Q is stored as a read-only absolute (ROD) IAW. Otherwise (CADDR(FAW) = $\emptyset$ ) the value must be copied. The details of this depend on the type: If TYPE = 1 and STR(AAK) $\neq \emptyset$ , OP or the A register (in the special case) is copied to FQ. For TYPE < 6 and STR(AAW) $\neq \emptyset$ , the number of words specified above is copied from Q to FQ, or from the central registers (A, B, C and D) to FQ if appropriate. If TYPE = 3 or TYPE = 4, the floating point number addressed is examined. If it is <u>undefined</u> (see <u>Floating Point</u>) the trap UFN will occur. In case the central registers are used, storing is performed as in the floating point store MICPU/M-4.4 (STF) instruction. (Refer to <u>Floating Point</u>.) Note that TDFLAG has to be set in accordance of the TYPE as the number of words stored by STF depends on it. For TYPE = 7 and STR(AAW) \( \neq \text{0}\), the four-word string descriptor is copied. If the BLL being executed is a system call (as described later), four ring checks are done, with P as source and each of the four word addresses as target. Furthermore, the word address must be non-decreasing from one word to the next, and the COPS and CSIZE fields of the first word are copies into the others. Finally, 2 is forced into the top two bits of each word to ensure that it is a string descriptor. For TYPE = 8 and STR(AAW) $\neq \emptyset$ a label is copied as follows: The first word is made absolute, i.e. Q added to the sign-extended SRW becomes the new LW if SREL is set, then SREL is cleared. In the second word if bits 6-23 are $\emptyset$ , the word is replaced by L if STK = $\emptyset$ . NEWL + the STK and UWSTK bits, if STK = 1 The basic idea is to supply the proper context, so that the current local environment will be restored if the label is branched to. Refer to the discussion of how to unwind the stack to see why NEWL is used when STK = 1. If the label is passed by a system call, the absolute address in the first word is ring-checked. Before copying the second word CLL, STK and RDL are cleared and bits 6-23 are OCC MICPU/M-4.4 P: checked. If they are not Ø, BLLERR(6) occurs. For STR(AAW) = Ø the type is ignored. An array descriptor is also copied like a two-word scalar, except that the second word W2 is replaced by an X or ROX IAW with address equal to the effective address which results from treating W2 as an IAW. This permits an array descriptor which uses relative addressing to be passed as a parameter, since the relative address is automatically converted to absolute. If BLL is a system call, in addition two ring checks are done with P as source and both the first and last words of the array as targets. This means that if an array descriptor is passed to a higher ring, the higher ring can use it without fear of accessing storage which the calling program could not have accessed. When the address or value has been copied, ENDF (AAW) is compared with ENDF (NAW). If they differ, BLLERR(2) occurs. If both are $\emptyset$ , copying continues with $NAW \leftarrow NAW + 1; NFW \leftarrow NFW + 1;$ otherwise it stops. In the latter case NEWP + NDW + I 3) If the CLL bit is on, a return descriptor is computed and stored at NEWL. It consists of 2 words: NAW + 1 $^{\prime}$ Note that this is the return address L + 1B7 'CPR + 2B7 \*STK i.e., the old local environment, with STK on if it is on in the descriptor, and CPA on if CPR is on in the call' descriptor. B/t-nr page MICPU/M-4.4 46 4) Set L to NEWL, P to NEWP, and continue execution. If the FTN bit is set, skip one word unless the FTNAT flag is on. The instruction skipped presumably will contain a subroutine call to take care of the special cases in FORTRAN mentioned earlier. In order to state precisely and concisely how this instruction works and to describe the details of ring-checking, an SPL program is presented in the Appendix which duplicates its functioning. This program uses some special functions. (Those not mentioned here refer to fields of functions defined elsewhere in this document). - 1) The construction \$X \in implies a ringcheck with R as source and X as target. As the access is a store, the trap PRO may also occur. - 2) RINGCHECK(X) performs a ring check with R as source and X as target. If the check fails, trap MACC will occur. - 3) RING(X) produces a number depending on the ring which contains X, say - 1 if X is in the user ring 2 if X is in the utility ring 3 if X is in the monitor ring - 4) MENTER(), MEXIT() and INTERRUPT() designate the places where the actions described under "CPU Interruptability" are taken. - 5) EA(X) initiates the effective address calculation similar to IA(X), but the format of CONTENTS(X) is like an instruction (or an AAW) rather than an IAW. p'c-n.r MICPU/M-4.3 page 47 ### Programmed Operators If the P bit of an instruction is 1, it is interpreted as a rather peculiar kind of subroutine call rather than an ordinary machine instruction. Execution proceeds as follows: the OPC field of the instruction is put into IR a BLL \$G' [Ø] is executed Presumably word Ø of G will contain the address of a transfer vector. If desired, it may contain an array descriptor which limits the number of programmed operators and supplies a multiplier of 2. There is one additional feature: BLL will initialize NAW to P, rather than to P + 1, so it will use the instruction word as the first AAW. STR, TYPE and ENDF will be taken from the corresponding bit positions of the first FAW. p/t-n.r MICPU/M-4.4 48 ### System Calls Two versions of the OPR instruction provide protected entry points into the system. The MCALL instruction works as follows: 8 bits provided by the OPR are put into IR a BLL \$BA is executed, with BA = 604000B when the BLL is completed, G ← NEWG, where NEWG = 600000B. The intention is that 604000B should contain an array descriptor with $LB = \emptyset$ UB = total number of defined system calls MULT = 2 which points to an array of BLL descriptors for the various protected entry points. Note that if the system call involves a ring crossing, where the called system is in a <u>higher</u> ring than the caller, G is saved in NEWG[14]. G is restored from G'[14] by <u>ary PLL</u> (BLIN, POP etc.) which crosses the ring boundary into a lower ring. For calls into the utility the UCALL version of OPR works the same way, except that BA = 403016B and NEWG = 403000B. Note that this is the beginning of the utility ring. Variants of these OPRs exist which execute a BLLN instead of a BLL. (MCALN, UCALN) The PDFLAG, TDFLAG bits in the status register are cleared by both MCALLs and UCALLs. MCALLs also set the LOCKED bit of the CPU as described bcc p/c-n.r MICPU/M-4.4 49 under "CPU interruptability." #### Traps A machine trap is a forced transfer of control which may occur as a result of a variety of untoward events which may arise during the execution of a program. It does not involve a switch to a new process. A trap may be fixed or ring-dependent. All fixed traps save the state in the 10 words starting at 602752B (i.e., at the end of the monitor portion of the context block). They then set G to 6000000 and do X < n; BRU 604002B, where n is the trap number. They all have a one word parameter which is put into the A register after the state is stored. The value of the parameter depends on the trap. Like MCALL-s, fixed traps also clear PDFLAG, TDFLAG, M940 and set the LOCKED bit. A table of all fixed traps is given in the appendix. Each one is described more fully in its proper place in the manual. The ring-dependent traps differ in that they send control to a location determined by the ring that P is in. They store P and the parameter at G'[4] and G'[5] respectively and then clear the 940M bit in the status register and do IR $\leftarrow$ n; BRU \$G'[6]. In 940 mode, if the S bit (bit $\emptyset$ ) of an instruction and the P bit (bit 2) are set, the instruction is called a SYSPOP. MICPU/M-4.4 50 The first 10 words of the state are stored starting at L[3], then A is set to the effective address of the instruction, clear M940 and do $X \leftarrow OPC$ , BRU 1'[2]. bcc p/c-n.r proce MICPU/M-4.3 51 #### CPU Interruptability The CPU described in this manual is expected to run as part of a system which includes, among other things, - Several physical CPUs, which are identical except for a number called the <u>CPU number</u> attached to each CPU. The CPUs are numbered from \$\mathscr{g}\$ to n-1 where n is the number of CPUs. - 2) A separate processor called the <u>uscheduler</u> which is responsible for allocating CPUs to processes. The uscheduler also has facilities for causing the CPU to operate in a single-step mode, in which it stores the state, waits and then reloads it after each instruction execution, and for telling the CPU to stop execution at once (crash). - 3) A protect mechanism which allows the various processors in the system to be interlocked or synchronized. There are four protect lines, any of which may be seized by any processor. A line may be seized by only one processor at a time; anyone else attempting to seize the line is held up until the current owner lets it go. This section describes the behavior of the CPU with respect to - 1) A STROBE signal, which the $\mu$ scheduler sends when the CPU is to switch processes - 2) The single-step and crash signals - 3) Protect 4, which is used to interlock the CPUs, keeping more than one from being in a <u>locked</u> state. - 4) The timer trap, which occurs when the interval timer D/c-nr Page MICPU/M-4.3 52 in the state becomes negative - 5) The XMON and XUTIL traps - 6) Initialization The relevant information is: - a) Some information in the state - 1) The ring in which the P-counter is contained - 2) The XMON trap bit in SR - 3) The XUTIL trap bit in SR - 4) The sign bit of the interval timer, which we call TO - Some flip-flops in the microprocessor which are not part of the CPU state - 1) STROBE, which may be set by another microprocessor, normally the uscheduler - 2) STEP, which may be set by some external device to make the CPU operate in single-step mode. - 3) LOCKED, which is not accessible to external devices - ALARM, which is set when a system crash is impending - c) The state of protect 4, which will be called CPUPRO - d) A location in absolute core called CPUWAIT which is used to keep the CPU idle after the system has crashed or between STEPs. pic-ne MICPU/M-4.3 A. Idle State When it is initialized (by setting the O register in the microprocessor to Ø) the CPU goes into idle state. IDLE: Clear map scan request; GOTO IDLE IF NOT STEDEE: Clear STROBE. PWAIT: T + contents of absolute cell (6 + CPU number) (T is the process' PRT index) Goto PWAIT if $T = \emptyset$ ; Clear absolute cell (6 + CPU number); Clear LOCKED; Clear the map; Find the page with the name in (T) and (T+1) Take it as a context block and load the state from location 2764B-2777B in it (called the SAVE area) . If the page is not found in CHT, send a STROBE2 to the µscheduler with a message 4B7 in absolute cell 2454B + C2U number \*4 then do like ABORT. Start executing instructions at the location given by the P-counter; The CPU returns to the idle state whenever it dumps the state of a process. B. Interruption of program execution At the start of every instruction, the truth of any of the following conditions will stop execution and cause the indicated action to be taken. The conditions are treated in the order in which they are listed. | b/c-fi.r | page | 54 | 54 - 2) NOT LOCKED AND STROBE: dump the state into the SAVE area, send a RETURN message to the µscheduler and go into idle state. - 3) STEP OR ALARM: dump the state into the SAVE area; clear STEP. Clear the wait location (23B + CPU number) and wait until it becomes 12343210B; then reload the state from the SAVE area and proceed. At every step of indirection, every start of an instruction which is the target of EXU, every parameter of a BLL and in all other places where the CPU might be held up for more than a few microscoonds, (MVB, MVS, CPS), conditions 1 and 2 are tested and their indicated actions taken. C. Setting the bits $\tt XMON$ and $\tt XUTIL$ are part of SR and may be set or cleared with SRS, LOADS or XSA. LOCKED is set by MCALL or fixed trap. It can also be set by SLOK. It is cleared by any BLL or LOADS which leaves the monitor ring (BLL, here, includes all variants: UCALL, MCALL, POP), and can also be cleared by RLOK. TO can be changed by loading a state from the SAVE area or by the OPR to set the interval timer. D. The X traps At every BLL or LOADS a check is made for transition into a bec %-nr page MICPU/M-4.3 55 lower ring. If there is a transition from monitor to utility or user rings, the XMON trap is caused if the XMONT bit is set. Then if there is a transition from utility to user ring, the XUTIL trap is caused if the XUTILT bit is set. E. The CPUPRO signat This protect is seized automatically at each point where LOCKED is set and cleared at each point where LOCKED is cleared. The programmer can set it himself with the PRO operate, but this is probably unwise. P/c-n.r Pcgs MICPU/M-4.3 56 Ordinary Instructions This scation contains a complete description of the behavior of the machine when interpreting an instruction word, with the following exceptions: instructions with $P \approx 1$ are described under "Programmed Operators" the BLL instruction is described under "Function Calls" the floating point instructions are treated in a separate section. effective address computation for all instructions is described under "Addressing" Each instruction is specified in terms of its operands, its effect on the state of memory of the running process, and any unusual traps it may cause. Traps which are caused by the addressing system are the same for all instructions and are not considered. Traps caused by the map are the same except for the read-only trap. Its occurrence depends on whether the instruction attempts to modify memory; this should be obvious from the instruction description and will not be further mentioned. The address type is S or D for instructions which modify memory. Part of the state is a 2-bit condition-code. This code is set by the PESULT of most instructions as follows: ø if RESULT ( ø 1 if RESULT = Ø 2 if RESULT ( Ø DCC д/c-л.r MICPU/M-4'.3 реде The RESULT is indicated in the description of each instruction. Unless some other change in P is indicated, all instructions end with $P' \leftarrow P' + 1$ The INSTD bit in the status register is set to g at the end of every instruction, except for LOADS. The address type of the instruction is indicated for every instruction, e.g., LDA . (F) In the description seme special notation is used: STORE(X, Y) stores X in the memory location addressed by Y. The storing includes some special logic for (S) type instructions if a field or character is specified as operand (refer to Use of Addresses by Instructions); ABS(T) is the absolute value of T. ABS(T) = 4B7. Page MICPU/M-4.3 58 Summary of Abbreviations AR A register B register C register (used only for double-precision floating- D register point and quadruple loads and stores) X register Program counter Local environment register Global environment register Condition code, equivalent to RESULT: RESULT < Ø $CC = \emptyset$ RESULT = Ø CC = 1 CC = 2RESULT > Ø SR Status register OV = SR[22] Overflow bit TOV = SR[21] Temporary overflow bit CARRY = SR[20]Carry bit PDFIAG = SR[19] Permanent double-precision flag. Used to set TDFLAG after STF, STD or FCP TDFLAG = SR[18] Temporary double-precision flag. Makes all floating-point instructions double- precision. MICPU/M-4,3 page 59 Data Transfer Instructions (12) LDA (F) Load A register AR + OP; RESULT + AR; LDB (F) Load B register BR + OP; RESULT \* BR; LDX (F) Load X register XR + OP; CC is unchagned LDD (E) Load double AR + CONTENTS (Q); BR + CONTENTS (Q+1); CR + CONTENTS (Q+2) & BR + CONTENTS (Q+3) IF TDFLAG-1 RESULT + AR; EAX (E) Effective address to X XR ← 0: CC is unchanged LAX (E) Load array index $XR \leftarrow Q$ OR 4B6 (sets TAG to 2 for indirection) cc is unchanged Treats bit ATRAP in an array descriptor opposite to all other instructions INX (F) Load negative to X XR + -OP; two-s complement negation CC is unchanged ``` )CC p/c-n.t MICPU/M-4.3 ``` STA (S) Store A register STORE(AR, Q); CC is unchanged STB (S) Store B register STORE(BR,Q); CC is unchanged STORE (XR, Q); CC is unchanged STX (S) Store X register XMA (S) Exchange memory and A TEMP AR; AR OP; STORE(TEMP,Q); RESULT AR; # bcc page 60 F/c-n.r MICPU/M-4.3 61 B. Integer Arithmetic Instructions (10) ADD (F) Add memory to A AR + AR + OP; (two's complement) CARRY $\leftarrow$ carry from bit Ø of adder, i.e., set if the sum of AR and OP taken as unsigned 24-bit integers, is $\geq 2^{24}$ , and cleared otherwise; TOV • 1 if the add causes overflow, i.e., if AR and OP have the same sign but the sum has a different sign, else Ø; ov ← ov or ToV; RESULT + AR; SUB (F) Subtract memory from A Proceed exactly like ADD except that (-OP) replaces OP. This is a two's complement negate, i.e., (NOT OP + 1) ADC (F) Add memory and CARRY to A ov ← Ø; AR + AR + OP + CARRY; Then proceed exactly like ADD SUC (F) Subtract memory from A + CARRY ov ← Ø . AR + AR + CARRY + (NOT OP) Then proceed exactly like ADD MIN (S) Memory increment RESULT + AR + OP + 1; STORE (RESULT, Q): occ p/c-n.r page MICPU/M-4.3 62 MDC (S) Memory decrement RESULT + AR + OP -1; STORE (RESULT,Q) ADM (S) Add to memory RESULT + AR + OP + AR; STORE (RESULT, Q) ADX (F) Add to X XR - XR + OP CC is unchanged MUL (F) Multiply memory and A TOV + Ø; TOV $\leftarrow$ OV $\leftarrow$ 1 IF OP = AR = 40000000B; PROD $\leftarrow$ AR \* OP; as two's complement numbers, yielding a 47-bit two's complement result $AR[\emptyset,23] \leftarrow PROD[\emptyset,23];$ BR[Ø,22] + PROD[24,46]; $BR[23] \leftarrow \emptyset$ ; RESULT + (AR OR (BR RSH 1)); The product, consisting of a sign bit and 46 magnitude bits, is left-justified in the AB registers. If integers are being multipized, and ASHD -1 is required to obtain the integer product in B. bcc 6 p/c-n.r page MICPU/M-4.3 G3 DIV (F) Divide memory into AB TEMP + OP: TOV + Ø; DIVIDEND - AB[0,46]; QUOTIENT + DIVIDEND/TEMP; a 47 bit two's-complement integer treating both operands as fractions in the range -l\(\frac{1}{2}\), and obtaining a quotient with 23 fraction bits TOV $\leftarrow$ OV $\leftarrow$ 1 and proceed to next instruction unless -1 $\leq$ QUOTIENT $\leq$ 1 AR + OUOTJENT; TEMP ← QUOTIENT \* TEMP: yielding a 47-bit product as for multiply BR + (DIVIDEND - TEMP); this is the remainder RESULT + AR; The quoteint of the 47-bit dividend and the 24-bit divisor, both taken as signed two's complement fractions, is put into A and the remainder into B. Overflow occurs if the dividend is larger than the divisor, since the quotient cannot be represented as a fraction; in this case, the central registers are unaltered. To divide an integer in A by one in memory, do ASHD -23 first. p/c-n.r page MICPU/M-4.3 64 C. Test' Instructions (5) ICP (F) Integer compare RESULT + AR - OP; CPZ (F) Compare with zero RESULT + OP; CMZ (F) Compare A and memory with zero RESULT + AR AMD OP; The following two instructions operate on string descriptors, which are pairs of indirect address words of type string. The intended interpretation is that the first points to the first character of the string, the second to the last character. ISD (E) Increment string descriptor TEMP ← CONTENTS(Q): CSIZE < TEMP[2,3]; CPOS $\leftarrow$ TEMP[4,5]); RESULT + TEMP - CONTENTS (Q + 1); Proceed to next instruction if RESULT = $\emptyset$ ; IF CPOS + CSIZE <3 DO; CPOS < CPOS+1; ELSE DO; CPOS ← 0; TEMP ← TEMP + 1. ENDIF; $TEMP[2,3] \leftarrow CSIZE; TEMP[4,5] \leftarrow CPOS;$ STORE (TEMP, Q); bcc p/c-nr MICPU/M-4.3 65 If the string is empty (the two IAWs are equal) the instruction sets CC to I and exits. Otherwise it sets CC to $\emptyset$ or 2, and increments the first IAW by one character position in the string. DSD (E) Decrement string descriptor TEMP + CONTENTS (Q+1); CSIZE + TEMF[2,3]; CPOS + TEMP[4,5]; RESULT + TEMP - CONTENTS (Q); Proceed to next instruction if RESULT = Ø; IF CPOS > Ø DO; CPOS + CPOS -1; ELSE DO; CPOS ← 3-CSIZE; TEMP ← TEMP -1; ENDIF: TEMP[2,3] '+ CSIZE: TEMP[4',5] '+ CPOS: : STORE (TEMP, Q+1); The idea is the same as for ISD, but the second IAW is decremented by one character position. D. Logical instructions (3) ETR (F) And A and memory AR - AR AND OP; 'RESULT + AR; IOR (F) Or A and memory AR + AR OR OP; RESULT ← AR; occ P/4-n.r Page 66 EOR (F) Exclusive or A and memory AR + AR EOR OP; RESULT + AR: E. Shift Instructions (6) All shift instructions interpret the absolute value of OP MOD 64 as the number of shifts to be done. The sign of OP specifies the direction: positive for left shifts, negative for right. SHIFTC & ALS(OP MOD 64); right shift as specified IF OP < Ø ELSE left shift as specified; RESULT ← AR; ASHD (F) Arithmetic shift double (A and B registers) A and B taken as a single 48-bit register are shifted. On a right shift, the original sign bit is copied into vacated bit positions. On a left shift, $OV \leftarrow 1$ if any of the bits shifted out differ from the final sign of A. TOV is set to 1 when OV is set, otherwise it is set to $\emptyset$ . ASHA (F) Arithmetic shift A Identical to ASHD except that only AR is shifted LSHD (F) Logical shift double A and B taken as a single 48-bit register are shifted. Vacated bit positions are filled with zeros. bcc MTCPU/M-4.3 67 LSHA (F) Logical shift A Identical to LSHD except that only AR is shifted CYD (F) Cycle double A and B taken as a single 48-bit register are cycled. I.e., they are shifted, but bits which are shifted out one end fill the vacated positions at the other end CYA (F) Cycle A Identical to CYD except that only AR is cycled F. Branch instructions (10) BRU (E) Branch unconditionally P ← Q: cc is unchanged Six instructions test the condition code BLT (E) Branch on less than $$P \leftarrow Q$$ IF $CC = \emptyset$ ; (RESULT $\langle \emptyset$ ) CC is unchanged BLE (E) Branch on less than or equal $$P \leftarrow Q$$ IF $CC = \emptyset$ OR $CC = I$ ; (RESULT $\leq \emptyset$ ) cc is unchanged BEQ (E) Branch on equal $$P \leftarrow Q$$ IF CC = I; (RESULT = $\emptyset$ ) CC is unchanged p/c-n.r page 6.0 MICHUM M. 4. T BNE (E) Branch on not equal $P \leftarrow Q$ IF $CC \neq 1$ ; (RESULT $\neq \emptyset$ ) CC is unchanged BGE (E) Branch on greater than or equal P + Q IF CC = 1 or CC = 2; (RESULT $\geq \emptyset$ ) CC is unchanged EGT (E) Branch on greater than $P \leftarrow Q$ IF CC = 2; (RESULT > $\emptyset$ ) CC is unchanged Two branch instructions affect the X register . BRX (E) Branch on index $XR \leftarrow XR + 1$ : $P \leftarrow Q \text{ IF } XR < \emptyset$ ; CC is unchanged BSX (E) Branch and set X $XR \leftarrow P + 1$ : P + 0; CC is unchanged BLL (E) Branch and load L is described elsewhere G. Miscellaneous instructions (5) HLT (F) Halt Always causes the TI trap pic-nir mit with 4.3 EXU (E) Execute Initializes IR $\leftarrow$ XR & R $\leftarrow$ Q, then interprets CONTENTS(Q) as an instruction and executes it. EAC (E) Effective address computation This instruction computes the effective address of CONTENTS(Q) interpreted as an instruction word. Similar to EXU, IR and R are initialized to XR and Q respectively. The results of the computation are given in registers as follows: $XR[\emptyset,5] \leftarrow RESULT \leftarrow 1 \& AR \leftarrow OP$ if the address is Immediate $XR[\emptyset,5] \leftarrow RESULT \leftarrow 2 \& XR[6,23] \leftarrow Q$ if the address is ROD or ROX read only $XR[\emptyset,5] \leftarrow RESULT \leftarrow 3 \& XR[6,23] \leftarrow 0 \& AR \leftarrow MASK &$ BR + SHIFT if the address refers to a field or or character. MASK has bits (24-SIZE), 23 on, the rest off. SHIFT equals to 24-(FB + SIZE) $XR[\emptyset,5] \leftarrow RESULT \leftarrow \emptyset \& XR[6,23] \leftarrow Q$ in all other cases. Note that Q - whenever given - is ring checked against R in the final phase of the address calculation. (refer to Addressing from Instructions) p/c-n,r page Michil/M -1,1 /0 SRS (F) set or reset status bits The operand is used to set or reset the status register in the state in the following way: SR \* SR OR OP IF (OP AND 1) = 1 ELSE SR AND NOT OP; TSB (F) Test status bits RESULT + SR AND OP; I.e., 1 bits in the operand select bits of SR. The condition code is set depending on whether all the selected bits are $\emptyset$ or not. #### H. OPR (F) Operate (1) If the operand is negative, the instruction is a system call. Bits 14-15 in the absolute value of the operand select one of four alternatives: Ø UCALL - 1 UCALN - 2 MCALL - 3 MCALN Bits 16-23 in the absolute value is the address for the system call. (as described in a separate section) If the operand is positive, it is decoded to determine what is to be done: p/c-n.r bcc pege MICHU/M-4.3 11 CAB Copy A to B BR + AR; XAB Exchange A and B T + AR; AR + RESULT + BR; BR + T; CBA Copy B to A AR + RESULT + BR: CBX Copy B to X XR + BR; XXB Exchange B and X T + BR; BR + XR; XR + T; CXB Copy X to B BR + XR; CAX Copy A to X XR + AR! XXA Exchange X and A $T \leftarrow AR$ ; $AR \leftarrow RESULT \leftarrow XR$ ; $XR \leftarrow T$ ; CXA Copy X to A RESULT + AR + XR; CNA Negate A AR + RESULT + -AR; CNX Negate X $XR \leftarrow -XR$ ; ZOA Clear A $AR \leftarrow RESULT \leftarrow \emptyset$ ; ZAB Clear AB $AR \leftarrow BR \leftarrow ER \leftarrow \emptyset$ ; ZOB Clear B BR $\leftarrow \emptyset$ : CGA Copy G to A AR - RESULT - G; XGA Exchange G and A $T \leftarrow AR$ ; $AR \leftarrow RESULT \leftarrow G$ ; $G \leftarrow T$ ; CIA Copy L to A AR <- RESULT + L; XLA Exchange L and A $T \leftarrow AR$ ; $AR \leftarrow RESULT \leftarrow L$ ; $L \leftarrow T$ CSA Copy SR to A AR - RESULT - SR; XSA Exchange SR and A T + AR; AR + RESULT + SR; SR + T; CTA Copy interval A + RESULT + IT: Timer to A CCA Copy Compute A < RESULT < CTC; time clock to A NOP No operation bec р/с-д.r Місти/м 4.1 72 WR Move block The block of AR words starting at XR is moved to the AR words starting at BR. The words are moved one at a time, and the registers are updated after each word is moved to reflect the number of words remaining to be moved. This instruction is interruptable. The move is done in such a way that no word is overwritten until it has been moved. MVC Move constant XR is stored into the AR words starting at BR. This instruction is interruptable. MVS Move string The string of AR bytes starting at the byte specified by BR taken as a string IAW is moved to the AR bytes starting at the byte specified by XR taken as a string IAW. The bytes are moved one at a time, and the registers are updated after each byte is moved to reflect the number of bytes remaining to be moved. If the source and target strings overlap, the move is done in such a way that no character is overwritten until it has been moved. If the strings do not overlap, after execution BR and XR will always point to the first characters after the source and target strings respectively. This instruction is interruptable. CPS Compare string The string of AR bytes starting at the byte specified by BR taken as a string IAW is compared with the AR bytes starting at the byte specified by XR. RESULT is set to indicate whether the first string is smaller, equal to, or greater than the second. The registers are updated every time a byte is compared. This instruction is interruptable CLS Compute length of string AR and BR are taken as string IAWs. The number of bytes in the string starting at the byte specified by AR and ending at the byte specified by BR, -1 is put into AR. The CSIZE field of BR is used to determine the byte size. RESULT - AR; ASP Add to string pointer AR is taken as a string IAW. Into XR is put a string IAW which points to the XRth byte beyond the one pointed to by AR. LLT Locate leading transition The bit number (counting from Ø on the left) of the leftmost bit in AB which differs from the sign bit of A is put into XR. If no bits differ, Ø is put into XR. RESULT + XR: COB Count one bits The number of one bits in the A and B registers is put into XR. RESULT ← XR; LOADS Load state Loads the first 10 words of the state (hot including the P/e-n.r page MICPU/M-4.3 74 compute time clock or the interval timer) from the 10 words addressed by X. A ring trap will occur if the new P is in a higher ring than the current P. This instruction does not clear the INSTD bit. An XMON or XUTIL trap may occur if the new P is in a lower ring than the current P and the XMONT or XUTILT bits are set in the current SR as described under "CPU Interruptability." STORS Store state Stores the first 10 words of the state into the 10 words, addressed by X, but does not store P and X; the corresponding locations are left unchanged. ASC load string constant The word addressed by X is fetched and used to form a 4-word string constant in A, B, C and D as follows: TEMP <- CONTENTS(XR); CSIZE $\leftarrow$ TEMP[2,3]; CPOS $\leftarrow$ TEMP[4,5]; AR + BR + 4B7 + CSIZE \* 4B6 + 011.11 (3 - CSIZE) \*. 1B6 + XR; CR < DR < 487. + CSIZE \* 486 + CPOS \* 136 + XR + TEMP[6,23]; The following OPRs are privileged. If P < 600000, the TI trap will occur. SLOK Set CPU lock RLOK Reset CPU lock ALD Absolute load, A + bcc P/e-n.r page MICPU/M-4.3 75 Loads A with the contents of the core location whose absolute address (i.e., unmapped address) is contained in X. AST absolute store A stores A into the core location whose absolute address is contained in X. AAX Absolute address to X Loads X with the absolute address corresponding to the virtual address in X. Bit Ø is set if the physical map entry was empty. Bit 3 is set if PMRO was on in the physical map entry, bit 2 is set if bit 3 is set or the dirty bit was clear. Attempts to set PROi if $AR[2\emptyset+i]$ is on. If all the selected PROs are set successfully $CC \leftarrow \emptyset$ ; if none are, $CC \leftarrow 1$ . These are the only possibilities. UNPRO Unprotect Clears PROI if AR[2f:i] is set ATTN Attention Sends a Strobe signal to microprocessor i if AR[16+i] is set. This OPR initiates a switch-processes sequence. The state of the machine is dumped at the SAVE area (602764B). The Interval Timer, shifted 7 to the right so that the least significant bit counts milliseconds, is stored into the MCT field (8,0.7) of the process' PRT entry. bec p/c-n.r page MtCPU/M 4.3 7G The µscheduler is called with bits $\emptyset_15$ in A as an opcode, the CPU is put into the IDLE state. CMAP Sets all EF empty flags in the map to 1 CMAPS Clears the maps of both CPUs in the system CAT Copy A to interval timer IT + A: CAC Copy A to compute time clock CTC + A; RUN Read Unique Name A unique name is read from the unique name generator and put into AB. BR ← low order bits of unique name; AR ← high order bits of unique name; /c-n.r 1410391/14 4,3 77 ## Ploating Point ### A. Number Representation A 48-bit single precision floating point datum represents a rational number in the following way: 1) Positive numbers | | Ø | 1 11 | 12 47 | | |----|---|------|-------|--| | x: | ø | M | Ŋ | | M is the biased exponent E: positive number $X = N * 2^{(E-35)}$ where 2 $^{35}$ $\leq$ N $\leq$ 2 $^{36}$ -1 and -2 $^{10}$ $\leq$ E $\leq$ 2 $^{10}$ -1 E. g. + 1.% is represented as Largest number is $2^{2^{10}} * (1 - 2^{-36})$ : Smallest positive number is (except for unnormalized numbers, see below) $2^{-2}$ : ### 2) Negative numbers The sign bit (bit Ø) indicates that the number is p/c-n.r page MICPU/M-4.3 78 negative, N is given in two's complement form: negative number $X = (N - 2^{36}) + 2^{(E-35)}$ , $1 \le N \le 2^{35}$ Ø 1 11 12 47 -1.9: 1 10 Ø 1.00 Ø Lowest negative number is $-2^{210} * (1 - 2^{-36})$ | Ø | 1 | 11 | 12 | 47 | |---|----|----|------|----| | 1 | 11 | 1 | g.gg | 1 | Maximum negative number is -2-210 | Ø | 1 | 11 | 12 | 47 | |---|----|----|------|----| | 1 | øø | Ø | 1.ØØ | ø | 3) Zero: 4) Un-normalized numbers The $\underline{\text{only}}$ un-normalized numbers allowed are these: | Ş | 7 1 | 11 | 12 | 47 | | | | | | |-----|------|----|----|----|-----|---|---|---|-----| | [ 9 | g ØØ | ø | N | , | , 1 | ۷ | N | ۷ | 235 | and their negatives, i.e., $|x| \le 2^{-2^{10}}$ . Note that $\pm 2^{-2^{10}}$ are both normalized and un-normalized 5) Infinity X: The symbol - - is treated as the single point at bee p/c=n.r page 7's infinity in the one-point (projective) closure of the reals. Operations on - $\infty$ are summarized in the Appendix. 6) Undefined floating point numbers Data of the form | | Ø | 1 | 11 | 12 | 4 | • | |----|---|---|----|----|---|---| | θ: | Ø | М | | | N | | with $\emptyset < M \approx \emptyset \le N \le 2^{35} - 1$ , and their negatives are <u>not</u> floating point numbers. If such a number appears as an operand for any floating point operation, the trap UFN will occur. - B. Algebraic Closure Properties of Normalized Numbers Numbers of the form A.1, A.2 and A.3 are normalized numbers. (n.n's) - 1) 'If X is an n.n., so is -X. - 2) If X is an n.n not zero nor $\pm 2^{-2^{10}}$ , so is 1.0/X. The smallest positive n.n. whose reciprocal is an n.n. is $2^{-2^{10}}$ (1 + $2^{-35}$ ). - C. Double Precision The 96-bit double precision data have an additional 48 fraction bits. For example a DP positive number: | ø 1 | L | 11 12 | | 47 | |-----|---|-------|---|------------| | Ø | М | | N | | | 48 | | | | <b>9</b> 5 | | | | | | | N' p/c-n.r MICPU/M-4.3 80 represents X = (N + N' \* 2-48) \* 2(E-35), $\emptyset \le N' \le 2^{48}$ -1 D. Floating Point Instructions (8) and OPRs All floating operations have single (SP) and double (DP) precision variants, bit TDFLAG in SR selecting the one to be used. Bit PDFLAG is used to set TDFLAG after a compare (FCP) or store (STF). Floating operations set CC to indicate if the result is less or greater than or equal to Ø. (STF and FIX leave CC unchanged) PID (E) Floating load An SP or DP floating point number starting at Q is copied into the floating point accumulator. (The A, B, C, D and E central registers) STF (D) Floating store SP: The floating point accumulator is rounded at bit 35 of the fraction and copied to (Q) and (Q $^{\pm}$ 1). DP: Four words are copied from FA to the locations starting at Q. A double floating store causes no rounding if the FDP bit in SR is set. Otherwise it rounds at bit 71 of the fraction and zeroes the last labits. The FDP bit thus determines whether DP numbers are stored with 72 or 84 bits of fraction. Overflow may occur because of the rounding. In all cases bcc p/c-n.r MICIU/M 4.3 97 (i.e., r[84], since when we say 'bit 83 of the fraction' we don't count the sign bit) in accordance with the rounding mode in force, is assigned to the floating point accumulator. See the discussion of rounding below for details. Both overflow and underflow may occur. FSB (E) Floating subtract Identical to addition except that the negative of the second operand is taken first. This cannot cause any abnormal conditions. FMP (E) Floating multiply SP: The accumulator is rounded to single precision, then the two 36-bit fractions are multiplied to yield a 72-bit result. The exponent which goes with the result is the sum of the exponents of the operands plus one, to correct for the placement of the binary point in the product. The 72-bit fraction is shifted left if required for normalization. No rounding is required since the accumulator can hold this entire product. Overflow or underflow may occur. DP: The two 84-bit fractions and the two signs are multiplied to yield an 86-bit result (sign plus 85 magnitude bits) and an 97th bit which is the union of the 82 least significant bits of the full 168-bit product. The resulting 87-bit number and the exponent obtained by the procedure described for single precision are normalized and rounded like the result of an add. p/c-n.r proc MICPU/M-4.3 81 FAD (E) Floating add SP: The operand is extended with 48 zeros on the right. A DP is then done. D: Let the operands be a \* $2^b$ , c \* $2^d$ . The two exponents are compared. Suppose b $\geq$ d. Then c is shifted right by b - d. A 87 bit register is provided to hold c, which is loaded (sign + 84-bit fraction) into the 85 most significant bits. The two least significant bits are cleared. The 86 most significant bits participate in the right shift in the usual way. The least significant bit is 'sticky': if a 1 is ever shifted into it, it remains 1 from then on. After c has been shifted, it is added to a in an 85-bit adder, yielding a result r of 87 bits. Bits 85:86 of c dc not participate in addition. Now, if an overflow has occurred $(a[\emptyset] = c[\emptyset] \neq r[\emptyset])$ , r is shifted right by 1. r[36] is treated as a sticky bit in this shift just as it was in the shift of c. b is incremented by 1 if this shift occurs and $r[\emptyset] \leftarrow NOT$ r[\( \Omega \)]; The result is normalized by left shifting until either: - 1) the sign bit differs from the next bit or - 2) the fraction is 1100 ... Ø The exponent b is decremented by 1 for each left shift. Lastly the result, rounded at bit 83 of the fraction OCC /c-n.r eago MICPU/M-4,3 84 XR is assigned a 24-bit integer which is the floor of the floating operand. If the floor is $> 2^{23}$ -1 in magnitude, the trap FLXO occurs. The result does not depend on SP or DP mode. FNA (OPR) Floating negative The number in the floating point accumulator is replaced by its negative. PIX (OPR) Similar to FLX, but the operand is taken from the floating point accumulator and the result is put into RESULT and AR. FLOAT (OPR) A FLOAT operation produces a (normalized) floating point number in the floating point accumulator which when FIXed will restore the integer operand in AR. (unless it is 487). Nothing can go wrong with FLOAT. #### E. Rounding There is a three-bit field (TRMOD) in SR which specifies how rounding is to be done (the field PRMOD is used to set TRMOD after every FAD, FSB, FMP, FDV, STF or FCP). The descriptions of instructions above state explicitly each point where rounding is done. The phrase 'round at bit n of the fraction' means that bit n of the fraction (numbering the magnitude bits from Ø and not counting the sign) is the least significant bit retained. F/c-n.e pege MICPU/M-4.3 83 FDV (E) Floating divide SP: The 36-bit divisor fraction is divided into 38 bits of the accumulator fraction to produce a 37-bit quotient. To this is appended a 38th bit which is set if the division is not exact or if the other 46 bits of the accumulator fraction are non-zero. The resulting 38-bit number is put into the fraction of the accumulator and filled out with 46 zeros on the right. The exponent of the result is computed by subtracting the divisor exponent from the dividend exponent. DP: The 84-bit divisor fraction is divided into the 84-bit accumulator fraction to produce a 85-bit quotient. The exponent is computed as for SP and the result is rounded in the usual way. Overflow or underflow may occur. Division by $\emptyset$ produces its own trap. (DIZ) If the divisor is an un-normalized number it is normalized prior to division. It may or may not cause overflow as explained below. FCP (E) Floating compare Identical to floating subtract, but the result is not assigned to the floating accumulator. CC will be set as usual to indicate the sign of the result. TDFLAG + PDFLAG. FLX (E) Fix and load X p/c-m.r page MICPU/M-4.3 85 The rounding modes are: | TRMCD | Name | Rounding | |-------|------|-----------------------| | ø | Ŋ | nearest number | | 2 | È | floor (toward Ø) | | ŝ | ĉ | ceiling (away from Ø) | | 4 | P | away from - ∞ | | 5 | м | toward - = | Rounding involves three bits. The first is the least significant bit to be retained and is called Q. The one following Q is called R. The third is the union of all the bits following R (sometimes only 1, none for double divide) and is called T. The rounding rules are as follows (call the sign S): - N: +1 (add 1 to least significant retained bit) if R = 1 unless $Q = \emptyset$ and $T = \emptyset$ - $\hat{\mathbf{f}}$ : +1 if S = 1 and R or T = 1 - C: +1 if $S = \emptyset$ and R or T = 1 - P: +1 if R or T = 1 - M: no action # F. Overflow and Underflow Overflow or underflow occurs if at the <u>end</u> of a floating point instruction, the exponent is outside the permitted range. Overflow always causes a trap (FLO). It leaves a correct result except for the exponent, which must be read as a p/c-n.r page MICPU/M-4.3 86 12-bit two's complement number with sign bit the complement of the high-order bit preserved. Underflow action depends on the SUF bit in SR. If it is set, no trap occurs and a suitable unnormalized number or zero results. Otherwise, trap FLU occurs and the result is correct (and normalized) with the same rule for the exponent as was stated for overflow. p/c-n,r page MICPU/M-4.3 87 # DEFINITION OF INSTRUCTION CODES | code | mnemonic | a.type | code | mnemonic | a.type | |-----------------------|----------|----------|------------|----------|--------| | ø | HLT | F | 4ø | ASHD | F* | | í | LDA | F* | 41 | ASHA | F* | | Ø<br>1<br>2<br>3<br>4 | LDB | F* | 42 | ISHD | F* | | 3 | LDX | F | 43 | LSHA | £.* | | 4 | LDD | E* | 44 | CYD | F* | | 5 | EAX | E | 45 | CYA | P* | | 5<br>6 | INX | E | 46 | TSB | F* | | 7 | XMA | s* | 47 | LAX | E | | 1ø | ETR | F* | 5ø | BRU | E | | īĩ | IOR | F* | 51 | BLT | E | | 12 | EOR | F* | 52 | BEQ | E | | 13 | STD | D | 53 | BLE | E | | 14 | STF | D | 54 | BGT | E | | 15 | STA | S | <b>5</b> 5 | BNE | E | | 16 | STB | S | 56 | BGE | E | | 17 | STX | S | 57 | BLI, | E | | 2ø | ADD | F* | 6¢ | PLLN | E | | 21 | SUB | F* | 61 | BRX | E | | 22 | ADC | F* | 62 | BSX | E | | 23 | SUC | F* | <b>6</b> 3 | SRS | F | | 24 | ADM | S* | 64 | EAC | E* | | 25 | ADX | F | 65 | | | | 26 | ' MIN | s* | 66 | | | | 27 | MDC | s* | 67 | • | | | 3ø | MUL | F* | 7Ø | FLX | E | | 31 | DIV | F* | 71 | FLD | E* | | 32 | ICP | F* | 72 | FCP | E* | | 33 | CPZ | <b>*</b> | 73 | FAD | E* | | 34 | CMZ | F* | 74 | FSB | E* | | 35 | ISD | E* | 75 | FMP | E* | | 36 | DSD | E* | 76 | FDV | E* | | 37 | EXU | E? | <b>7</b> 7 | OPR | F? | \* indicates that CC is set by the instruction p/c-n.r pege MICPU/N-4.3 88 #### DEFINITION OF OPR ADDRESSES | OPR address | mnemonic | | OPR address | muemonic | | |---------------------------------|-------------|---|--------------|----------|---| | ø | CAB | | 40 | | , | | í | XAB | * | 41 | toms | * | | ž | CBA | * | 42 | STORS | | | 3 | CBX | | 43 | LSC | | | 4 | XXB | | 44 | FIX | * | | 5 | CXB | | 45 | FLOAT | * | | Ø<br>1<br>2<br>3<br>4<br>5<br>6 | CAX | | 46 | FNA | * | | 7 | XXA | * | 47 | | | | 1ø | CXA | * | 5ø | • | | | 11 | CNA | * | 51 | | | | 12 | CNX | | . 52 | | | | 13 | ZOA | * | 53 | | | | 14 | ZAB | | 54 | | | | 15 | ZOB | | 55 | SLOK | | | 16 | CGA | * | 56 | RLOK | | | 17 | XGY | * | 57 | ALD | * | | 2ø | CIA | * | 6ø | AST | | | 21 | XIA | * | 61 | AAX | | | 22 | <b>C</b> SA | * | 62 | PRO | * | | 23 | XSA | * | 63 | | | | 24 | CTA | * | 64 | UNPRO | | | 25 | CCA | * | <b>6</b> 5 . | ATTN | | | 26 | NOP | | 66 | USCL | | | 27 | . MVĐ | | 67 | CMA P | | | зø | MVC | | 7ø | CMAPS | | | 31 | MVS | | 71 | CAT | | | 32 | CPS | * | 72 | CAC | | | 33 | CLS | * | 73 | RUN | * | | 34 | ASP | | 74 | | | | 35 | LLT | * | 75 | | | | 36 | СОВ | * | 76 | | | | 37 | | | 77 | | | | | | | | | | \* indicates that CC is set by the OPR bcc P/2-m.r page MICPU/M-4.3 90 SIGN (W[i,j]) means W[i,j] interpreted as a twos-complement number of (j-i+1) bits. CONT(W) or CONTENTS (W) means the contents of the memory location whose address is the value of W. A ring check is performed with R as a source and W as target. XX(W), where XX is the abbreviation for an addressing mode, means the value of Q if that mode is applied to W. IA (X) means to initiate indirect address word calculation on IAW $\leftarrow$ CONTENTS(X) & R $\leftarrow$ X. The calculation depends on IAT $\leftarrow$ IAW[\$\mathcal{G}\$, X] All instructions start with IR $\leftarrow$ XR & R $\leftarrow$ P; ### Summary of Indirect Addressing | Name | <u>IAT</u> | Notation | Address Computation | |--------|------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Normal | ø | Like instruction, with IAW for OP | TAG = IAW [2,4], then like instruction, except for TAG = D,I,X use IAW [6,23] for W and don't add G. Trap IATRP (R) if W[5]=1. Add IR to Q (for LR or SR mode) or to LR or SR (for ILR, ISR) if IAW [6]=1, and use IAW [7,23] for W. For TAG=PD, IPD, calculate address as D,X (G is not added). This is the read only (ROD,ROX) addressing mode. | | Field | 1 | FIELD D:FB,<br>FB:SIZE | Q ← IR + (DISPL ← SIGN(IAW [13,23]); U←CONT(Q); OP ← U[FB ← IAW [8,12],FB + (SIZE ← IAW [3,7])]; IF(SE ← IAW [2,2])=0 ELSE SIGN(U[FB,FB:SIZE]); | | String | 2 | STRING WA: CPOS,<br>CSIZE | CSIZE IAW [2,3] gives byte size: 6,8,12 or 24. Then IAW selects byte COPS IAW [4,5] from word WA IAW [6,23]. | | | 100 | 5 | | p/c-n.r page<br>MICPU/M-4.3 89 | |---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---------------------------------|-----------------------------------------------------------------------------------| | - | 1200 | 0 | 1 | | | | | Summary of | Instruction Add | | | | Abbr. | Namo | Notation | Address Computation | | | α | Direct | OPC G'[W] | $Q \leftarrow W+G$ ; OP $\leftarrow$ CONT(Q) | | | I | Indirect | OPC \$G'[W] | IA(W G); | | | x | Indexed | OPC X'[W] | Q + W+IR; OP + CONT(Q); | | | PD | Pointer dis-<br>placement | OPC PRT[D] | Q + SHORTPTR(PTR + W [16,23].IR)+(D + SIGN (W[10,15])); OP + CONT(Q); | | | IPD | Indirect-pointer displacement | OPC \$PTR[D] | IA(PD(W)); | | | BX | Base-index | OPC B[X] | T ← SHORTADR(B ← W[16,<br>23]);<br>IR ← SHORTPTR(X ← W<br>[10,15], IR);<br>IA(T); | | | BXD . | Base-index-<br>displacement | OPC (\$X')[X+D] | <pre>T ← IR; IR ← SHORTPTR(W[16,23], Ø) + SIGN(W[10,15]); IA(T);</pre> | | i | IM | Immediate | OPC I | OP + SIGN(W[13,23]); | | | IMX | Immediate indexed | OPC X'+I | OP ← IR + SIGN(W[13,<br>23]); | | | LR | L-relative | OPC L'[D] | $Q \leftarrow L+(D \leftarrow W[13,23]);$<br>$OP \leftarrow CONT(Q);$ | | | ILR | Indirect<br>L-relative | OPC \$L'[D] | <pre>IA(LR(W));</pre> | | | SR | Source-relative | OPC R'[D] | Q ← R+(D ← SIGN(W[12,<br>23])); OP ← CONT(Q); | | | ISR | Indirect source relative | OPC \$R'[D] | IA(PR(W)); | | | Notes | Ø is the leftmos | t bit. | 24-bit quantity W. Bit | | | | SHORTADR(W[i,j]) | means IR IF W[G+W[i+1, L+W[i+1, | j] IF W[i]=Ø ELSE | | Section of the section of | And the second s | SHORTPTR(W[i,j]Y | CONTENTS | i,j]=Ø ELSE<br>:(G:W[i+1,j] FI W[i]=Ø<br>L+W[i+1,j]) | | bcc | | |-----|--| |-----|--| p,c-n.r page MICPU/M-4.3 91 Two words. Trap APE(R) IF IRCLE + W1[8,8] OR IR > UB+ (W1[7,23] IF (LEB + W1[4,4] =Ø) ELSE W1[11,23]); IATRP(R) IF (W1[3,3]=1) + (INSTRUCTION = LAX); IR + (IR-LB) \* (MULT + (W1[5,6] IF LEB=Ø ELSE W1[5,16]) ARRAY LB: UB\*MULT; Array IAW +1); p/t-n.r poge MICPU/M-4,4 92 FIXED TRAPS | | Number | Name | Caused By | Parameter | |---|--------|-------|---------------------------------------------------------------------------------------------------|---------------------------| | | 1 | MACC | Memory access error - at-<br>tempted access to monitor<br>from below M or utility<br>from below U | Q+<br>(RING(R)-1)*<br>1B6 | | | 2 | PRO | attempted write of RO page | Q | | | 3 | PNIM | attempted reference to page not in map | Q | | - | 4 | PNIC | attempted reference to page not in core | o. | | | 5 | то | timer overflow - not in monitor mode | des des des | | - | 6 | PI | privileged instruction | gas-sale des | | | 7 | TI | trapped instruction | | | | 8 | XMON | on exit from monitor via<br>any BLL or LOADS if XMONT<br>is set in the state | | | | 9 | XUTIL | on exit from utility via any BLL or LOADS if XUTILT is set in the state | | | | 11 | ILIM | indirect limit exceeded | address of<br>IAW | | | 12 | MAB | map abort | | bcc p/c=n.r page MICPU/M-4,3 93 # RING-DEPENDENT TRAPS | Number | Name | Caused By | Parameter | |--------|---------|-------------------------------------------------|---------------------------| | 1 | ABE | array bound exceeded | address of<br>IAW | | 2 | FLO | floating overflow | <del></del> | | 3 | FLU | floating underflow | | | 4 | RO | read only trap | address of ROO or ROX IAW | | 5 | IATRP | indirect address trap bit | address of<br>IAW | | 6 | UFN | undefined floating number | <b></b> | | 7 | FLXO | overflow on FIX or FLX instruction | ager haps man | | В | DIZ | floating divide by zero | | | 9 | STKOV | stack overflow | | | 10 | BLL ERR | function call error described in separate table | CLASS * 1B6 | | | bcc | p/s-n.r<br>MICPU/M-4.4 | |---|-----|------------------------| | r | | | page 94 # RING DEPENDENT TRAP IO: BLL ERR | Class | •, | | Parameter | |-------|----|------------------------------------------------|-----------| | 1 | | address type error in A | 186 | | 2 | | wrong number of arguments | 286 + NAW | | 3 | | argument type mismatch | 3B6 + NAW | | 4 | | inadmissible argument | 486 + NAW | | 5 | | address type error | 586 + NAW | | 6 | | array, label or string descriptor format error | 6B6 + NAW | | bcc | p/t-n.r pege<br>MICPU/M-4.4 95 | |------------|--------------------------------------------------| | | 1 | | | SUMMARY OF IMPORTANT CORE ADDICATES | | ø | Start to the user ring | | G'[Ø] | POP entry IAW | | G'[1] | 2nd word of POP entry IAW | | G'[2] | SP - Stack Pointer | | G,[3] | SL - Stack Limit | | G'[4] | Ring dependent trap - P is stored here | | G'[5] | Ring dependent trap - parameter is stored here | | G'[6] | Ring dependent trap service entry IAW | | G'[7] | (may be used as 2nd word of IAW) | | G'[31] | Last word which can be used as an index in BX | | G'[127] | Last word which can be used as a pointer in PD | | | or IPD or as a base in BX | | G'[37777B] | Last word which can be accessed by D, I addressi | | r,[a] ; | 1st word of the return descriptor - P | | L'[1] | 2nd word of the return descriptor - L, STK, CPA | | r,[5] | SYSPOP transfer address | | r,[31] | Similar to G'[32] | | L'[127] | Similar to G'[127] | | L'[2Ø47] | Last word which can be addressed by L, LI | | | addressing | | 4ØØØØØB | Start of monitor ring | | | • | | | | MICPU/M-4.4 96 4Ø3ØØØB Start of utility ring, G for utility 4Ø3Ø14B G may be stored here 4Ø3Ø16B UCALL entry IAW **6**дффффВ Monitor ring starts again, G for monitor, context block 6ØØØ14B G may be stored here 6Ø2752B State is stored here if a fixed trap occurs 6Ø2764B Start of the SAVE area 6Ø4ØZØB MCALL entry IAW 6Ø1ØØ2B Fixed trap entry Maximum virtual address 77777B p/c-n.r MICPU/M-4.4 97 \* SPL PROGRAM TO DEFINE BLL N+0; SPEC+0; MCAL+0; NEVG+G; GOTO BLL1; BLLN: N+1; SPEC+G; MCAL-0; NEVG-G; GOTO BLL1; \* OPR WITH NEGATIVE OPERAND: OPR: OP- -OP1 N-OP \$ BIT15; SPEC-0; MCAL+OP \$ BIT14+1; (NEVG-403000B & R-403014B) IF MCAL=1 ELSE (NEWG-6000008 & R-6043008); IR-OP & BIT16THRU23; IA(R); GOTO BLL1; POPI POPM-CONTENTS(P); IR-POPM \$ FOPC; N+0 SPEC-1: MCAL-C: NEWG-G: IA(G): TI() IF IMMEDIATE=1; GOTO BLL1; BLL1: NEWPW-CONTENTS(0); BLLERR(I) IF NEVPY \$ BITS! NEWP+(NEWPW & FLW IF NEWPW & BIT4=0 ELSE OFNEVAR \$ FSRV); BRD-CONTENTS (C+1) FTNATF+6; CLL-BRD & BITO; STK-GRD & BITI; CPA+BRD \$ BIT2; CPR+BRD \$ BIT3 IF CLL=1 ELSE UNSTK+BRD \$ BIT3; REL-BRD & BITA; FIN-BRD & BITS; NEWL-E-BRD 5 FEI IF RING(NEWP) < RING(P) DO; NEWG-G[14]; RET-1; ENDIF: OBTAIN NEW LOCAL ENVIRONMENT IF STK=1 DO; IF CLL=0 D3; IF UWSTK=0; SP-L; ELSE DOJ SP-EJ NENL-E-FEJ ENDIFI ELSE DO: SP+NEWG(21+E) STROV() IF SP>=NEWG(31) NEWL+NEWG[2]; END!F3 ELSE DOJ NEWL+L IF NEWL=01 ENDIF; RINGCHECK (NEVP); COPY ARGUMENTS BLLERR(2) IF N=CPA; NAN-P+11 IF CPA#0 DO: FOR NEW-NEWP BY 1 DOJ ``` P/s-mr pega MICPU/M-4.4 98 R-NEWP; FP-CONTENTS(NFW); FTYPE+FP $ TYPE! IF SPECEL DOX SPEC-03 AP-POPW; NAW-NAW-13 ATYPE-FTYPE; ASTR-FP $ FSTR; AENDF-FP $ ENDF; ELSE DOI LØ: R-P; AP-CONTENTS(NAW); ATYPE-AP $ TYPE; ASTR-AP $ STR; AENDF+AP S ENDF; ENDIF: - IF ATYPE=0 DO; * JUMP IN ACTUAL ARGUMENT LIST R-PJ IR+XRJ EA(NAV); BLLERR(5) IF IMMEDIATE; NAW-03 GOTO LOS ELSE DUI BLLERR(2) IF AENDF#FP $ ENDF; IF ATYPE#FTYPE DO: TYPES DISAGREE. ERROR UNLESS ONE IS JOKER, JOKER IS CHECKED FOR BELOW UNLESS CADDR=1 OR FSTR:ARRAY. IN WHICH CASE IT IS * NOT CHECKED. IF ATYPE#14 DOS BLLERR(3) IF FTYPE#143 FTYPE-ATYPES ENDIF ENDIF; NAMP+NAM3 IF ASTR=0 OR ASTR=2 DO; NAW+NAW+1 IF ASTR=2; IF FP $ FSTR=0 AND ASTR=2 OR FP $ FSTR=1 AND ASTR=0 DO; BLLERR(3) IF FTN=0; FTNATF-1; TEMP-NAW+186) GOTO L1; ENDIF: ELSE DO: BLLERR(3) IF FP $ FSTR=0; ENDIF: * CHECK FOR ACTUAL ARG IN ACCUMULATOR IF (AP AND 700371778)#0 DO; R+P; IR+XR; EA(NAMP); ARGADR+Q; IF FP 5 CADDR=1 DO; IF IMMEDIATE=1 DOX * CONSTRUCT IMMEDIATE, IAV TEMP+OP AND 37778, OR 1634841 ... ELSE DOI RINGCHECK (ARGADR); TEMP+ARGADR; * MAKE THE IAW READ-ONLY IF NECESSARY TEMP+TEMP+187 IF READONLY=1 OR ASTR=3; ENDIF; * FIX UP SO THE COPY VALUE CODE WILL COPY THE ADDRESS IN TEMP L1: FTYPE+1; FP & FSTR+1; ELSE DO: ``` ``` P/c-n.r page MICPU/M-4.4 99 IF IMMEDIATE=1 DO; BLLERR(5) IF FTYPE#1 OR FP $ FSTR=C; TEMP-(OF IF FIYPE=1 ELSE CONTENIS(ARGADR)); ENDIF: OLDR-R; CPYADR+((FP AND 37778)+NEWL IF FP<0 ELSE (FP AND 37777B)+NENG); GOTO ARRAY IF FP $ FSTR=01 COUNT-(1 IF FTYPE=1 CR FTYPE=9 ELSE 2 IF FTYPE=2 OR FTYPE=3 ELSE 4 IF FTYPE=4 OR FTYPE=5 OR FTYPE =6 ELSE GOTO STRING IF FTYPE=7 ELSE GOTO LABEL IF FTYPE≈8 ELSE BLLERR(4)); UFN'TRAP() IF(FTYPE=3 OR FTYPE=4) AND UNDEFINED (TEMP); L2: R-NEWP3 SCRYADR-TEMP3 COUNT-COUNT-13 IF COUNT#P DOJ R-OLDE: 0-0+1; CPYADR+CPYADR+1; TEMP+CONTENTS(Q); GOTO L2; ENDIF: ELSE DO; BLLERR(5) IF FP $ CADDR=1 OR FP $ FSTR=0; CPYADR-((FP AND 37778)+NEWL IF FP<0 ELSE (FP AND 37777B)+NEWG); IF TYPE=3 OR TYPE=4 DOI STF(CPYADR); ELSE DJ; COUNT+(1 IF FTYPE=1 OR FTYPE=9 ELSE 2 IF FTYPE=2 ELSE 4 IF FTYPE=5 OR FTYPE=6 ELSE BLLERR(4)); R+NEYP; STORE (CPYADR, A); IF COUNT#1 DO; STORE(CPYADR+1, B); IF COUNT#2 DO: STORE(CPYADR+2, C); STORE(CPYADR+3, D); ENDIF; ENDIF; ENDIF; FNDIF: NAV-NAS'+11 L3: ENDIF INTERRUPT'CHECK(); GOTO L4 IF FP S ENDF=TF ENDFOR; L4: NEWP+NFW+1; ENDIF: * COMPUTE RETURN DESCRIPTOR ``` ``` P/c-n.r Page MICPU/M-4.4 100 IF CLL=1 DO; R-NEWP: NEWL[0]+NAWI NEVL[1]+L+287*STK+187*CPR; NEVG[148]+G IF MCAL>0 AND RING(NEWP)>RING(P); ENDIF IF STK=1 DOI IF CLL=1 DO R+NEUP; NEUGI21+SP; ELSE DOJ R-P; G[2]-SP; ENDIF ENDIF IF MCAL=2 DOJ MENTER: PROTECT(4); SET'LOCK(); ENDIF: SR $ TOFLAG-SR $ PDFLAG-0 IF MCAL>0; L-NE'L J G-NEWG J OLDP-PJ P-NEWPJ IF RET=1 DO; IF OLDP>=685 DO; UNPROTECT(4)3 MEXIT: RESET'LOCK(); XMON'TRAP() IF SR $ XMONT; ELSE DO XUTIL'TRAP() IF SR $ XUTILTI ENDIF; ENDIF; P-P+1 IF FTN=1 AND FTNATF=0; EXIT FROM BLL GOTO NEXT'INSTRUCTION; STRING: COUNT-4; GOTO L2 IF MCAL=0; FORM+TEMP AND 1486 OR 487; OLDT+0; FOR I+0 BY 1 DOJ R+P; RINGCHECK(TEMP); BLLERR(6) IF OLDT $ WA>TEMP $ WA OR OLDT $ WA=TEMP $ WA AND OLDT $ CPOS>TEMP $ CPOS; R+NEWP; $(CPYADR+I)-TEMP AND NOT 7486 OR FORM; GOTO L3 IF I=3; R+OLDR; OLDT+TEMP; TEMP+CONTENTS(ARGADR+I+1); ENDFOR; LABEL: 0-(TEMP & FLW IF TEMP & BIT4-0 .ELSE ARGADR+TEMP $ FSRW); RINGCHECK(Q) IF MCAL>0; R-NEWP1 STORE(CPYADR, @ AND NOT 7586 OR TEMP AND 7586); R-OLDR; BRD-CONTENTS(ARGADR+1); IF BRD & FE=0 AND BRD & FSTK=0 DO; BRD+BRD AND NOT 487 IF MCAL>8; BRD+BRD OR (L. IF STK=0 ELSE NEVL+287+486); ``` ``` ELSE DO; BLLERR(6) IF MCAL>0; ENDIF; ```