## Comparison Chart of SIC and SIC/XE machine | Specification | SIC | SIC/XE | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Memory | <ul> <li>Word size: 3 bytes (24 bits)</li> <li>Total size: 32,768 bytes (215). Thus any memory address will need at most 15 bits to be referenced ('almost' four hex characters).</li> </ul> | <ul> <li>Word size: 3 bytes (24 bits)</li> <li>Total size: 32,768 bytes (215). Thus any memory address will need at most 15 bits to be referenced ('almost' four hex characters).</li> </ul> | | Register | <ul> <li>Total Registers: 5</li> <li>Accumulator (A): Used for most of the operations (number 0)</li> <li>Index (X): Used for indexed addressing (number 1)</li> <li>Linkage (L): Stores return addresses for JSUB (number 2)</li> <li>Program Counter (PC): Address for next instruction (number 8)</li> <li>Status Word (SW): Information and condition codes (number 9).</li> </ul> | <ul> <li>Total Registers: 9 , same 5 from SIC plus 4 additional ones.</li> <li>Base (B): Used for base-relative addressing (number 3)</li> <li>General (S and T): General use (numbers 4 and 5 resp.)</li> <li>Floating Point Accumulator (F): Used for floating point arithmetic, 48 bits long (number 6)</li> </ul> | | Instruction Formats | <ul> <li>Only one instruction format of 24 bits (3 bytes / 1 word)</li> <li>Opcode: first 8 bits, direct translation from the Operation Code Table</li> <li>Flag (x): next bit indicates address mode (0 direct - 1 indexed)</li> <li>Address: next 15 bits, indicate address of operand according to address mode.</li> </ul> | <ul> <li>Four instruction formats</li> <li>Format 1 (1 byte): contains only operation code (straight from table)</li> <li>Format 2 (2 bytes): first eight bits for operation code, next four for register 1 and following four for register 2.</li> <li>The numbers for the registers go according to the numbers indicated at the registers section (ie, register T is replaced by hex 5).</li> <li>If the operation uses only one register the last hex digit becomes \0" (ie,TIXR T becomes B850)</li> <li>Format 3 (3 bytes): First 6 bits contain operation code, next 6 bits contain flags, last 12 bits contain displacement for the address of the operand.</li> <li>Operation code uses only 6 bits, thus the second hex digit will be a affected by the values of the first two flags (n and i)</li> <li>The flags, in order, are: n, i, x, b, p, and e. Its functionality is explained in the next section.</li> <li>The last flag e indicates the instruction format (0 for 3 and 1 for 4)</li> <li>Format 4 (4 bytes): same as format 3 with an extra 2 hex digits (8 bits) for addresses that require more than 12 bits to be represented</li> </ul> | | Specification | SIC | SIC/XE | |-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Addressing Modes | <ul> <li>Only two possible addressing modes</li> <li>Direct (x = 0): operand address goes as it is Indexed (x = 1): value to be added to the value stored at the register x to obtain real address of the operand.</li> </ul> | <ul> <li>five possible addressing modes plus combinations (see page 11 for examples)</li> <li>Direct (x, b, and p all set to 0): operand address goes as it is. n and i are both set to the same value, either 0 or 1. While in general that value is 1, if set to 0 for format 3 we can assume that the rest of the flags (x, b, p, and e) are used as a part of the address of the operand, to make the format compatible to the SIC format</li> <li>Relative (either b or p equal to 1 and the other one to 0): the address of the operand should be added to the current value stored at the B register (if b = 1) or to the value stored at the PC register (if p = 1)</li> <li>Immediate (i = 1, n = 0): The operand value is already enclosed on the instruction (ie. lies on the last 12/20 bits of the instruction)</li> <li>Indirect (i = 0, n = 1): The operand value points to an address that holds the address for the operand value</li> <li>Indexed (x = 1): value to be added to the value stored at the register x to obtain real address of the operand. This can be combined with any of the previous modes except immediate.</li> </ul> | | Assembler<br>Considerations | <ul> <li>Operation code gets translated directly from table (no need to check other bits)</li> <li>x bit dependent on the addressing mode of the operand. If indexed the code will have to indicate it with X" after the operand name (ie. BUFFER,X)</li> <li>The last 3 hex digits of the address will remain the same, the first hex digit (leftmost) will change if the address is indexed (first bit becomes one, thus the hex digit increases by 8). Ie, if the address of the operand is 124A and the addressing is indexed, the object code will indicate 924A.</li> </ul> | <ul> <li>Operation code gets translated directly from table. While the first hex digit remains the same, the second one can change according to the values of the n and i flags. Thus, we can add 1, 2 or 3 to the operation code.</li> <li>Direct addressing is mainly used in extended format (format 4) and is indicated with a \+" before the operand (an indication that the format is 4, which will also make the e flag to be 1).</li> <li>Relative: for Base relative, the instruction BASE will precede the current instruction.</li> <li>Any other format, except immediate, will be considered Program Counter relative. If the displacement with respect to the PC does not t into the 12 bits, the assembler should try to compute the displacement with respect to the Base register. If neither case works, the instruction should be extended to format 4, where the addressing mode becomes direct.</li> </ul> | | Specification | SIC | | SIC/XE | |---------------|-----|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | • | Immediate addressing will be indicated by the use of \#" before the operand name/value (ie. #1) Indirect addressing will be indicated by adding the prex | | | | • | \@" to the operand name (ie. @RETADR) Indexed addressing will be indicated the same way as it was for the SIC machine, X" after the operand name (ie. BUFFER,X) | | | | • | Hex digits for the address are not affected by the content of the flags, since the first two flags affect the second digit of the operation code, and the following four make up its own hex digit. |