# VMAX: A VIRTUAL MACHINE FOR THE PCMAX2

Version 2.00

1990 July 16

Roger House Everex Sebastopol R&D 707-823-0733

# Table of Contents

|                                                                                                                                                                                                                                                                                                                                                                                   | page                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| Introduction                                                                                                                                                                                                                                                                                                                                                                      | 7                                                                                                                    |
| Design Criteria                                                                                                                                                                                                                                                                                                                                                                   | 7                                                                                                                    |
| VMAX Memory and Address Space                                                                                                                                                                                                                                                                                                                                                     | 8                                                                                                                    |
| Operand Types                                                                                                                                                                                                                                                                                                                                                                     | 10                                                                                                                   |
| VMAX Registers<br>General Registers<br>Stack Pointer<br>Frame Pointer<br>Program Counter<br>Flags Register                                                                                                                                                                                                                                                                        | 12<br>13<br>13<br>15<br>18<br>19                                                                                     |
| Addressing Modes                                                                                                                                                                                                                                                                                                                                                                  | 21                                                                                                                   |
| Instruction Formats<br>General Considerations<br>Overview of Formats<br>The qr Format<br>The r-operand<br>The q-operand<br>Notation for qr Operands<br>Decoding the q-field<br>The qc Format<br>The qo Format<br>The qo Format<br>The ir Format<br>The ir Format<br>The i-operand<br>The j-operand<br>Notation for ij Operands<br>The b1 Format<br>The n0 Format<br>The n0 Format | 23<br>25<br>27<br>28<br>29<br>36<br>37<br>39<br>40<br>41<br>43<br>44<br>45<br>46<br>49<br>49<br>50<br>51<br>52<br>52 |
| Instruction Set Summary by Function<br>Data Movement Instructions<br>Move Instructions<br>Store Instructions<br>Load Address Instruction<br>Flags Instructions<br>Arithmetic Instructions<br>Add Instructions<br>Subtract Instructions<br>Multipy Instructions                                                                                                                    | 53<br>53<br>54<br>55<br>55<br>56<br>56<br>57<br>58                                                                   |

| Divide Instructions<br>Other Arithmetcic Instructions<br>Shift Instructions<br>Logical Instructions<br>Convert Instructions<br>Compare Instructions<br>Jump Instructions<br>Stack Instructions<br>Miscellaneous Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                   | 59<br>63<br>64<br>65<br>66<br>69<br>70<br>72<br>72                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| Notation Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                   | 73                                                                                     |
| Instruction DescriptionsabsdAbsolute value of doubleabsfAbsolute value of floatabs1Absolute value of longabswAbsolute value of wordaddc1Add long with carryadddAdd floataddfAdd longaddlAdd longadduwlAdd word to longaddwAdd wordandlAnd word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                   | 76<br>77<br>78<br>79<br>79<br>80<br>80<br>81<br>81<br>81<br>82<br>82<br>83             |
| callCallCall backwardcallfCall forwardcmpdCompare doublecmpfCompare floatcmplCompare longcmplbCompare loworder byte of long tocmpwCompare loworder byte of word tocmpwbCompare loworder byte of word tocvtbslConvert byte sign-extended to JcvtbslConvert byte sign-extended to JcvtbslConvert byte zero-extended to JcvtbzwConvert byte zero-extended to JcvtbdfConvert float to doublecvtsldConvert signed long to doublecvttdslConvert truncated double to signcvttdslConvert truncated float to signcvttfulConvert trunc. float to unsigncvttfulConvert unsigned long to doublecvtudConvert unsigned long to floatcvtuldConvert unsigned long to floatcvtuldConvert unsigned long to floatcvtuldConvert unsigned long to floatcvtuldConvert unsigned long to floatcvtulfConvert unsigned long to float | to byte<br>to byte<br>long<br>word<br>word<br>word<br>gned long<br>ned long<br>ed long<br>ed long | 83<br>84<br>85<br>86<br>87<br>87<br>88<br>89<br>90<br>91<br>92<br>92<br>93<br>94<br>95 |

| cvtwzl<br>divd<br>divf<br>divrsl<br>divrsw<br>divrul<br>divrulw<br>divruw<br>divsl<br>divsw<br>divul<br>divuu                               | Convert word zero-extended to long<br>Divide double<br>Divide float<br>Divide with remainder signed long<br>Divide with rem. signed long by word<br>Divide with remainder signed word<br>Divide with remainder unsigned long<br>Divide with remainder unsigned long by word<br>Divide with remainder unsigned word<br>Divide signed long<br>Divide signed long<br>Divide unsigned long                                              | 95<br>96<br>97<br>97<br>98<br>98<br>99<br>99<br>100<br>100<br>101                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| enter                                                                                                                                       | Enter function                                                                                                                                                                                                                                                                                                                                                                                                                      | 102                                                                                                          |
| entersav                                                                                                                                    | Enter function and save registers                                                                                                                                                                                                                                                                                                                                                                                                   | 103                                                                                                          |
| gmov                                                                                                                                        | General move                                                                                                                                                                                                                                                                                                                                                                                                                        | 104                                                                                                          |
| gsto                                                                                                                                        | General store                                                                                                                                                                                                                                                                                                                                                                                                                       | 104                                                                                                          |
| halt                                                                                                                                        | Halt the VMAX machine                                                                                                                                                                                                                                                                                                                                                                                                               | 105                                                                                                          |
| jump<br>jumpb<br>jumpf                                                                                                                      | JumpJump backwardJump backwardJump forward                                                                                                                                                                                                                                                                                                                                                                                          | 105<br>106<br>106                                                                                            |
| leal                                                                                                                                        | Load effective address                                                                                                                                                                                                                                                                                                                                                                                                              | 107                                                                                                          |
| leave                                                                                                                                       | Leave function                                                                                                                                                                                                                                                                                                                                                                                                                      | 108                                                                                                          |
| leaveres                                                                                                                                    | Leave function and restore registers                                                                                                                                                                                                                                                                                                                                                                                                | 109                                                                                                          |
| movbl<br>movbw<br>movd<br>movf<br>movflags<br>movl<br>movw<br>movwl<br>muld<br>mulf<br>mulsl<br>mulsw<br>mulswl<br>mulswl<br>muluw<br>muluw | Move byte to loworder byte of long<br>Move byte to loworder byte of word<br>Move double<br>Move float<br>Move word to flags register<br>Move word<br>Move word<br>Move word of long<br>Move word to loworder word of long<br>Multiply double<br>Multiply float<br>Multiply signed long<br>Multiply signed word<br>Multiply signed word syielding long<br>Multiply unsigned word<br>Multiply unsigned word<br>Multiply unsigned word | 110<br>110<br>111<br>111<br>112<br>112<br>113<br>113<br>114<br>114<br>115<br>115<br>116<br>116<br>117<br>117 |
| negd                                                                                                                                        | Negate double                                                                                                                                                                                                                                                                                                                                                                                                                       | 118                                                                                                          |
| negf                                                                                                                                        | Negate float                                                                                                                                                                                                                                                                                                                                                                                                                        | 118                                                                                                          |
| negl                                                                                                                                        | Negate long                                                                                                                                                                                                                                                                                                                                                                                                                         | 119                                                                                                          |

| negw<br>nop<br>notl<br>notw                                                                                                                  | Negate word<br>No operation<br>Not long<br>Not word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 119<br>120<br>120<br>121                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| orl<br>orw                                                                                                                                   | Or long<br>Or word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 121<br>122                                                                                                          |
| popd<br>popf<br>popl<br>popregs<br>popw<br>pushd<br>pushf<br>pushl<br>pushregs<br>pushw                                                      | Pop double<br>Pop float<br>Pop long<br>Pop multiple registers<br>Pop word<br>Push double<br>Push float<br>Push long<br>Push multiple registers<br>Push word                                                                                                                                                                                                                                                                                                                                                                                                                               | 122<br>123<br>123<br>124<br>124<br>125<br>125<br>125<br>126<br>126<br>127                                           |
| remsl<br>remsw<br>remuu<br>ret<br>rlil<br>rliw<br>rll<br>rlw<br>rril<br>rriw<br>rri<br>rriw                                                  | Remainder signed long<br>Remainder signed word<br>Remainder unsigned long<br>Remainder unsigned word<br>Return from call<br>Rotate left immediate long<br>Rotate left immediate word<br>Rotate left long<br>Rotate left word<br>Rotate right immediate long<br>Rotate right immediate word<br>Rotate right immediate word<br>Rotate right long                                                                                                                                                                                                                                            | 127<br>128<br>129<br>130<br>131<br>131<br>132<br>132<br>133<br>133<br>134<br>134                                    |
| set0l<br>set0w<br>set1l<br>set1w<br>slil<br>sliw<br>sll<br>slw<br>sqrtd<br>sqrtf<br>srail<br>sraiw<br>sral<br>sraw<br>srlil<br>srliw<br>srll | <pre>Store condition(0) into long<br/>Store condition(0) into word<br/>Store condition(1) into long<br/>Store condition(1) into word<br/>Shift left immediate long<br/>Shift left immediate word<br/>Shift left long<br/>Shift left word<br/>Square root of double<br/>Square root of float<br/>Shift right arithmetic immediate long<br/>Shift right arithmetic long<br/>Shift right arithmetic long<br/>Shift right arithmetic long<br/>Shift right arithmetic word<br/>Shift right arithmetic word<br/>Shift right logical immediate word<br/>Shift right logical immediate word</pre> | 135<br>136<br>136<br>137<br>137<br>138<br>138<br>139<br>139<br>140<br>140<br>141<br>141<br>141<br>142<br>142<br>143 |

| <pre>srlw stod stof stoflags stol stolb stolw stow stow stowb subcl subd subf subl subswl subuwl subwul subw</pre> | Shift right logical word<br>Store double<br>Store float<br>Store flags register into word<br>Store long<br>Store loworder byte of long into byte<br>Store loworder word of long into word<br>Store loworder byte of word into byte<br>Store loworder byte of word into byte<br>Subtract long with carry<br>Subtract double<br>Subtract float<br>Subtract long<br>Subtract signed word from long<br>Subtract word | 143<br>144<br>145<br>145<br>146<br>146<br>147<br>147<br>147<br>148<br>148<br>149<br>149<br>150<br>150<br>151 |
|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| xorl                                                                                                               | Exclusive or long                                                                                                                                                                                                                                                                                                                                                                                                | 151                                                                                                          |
| xorw                                                                                                               | Exclusive or word                                                                                                                                                                                                                                                                                                                                                                                                | 152                                                                                                          |

| Appendix A: | Instructions Grouped by Format                | 153 |
|-------------|-----------------------------------------------|-----|
| Appendix B: | Instructions Grouped by Function              | 161 |
| Appendix C: | Instructions Ordered Alphabetically by Opcode | 168 |
| Appendix D: | Differences Between VMAX v1.00 and v2.00      | 172 |
| Appendix E: | Ideas and Notes for Future Versions           | 177 |
| Appendix F: | Diagrams of Instruction Formats               | 181 |

## VMAX: A Virtual Machine for the PCMAX2

#### Introduction

VMAX is one component of a system which will allow a programmer to compile and execute C programs on a PCMAX2 board on a PC running DOS. This system is based on a C compiler, GCC, which can be tailored to generate code for most any 32-bit machine that addresses 8-bit bytes and has several general registers.

Since the PCMAX2 has a rather small code space (the Writable Control Store or WCS) and a rather small data space (the DataRam), it is not feasible to tailor GCC to generate PCMAX2 microcode. Instead, GCC is tailored to generate code for a virtual computer, the VMAX, which is then executed on the PCMAX2 by an interpreter which simulates the VMAX.

This document describes the architecture of VMAX: The address space, register structure, instruction formats, and detailed actions of all instructions. The intention is that this document should provide a complete and detailed description of VMAX which contains all the information needed for a programmer to write a VMAX interpreter.

Although VMAX is a general-purpose computer which could be described independently of both the PCMAX2 and GCC, it does not seem to be a good idea to treat VMAX as if if exists in a vacuum. The only reason the VMAX computer has been designed is so that GCC can be ported to the PCMAX2. Thus, both GCC and the PCMAX2 are mentioned frequently in this document.

#### Design Criteria

The design of the VMAX architecture was driven by two major requirements:

- 1. The VMAX interpreter on the PCMAX2 must be efficient in terms of speed.
- 2. It must be possible to describe VMAX to GCC so that GCC can generate reasonably good code for the machine.

Although considerable care was taken to satisfy these requirements, it is anticipated that the definition of VMAX will be an iterative process. The machine definition will undoubtedly change as experience is gained with GCC and as the interpreter is developed.

#### VMAX Memory and Address Space

The VMAX memory is organized as a flat 32-bit address space of up to 2^32 bytes. The first byte has address 0, and the last byte address 2^32-1. Each byte can be addressed, so in the general case an address requires 32 bits (= 4 bytes). Data operands have no alignment requirements, e.g., a 2-byte word operand need not be word-aligned in memory. However, all instructions must be word-aligned (all instructions occupy an even number of bytes).

VMAX programs generated by the C compiler organize the VMAX memory like this:



MEMSIZE ->

It should be noted that there is nothing in the VMAX architecture itself which forces the above memory organization (except, perhaps, the fact that the VMAX stack grows from high addresses to low addresses). This organization is very convenient and efficient for programs generated from C

source code, but if one were to write programs directly in VMAX assembly language, it would be possible to intermingle code, data, and the stack in anyway the programmer desired.

The VMAX address space is mapped onto the PCMAX2 Vram: Address zero of VMAX memory is address zero of Vram. Thus the Vram is the VMAX memory.

The VMAX stack begins at the highest available address of Vram and grows downward towards lower addresses.

The VMAX interpreter can use PCMAX2 DataRam in a number of ways: All VMAX registers might be stored in DataRam, or some of them might be stored in PCMAX2 registers. Portions of VMAX memory might be cached in DataRam, e.g., the memory near the current top of the stack, and the memory near the current value of the program counter. However, these are all implementation issues, more or less independent of the definition of VMAX, so no more will be said about them at this time.

One advantage of the mapping from VMAX memory to Vram is that VMAX executable programs do not need to be relocated. They always load at byte zero of Vram.

#### Operand Types

VMAX instructions operate on 9 operand types. The following table lists the types and their corresponding C declarations:

| VMAX data type                                                                                                             | Size (bytes)                                   | C declaration                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| signed byte<br>unsigned byte<br>signed word<br>unsigned word<br>signed long<br>unsigned long<br>float<br>double<br>address | 1<br>1<br>2<br>2<br>4<br>4<br>4<br>4<br>8<br>4 | signed char<br>unsigned char<br>short<br>unsigned short<br>long<br>unsigned long<br>float<br>double<br>pointer to whatever |
|                                                                                                                            |                                                | •                                                                                                                          |

The float and double data types use the standard IEEE 754 formats for single-and double-precision floating-point numbers. All other data types are integer types which are stored in 2's complement form. VMAX is a "little endian" machine, which means that the loworder bytes of a data item are stored at lower addresses than the highorder bytes of the item. In other words, the order of the bytes in memory is opposite to the order in which numbers are usually written. As an example, consider these four bytes stored at memory address A:

|           |         |     | ff | ee | dd | сс  |
|-----------|---------|-----|----|----|----|-----|
|           |         |     |    | Ι  | I  |     |
| stored at | address | А   | +  |    |    |     |
| stored at | address | A+1 |    | -+ |    |     |
| stored at | address | A+2 |    |    | -+ |     |
| stored at | address | A+3 |    |    |    | - + |

The following table shows how these bytes are interpreted when address A appears in an instruction requiring an operand of a specific data type:

| operand type  | order in mem. | usually written a | is value       |
|---------------|---------------|-------------------|----------------|
| signed byte   | ff            | ff                | -1             |
| unsigned byte | ff            | ff                | +255           |
| signed word   | ffee          | eeff              | -4,353         |
| unsigned word | ffee          | eeff              | +61,183        |
| signed long   | ffeeddcc      | ccddeeff          | -857,870,593   |
| unsigned long | ffeeddcc      | ccddeeff          | +3,437,096,703 |

[Note: In this document, unless stated otherwise, numbers are written in the usual order expected by humans, not in the little endian order in which they are actually stored in memory.]

A data item representing an address is the same as an unsigned long. GCC treats the C type "int" as a 32-bit integer, i.e., as a long. Thus there is little mention of "int" in this document, because an "int" is always a long.

As already mentioned, there are no alignment requirements for data operands. An operand may begin at any address in VMAX memory.

#### VMAX Registers

Since GCC is very good at optimizing register usage, VMAX offers a fairly large number of registers:

| general registers<br>8 16-bit word registers:<br>8 32-bit long registers:<br>8 32-bit float registers:<br>8 64-bit double registers: | w0, w1, w2, w3, w4, w5, w6, w7<br>L0, L1, L2, L3, L4, L5, L6, L7<br>f0, f1, f2, f3, f4, f5, f6, f7<br>d0, d1, d2, d3, d4, d5, d6, d7                          |
|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| other registers<br>1 32-bit program counter:<br>1 16-bit flags register:                                                             | pc<br>flags<br>LUF: less than unsigned flag<br>LF: less than signed flag<br>EF: equal flag<br>GF: greater than signed flag<br>GUF: greater than unsigned flag |

The two long registers L6 and L7 are special in that some instructions use them as implicit operands. Thus, these registers are usually denoted by fp and sp:

fp (= L6) is the frame pointer
sp (= L7) is the stack pointer

The following diagram shows all the VMAX registers:

| ++             | ++              | +       | + +. | +  |
|----------------|-----------------|---------|------|----|
| 0   w0         | 8   L0          | 16   f0 | 24   | d0 |
| 1   w1         | 9   L1          | 17   f1 | 25   | d1 |
| 2   w2  <br>++ | 10   L2         | 18   f2 | 26   | d2 |
| 3   w3  <br>++ | 11   L3         | 19   f3 | 27   | d3 |
| 4   w4         | 12   L4  <br>++ | 20   f4 | 28   | d4 |
| 5   w5         | 13   L5         | 21   f5 | 29   | d5 |
| 6   w6  <br>++ | 14   fp = L6    | 22   f6 | 30   | d6 |
| 7   w7  <br>++ | 15   sp = L7    | 23   f7 | 31   | d7 |
| ++             | ++              | +       | г т· |    |
| ++             | ++              |         |      |    |
| flags          | pc              |         |      |    |
| ++             | ++              |         |      |    |

Note that all registers other than the flags and pc registers are numbered from 0 through 31. This numbering is used in a few instructions which reference registers of any type (most instructions only reference registers of one type).

### General Registers

The decision to provide several types of registers for VMAX was based primarily on the fact that the PCMAX2 is a word machine (word = 2-bytes), which means that operations on operands longer than a word are inherently slower than operations on words. Thus, by providing word registers on the VMAX, operations on C short integers will execute faster than operations on long (4-byte) integers. Also, the new ANSI definition of C allows operands of type float to be operated on with single-precision floating point operations rather than double-precision operations. Thus, when the extra precision of doubles is not needed, speed can be gained by using floats.

VMAX has no byte registers as such. However, individual bytes can be moved to and from the loworder bytes of word and long registers, so all byte operations can be handled. For example, to implement A = B + C, where all three variables are unsigned characters, this VMAX code can be used:

| movbzw | В  | w0 | ; Move byte B zero-extended to word w0  |
|--------|----|----|-----------------------------------------|
| movbzw | С  | w1 | ; Move byte C zero-extended to word w1  |
| addw   | w1 | w0 | ; Add word w1 to w0                     |
| stowb  | w0 | А  | ; Store loworder byte of w0 into byte A |

#### Stack Pointer

Since the primary aim of VMAX is to execute C programs, it is almost imperative that VMAX have a hardware stack. The stack pointer register is an unsigned long register that contains the memory address of the top word in the stack. (The stack grows from high addresses to low addresses, so the "top" of the stack is at a lower address than other elements on the stack.)

Push and pop operations handle variable-length data items, e.g., push word, push long, push float, and push double. A word is the shortest item that can be pushed or popped; there are no instructions to push or pop single bytes.

As an example of how the stack pointer changes, consider this situation:

13



The stack pointer contains the value 100, which means that the current top of the stack is at memory address 100. Now say that the instruction

#### pushl 0xccddeeff

is executed to push a long value onto the stack. After this instruction is executed, the stack looks like this:



The pushl operation decrements sp by 4 and moves 4 bytes to the address contained in sp. The inverse operation, popl, fetches the 4 bytes starting with the byte addressed by sp, and then increments sp by 4.

Note that the long value 0xccddeeff is pushed onto the stack with its loworder byte at a lower address than its highorder byte. This is essential to maintain the "little endian" order of operands in memory. Since the VMAX has a flat 32-bit address space, there are no segment registers. In particular, there is no register containing the base of the stack. The stack pointer is an absolute memory address, not an offset relative to some base register. If it is conceptually helpful, the stack can be considered to have a base address of zero.

Frame Pointer

A language like C can be implemented easily enough without a frame pointer, provided that memory can be accessed relative to sp (which is not the case for 80x86 processors). However, GCC seems to require a frame pointer, so VMAX provides one, namely the fp register. This is a 32-bit unsigned long register which usually contains a memory address (almost always the address of something on the stack). Addressing modes exist for accessing operands relative to fp.

To illustrate the use of fp, consider the following C function prototype, definition, and call:

The call of F generates the following VMAX code:

| pushd | 60.0 |    | ; Push third parameter onto stack  |
|-------|------|----|------------------------------------|
| pushl | 50   |    | ; Push second parameter onto stack |
| pushw | 40   |    | ; Push first parameter onto stack  |
| call  | F    |    | ; Call function F                  |
| addl  | 14   | sp | ; Clear parameters from the stack  |

Note that the parameters in the call of F are pushed onto the stack in reverse order, so that the first parameter is at the top of the stack when F is entered. The parameters occupy a total of 14 bytes on the stack (2 for W, 4 for L, and 8 for D), so after the call, sp is incremented by 14 to clear the parameters from the stack. These conventions are usual in C implementations because a function may have a variable number of parameters.

When function F is entered, the stack looks like this:



Here is the code generated for the definition of function F:

| F: | pushl<br>movl<br>subl | fp<br>sp<br>6 | fp<br>sp | ; Save old fp on the stack<br>; Set fp to sp<br>; Reserve stack space for locals |
|----|-----------------------|---------------|----------|----------------------------------------------------------------------------------|
|    | movl<br>popl<br>ret   | fp<br>fp      | sp       | ; Clear locals from the stack<br>; Restore old fp<br>; Return to caller          |

After the subl instruction at the beginning of  ${\sf F}$  is executed, the stack looks like this:

| ++  |            |        |         |   |       |
|-----|------------|--------|---------|---|-------|
| sp: | +          |        |         |   |       |
| ++  | I          |        |         |   |       |
|     | +> fp-6 -> | LA:    | у       | 4 | bytes |
| ++  | fp-2 ->    | WA:    | Х       | 2 | bytes |
| fp: | >          | old    | fp      | 4 | bytes |
| ++  | fp+4 ->    | return | address | 4 | bytes |
|     | fp+8 ->    | W:     | 40      | 2 | bytes |
|     | fp+10 ->   | L:     | 50      | 4 | bytes |
|     | fp+14 ->   | D:     | 60      | 8 | bytes |
|     |            |        |         |   |       |
|     |            |        |         |   |       |

Now, all parameters and local variables of F can be accessed relative to fp. Parameters are accessed with positive offsets, and locals are accessed with negative offsets.

The code at the end of the function clears the local variables from the stack (movl fp sp), restores the old fp (popl fp), and returns to the caller (ret).

A few notes on the preceding:

1. The function prologue and epilogue shown in the example above are not what are actually generated for VMAX. Instead the enter, entersav, leave, and leaveres instructions are used. These instructions perform the same actions as shown in the example, but they require quite a bit fewer bytes of code.

2. Traditional C required that all integer parameters shorter than int in a function call be promoted to int. Thus parameter W in the preceding example would be promoted to an int and pushed onto the stack as 4 bytes instead of as 2 bytes. Similarly, floats were promoted to doubles. However, ANSI C now allows shorts and floats to be passed as they are without promotion (if a prototype for the function specifies the parameters as shorts and floats). The example shown assumes this new standard.

3. Traditional C required that the code for every function be prepared to handle a variable number of arguments. This has changed with ANSI C: If a function prototype does not explicitly indicate that the function takes a variable number of parameters, the compiler can assume that the function takes a fixed number of parameters of fixed types, namely those specified by the prototype. This means that it is now possible for a function to clear its own parameters off the stack, instead of requiring the caller to do this. Although the example above shows the traditional C implementation, GCC will generate code for the new standard when appropriate.

[A note on sp and fp: In the preceding, it has been stated that sp and fp are unsigned long registers. This is not quite correct. In the vast majority of cases sp and fp contain memory addresses, which are unsigned longs. However, all instructions which operate on longs may have either sp or fp as an operand, which means that these two registers are treated like any other long registers. Thus, when it is useful, their contents can be thought of as signed longs.]

GCC requires that, when necessary, a function preserve certain registers, so part of the function prologue saves registers on the stack. Here is a diagram showing a typical stack frame just after the function prologue has been executed for a function with:



Program Counter

The program counter register, pc, is an unsigned long register which always contains the memory address of the next instruction to execute. The only way this register can be changed under program control is by jump, call, leave, leaveres, and return instructions. Since instructions are always word-aligned and consist of an even number of bytes, the value of pc is always an even number. In addition, when a C program is interpreted, pc must always point to an address in the Code Space (see a figure in an earlier section). Flags Register

The flags register is an unsigned word register whose highorder 11 bits are always zero. The loworder five bits are used to flag various conditions:

| 4       | 3     | 2     | 1     | 0       | L |
|---------|-------|-------|-------|---------|---|
|         |       |       |       |         |   |
| LUF     | LF    | EF    | GF    | GUF     |   |
| < unsgn | < sgn | equal | > sgn | > unsgn |   |
|         |       |       |       |         |   |

Traditionally, computers tend to have a zero flag, a sign flag, an overflow flag, and a carry flag, all of which are changed by many instructions. Because of the nature of the PCMAX2, it would be rather expensive in terms of time to implement this style of flags. Thus, another approach has been taken:

1. The ONLY instructions which change the flags register are compare instructions.

2. Floating point compares set exactly one of the LF, EF, or GF bits, and clear all the others.

3. Integer compares work like this:

If the operands are equal, EF is set and all other flags are cleared.

If the operands are not equal, one of (LF, GF) and one of (LUF, GUF) are set, and all other flags are cleared.

Thus, after an integer compare, it is possible to determine the relationship between the two operands as either signed quantities or unsigned quantities.

This scheme makes it possible to avoid the overhead of setting flag bits after most instructions. Only the compare instructions set the flags. This fits in very well with the way GCC works: It handles conditional branches using the model "compare and branch on the result of the compare".

Of course, the flags scheme described here is not really completely adequate in general. For example, there are no provisions for checking for overflow of arithmetic operations. This is not a problem for GCC because the C language makes no provisions for overflow. However, for general programming it is imperative that some sort of overflow checking be provided on some basis. This will be addressed in a future version of VMAX. [At present VMAX has no control flags for floating point operations. The IEEE 754 floating point standard requires a rather extensive set of control flags, exception flags, etc. These will be added as the VMAX floating point package evolves. Note that we may end up with a flags register of 32 bits rather than 16 bits, or perhaps we will have two flags registers, one for floating point and one for fixed point.]

#### Addressing Modes

The typical VMAX instruction has two operands, one of which is almost always a register. The other operand is a general operand which can be any of the following:

> register immediate operand memory address absolute address of the operand based addressing: base\_register base\_register + displacement indexed addressing: index\_register + displacement based and indexed addressing: base\_register + index\_register

All long registers can be used as both base registers and index registers. When indexing is used, the value of the index register can be scaled by a factor of 1, 2, 4, or 8.

base\_register + index\_register + displacement

The displacements used in based, indexed, and based-indexed addressing modes are of varying lengths. The following list shows the displacement sizes available, and the notation commonly used for these addressing modes:

Based Addressing

| b   | base |   |             |
|-----|------|---|-------------|
| bd1 | base | + | 1-byte-disp |
| bd2 | base | + | 2-byte-disp |
| bd3 | base | + | 3-byte-disp |
| bd4 | base | + | 4-byte-disp |
|     |      |   |             |

# Indexed Addressing

| i   | index |   |             |
|-----|-------|---|-------------|
| id1 | index | + | 1-byte-disp |
| id3 | index | + | 3-byte-disp |
| id4 | index | + | 4-byte-disp |

# Indexed Addressing

| bi   | base + index                          |
|------|---------------------------------------|
| bid2 | base + index + 2-byte-disp            |
| bid4 | <pre>base + index + 4-byte-disp</pre> |

#### Instruction Formats

#### General Considerations

This section discusses the general characteristics of VMAX instructions, as well as the reasons behind the overall design of the instruction formats.

### Instruction length:

All VMAX instructions occupy an even number of bytes; the possible lengths are 2, 4, 6, 8, and 10 bytes (the latter length only occurs when an instruction contains an 8-byte double as an immediate operand). The primary reason that instructions are an even number of bytes long is that the PCMAX2 Vram (where all VMAX instructions are stored) can only be accessed at the word level, not at the byte level. Thus, we increase interpretation speed by using a bit of space (some instructions could be one byte shorter if an odd number of bytes were allowed in an instruction).

## Separate opcode byte:

The first byte of every instruction is an opcode; no other information is encoded in the first byte (although opcodes often imply operand type). Thus, the opcode byte can be used as an index to a jump table in the PCMAX2 DataRam which contains WCS addresses of routines for interpreting opcodes. At present about 145 VMAX opcodes have been defined, and it is anticipated that at most 40 more will be needed. This leaves at least 60 unused opcode values, which allows plenty of leeway for later optimization of the interpreter after experience shows what new instructions would speed up applications.

#### Data types indicated by opcodes:

Instead of encoding operand type information in the operand bytes of an instruction, each opcode operates on a specific data type. Thus, there are four add instructions: Add word, add long, add float, and add double. The format of the operand bytes in these four instructions is identical (except for immediate operands) but the operand bytes describe different types of data depending on the opcode. In effect, type information is carried by the opcode, not by the operand bytes. This allows a more efficient encoding of information in an instruction (see the description of the qr instruction format below).

#### Two-operand instructions:

Most instructions have two operands, one of which is always a register. The other operand is general, i.e., a register, a memory reference, or an immediate operand. Care has been taken to insure that register-to-register instructions are of minimum length, i.e., 2 bytes. For most instructions, both operands have the same type, i.e., both are words, both are longs, etc. However, some instructions exist for converting one type to another, so, of necessity, the two operands are of different types.

## Uniformity:

The instruction formats are fairly uniform, adhering to general schemes with few exceptions. This cuts down on the work needed to interpret the instructions.

[A note on notation: Examples of VMAX instructions in this document are shown in a sort of pseudo assembly language, for example:

| movw | В  | w5 | ; | Move contents of B to w5 |
|------|----|----|---|--------------------------|
| stow | w5 | А  | ; | Store w5 into A          |

Mnemonics for opcodes reflect the actual opcode stored in memory, not what might normally be written in assembly language. For example, in a real assembly language, the single opcode sto might be used instead of stow, stol, stof, and stod. The assembler can figure out which opcode to generate based on the types of the operands.] The VMAX instruction formats are summarized in the following table:

| + -          | +            | +                    | ++                   | +                   | +              |
|--------------|--------------|----------------------|----------------------|---------------------|----------------|
|              | format  <br> | number<br>  operands | first  <br>  operand | second  <br>operand | examples  <br> |
|              | qr           | 2                    | general              | register            | add, move      |
|              | qc           | 2                    | general              | cond. code          | store cond.    |
|              | qo           | 1                    | general              | -                   | push, pop      |
| +-<br> <br>+ | mr           | 2                    | general              | register            | gmov, gsto     |
|              | ir           | 2                    | imm. int             | register            | shift, rotate  |
|              | ij           | 2                    | cond. code           | jump adr            | jump, call     |
|              | a3           | 1                    | 3-byte adr           | -                   | jump, call     |
|              | b1           | 1                    | 1-byte int           | -                   | ret            |
|              | b14          | 2                    | 1-byte int           | 4-byte msk          | entersav       |
| + -          | n0           | 0                    | -                    |                     | halt, nop      |
| +-           | n04          | 1<br>+               | 4-byte msk           | -                   | pushregs       |
|              | = 1          |                      |                      | 1                   | 1              |

## qr-format

Most instructions have the qr-format, in which the q-operand is a general operand (a register, a memory reference, or an immediate value), and the r-operand is a register. The qoperand can involve based addressing, indexed addressing, or both.

## qc-format

This format is used by instructions which store a 0 or a 1 depending on the condition codes. One operand is a general q-operand, and the other specifies a condition.

# qo-format

This is the "q-only" format, i.e., there is only one operand, which is a general q-operand. Push and pop instructions use this format.

#### mr-format

This format is used by only two instructions: gmov and gsto. It includes all the addressing modes of the qr-format except immediate operands, and in addition allows data to be moved regardless of type (for example, 4 word registers can be moved to one double register).

#### ir-format

In this format, one operand is an immediate 5-bit integer, and the other is a register. At present this format is used only by some shift and rotate instructions.

#### ij-format

This format is used by all conditional jump instructions. One operand is a condition, and the other is an address to jump to. Several addressing modes are available for the address.

#### a3-format

This format consists of a single operand, a 3-byte memory address. It is used by jump and call instructions.

## b1-format

There is one operand, a 1-byte integer. The enter, leave, and ret and instructions have this format.

#### b14-format

This is the same as the b1-format except that in addition to the 1-byte integer operand there is a 4-byte mask operand. The entersav and leaveres instructions have this format.

#### n0-format

This is the simplest format there is: There are no operands, only an opcode. An example is nop.

## n04-format

There is one operand, a 4-byte mask. Only the pushregs and popregs instructions have this format.

Each instruction format is described in detail in the following sections.

The qr Format

The qr-format is the most widely used format in the VMAX instruction set. It specifies two operands, a source and a destination, one of which is a general operand, and the other of which is a register.

A qr-format instruction consists of an opcode, a qr-byte, and, for some addressing modes, a sequence of q-bytes.

| 1 byte<br>++       | 1 byte  | 0, 2,<br>+      |      | -    |   | -                   |
|--------------------|---------|-----------------|------|------|---|---------------------|
| <br>  opcode  <br> | qr-byte | <br> <br> <br>+ | q-by | yte: | S | <br> <br> <br> <br> |

The qr-byte consists of two fields, the q-field and the r-field:

| ++<br>  q-field   r-field  <br>  (5 bits)   (3 bits)  <br> |                       | 7 | 6 | 5 | 4 | 3                    | 2 | 1 | 0 |
|------------------------------------------------------------|-----------------------|---|---|---|---|----------------------|---|---|---|
|                                                            | +-<br> <br> <br> <br> |   |   |   |   | +<br> <br> <br> <br> |   |   |   |

The q-field specifies the q-operand, a general operand, and the r-field specifies the r-operand, which is always a register. With a few exceptions, the q-operand is the source operand, and the r-operand is the destination operand. In some cases, e.g., the set of sto instructions which store registers to memory, the r-operand is the source, and the q-operand is the destination.

The sequence of q-bytes which may follow the qr-byte depends on the addressing mode specified in the q-field. All cases are described in detail in following sections.

Since the r-operand is simpler than the q-operand, it is described first.

The r-operand

The register specified by the r-operand is fully determined by two things: The 3-bit integer in the r-field and the operand type implied by the opcode. The following table shows the possible combinations:

| +<br>  r-field<br>  bit | +<br> <br>  decimal · | operand type specified by opcode |      |       |        |  |  |
|-------------------------|-----------------------|----------------------------------|------|-------|--------|--|--|
| pattern                 | value                 | word                             | long | float | double |  |  |
| 000                     | 0                     | w0                               | L0   | f0    | d0     |  |  |
| 001                     | 1                     | w1                               | L1   | f1    | d1     |  |  |
| 010                     | 2                     | w2                               | L2   | f2    | d2     |  |  |
| 011                     | 3                     | w3                               | L3   | f3    | d3     |  |  |
| 100                     | 4                     | w4                               | L4   | f4    | d4     |  |  |
| 101                     | 5                     | w5                               | L5   | f5    | d5     |  |  |
| 110                     | 6                     | w6                               | fp   | f6    | j d6 j |  |  |
| 111                     | 7                     | w7                               | sp   | f7    | d7     |  |  |
| +                       | +                     | +                                |      | +     | ++     |  |  |

As an example, consider this movl (move long) instruction:

| opcode | q-field<br>⊦ | r-field         |  |  |  |
|--------|--------------|-----------------|--|--|--|
| movl   | 00:001       | <br>  110  <br> |  |  |  |

The operand type implied by the opcode is long, so the two registers appearing in the instruction are long registers. Thus the instruction moves the contents of long register 1 to long register 6, i.e., from L1 to fp.

If the opcode is changed to movw (move word), then the registers appearing in the instruction are word registers, so the instruction moves the contents of word register 1 to word register 6, i.e., from w1 to w6.

Note that fp (the frame pointer) and sp (the stack pointer) are long registers. Thus, any instruction that operates on long operands can operate on fp and sp. The q-operand

The q-operand is more complex than the r-operand since it may be a register, an immediate value, or a value in memory accessed via one of several addressing modes. The following options are encoded in the q-field:

|   | 7 | 6 | 5 | 4    | 3 |       |                       |
|---|---|---|---|------|---|-------|-----------------------|
|   | 0 | 0 |   | qreg |   | reg:  | register              |
|   | 0 | 1 |   | Lreg |   | b:    | base register         |
| I | 1 | 0 |   | Lreg |   | bd2:  | base register + disp2 |
|   | 1 | 1 | 0 | 0    | 0 | mema: | memory address        |
|   | 1 | 1 |   | ival |   | imm:  | immediate             |
| ļ | 1 | 1 | 1 | 1    | 1 | regx: | register extended add |

The regx option indicates that there are bytes following the qr-byte which specify the addressing mode. These bytes are described in detail in the following pages.

Before describing each of the q-operand options, some discussion of addresses and values is appropriate.

A q-operand can be either a value or an address. For example, when memory is moved to a register, the q-operand is a VALUE, namely, the contents of a memory location. However, when a register is moved to memory, the q-operand is an ADDRESS, namely, the address of the memory location where the register is to be stored.

For the reg and imm q-operand options, the distinction between values and addresses is not of great importance, because neither registers nor immediate values have addresses (although by stretching things a bit we could probably define some kind of addresses for them).

However, for all other q-operand options, the distinction between values and addresses is important, because these kinds of q-operands are addressing modes. Thus, for each mode the "effective address" is described. For an instruction which requires an address as a q-operand, the effective address is the operand. For an instruction which requires a value as a qoperand, the value stored at the effective address is the operand. The notation EA will be used for "effective address".

Now that the distinction between addresses and values is clear, each of the q-operand options are described in detail:

\* reg: register: q-operand is register contents

The 3-bit qreg field contains an integer which, when combined with the operand type, specifies a register. The encoding is exactly the same as for an r-operand register, as shown in the table for r-operands on a previous page.

\* b: base register: q-operand EA is long register contents

The 3-bit Lreg field contains an integer which specifies any one of the eight long registers, encoded exactly the same as for an r-operand register, as shown in the table for r-operands on a previous page.

The contents of the specified long register is the effective address. As an example of the use of this addressing mode, consider the C statement \*(P+1) = B, where B is a short and P is a pointer to short (both are globals). This can be implemented in VMAX as

| movl | Р  | L3   |              |
|------|----|------|--------------|
| addl | 2  | L3   | ; L3 = P + 1 |
| movw | В  | w0   |              |
| stow | w0 | [L3] | ; *L3 = B    |

Note that both sp and fp can be used in the Lreg field of the base register mode.

> This is the same as the base register mode except that the qr-byte is followed by a signed 2-byte displacement which is added to the contents of the long register specified by Lreg to determine the effective address. Conceptually the displacement is sign-extended to a 4-byte signed value before it is added to the register. (Note: The register contents are NOT changed by this mode.)

As an example, consider the following instruction which stores register w0 to memory. If L3 contains 10, then the instruction stores w0 into memory address 10+2 = 12.

|         |        | •          | qr-byte | -                |
|---------|--------|------------|---------|------------------|
| stow w0 | [L3+2] | <br>  stow |         | <br>  0002  <br> |

\* mema: memory address: q-operand EA is memory address in instruction

The qr-byte is followed by a 4-byte unsigned long which is the effective address. As an example, the following instruction stores register w0 into memory location 65536:

|            | •           | le qr-byt |             | •              |
|------------|-------------|-----------|-------------|----------------|
| stow w0 m6 | 5536   stow | ·<br>     | <br>  0   0 | 00010000  <br> |

\* imm: immediate: q-operand is an immediate value

The 3-bit ival field specifies the immediate value: 001 (imm\_1): -1 010 (imm0): 0 011 (imm1): +1 100 (immv): The immediate value follows the qr-byte 101 (imm2): 2-byte immediate value for long operands

When the immediate value is one of the special values -1, 0, or +1, then there is no need to follow the qr-byte with the value. Thus, the instruction is only 2 bytes long instead of 4 or more bytes. However, the actual operand represented by imm\_1, imm0, or imm1 depends on the operand type specified by the opcode:

| type                                         | imm_1                                                | imm⊙                                               | imm1                                                                 |
|----------------------------------------------|------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------|
| byte:<br>word:<br>long:<br>float:<br>double: | ff<br>ffff<br>ffffffff<br>bf800000<br>bff00000000000 | 00<br>0000<br>00000000<br>00000000<br>000000000000 | 01<br>0001<br>00000001<br>3f800000<br>3ff000000000000000000000000000 |
|                                              |                                                      |                                                    |                                                                      |

Similarly, in the immv case, the immediate value following the qr-byte depends on the operand type:

type immediate operand format byte: 2-byte integer; highorder byte always zero word: 2-byte integer long: 4-byte integer float: 4-byte float double: 8-byte double

Following are examples of immv, in which all types of the immediate value 3 are moved to registers. Note that the qr-bytes of all the instructions are identical, but the byte strings representing the immediate values are different, depending on the operand type indicated by the opcode:

|       |   |    | opcode<br>++      | qr-by1 | te | 2 bytes              |
|-------|---|----|-------------------|--------|----|----------------------|
| movbw | 3 | wO |                   | imm∨   | i  | 0003                 |
|       |   |    | opcode            | qr-by1 | te | 2 bytes              |
| mo∨w  | 3 | wO | <br>  mo∨w  <br>  | imm∨   | 0  | 0003                 |
|       |   |    | opcode            | qr-by1 | te | 4 bytes              |
| movl  | 3 | LO |                   | imm∨   | 0  | <br>  00000003  <br> |
|       |   |    | opcode            | qr-by1 | te | 4 bytes              |
| movf  | 3 | f0 | <br>  movf   <br> | imm∨   | 0  | 40400000  <br>       |
|       |   |    | opcode            | qr-by  | te | 8 bytes              |
| movd  | 3 | d0 | <br>  movd  <br>  | imm∨   | 0  | 4008000000000000000  |
|       |   |    | ++                |        | +  | ++                   |

The imm2 option can only be used with instructions that operate on long data. It indicates that the long immediate value following the qr-byte consists of only 2 bytes. Conceptually these 2 bytes are sign-extended to a 4-byte immediate value. Here is an example of an instruction which moves the value 3 to long register L0:

|      |   |    | •          | qr-byte      | •                |
|------|---|----|------------|--------------|------------------|
| movl | 3 | L0 | <br>  movl | imm2   0<br> | <br>  0003  <br> |

The imm2 option reduces the instruction length from 6 bytes to 4 bytes for many long instructions which have an immediate value.

\* regx: register extended addressing: q-operand specified by x-bytes

The regx option is not really an addressing mode. It is an escape code that indicates that one or two x-bytes follow the qr-byte.

The x-bytes specify one of these addressing modes for the q-operand:

i: index index + disp1 id1: id3: index + disp3 id4: index + disp4 b: base bd1: base + disp1 base + disp3 bd3: bd4: base + disp4 bi: base + index bid2: base + index + disp2 bid4: base + index + disp4

The first byte following the qr-byte is the x1-byte. Bits 4 and 5 of the x1-byte specify the major addressing mode:

| Bits | Meaning                       | Specified by     |  |  |  |  |
|------|-------------------------------|------------------|--|--|--|--|
| 0x   | Index register only           | x1-byte          |  |  |  |  |
| 10   | Base register only            | x1-byte          |  |  |  |  |
| 11   | Both base and index registers | x1- and x2-bytes |  |  |  |  |

The exact bit encoding of each addressing mode is shown in the following diagrams, where this notation is used:

| breg            | A 3-bit base register number (a long register)   |
|-----------------|--------------------------------------------------|
| ireg            | A 3-bit index register number (a long register)  |
| S               | An 2-bit index scale factor                      |
|                 | 00 = 1 (Note: Shifting the index reg.            |
|                 | 01 = 2 left by the number of bits in             |
|                 | 10 = 4 the s field is the same as mul-           |
|                 | <pre>11 = 8 tiplying by the scale factor.)</pre> |
| <0-byte>        | A byte consisting of all zero bits               |
| <dispn></dispn> | An N-byte displacement                           |

| Index Only                      | x1-byte      |                      |                 |  |  |  |
|---------------------------------|--------------|----------------------|-----------------|--|--|--|
| 7                               | 6 5 4 3 2 1  | Θ                    |                 |  |  |  |
| i:   0                          | 0 0   s   ir | eg   <0-byte>        |                 |  |  |  |
| id1:   0                        | 1 0   s   ir | eg   <disp1></disp1> |                 |  |  |  |
| id3:   1                        | 0 0   s   ir | eg   <disp3></disp3> |                 |  |  |  |
| id4:   1                        | 1 0   s   ir | eg   <0-byte>        | <disp4></disp4> |  |  |  |
| +                               |              |                      |                 |  |  |  |
| Base Only:                      | x1-byte      |                      |                 |  |  |  |
| 7                               | 654321       | Θ                    |                 |  |  |  |
|                                 | 0 1 0 0   br |                      |                 |  |  |  |
| bd1:   0                        | 1 1 0 0   br | eg   <disp1></disp1> |                 |  |  |  |
| bd3:   1                        | 0 1 0 0   br | eg   <disp3></disp3> |                 |  |  |  |
| bd4:   1                        | 1 1 0 0   br | eg   <0-byte>        | <disp4></disp4> |  |  |  |
| +                               |              |                      |                 |  |  |  |
| Base and Index: x1-byte x2-byte |              |                      |                 |  |  |  |

|       |   |   |   |   |   |   | 1 |   |   |   |  |   |   |     |   | F |                 |
|-------|---|---|---|---|---|---|---|---|---|---|--|---|---|-----|---|---|-----------------|
| bi:   | 0 | 0 | 1 | 1 | Θ | I |   | 0 | 0 | 0 |  | s | Ι | ire | g |   |                 |
| bid2: | 1 | 0 | 1 | 1 | 0 | I |   | 0 | 0 | 0 |  | s | Ι | ire | g |   | <disp2></disp2> |
| bid4: | 1 | 1 | 1 | 1 | Θ | I |   | 0 | 0 | 0 |  | s | Ι | ire | g |   | <disp4></disp4> |

Note that bits 6 and 7 of the x1-byte specify the displacement and/or 0byte filler needed for each addressing mode. In a sense, bits 6 and 7 are a submode of the major mode specified by bits 4 and 5.

The way in which the effective address of the q-operand is determined for the addressing modes above can be represented by this formula, where B is the contents of the base register, I is the contents of the index register, S is the scale factor, and D is the value of the displacement:

## B + S\*I + sign-extend(D)

This formula works for all the addressing modes if we define B as zero when there is no base register, I as zero when there is no index register, and D as zero when there is no displacement. (Note: A displacement is sign-extended to a 4-byte value before being used in an address calculation.)

[A note on unused bit patterns in the qr-format: The five bits of the q-field can store 32 different bit patterns. At present all bit patterns are used except for one:

#### 11110

The q-field never contains this bit pattern. Also, pattern 11101 (imm2) can only appear in instructions which operate on long data. Numerous bit patterns are not used in the two x-bytes. At some point the unused bit patterns should be listed so that the interpreter can test for them during error checking.]

Notation for qr Operands

In the description of a qr-format instruction, the following notation is used to show what types of operands the instruction takes:

| bvwbyte value (word register)bvlbyte value (long register)wvword valuelvlong valuefvfloat valuedvdouble valuebawbyte address (word register)balbyte address (long register)waword addresslalong address |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>wv word value<br/>lv long value<br/>fv float value<br/>dv double value<br/>baw byte address (word register)<br/>bal byte address (long register)<br/>wa word address</pre>                         |
| Ivlong valuefvfloat valuedvdouble valuebawbyte address (word register)balbyte address (long register)waword address                                                                                     |
| fvfloat valuedvdouble valuebawbyte address (word register)balbyte address (long register)waword address                                                                                                 |
| dvdouble valuebawbyte address (word register)balbyte address (long register)waword address                                                                                                              |
| baw byte address (word register)<br>bal byte address (long register)<br>wa word address                                                                                                                 |
| bal byte address (long register)<br>wa word address                                                                                                                                                     |
| wa word address                                                                                                                                                                                         |
| wa word address                                                                                                                                                                                         |
| la long address                                                                                                                                                                                         |
|                                                                                                                                                                                                         |
| fa float address                                                                                                                                                                                        |
| da double address                                                                                                                                                                                       |
| r-field                                                                                                                                                                                                 |
| wr word register                                                                                                                                                                                        |
| lr long register                                                                                                                                                                                        |
| fr float register                                                                                                                                                                                       |
| dr double register                                                                                                                                                                                      |

The r-field always specifies a register. The q-field, on the other hand, specifies either a value or an address. When an address is required, it means that the q-operand CANNOT be an immediate value. However, the q-operand can be a register. In effect, when an address is required, it means that the operand must be something in which values can be stored, i.e., a memory location or a register, but not an immediate value.

Here are some examples:

movl lv lr

The "move long" instruction requires a long VALUE as a q-operand (source), and a long register as an r-operand (destination).

stol lr la

The "store long" instruction requires a long ADDRESS as a q-operand (destination), and a long register as an r-operand (source). Decoding the q-field

Although the above list contains 12 specifiers for q-operands, the VMAX interpreter does not need 12 different functions for decoding a q-operand.

For example, the process of determining an address is exactly the same for all address specifiers, except when the "address" is a register. Also, except for immediate values, the process of determining a value consists of determining the address of the value, and then accessing the value at the address.

Thus, except for the reg and imm options of a q-operand, the type of operand (word, long, etc.) is not a factor in decoding the q-field. However, for reg and imm options the operand type is critical. For example, the bit pattern 000 stands for 4 different registers (w0, L0, f0, and d0) depending on the type of opcode. Also, the format of an immediate operand in an instruction depends on the opcode type.

The byte value and byte address specifiers (bvw, bvl, baw, and bal) require some discussion. The VMAX architecture is somewhat inconsistent when it comes to byte operands. It is possible to address individual bytes of memory and to move single bytes back and forth between memory and registers, but there are no byte registers. Thus, the loworder bytes of word and long registers are used as byte registers. This means that when a byte value or a byte address specifier is used, it is necessary to indicate whether the byte operand is in a word register or in a long register. Thus the suffixes "w" and "l" are appended to bv and ba, resulting in the specifiers bvw, bvl, baw, and bal.

It should be stressed that the "w" and "l" suffixes are only relevant for the reg q-operand option, not for any other options. For example, consider the description of the "move byte to loworder byte of word register" instruction:

movbw bvw wr

The q-operand is a byte value, and the r-operand is a word register. Thus,

movbw [sp+2] w3

moves the single byte stored at memory address sp+2 to the loworder byte of word register w3. The decoding of sp+2 does not depend on the fact that the q-operand is a byte or that the byte will be placed in a word register. However, in this instruction

movbw w2 w3

the q-operand is a register, so the "w" suffix of bvw indicates that the q-register is a word register, not a long register.

When the q-operand specifier is bow or bol, and the imm option is used, the format of the immediate value is the same: A 2-byte integer with a zero highorder byte. The "w" and "l" suffixes do not effect the format of an immediate value. All byte immediate values have the same format. For example, the following two instructions are bitwise identical except for the opcode bytes:

| mo∨bw | 18 | w0 |
|-------|----|----|
| movbl | 18 | L0 |

[Note: The VMAX inconsistency regarding bytes imposes a bit of a restriction on register-to-register moves of bytes: The source and destination registers of the move must be of the same type. For example, if the destination register is a word register, then the source register must also be a word register, even though from a strictly logical point of view, there is no reason why it shouldn't be possible for the source register to be a long register.] The qc Format

The qc-format instruction has exactly the same format as a qr-format instruction, except that the r-field is called the c-field, and it contains a condition code instead of a register number. Actually, the c-field only contains part of a condition code, namely, the loworder 3 bits of the code. The highorder bit of the code is determined by the opcode. There are only 4 instructions which use the qc-format, which is a special format for converting conditions into the values 0 and 1. This is best described by a discussion of two instructions:

setOw Store condition(0) in word
set1w Store condition(1) in word

The only difference between these two instructions is the way in which the condition code is created: For set0w, the condition code is the c-field with a zero bit appended at the beginning, and for set1w, the condition code is the c-field with a one bit appended at the beginning. In both cases, the result is a 4-bit condition code with a value in the range [0, 15]. See the description of the i-operand of the ij-format in a later section for all condition codes and what they mean.

The effect of set0w and set1w is simple: If the condition is TRUE, set the destination word to the value 1, otherwise set it to the value 0. The q-field describes the destination operand in exactly the same way as the q-field of a qr-format instruction. The q-field must describe an address (memory location or register); an immediate value is not allowed.

The other two instructions which have the qc-format are

set0l Store condition(0) in long
set1l Store condition(1) in long

The action of these instructions is exactly the same as set0w and set1w except that the type of the destination operand is long.

The qo Format

The qo-format instruction has exactly the same format as a qr-format instruction, except that the r-field is not used (it is always 000). The qo instructions are 1-operand instructions, most of which are push and pop instructions. Here is an example of a qo instruction which pushes long integer 2 onto the stack:

|       |   | • | qo-byte      | •     |
|-------|---|---|--------------|-------|
| pushl | 2 | l | imm2   0<br> | · · · |

The same operand specifiers used for the q-field of qr instructions are used for the q-field of qo instructions. Some examples:

pushl lv popd da The mr Format

The mr-format is used by only two instructions, gmov (general move) and gsto (general store). These instructions allow 1, 2, 4, or 8 bytes to be moved from memory to any register (and vice versa), and from any register type to any other register type.

An mr-format instruction consists of an opcode, an mr-byte, and a sequence of m-bytes.

| 1 byte             | 1 byte  | 2, 4, or 6 bytes    |
|--------------------|---------|---------------------|
| <br>  opcode  <br> | mr-byte | <br>  m-bytes  <br> |

The mr-byte consists of two fields, the m-field and the r-field:

| 7 6 5 4 3 |                | - | Θ |                 |
|-----------|----------------|---|---|-----------------|
| 1 1       | -fie]<br>3 bit |   |   | +<br> <br> <br> |

The m-field specifies the m-operand, a general operand (except that the m-operand cannot be an immediate value), and the r-field specifies the r-operand, which is always a register.

The sequence of m-bytes which may follow the mr-byte depends on the addressing mode specified in the m-field. All cases are described in detail in following sections.

The r-field contains a register number without regard to type. The 5-bits of this field contain a value from 0 through 31, which indicates a register as shown in the diagram in the General Registers section near the beginning of this document. Thus, 0 indicates w0, 9 indicates L1, and 31 indicates d7. Another way of looking at the r-field is to consider bits 3 and 4 as type bits, and bits 0, 1, and 2 as a register number within a type. The types are these:

| 00 | word   |
|----|--------|
| 01 | long   |
| 10 | float  |
| 11 | double |

### The m-field consists of two subfields:

| 7  | 6 | 5 |
|----|---|---|
| ++ |   | + |
|    |   | ļ |
| g  | n | ļ |
|    | _ |   |

The n-field specifies the number of bytes to move, using these encodings:

00 1 01 2 10 4 11 8

The g-field indicates an addressing mode. If g = 0, then the mr-byte is followed by a 4-byte memory address, which is the address to move to or from (this is equivalent to the mema addressing mode of the gr-format).

If g = 1, then the mr-byte is followed by one or two x-bytes, just as for the qr-format. Thus, all based, indexed, and based + indexed addressing modes are available for mr-format instructions. In addition, for the mrformat, the x-bytes can specify the following addressing mode (which is not available in the x-bytes of the qr-mode):

|       | x1-byte |   |   |   |   |   |   | Х | 2-b | yte |   |   |   |     |   |   |
|-------|---------|---|---|---|---|---|---|---|-----|-----|---|---|---|-----|---|---|
|       |         | - | - |   | - |   |   | - | 7   | -   | - |   | - |     |   | 0 |
| mreg: | 0       | 1 | 1 | 1 | 0 | Θ | Θ | 0 | 0   | 0   | Θ | I |   | mre | g |   |

The mreg is a 5-bit field specifying a register of any type, using the register numbers shown in the General Registers section near the beginning of this document. This addressing mode provides for register-to-register operations in the mr-format.

The operand specifiers for mr instructions are these:

| gv | general value    |
|----|------------------|
| ga | general address  |
| gr | general register |

The ir Format

The ir-format instruction has exactly the same format as a qr-format instruction, except that the q-field is a 5-bit integer instead of a general q-operand specifier. The r-field specifies a register, as in the qr-format. The integer in the i-field can be used for various purposes, depending on the opcode, but the most common use of this field is for a shift count in shift-immediate instructions. As an example, consider the following instruction which shifts word register w7 left by 14 bits:

|      |    |    | • | ir-byte | +         |
|------|----|----|---|---------|-----------|
| sliw | 14 | w7 |   |         | <br> <br> |

All ir instructions are 2-operand instructions in which one operand is a 5-bit integer and the other operand is a register.

The same operand specifiers used for the r-field of qr instructions are used for the r-field of ir instructions. The specifiers used for the ifield depend on the opcode; at present there is only one specifier:

> i-field sc shift count

An example of a description of a ir instruction:

sliw sc wr

The ij Format

The ij-format is used for conditional and unconditional jumps and calls. It specifies two operands, a condition and a memory address of an instruction. Any address in the VMAX address space can be specified with the ijformat.

An ij-format instruction consists of an opcode, an ij-byte, and, for some addressing modes, a sequence of j-bytes.

| 1 byte                 | 1 byte            | 0, 2, or 4 bytes |
|------------------------|-------------------|------------------|
| <br>  opcode<br> <br>+ | <br>  ij-byte<br> | j-bytes          |

The ij-byte consists of two fields, the i-field and the j-field:

|                  | 7 | 6           | 5            | 4 | 3               | 2 | 1            | 0 |                  |
|------------------|---|-------------|--------------|---|-----------------|---|--------------|---|------------------|
| +-<br> <br> <br> |   | i-f<br>(4 b | ield<br>its) |   | +<br> <br> <br> |   | ielc<br>its) |   | -+<br> <br> <br> |
| <br>+-           |   |             |              |   | <br>·+          |   |              |   | <br>-+           |

The i-field specifies a condition, and the j-field is an addressing mode for determining the target address of the instruction. The sequence of jbytes which may follow the ij-byte depends on the addressing mode specified in the j-field. The i-field, j-field, and j-bytes are described in detail in the following sections. The i-operand

The i-operand specifies a condition based on the bits in the flags register:

| i-field<br>  contents                                                                                                         |                                                                                    | sym-<br>  bol                                                                 | condition                                                                                                                                                                                                                                                                                                               | <br>  expression                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| <pre>0000 0001 0010 0011 0100 0111 0100 0111 0110 0111 1000 1001 1011 1000 1001 1011 1100 1101 1100 1110 1110 1110 1111</pre> | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15 | UNC<br>  LEU<br>  LU<br>  LE<br>  E<br>  GE<br>  GU<br>  GU<br>  GEU<br> <br> | unconditional<br>less than or equal unsigned<br>less than unsigned<br>less than signed<br>less than or equal signed<br>equal<br>not equal<br>greater than or equal signed<br>greater than signed<br>greater than unsigned<br>greater than or equal unsigned<br>RESERVED<br>RESERVED<br>RESERVED<br>RESERVED<br>RESERVED | TRUE  <br>LUF=1    EF=1 <br>LUF=1    EF=1 <br>EF=1    EF=1<br>EF=0  <br>GF=1    EF=1<br>GUF=1    EF=1<br>GUF=1    EF=1 |

When an ij instruction is executed, the result depends on the expression in the rightmost column above. If the expression is FALSE, then the ij instruction is equivalent to a NOP, i.e., control passes to the following instruction.

If the expression is TRUE, then pc is changed to the memory address specified by the j-operand, i.e., a jump or a call is performed.

Note that at present only 11 bit patterns are defined for the i-field. No bit patterns other than those shown above may appear in the i-field.

The j-operand

The j-operand is specified by one of these encodings in the j-field:

| ±            | 3 |   | 2 |   | 1   |  | 0         |         |                         |
|--------------|---|---|---|---|-----|--|-----------|---------|-------------------------|
|              | 0 |   |   | L | reg |  | <br> <br> | jregi:  | register-indirect       |
|              | 1 | Ι | 0 |   | 0   |  | 0         | pcrp:   | pc-relative-plus        |
|              | 1 |   | 0 |   | 0   |  | 1         | pcrm:   | pc-relative-minus       |
|              | 1 |   | 0 |   | 1   |  | 0         | jmema:  | memory-address          |
| +-<br> <br>+ | 1 |   | 0 |   | 1   |  | 1         | jmemai: | memory-address-indirect |
|              | 1 |   | 1 |   | 0   |  | 0         | sprmi:  | sp-relative-indirect    |

Each of the above kinds of j-operands is described in the following pages.

\* jregi: register-indirect: j-operand EA is long register contents

The 3-bit Lreg field contains an integer which specifies one of the eight long registers. The contents of the specified long register is the effective address to jump to or to call.

\* pcrp: pc-relative-plus: j-operand EA is pc contents plus an offset

The ij-byte is followed by a 2-byte unsigned offset which is scaled by a factor of 2. If the i-field condition is satisfied, then pc is changed like this:

pc = pc + 2\*offset

The offset is scaled so that the range of addresses reachable by this addressing mode is doubled. Since all instructions start at word boundaries, the loworder bit of an instruction address is always 0, so there is no need to carry it. Thus, this addressing mode can be used to reach any instruction located at an address in the range pc +  $[0, 2^{17}-2 = 131, 070]$ .

The C compiler generates jump instructions using the pcrp and pcrm modes, so the maximum safe size for a C function is 128KB. This should not be a restriction. Any C function which results in code of such a size is probably a logical mess which should be rewrit-

ten anyway. (Note: One of the advantages of using pc-relative addresses for jump instructions is that such instructions do not need to be relocated.)

At the point when pc is incremented, it addresses the byte following the current instruction. Thus, if the offset is zero, the effect is the same as a NOP: Control passes to the next instruction just as if the jump condition were not satisfied.

Here is an example of an unconditional jump to pc+8:

|      |     |        | •              | ij-byte<br>+        | •                |
|------|-----|--------|----------------|---------------------|------------------|
| jump | UNC | pcrp 8 | <br>  jump<br> | <br>  UNC  pcrp<br> | <br>  0008  <br> |

\* pcrm: pc-relative-minus: j-operand EA is pc contents minus an offset

This mode is exactly the same as pcrp except that the 2-byte unsigned offset is subtracted from pc:

$$pc = pc - 2*offset$$

This addressing mode can be used to reach any instruction located at an address in the range  $pc - [0, 2^{17-2} = 131,070]$ .

\* jmema: memory-address: j-operand EA is memory address in instruction

The ij-byte is followed by a 4-byte unsigned long which is the effective address. This address is placed in pc (without scaling) to transfer control. Note that any address in the VMAX address space can be reached with the jmema addressing mode.

As an example, the following instruction jumps to address 65536:

|      |     |        | •                | ij-byte | -                    |
|------|-----|--------|------------------|---------|----------------------|
| jump | UNC | m65536 | <br>  jump  <br> |         | <br>  00010000  <br> |

\* jmemai: memory-address-indirect: j-operand EA is memory address in instruction, indirect

The ij-byte is followed by a 4-byte unsigned long which is the address of a memory location where the effective address is located. The effective address is moved to pc to transfer control.

As an example, if 00000004 is stored at memory address 65536, then the following instruction jumps to memory address 4:

|      |     |          | •              | ij-byte         |                |
|------|-----|----------|----------------|-----------------|----------------|
| jump | UNC | [m65536] | <br>  jump<br> | UNC  memai <br> | 00010000  <br> |

sprmi: sp-relative-indirect: j-operand EA is in the stack

The ij-byte is followed by a 2-byte unsigned offset which is scaled by a factor of 2. If the i-field condition is satisfied, then pc is changed like this:

pc = [sp - 2 \* offset]

In other words, the long value located on the stack at address sp-2\*offset is the address to jump to. This mode is similar to pcrm in that the ij-byte is followed by a 2-byte scaled offset. However, this offset is relative to sp rather than to pc, and a level of indirectness is involved.

The sprmi mode is a bit ad hoc, but it turns out to be quite useful in the epilogue of a C function when the function pops its own arguments off the stack, and there are more than 510 bytes of arguments (which means that leave, leaveres, and ret cannot be used to pop the arguments and return).

[Note: The bit patterns 1101, 1110, and 1111 are currently not used in the j-field. Thus, up to 3 more addressing modes for jump and call instructions could be defined. Also, it is not clear if the jmemai mode is really useful for code generated by a compiler. As experience is gained with GCC and how it deals with jumps and calls, it may turn out that the the j-field addressing modes should be reconsidered.] Notation for ij Operands

In the description of an ij-format instruction, the notation used to show what types of operands the instruction takes is very simple:

i-field cc condition code

j-field ma memory address

The a3 Format

The a3-format is used for unconditional jumps and calls. These instructions consist of an opcode and a 3-byte operand:

| 1 byte                 | 3 bytes |
|------------------------|---------|
| <br>  opcode<br> <br>+ | offset  |

The operand is a 3-byte unsigned offset which is scaled by a factor of 2. This offset is used to change pc like this:

pc = pc + - 2\*offset

Whether the offset is added or subtracted depends on the opcode (the following instructions are the only ones which have the a3 format):

opcode instruction change to pc jumpf jump forward Add offset to pc callf call forward Add offset to pc jumpb jump backward Subtract offset from pc callb call backward Subtract offset from pc A jump or call using the a3-format can reach a memory address as far away as 2^25-2 = 33,554,430.

The C compiler generates call instructions using the a3-format, so the maximum safe size for a compiled C program is 32MB. This should be big enough for the near future. (Note: If a program gets too large, the compiler can be told to generate ij-format calls with the mema option. This will increase the size of every call from a 4-byte instruction to a 6-byte instruction, but then there are no limits at all except for the 4GB address space.)

One of the advantages of using the a3 format for calls is that no relocation is needed for these instructions.

At the point when pc is incremented or decremented, it addresses the byte following the current instruction.

The specifier used in descriptions of a3 instructions is

ma3 3-byte memory address

An example of a description of an a3 instruction:

jumpf ma3

The b1 Format

The b1-format is used for instructions which require only a single byte as an operand:

| ,                       | 1 byte  |
|-------------------------|---------|
| ++<br>     <br>  opcode | operand |
| ++                      | ·+      |

The 1-byte operand is used for various purposes, depending on the opcode. See the descriptions of the enter and ret instructions for examples.

The specifiers used in descriptions of b1 instructions depend on the opcode; at present there is only one specifier:

stkc stack change

50

An example of a description of a b1 instruction:

ret stkc

The b14 Format

The b14-format is the same as the b1 format with an additional 4-byte operand:

The two operands are used for various purposes, depending on the opcode. See the descriptions of the entersav and leaveres instructions for examples.

The specifiers used in descriptions of b14 instructions depend on the opcode; at present only these specifiers are used:

> stkc stack change bmsk bit mask

An example of a description of a b14 instruction:

entersav stkc bmsk

The n0 Format

The n0-format is used for instructions which have no operands at all:

1 byte 1 byte +----+ | opcode | 00000000 | | | | |

Since an instruction must be an even number of bytes long, the opcode of an n0-format instruction is followed by a single byte which is always zero. Examples of n0-format instructions are nop and halt.

The n04 Format

The n04-format is the same as the n0 format with an additional 4-byte operand:

| 1 byte           | 1 byte             | 4 bytes |
|------------------|--------------------|---------|
| <br>  opcode<br> | <br>  00000000<br> | operand |

The operand is used for various purposes, depending on the opcode. See the descriptions of the pushregs and popregs instructions for examples.

The specifiers used in descriptions of nO4 instructions depend on the opcode; at present only one specifiers is used:

bmsk bit mask

An example of a description of a n04 instruction:

popregs bmsk

#### Instruction Set Summary by Function

Data Movement Instructions

Move Instructions

[Terminology: For VMAX instructions, "move" means move TO a register, and "store" means store FROM a register (usually into memory).]

The following instructions move an operand (memory, immediate, or register) to a register:

| mo∨w  | Move word                          |
|-------|------------------------------------|
| mo∨l  | Move long                          |
| mo∨f  | Move float                         |
| mo∨d  | Move double                        |
| movbw | Move byte to loworder byte of word |
| movbl | Move byte to loworder byte of long |
| movwl | Move word to loworder word of long |
| gmov  | General move                       |

For movw, movl, movf, and movd, the source and destination operands are of the same type. For movbw and movbl, the source operand is a byte, and the destination operand is a word register (movbw) or a long register (movbl). These move instructions change ONLY the loworder byte of the destination register; the other bytes in the destination register are left unchanged. The movwl instruction moves a word to a long register, changing ONLY the loworder word of the long register.

The general move instruction, gmov, is provided to allow data of any type to be moved to any type of register, using multiple registers if needed. This instruction allows 1, 2, 4, or 8 bytes to be moved from any register or from memory to any register. For example, a double register can be moved to 4 word registers with gmov, or 8 bytes of memory can be moved to 2 long registers. The source operand of gmov cannot be an immediate value.

[Note: GCC uses all the move instructions defined above. However, at the moment GCC does not utilize the fact that movbw, movbl, and movwl leave part of the destination register unchanged. It seems that GCC has the capability to use this fact, but it is not yet clear how to tell GCC about this. The gmov instruction was defined solely because GCC requires it. However, it turns out that it is probably a convenient and useful instruction to have anyway.]

Store Instructions

[Terminology: For VMAX instructions, "move" means move TO a register, and "store" means store FROM a register (usually into memory).]

The following instructions store a register into memory:

| stow  | Store word                            |
|-------|---------------------------------------|
| stol  | Store long                            |
| stof  | Store float                           |
| stod  | Store double                          |
|       |                                       |
| stowb | Store loworder byte of word into byte |
| stolb | Store loworder byte of long into byte |
|       |                                       |
| stolw | Store loworder word of long into word |
|       |                                       |
| gsto  | General store                         |

For stow, stol, stof, and stod, the source and destination operands are of the same type. For stowb and stolb, the source operand is the loworder byte of a word register (stowb) or a long register (stolb), and the destination is a single byte. These instructions change ONLY one byte. The stolw instruction stores the loworder word of a long register into a word.

The general store instruction, gsto, is provided to allow any type of data to be stored from any type of register into memory. This instruction allows 1, 2, 4, or 8 bytes to be stored from any register (or group of contiguous registers) into memory. For example, 2 word registers can be stored into 4 bytes of memory with gsto, or 2 long registers can be stored into 8 bytes of memory.

[Note: GCC uses all the store instructions defined above. The gsto instruction was defined solely because GCC requires it. However, it turns out that it is probably a convenient and useful instruction to have anyway.]

Note that sto instructions can be used to move from register to register. However, this is usually done with a mov instruction rather than with a sto instruction. [Perhaps we should not allow a sto instruction to be used for register-to-register moves?] Load Address Instruction

There is one instruction for loading an address into a register:

leal Load effective address

This instruction computes the effective address of its operand and places the effective address in a long register. It is also possible to use leal to perform calculations on the contents of long registers. For example, if L0 is referenced as a base register and L1 is referenced as an index register, leal can be used to add the contents of L0 and L1 and place the result in a third long register, say L2.

[Note: GCC uses the leal instruction.]

Flags Instruction

The following instructions load and store the flags register:

| movflags | Move word to flags register    |
|----------|--------------------------------|
| stoflags | Store flags register into word |
| set0w    | Store condition(0) into word   |
| set1w    | Store condition(1) into word   |
| set0l    | Store condition(0) into long   |
| set1l    | Store condition(1) into long   |

The movflags instruction moves a 16-bit value into the flags register, changing all the flags. The stoflags instruction stores the flags register into a word. Thus, individual flag bits or groups of bits can be changed by moving the flags register into a word register with stoflags, changing bits of the word register, and then moving the word register to the flags register with movflags.

The set instructions are used to store a 0 or a 1 into a word or a long, depending on the condition codes.

[Note: GCC uses the set instructions, but it does not use movflags and stoflags.]

## Arithmetic Instructions

## Add Instructions

The following instructions perform addition operations, producing a sum from two addends:

| addw             | Add | word                                         |
|------------------|-----|----------------------------------------------|
| addl             | Add | long                                         |
| addf             | Add | float                                        |
| addd             | Add | double                                       |
| addcl            | Add | long with carry                              |
| adduwl<br>addswl |     | unsigned word to long<br>signed word to long |

For a given add instruction, the addends and sum are all of the same type except for adduwl and addswl. For these two instructions the addends are words, but the sum is long.

Note that addw can be used for both unsigned addition and signed addition. The same is true of addl.

[Note: GCC uses all the add instructions defined above except for addcl, adduwl, and addswl. These instructions can probably be used in a VMAX C program via the asm feature which allows assembly language to be embedded in C source code. Combining this with the in-line function capability of GCC should make these instructions usable in a fairly reasonably way.]

Subtract Instructions

The following instructions perform subtraction operations, producing a difference from two operands:

| subw   | Subtract word                    |
|--------|----------------------------------|
| subl   | Subtract long                    |
| subf   | Subtract float                   |
| subd   | Subtract double                  |
| subcl  | Subtract long with carry         |
| subuwl | Subtract unsigned word from long |
| subswl | Subtract signed word from long   |
| negw   | Negate word                      |
| negl   | Negate long                      |
| negf   | Negate float                     |
| negd   | Negate double                    |

For a given subtraction instruction, the operands and difference are all of the same type except for subuwl and subswl. For these two instructions the operands are words, but the difference is long.

Note that subw can be used for both unsigned subtraction and signed subtraction. The same is true of subl.

The negate instructions perform arithmetic negation operations on their operands. (The negate instructions are unary in one sense, but binary in another: The negation of the source operand is placed in the destination register. Thus, both a negation and a move are performed in the general case.)

[Note: GCC uses all the subtraction instructions defined above except for subcl, subuwl, and subswl. These instructions can probably be used via asm and in-line functions, as discussed in the above section on add instructions.]

Multiply Instructions

The following instructions perform multiplication operations generating a product from a multiplier and a multiplicand:

| muluw<br>mulsw   |                      | unsigned word<br>signed word                               |
|------------------|----------------------|------------------------------------------------------------|
| mulul<br>mulsl   |                      | unsigned long<br>signed long                               |
| mulf<br>muld     | Multiply<br>Multiply |                                                            |
| muluwl<br>mulswl |                      | unsigned words yielding long<br>signed words yielding long |

For a given multiply instruction, the multiplier, multiplicand, and product are all of the same type except for muluwl and mulswl. For these two instructions the multiplier and multiplicand are words, but the product is long.

[Note: GCC uses all the multiply instructions defined above.]

Divide Instructions

The following instructions perform division operations, producing a quotient, a remainder, or both:

| divuw   | Divide unsigned word                        |
|---------|---------------------------------------------|
| divsw   | Divide signed word                          |
| divul   | Divide unsigned long                        |
| divsl   | Divide signed long                          |
| divf    | Divide float                                |
| divd    | Divide double                               |
| remuw   | Remainder unsigned word                     |
| remsw   | Remainder signed word                       |
| remul   | Remainder unsigned long                     |
| remsl   | Remainder signed long                       |
| divruw  | Divide with remainder unsigned word         |
| divrsw  | Divide with remainder signed word           |
| divrul  | Divide with remainder unsigned long         |
| divrsl  | Divide with remainder signed long           |
| divrulw | Divide with remainder unsigned long by word |
| divrslw | Divide with remainder signed long by word   |

The first group of instructions (div) produce only a quotient; no remainder is calculated. The second group of instructions (rem) produce only a remainder; no quotient is calculated. The third group of instructions (divr) produce both a quotient and a remainder. (Actually, divr instructions produce both a quotient and a remainder ONLY when the divisor is in a register. If the divisor is not in a register, then no remainder is produced.)

This table shows divide instructions grouped by operand type to make clear which operations are available for which data types:

| operand types                                                                                                             | divide                                           | remainder                        | both                                                       |
|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|----------------------------------|------------------------------------------------------------|
| unsigned word<br>signed word<br>unsigned long<br>signed long<br>unsigned long/word<br>signed long/word<br>float<br>double | divuw<br>divsw<br>divul<br>divsl<br>divf<br>divf | remuw<br>remsw<br>remul<br>remsl | divruw<br>divrsw<br>divrul<br>divrsl<br>divrulw<br>divrslw |
|                                                                                                                           |                                                  |                                  |                                                            |

For a given divide instruction, the divisor, dividend, quotient, and remainder are all of the same type except for divrulw and divrslw. For

these two instructions the divisor, quotient, and remainder are words, but the dividend is long.

[Note: GCC uses all the divide instructions defined above except for divrulw and divrslw, the instructions which divide a long by a word and produce word results. GCC can use an instruction which divides an 8-byte integer by a long, but it does not seem useful to have such an instruction for VMAX, since VMAX does not support integers longer than 4 bytes. The divrulw and divrslw instructions can probably be used via asm and inline functions, as discussed in the above section on add instructions.]

Since integer division of signed quantities can be defined in more than one way, it is important to make clear just what VMAX integer division instructions do. We use the following notation:

d - divisor (denominator)
n - dividend (numerator)
q - quotient
r - remainder

Given inputs d and n, the VMAX divide instructions produce the unique q and r which satisfy these relationships:

| Unsigned: | n = d * q + r<br>0 <= r < q                       |
|-----------|---------------------------------------------------|
| Signed:   | n = d * q + r<br>sgn(r) = sgn(n)<br>0 <=  r  <  q |

Note that in signed division, if n is negative and r != 0, then r is negative. Thus, the remainder produced by a VMAX divide instruction is NOT n mod d in the mathematical sense (because n mod d is usually defined to be a nonnegative value). However, the mathematical mod function is rather easily obtained from the remainder:

if (r < 0) r += abs(d);

[Note: If we later want to add some VMAX instructions to compute the mathematical mod, it might be a good idea to look at the Intel 80960MC. This machine has separate instructions for remainder (as it is defined for VMAX) and mod. The mod instructions produce a remainder with the same sign as the divisor (instead of with the same sign as the dividend).]

This section concludes with detailed definitions and examples of unsigned and signed division:

Unsigned integer division: Input: There are two unsigned inputs: n is the dividend (numerator) d is the divisor (denominator) Output: If d = 0 then an exception is generated. Otherwise, there are two outputs: q is the quotient r is the remainder The outputs are the unique unsigned integers which satisfy the following: n = d \* q + r0 <= r < qNotes: If n, d, q, and r are all the same type (i.e., consist of the same number of bits), then unsigned division can NEVER result in overflow. Examples: n/d q r d\*q+r=n -----

Signed integer division: Input: There are two signed inputs: n is the dividend (numerator) d is the divisor (denominator) Output: If d = 0 then an exception is generated. Otherwise, there are two outputs: q is the quotient r is the remainder The outputs are the unique signed integers which satisfy the following: n = d \* q + rsgn(r) = sgn(n)0 <= |r| < |q|Notes: If n and d are both nonnegative, then signed division produces exactly the same outputs as unsigned division. If n, d, q, and r are all the same type (i.e., consist of the same number of bits), then signed division can occur in ONLY ONE case: n = smallest possible negative number, and q = -1. In this case, the quotient is the largest positive number + 1, which is too big to fit. For example, if the operands are 16 bits long, then -32768/-1 = +32768, and +32767 is the largest positive number that will fit in a 16-bit signed quantity. Examples: n/d qr d\*q+r=n 

| -1 / 4<br>-2 / 4<br>-3 / 4<br>-4 / 4<br>-5 / 4<br>-6 / 4<br>-7 / 4<br>-8 / 4         | 0<br>0<br>-1<br>-1<br>-1<br>-1<br>-1 | -2<br>-3<br>0<br>-1<br>-2<br>-3            | 4 * 0 + -1 = -1 $4 * 0 + -2 = -2$ $4 * 0 + -3 = -3$ $4 * -1 + 0 = -4$ $4 * -1 + -1 = -5$ $4 * -1 + -2 = -6$ $4 * -1 + -3 = -7$ $4 * -2 + 0 = -8$ |
|--------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| -1 / -4<br>-2 / -4<br>-3 / -4<br>-4 / -4<br>-5 / -4<br>-6 / -4<br>-7 / -4<br>-8 / -4 | 0<br>0<br>1<br>1<br>1<br>2           | -1<br>-2<br>-3<br>0<br>-1<br>-2<br>-3<br>0 | $\begin{array}{rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr$                                                                                             |

# Other Arithmetic Instructions

The following instructions take absolute values and square roots:

| absw           | Absolute value of word                        |
|----------------|-----------------------------------------------|
| absl           | Absolute value of long                        |
| absf           | Absolute value of float                       |
| absd           | Absolute value of double                      |
| sqrtf<br>sqrtd | Square root of float<br>Square root of double |

[Note: GCC uses all the instructions defined above.]

Shift Instructions

The following instructions perform shift and rotate operations:

General shift instructions:

| slw  | Shift left word             |
|------|-----------------------------|
| sll  | Shift left long             |
| srlw | Shift right logical word    |
| srll | Shift right logical long    |
| sraw | Shift right arithmetic word |
| sral | Shift right arithmetic long |

Shift count is an immediate operand:

| sliw  | Shift left immediate word             |
|-------|---------------------------------------|
| slil  | Shift left immediate long             |
| srliw | Shift right logical immediate word    |
| srlil | Shift right logical immediate long    |
| sraiw | Shift right arithmetic immediate word |
| srail | Shift right arithmetic immediate long |

General rotate instructions:

| rlw<br>rll | <br>left word<br>left long |
|------------|----------------------------|
| rrw<br>rrl | right word<br>right long   |

Rotate count is an immediate operand:

| rliw | Rotate left immediate word  |
|------|-----------------------------|
| rlil | Rotate left immediate long  |
| rriw | Rotate right immediate word |
| rril | Rotate right immediate long |

Only word registers and long registers can be shifted. There are three different kinds of shifts:

| left             | shift to | the left,  | fill with zero bit |
|------------------|----------|------------|--------------------|
| right logical    | shift to | the right, | fill with zero bit |
| right arithmetic | shift to | the right, | fill with sign bit |

Each shift instruction comes in two forms: The shift count is a general

operand, or the shift count is an immediate value. The latter type of shift instructions are shorter than the general shift instructions.

Rotate instructions are very similar to shift instructions, but bits shifted out of one end of a register are shifted into the other end of the register.

Logical Instructions

The following instructions perform logical operations:

| andw | And word          |
|------|-------------------|
| andl | And long          |
| orw  | Or word           |
| orl  | Or long           |
| xorw | Exclusive or word |
| xorl | Exclusive or long |
| notw | Not word          |
| notl | Not long          |

The and, or, and xor instructions perform the usual bitwise logical operations on their two operands. The not instructions perform logical negation operations on their operands. (The not instructions are unary in one sense, but binary in another: The negation of the source operand is placed in the destination register. Thus, both a negation and a move are performed, in the general case.)

[Note: GCC uses all the logical instructions defined above.]

Convert Instructions

The following instructions convert from one type of data to another type of data:

| Byte -> Word     |                                           |
|------------------|-------------------------------------------|
| cvtbzw           | Convert byte zero-extended to word        |
| cvtbsw           | Convert byte sign-extended to word        |
| Byte -> Long     |                                           |
| cvtbzl           | Convert byte zero-extended to long        |
| cvtbsl           | Convert byte sign-extended to long        |
| Word -> Long     |                                           |
| cvtwzl           | Convert word zero-extended to long        |
| cvtwsl           | Convert word sign-extended to long        |
| Long -> Float    |                                           |
| cvtulf           | Convert unsigned long to float            |
| cvtslf           | Convert signed long to float              |
| Long -> Double   |                                           |
| cvtuld           | Convert unsigned long to double           |
| cvtsld           | Convert signed long to double             |
| Float -> Long    |                                           |
| cvttful          | Convert truncated float to unsigned long  |
| cvttfsl          | Convert truncated float to signed long    |
| Double -> Long   |                                           |
| cvttdul          | Convert truncated double to unsigned long |
| cvttdsl          | Convert truncated double to signed long   |
| Float <-> Double |                                           |
| cvtdf            | Convert double to float                   |
| cvtfd            | Convert float to double                   |

It is important to note that cvttful, cvttfsl, cvttdul, and cvttdsl convert from floating to integer by TRUNCATING TOWARD ZERO. This is exactly what is wanted for C, but it does not conform to the IEEE 754 standard for floating point operations, which defines a variety of rounding methods, usually controlled by rounding control bits of a floating point control word. Later we may want to define other floating -> integer conversion instructions which take rounding control bits into account. This is done on the Intel 80960MC: There are floating -> integer conversion instructions which ignore the rounding control bits, and there are floating -> integer conversion instructions which use the rounding control bits.

Later it may also prove useful to provide an instruction which truncates a floating value to a FLOATING integer. However, such an instruction does not seem to be required by GCC, so for now we forget about it.

Although VMAX provides numerous conversion instructions, there is not one instruction for every type of conversion required by C. For example, there is no instruction to convert a word to a floating value. The table on the following page shows how all possible C conversions can be implemented with VMAX instructions. A single instruction suffices except when integers other than longs are converted to floating, and vice versa. In these cases, two VMAX instructions are needed. (Of course, if it proves useful, we can later define other conversion instructions, e.g., word to double.)

Some of the conversions shown in the following table may seem somewhat peculiar. For example, if the value 0xff stored in a signed char is converted to to an unsigned short, the result is 0xffff, i.e., the source value is sign-extended to the size of the destination value. Since the destination is an unsigned entity, it might seem that the converted value should be 0x00ff. However, according to ANSI C, the correct thing to do is to sign-extend. As best as could be determined, all conversions shown in the table conform to ANSI C (and Microsoft C 5.1 and 6.0).

[Note: GCC uses all the conversion instructions defined above.]

# VMAX Instructions for C Type Conversions

| ·+<br>\               | +                     | +                     | +               | +           | +               | +       | +                     | +<br>             |
|-----------------------|-----------------------|-----------------------|-----------------|-------------|-----------------|---------|-----------------------|-------------------|
| `\ to <br>from \      | UCHAR                 | SCHAR<br>             | UWORD           | SWORD       | ULONG           | SLONG   | FLOAT                 | DOUBLE            |
| UCHAR                 | X                     | <br>  SBP<br>         | <br> cvtbzw<br> | cvtbzw      | <br> cvtbzl     |         |                       | cvtbzl<br> cvtuld |
| SCHAR                 | <br>  SBP<br>         | <br>  X<br>           | <br> cvtbsw<br> | <br> cvtbsw | <br> cvtbsl<br> |         | cvtbsl<br> cvtslf     |                   |
| +<br> <br>UWORD  <br> | <br> stowb            | <br> stowb            | <br>  X<br>     | SBP         | <br> cvtwzl     |         | cvtwzl<br> cvtulf<br> | cvtwzl<br> cvtuld |
| SWORD                 | <br> stowb            | <br> stowb            | <br>  SBP<br>   | x           | <br> cvtwsl     |         | cvtwsl<br> cvtslf<br> |                   |
| ULONG                 | <br> stolb            | <br> stolb            | <br> stolw      | <br> stolw  | X               | SBP     | <br> cvtulf           | <br> cvtuld       |
| SLONG                 | <br> stolb            | <br> stolb            | <br> stolw      | <br> stolw  | <br>  SBP<br>   | x       | <br> cvtslf           | <br> cvtsld       |
| FLOAT                 | cvttfsl<br> stolb<br> |                       |                 |             | <br> cvttful    | cvttfsl | x                     | <br>  cvtfd       |
| DOUBLE                | cvttdsl<br> stolb<br> | cvttdsl<br> stolb<br> |                 |             |                 | cvttdsl | cvtdf                 | <br>  X<br>       |

SBP: Same Bit Pattern

X: No conversion needed

VMAX type C type

| C ' | נט | УI | p | e |
|-----|----|----|---|---|
|     |    |    |   |   |

| UCHAR  | signed byte   | signed char    |
|--------|---------------|----------------|
| SCHAR  | unsigned byte | unsigned char  |
| UWORD  | unsigned word | unsigned short |
| SWORD  | signed word   | signed short   |
| ULONG  | unsigned long | unsigned long  |
| SLONG  | signed long   | signed long    |
| FLOAT  | float         | float          |
| DOUBLE | double        | float          |

#### Compare Instructions

The following instructions compare two operands:

| cmpw<br>cmpl<br>cmpf<br>cmpd | Compare<br>Compare<br>Compare<br>Compare | long<br>float        |  |  |  |
|------------------------------|------------------------------------------|----------------------|--|--|--|
| cmpwb<br>cmplb               |                                          | loworder<br>loworder |  |  |  |

For all the compare instructions, the two operands to be compared are of the same type. However, since VMAX has no byte registers, at least one operand of a byte compare must be in either a word register or a long register. The cmpwb and cmplb instructions handle these two cases.

[Note: GCC uses all the compare instructions defined above.]

The floating point compare instructions cmpf and cmpd set a single flag bit and clear the others. Only these three patterns are possible:

| LU L EQ G GU Exam | ples                                                      |
|-------------------|-----------------------------------------------------------|
| 00100 comp        | pare 3.0 and -1.0<br>pare 3.0 and 3.0<br>pare 1.0 and 3.0 |

The fixed point compare instructions cmplb, cmpwb, cmpw, and cmpl set one or two flag bits and clear the others. In concept, fixed point compare instructions involve three steps:

- 1. Clear all the flag bits to zero.
- 2. Compare the operands as unsigned values and set a single bit.
- 3. Compare the operands as signed values and set a single bit.

If the operands are equal (bit-for-bit the same), then steps 2 and 3 above both set the EQ bit. Thus, only one bit of the five is set. However, if the operands are not equal, then two of the five bits are set. Step 2 sets one of LTU or GTU, and step 3 sets one of LT or GT. Thus a total of five patterns are possible:

| LU | L | EQ | G | GU | Examples (bytes | ) Uns  | signed  | Signed      |
|----|---|----|---|----|-----------------|--------|---------|-------------|
| 0  | 0 | 0  | 1 | 1  | compare Of and  |        | and 1   | . 15 and 1  |
| 0  | 1 | 0  | 0 | 1  | compare ff and  | 0f 255 | and 15  | 5 -1 and 15 |
| 1  | 0 | 0  | 1 | Θ  | compare Of and  | ff 15  | and 255 | 5 15 and -1 |
| Θ  | 0 | 1  | 0 | 0  | compare ff and  | ff 255 | and 255 | 5 -1 and -1 |
| 1  | 1 | 0  | 0 | 0  | compare 01 and  | 0f 1   | and 15  | 5 1 and 15  |

When the patterns resulting from floating point compares are combined with those resulting from fixed point compares, a total of seven distinct patterns are possible:

|   | LU | L | EQ | G | GU | Decimal value |
|---|----|---|----|---|----|---------------|
| - | 0  | 0 | 0  | 1 | 0  | 2             |
|   | 0  | 0 | 0  | 1 | 1  | 3             |
|   | 0  | 0 | 1  | 0 | 0  | 4             |
|   | 0  | 1 | 0  | 0 | 0  | 8             |
|   | 0  | 1 | 0  | 0 | 1  | 9             |
|   | 1  | 0 | 0  | 1 | 0  | 18            |
|   | 1  | 1 | 0  | Θ | 0  | 24            |
|   |    |   |    |   |    |               |

# Jump Instructions

The following instructions jump and call functions, both conditionally and unconditionally:

| call     | Call                                 |
|----------|--------------------------------------|
| callb    | Call backward                        |
| callf    | Call forward                         |
| jump     | Jump                                 |
| jumpb    | Jump backward                        |
| jumpf    | Jump forward                         |
| ret      | Return from call                     |
| leave    | Leave function                       |
| leaveres | Leave function and restore registers |

Except for the fact that call instructions push the program counter onto the stack, call and jump instructions behave in the same way, so in the following only jump instructions are discussed.

The jump instruction either jumps or doesn't based on the condition bits in the instruction and the current settings of the condition codes. The following conditions can be tested for:

| UNC | Unconditional                    |
|-----|----------------------------------|
| LU  | Less than (unsigned)             |
| LEU | Less than or equal (unsigned)    |
| L   | Less than                        |
| LE  | Less than or equal               |
| EQ  | Equal                            |
| NE  | Not equal                        |
| GE  | Greater than or equal            |
| G   | Greater than                     |
| GEU | Greater than or equal (unsigned) |
| GU  | Greater than (unsigned)          |

A jump instruction also specifies one of several jump adressing modes, as described in an earlier section. One of the modes specifies a 4-byte absolute address, so any instruction in a 4-gigabyte address space can be reached with a jump instruction.

The jump forward and jump backward instructions are unconditional. These instructions jump relative to the program counter with a range of 32MB.

The return instruction is used to exit a function and return to the caller, possible clearing arguments from the stack. The leave instruction is similar, but it does even more stack cleanup. The leaveres instruction is the same as the leave instruction, but it restores registers saved in the stack.

[Note: GCC uses all the instructions defined above.]

Stack Instructions

The following instructions operate on the stack:

| pushw    | Push word                         |
|----------|-----------------------------------|
| pushl    | Push long                         |
| pushf    | Push float                        |
| pushd    | Push double                       |
| pushregs | Push multiple registers           |
| popw     | Pop word                          |
| popl     | Pop long                          |
| popf     | Pop float                         |
| popd     | Pop double                        |
| popregs  | Pop multiple registers            |
| enter    | Enter function                    |
| entersav | Enter function and save registers |

The push and pop instructions allow data of all types to be pushed onto the stack and popped off the stack. The pushregs instruction allows any subset of the 32 major VMAX registers to be pushed with one instruction; popregs is the inverse function.

The enter and entersav instructions are used to handle common operations required upon function entry. The entersav instruction performs the same tasks as enter, and in addition it saves registers in the stack.

[Note: GCC uses all the instructions defined above.]

Miscellaneous Instructions

The following instructions do not fit in any other categories:

| halt | Halt the VMAX machine |
|------|-----------------------|
| nop  | No operation          |

[Note: Surprisingly enough, GCC uses nop: In certain instances when GCC is not optimizing, a nop is generated as a convenient place to attach a label that might be helpful when running a debugger on the compiled program. GCC does not use the halt instruction.]

#### Notation Sumary

Most of the notation used in the following instruction descriptions has already been defined earlier in this document, but for ease of reference, all the notation is summarized here in one place.

| qr instructions:                                   | q-operand                                                      | r-operand                     |  |  |  |  |
|----------------------------------------------------|----------------------------------------------------------------|-------------------------------|--|--|--|--|
| q-operand is<br>bvw<br>bvl<br>wv<br>lv<br>fv<br>dv | byte value (wor<br>byte value (lon<br>word value<br>long value | long value<br>float value     |  |  |  |  |
| baw<br>bal<br>wa<br>la<br>fa<br>da                 |                                                                | long address<br>float address |  |  |  |  |
| r-operand is                                       | always a register                                              |                               |  |  |  |  |
| wr                                                 | word register:                                                 |                               |  |  |  |  |
| lr                                                 | long register:                                                 |                               |  |  |  |  |
| fr<br>dr                                           | float register:<br>double register                             |                               |  |  |  |  |
| ac instructions:                                   | a_operand                                                      | c-operand                     |  |  |  |  |

qc instructions: q-operand c-operand q-operand is same as for a qr instruction (a value or an address) c-operand is a condition code c0: cUNC, cLEU, cLU, cL, cLE, cE, cNE, cGE c1: cG, cGU, cGEU

qo instructions: q-operand

q-operand is same as for a qr instruction (a value or an address)

73

mr instructions: r-operand m-operand m-operand is either a value or an address general value (immediate operand not allowed) gv general address ga r-operand is always a register general register (i.e., any register) gr ir instructions: i-operand r-operand i-operand is a 5-bit integer shift count SC r-operand is same as for a qr instruction (a register) ij instructions: i-operand j-operand i-operand is a condition code CUNC, CLEU, CLU, CL, CLE, CE, CNE, CGE cc: cG, cGU, cGEU j-operand is a memory address memory address ma a3 instructions: a3-operand a3-operand 3-byte memory address ma3 b1 instructions: b1-operand b1-operand is a 1-byte integer stack change stkc b14 instructions: b4-operand b1-operand b1-operand is a 1-byte integer stkc stack change b4-operand is a 4-byte bit mask bmsk bit mask

n0 instructions:

no operands

nO4 instructions: n4-operand

n4-operand is a 4-byte bit mask bmsk bit mask

Some miscellaneous notation:

Synonyms for registers: fp: frame pointer (= L6) stack pointer (= L7 sp: Registers other than general registers: pc: program counter flags: flags register LUF: less than unsigned flag LF: less than signed flag EF: equal flag greater than signed flag GF: greater than unsigned flag GUF:

Bytes and words:

| lob: | loworder byte of a word or a long  |
|------|------------------------------------|
| hob: | highorder byte of a word or a long |
| low: | loworder word of a long            |
| how: | highorder word of a long           |
|      |                                    |

In all cases in which an opcode takes typed operands, the last letter of the opcode indicates the type of the operands:

b: byte
w: word
l: long
f: float
d: double

#### Instruction Descriptions

The following pages contained detailed descriptions of all VMAX instructions, in alphabetical order by opcode name.

[Note: Each instruction description contains a "Flags" section, but at present there is no discussion of how flags are set by the instructions.]

| absd - Absolu | ite value            | e of douk        | ole                  | Format: qr Flags:                                                                  |
|---------------|----------------------|------------------|----------------------|------------------------------------------------------------------------------------|
| Syntax:       | absd                 | dv               | dr                   |                                                                                    |
| Semantics:    | dr := (              | (dv < 0 ?        | P -dv : (            | dv)                                                                                |
| Description:  | The abs<br>ter dr.   |                  | alue of (            | double dv is stored in double regis-                                               |
| Flags:        |                      |                  |                      |                                                                                    |
| Examples:     | absd<br>absd<br>absd | d1<br>d0<br>[L1] | d1<br>d1<br>d0       | ; d1 := abs(d1)<br>; d1 := abs(d0)<br>; d0 := abs(double value<br>addressed by L1) |
| absf - Absolu | ite value            | e of floa        | at                   | Format: qr Flags:                                                                  |
| Syntax:       | absf                 | fv               | fr                   |                                                                                    |
| Semantics:    | fr := (              | (fv < 0 ?        | P -fv :              | fv)                                                                                |
| Description:  | The abs<br>ter fr.   |                  | alue of <sup>.</sup> | float fv is stored in float regis-                                                 |
| Flags:        |                      |                  |                      |                                                                                    |
| Examples:     | absf<br>absf<br>absf | f1<br>f0<br>[L1] | f1<br>f1<br>f0       | ; f1 := abs(f1)<br>; f1 := abs(f0)<br>; f0 := abs(float value<br>addressed by L1)  |

ABSL

| absl - Absolu | ite value            | of long          |                | Format: qr Flags:                                                                |
|---------------|----------------------|------------------|----------------|----------------------------------------------------------------------------------|
| Syntax:       | absl                 | lv               | lr             |                                                                                  |
| Semantics:    | lr := (              | lv < 0 ?         | -lv : 1        | .v)                                                                              |
| Description:  | The abs<br>lr.       | olute va         | lue of l       | ong lv is stored in long register.                                               |
| Flags:        |                      |                  |                |                                                                                  |
| Examples:     | absl<br>absl<br>absl | L1<br>L0<br>[L1] | L1<br>L1<br>L0 | ; L1 := abs(L1)<br>; L1 := abs(L0)<br>; L0 := abs(long value<br>addressed by L1) |
| absw - Absolu | ite value            | e of word        |                | Format: qr Flags:                                                                |
| Syntax:       | absw                 | WV               | wr             |                                                                                  |
| Semantics:    | wr := (              | wv < 0 ?         | -WV : W        | /v )                                                                             |
| Description:  | The abs<br>wr.       | olute va         | lue of w       | ord wv is stored in word register                                                |
| Flags:        |                      |                  |                |                                                                                  |
| Examples:     | absw<br>absw<br>absw | w1<br>w0<br>[L1] | W1<br>W1<br>W0 | ; w1 := abs(w1)<br>; w1 := abs(w0)<br>; w0 := abs(word value<br>addressed by L1) |

ADDCL

| addcl - Add l |                                                                                                                                                  | mat: qr                                                      | Flags:           |  |  |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|------------------|--|--|--|
| Syntax:       | addcl lv lr                                                                                                                                      |                                                              |                  |  |  |  |
| Semantics:    | <pre>lr := lr + lv + carry bit</pre>                                                                                                             |                                                              |                  |  |  |  |
| Description:  | Long value lv and the carry bit are added to long register<br>lr. This instruction makes it possible to write multiple-<br>precision arithmetic. |                                                              |                  |  |  |  |
| Flags:        | NOTE: The carry bit is not<br>tion is not yet available.                                                                                         | yet defined,                                                 | so this instruc- |  |  |  |
| Examples:     | addcl L0 L1 ;L                                                                                                                                   | .1 := L1 + L1<br>.1 := L1 + L0<br>.0 := L0 + lon<br>addresse | + carry bit      |  |  |  |

| addd - Add do | ouble                |                  |                | Format: qr Flags:                                                                  |
|---------------|----------------------|------------------|----------------|------------------------------------------------------------------------------------|
| Syntax:       | addd                 | dv               | dr             |                                                                                    |
| Semantics:    | dr := dr             | - + dv           |                |                                                                                    |
| Description:  | Double v             | value dv         | is adde        | d to double register dr.                                                           |
| Flags:        |                      |                  |                |                                                                                    |
| Examples:     | addd<br>addd<br>addd | d1<br>d0<br>[L1] | d1<br>d1<br>d0 | ; d1 := d1 + d1<br>; d1 := d1 + d0<br>; d0 := d0 + double value<br>addressed by L1 |

ADDF

| addf - Add fl | oat                  |                  |                | Format: qr                                             | Flags:                      |
|---------------|----------------------|------------------|----------------|--------------------------------------------------------|-----------------------------|
| Syntax:       | addf                 | fv               | fr             |                                                        |                             |
| Semantics:    | fr := f              | r + fv           |                |                                                        |                             |
| Description:  | Float v              | alue fv          | is added       | to float registe                                       | er fr.                      |
| Flags:        |                      |                  |                |                                                        |                             |
| Examples:     | addf<br>addf<br>addf | f1<br>f0<br>[L1] | f1<br>f1<br>f0 | ; f1 := f1 + f1<br>; f1 := f1 + f0<br>; f0 := f0 + flc | at value<br>addressed by L1 |

| addl - Add lo | ng                   |                  |                | Format: qr                                             | Flags:                     |
|---------------|----------------------|------------------|----------------|--------------------------------------------------------|----------------------------|
| Syntax:       | addl                 | lv               | lr             |                                                        |                            |
| Semantics:    | lr := 1              | r + lv           |                |                                                        |                            |
| Description:  | Long va              | lue lv i         | s added        | to long register                                       | lr.                        |
| Flags:        |                      |                  |                |                                                        |                            |
| Examples:     | addl<br>addl<br>addl | L1<br>L0<br>[L1] | L1<br>L1<br>L0 | ; L1 := L1 + L1<br>; L1 := L1 + L0<br>; L0 := L0 + lon | g value<br>addressed by L1 |

# ADDSWL

ADDUWL

| addswl - Add | signed word to l                      | ong            | Format: qr Flags:                                                                                                       |
|--------------|---------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------|
| Syntax:      | addswl wv                             | lr             |                                                                                                                         |
| Semantics:   | lr := lr + sign                       | -extend(       | wv )                                                                                                                    |
| Description: | Word value wv i<br>to long registe    |                | xtended to 32 bits, and then added                                                                                      |
| Flags:       |                                       |                |                                                                                                                         |
| Examples:    | addswl w1<br>addswl w0<br>addswl [L1] | L1<br>L1<br>L0 | ; L1 := L1 + sign-extend(w1)<br>; L1 := L1 + sign-extend(w0)<br>; L0 := L0 + sign-extend(word value<br>addressed by L1) |
|              |                                       |                |                                                                                                                         |
|              |                                       |                |                                                                                                                         |
|              |                                       |                |                                                                                                                         |
| adduwl - Add | unsigned word to                      | long           | Format: qr Flags:                                                                                                       |
| Syntax:      | adduwl wv                             | lr             |                                                                                                                         |
| Semantics:   | lr := lr + zero                       | -extend(       | wv)                                                                                                                     |
| Description: | Word value wv i<br>to long registe    |                | xtended to 32 bits, and then added                                                                                      |
| Flags:       |                                       |                |                                                                                                                         |
| Examples:    | adduwl w1<br>adduwl w0<br>adduwl [L1] | L1<br>L1<br>L0 | ; L1 := L1 + zero-extend(w1)<br>; L1 := L1 + zero-extend(w0)<br>; L0 := L0 + zero-extend(word value<br>addressed by L1) |

| addw - Add wo | ord                             |                | Format: qr                                            | Flags: |
|---------------|---------------------------------|----------------|-------------------------------------------------------|--------|
| Syntax:       | addw wv                         | wr             |                                                       |        |
| Semantics:    | wr := wr + wv                   |                |                                                       |        |
| Description:  | Word value wv                   | is added       | to word register                                      | WV.    |
| Flags:        |                                 |                |                                                       |        |
| Examples:     | addw w1<br>addw w0<br>addw [L1] | W1<br>W1<br>W0 | ; w1 := w1 + w1<br>; w1 := w1 + w0<br>; w0 := w0 + w0 |        |

| andl - And lo | ng                   |                  |                | Format                     | : qr | Flags:            |
|---------------|----------------------|------------------|----------------|----------------------------|------|-------------------|
| Syntax:       | andl                 | lv               | lr             |                            |      |                   |
| Semantics:    | lr := 1              | r & lv           |                |                            |      |                   |
| Description:  | Long va              | lue lv i         | s bitwise      | e and-e                    | d to | long register lr. |
| Flags:        |                      |                  |                |                            |      |                   |
| Examples:     | andl<br>andl<br>andl | L1<br>L0<br>[L1] | L1<br>L1<br>L0 | ; L1 :<br>; L1 :<br>; L0 : | = L1 |                   |

| andw - And wo          | ord                  |                                                                                                                                                                             |                | Format:  | qr                              | Flags:                                                              |
|------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|---------------------------------|---------------------------------------------------------------------|
| Syntax:                | andw                 | WV                                                                                                                                                                          | wr             |          |                                 |                                                                     |
| Semantics:             | wr := w              | r & wv                                                                                                                                                                      |                |          |                                 |                                                                     |
| Description:           | Word va              | lue wv i                                                                                                                                                                    | s bitwis.      | e and-ed | to word n                       | register wr.                                                        |
| Flags:                 |                      |                                                                                                                                                                             |                |          |                                 |                                                                     |
| Examples:              | andw<br>andw<br>andw | w1<br>w0<br>[L1]                                                                                                                                                            | w1<br>w1<br>w0 | ; w1 :=  | w1 & w1<br>w1 & w0<br>w0 & word | d value<br>addressed by L1                                          |
| call - Call<br>Syntax: | call                 | сс                                                                                                                                                                          | ma             | Format:  | ij                              | Flags:                                                              |
|                        |                      |                                                                                                                                                                             |                |          |                                 |                                                                     |
| Semantics:             | if (cc)              | call EA                                                                                                                                                                     | (ma)           |          |                                 |                                                                     |
| Description:           | then ca              | If the condition indicated by condition code cc is TRUE,<br>then call the routine at the effective address specified<br>by ma. The return address is pushed onto the stack: |                |          |                                 |                                                                     |
|                        |                      | sp := sp - 4<br>Store pc at address contained in sp<br>pc := EA(ma)                                                                                                         |                |          |                                 |                                                                     |
| Flags:                 |                      |                                                                                                                                                                             |                |          |                                 |                                                                     |
| Examples:              | call<br>call<br>call | CUNC<br>CG<br>CNE                                                                                                                                                           |                | ; if (G  | F == 1) ca<br>F == 0) ca        | / call ReadOne<br>all Sort<br>all routine whose<br>address is in L1 |

# CALLB

| callb - Call | backward       | I                                                  | Format: a3                               | Flags: |  |  |
|--------------|----------------|----------------------------------------------------|------------------------------------------|--------|--|--|
| Syntax:      | callb          | ma3                                                |                                          |        |  |  |
| Semantics:   | call EA        | call EA(ma3)                                       |                                          |        |  |  |
| Description: |                |                                                    | e effective addres<br>dress is pushed or |        |  |  |
|              |                | sp := sp - 4<br>Store pc at add<br>pc := pc - 2*ma | dress contained in<br>a3                 | n sp   |  |  |
| Flags:       |                |                                                    |                                          |        |  |  |
| Examples:    | callb<br>callb | ReadOne<br>Sort                                    | ; Call ReadOne<br>; Call Sort            |        |  |  |

| callf - Call | forward        |                                                    | Format: a3                               | Flags: |
|--------------|----------------|----------------------------------------------------|------------------------------------------|--------|
| Syntax:      | callf          | ma3                                                |                                          |        |
| Semantics:   | call EA        | (ma3)                                              |                                          |        |
| Description: |                |                                                    | e effective addres<br>lress is pushed or |        |
|              |                | sp := sp - 4<br>Store pc at add<br>pc := pc + 2*ma | lress contained ir<br>13                 | n sp   |
| Flags:       |                |                                                    |                                          |        |
| Examples:    | callf<br>callf | ReadOne<br>Sort                                    | ; Call ReadOne<br>; Call Sort            |        |

CMPD

| cmpd - Compar | e double             |                      |                | Format: qr Flags:                                                                                             |
|---------------|----------------------|----------------------|----------------|---------------------------------------------------------------------------------------------------------------|
| Syntax:       | cmpd                 | dv                   | dr             |                                                                                                               |
| Semantics:    | Set flag             | gs as if             | dr - dv        | were executed                                                                                                 |
| Description:  |                      | gs regis             |                | racted from double register dr, and<br>et accordingly. The dr register is                                     |
| Flags:        |                      |                      |                |                                                                                                               |
| Examples:     | cmpd<br>cmpd<br>cmpd | d1<br>[sp+2]<br>[L1] | d0<br>d1<br>d0 | ; Compare d1 with d0<br>; Compare double at sp+2 with d1<br>; Compare double value addressed<br>by L1 with d0 |
| cmpf - Compar | e float              |                      |                |                                                                                                               |
| ompi compar   | 0 1 2000             |                      |                | Format: qr Flags:                                                                                             |
| Syntax:       | cmpf                 | fv                   | fr             |                                                                                                               |
| Semantics:    | Set flag             | gs as if             | fr - fv        | were executed                                                                                                 |
| Description:  |                      | gs regis             |                | acted from float register fr, and<br>et accordingly. The fr register is                                       |
| Flags:        |                      |                      |                |                                                                                                               |
| Examples:     | cmpf<br>cmpf<br>cmpf | f1<br>[sp+2]<br>[L1] | f0<br>f1<br>f0 | ; Compare f1 with f0<br>; Compare float at sp+2 with f1<br>; Compare float value addressed                    |

CMPLB

CMPL

cmpl - Compare long Format: qr Flags: Syntax: cmpl lv lr Set flags as if lr - lv were executed Semantics: Long value lv is subtracted from long register lr, and Description: the flags register is set accordingly. The lr register is NOT changed. Flags: Examples: cmpl ; Compare L1 with L0 L1 L0 cmpl [sp+2] ; Compare long at sp+2 with L1 L1 cmpl ; Compare long value addressed [L1] L0 by L1 with L0 cmplb - Compare loworder byte of long to byte Format: qr Flags: Syntax: cmplb bvl lr Set flags as if lob(lr) - bvl were executed Semantics: Description: Byte value bvl is subtracted from the loworder byte of long register lr, and the flags register is set accordingly. The lr register is NOT changed. Flags: Examples: cmplb L1 L2 ; Compare lob(L1) with lob(L2) ; Compare byte at sp+2 with lob(L1) cmplb [sp+2] L1 cmplb [L1] L0 ; Compare byte value addressed by L1 with lob(L0)

CMPW

CMPWB

| cmpw - Compar | e word                  |                      |                | Format: qr Flags:                                                                                                             |
|---------------|-------------------------|----------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | стрw                    | WV                   | wr             |                                                                                                                               |
| Semantics:    | Set flag                | gs as if             | wr - wv        | were executed                                                                                                                 |
| Description:  |                         | gs regis             |                | cted from word register wr, and<br>et accordingly. The wr register is                                                         |
| Flags:        |                         |                      |                |                                                                                                                               |
| Examples:     | стрw<br>стрw<br>стрw    | w1<br>[sp+2]<br>[L1] | w0<br>w1<br>w0 | ; Compare w1 with w0<br>; Compare word at sp+2 with w1<br>; Compare word value addressed<br>by L1 with w0                     |
|               |                         |                      |                |                                                                                                                               |
|               |                         |                      |                |                                                                                                                               |
|               |                         |                      |                |                                                                                                                               |
|               |                         |                      |                |                                                                                                                               |
| cmpwb - Compa | are loword              | der byte             | of word        | to byte<br>Format: qr   Flags:                                                                                                |
| Syntax:       | cmpwb                   | b∨w                  | wr             |                                                                                                                               |
| Semantics:    | Set flaç                | gs as if             | lob(wr)        | - bvw were executed                                                                                                           |
| Description:  | word reg                | gister w             | r, and t       | acted from the loworder byte of<br>he flags register is set according-<br>NOT changed.                                        |
| Flags:        |                         |                      |                |                                                                                                                               |
| Examples:     | cmpwb<br>cmpwb<br>cmpwb | w1<br>[sp+2]<br>[L1] | w2<br>w1<br>w0 | ; Compare lob(w1) with lob(w2)<br>; Compare byte at sp+2 with lob(w1)<br>; Compare byte value addressed by<br>L1 with lob(w0) |

# CVTBSL

CVTBSW

| cvtbsl - Conv | vert byte sign-e>                         | ktended 1             | o long<br>Format: qr Flags:                                                                                                                    |
|---------------|-------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | cvtbsl bvl                                | lr                    |                                                                                                                                                |
| Semantics:    | lob(lr) := bvl<br>the three highd         | order byt             | es of lr := sign bit of bvl                                                                                                                    |
| Description:  | ister lr, and t<br>three highorder        | the sign<br>r bytes d | to the loworder byte of long reg-<br>of bvl is extended to fill the<br>of lr. Thus, the three highorder<br>all zero bits or else all one bits. |
| Flags:        |                                           |                       |                                                                                                                                                |
| Examples:     | cvtbsl L1<br>cvtbsl [sp+2]<br>cvtbsl [L1] |                       | ; Move lob(L1) sign-extended to L0<br>; Move byte at sp+2 sign-ext to L1<br>; Move byte addressed by L1 sign-<br>extended to L0                |
|               |                                           |                       |                                                                                                                                                |
| cvtbsw - Conv | vert byte sign-e>                         | tended 1              | co word<br>Format: qr Flags:                                                                                                                   |
| Syntax:       | cvtbsw bvw                                | wr                    |                                                                                                                                                |
| Semantics:    | lob(wr) := bvw<br>hob(wr) := sigr         | n bit of              | b∨w                                                                                                                                            |
| Description:  | ister wr, and t<br>highorder byte         | the sign<br>of wr.    | I to the loworder byte of word reg-<br>of bvw is extended to fill the<br>Thus, the highorder byte of wr is<br>else all one bits.               |
| Flags:        |                                           |                       |                                                                                                                                                |
| Examples:     | cvtbsw w1<br>cvtbsw [sp+2]<br>cvtbsw [L1] | w0<br>w1<br>w0        | ; Move lob(w1) sign-extended to w0<br>; Move byte at sp+2 sign-ext to w1<br>; Move byte addressed by L1 sign-<br>extended to w0                |

# CVTBZL

| cvtbzl - Conv | vert byte zero-e                          | xtended t      | to long<br>Format: qr | Flags:                                                                      |
|---------------|-------------------------------------------|----------------|-----------------------|-----------------------------------------------------------------------------|
| Syntax:       | cvtbzl bvl                                | lr             |                       |                                                                             |
| Semantics:    | lob(lr) := bvl<br>the three high          |                | tes of lr := 0        |                                                                             |
| Description:  |                                           |                |                       | byte of long reg-<br>of lr are set to                                       |
| Flags:        |                                           |                |                       |                                                                             |
| Examples:     | cvtbzl L1<br>cvtbzl [sp+2]<br>cvtbzl [L1] | L0<br>L1<br>L0 | ; Move byte at a      | zero-extended to L0<br>sp+2 zero-ext to L1<br>ressed by L1 zero-<br>d to L0 |

| cvtbzw | - | Convert byte | zero-extended | to word |    |        |
|--------|---|--------------|---------------|---------|----|--------|
|        |   |              |               | Format: | qr | Flags: |

| Syntax: | cvtbzw | bvw | wr |
|---------|--------|-----|----|

Semantics: lob(wr) := bvw hob(wr) := 0

Description: Byte value bvw is moved to the loworder byte of word register wr, and the highorder byte of wr is set to zero.

Flags:

| Examples: | cvtbzw | w1     | w0 | ; Move lob(w1) zero-extended to w0 |
|-----------|--------|--------|----|------------------------------------|
|           | cvtbzw | [sp+2] | w1 | ; Move byte at sp+2 zero-ext to w1 |
|           | cvtbzw | [L1]   | w0 | ; Move byte addressed by L1 zero-  |
|           |        |        |    | extended to w0                     |

# CVTDF

| cvtdf - Conve | ert doubl               | e to flo.            | pat            | Format: qr Flags:                                                                                     |
|---------------|-------------------------|----------------------|----------------|-------------------------------------------------------------------------------------------------------|
| Syntax:       | cvtdf                   | dv                   | fr             |                                                                                                       |
| Semantics:    | fr := (                 | float) d             | lv             |                                                                                                       |
| Description:  | Double<br>registe       |                      | / is conv      | verted to float and stored in float                                                                   |
|               | QUESTIC                 | N: What              | loss of        | f precision, etc., can happen??                                                                       |
| Flags:        |                         |                      |                |                                                                                                       |
| Examples:     | cvtdf<br>cvtdf<br>cvtdf | d1<br>[sp+2]<br>[L1] | f0<br>f1<br>f0 | ; f0 := (float) d1<br>; f1 := (float) (double at sp+2)<br>; f0 := (float) (double addressed<br>by L1) |
| cvtfd - Conve | rt float                | to doub              | ole            | Format: qr Flags:                                                                                     |
| Syntax:       | cvtfd                   | fv                   | dr             |                                                                                                       |

Semantics: dr := (double) fv

Description: Float value fv is converted to double and stored in double register dr.

Flags:

| Examples: | cvtfd | f1     | d0 | ; d0 := (double) f1               |
|-----------|-------|--------|----|-----------------------------------|
|           | cvtfd | [sp+2] | d1 | ; d1 := (double) (float at sp+2)  |
|           | cvtfd | [L1]   | d0 | ; d0 := (double) (float addressed |
|           |       |        |    | by L1)                            |

# CVTSLD

| cvtsld - Conv | vert signed long to double<br>Format: qr Flags:                                                                                                                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | cvtsld lv dr                                                                                                                                                                                                                                                          |
| Semantics:    | dr := (double) lv                                                                                                                                                                                                                                                     |
| Description:  | Signed long value lv is converted to double and stored in<br>double register dr.                                                                                                                                                                                      |
|               | QUESTION: What about loss of precision?                                                                                                                                                                                                                               |
| Flags:        |                                                                                                                                                                                                                                                                       |
| Examples:     | cvtsldL1d0; d0 := (double)L1cvtsld[sp+2]d1; d1 := (double)(long at sp+2)cvtsld[L1]d0; d0 := (double)(long addressed<br>by L1)                                                                                                                                         |
|               |                                                                                                                                                                                                                                                                       |
|               |                                                                                                                                                                                                                                                                       |
|               |                                                                                                                                                                                                                                                                       |
| cytalf - Conv | vert signed long to float                                                                                                                                                                                                                                             |
|               | Format: qr Flags:                                                                                                                                                                                                                                                     |
| Syntax:       | cvtslf lv fr                                                                                                                                                                                                                                                          |
| Semantics:    | fr := (float) lv                                                                                                                                                                                                                                                      |
| Description:  | Signed long value lv is converted to float and stored in float register fr.                                                                                                                                                                                           |
|               | QUESTION: What about loss of precision?                                                                                                                                                                                                                               |
| Flags:        |                                                                                                                                                                                                                                                                       |
| Examples:     | cvtslf       L1       f0       ; f0 := (float)       L1         cvtslf       [sp+2]       f1       ; f1 := (float)       (long at sp+2)         cvtslf       [L1]       f0       ; f0 := (float)       (long addressed         by       L1       L1       by       L1 |

# CVTTDSL

CVTTDUL

| cvttdsl - Con | vert truncated double to                              | signed long<br>Format: qr                                 | Flags:                                          |
|---------------|-------------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------|
| Syntax:       | cvttdsl dv lr                                         |                                                           |                                                 |
| Semantics:    | lr := (long) dv                                       |                                                           |                                                 |
| Description:  | Double value dv is convo<br>in long register lr.      | erted to a signed                                         | long and stored                                 |
|               | QUESTION: What loss of                                | precision, etc.,                                          | can happen??                                    |
| Flags:        |                                                       |                                                           |                                                 |
| Examples:     | cvttdsl d1 L0<br>cvttdsl [sp+2] L1<br>cvttdsl [L1] L0 | ; L0 := (long) d:<br>; L1 := (long) (<br>; L0 := (long) ( | double at sp+2)                                 |
|               |                                                       |                                                           |                                                 |
| cvttdul - Con | vert truncated double to                              | unsigned long<br>Format: qr                               | Flags:                                          |
| Syntax:       | cvttdul dv lr                                         |                                                           |                                                 |
| Semantics:    | lr := (unsigned long) dv                              | v                                                         |                                                 |
| Description:  | Double value dv is convo<br>in long register lr.      | erted to an unsig                                         | ned long and stored                             |
|               | QUESTION: What loss of                                | precision, etc.,                                          | can happen??                                    |
| Flags:        |                                                       |                                                           |                                                 |
| Examples:     | cvttdul d1 L0<br>cvttdul [sp+2] L1                    | ; L0 := (unsigne<br>; L1 := (unsigne                      | d long) (double                                 |
|               | cvttdul [L1] L0                                       | ; L0 := (unsigne                                          | at sp+2)<br>d long) (double<br>addressed by L1) |

# CVTTFSL

CVTTFUL

| cvttfsl - Con | vert truncated float to signed long<br>Format: qr Flags:                                                                           |
|---------------|------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | cvttfsl fv lr                                                                                                                      |
| Semantics:    | lr := (long) fv                                                                                                                    |
| Description:  | Float value fv is converted to a signed long and stored in long register lr.                                                       |
|               | QUESTION: What loss of precision, etc., can happen??                                                                               |
| Flags:        |                                                                                                                                    |
| Examples:     | cvttfsl f1L0; L0 := (long) f1cvttfsl [sp+2]L1; L1 := (long) (float at sp+2)cvttfsl [L1]L0; L0 := (long) (float addressed<br>by L1) |
|               |                                                                                                                                    |
| cvttful - Con | vert truncated float to unsigned long<br>Format: qr Flags:                                                                         |
| Syntax:       | cvttful fv lr                                                                                                                      |
| Semantics:    | lr := (unsigned long) fv                                                                                                           |
| Description:  | Float value fv is converted to an unsigned long and stored in long register lr.                                                    |
|               | QUESTION: What loss of precision, etc., can happen??                                                                               |
| Flags:        |                                                                                                                                    |
| Examples:     | cvttful f1 L0 ; L0 := (unsigned long) f1<br>cvttful [sp+2] L1 ; L1 := (unsigned long) (float                                       |
|               | at sp+2)<br>cvttful [L1] L0 ; L0 := (unsigned long) (float<br>addressed by L1)                                                     |

# CVTULD

CVTULF

| cvtuld - Conv | ert unsigned long to double<br>Format: qr Flags:                                                                                                                    |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | cvtuld lv dr                                                                                                                                                        |
| Semantics:    | dr := (double) lv                                                                                                                                                   |
| Description:  | Unsigned long value lv is converted to double and stored in double register dr.                                                                                     |
|               | QUESTION: What about loss of precision?                                                                                                                             |
| Flags:        |                                                                                                                                                                     |
| Examples:     | cvtuld $L1$ $d0$ ; $d0 := (double)$ $L1$ $cvtuld$ $[sp+2]$ $d1$ ; $d1 := (double)$ (long at sp+2) $cvtuld$ $[L1]$ $d0$ ; $d0 := (double)$ (long addressed<br>by L1) |
|               |                                                                                                                                                                     |
|               |                                                                                                                                                                     |
| cvtulf - Conv | ert unsigned long to float<br>Format: qr Flags:                                                                                                                     |
| Syntax:       | cvtulf lv fr                                                                                                                                                        |
| Semantics:    | fr := (float) lv                                                                                                                                                    |
| Description:  | Unsigned long value lv is converted to float and stored in float register fr.                                                                                       |
|               | QUESTION: What about loss of precision?                                                                                                                             |
| Flags:        |                                                                                                                                                                     |
| Examples:     | <pre>cvtulf L1 f0 ; f0 := (float) L1 cvtulf [sp+2] f1 ; f1 := (float) (long at sp+2) cvtulf [L1] f0 ; f0 := (float) (long addressed</pre>                           |

# CVTWSL

CVTWZL

| cvtwsl - Conv | ert word sigr                           | n-extended                             | to long<br>Format: qr                                                               | Flags:                                    |
|---------------|-----------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------|
| Syntax:       | cvtwsl wv                               | lr                                     |                                                                                     |                                           |
| Semantics:    | low(lr) := w<br>how(lr) := s            |                                        | WV                                                                                  |                                           |
| Description:  | ter lr, and order word o                | the sign o <sup>.</sup><br>of lr. Thu: | to the loworder w<br>f wv is extended f<br>s, the highorder w<br>r else all one bit | vord of lr is                             |
| Flags:        |                                         |                                        |                                                                                     |                                           |
| Examples:     | cvtwsl w1<br>cvtwsl [sp+<br>cvtwsl [L1] |                                        |                                                                                     | sp+2 sign-ext to L1<br>ressed by L1 sign- |
| cvtwzl - Conv | ert word zero                           | o-extended                             | to long<br>Format: qr                                                               | Flags:                                    |
| Syntax:       | cvtwzl wv                               | lr                                     |                                                                                     |                                           |
| Semantics:    | low(lr) := w<br>how(lr) := 0            |                                        |                                                                                     |                                           |
| Description:  |                                         |                                        | to the loworder w<br>der word of lr is                                              | vord of long regis-<br>set to zero.       |
| Flags:        |                                         |                                        |                                                                                     |                                           |
| Examples:     | cvtwzl w1<br>cvtwzl [sp-<br>cvtwzl [L1] |                                        |                                                                                     | sp+2 zero-ext to L1<br>ressed by L1 zero- |

DIVD

| divd - Divide | double               |                  |                      | Format: qr Flags:                                                                  |
|---------------|----------------------|------------------|----------------------|------------------------------------------------------------------------------------|
| Syntax:       | divd                 | dv               | dr                   |                                                                                    |
| Semantics:    | dr := d              | r / dv           |                      |                                                                                    |
| Description:  |                      |                  | dr is d<br>ced in d  | ivided by double value dv, and the<br>r.                                           |
| Flags:        |                      |                  |                      |                                                                                    |
| Examples:     | divd<br>divd<br>divd | d1<br>d0<br>[L1] | d1<br>d1<br>d0       | ; d1 := d1 / d1<br>; d1 := d1 / d0<br>; d0 := d0 / double value<br>addressed by L1 |
| divf - Divide | float                |                  |                      | Format: qr Flags:                                                                  |
| Syntax:       | divf                 | fv               | fr                   |                                                                                    |
| Semantics:    | fr := f              | r / fv           |                      |                                                                                    |
| Description:  |                      |                  | fr is di<br>ced in f | vided by float value fv, and the<br>r                                              |
| Flags:        |                      |                  |                      |                                                                                    |
| Examples:     | divf<br>divf<br>divf | f1<br>f0<br>[L1] | f1<br>f1<br>f0       | ; f1 := f1 / f1<br>; f1 := f1 / f0<br>; f0 := f0 / float value<br>addressed by L1  |

# DIVRSL

| divrsl - Divi | de with remainder signed long<br>Format: qr Flags:                                                                                                                                                                                                                                                                                      |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | divrsl lv lr                                                                                                                                                                                                                                                                                                                            |
| Semantics:    | lr := lr / lv<br>lv := remainder (if lv is a register)                                                                                                                                                                                                                                                                                  |
| Description:  | Long register lr is divided by long value lv, and the quo-<br>tient is placed in lr If lv is a register, then lv is<br>set to the remainder of the division (so the original di-<br>visor is overwritten). If lv is not a register then no<br>remainder is produced by the operation. All quantities<br>are treated as SIGNED integers. |
| Flags:        |                                                                                                                                                                                                                                                                                                                                         |
| Examples:     | <pre>divrsl L2 L1 ; L1 := L1 / L2; L2 := remainder<br/>divrsl [sp+2] L1 ; L1 := L1 / long at sp+2; no rmdr<br/>divrsl [L1] L0 ; L0 := L0 / long value addressed<br/>by L1 (no remainder)</pre>                                                                                                                                          |
| divrslw - Div | vide with remainder signed long by word<br>Format: qr Flags:                                                                                                                                                                                                                                                                            |
| Syntax:       | divrslw wv lr                                                                                                                                                                                                                                                                                                                           |
| Semantics:    | lr := lr / wv<br>wv := remainder (if wv is a register)                                                                                                                                                                                                                                                                                  |
| Description:  | Long register lr is divided by word value wv, and the quo-<br>tient is placed in lr If wv is a register, then wv is<br>set to the remainder of the division (so the original di-<br>visor is overwritten). If wv is not a register then no<br>remainder is produced by the operation. All quantities<br>are treated as SIGNED integers. |
| Flags:        |                                                                                                                                                                                                                                                                                                                                         |
| Examples:     | divrslw w2 L1 ; L1 := L1 / w2; w2 := remainder<br>divrslw [sp+2] L1 ; L1 := L1 / word at sp+2; no rmdr<br>divrslw [L1] L0 ; L0 := L0 / word value addressed<br>by L1 (no remainder)                                                                                                                                                     |

#### DIVRSW

DIVRUL

| divrsw - Divi | de with remainder signed word<br>Format: qr Flags:                                                                                                                                                                                                                                                                                        |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | divrsw wv wr                                                                                                                                                                                                                                                                                                                              |
| Semantics:    | wr := wr / wv<br>wv := remainder (if wv is a register)                                                                                                                                                                                                                                                                                    |
| Description:  | Word register wr is divided by word value wv, and the quo-<br>tient is placed in wr If wv is a register, then wv is<br>set to the remainder of the division (so the original di-<br>visor is overwritten). If wv is not a register then no<br>remainder is produced by the operation. All quantities<br>are treated as SIGNED integers.   |
| Flags:        |                                                                                                                                                                                                                                                                                                                                           |
| Examples:     | divrsww2w1; w1 := w1 / w2; w2 := remainderdivrsw[sp+2]w1; w1 := w1 / word at sp+2; no rmdrdivrsw[L1]w0; w0 := w0 / word value addressedby L1 (no remainder)                                                                                                                                                                               |
| divrul - Divi | de with remainder unsigned long<br>Format: qr Flags:                                                                                                                                                                                                                                                                                      |
| Syntax:       | divrul lv lr                                                                                                                                                                                                                                                                                                                              |
| Semantics:    | lr := lr / lv<br>lv := remainder (if lv is a register)                                                                                                                                                                                                                                                                                    |
| Description:  | Long register lr is divided by long value lv, and the quo-<br>tient is placed in lr If lv is a register, then lv is<br>set to the remainder of the division (so the original di-<br>visor is overwritten). If lv is not a register then no<br>remainder is produced by the operation. All quantities<br>are treated as UNSIGNED integers. |
| Flags:        |                                                                                                                                                                                                                                                                                                                                           |
| Examples:     | <pre>divrul L2 L1 ; L1 := L1 / L2; L2 := remainder<br/>divrul [sp+2] L1 ; L1 := L1 / long at sp+2; no rmdr<br/>divrul [L1] L0 ; L0 := L0 / long value addressed<br/>by L1 (no remainder)</pre>                                                                                                                                            |

# DIVRULW

DIVRUW

| divrulw - Div | vide with remainder unsigned long by word<br>Format: qr Flags:                                                                                                                                                                                                                                                                            |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | divrulw wv lr                                                                                                                                                                                                                                                                                                                             |
| Semantics:    | lr := lr / wv<br>wv := remainder (if wv is a register)                                                                                                                                                                                                                                                                                    |
| Description:  | Long register lr is divided by word value wv, and the quo-<br>tient is placed in lr If wv is a register, then wv is<br>set to the remainder of the division (so the original di-<br>visor is overwritten). If wv is not a register then no<br>remainder is produced by the operation. All quantities<br>are treated as UNSIGNED integers. |
| Flags:        |                                                                                                                                                                                                                                                                                                                                           |
| Examples:     | <pre>divrulw w2 L1 ; L1 := L1 / w2; w2 := remainder<br/>divrulw [sp+2] L1 ; L1 := L1 / word at sp+2; no rmdr<br/>divrulw [L1] L0 ; L0 := L0 / word value addressed<br/>by L1 (no remainder)</pre>                                                                                                                                         |
| divruw - Div  | ide with remainder unsigned word<br>Format: qr Flags:                                                                                                                                                                                                                                                                                     |
| Syntax:       | divruw wv wr                                                                                                                                                                                                                                                                                                                              |
| Semantics:    | wr := wr ∕ wv<br>wv := remainder (if wv is a register)                                                                                                                                                                                                                                                                                    |
| Description:  | Word register wr is divided by word value wv, and the quo-<br>tient is placed in wr If wv is a register, then wv is<br>set to the remainder of the division (so the original di-<br>visor is overwritten). If wv is not a register then no<br>remainder is produced by the operation. All quantities<br>are treated as UNSIGNED integers. |
| Flags:        |                                                                                                                                                                                                                                                                                                                                           |
| Examples:     | divruw w2 w1 ; w1 := w1 / w2; w2 := remainder<br>divruw [sp+2] w1 ; w1 := w1 / word at sp+2; no rmdr<br>divruw [L1] w0 ; w0 := w0 / word value addressed<br>by L1 (no remainder)                                                                                                                                                          |

# DIVSL

| divsl - Divid | e signed                | long                 |                | Format: qr Flags:                                                                             |
|---------------|-------------------------|----------------------|----------------|-----------------------------------------------------------------------------------------------|
| Syntax:       | divsl                   | lv                   | lr             |                                                                                               |
| Semantics:    | lr := lr                | r / lv               |                |                                                                                               |
| Description:  | tient is                | s placed             | in lr          | ided by long value lv, and the quo-<br>No remainder is calculated. All<br>as SIGNED integers. |
| Flags:        |                         |                      |                |                                                                                               |
| Examples:     | divsl<br>divsl<br>divsl | L2<br>[sp+2]<br>[L1] |                | ; L1 := L1 / L2<br>; L1 := L1 / long at sp+2<br>; L0 := L0 / long value addressed<br>by L1    |
|               |                         |                      |                |                                                                                               |
|               |                         |                      |                |                                                                                               |
|               |                         |                      |                |                                                                                               |
| divsw - Divid | e signed                | word                 |                | Format: qr Flags:                                                                             |
| Syntax:       | divsw                   | WV                   | wr             |                                                                                               |
| Semantics:    | wr := wr                | r / wv               |                |                                                                                               |
| Description:  | tient is                | s placed             | in wr          | ided by word value wv, and the quo-<br>No remainder is calculated. All<br>as SIGNED integers. |
| Flags:        |                         |                      |                |                                                                                               |
| Examples:     | divsw<br>divsw<br>divsw | w2<br>[sp+2]<br>[L1] | W1<br>W1<br>W0 | ; w1 := w1 / w2<br>; w1 := w1 / word at sp+2<br>; w0 := w0 / word value addressed<br>by L1    |

# DIVUL

| divul - Divic | de unsigned long                                | Format: qr Flags:                                                                                   |
|---------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| Syntax:       | divul lv lr                                     |                                                                                                     |
| Semantics:    | lr := lr / lv                                   |                                                                                                     |
| Description:  | tient is placed in lr                           | ivided by long value lv, and the quo-<br>No remainder is calculated. All<br>d as UNSIGNED integers. |
| Flags:        |                                                 |                                                                                                     |
| Examples:     | divul L2 L1<br>divul [sp+2] L1<br>divul [L1] L0 | ; L1 := L1 / L2<br>; L1 := L1 / long at sp+2<br>; L0 := L0 / long value addressed<br>by L1          |
| divuw - Divic | de unsigned word                                |                                                                                                     |
|               |                                                 | Format: qr Flags:                                                                                   |
| Syntax:       | divuw wv wr                                     |                                                                                                     |
| Semantics:    | wr := wr / wv                                   |                                                                                                     |
| Description:  | tient is placed in wr                           | ivided by word value wv, and the quo-<br>No remainder is calculated. All<br>d as UNSIGNED integers. |

Flags:

Examples: divuw [sp+2] w1 ; w1 := w1 / w2 divuw [L1] w0 ; w1 := w1 / word at sp+2 ; w0 := w0 / word value addressed by L1

# ENTER

enter - Enter function

| Syntax:      | enter stkc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Semantics:   | sp := sp - 4<br>Move contents of fp to address contained in sp<br>fp := sp<br>sp := sp - 2*stkc                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Description: | This instruction is used as the first instruction in a<br>routine generated from a C function definition. Its ef-<br>fect is exactly equivalent to the action of these three<br>instructions:                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|              | pushl fp<br>movl sp fp<br>subl 2*stkc sp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|              | Typically, 2*stkc is the number of bytes needed by local<br>automatic variables of the function. Note that stkc is<br>an unsigned quantity, scaled by a factor of 2 (because the<br>smallest entity that can be pushed or popped is a word).<br>Thus, at most 510 bytes can be reserved on the stack for<br>local variables by the enter instruction. If more are<br>needed, this is easily handled by generating an addl in-<br>struction. For example, say that a function requires 528<br>bytes for locals. Then the first two instructions in the<br>function are |  |  |
|              | enter 510<br>subl 18 sp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| Flags:       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Examples:    | enter22; Reserve 22 bytes for localsenter0; Reserve no bytes for locals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |

Format: b1 Flags:

#### ENTERSAV

ENTERSAV

entersav - Enter function and save registers Format: b14 Flags: Syntax: entersav stkc bmsk Semantics: sp := sp - 4 Move contents of fp to address contained in sp fp := spsp := sp - 2\*stkc pushregs bmsk Description: This instruction is used as the first instruction in a routine generated from a C function definition. Its effect is exactly equivalent to the action of these four instructions: pushl fp movl fp sp subl 2\*stkc sp pushregs bmsk Or, more succinctly, the effect of entersav is exactly equivalent to these two instructions: enter stkc pushregs bmsk Thus, entersav performs the function entry housekeeping of enter, followed by saving of up to 32 registers on the stack. Flags: Examples: entersav 22 0x80000003 ; Reserve 22 bytes for locals and push w0, w1, and d7 entersav 0 0x30000008 ; Reserve no bytes for locals and push w3, d4, and d5 GMOV

| gmov - Genera | I move Format: mr Flags:                                                                                                                                                                  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | gmov n ga gr                                                                                                                                                                              |
| Semantics:    | gr := n bytes from ga                                                                                                                                                                     |
| Description:  | Move n bytes (n = 1, 2, 4, or 8) from general address ga<br>to general register gr. The general address can be any<br>memory address or any register; it cannot be an immediate<br>value. |
|               | NOTE: How bytes are aligned in multiple registers and partial registers will be determined later.                                                                                         |
| Flags:        |                                                                                                                                                                                           |
| Examples:     | gmov 8 d1 w0 ; w0 thru w3 := 8 bytes from d1<br>gmov 1 [sp+2] f2 ; part of f2 := byte at sp+2<br>gmov 4 [L1] d0 ; part of d0 := 4 bytes addressed<br>by L1                                |
| gsto - Genera | al store<br>Format: mr Flags:                                                                                                                                                             |
| Syntax:       | gsto n gr ga                                                                                                                                                                              |
| Semantics:    | ga := n bytes from gr                                                                                                                                                                     |
| Description:  | Move n bytes (n = 1, 2, 4, or 8) from general register gr<br>to general address ga. The general address can be any<br>memory address or any register; it cannot be an immediate<br>value. |
|               | NOTE: How bytes are aligned in multiple registers and partial registers will be determined later.                                                                                         |
| Flags:        |                                                                                                                                                                                           |
| Examples:     | gsto 8 w0 d1 ; d1 := w0 thru w3<br>gsto 1 f2 [sp+2] ; byte at sp+2 : = byte from f2<br>gsto 4 d0 [L1] ; 4 bytes addressed by L1 := bytes<br>from d0                                       |

halt - Halt the VMAX machine

Format: n0 Flags:

Syntax: halt

Semantics: Halt processing

Description: The VMAX stops processing instrutions.

QUESTION: We need to define exactly what happens: A message is sent from PCMAX2 to PC? Maybe some sort of return code should be transmitted?

```
Flags:
```

Example: halt ; Halt processing

jump -Jump Format: ij Flags: Syntax: jump СС ma Semantics: if (cc) goto EA(ma) If the condition indicated by condition code cc is TRUE, Description: then jump to the effective address specified by ma. Flags: Examples: ReadOne ; Unconditionally goto ReadOne jump CUNC Sort ; if (GF == 1) goto Sort jump сG jump CNE [L1] ; if (EF == 0) goto routine whose address is in L1

#### JUMPB

| jumpb - Jump | backward       |                                         | Format: a3                    | Flags:  |  |  |  |  |
|--------------|----------------|-----------------------------------------|-------------------------------|---------|--|--|--|--|
| Syntax:      | jumpb          | ma3                                     |                               |         |  |  |  |  |
| Semantics:   | goto EA(ma3)   |                                         |                               |         |  |  |  |  |
| Description: | Jump to        | the effective address specified by ma3: |                               |         |  |  |  |  |
|              |                | pc := pc - 2*ma3                        |                               |         |  |  |  |  |
| Flags:       |                |                                         |                               |         |  |  |  |  |
| Examples:    | jumpb<br>jumpb | ReadOne<br>Sort                         | ; goto ReadOne<br>; goto Sort |         |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
| jumpf - Jump | forward        |                                         | Format: a3                    | Flags:  |  |  |  |  |
|              |                |                                         |                               |         |  |  |  |  |
| Syntax:      | jumpf          | ma3                                     |                               |         |  |  |  |  |
| Semantics:   | goto EA(ma3)   |                                         |                               |         |  |  |  |  |
| Description: | Jump to        | the effective a                         | ddress specified              | by ma3: |  |  |  |  |
|              |                | pc := pc + 2*ma3                        |                               |         |  |  |  |  |
| Flags:       |                |                                         |                               |         |  |  |  |  |
| Examples:    | jumpf<br>jumpf | ReadOne<br>Sort                         | ; goto ReadOne<br>; goto Sort |         |  |  |  |  |

| leal - Load e | ffective                                                                                                                                                                  | address                  |    | Format: qr                                       | Flags: |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----|--------------------------------------------------|--------|--|--|
| Syntax:       | leal                                                                                                                                                                      | lv                       | lr |                                                  |        |  |  |
| Semantics:    | lr := E                                                                                                                                                                   | A(lv)                    |    |                                                  |        |  |  |
| Description:  | Move the effective address of long value lv into long<br>register lr. If lv is an immediate value or the contents<br>of a register, the effect is the same as movl lv lr. |                          |    |                                                  |        |  |  |
| Flags:        |                                                                                                                                                                           |                          |    |                                                  |        |  |  |
| Examples:     | leal<br>leal<br>leal                                                                                                                                                      | [L1+L2]<br>14<br>[L1+14] | L1 | ; L0 := L1 + L2<br>; L1 := 14<br>; L0 := L1 + 14 |        |  |  |

LEAVE

LEAVE

leave - Leave function

Format: b1 Flags:

Syntax: leave stkc

- Semantics: sp := fp
  Move long addressed by sp to fp
  sp := sp + 4
  Move long addressed by sp to pc
  sp := sp + 4
  sp := sp + 2\*stkc
- Description: This instruction is used to return from a routine generated from a C function definition. Its effect is exactly equivalent to the action of these three instructions:

movlfpsppoplfpretstkc

Typically, 2\*stkc is the number of bytes needed for parameters to the function. Part of the task of leave is to clear these parameters out of the stack. Note that stkc is an unsigned quantity, scaled by a factor of 2 (because the smallest entity that can be pushed or popped is a word). Thus, at most 510 bytes can be cleared from the stack by the leave instruction. If more must be cleared, then this must be done by a addl to sp following the call of the function.

Many implementations of C assume that every function can take a variable number of parameters. Thus "leave O" is always generated, and the stack is adjusted by a addl instruction following the call.

Note that the stkc operand for a leave instruction is the number of bytes used by PARAMETERS, while the stkc operand for an enter instruction is the number of bytes used by LOCALS. Thus, the two instructions are not exactly symmetrical.

Flags:

| Examples: | leave | 22 | ; | Clear | 22 | bytes | from | stack |
|-----------|-------|----|---|-------|----|-------|------|-------|
|           | leave | Θ  | ; | Clear | no | bytes | from | stack |

#### LEAVERES

#### LEAVERES

leave - Leave function and restore registers Format: b14 Flags: Syntax: leaveres stkc bmsk Semantics: popregs bmsk sp := fp Move long addressed by sp to fp sp := sp + 4Move long addressed by sp to pc sp := sp + 4sp := sp + 2\*stkcDescription: This instruction is used as the last instruction in a routine generated from a C function definition. Its effect is exactly equivalent to the action of these four instructions: popregs bmsk movl fp sp popl fp stkc ret Or, more succinctly, the effect of leaveres is exactly equivalent to these two instructions: popregs bmsk leave stkc Thus, leaveres restores of up to 32 registers from the stack, and then performs the function exit housekeeping of leave.

Flags:

Examples: leaveres 22 0x80000003 ; Pop d7, w1, w0, and clear 22 bytes from stack leaveres 0 0x30000008 ; Pop d5, d4, w3, and clear no bytes from stack

# MOVBL

MOVBW

| movbl - Move | byte to I               | loworder             | byte of        | long<br>Format: qr Flags:                                                                                |
|--------------|-------------------------|----------------------|----------------|----------------------------------------------------------------------------------------------------------|
| Syntax:      | movbl                   | bvl                  | lr             |                                                                                                          |
| Semantics:   | lob(lr)                 | := bvl               |                |                                                                                                          |
| Description: |                         |                      |                | to the loworder byte of long reg-<br>horder bytes of lr are NOT changed.                                 |
| Flags:       |                         |                      |                |                                                                                                          |
| Examples:    | movbl<br>movbl<br>movbl | L1<br>[sp+2]<br>[L1] | L0<br>L1<br>L0 | ; Move lob(L1) to lob(L0)<br>; Move byte at sp+2 to lob(L1)<br>; Move byte addressed by L1 to<br>lob(L0) |
|              |                         |                      |                |                                                                                                          |
|              |                         |                      |                |                                                                                                          |
|              |                         |                      |                |                                                                                                          |
|              |                         |                      |                |                                                                                                          |
|              |                         |                      |                |                                                                                                          |
| movbw - Move | byte to 1               | loworder             | byte of        | word<br>Format: qr Flags:                                                                                |
| Syntax:      | mo∨bw                   | bvw                  | wr             |                                                                                                          |
| Semantics:   | lob(wr)                 | := bvw               |                |                                                                                                          |
| Description: |                         |                      |                | to the loworder byte of word reg-<br>byte of wr is NOT changed.                                          |
| Flags:       |                         |                      |                |                                                                                                          |
| Examples:    | mo∨bw<br>mo∨bw<br>mo∨bw | w1<br>[sp+2]<br>[L1] | w0<br>w1<br>w0 | ; Move lob(w1) to lob(w0)<br>; Move byte at sp+2 to lob(w1)<br>; Move byte addressed by L1 to<br>lob(w0) |

MOVD

| movd - Move d | louble               |                      |                | Format: qr Flags:                                                |       |
|---------------|----------------------|----------------------|----------------|------------------------------------------------------------------|-------|
| Syntax:       | movd                 | dv                   | dr             |                                                                  |       |
| Semantics:    | dr := d              | v                    |                |                                                                  |       |
| Description:  | Move do              | uble val             | ue dv to       | double register dr.                                              |       |
| Flags:        |                      |                      |                |                                                                  |       |
| Examples:     | mo∨d<br>mo∨d<br>mo∨d | d1<br>[sp+2]<br>[L1] | d0<br>d1<br>d0 | ; d0 := d1<br>; d1 := double at sp+2<br>; d0 := double addressed | by L1 |

| movf - Move f | loat                 |                      |                | Format: qr Flags:                                                    |
|---------------|----------------------|----------------------|----------------|----------------------------------------------------------------------|
| Syntax:       | movf                 | fv                   | fr             |                                                                      |
| Semantics:    | fr := f              | v                    |                |                                                                      |
| Description:  | Move fl              | oat valu             | e fv to        | float register fr.                                                   |
| Flags:        |                      |                      |                |                                                                      |
| Examples:     | mo∨f<br>movf<br>movf | f1<br>[sp+2]<br>[L1] | f0<br>f1<br>f0 | ; f0 := f1<br>; f1 := float at sp+2<br>; f0 := float addressed by L: |

| movflags - Mo | ve word to flags regis                          | ter<br>Format: qo                                 | Flags:                         |
|---------------|-------------------------------------------------|---------------------------------------------------|--------------------------------|
| Syntax:       | movflags wv                                     |                                                   |                                |
| Semantics:    | flags := wv                                     |                                                   |                                |
| Description:  | Move word value wv to                           | the flags regist                                  | er.                            |
| Flags:        |                                                 |                                                   |                                |
| Examples:     | movflags w1<br>movflags [sp+2]<br>movflags [L1] | ; flags := w1<br>; flags := wor<br>; flags := wor | d at sp+2<br>d addressed by L1 |

| movl - Move l | ong                  |                      |                | Format: qr                                        | Flags: |
|---------------|----------------------|----------------------|----------------|---------------------------------------------------|--------|
| Syntax:       | movl                 | lv                   | lr             |                                                   |        |
| Semantics:    | lr := 1              | v                    |                |                                                   |        |
| Description:  | Move lo              | ng value             | lv to l        | ong register lr.                                  |        |
| Flags:        |                      |                      |                |                                                   |        |
| Examples:     | movl<br>movl<br>movl | L1<br>[sp+2]<br>[L1] | L0<br>L1<br>L0 | ; L0 := L1<br>; L1 := long at<br>; L0 := long add |        |

MOVL

# MOVW

| movw - Move w | ord                  |                      |                | Format: qr Flags:                                                  |
|---------------|----------------------|----------------------|----------------|--------------------------------------------------------------------|
| Syntax:       | MO∨W                 | WV                   | wr             |                                                                    |
| Semantics:    | wr := w              | IV                   |                |                                                                    |
| Description:  | Move wo              | ord value            | wv to w        | ord register wr.                                                   |
| Flags:        |                      |                      |                |                                                                    |
| Examples:     | mo∨w<br>mo∨w<br>mo∨w | w1<br>[sp+2]<br>[L1] | w0<br>w1<br>w0 | ; w0 := w1<br>; w1 := word at sp+2<br>; w0 := word addressed by L1 |

| movwl | - | Move | word | to | loworder | word | of | long    |    |        |
|-------|---|------|------|----|----------|------|----|---------|----|--------|
|       |   |      |      |    |          |      |    | Format: | qr | Flags: |
|       |   |      |      |    |          |      |    |         |    |        |

Syntax: movwl wv lr

Semantics: low(lr) := wv

Description: Word value wv is moved to the loworder word of long register lr. The highorder word of lr is NOT changed.

| movwl | w1     | L0      | ; Move w1 to low(L0)           |
|-------|--------|---------|--------------------------------|
| movwl | [sp+2] | L1      | ; Move word at sp+2 to low(L1) |
| movwl | [L1] - | L0      | ; Move word addressed by L1 to |
|       |        |         | low(L0)                        |
|       | movwl  | · · · · | movwl [sp+2] L1                |

MULD

| muld - Multip | y double             |                  | Format: qr Flags: |                                                                                    |
|---------------|----------------------|------------------|-------------------|------------------------------------------------------------------------------------|
| Syntax:       | muld                 | dv               | dr                |                                                                                    |
| Semantics:    | dr := d              | r * dv           |                   |                                                                                    |
| Description:  | Double               | register         | dr is m           | nultiplied by double value dv.                                                     |
| Flags:        |                      |                  |                   |                                                                                    |
| Examples:     | muld<br>muld<br>muld | d1<br>d0<br>[L1] | d1<br>d1<br>d0    | ; d1 := d1 * d1<br>; d1 := d1 * d0<br>; d0 := d0 * double value<br>addressed by L1 |
|               |                      |                  |                   |                                                                                    |
|               |                      |                  |                   |                                                                                    |
|               |                      |                  |                   |                                                                                    |
| mulf - Multip | y float              |                  |                   | Format: qr Flags:                                                                  |
| Syntax:       | mulf                 | fv               | fr                |                                                                                    |
| Semantics:    | fr := f              | r * fv           |                   |                                                                                    |
| Description:  | Float r              | egister          | fr is mu          | ltiplied by float value fv.                                                        |
| Flags:        |                      |                  |                   |                                                                                    |
| Examples:     | mulf<br>mulf<br>mulf | f1<br>f0<br>[L1] | f1<br>f1<br>f0    | ; f1 := f1 * f1<br>; f1 := f1 * f0<br>; f0 := f0 * float value<br>addressed by L1  |

# MULSL

| mulsl - Multi                                    | py signed long                                    | Format: qr Flags:                                                                            |  |  |  |
|--------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------|--|--|--|
| Syntax:                                          | mulsl lv lr                                       |                                                                                              |  |  |  |
| Semantics:                                       | lr := lr * lv                                     |                                                                                              |  |  |  |
| Description:                                     | Long register lr is mul<br>quantities are treated | ltiplied by long value lv. Both<br>as SIGNED integers.                                       |  |  |  |
| Flags:                                           |                                                   |                                                                                              |  |  |  |
| Examples:                                        | mulsl L2 L1<br>mulsl [sp+2] L1<br>mulsl [L1] L0   | ; L1 := L1 * L2;<br>; L1 := L1 * long at sp+2;<br>; L0 := L0 * long value addressed<br>by L1 |  |  |  |
| mulsw - Multipy signed word<br>Format: qr Flags: |                                                   |                                                                                              |  |  |  |
| Syntax:                                          | mulsw wv wr                                       |                                                                                              |  |  |  |
| Semantics:                                       | wr := wr * wv                                     |                                                                                              |  |  |  |
| Description:                                     | Word register wr is mul<br>quantities are treated | ltiplied by word value wv. Both<br>as SIGNED integers.                                       |  |  |  |
| Flags:                                           |                                                   |                                                                                              |  |  |  |

| Examples: | mulsw | w2     | w1 | ; w1 := w1 * w2;                  |
|-----------|-------|--------|----|-----------------------------------|
| -         | mulsw | [sp+2] | w1 | ; w1 := w1 * word at sp+2;        |
|           | mulsw | [L1]   | w0 | ; w0 := w0 * word value addressed |
|           |       |        |    | by L1                             |

MULSWL

| mulswl - Mult | ipy signed words yi                                                                                         |                                                                                                                                                                             | Flags:                                                                                           |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|
| Syntax:       | mulswl wv lr                                                                                                |                                                                                                                                                                             |                                                                                                  |  |  |
| Semantics:    | lr := lr * wv                                                                                               |                                                                                                                                                                             |                                                                                                  |  |  |
| Description:  | word value wv, and<br>lr. Note that the<br>before this instru-<br>the instruction is<br>is part of the pro- | of long register lr is<br>the result is placed<br>highorder word of lr<br>ction is executed; it<br>executed, the highord<br>duct computed by this<br>ated as SIGNED integer | in long register<br>can have any value<br>is ignored. After<br>er word of lr<br>instruction. All |  |  |
| Flags:        |                                                                                                             |                                                                                                                                                                             |                                                                                                  |  |  |
| Examples:     | mulswl w2 L1<br>mulswl [sp+2] L1<br>mulswl [L1] L0                                                          | ; L1 := low(L1)                                                                                                                                                             | * word at sp+2;                                                                                  |  |  |
| mulul - Multi | py unsigned long                                                                                            | Format: qr                                                                                                                                                                  | Flags:                                                                                           |  |  |
| Syntax:       | mulul lv lr                                                                                                 |                                                                                                                                                                             |                                                                                                  |  |  |
| Semantics:    | lr := lr * lv                                                                                               |                                                                                                                                                                             |                                                                                                  |  |  |
| Description:  | Long register lr is multiplied by long value lv. Both<br>quantities are treated as UNSIGNED integers.       |                                                                                                                                                                             |                                                                                                  |  |  |
| Flags:        |                                                                                                             |                                                                                                                                                                             |                                                                                                  |  |  |
| Examples:     | mulul L2 L1<br>mulul [sp+2] L1<br>mulul [L1] L0                                                             | ; L1 := L1 * lon                                                                                                                                                            |                                                                                                  |  |  |

# MULUW

MULUWL

| muluw - Multi            | ipy unsigned word<br>Format: qr Flags:                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                  | muluw wv wr                                                                                                                                                                                                                                                                                                                                                                                                       |
| Semantics:               | wr := wr * wv                                                                                                                                                                                                                                                                                                                                                                                                     |
| Description:             | Word register wr is multiplied by word value wv. Both<br>quantities are treated as UNSIGNED integers.                                                                                                                                                                                                                                                                                                             |
| Flags:                   |                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Examples:                | <pre>muluw w2 w1 ; w1 := w1 * w2;<br/>muluw [sp+2] w1 ; w1 := w1 * word at sp+2;<br/>muluw [L1] w0 ; w0 := w0 * word value addressed<br/>by L1</pre>                                                                                                                                                                                                                                                              |
| muluwl - Mult<br>Syntax: | tipy unsigned words yielding long<br>Format: qr Flags:<br>muluwl wv lr                                                                                                                                                                                                                                                                                                                                            |
| Semantics:               | lr := lr * wv                                                                                                                                                                                                                                                                                                                                                                                                     |
| Description:             | The loworder word of long register lr is multiplied by<br>word value wv, and the result is placed in long register<br>lr. Note that the highorder word of lr can have any value<br>before this instruction is executed; it is ignored. After<br>the instruction is executed, the highorder word of lr<br>is part of the product computed by this instruction. All<br>quantities are treated as UNSIGNED integers. |
| Flags:                   |                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Examples:                | <pre>muluwl w2 L1 ; L1 := low(L1) * w2;<br/>muluwl [sp+2] L1 ; L1 := low(L1) * word at sp+2;<br/>muluwl [L1] L0 ; L0 := low(L0) * word value<br/>addressed by L1</pre>                                                                                                                                                                                                                                            |

NEGD

| negd - Negate | double               |                      |                | Format: qr Flags:                                                         |
|---------------|----------------------|----------------------|----------------|---------------------------------------------------------------------------|
| Syntax:       | negd                 | dv                   | dr             |                                                                           |
| Semantics:    | dr := -d             | lv                   |                |                                                                           |
| Description:  | Double r<br>dv.      | egister              | dr is s        | et to the negation of double value                                        |
| Flags:        |                      |                      |                |                                                                           |
| Examples:     | negd<br>negd<br>negd | d1<br>d0<br>[L1]     | d1<br>d1<br>d0 | ; d1 := -d1<br>; d1 := -d0<br>; d0 := - (double value<br>addressed by L1) |
| negf - Negate | float                |                      |                | Format: qr Flags:                                                         |
| Syntax:       | negf                 | fv                   | fr             |                                                                           |
| Semantics:    | fr := -f             | v                    |                |                                                                           |
| Description:  | Float re<br>fv.      | egister <sup>.</sup> | fr is se       | t to the negation of float value                                          |
| Flags:        |                      |                      |                |                                                                           |
| Examples:     | negf<br>negf<br>negf | f1<br>f0<br>[L1]     | f1<br>f1<br>f0 | ; f1 := -f1<br>; f1 := -f0<br>; f0 := - (float value<br>addressed by L1)  |

NEGL

| negl - Negate | long                            |                  | Format: qr                                                | Flags:                    |
|---------------|---------------------------------|------------------|-----------------------------------------------------------|---------------------------|
| Syntax:       | negl lv                         | lr               |                                                           |                           |
| Semantics:    | lr := -lv                       |                  |                                                           |                           |
| Description:  | lv. The neg                     | gation of a      | t to the negation<br>long is the 2's-<br>not changed by n | complement of the         |
| Flags:        |                                 |                  |                                                           |                           |
| Examples:     | negl L1<br>negl L0<br>negl [L1] | L1               | ; L1 := -L1<br>; L1 := -L0<br>; L0 := - (long             | value<br>addressed by L1) |
| negw - Negate | word                            |                  | Format: qr                                                | Flags:                    |
| Syntax:       | negw wv                         | wr               |                                                           |                           |
| Semantics:    | wr := -wv                       |                  |                                                           |                           |
| Description:  | wv. The neg                     | gation of a      | t to the negation<br>word is the 2's-<br>changed by negat | complement of the         |
| Flags:        |                                 |                  |                                                           |                           |
| Examples:     | negw w1<br>negw w0<br>negw [L1] | W1<br>W1<br>  W0 | ; w1 := -w1<br>; w1 := -w0<br>; w0 := - (word             | value<br>addressed by L1) |

NOP

| nop - No oper | ation                   | Format: n0       | Flags: |
|---------------|-------------------------|------------------|--------|
| Syntax:       | nop                     |                  |        |
| Semantics:    | No operation            |                  |        |
| Description:  | This instruction does r | nothing.         |        |
| Flags:        |                         |                  |        |
| Example:      | пор                     | ; Kill some time |        |

| notl - Not lo | ng                   |                  |                | Format: qr                                     | Flags:                    |
|---------------|----------------------|------------------|----------------|------------------------------------------------|---------------------------|
| Syntax:       | notl                 | lv               | lr             |                                                |                           |
| Semantics:    | lr := ~:             | lv               |                |                                                |                           |
| Description:  | Long reg<br>value ly | •                | r is set       | to the bitwise r                               | negation of long          |
| Flags:        |                      |                  |                |                                                |                           |
| Examples:     | notl<br>notl<br>notl | L1<br>L0<br>[L1] | L1<br>L1<br>L0 | ; L1 := ~L1<br>; L1 := ~L0<br>; L0 := ~(long v | value addressed<br>by L1) |

NOTW

notw - Not word

Syntax: notw wv wr

Semantics: wr := ~wv

Description: Long register wr is set to the bitwise negation of long value wv.

Flags:

Examples: notw w1 w1 ; w1 :=  $\neg$ w1 notw w0 w1 ; w1 :=  $\neg$ w0 notw [L1] w0 ; w0 :=  $\neg$ (word value addressed by L1)

| orl - Or long |                   |                  |                | Format: qr        | Flags:                     |
|---------------|-------------------|------------------|----------------|-------------------|----------------------------|
| Syntax:       | orl               | lv               | lr             |                   |                            |
| Semantics:    | lr := 1           | r   lv           |                |                   |                            |
| Description:  | Long va           | lue lv i         | s bitwis       | e or-ed to long r | egister lr.                |
| Flags:        |                   |                  |                |                   |                            |
| Examples:     | orl<br>orl<br>orl | L1<br>L0<br>[L1] | L1<br>L1<br>L0 | ; L0 := L0   lon  | g value<br>addressed by L1 |

ORW

| orw - Or word | I                            |                | Format: qr                                             | Flags:                     |
|---------------|------------------------------|----------------|--------------------------------------------------------|----------------------------|
| Syntax:       | orw wv                       | wr             |                                                        |                            |
| Semantics:    | wr := wr   wv                |                |                                                        |                            |
| Description:  | Word value wv                | is bitwis      | se or-ed to word r                                     | egister wr.                |
| Flags:        |                              |                |                                                        |                            |
| Examples:     | orw w1<br>orw w0<br>orw [L1] | W1<br>W1<br>W0 | ; w1 := w1   w1<br>; w1 := w1   w0<br>; w0 := w0   wor | d value<br>addressed by L1 |

| popd - Pop do | uble                 |                            | Format: qo                                            | Flags:                         |
|---------------|----------------------|----------------------------|-------------------------------------------------------|--------------------------------|
| Syntax:       | popd                 | da                         |                                                       |                                |
| Semantics:    | da := d<br>sp := s   | ouble addressed  <br>p + 8 | by sp                                                 |                                |
| Description:  | Pop a d              | ouble off the sta          | ack into da.                                          |                                |
| Flags:        |                      |                            |                                                       |                                |
| Examples:     | popd<br>popd<br>popd | d1<br>[fp+2]<br>[L1]       | ; Pop into d1<br>; Pop into doubl<br>; Pop into doubl | e at fp+2<br>e addressed by L1 |

POPF

| popf - Pop fl | oat                                         | F             | ormat: qo                        |       | Flags:               |       |
|---------------|---------------------------------------------|---------------|----------------------------------|-------|----------------------|-------|
| Syntax:       | popf fa                                     |               |                                  |       |                      |       |
| Semantics:    | fa := float addressed by sp<br>sp := sp + 4 |               |                                  |       |                      |       |
| Description:  | Pop a float                                 | off the stack | into fa.                         |       |                      |       |
| Flags:        |                                             |               |                                  |       |                      |       |
| Examples:     | popf f1<br>popf [fp+<br>popf [L1]           | -2] ;         | Pop into<br>Pop into<br>Pop into | float | at fp+2<br>addressed | by L1 |

| popl - Pop lo | ng                   |                           | Format: qo                                          | Flags:                     |
|---------------|----------------------|---------------------------|-----------------------------------------------------|----------------------------|
| Syntax:       | popl                 | la                        |                                                     |                            |
| Semantics:    | la := lo<br>sp := s  | ong addressed by<br>o + 4 | sp                                                  |                            |
| Description:  | Pop a lo             | ong off the stac          | k into la.                                          |                            |
| Flags:        |                      |                           |                                                     |                            |
| Examples:     | popl<br>popl<br>popl | L1<br>[fp+2]<br>[L1]      | ; Pop into L1<br>; Pop into long<br>; Pop into long | at fp+2<br>addressed by L1 |

#### POPREGS

popregs - Pop multiple registers

рорм

[L1]

Format: n04 Flags:

Syntax: popregs bmsk

Semantics: Multiple registers are popped.

Description: The bit mask bmsk is scanned from bit 31 to bit 0, and for each bit that is on, the corresponding register is popped (i.e., the top of the stack is popped into the register). See an earlier section for the numbering of the 32 major VMAX registers. Only as many bytes as a register holds are popped for each register. Thus, if bmsk indicates that d1, f1, L1, and w1 are to be popped, then 8-bytes, 4bytes, 4-bytes, and 2-bytes are popped. Note that popregs and pushregs scan the bit mask in opposite orders, so the masked used to push a group of registers can also be used to pop the registers.

Flags:

| Examples: | popregs | 0x80000003 | ; | Рор | d7,  | w1,  | and | w0 |
|-----------|---------|------------|---|-----|------|------|-----|----|
|           | popregs | 0x30000008 | ; | Рор | d5,  | d4,  | and | wЗ |
|           | popregs | 0          | ; | Рор | notl | hing |     |    |

| рорм - Рор wo | rd                       | F                   | Format: qo                | Flags: |
|---------------|--------------------------|---------------------|---------------------------|--------|
| Syntax:       | рорм wa                  |                     |                           |        |
| Semantics:    | wa := word<br>sp := sp + | addressed by s<br>2 | sp                        |        |
| Description:  | Pop a word               | off the stack       | into wa.                  |        |
| Flags:        |                          |                     |                           |        |
| Examples:     | popw w1<br>popw [fr      | ;<br>)+2]      ;    | Pop into wi<br>Pop into w |        |

; Pop into word addressed by L1

POPW

PUSHD

PUSHF

| pushd - Push | double                           |                                     | Fo  | ormat | : qo             | Flags:                          |      |    |
|--------------|----------------------------------|-------------------------------------|-----|-------|------------------|---------------------------------|------|----|
| Syntax:      | pushd                            | dv                                  |     |       |                  |                                 |      |    |
| Semantics:   | sp := s<br>Move dv               | p - 8<br>to address cont            | ain | ed in | n sp             |                                 |      |    |
| Description: | Push do                          | Push double value dv onto the stack |     |       |                  |                                 |      |    |
| Flags:       |                                  |                                     |     |       |                  |                                 |      |    |
| Examples:    | pushd<br>pushd<br>pushd<br>pushd | d1<br>[fp+2]<br>[L1]<br>3.14159     | ;;  | Push  | double<br>double | at fp+2<br>addressed<br>3.14159 | by l | _1 |

| pushf - Push | float                            |                                 | Format: qo                                                      | Flags:         |
|--------------|----------------------------------|---------------------------------|-----------------------------------------------------------------|----------------|
| Syntax:      | pushf                            | fv                              |                                                                 |                |
| Semantics:   | sp := s<br>Move fv               | p - 4<br>to address cont        | ained in sp                                                     |                |
| Description: | Push fl                          | oat value fv ont                | o the stack                                                     |                |
| Flags:       |                                  |                                 |                                                                 |                |
| Examples:    | pushf<br>pushf<br>pushf<br>pushf | f1<br>[fp+2]<br>[L1]<br>3.14159 | ; Push f1<br>; Push float a<br>; Push float a<br>; Push float 3 | ddressed by L1 |

#### PUSHREGS

#### PUSHL

pushl - Push long Format: qo Flags: Syntax: pushl lv Semantics: sp := sp - 4 Move lv to address contained in sp Description: Push long value lv onto the stack Flags: Examples: pushl ; Push L1 L1 pushl [fp+2] ; Push long at fp+2 ; Push long addressed by L1 pushl [L1] 0xaabbccdd ; Push long 0xaabbccdd pushl

pushregs - Push multiple registers Format: n04 Flags:

Syntax: pushregs bmsk

Semantics: Multiple registers are pushed.

Description: The bit mask bmsk is scanned from bit 0 to bit 31, and for each bit that is on, the corresponding register is pushed onto the stack. See an earlier section for the numbering of the 32 major VMAX registers. Only as many bytes as a register holds are pushed for each register. Thus, if bmsk indicates that w1, L1, f1, and d1 are to be pushed, then 2-bytes, 4-bytes, 4-bytes, and 8-bytes are pushed. Note that pushregs and popregs scan the bit mask in opposite orders, so the masked used to push a group of registers can also be used to pop the registers.

| Examples: | pushregs | 0x80000003 | ; | Push | w0,  | w1,  | and | d7 |
|-----------|----------|------------|---|------|------|------|-----|----|
|           | pushregs | 0x30000008 | ; | Push | w3,  | d4,  | and | d5 |
|           | pushregs | 0          | ; | Push | notl | ning |     |    |

# PUSHW

REMSL

| pushw - Push | word Format: qo Flags:                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------|
| Syntax:      | pushw wv                                                                                                        |
| Semantics:   | sp := sp - 2<br>Move wv to address contained in sp                                                              |
| Description: | Push word value wv onto the stack                                                                               |
| Flags:       |                                                                                                                 |
| Examples:    | pushww1; Push w1pushw[fp+2]; Push word at fp+2pushw[L1]; Push word addressed by L1pushw0xeeff; Push word 0xeeff |

| remsl - Remai | nder signed long                       | 9         | Format: qr                                                     | Flags:                                       |
|---------------|----------------------------------------|-----------|----------------------------------------------------------------|----------------------------------------------|
| Syntax:       | remsl lv                               | lr        |                                                                |                                              |
| Semantics:    | lr := lr % lv                          |           |                                                                |                                              |
| Description:  | mainder is plac                        | ce in lr. |                                                                | ue lv, and the re-<br>calculated. All<br>rs. |
| Flags:        |                                        |           |                                                                |                                              |
| Examples:     | remsl L2<br>remsl [sp+2]<br>remsl [L1] | L1        | ; L1 := L1 % L2<br>; L1 := L1 % lo<br>; L0 := L0 % lo<br>by L1 |                                              |

# REMSW

| remsw - Remai | nder signed wor                        | d              | Format: q | r Fi       | lags:                                  |
|---------------|----------------------------------------|----------------|-----------|------------|----------------------------------------|
| Syntax:       | remsw wv                               | wr             |           |            |                                        |
| Semantics:    | wr := wr % wv                          |                |           |            |                                        |
| Description:  |                                        | ce in wr.      | No quoti  | ent is ca  | wv, and the re-<br>lculated. All       |
| Flags:        |                                        |                |           |            |                                        |
| Examples:     | remsw w2<br>remsw [sp+2]<br>remsw [L1] |                |           | 1 % word a | at sp+2<br>value addressed             |
| remul - Remai | nder unsigned l                        | ong            | Format: q | r F        | lags:                                  |
| Syntax:       | remul lv                               | lr             |           |            |                                        |
| Semantics:    | lr := lr % lv                          |                |           |            |                                        |
| Description:  |                                        | ce in lr.      | No quoti  | ent is ca  | lv, and the re-<br>lculated. All<br>s. |
| Flags:        |                                        |                |           |            |                                        |
| Examples:     | remul L2<br>remul [sp+2]<br>remul [L1] | L1<br>L1<br>L0 |           | 1 % long a | at sp+2<br>value addressed             |

by L1

# REMUW

| remuw - Remai | nder unsigned word.                             | Format: qr Flags:                                                                                       |
|---------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| Syntax:       | remuw wv wr                                     |                                                                                                         |
| Semantics:    | wr := wr % wv                                   |                                                                                                         |
| Description:  | mainder is place in w                           | divided by word value wv, and the re-<br>wr. No quotient is calculated. All<br>ed as UNSIGNED integers. |
| Flags:        |                                                 |                                                                                                         |
| Examples:     | remuw w2 w1<br>remuw [sp+2] w1<br>remuw [L1] w0 | ; w1 := w1 % w2<br>; w1 := w1 % word at sp+2<br>; w0 := w0 % word value addressed<br>by L1              |

RET

ret - Return from call

Format: b1 Flags:

Syntax: ret stkc

- Semantics: Move long addressed by sp to pc sp := sp + 4 sp := sp + 2\*stkc
- Description: This instruction is used to return from a subroutine. It pops the return address off the stack into pc, and then increments the stack by 2\*stkc to clear parameters to the subroutine out of the stack. Note that stkc is an unsigned quantity, scaled by a factor of 2 (because the smallest entity that can be pushed or popped is a word). Thus, at most 510 bytes can be cleared from the stack by the ret instruction. If more must be cleared, then this must be done by a addl to sp following the call of the function.

Many implementations of C assume that every function can take a variable number of parameters. In such cases, "ret 0" is always generated, and the stack is adjusted by an addl instruction following the call.

| Examples: | ret | 22 | ; | Clear | 22 | bytes | from | stack |
|-----------|-----|----|---|-------|----|-------|------|-------|
|           | ret | 0  | ; | Clear | no | bytes | from | stack |

| rlil - Rotate | e left immediate long<br>Format: ir Flags:                                                                                                                                                                                                                                                                                                                             |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | rlil sc lr                                                                                                                                                                                                                                                                                                                                                             |
| Semantics:    | <pre>lr := lr rotated left by sc bits</pre>                                                                                                                                                                                                                                                                                                                            |
| Description:  | Long register lr is rotated left by sc bits. Bits shifted<br>out of the highorder end of the register are shifted into<br>the loworder end of the register. Note that the maximum<br>value sc can have is 31. This is no problem, since there<br>is never any need to rotate a long register by 32 bits,<br>specified as an immediate value. The sc value is UNSIGNED. |
| Flags:        |                                                                                                                                                                                                                                                                                                                                                                        |

| Examples: | rlil | 1  | L1 | ; | Rotate | L1 | left | 1 I | bit  |
|-----------|------|----|----|---|--------|----|------|-----|------|
| -         | rlil | 10 | L2 | ; | Rotate | L2 | left | 10  | bits |
|           | rlil | 31 | L3 | ; | Rotate | L3 | left | 31  | bits |

| rliw | - | Rotate lef | t imme | diate | word |         |    |        |
|------|---|------------|--------|-------|------|---------|----|--------|
|      |   |            |        |       |      | Format: | ir | Flags: |

Syntax: rliw sc wr

Semantics: wr := wr rotated left by sc bits

Description: Word register wr is rotated left by sc bits. Bits shifted out of the highorder end of the register are shifted into the loworder end of the register. If sc >= 16, then the effect is the same as if the number of bits rotated is sc mod 16. The sc value is UNSIGNED.

| Examples: | rliw | 1  | w1 | ; | Rotate | w1 | left | 11 | oit  |
|-----------|------|----|----|---|--------|----|------|----|------|
|           | rliw | 10 | w2 | ; | Rotate | w2 | left | 10 | bits |
|           | rliw | 31 | w3 | ; | Rotate | wЗ | left | 15 | bits |

Format: qr Flags: Syntax: rll bvl lr lr := lr rotated left by bvl bits Long register lr is rotated left by bvl bits. Bits shiftbvl mod 32. The bvl value is UNSIGNED. ifed by byte addressed by L1 rlw - Rotate left word Format: gr Flags: Syntax: rlw bvw wr wr := wr rotated left by bvw bits Semantics: Description: Word register wr is rotated left by bvw bits. Bits shifted out of the highorder end of the register are shifted into the loworder end of the register. If bvw >= 16, then the effect is the same as if the number of bits rotated is bvw mod 16. The bvw value is UNSIGNED. Flags: · Rotate w1 left by loh(w2) bits w2 rlw Examples: w1

| ampies: | Γ⊥W | WZ     | WT | ; ROTATE WI LETT DY LOD(WZ) DITS   |
|---------|-----|--------|----|------------------------------------|
|         | rlw | [sp+2] | w2 | ; Rotate w2 left by no. bits spec- |
|         |     |        |    | ifed by byte at sp+2               |
|         | rlw | [L1]   | w3 | ; Rotate w3 left by no. bits spec- |
|         |     |        |    | ifed by byte addressed by L1       |

rll - Rotate left long

Semantics:

Description: ed out of the highorder end of the register are shifted into the loworder end of the register. If bvl >= 32, then the effect is the same as if the number of bits rotated is

| Examples: | rll | L2     | L1 | ; Rotate L1 left by lob(L2) bits   |
|-----------|-----|--------|----|------------------------------------|
|           | rll | [sp+2] | L2 | ; Rotate L2 left by no. bits spec- |
|           |     |        |    | ifed by byte at sp+2               |
|           | rll | [L1]   | L3 | ; Rotate L3 left by no. bits spec- |
|           |     |        |    | ifed by byte addressed by 11       |

| rril - Rotate | right immediate                                                                                                                                                                                                                                                                          | e long                                                                                                                                                                                                                                                                                                                                                                           | Format: ir Flags:                                                                 |  |  |  |  |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:       | rril sc                                                                                                                                                                                                                                                                                  | lr                                                                                                                                                                                                                                                                                                                                                                               |                                                                                   |  |  |  |  |  |
| Semantics:    | lr := lr rotate                                                                                                                                                                                                                                                                          | ed right                                                                                                                                                                                                                                                                                                                                                                         | by sc bits                                                                        |  |  |  |  |  |
| Description:  | ed out of the l<br>to the highorde<br>mum value sc ca<br>there is never                                                                                                                                                                                                                  | Long register lr is rotated right by sc bits. Bits shift-<br>ed out of the loworder end of the register are shifted in-<br>to the highorder end of the register. Note that the maxi-<br>num value sc can have is 31. This is no problem, since<br>there is never any need to rotate a long register by 32<br>pits, specified as an immediate value. The sc value is<br>JNSIGNED. |                                                                                   |  |  |  |  |  |
| Flags:        |                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                   |  |  |  |  |  |
| Examples:     | rril 1<br>rril 10<br>rril 31                                                                                                                                                                                                                                                             | L1<br>L2<br>L3                                                                                                                                                                                                                                                                                                                                                                   | ; Rotate L1 right 1 bit<br>; Rotate L2 right 10 bits<br>; Rotate L3 right 31 bits |  |  |  |  |  |
| rriw - Rotate | right immediate                                                                                                                                                                                                                                                                          | e word                                                                                                                                                                                                                                                                                                                                                                           | Format: ir Flags:                                                                 |  |  |  |  |  |
| Syntax:       | rriw sc                                                                                                                                                                                                                                                                                  | wr                                                                                                                                                                                                                                                                                                                                                                               |                                                                                   |  |  |  |  |  |
| Semantics:    | wr := wr rotate                                                                                                                                                                                                                                                                          | ed right                                                                                                                                                                                                                                                                                                                                                                         | by sc bits                                                                        |  |  |  |  |  |
| Description:  | Word register wr is rotated right by sc bits. Bits shift-<br>ed out of the loworder end of the register are shifted in-<br>to the highorder end of the register. If sc >= 16, then<br>the effect is the same as if the number of bits rotated is<br>sc mod 16. The sc value is UNSIGNED. |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                   |  |  |  |  |  |
| Flags:        |                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                   |  |  |  |  |  |
| Examples:     | rriw 1<br>rriw 10<br>rriw 31                                                                                                                                                                                                                                                             | w1<br>w2<br>w3                                                                                                                                                                                                                                                                                                                                                                   | ; Rotate w1 right 1 bit<br>; Rotate w2 right 10 bits<br>; Rotate w3 right 15 bits |  |  |  |  |  |

RRW

| rrl - Rotate | right lo                                     | ng                 |                               | Fo              | ormat:                  | qr                      |                       | Flags:                                                                               |
|--------------|----------------------------------------------|--------------------|-------------------------------|-----------------|-------------------------|-------------------------|-----------------------|--------------------------------------------------------------------------------------|
| Syntax:      | rrl                                          | bvl                | lr                            |                 |                         |                         |                       |                                                                                      |
| Semantics:   | lr := 1                                      | r rotate           | d right                       | by              | bvl b                   | oits                    |                       |                                                                                      |
| Description: | ted out<br>into the<br>then the              | of the<br>e highor | loworder<br>der end<br>is the | en<br>of<br>sam | nd of<br>the r<br>ne as | the r<br>egist<br>if th | egist<br>er.<br>e nur | bits. Bits shif-<br>ter are shifted<br>If bvl >= 32,<br>mber of bits ro-<br>NSIGNED. |
| Flags:       |                                              |                    |                               |                 |                         |                         |                       |                                                                                      |
| Examples:    | rrl<br>rrl                                   | L2<br>[sp+2]       |                               | ;               | Rotat<br>cif            | e L2<br>ed by           | right<br>byte         | t by lob(L2) bits<br>t by no. bits spe-<br>e at sp+2                                 |
|              | rrl                                          | [L1]               | L3                            | ;               |                         |                         |                       | t by no. bits spe-<br>e addressed by L1                                              |
| rrw - Rotate | rrw - Rotate right word<br>Format: qr Flags: |                    |                               |                 |                         |                         |                       |                                                                                      |
| Syntax:      | rrw                                          | b∨w                | wr                            |                 |                         |                         |                       |                                                                                      |
| Semantics:   | wr := w                                      | r rotate           | d right                       | by              | bvw b                   | oits                    |                       |                                                                                      |
| Description: | ted out<br>into the<br>then the              | of the<br>e highor | loworder<br>der end<br>is the | en<br>of<br>sam | nd of<br>the r<br>ne as | the r<br>egist<br>if th | egist<br>er.<br>e nur | bits. Bits shif-<br>ter are shifted<br>If bvw >= 16,<br>mber of bits ro-<br>NSIGNED. |
| Flags:       |                                              |                    |                               |                 |                         |                         |                       |                                                                                      |
| Examples:    | rrw<br>rrw                                   | w2<br>[sp+2]       | w1<br>w2                      |                 | Rotat                   | e w2                    | right                 | t by lob(w2) bits<br>t by no. bits spe-<br>e at sp+2                                 |
|              | rrw                                          | [L1]               | w3                            | ;               | Rotat                   | e w3                    | right                 | by no. bits spe-<br>addressed by L1                                                  |

RRL

SET0L

| set0l - Store | condition(0) in long<br>Format: qc Flags:                                                                                                                                                                                                                                                                                                             |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | set0l c0 la                                                                                                                                                                                                                                                                                                                                           |
| Semantics:    | la := (condition c0 is TRUE)                                                                                                                                                                                                                                                                                                                          |
| Description:  | The long addressed by la is set to the integer value 1 if<br>the condition specified by c0 is TRUE. Otherwise, it is<br>set to 0. Note that only conditions 1 through 7 can be<br>specified by c0; see the set1l instruction for conditions<br>8 through 14. (See the description of the i-operand of<br>the ij-format for a list of all conditions.) |
| Flags:        |                                                                                                                                                                                                                                                                                                                                                       |
|               |                                                                                                                                                                                                                                                                                                                                                       |

| Examples: | set0l | cNE | L2     | ; L2 := (EF==0)                    |
|-----------|-------|-----|--------|------------------------------------|
|           | set0l | cG  | [sp+2] | ; Long at sp+2 := (GF==1)          |
|           | set0l | cLU | [L1]   | ; Long addressed by L1 := (LUF==1) |

| set0w | - | Store | condition(0) | in w | ord |         |    |        |
|-------|---|-------|--------------|------|-----|---------|----|--------|
|       |   |       |              |      |     | Format: | qc | Flags: |

Syntax: setOw cO wa

Semantics: wa := (condition c0 is TRUE)

Description: The word addressed by wa is set to the integer value 1 if the condition specified by c0 is TRUE. Otherwise, it is set to 0. Note that only conditions 1 through 7 can be specified by c0; see the set1w instruction for conditions 8 through 14. (See the description of the i-operand of the ij-format for a list of all conditions.)

```
Examples: setOw cNE w2 ; w2 := (EF==0)
setOw cG [sp+2] ; Word at sp+2 := (GF==1)
setOw cLU [L1] ; Word addressed by L1 := (LUF==1)
```

SET1L

Flags:

| set1l - Store                                                                                                                                                                                                                                                                                                                                        | re condition(1) in long<br>Format: qc Flags | : |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|---|--|--|--|
| Syntax:                                                                                                                                                                                                                                                                                                                                              | set1l c0 la                                 |   |  |  |  |
| Semantics:                                                                                                                                                                                                                                                                                                                                           | la := (condition c1+8 is TRUE)              |   |  |  |  |
| Description: The long addressed by la is set to the integer value 1<br>the condition specified by c1+8 is TRUE. Otherwise, is<br>set to 0. Note that only conditions 8 through 14 can<br>specified by c1; see the set0l instruction for condit.<br>1 through 7. (See the description of the i-operand of<br>ij-format for a list of all conditions.) |                                             |   |  |  |  |
| Flags:                                                                                                                                                                                                                                                                                                                                               |                                             |   |  |  |  |
| Examples:                                                                                                                                                                                                                                                                                                                                            | set1l cL L2 ; L2 := (LF==1)                 |   |  |  |  |

| Examples: | set1l | cL  | L2     | ; L2 := (LF==1)                    |
|-----------|-------|-----|--------|------------------------------------|
|           | set1l | cE  | [sp+2] | ; Long at sp+2 := (EF==1)          |
|           | set1l | cGU | [L1]   | ; Long addressed by L1 := (GUF==1) |

| set1w | - | Store condition(1) in word |         |    |  |
|-------|---|----------------------------|---------|----|--|
|       |   |                            | Format: | qc |  |

Syntax: set1w c0 wa

Semantics: wa := (condition c1+8 is TRUE)

Description: The word addressed by wa is set to the integer value 1 if the condition specified by c1+8 is TRUE. Otherwise, it is set to 0. Note that only conditions 8 through 14 can be specified by c1; see the set0w instruction for conditions 1 through 7. (See the description of the i-operand of the ij-format for a list of all conditions.)

```
Examples: set1w cL w2 ; w2 := (LF==1)
set1w cE [sp+2] ; Word at sp+2 := (EF==1)
set1w cGU [L1] ; Word addressed by L1 := (GUF==1)
```

|              |                                                                                      | U                                                                                                                                                                                                                                                                                                                                                                                                  | Format: ir                                            | Flags:  |  |  |  |  |
|--------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|---------|--|--|--|--|
| Syntax:      | slil sc                                                                              | lr                                                                                                                                                                                                                                                                                                                                                                                                 |                                                       |         |  |  |  |  |
| Semantics:   | lr := lr shift                                                                       | ed left                                                                                                                                                                                                                                                                                                                                                                                            | by sc bits                                            |         |  |  |  |  |
| Description: | out of the hig<br>zero bits are<br>ter. Note that<br>is no problem,<br>long register | Long register lr is shifted left by sc bits. Bits shifted<br>out of the highorder end of the register are lost, and<br>zero bits are shifted into the loworder end of the regis-<br>ter. Note that the maximum value sc can have is 31. This<br>is no problem, since there is never any need to shift a<br>long register by 32 bits, specified as an immediate value.<br>The sc value is UNSIGNED. |                                                       |         |  |  |  |  |
| Flags:       |                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                    |                                                       |         |  |  |  |  |
| Examples:    | slil 1<br>slil 10<br>slil 31                                                         | L1<br>L2<br>L3                                                                                                                                                                                                                                                                                                                                                                                     | ; Shift L1 left<br>; Shift L2 left<br>; Shift L3 left | 10 bits |  |  |  |  |
| sliw - Shift | left immediate v                                                                     | word                                                                                                                                                                                                                                                                                                                                                                                               | Format: ir                                            | Flags:  |  |  |  |  |

Syntax: sliw sc wr

slil - Shift left immediate long

wr := wr shifted left by sc bits Semantics:

Word register wr is shifted left by sc bits. Bits shifted out of the highorder end of the register are lost, and Description: zero bits are shifted into the loworder end of the register. If sc >= 16, then wr is set to zero. The sc value is UNSIGNED.

| Examples: | sliw | 1  | w1 | ; | Shift | w1 | left | 1  | oit  |
|-----------|------|----|----|---|-------|----|------|----|------|
|           | sliw | 10 | w2 | ; | Shift | w2 | left | 10 | bits |
|           | sliw | 16 | w3 | ; | w3 := | 0  |      |    |      |

| sll - Shift I | left long         | ]                                |                        | Format: qr Flags:                                                                                                                                        |
|---------------|-------------------|----------------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | sll               | bvl                              | lr                     |                                                                                                                                                          |
| Semantics:    | lr := ]           | r shifte                         | ed left H              | by bvl bits                                                                                                                                              |
| Description:  | ed out<br>zero bi | of the h<br>ts are s<br>f bvl >= | nighorden<br>shifted : | ifted left by bvl bits. Bits shift-<br>r end of the register are lost, and<br>into the loworder end of the regis-<br>en lr is set to zero. The bvl value |
| Flags:        |                   |                                  |                        |                                                                                                                                                          |
| Examples:     | sll<br>sll        | L2<br>[sp+2]                     |                        | ; Shift L1 left by lob(L2) bits<br>; Shift L2 left by no. bits spec-<br>ifed by byte at sp+2                                                             |
|               | sll               | [L1]                             | L3                     | ; Shift L3 left by no. bits spec-<br>ifed by byte addressed by L1                                                                                        |
| slw - Shift I | left word         | I                                |                        | Format: qr Flags:                                                                                                                                        |
| Syntax:       | slw               | bvw                              | wr                     |                                                                                                                                                          |
| Semantics:    | wr := w           | vr shifte                        | ed left H              | by bvw bits                                                                                                                                              |
| Description:  | ed out<br>zero bi | of the h<br>ts are s<br>f bvw >= | nighorden<br>shifted : | ifted left by bvw bits. Bits shift-<br>r end of the register are lost, and<br>into the loworder end of the regis-<br>en wr is set to zero. The bvw value |
| Flags:        |                   |                                  |                        |                                                                                                                                                          |
| Examples:     | slw<br>slw        | w2<br>[sp+2]                     | w1<br>w2               | ; Shift w1 left by lob(w2) bits<br>; Shift w2 left by no. bits spec-<br>ifed by byte at sp+2                                                             |
|               | slw               | [L1]                             | w3                     | ; Shift w3 left by no. bits spec-<br>ifed by byte addressed by L1                                                                                        |

# SQRTD

| sqrtd - Squar | e root of double                   | Fc         | ormat: q | l.                                     | Flags:                      |
|---------------|------------------------------------|------------|----------|----------------------------------------|-----------------------------|
| Syntax:       | sqrtd dv                           | dr         |          |                                        |                             |
| Semantics:    | dr := sqrt(dv)                     |            |          |                                        |                             |
| Description:  | The square root<br>dr.             | of double  | dv is s  | stored in                              | double register             |
|               | QUESTION: What                     | if dv < 0? | ?        |                                        |                             |
| Flags:        |                                    |            |          |                                        |                             |
| Examples:     | sqrtd d1<br>sqrtd d0<br>sqrtd [L1] | d1 ;       | d1 := s  | sqrt(d1)<br>sqrt(d0)<br>sqrt(doub<br>a | le value<br>ddressed by L1) |
| sqrtf - Squar | e root of float                    | Fc         | ormat: q | ır                                     | Flags:                      |
| Syntax:       | sqrtf fv                           | fr         |          |                                        |                             |
| Semantics:    | <pre>fr := sqrt(fv)</pre>          |            |          |                                        |                             |
| Description:  | The square root<br>fr.             | of float f | Fv is st | ored in                                | float register              |
|               | QUESTION: What                     | if fv < 0? | ?        |                                        |                             |
| Flags:        |                                    |            |          |                                        |                             |
| Examples:     | sqrtf f1<br>sqrtf f0<br>sqrtf [L1] | f1 ;       | f1 := s  | sqrt(f1)<br>sqrt(f0)<br>sqrt(floa<br>a | t value<br>ddressed by L1)  |

| srail - Shift | right arithmetic immediat<br>F                                                                                                                                                                                                                                                                                                                                                                                            | e long<br>Format: ir                               | Flags:         |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------|--|--|--|
| Syntax:       | srail sc lr                                                                                                                                                                                                                                                                                                                                                                                                               |                                                    |                |  |  |  |
| Semantics:    | lr := lr shifted right ar                                                                                                                                                                                                                                                                                                                                                                                                 | ithmetically by                                    | sc bits        |  |  |  |
| Description:  | Long register lr is shifted right arithmetically by sc<br>bits. Bits shifted out of the loworder end of the regis-<br>ter are lost. The sign bit is shifted into the highorder<br>bits of the register. Note that the maximum value sc can<br>have is 31. This is not a problem, because after a shift<br>of 31 bits, lr is completely filled with the sign bit,<br>i.e., lr is either 0 or -1. The sc value is UNSIGNED. |                                                    |                |  |  |  |
| Flags:        |                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                    |                |  |  |  |
| Examples:     | srail 10 L2 ;                                                                                                                                                                                                                                                                                                                                                                                                             | Shift L1 right<br>Shift L2 right<br>Shift L3 right | arith. 10 bits |  |  |  |
| sraiw - Shift | right arithmetic immediat<br>F                                                                                                                                                                                                                                                                                                                                                                                            | e word<br>Format: ir                               | Flags:         |  |  |  |

Syntax: sraiw sc wr

Semantics: wr := wr shifted right arithmetically by sc bits

Description: Word register wr is shifted right arithmetically by sc bits. Bits shifted out of the loworder end of the register are lost. The sign bit is shifted into the highorder bits of the register. If sc >= 15, then wr is completely filled with the sign bit, i.e., wr is either 0 or -1. The sc value is UNSIGNED.

| Examples: | sraiw | 1  | w1 | ; Shift w1 right arith. 1 bit   |
|-----------|-------|----|----|---------------------------------|
|           | sraiw | 10 | w2 | ; Shift w2 right arith. 10 bits |
|           | sraiw | 15 | wЗ | ; w3 := 0 or -1                 |

SRAW

| sral - Shift | right ar                              | ithmetic                    | long                                      | Format: qr Flags:                                                                                                                                                                       |
|--------------|---------------------------------------|-----------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:      | sral                                  | bvl                         | lr                                        |                                                                                                                                                                                         |
| Semantics:   | lr := 1                               | r shifte                    | d right                                   | arithmetically by bvl bits                                                                                                                                                              |
| Description: | bits.<br>ter are<br>bits of<br>filled | Bits shi<br>lost<br>the reg | fted out<br>The sign<br>ister.<br>sign bi | fted right arithmetically by bvl<br>of the loworder end of the regis-<br>bit is shifted into the highorder<br>If bvl >= 31, then lr is completely<br>t, i.e., lr is either 0 or -1. The |
| Flags:       |                                       |                             |                                           |                                                                                                                                                                                         |
| Examples:    | sral                                  | L2                          | L1                                        | ; Shift L1 right arith. by lob(L2)<br>bits                                                                                                                                              |
|              | sral                                  | [sp+2]                      | L2                                        | ; Shift L2 right arith. by no.<br>bits specifed by byte at sp+2                                                                                                                         |
|              | sral                                  | [L1]                        | L3                                        | ; Shift L3 right arith. by no.<br>bits specifed by byte address-<br>ed by L1                                                                                                            |
| sraw - Shift | right ar                              | ithmetic                    | word                                      | Format: qr Flags:                                                                                                                                                                       |
| Syntax:      | sraw                                  | b∨w                         | wr                                        |                                                                                                                                                                                         |
| Semantics:   | wr := w                               | r shifte                    | d right                                   | arithmetically by bvw bits                                                                                                                                                              |
| Description: | bits.<br>ter are<br>bits of<br>filled | Bits shi<br>lost<br>the reg | fted out<br>The sign<br>ister.<br>sign bi | fted right arithmetically by bvw<br>of the loworder end of the regis-<br>bit is shifted into the highorder<br>If bvw >= 15, then wr is completely<br>t, i.e., wr is either 0 or -1. The |
| Flags:       |                                       |                             |                                           |                                                                                                                                                                                         |
| Examples:    | sraw                                  | w2                          | w1                                        | ; Shift w1 right arith. by lob(w2)<br>bits                                                                                                                                              |
|              | sraw                                  | [sp+2]                      | w2                                        | ; Shift w2 right arith. by no.<br>bits specifed by byte at sp+2                                                                                                                         |
|              | sraw                                  | [L1]                        | w3                                        | ; Shift w3 right arith. by no.<br>bits specifed by byte address-<br>ed by L1                                                                                                            |

SRAL

| srlil - Shift | right logical :                                                      | immediate                                      | long<br>Format: ir                                         | Flags:                                                                                                                                               |
|---------------|----------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | srlil sc                                                             | lr                                             |                                                            |                                                                                                                                                      |
| Semantics:    | lr := lr shift                                                       | ed right                                       | logically by                                               | / sc bits                                                                                                                                            |
| Description:  | Bits shifted or<br>lost, and zero<br>the register.<br>31. This is no | ut of the<br>bits are<br>Note tha<br>ot a prob | loworder er<br>shifted int<br>t the maximu<br>lem, because | ogically by sc bits.<br>Ind of the register are<br>to the highorder end of<br>an value sc can have is<br>a shift of 32 bits<br>sc value is UNSIGNED. |
| Flags:        |                                                                      |                                                |                                                            |                                                                                                                                                      |
| Examples:     | srlil 1                                                              | L1                                             | ; Shift L1                                                 | right logical 1 bit                                                                                                                                  |

| Exampies: | SFIII | 1  | LI | Shift Li right logical i | . DIT  |
|-----------|-------|----|----|--------------------------|--------|
|           | srlil | 10 | L2 | Shift L2 right logical 1 | 0 bits |
|           | srlil | 31 | L3 | Shift L3 right logical 3 | 1 bits |

| srliw | - | Shift | right | logical | immediate | word    |    |        |
|-------|---|-------|-------|---------|-----------|---------|----|--------|
|       |   |       |       |         |           | Format: | ir | Flags: |

Syntax: srliw sc wr

Semantics: wr := wr shifted right logically by sc bits

Description: Word register wr is shifted right logically by sc bits. Bits shifted out of the loworder end of the register are lost, and zero bits are shifted into the highorder end of the register. If sc >= 16, then wr is set to zero. The sc value is UNSIGNED.

| Examples: | srliw | 1  | w1 | ; Shift w1 right logical 1 bit   |
|-----------|-------|----|----|----------------------------------|
|           | srliw | 10 | w2 | ; Shift w2 right logical 10 bits |
|           | srliw | 16 | w3 | ; w3 := 0                        |

SRLW

| srll - Shift                                         | right lo                                                                                                                                                                                                                                                                   | gical lo  | ong     | Format: qr Flags:                                                             |  |  |  |
|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|-------------------------------------------------------------------------------|--|--|--|
| Syntax:                                              | srll                                                                                                                                                                                                                                                                       | bvl       | lr      |                                                                               |  |  |  |
| Semantics:                                           | lr := 1                                                                                                                                                                                                                                                                    | r shifte. | d right | logically by bvl bits                                                         |  |  |  |
| Description:                                         | Long register lr is shifted right logically by bvl bits.<br>Bits shifted out of the loworder end of the register are<br>lost, and zero bits are shifted into the highorder end of<br>the register. If bvl >= 32, then lr is set to zero. The<br>bvl value is UNSIGNED.     |           |         |                                                                               |  |  |  |
| Flags:                                               |                                                                                                                                                                                                                                                                            |           |         |                                                                               |  |  |  |
| Examples:                                            | srll                                                                                                                                                                                                                                                                       | L2        | L1      | ; Shift L1 right logical by<br>lob(L2) bits                                   |  |  |  |
|                                                      | srll                                                                                                                                                                                                                                                                       | [sp+2]    | L2      | ; Shift L2 right logical by no.<br>bits specifed by byte at sp+2              |  |  |  |
|                                                      | srll                                                                                                                                                                                                                                                                       | [L1]      | L3      | ; Shift L3 right logical by no.<br>bits specifed by byte address-<br>ed by L1 |  |  |  |
| srlw - Shift right logical word<br>Format: qr Flags: |                                                                                                                                                                                                                                                                            |           |         |                                                                               |  |  |  |
| Syntax:                                              | srlw                                                                                                                                                                                                                                                                       | b∨w       | wr      |                                                                               |  |  |  |
| Semantics:                                           | wr := w                                                                                                                                                                                                                                                                    | ır shifte | d right | logically by bvw bits                                                         |  |  |  |
| Description:                                         | on: Word register wr is shifted right logically by bvw bits.<br>Bits shifted out of the loworder end of the register are<br>lost, and zero bits are shifted into the highorder end of<br>the register. If bvw >= 16, then wr is set to zero. The<br>bvw value is UNSIGNED. |           |         |                                                                               |  |  |  |
| Flags:                                               |                                                                                                                                                                                                                                                                            |           |         |                                                                               |  |  |  |
| Examples:                                            | srlw                                                                                                                                                                                                                                                                       | w2        | w1      | ; Shift w1 right logical by<br>lob(w2) bits                                   |  |  |  |
|                                                      | srlw                                                                                                                                                                                                                                                                       | [sp+2]    | w2      | ; Shift w2 right logical by no.<br>bits specifed by byte at sp+2              |  |  |  |
|                                                      | srlw                                                                                                                                                                                                                                                                       | [L1]      | w3      | ; Shift w3 right logical by no.<br>bits specifed by byte address-<br>ed by L1 |  |  |  |

STOD

| stod - Store | double               |                |                      | Format: qr                                         | Flags:  |
|--------------|----------------------|----------------|----------------------|----------------------------------------------------|---------|
| Syntax:      | stod                 | dr             | da                   |                                                    |         |
| Semantics:   | da := d              | r              |                      |                                                    |         |
| Description: | Store d              | ouble re       | gister d             | r at double addre                                  | ess da. |
| Flags:       |                      |                |                      |                                                    |         |
| Examples:    | stod<br>stod<br>stod | d0<br>d1<br>d0 | d1<br>[sp+2]<br>[L1] | ; d1 := d0<br>; double at sp+2<br>; double address |         |

| stof - Store | float                |                |                      | Format: qr                                        | Flags: |
|--------------|----------------------|----------------|----------------------|---------------------------------------------------|--------|
| Syntax:      | stof                 | fr             | fa                   |                                                   |        |
| Semantics:   | fa := fr             |                |                      |                                                   |        |
| Description: | Store f              | loat reg       | ister fr             | at float address                                  | fa.    |
| Flags:       |                      |                |                      |                                                   |        |
| Examples:    | stof<br>stof<br>stof | f0<br>f1<br>f0 | f1<br>[sp+2]<br>[L1] | ; f1 := f0<br>; float at sp+2<br>; float addresse |        |

| stoflags - St | ore flags                        | register into v      | word<br>Format: qo                                    | Flags: |
|---------------|----------------------------------|----------------------|-------------------------------------------------------|--------|
| Syntax:       | stoflags                         | wa                   |                                                       |        |
| Semantics:    | wa := fla                        | gs                   |                                                       |        |
| Description:  | Store the                        | flags registe        | r at word address                                     | wa.    |
| Flags:        |                                  |                      |                                                       |        |
| Examples:     | stoflags<br>stoflags<br>stoflags | w1<br>[sp+2]<br>[L1] | ; w1 := flags<br>; word at sp+2 :<br>; word addressed |        |

| stol - Store | long                          |             | Format: qr                                      | Flags: |
|--------------|-------------------------------|-------------|-------------------------------------------------|--------|
| Syntax:      | stol lr                       | la          |                                                 |        |
| Semantics:   | la := lr                      |             |                                                 |        |
| Description: | Store long                    | register lr | at long address                                 | la.    |
| Flags:       |                               |             |                                                 |        |
| Examples:    | stol L0<br>stol L1<br>stol L0 |             | ; L1 := L0<br>; long at sp+2<br>; long addresse |        |

| stolb - Store | e loworder byte of long into byte<br>Format: qr Flags:                                                                       |
|---------------|------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | stolb lr bal                                                                                                                 |
| Semantics:    | <pre>bal := lob(lr)</pre>                                                                                                    |
| Description:  | The loworder byte of long register lr is stored at byte<br>address bal. Only a single byte of the destination is<br>changed. |
| Flags:        |                                                                                                                              |
| Examples:     | stolbL0L1; lob(L1) := lob(L0)stolbL1[sp+2]; byte at sp+2 := lob(L1)stolbL0[L1]; byte addressed by L1 := lob(L0)              |
|               |                                                                                                                              |
|               |                                                                                                                              |
|               |                                                                                                                              |
|               |                                                                                                                              |
| stolw - Store | e loworder word of long into word<br>Format: qr Flags:                                                                       |
| Syntax:       | stolw lr wa                                                                                                                  |
| Semantics:    | wa := low(lr)                                                                                                                |
| Description:  | The loworder word of long register lr is stored at word<br>address wa. Only a single word of the destination is<br>changed.  |
| Flags:        |                                                                                                                              |

| Examples: | stolw | LO | w1     | ; w1 := low(L0)                   |
|-----------|-------|----|--------|-----------------------------------|
|           | stolw | L1 | [sp+2] | ; word at sp+2 := low(L1)         |
|           | stolw | LO | [L1]   | ; word addressed by L1 := low(L0) |

STOW

| stow - Store | word                          |             | Format: qr                                    | Flags:                  |
|--------------|-------------------------------|-------------|-----------------------------------------------|-------------------------|
| Syntax:      | stow wr                       | wa          |                                               |                         |
| Semantics:   | wa := wr                      |             |                                               |                         |
| Description: | Store word                    | register wr | at word address                               | wa.                     |
| Flags:       |                               |             |                                               |                         |
| Examples:    | stow w0<br>stow w1<br>stow w0 | [sp+2]      | ; w1 = w0<br>; word at sp+2<br>; word address | := w1<br>ed by L1 := w0 |

stowb - Store loworder byte of word into byte Format: qr Flags:

Syntax: stowb wr baw

Semantics: baw := lob(wr)

Description: The loworder byte of word register wr is stored at byte address baw. Only a single byte of the destination is changed.

Flags:

| Examples: | stowb | w0 | w1     | ; lob(w1) := lob(w0)              |
|-----------|-------|----|--------|-----------------------------------|
|           | stowb | w1 | [sp+2] | ; byte at sp+2 := lob(w1)         |
|           | stowb | w0 | [L1]   | ; byte addressed by L1 := lob(w0) |

### SUBCL

SUBD

| subcl - Subtr | act long with carry                                                             | Format: qr                                             | Flags:           |
|---------------|---------------------------------------------------------------------------------|--------------------------------------------------------|------------------|
| Syntax:       | subcl lv lr                                                                     |                                                        |                  |
| Semantics:    | lr := lr - lv - carry bi                                                        | t                                                      |                  |
| Description:  | Long value lv and the ca<br>register lr. This instr<br>multiple-precision arith | uction makes it                                        |                  |
| Flags:        | NOTE: The carry bit is<br>tion is not yet availabl                              | •                                                      | so this instruc- |
| Examples:     | subcl L1 L1<br>subcl L0 L1<br>subcl [L1] L0                                     | ; L1 := L1 - L1<br>; L1 := L1 - L0<br>; L0 := L0 - lon | - carry bit      |

addressed by L1 - carry bit

| subd - Subtra | ict doubl            | e                |                | Format: qr                                             | Flags:                       |
|---------------|----------------------|------------------|----------------|--------------------------------------------------------|------------------------------|
| Syntax:       | subd                 | dv               | dr             |                                                        |                              |
| Semantics:    | dr := d              | r - dv           |                |                                                        |                              |
| Description:  | Double               | value dv         | is subt        | racted from doubl                                      | e register dr.               |
| Flags:        |                      |                  |                |                                                        |                              |
| Examples:     | subd<br>subd<br>subd | d1<br>d0<br>[L1] | d1<br>d1<br>d0 | ; d1 := d1 - d1<br>; d1 := d1 - d0<br>; d0 := d0 - dou | ble value<br>addressed by L1 |

SUBF

SUBL

| subf - Subtra | ct float             |                  |                | Format: qr                                                   | Flags:                    |
|---------------|----------------------|------------------|----------------|--------------------------------------------------------------|---------------------------|
| Syntax:       | subf                 | fv               | fr             |                                                              |                           |
| Semantics:    | fr := f              | r - fv           |                |                                                              |                           |
| Description:  | Float v              | alue fv          | is subtr       | acted from float r                                           | egister fr.               |
| Flags:        |                      |                  |                |                                                              |                           |
| Examples:     | subf<br>subf<br>subf | f1<br>f0<br>[L1] | f1<br>f1<br>f0 | ; f1 := f1 - f1<br>; f1 := f1 - f0<br>; f0 := f0 - floa<br>a | t value<br>ddressed by L1 |
| subl - Subtra | ct long              |                  |                | Format: qr                                                   | Flags:                    |
| Syntax:       | subl                 | lv               | lr             |                                                              |                           |
| Semantics:    | lr := 1              | r - lv           |                |                                                              |                           |
| Description:  | Long va              | lue lv i         | is subtra      | cted from long reg                                           | ister lr.                 |
| Flags:        |                      |                  |                |                                                              |                           |
| Examples:     | subl<br>subl<br>subl | L1<br>L0<br>[L1] | L1<br>L1<br>L0 | ; L1 := L1 - L1<br>; L1 := L1 - L0<br>; L0 := L0 - long      | value                     |

addressed by L1

### SUBSWL

SUBUWL

| subswl - Subt | ract signed word from long<br>Format: qr Flags:                                                                                                   |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:       | subswl wv lr                                                                                                                                      |  |  |  |  |
| Semantics:    | <pre>lr := lr - sign-extend(wv)</pre>                                                                                                             |  |  |  |  |
| Description:  | Word value wv is sign-extended to 32 bits, and then sub-<br>tracted from long register lr.                                                        |  |  |  |  |
| Flags:        |                                                                                                                                                   |  |  |  |  |
| Examples:     | <pre>subswl w1 L1 ; L1 := L1 - sign-extend(w1) subswl w0 L1 ; L1 := L1 - sign-extend(w0) subswl [L1] L0 ; L0 := L0 - sign-extend(word value</pre> |  |  |  |  |
| subuwl - Subt | subuwl - Subtract unsigned word from long<br>Format: qr Flags:                                                                                    |  |  |  |  |
| Syntax:       | subuwl wv lr                                                                                                                                      |  |  |  |  |
| Semantics:    | <pre>lr := lr - zero-extend(wv)</pre>                                                                                                             |  |  |  |  |
| Description:  | Word value wv is zero-extended to 32 bits, and then sub-<br>tracted from long register lr.                                                        |  |  |  |  |
| Flags:        |                                                                                                                                                   |  |  |  |  |
| Examples:     | subuw] w1  1 : 1 :=  1 - zero-extend(w1)                                                                                                          |  |  |  |  |

Examples: subuwl w1 L1 ; L1 := L1 - zero-extend(w1) subuwl w0 L1 ; L1 := L1 - zero-extend(w0) subuwl [L1] L0 ; L0 := L0 - zero-extend(word value addressed by L1) SUBW

| subw - Subtra | ict word             |                  |                | Format: qr                                            | Flags:      |
|---------------|----------------------|------------------|----------------|-------------------------------------------------------|-------------|
| Syntax:       | subw                 | WV               | wr             |                                                       |             |
| Semantics:    | wr := w              | vr - wv          |                |                                                       |             |
| Description:  | Word va              | alue wv          | is subtra      | acted from word r                                     | egister wr. |
| Flags:        |                      |                  |                |                                                       |             |
| Examples:     | subw<br>subw<br>subw | W1<br>W0<br>[L1] | W1<br>W1<br>W0 | ; w1 := w1 - w1<br>; w1 := w1 - w0<br>; w0 := w0 - w0 |             |
| xorl - Exclus | sive or i            | Long             |                | Format: qr                                            | Flags:      |
| Or we have a  |                      | 1                | 1              |                                                       |             |

Syntax: xorl lv lr Semantics: lr := lr ^ lv Long value lv is bitwise exclusive-or-ed to long register Description: lr. Flags: L1 L0 Examples: xorl L1 ; L1 := L1 ^ L1 ; L1 := L1 ^ L0 xorl L1 ; L0 := L0 ^ long value L0 [L1] xorl addressed by L1

### XORW

| xorw - Exclus | ive or word                     |                | Format: qr                                             | Flags:                     |
|---------------|---------------------------------|----------------|--------------------------------------------------------|----------------------------|
| Syntax:       | XOrw WV                         | wr             |                                                        |                            |
| Semantics:    | wr := wr ^ w                    | V              |                                                        |                            |
| Description:  | Word value w<br>wr.             | ∨ is bitwis    | e exclusive-or-ed                                      | to word register           |
| Flags:        |                                 |                |                                                        |                            |
| Examples:     | xorw w1<br>xorw w0<br>xorw [L1] | w1<br>w1<br>w0 | ; w1 := w1 ^ w1<br>; w1 := w1 ^ w0<br>; w0 := w0 ^ wor | d value<br>addressed by L1 |

# APPENDIX A: Instructions Grouped by Format

This appendix contains a list of all VMAX instructions, organized by format:

| ++           | +                    | ++                   | +                   | 4             |
|--------------|----------------------|----------------------|---------------------|---------------|
| format  <br> | number<br>  operands | first  <br>  operand | second  <br>operand | examples      |
| a3           | 1                    | 3-byte adr           | -                   | jump, call    |
| b1           | 1                    | 1-byte int           | -                   | ret           |
| b14          | 2                    | 1-byte int           | 4-byte msk          | entersav      |
| ij           | 2                    | cond. code           | jump adr            | jump, call    |
| ir           | 2                    | imm. int             | register            | shift, rotate |
| mr           | 2                    | general              | register            | gmov, gsto    |
| n0           | 0                    | -                    | -                   | halt, nop     |
| n04          | 1                    | 4-byte msk           | -                   | pushregs      |
| qc           | 2                    | general              | cond. code          | store cond.   |
| qo           | 1                    | general              |                     | push, pop     |
| qr           | 2                    | general              | register            | add, move     |
|              |                      | ,                    |                     |               |

### a3 Format

| 0pcode         | Operands   | Instruction                   | Format   | Function     |
|----------------|------------|-------------------------------|----------|--------------|
|                |            |                               |          |              |
| callb<br>callf | ma3<br>ma3 | Call backward<br>Call forward | a3<br>a3 | jump<br>jump |
| iumph          | ma3        | Jump backward                 | a3       |              |
| jumpb<br>jumpf | ma3        | Jump forward                  | a3       | jump<br>jump |

APPENDIX A: Instructions Grouped by Format (continued)

### b1 Format

| 0pcode | Operands | Instruction      | Format | Function |
|--------|----------|------------------|--------|----------|
| enter  | stkc     | Enter function   | b1     | stack    |
| leave  | stkc     | Leave function   | b1     | jump     |
| ret    | stkc     | Return from call | b1     | jump     |

#### b14 Format

OpcodeOperandsInstructionFormatFunctionentersavstkcbmskEnter func. and save regsb14stackleaveresstkcbmskLeave func. and restore regsb14jump

### ij Format

| 0pcode | 0perands |    | Instruction | Format | Function |   |
|--------|----------|----|-------------|--------|----------|---|
| call   | cc       | ma | Call        | ij     | jump     | - |
| jump   | cc       | ma | Jump        | ii     | jump     |   |

### ir Format

| 0pcode                                           | 0perar                           | nds                              | Instruction                                                                                                                                                                                | Format                     | Function                                           |
|--------------------------------------------------|----------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------------------------------------------|
| rlil<br>rliw<br>rril<br>rriw                     | SC<br>SC<br>SC<br>SC<br>SC       | lr<br>wr<br>lr<br>wr             | Rotate left immediate long<br>Rotate left immediate word<br>Rotate right immediate long<br>Rotate right immediate word                                                                     | ir<br>ir<br>ir<br>ir<br>ir | shift<br>shift<br>shift<br>shift<br>shift          |
| slil<br>sliw<br>srail<br>sraiw<br>srlil<br>srliw | SC<br>SC<br>SC<br>SC<br>SC<br>SC | lr<br>wr<br>lr<br>wr<br>lr<br>wr | Shift left immediate long<br>Shift left immediate word<br>Shift right arithmetic imm lon<br>Shift right arithmetic imm wor<br>Shift right logical imm long<br>Shift right logical imm word | 0                          | shift<br>shift<br>shift<br>shift<br>shift<br>shift |

### mr Format

| 0pcode | Operands |    | Instruction   | Format | Function |
|--------|----------|----|---------------|--------|----------|
| gmov   | ga       | gr | General move  | mr     | move     |
| gsto   | ga       | gr | General store | mr     | store    |

### n0 Format

| 0pcode | Operands | Instruction           | Format | Function |
|--------|----------|-----------------------|--------|----------|
| halt   |          | Halt the VMAX machine | n0     | misc     |
| nop    |          | No operation          | n0     | misc     |

APPENDIX A: Instructions Grouped by Format (continued)

### n04 Format

| Opcode   | Operands | Instruction             | Format | Function |
|----------|----------|-------------------------|--------|----------|
| pushregs |          | Push multiple registers | n04    | stack    |
| popregs  |          | Pop multiple registers  | n04    | stack    |

# qc Format

| 0pcode | 0perar | nds | Instruction                | Format | Function |
|--------|--------|-----|----------------------------|--------|----------|
|        |        |     |                            |        |          |
| set0l  | la     | c0  | Store condition(0) in long | dc     | flags    |
| set1l  | la     | c1  | Store condition(1) in long | dc     | flags    |
| set0w  | wa     | c0  | Store condition(0) in word | qc     | flags    |
| set1w  | wa     | c1  | Store condition(1) in word | qc     | flags    |

# qo Format

| 0pcode                       | Operands             | Instruction                                     | Format               | Function                         |
|------------------------------|----------------------|-------------------------------------------------|----------------------|----------------------------------|
| movflag                      | is wv                | Move word to flags reg                          | qo                   | flags                            |
| popd<br>popf<br>popl<br>popw | da<br>fa<br>la<br>wa | Pop double<br>Pop float<br>Pop long<br>Pop word | qo<br>qo<br>qo<br>qo | stack<br>stack<br>stack<br>stack |

APPENDIX A: Instructions Grouped by Format (continued)

# qo Format (continued)

| 0pcode  | Operands | Instruction               | Format | Function |
|---------|----------|---------------------------|--------|----------|
|         |          |                           |        |          |
| pushd   | dv       | Push double               | qo     | stack    |
| pushf   | fv       | Push float                | qo     | stack    |
| pushl   | lv       | Push long                 | qo     | stack    |
| pushw   | WV       | Push word                 | qo     | stack    |
| stoflag | is wa    | Store flags reg into word | qo     | flags    |

# qr Format

| 0pcode | 0pera | ands | Instruction                   | Format | Function   |
|--------|-------|------|-------------------------------|--------|------------|
|        |       |      |                               |        |            |
| absd   | dv    | dr   | Absolute value of double      | qr     | otherarith |
| absf   | fv    | fr   | Absolute value of float       | qr     | otherarith |
| absl   | lv    | lr   | Absolute value of long        | qr     | otherarith |
| absw   | WV    | wr   | Absolute value of word        | qr     | otherarith |
| addcl  | lv    | lr   | Add long with carry           | qr     | add        |
| addd   | dv    | dr   | Add double                    | qr     | add        |
| addf   | fv    | fr   | Add float                     | qr     | add        |
| addl   | lv    | lr   | Add long                      | qr     | add        |
| addswl | WV    | lr   | Add signed word to long       | qr     | add        |
| adduwl | WV    | lr   | Add unsigned word to long     | qr     | add        |
| addw   | WV    | wr   | Add word                      | qr     | add        |
| andl   | lv    | lr   | And long                      | qr     | logical    |
| andw   | WV    | wr   | And word                      | qr     | logical    |
| cmpd   | dv    | dr   | Compare double                | qr     | compare    |
| cmpf   | fv    | fr   | Compare float                 | qr     | compare    |
| cmpl   | lv    | lr   | Compare long                  | qr     | compare    |
| cmplb  | bvl   | lr   | Compare lob(long) to byte     | qr     | compare    |
| cmpw   | WV    | wr   | Compare word                  | qr     | compare    |
| cmpwb  | bvw   | wr   | Compare lob(word) to byte     | qr     | compare    |
| cvtbsl | bvl   | lr   | Convert byte sign-ext to long |        | convert    |
| cvtbsw | bvw   | wr   | Convert byte sign-ext to word |        | convert    |
| cvtbzl | bvl   | lr   | Convert byte zero-ext to long |        | convert    |

# qr Format (continued)

| 0pcode  | 0peran | ds       | Instruction                     | Format | Function |
|---------|--------|----------|---------------------------------|--------|----------|
|         |        |          |                                 |        |          |
| cvtbzw  | bvw    | wr       | Convert byte zero-ext to word   | qr     | convert  |
| cvtdf   | dv     | fr       | Convert double to float         | qr     | convert  |
| cvtfd   | fv     | dr       | Convert float to double         | qr     | convert  |
| cvtsld  | lv     | dr       | Convert signed long to double   | qr     | convert  |
| cvtslf  | lv     | fr       | Convert signed long to float    | qr     | convert  |
| cvttdsl | dv     | lr       | Cnvrt trunc double to sgned ln  | gqr    | convert  |
| cvttdul | dv     | lr       | Cnvrt trunc doub to unsigned ln |        | convert  |
| cvttfsl | fv     | lr       | Cnvrt trunc float to signed ln  | gqr    | convert  |
| cvttful | fv     | lr       | Cnvrt trunc float to unsgnd ln  |        | convert  |
| cvtuld  | lv     | dr       | Convert unsigned long to doubl  |        | convert  |
| cvtulf  | lv     | fr       | Convert unsigned long to float  | ġr     | convert  |
| cvtwsl  | WV     | lr       | Convert word sign-ext to long   | qr     | convert  |
| cvtwzl  | WV     | lr       | Convert word zero-ext to long   | qr     | convert  |
|         |        |          |                                 |        |          |
| divd    | dv     | dr       | Divide double                   | qr     | divide   |
| divf    | fv     | fr       | Divide float                    | qr     | divide   |
| divrsl  | lv     | lr       | Divide with rem signed long     | qr     | divide   |
| divrslw | WV     | lr       | Div with rem sgned long by wor  | d qr   | divide   |
| divrsw  | WV     | wr       | Divide with rem signed word     | qr     | divide   |
| divrul  | lv     | lr       | Divide with rem unsigned long   | qr     | divide   |
| divrulw | WV     | lr       | Div with rem unsgnd lng by wor  | d qr   | divide   |
| divruw  | WV     | wr       | Divide with rem unsigned word   | qr     | divide   |
| divsl   | lv     | lr       | Divide signed long              | qr     | divide   |
| divsw   | WV     | wr       | Divide signed word              | qr     | divide   |
| divul   | lv     | lr       | Divide unsigned long            | qr     | divide   |
| divuw   | WV     | wr       | Divide unsigned word            | qr     | divide   |
| leal    | lv     | lr       | Load effective address          | qr     | load     |
| mouhl   | by 1   | ٦٣       | Move byte to $leb(leng)$        | ar     | mo) (0   |
| movbl   | bvl    | lr       | Move byte to lob(long)          | qr     | move     |
| movbw   | bvw    | wr       | Move byte to lob(word)          | qr     | move     |
| movd    | dv     | dr<br>fr | Move double                     | qr     | move     |
| movf    | fv     | fr       | Move float                      | qr     | move     |
| movl    | lv     | lr       | Move long                       | qr     | move     |
| movw    | WV     | wr       | Move word                       | qr     | move     |
| movwl   | WV     | lr       | Move word to low(long)          | qr     | move     |
| muld    | dv     | dr       | Multiply double                 | qr     | multiply |
| mulf    | fv     | fr       | Multiply float                  | qr     | multiply |
| mulsl   | lv     | lr       | Multiply signed long            | qr     | multiply |
| mulsw   | WV     | wr       | Multiply signed word            | qr     | multiply |
| mulswl  | WV     | lr       | Multiply signed words -> long   | qr     | multiply |
| mulul   | lv     | lr       | Multiply unsigned long          | qr     | multiply |
| muluw   | WV     | wr       | Multiply unsigned word          | qr     | multiply |

# qr Format (continued)

| Opcode | 0peran | nds | Instruction F                   | ormat | Function   |
|--------|--------|-----|---------------------------------|-------|------------|
|        |        |     |                                 |       |            |
| muluwl | WV     | lr  | Multiply unsigned words -> long | qr    | multiply   |
| negd   | dv     | dr  | Negate double                   | qr    | subtract   |
| negf   | fv     | fr  | Negate float                    | qr    | subtract   |
| negl   | lv     | lr  | Negate long                     | qr    | subtract   |
| negw   | WV     | wr  | Negate word                     | qr    | subtract   |
| notl   | lv     | lr  | Not long                        | qr    | logical    |
| notw   | WV     | wr  | Not word                        | qr    | logical    |
| orl    | lv     | lr  | Or long                         | qr    | logical    |
| orw    | WV     | wr  | Or word                         | qr    | logical    |
| remsl  | lv     | lr  | Remainder signed long           | qr    | divide     |
| remsw  | WV     | wr  | Remainder signed word           | qr    | divide     |
| remul  | lv     | lr  | Remainder unsigned long         | qr    | divide     |
| remuw  | WV     | wr  | Remainder unsigned word         | qr    | divide     |
| rll    | bvl    | lr  | Rotate left long                | qr    | shift      |
| rlw    | bvw    | wr  | Rotate left word                | qr    | shift      |
| rrl    | bvl    | lr  | Rotate right long               | qr    | shift      |
| rrw    | b∨w    | wr  | Rotate right word               | qr    | shift      |
| sll    | bvl    | lr  | Shift left long                 | qr    | shift      |
| slw    | bvw    | wr  | Shift left word                 | qr    | shift      |
| sqrtd  | dv     | dr  | Square root of double           | qr    | otherarith |
| sqrtf  | fv     | fr  | Square root of float            | qr    | otherarith |
| sral   | bvl    | lr  | Shift right arithmetic long     | qr    | shift      |
| sraw   | bvw    | wr  | Shift right arithmetic word     | qr    | shift      |
| srll   | bvl    | lr  | Shift right logical long        | qr    | shift      |
| srlw   | bvw    | wr  | Shift right logical word        | qr    | shift      |
| stod   | da     | dr  | Store double                    | qr    | store      |
| stof   | fa     | fr  | Store float                     | qr    | store      |
| stol   | la     | lr  | Store long                      | qr    | store      |
| stolb  | bal    | lr  | Store lob(long) into byte       | qr    | store      |
| stolw  | wa     | lr  | Store low(long) into word       | qr    | store      |
| stow   | wa     | wr  | Store word                      | qr    | store      |
| stowb  | baw    | wr  | Store lob(word) into byte       | qr    | store      |
| subcl  | lv     | lr  | Subtract long with carry        | qr    | subtract   |
| subd   | dv     | dr  | Subtract double                 | qr    | subtract   |
| subf   | fv     | fr  | Subtract float                  | qr    | subtract   |
| subl   | lv     | lr  | Subtract long                   | qr    | subtract   |
| subswl | WV     | lr  | Subtract signed word from long  | qr    | subtract   |
| subuwl | WV     | lr  | Subtract unsigned word from lng |       | subtract   |
|        |        |     |                                 | 1.    |            |

APPENDIX A: Instructions Grouped by Format (continued)

# qr Format (continued)

| 0pcode       | e Operands |          | Instruction                            | Format   | Function           |
|--------------|------------|----------|----------------------------------------|----------|--------------------|
| subw         | WV         | wr       | Subtract word                          | qr       | subtract           |
| xorl<br>xorw | lv<br>wv   | lr<br>wr | Exclusive or long<br>Exclusive or word | qr<br>qr | logical<br>logical |

This appendix contains a list of all VMAX instructions, organized into these functional groups:

| data movement<br>move<br>store<br>load<br>flags                    | memory-to-register moves<br>register-to-memory moves<br>load effective address<br>move and store flags register |
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| arithmetic<br>add<br>subtract<br>multiply<br>divide<br>other arith | divide longs,                                                                                                   |
| shift                                                              | shift and rotate                                                                                                |
| logical                                                            | and, or, not,                                                                                                   |
| convert                                                            | convert from one data type to another                                                                           |
| compare                                                            | compare bytes, words, longs,                                                                                    |
| jump                                                               | jump and call                                                                                                   |
| stack                                                              | pop, push,                                                                                                      |
| misc                                                               | miscellaneous                                                                                                   |

#### Data Movement Instructions

| Opcode                                                          | Operands                                       |                                              | Instruction                                                                                                                                       | Format                                                   | Function                                                     |
|-----------------------------------------------------------------|------------------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------|
| gmov<br>movbl<br>movbw<br>movd<br>movf<br>movl<br>movw<br>movwl | ga<br>bvl<br>bvw<br>dv<br>fv<br>lv<br>wv<br>wv | gr<br>lr<br>wr<br>dr<br>fr<br>lr<br>wr<br>lr | General move<br>Move byte to lob(long)<br>Move byte to lob(word)<br>Move double<br>Move float<br>Move long<br>Move word<br>Move word to low(long) | mr<br>qr<br>qr<br>qr<br>qr<br>qr<br>qr<br>qr<br>qr<br>qr | move<br>move<br>move<br>move<br>move<br>move<br>move<br>move |

| Opcode                           | Opcode Operands      |                      | Instruction                                                                                                          |                      | Function                         |
|----------------------------------|----------------------|----------------------|----------------------------------------------------------------------------------------------------------------------|----------------------|----------------------------------|
|                                  |                      |                      |                                                                                                                      |                      |                                  |
| gsto                             | ga                   | gr                   | General store                                                                                                        | mr                   | store                            |
| stod                             | da                   | dr                   | Store double                                                                                                         | qr                   | store                            |
| stof                             | fa                   | fr                   | Store float                                                                                                          | qr                   | store                            |
| stol                             | la                   | lr                   | Store long                                                                                                           | qr                   | store                            |
| stolb                            | bal                  | lr                   | Store lob(long) into byte                                                                                            | qr                   | store                            |
| stolw                            | wa                   | lr                   | Store low(long) into word                                                                                            | qr                   | store                            |
| stow                             | wa                   | wr                   | Store word                                                                                                           | qr                   | store                            |
| stowb                            | baw                  | wr                   | Store lob(word) into byte                                                                                            | qr                   | store                            |
| leal                             | lv                   | lr                   | Load effective address                                                                                               | qr                   | load                             |
| movflag                          | S WV                 |                      | Move word to flags reg                                                                                               | qo                   | flags                            |
| stoflags wa                      |                      |                      | Store flags reg into word                                                                                            | qo                   | flags                            |
| set0l<br>set1l<br>set0w<br>set1w | la<br>la<br>wa<br>wa | C0<br>C1<br>C0<br>C1 | Store condition(0) in long<br>Store condition(1) in long<br>Store condition(0) in word<br>Store condition(1) in word | qc<br>qc<br>qc<br>qc | flags<br>flags<br>flags<br>flags |

# Data Movement Instructions (continued)

# Arithmetic Instructions

| 0pcode | 0peran | ds   | Instruction               | Format | Function |
|--------|--------|------|---------------------------|--------|----------|
|        |        |      |                           |        |          |
| addcl  | lv     | lr   | Add long with carry       | qr     | add      |
| addd   | dv     | dr   | Add double                | qr     | add      |
| addf   | fv     | fr   | Add float                 | qr     | add      |
| addl   | lv     | lr   | Add long                  | qr     | add      |
| addswl | WV     | lr   | Add signed word to long   | qr     | add      |
| adduwl | WV     | lr   | Add unsigned word to long | qr     | add      |
| addw   | WV     | wr   | Add word                  | qr     | add      |
| negd   | dv     | dr   | Negate double             | qr     | subtract |
| negf   | fv     | fr   | Negate float              | qr     | subtract |
| negl   | lv     | lr   | Negate long               | qr     | subtract |
| negw   | WV     | wr   | Negate word               | qr     | subtract |
| negw   | VV V   | VV I | Negale word               | 41     | 30511461 |

| Opcode  | Operano | ds | Instruction F                   | ormat I  | -unction   |
|---------|---------|----|---------------------------------|----------|------------|
|         | _       |    |                                 |          |            |
| subcl   | lv      | lr | Subtract long with carry        | qr       | subtract   |
| subd    | dv      | dr | Subtract double                 | qr       | subtract   |
| subf    | fv      | fr | Subtract float                  | qr       | subtract   |
| subl    | lv      | lr | Subtract long                   | qr       | subtract   |
| subswl  | WV      | lr | Subtract signed word from long  | qr       | subtract   |
| subuwl  | WV      | lr | Subtract unsigned word from lng | qr       | subtract   |
| subw    | WV      | wr | Subtract word                   | qr       | subtract   |
| muld    | dv      | dr | Multiply double                 | qr       | multiply   |
| mulf    | fv      | fr | Multiply float                  | qr       | multiply   |
| mulsl   | lv      | lr | Multiply signed long            | qr       | multiply   |
| mulsw   | WV      | wr | Multiply signed word            | qr       | multiply   |
| mulswl  | WV      | lr | Multiply signed words -> long   | qr       | multiply   |
| mulul   | lv      | lr | Multiply unsigned long          | qr       | multiply   |
| muluw   | WV      | wr | Multiply unsigned word          | qr       | multiply   |
| muluwl  | WV      | lr | Multiply unsigned words -> long | qr       | multiply   |
| divd    | dv      | dr | Divide double                   | qr       | divide     |
| divf    | fv      | fr | Divide float                    | qr       | divide     |
| divrsl  | lv      | lr | Divide with rem signed long     | gr       | divide     |
| divrslw | WV      | lr | Div with rem sgned long by word |          | divide     |
| divrsw  | WV      | wr | Divide with rem signed word     | qr       | divide     |
| divrul  | lv      | lr | Divide with rem unsigned long   | ġr       | divide     |
| divrulw | WV      | lr | Div with rem unsgnd lng by word |          | divide     |
| divruw  | WV      | wr | Divide with rem unsigned word   | qr       | divide     |
| divsl   | lv      | lr | Divide signed long              | qr       | divide     |
| divsw   | WV      | wr | Divide signed word              | qr       | divide     |
| divul   | lv      | lr | Divide unsigned long            | gr       | divide     |
| divuw   | WV      | wr | Divide unsigned word            | qr       | divide     |
| remsl   | lv      | lr | Remainder signed long           | qr       | divide     |
| remsw   | WV      | wr | Remainder signed word           | ġr       | divide     |
| remul   | lv      | lr | Remainder unsigned long         | qr       | divide     |
| remuw   | WV      | wr | Remainder unsigned word         | qr       | divide     |
| absd    | dv      | dr | Absolute value of double        | qr       | otherarith |
| absf    | fv      | fr | Absolute value of float         | qr       | otherarith |
| absl    | lv      | lr | Absolute value of long          | qr<br>qr | otherarith |
| absw    | WV      | wr | Absolute value of word          | qr       | otherarith |
| sqrtd   | dv      | dr | Square root of double           | qr       | otherarith |
| sqrtf   | fv      | fr | Square root of float            | qr       | otherarith |
|         |         |    |                                 |          |            |

# Arithmetic Instructions (continued)

163

### Shift Instructions

| Opcode | 0perar | nds | Instruction                    | Format | Function |
|--------|--------|-----|--------------------------------|--------|----------|
|        |        |     |                                |        |          |
| rlil   | SC     | lr  | Rotate left immediate long     | ir     | shift    |
| rll    | bvl    | lr  | Rotate left long               | qr     | shift    |
| rril   | SC     | lr  | Rotate right immediate long    | ir     | shift    |
| rrl    | bvl    | lr  | Rotate right long              | qr     | shift    |
| rliw   | SC     | wr  | Rotate left immediate word     | ir     | shift    |
| rlw    | bvw    | wr  | Rotate left word               | qr     | shift    |
| rriw   | SC     | wr  | Rotate right immediate word    | ir     | shift    |
| rrw    | b∨w    | wr  | Rotate right word              | qr     | shift    |
| slil   | SC     | lr  | Shift left immediate long      | ir     | shift    |
| sll    | bvl    | lr  | Shift left long                | qr     | shift    |
| srail  | SC     | lr  | Shift right arithmetic imm lon | •      | shift    |
| sral   | bvl    |     | Shift right arithmetic long    | qr     | shift    |
| srlil  | SC     | lr  | Shift right logical imm long   | ir     | shift    |
| srll   | bvl    | lr  | Shift right logical long       | qr     | shift    |
|        |        |     |                                |        |          |
| sliw   | SC     | wr  | Shift left immediate word      | ir     | shift    |
| slw    | bvw    | wr  | Shift left word                | qr     | shift    |
| sraiw  | SC     | wr  | Shift right arithmetic imm wor | d ir   | shift    |
| sraw   | bvw    | wr  | Shift right arithmetic word    | qr     |          |
| srliw  | SC     | wr  | Shift right logical imm word   | ir     | shift    |
| srlw   | bvw    | wr  | Shift right logical word       | qr     | shift    |

# Logical Instructions

| 0pcode | Operands |    | Instruction       | Format | Function |
|--------|----------|----|-------------------|--------|----------|
|        |          |    |                   |        |          |
| andl   | lv       | lr | And long          | qr     | logical  |
| notl   | lv       | lr | Not long          | qr     | logical  |
| orl    | lv       | lr | Or long           | qr     | logical  |
| xorl   | lv       | lr | Exclusive or long | qr     | logical  |
| andw   | WV       | wr | And word          | qr     | logical  |
| notw   | WV       | wr | Not word          | qr     | logical  |
| orw    | WV       | wr | Or word           | qr     | logical  |
| xorw   | WV       | wr | Exclusive or word | qr     | logical  |

### Conversion Instructions

| Opcode Operar                                        | nds                  | Instruction F                                                                                                                            | ormat        | Function                                 |
|------------------------------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------|
| cvtbzw bvw                                           | wr                   | Convert byte zero-ext to word                                                                                                            | qr           | convert                                  |
| cvtbsw bvw                                           | wr                   | Convert byte sign-ext to word                                                                                                            | qr           | convert                                  |
| cvtbzl bvl                                           | lr                   | Convert byte zero-ext to long                                                                                                            | qr           | convert                                  |
| cvtbsl bvl                                           | lr                   | Convert byte sign-ext to long                                                                                                            | qr           | convert                                  |
| cvtwzl wv                                            | lr                   | Convert word zero-ext to long                                                                                                            | qr           | convert                                  |
| cvtwsl wv                                            | lr                   | Convert word sign-ext to long                                                                                                            | qr           | convert                                  |
| cvtulf lv                                            | fr                   | Convert unsigned long to float                                                                                                           | qr           | convert                                  |
| cvtslf lv                                            | fr                   | Convert signed long to float                                                                                                             | qr           | convert                                  |
| cvtuld lv                                            | dr                   | Convert unsigned long to double                                                                                                          | e qr         | convert                                  |
| cvtsld lv                                            | dr                   | Convert signed long to double                                                                                                            | qr           | convert                                  |
| cvttful fv<br>cvttfsl fv<br>cvttdul dv<br>cvttdsl dv | lr<br>lr<br>lr<br>lr | Cnvrt trunc float to unsgnd lng<br>Cnvrt trunc float to signed lng<br>Cnvrt trunc doub to unsgned lng<br>Cnvrt trunc double to sgned lng | g qr<br>g qr | convert<br>convert<br>convert<br>convert |
| cvtdf dv                                             | fr                   | Convert double to float                                                                                                                  | qr           | convert                                  |
| cvtfd fv                                             | dr                   | Convert float to double                                                                                                                  | qr           | convert                                  |

# Compare Instructions

| 0pcode | 0pera | nds | Instruction               | Format | Function |
|--------|-------|-----|---------------------------|--------|----------|
|        |       |     |                           |        |          |
| cmpd   | dv    | dr  | Compare double            | qr     | compare  |
| cmpf   | fv    | fr  | Compare float             | qr     | compare  |
| cmpl   | lv    | lr  | Compare long              | qr     | compare  |
| cmplb  | bvl   | lr  | Compare lob(long) to byte | qr     | compare  |
| стрw   | WV    | wr  | Compare word              | qr     | compare  |
| cmpwb  | bvw   | wr  | Compare lob(word) to byte | qr     | compare  |

APPENDIX B: Instructions Grouped by Function (continued)

# Jump Instructions

| 0pcode  | 0pera  | nds  | Instruction                  | Format | Function |
|---------|--------|------|------------------------------|--------|----------|
| call    | cc     | ma   | Call                         | ij     | jump     |
| callb   | ma3    |      | Call backward                | a3     | jump     |
| callf   | ma3    |      | Call forward                 | a3     | jump     |
| jump    | cc     | ma   | Jump                         | ij     | jump     |
| jumpb   | ma3    |      | Jump backward                | a3     | jump     |
| jumpf   | ma3    |      | Jump forward                 | a3     | jump     |
| leave   | stkc   | bmsk | Leave function               | b1     | jump     |
| leavere | s stkc |      | Leave func. and restore regs | b14    | jump     |
| ret     | stkc   |      | Return from call             | b1     | jump     |

### Stack Instructions

| Opcode Operands    | Instruction               | Format | Function |  |
|--------------------|---------------------------|--------|----------|--|
|                    |                           |        |          |  |
| enter stkc         | Enter function            | b1     | stack    |  |
| entersav stkc bmsk | Enter func. and save regs | b14    | stack    |  |
| pushregs bmsk      | Push multiple registers   | n04    | stack    |  |
| popregs bmsk       | Pop multiple registers    | n04    | stack    |  |
| popd da            | Pop double                | qo     | stack    |  |
| pushd dv           | Push double               | qo     | stack    |  |
| popf fa            | Pop float                 | qo     | stack    |  |
| pushf fv           | Push float                | qo     | stack    |  |
| popl la            | Pop long                  | qo     | stack    |  |
| pushl lv           | Push long                 | qo     | stack    |  |
| рорм wa            | Pop word                  | qo     | stack    |  |
| pushw wv           | Push word                 | qo     | stack    |  |

APPENDIX B: Instructions Grouped by Function (continued)

# Miscellaneous Instructions

| 0pcode | Operands | Instruction           | Format | Function |
|--------|----------|-----------------------|--------|----------|
| halt   |          | Halt the VMAX machine | n0     | misc     |
| nop    |          | No operation          | n0     | misc     |

APPENDIX C: Instructions Ordered Alphabetically by Opcode

| Opcode             | Operan    | ds         | Instruction F                                                      | ormat    | Function           |
|--------------------|-----------|------------|--------------------------------------------------------------------|----------|--------------------|
| absd               | dv        | dr         | Absolute value of double                                           | qr       | otherarith         |
| absf               | fv        | fr         | Absolute value of float                                            | qr       | otherarith         |
| absl               | lv        | lr         | Absolute value of long                                             | qr       | otherarith         |
| absw               | WV        | wr         | Absolute value of word                                             | qr       | otherarith         |
| addcl              | lv        | lr         | Add long with carry                                                | qr       | add                |
| addd               | dv        | dr         | Add double                                                         | qr       | add                |
| addf               | fv        | fr         | Add float                                                          | qr       | add                |
| addl               | lv        | lr         | Add long                                                           | qr       | add                |
| addswl             | WV        | lr         | Add signed word to long                                            | qr       | add                |
| adduwl             | WV        | lr         | Add unsigned word to long                                          | qr       | add                |
| addw               | WV        | wr         | Add word                                                           | qr       | add                |
| andl               | lv        | lr         | And long                                                           | qr       | logical            |
| andw               | WV        | wr         | And word                                                           | qr       | logical            |
| 11                 |           |            | 0.11                                                               |          | •                  |
| call               | CC        | ma         | Call                                                               | ij       | jump               |
| callb              | ma3       |            | Call backward                                                      | a3       | jump               |
| callf              | ma3       |            | Call forward                                                       | a3       | jump               |
| cmpd               | dv        | dr         | Compare double                                                     | qr       | compare            |
| cmpf               | fv        | fr         | Compare float                                                      | qr       | compare            |
| cmpl               | lv        | lr         | Compare long                                                       | qr       | compare            |
| cmplb              | bvl       | lr         | Compare lob(long) to byte                                          | qr       | compare            |
| cmpw               | WV        | wr         | Compare word                                                       | qr       | compare            |
| cmpwb              | bvw       | wr         | Compare lob(word) to byte                                          | qr       | compare            |
| cvtbsl             | bvl       | lr         | Convert byte sign-ext to long                                      | qr       | convert            |
| cvtbsw             | bvw       | wr         | Convert byte sign-ext to word                                      | qr       | convert            |
| cvtbzl             | bvl       | lr         | Convert byte zero-ext to long                                      | qr       | convert            |
| cvtbzw             | bvw       | wr<br>fr   | Convert byte zero-ext to word                                      | qr       | convert            |
| cvtdf              | dv<br>fv  | fr         | Convert double to float                                            | qr       | convert            |
| cvtfd              | fv        | dr         | Convert float to double                                            | qr       | convert            |
| cvtsld             | lv        | dr<br>fr   | Convert signed long to double<br>Convert signed long to float      | qr       | convert            |
| cvtslf             | lv        | fr<br>1r   |                                                                    | qr       | convert            |
| cvttdsl<br>cvttdul |           | lr         | Cnvrt trunc double to sgned lng<br>Cnvrt trunc doub to unsgned lng |          | convert            |
| cvttfsl            |           | lr<br>lr   | Cnvrt trunc float to signed ing                                    |          | convert            |
| cvttful            |           | lr         | Cnvrt trunc float to unsgnd lng                                    |          | convert<br>convert |
| cvtuld             | lv        | dr         | Convert unsigned long to double                                    |          | convert            |
| cvtulf             | lv        | fr         | Convert unsigned long to float                                     | •        | convert            |
| cvtwsl             | T V<br>WV | lr         | Convert word sign-ext to long                                      | qr<br>qr | convert            |
| cvtwzl             | WV        | lr         | Convert word zero-ext to long                                      | qr       | convert            |
| ovener             |           | <b>_</b> . |                                                                    | 4'       | 001110112          |
| divd               | dv        | dr         | Divide double                                                      | qr       | divide             |
| divf               | fv        | fr         | Divide float                                                       | qr       | divide             |
| divrsl             | lv        | lr         | Divide with rem signed long                                        | qr       | divide             |
| divrslw            | WV        | lr         | Div with rem sgned long by word                                    | d qr     | divide             |
| divrsw             | WV        | wr         | Divide with rem signed word                                        | qr       | divide             |
| divrul             | lv        | lr         | Divide with rem unsigned long                                      | qr       | divide             |
| divrulw            | WV        | lr         | Div with rem unsgnd lng by word                                    | d qr     | divide             |

APPENDIX C: Instructions Ordered Alphabetically by Opcode (continued)

| Opcode                                                                                                                                     | 0perar                           | nds                                                                              | Instruction                                                                                                                                                                                                                                                                                                                                                                | Format                                 | Function                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| divruw<br>divsl<br>divsw<br>divul<br>divuu                                                                                                 | lv<br>wv<br>lv                   | wr<br>lr<br>wr<br>lr<br>wr                                                       | Divide with rem unsigned word<br>Divide signed long<br>Divide signed word<br>Divide unsigned long<br>Divide unsigned word                                                                                                                                                                                                                                                  | qr<br>qr<br>qr<br>qr<br>qr             | divide<br>divide<br>divide<br>divide<br>divide                                                                                                                                |
| enter<br>entersa                                                                                                                           | stkc<br>v stkc                   | bmsk                                                                             | Enter function<br>Enter func. and save regs                                                                                                                                                                                                                                                                                                                                | b1<br>b14                              | stack<br>stack                                                                                                                                                                |
| gmov<br>gsto                                                                                                                               | ga<br>ga                         | gr<br>gr                                                                         | General move<br>General store                                                                                                                                                                                                                                                                                                                                              | mr<br>mr                               | move<br>store                                                                                                                                                                 |
| halt                                                                                                                                       |                                  |                                                                                  | Halt the VMAX machine                                                                                                                                                                                                                                                                                                                                                      | n0                                     | misc                                                                                                                                                                          |
| jump<br>jumpb<br>jumpf                                                                                                                     | CC<br>ma3<br>ma3                 | ma                                                                               | Jump<br>Jump backward<br>Jump forward                                                                                                                                                                                                                                                                                                                                      | ij<br>a3<br>a3                         | jump<br>jump<br>jump                                                                                                                                                          |
| leal<br>leave<br>leavere                                                                                                                   |                                  | lr<br>bmsk                                                                       | Load effective address<br>Leave function<br>Leave func. and restore regs                                                                                                                                                                                                                                                                                                   | qr<br>b1<br>b14                        | load<br>jump<br>jump                                                                                                                                                          |
| movbl<br>movbw<br>movd<br>movf<br>movflag<br>movu<br>movw<br>movwl<br>muld<br>mulf<br>mulsl<br>mulsw<br>mulswl<br>mulswl<br>muluu<br>muluw | lv<br>wv<br>dv<br>fv<br>lv<br>wv | lr<br>wr<br>fr<br>lr<br>wr<br>lr<br>fr<br>lr<br>wr<br>lr<br>lr<br>wr<br>lr<br>lr | Move byte to lob(long)<br>Move byte to lob(word)<br>Move double<br>Move float<br>Move word to flags reg<br>Move long<br>Move word<br>Move word to low(long)<br>Multiply double<br>Multiply float<br>Multiply float<br>Multiply signed long<br>Multiply signed word<br>Multiply unsigned long<br>Multiply unsigned word<br>Multiply unsigned word<br>Multiply unsigned word | qr<br>qr                               | move<br>move<br>move<br>flags<br>move<br>move<br>move<br>multiply<br>multiply<br>multiply<br>multiply<br>multiply<br>multiply<br>multiply<br>multiply<br>multiply<br>multiply |
| negd<br>negf<br>negu<br>negw<br>nop<br>notl<br>notw                                                                                        | dv<br>fv<br>lv<br>wv<br>lv       | dr<br>fr<br>lr<br>wr<br>lr<br>wr                                                 | Negate double<br>Negate float<br>Negate long<br>Negate word<br>No operation<br>Not long<br>Not word                                                                                                                                                                                                                                                                        | qr<br>qr<br>qr<br>qr<br>n0<br>qr<br>qr | subtract<br>subtract<br>subtract<br>subtract<br>misc<br>logical<br>logical                                                                                                    |

169

| 0pcode     | 0peran | ıds | Instruction                    | Format | Function   |
|------------|--------|-----|--------------------------------|--------|------------|
| orl        | lv     | lr  | Or long                        | qr     | logical    |
| orw        | WV     | wr  | Or word                        | qr     | logical    |
| popd       | da     |     | Pop double                     | qo     | stack      |
| popf       | fa     |     | Pop float                      | qo     | stack      |
| popl       | la     |     | Pop long                       | qo     | stack      |
| popregs    |        |     | Pop multiple registers         | n04    | stack      |
| рорм       | wa     |     | Pop word                       | qo     | stack      |
| pushd      | dv     |     | Push double                    | qo     | stack      |
| ,<br>pushf | fv     |     | Push float                     | qo     | stack      |
| pushl      | lv     |     | Push long                      | qo     | stack      |
| pushreg    | s bmsk |     | Push multiple registers        | n04    | stack      |
| ,<br>pushw | WV     |     | Push word                      | qo     | stack      |
| •          |        |     |                                | ·      |            |
| remsl      | lv     | lr  | Remainder signed long          | qr     | divide     |
| remsw      | WV     | wr  | Remainder signed word          | qr     | divide     |
| remul      | lv     | lr  | Remainder unsigned long        | qr     | divide     |
| remuw      | WV     | wr  | Remainder unsigned word        | qr     | divide     |
| ret        | stkc   |     | Return from call               | b1     | jump       |
| rlil       | SC     | lr  | Rotate left immediate long     | ir     | shift      |
| rliw       | SC     | wr  | Rotate left immediate word     | ir     | shift      |
| rll        | bvl    | lr  | Rotate left long               | qr     | shift      |
| rlw        | bvw    | wr  | Rotate left word               | qr     | shift      |
| rril       | SC     | lr  | Rotate right immediate long    | ir     | shift      |
| rriw       | SC     | wr  | Rotate right immediate word    | ir     | shift      |
| rrl        | bvl    | lr  | Rotate right long              | qr     | shift      |
| rrw        | b∨w    | wr  | Rotate right word              | qr     | shift      |
| set0l      | la     | c0  | Store condition(0) in long     | qc     | flags      |
| set0w      | wa     | C0  | Store condition(0) in word     | qc     | flags      |
| set1l      | la     | c1  | Store condition(1) in long     | qc     | flags      |
| set1w      | wa     | c1  | Store condition(1) in word     | qc     | flags      |
| slil       | SC     | lr  | Shift left immediáte long      | ir     | shift      |
| sliw       | SC     | wr  | Shift left immediate word      | ir     | shift      |
| sll        | bvl    | lr  | Shift left long                | qr     | shift      |
| slw        | bvw    | wr  | Shift left word                | qr     | shift      |
| sqrtd      | dv     | dr  | Square root of double          | qr     | otherarith |
| sqrtf      | fv     | fr  | Square root of float           | qr     | otherarith |
| srail      | SC     | lr  | Shift right arithmetic imm lon | gir    | shift      |
| sraiw      | SC     | wr  | Shift right arithmetic imm wor | d ir   | shift      |
| sral       | bvl    | lr  | Shift right arithmetic long    | qr     | shift      |
| sraw       | bvw    | wr  | Shift right arithmetic word    | qr     | shift      |
| srlil      | SC     | lr  | Shift right logical imm long   | ir     | shift      |
| srliw      | SC     | wr  | Shift right logical imm word   | ir     | shift      |
| srll       | bvl    | lr  | Shift right logical long       | qr     | shift      |
| srlw       | bvw    | wr  | Shift right logical word       | qr     | shift      |
|            |        |     |                                |        |            |

# APPENDIX C: Instructions Ordered Alphabetically by Opcode (continued)

| 0pcode  | Operar | nds | Instruction                     | ormat= | Function |
|---------|--------|-----|---------------------------------|--------|----------|
|         |        |     |                                 |        |          |
| stod    | da     | dr  | Store double                    | qr     | store    |
| stof    | fa     | fr  | Store float                     | ġr     | store    |
| stoflag | s wa   |     | Store flags reg into word       | qo     | flags    |
| stol    | la     | lr  | Store long                      | qr     | store    |
| stolb   | bal    | lr  | Store lob(long) into byte       | qr     | store    |
| stolw   | wa     | lr  | Store low(long) into word       | qr     | store    |
| stow    | wa     | wr  | Store word                      | qr     | store    |
| stowb   | baw    | wr  | Store lob(word) into byte       | qr     | store    |
| subcl   | lv     | lr  | Subtract long with carry        | qr     | subtract |
| subd    | dv     | dr  | Subtract double                 | qr     | subtract |
| subf    | fv     | fr  | Subtract float                  | qr     | subtract |
| subl    | lv     | lr  | Subtract long                   | qr     | subtract |
| subswl  | WV     | lr  | Subtract signed word from long  | qr     | subtract |
| subuwl  | WV     | lr  | Subtract unsigned word from lng | g qr   | subtract |
| subw    | WV     | wr  | Subtract word                   | qr     | subtract |
| xorl    | lv     | lr  | Exclusive or long               | qr     | logical  |
| xorw    | WV     | wr  | Exclusive or word               | qr     | logical  |

APPENDIX C: Instructions Ordered Alphabetically by Opcode (continued)

APPENDIX D: Differences Between VMAX v1.00 and v2.00

Version History

Version 1.00: 1990 April 26 Version 2.00: 1990 July 16

Document Changes from Version 1.00 to Version 2.00

The following sections are new or have been changed:

| VMAX Memory and Address Space       | CHANGED          |
|-------------------------------------|------------------|
| VMAX Registers                      | CHANGED          |
| Addressing Modes                    | NEW              |
| Overview of Formats                 | EXPANDED         |
| The qr Format                       | CHANGED          |
| The mr Format                       | NEW              |
| The b14 Format                      | NEW              |
| The nO4 Format                      | NEW              |
| Instruction Set Summary by Function | NEW              |
| Appendices D, E, and F              | NEW              |
| Instruction Descriptions            | NEW INSTRUCTIONS |

Each of the major changes is described in the following.

### VMAX Memory and Address Space (CHANGED)

VMAX memory is now mapped directly onto the PCMAX2 Vram. The VMAX stack grows from high addresses to low addresses, so the organization of Code Space, Data Space, Heap, and Stack is now reversed in VMAX memory.

VMAX Registers (CHANGED)

There are now 8 of each type of register, and no registers overlap. For the time being, VMAX registers will be stored in the PCMAX2 DataRam rather than in PCMAX2 registers.

The flags register has been changed so that instead of the traditional overflow flag, carry flag, zero flag, and sign flag, the following flags are used: less than unsigned flag, less than signed flag, equal flag, greater than signed flag, and greater than unsigned flag. Only compare instructions change the flag bits, so the VMAX interpreter need not deal with flags for every arithmetic instruction.

#### Addressing Modes (NEW)

Most of the original addressing modes have been omitted and replaced with based, indexed, and based-indexed modes. The indexed modes allow a scale factor of 1, 2, 4, or 8 to be used. Displacements of various lengths are allowed with all the new addressing modes.

Overview of Formats (EXPANDED)

This section of the document now includes a brief discussion of each instruction format.

The qr Format (CHANGED)

The qr format was changed to allow for the new based, indexed, and basedindexed addressing modes.

The mr, b14, and n04 Formats (NEW)

The mr format allows 1, 2, 4, or 8 bytes to be moved from memory to any register type (and vice versa), as well as from any register type to any register type. Thus, for example, a double register can be moved to 4 contiguous word registers. In version 1.00 this could only be done by storing the double register into memory, and then moving it in pieces to word registers, using 4 move word instructions. -- All the addressing modes of the qr format are available in the mr format except for immediate operands.

The b14 and n04 are simple extensions of the b1 and n0 formats, used by the new instructions entersav, leaveres, pushregs, and popregs.

Instruction Set Summary by Function (NEW)

This section describes groups of instructions by the functions they perform. Several subsections contain important information not found elsewhere, e.g., the subsections on divide, convert, and compare instructions.

Appendices D, E, and F (NEW)

These appendices include the one you are now reading, a discussion of possible future directions for VMAX, and a set of diagrams for all the instruction formats.

#### Instruction Descriptions

The opcode mnemonics for the following instructions have been changed:

| new name | instruction                             | old name |
|----------|-----------------------------------------|----------|
| cmplb    | Compare loworder byte of long to byte   | cmpbl    |
| cmpwb    | Compare loworder byte of word to byte   | cmpbw    |
| cvtsld   | Convert signed long to double           | cvtld    |
| cvttdsl  | Convert truncated double to signed long | cvtdl    |
| divrsl   | Divide with rem signed long             | divsl    |
| divrsw   | Divide with rem signed word             | divsw    |
| divrul   | Divide with rem unsigned long           | divul    |
| divruw   | Divide with rem unsigned word           | divuw    |
| stolb    | Store loworder byte of long into byte   | stobl    |
| stolw    | Store loworder word of long into word   | stowl    |
| stowb    | Store loworder byte of word into byte   | stobw    |

The following instructions are new:

| new name | instruction                               |
|----------|-------------------------------------------|
| addcl    | Add long with carry                       |
| addswl   | Add signed word to long                   |
| adduwl   | Add unsigned word to long                 |
| cvtslf   | Convert signed long to float              |
| cvttdul  | Convert truncated double to unsigned long |
| cvttfsl  | Convert truncated float to signed long    |
| cvttful  | Convert truncated float to unsigned long  |
| cvtuld   | Convert unsigned long to double           |
| cvtulf   | Convert unsigned long to float            |
| divrslw  | Divide with rem signed long by word       |
| divrulw  | Divide with rem unsigned long by word     |
| divsl    | Divide signed long                        |
| divsw    | Divide signed word                        |
| divul    | Divide unsigned long                      |
| divuw    | Divide unsigned word                      |
| entersav | Enter function and save registers         |
| gmov     | General move                              |
| gsto     | General store                             |
| leal     | Load effective address into long register |
| leaveres | Leave function and restore registers      |
| movflags | Move word to flags register               |
| mulswl   | Multiply signed words yielding long       |
| muluwl   | Multiply unsigned words yielding long     |
| popregs  | Pop multiple registers                    |
| pushregs | Push multiple registers                   |
| remsl    | Remainder signed long                     |
| remsw    | Remainder signed word                     |
| remul    | Remainder unsigned long                   |
| remuw    | Remainder unsigned word                   |
| stoflags | Store flags register into word            |
| subcl    | Subtract long with carry                  |
| subswl   | Subtract signed word from long            |
| subuwl   | Subtract unsigned word from long          |

The following paragraphs briefly discuss the rationale behind these new instructions:

addcl and subcl instructions allow for multiple-precision arithmetic.

addswl, adduwl, divrslw, divrulw, mulswl, muluwl, subswl, and subuwl allow arithmetic on operands of different sizes, namely words and longs.

cvtslf, and the the other new conversion instructions make it possible to convert floating to unsigned integers as well as to signed integers. Also, these new conversions operations have been carefully chosen to satisfy all of GCC's requirements.

divsl, and other new division and remainder instructions separate the calculation of quotients and remainders, so just the one desired in a given instance need be computed. This also conforms to what GCC wants.

entersav and leaveres make it possible to code C function prologues and epilogues with fewer bytes.

gmov and gsto allow greater freedom of data movement when data type is not a consideration. Also, these instructions are more or less required by GCC.

leal allows address calculations to be shorter and faster.

movflags and stoflags allow the flags register to be read, changed, and written in a reasonable easy manner.

popregs and pushregs allow any number of registers to be saved and restored with a single instruction.

#### APPENDIX E: Ideas and Notes for Future Versions

Ultimately we will probably want two versions of the VMAX interpreter, one which runs as fast as possible, and one which does as much error checking as possible. The latter version should include stack checking, as discussed in the next section.

Stack Checking

A nagging problem with hardware stacks on machines like the 8086 is that there is no hardware checking of stack overflow or underflow. This can be especially irksome when the heap and the stack compete for memory: When one grows into the other the results are usually disasterous.

Thus, we define two new VMAX registers, spmin and spmax. These are 32-bit registers containing unsigned long values which define the extent of the stack. Each time sp is changed (either explicitly or implicitly via push, pop, call, ret, etc.), this check is made:

spmin <= sp <= spmax</pre>

If sp is out of bounds, a trap occurs. (Exactly what it means for a trap to occur on VMAX will not be dealt with at this time.)

The following new qo-format instructions are used to operate on spmin and spmax:

| movspmin | lv | Move q-operand | to spmin  |
|----------|----|----------------|-----------|
| movspmax | lv | Move q-operand | to spmax  |
| stospmin | la | Store spmin in | q-operand |
| stospmax | la | Store spmax in | q-operand |

Note that movspmin, movspmax, stospmin, and stospmax do no checking at all. These instructions simply move values into and out of spmin and spmax. All checking is done when sp changes or is operated on.

[Are stospmin and stospmax really needed?]

To illustrate how these instructions are used, consider the following memory map for a compiled C program:



MEMSIZE ->

Before the loader transfers control to the loaded program, it executes these instructions:

| movspmin | FSTFREE       | ; spmin = FSTFREE   |
|----------|---------------|---------------------|
| movspmax | MEMSIZE-4     | ; spmax = MEMSIZE-4 |
| movl     | MEMSIZE-4, sp | ; sp = MEMSIZE-4    |

Thus, as the program executes, sp is guaranteed to always lie in the interval [FSTFREE, MEMSIZE-4].

Whenever a malloc call needs to increase the size of the heap, the following code is executed, where HeapTop is the address of the first free byte after the top of the heap, and NewHeapTop is the new value we wish to assign to HeapTop:

APPENDIX E: Ideas and Notes for Future Versions (continued)

if (NewHeapTop < sp)
 spmin = HeapTop = NewHeapTop;
else
 out of memory (or need to garbage collect)</pre>

Thus, spmin always contains the address of the top of the heap, so that the stack cannot overflow into the heap without a trap. (The variable HeapTop is not really needed since its value is always equal to the contents of the spmin register.)

In some instances strict stack checking can get in the way, so we have a new instruction to turn stack checking on and off:

stkchk 0/1 Turn stack checking on or off

This is a b1-format instruction whose operand is either 0 (off) or 1 (on).

[NOTE: Perhaps there should be a bit in the flags register which tells if stack checking is on or off? If so, then we probably don't want a stkchk instruction, because stoflags and movflags can be used to turn the bit on or off.]

Summary of Stack Checking Instructions

format opcode operands instruction Move address to spmin register movspmin lv qo qo movspmax lv Move address to spmax register qo stospmin la Store spmin register stospmax la Store spmax register qo stkchk 0/1 Turn stack checking off/on b1

APPENDIX E: Ideas and Notes for Future Versions (continued)

Loose Ends

Following is a list of loose ends:

1. At present, numeric values have not been assigned to VMAX opcodes. This can be done at anytime; it is a question of what works best for the VMAX interpreter.

2. No instructions have been defined for I/O, in particular for communication with the host PC. This is an important area which will be dealt with later.

3. Thought needs to be given to how a C program running on the PCMAX2 accesses XMEM, the extended memory available to both the PC and PCMAX2.

4. The effect of each instruction on the flags register is not yet defined and documented in the instruction descriptions. At present only compare instructions change the flags register, but (as discussed elsewhere in this document), at some point we need to decide what to do about arithmetic overflow. APPENDIX F: Diagrams of Instruction Formats

```
Overview of Formats
```

qr format (2, 4, 6, 8, or 10 bytes)

| +                    | 8      | 5           | 3 |                                |
|----------------------|--------|-------------|---|--------------------------------|
| <br> <br> <br> <br>+ | opcode | <br>  q<br> |   | [0, 2, 4, 6, or 8 bytes for q] |

qc format (2, 4, 6, 8, or 10 bytes)

| 8                            | 5 | 3                          |        |          |                |
|------------------------------|---|----------------------------|--------|----------|----------------|
| +<br> <br>  opcode<br> <br>+ |   | +<br>     <br>  cond  <br> | [0, 2, | 4, 6, or | 8 bytes for q] |

qo format (2, 4, 6, 8, or 10 bytes)

| ± | 8 | 5 | 3         |          |          |                |
|---|---|---|-----------|----------|----------|----------------|
| + |   |   | <br>  000 | [0, 2, / | 4, 6, or | 8 bytes for q] |

mr format (4, 6, or 8 bytes)

| + | 8 | 3             | e          |                   |
|---|---|---------------|------------|-------------------|
|   |   | <br>  m  <br> | rreg  <br> | or 6 bytes for m] |

Overview of Formats (continued)

ir format (2 bytes)

| 8                | 5       | 3          |
|------------------|---------|------------|
| <br>  opcode<br> | integer | rreg  <br> |

ij format (2, 4, or 6 bytes)

| +                    | 8            | 4          | 4 | - +           |      |      |       |     |    |
|----------------------|--------------|------------|---|---------------|------|------|-------|-----|----|
| <br> <br> <br> <br>+ | opcode  <br> | cond  <br> | j | <br>  [0,<br> | , 2, | or 4 | bytes | for | j] |

a3 format (4 bytes)



b14 format (6 bytes)

| 8                | 8                              | 32             |
|------------------|--------------------------------|----------------|
| <br>  opcode<br> | <br>  1-byte integer<br> <br>+ | 4-byte operand |
| 1                | •                              | · · ·          |

APPENDIX F: Diagrams of Instruction Formats (continued)

Overview of Formats (continued)

b1 format (2 bytes)

8 8 +-----+ | | | | | opcode | 1-byte integer | | | |

n04 format (6 bytes)

| 8                | 8                         | 32                   |
|------------------|---------------------------|----------------------|
| <br>  opcode<br> | 00000000  <br>  010000000 | 4-byte operand  <br> |

n0 format (2 bytes)



The qr Format: Basic q-Operands

reg (2 bytes)

| 8      | 5    | 3    |
|--------|------|------|
|        |      |      |
| opcode | qreg | rreg |
|        |      |      |

b (2 bytes)

| 8                | 5                    | 3            |
|------------------|----------------------|--------------|
| <br>  opcode<br> | <br>  breg<br> <br>+ | rreg  <br> + |

bd2 (4 bytes)

| 8                      | 5                    | 3                | 16          | +                   |
|------------------------|----------------------|------------------|-------------|---------------------|
| <br>  opcode<br> <br>+ | <br>  breg<br> <br>+ | <br>  rreg  <br> | 2-byte disp | <br> <br> <br> <br> |

mema (6 bytes)

| 8 5 | 3   | 32 |
|-----|-----|----|
|     | I I | Ĭ  |

The qr Format: Immediate q-Operands

imm\_1, imm0, imm1 (2 bytes)

| 8                | 5     | 3 |
|------------------|-------|---|
| <br>  opcode<br> | imm_1 |   |

immv byte (4 bytes)

| 8                      | 5              | 3                | 8    | 8 |
|------------------------|----------------|------------------|------|---|
| <br>  opcode<br> <br>+ | <br>  imm∨<br> | <br>  rreg  <br> | byte |   |

immv word (4 bytes)

| 8 | 5                    | 3              | 16               |
|---|----------------------|----------------|------------------|
| + | +<br> <br>  imm∨<br> | <br>  rreg<br> | 2-byte word val. |

immv long (6 bytes)

| 8                      | 5                          | 3 | 32 |
|------------------------|----------------------------|---|----|
| <br>  opcode<br> <br>+ | +<br> <br>  immv<br> <br>+ |   |    |

The qr Format: Immediate q-Operands (continued)

imm2 long (4 bytes)

| . 8 | 5                          | 3              | 16                               |
|-----|----------------------------|----------------|----------------------------------|
| +   | +<br> <br>  imm2<br> <br>+ | <br>  rreg<br> | <br>  2-byte long val. <br> <br> |

immv float (6 bytes)

| 8                | 5                    | 3              | 32 |
|------------------|----------------------|----------------|----|
| <br>  opcode<br> | <br>  immv<br> <br>+ | <br>  rreg<br> |    |

immv double (10 bytes)

| 8      | 5    | •    | 64                  |
|--------|------|------|---------------------|
|        |      |      | 8-byte double value |
| opcode | imm∨ | rreg |                     |
|        |      |      |                     |

The qr Format: Indexed q-Operands

i (4 bytes)

| 8 | •               | 3    | •           | -           | U    | 8 |
|---|-----------------|------|-------------|-------------|------|---|
|   | <br>  11111<br> | rreg | <br>  i<br> | <br> s <br> | ireg |   |

## id1 (4 bytes)

| 8                      | 5                     | 3          | 3 | 2           | 3 | 8                         |
|------------------------|-----------------------|------------|---|-------------|---|---------------------------|
| <br>  opcode<br> <br>+ | <br>  11111<br> <br>+ | <br>  rreg |   | <br> s <br> |   | <br>  1-byte  <br>  disp. |

id3 (6 bytes)

| 8                      | - | 3 | 3 | _ | - | 24                       |
|------------------------|---|---|---|---|---|--------------------------|
| <br>  opcode<br> <br>+ | l |   |   |   |   | <br>  3-byte disp.  <br> |

id4 (8 bytes)

| 8                | -               | 3              | -             |             | -    | 8                  | 32 | -         |
|------------------|-----------------|----------------|---------------|-------------|------|--------------------|----|-----------|
| <br>  opcode<br> | <br>  11111<br> | <br>  rreg<br> | <br>  id4<br> | <br> s <br> | ireg | <br> 00000000 <br> |    | <br> <br> |

The qr Format: Based q-Operands

b (4 bytes)

| 8 | 5               | 3 | 4           | 1           | 3    | 8<br>++            |
|---|-----------------|---|-------------|-------------|------|--------------------|
|   | <br>  11111<br> |   | <br>  b<br> | <br> 0 <br> | breg | <br> 00000000 <br> |

## bd1 (4 bytes)

| 8                      | 5                     | 3    | 4                   | 1           | 3    | 8                         |
|------------------------|-----------------------|------|---------------------|-------------|------|---------------------------|
| <br>  opcode<br> <br>+ | <br>  11111<br> <br>+ | rreg | <br>  bd1<br> <br>+ | <br> 0 <br> | breg | <br>  1-byte  <br>  disp. |

## bd3 (6 bytes)

| 8 | - | 3 | 4 | _ | • | 24                       |
|---|---|---|---|---|---|--------------------------|
| Ì | I | I |   |   |   | <br>  3-byte disp.  <br> |

## bd4 (8 bytes)

| 8                | -               | 3              | -             | _           | -    | 8                  | 32 | Ŧ         |
|------------------|-----------------|----------------|---------------|-------------|------|--------------------|----|-----------|
| <br>  opcode<br> | <br>  11111<br> | <br>  rreg<br> | <br>  bd4<br> | <br> 0 <br> | breg | <br> 00000000 <br> |    | <br> <br> |

The qr Format: Based-Indexed q-Operands

bi (4 bytes)

| 8                | 5 | -              | 4            | _            | -    | -   | _           | -         |
|------------------|---|----------------|--------------|--------------|------|-----|-------------|-----------|
| <br>  opcode<br> | I | <br>  rreg<br> | <br>  bi<br> | <br> 0  <br> | oreg | 000 | <br> s <br> | ireg <br> |

bid2 (6 bytes)

| 8                | •     | 3              |               | _      | •                   | •   | _           | •    | 16                 |
|------------------|-------|----------------|---------------|--------|---------------------|-----|-------------|------|--------------------|
| <br>  opcode<br> | 11111 | <br>  rreg<br> | <br> bid2<br> | <br> 0 | <br> <br> <br> <br> | 000 | <br> s <br> | ireg | <br>  2-byte disp. |

bid4 (8 bytes)

| 8                | 5               | -              | -         | _          | -              | -   | _           | -    | 32 | т |
|------------------|-----------------|----------------|-----------|------------|----------------|-----|-------------|------|----|---|
| <br>  opcode<br> | <br>  11111<br> | <br>  rreg<br> | <br> bid4 | <br>  0  t | <br> <br> <br> | 000 | <br> s <br> | ireg |    |   |

The mr Format

mmema (6 bytes)

| 0                      | 1      | _ |         | 5 | 32 |
|------------------------|--------|---|---------|---|----|
| <br>  opcode<br> <br>+ | <br> 0 | n | <br>  r |   |    |

mreg (4 bytes)

| 8<br>+           | 12        | 5    |                | 4    | 3<br>+        | 5 | - |
|------------------|-----------|------|----------------|------|---------------|---|---|
| <br>  opcode<br> | <br> 1  n | rreg | <br> mreg <br> | 0000 | <br> 000 <br> | l |   |

i, b, bi (4, 6, or 8 bytes)

| - | 8      | _           | _       | -    | - + |       |       |   |       |     |    |
|---|--------|-------------|---------|------|-----|-------|-------|---|-------|-----|----|
|   | opcode | <br> 1 <br> | n  <br> | rreg |     | [2, 4 | l, or | 6 | bytes | for | m] |

The m-operand of an mr instruction can be specified using any of the indexed, based, or based-indexed addressing modes used to specify q-operands.

```
The ij Format
```

jregi (2 bytes)

| 8                | 4    | 4              | +               |
|------------------|------|----------------|-----------------|
| <br>  opcode<br> | cond | <br>  Lreg<br> | '<br> <br> <br> |

pcrp (4 bytes)

| 8                      | 4<br>          | 4              | 16                            | +         |
|------------------------|----------------|----------------|-------------------------------|-----------|
| <br>  opcode<br> <br>+ | <br>  cond<br> | <br>  pcrp<br> | <br>  2-byte offset<br> <br>+ | <br> <br> |

pcrm (4 bytes)

| 8                      | 4                    | 4              | 16 |
|------------------------|----------------------|----------------|----|
| <br>  opcode<br> <br>+ | <br>  cond<br> <br>+ | <br>  pcrm<br> |    |

jmema (6 bytes)

| 8      | 4    | 4     | 32                    |
|--------|------|-------|-----------------------|
|        |      |       | 4-byte memory address |
| opcode | cond | jmema |                       |
|        |      |       |                       |

The ij Format (continued)

jmemai (6 bytes)

| 8                      | 4                    | 4                 | 32 |
|------------------------|----------------------|-------------------|----|
| <br>  opcode<br> <br>+ | <br>  cond<br> <br>+ | <br> jmemai  <br> |    |

sprmi (4 bytes)

| 8                      | 4              | 4                 | 16            | -+ |
|------------------------|----------------|-------------------|---------------|----|
| <br>  opcode<br> <br>+ | <br>  cond<br> | <br>  sprmi  <br> | 2-byte offset |    |

<END DOCUMENT>