



## System Programming 系統程式

Yuan-Hao Chang (張原豪) johnsonchang@ntut.edu.tw Department of Electronic Engineering National Taipei University of Technology

October 8, 2010



## **Course Information**

#### • Lecturer:

- Yuan-Hao Chang
- Office: Room 207-2
- Phone: +886-2-2771-2171 ext. 2288
- Lecturing hours:
  - 2:10 pm ~ 5:00 pm, Friday
- Classroom:
  - Room 309, Third Education Building (三教 309)
- Textbook:
  - System Software An Introduction to Systems Programming, 3rd Edition, 1997
  - Author: Leland L. Beck Publisher: Addison Wesley (台北圖書代理), ISBN: 0-321-21177-4
- Course webpage:
  - <u>http://www.ntut.edu.tw/~johnsonchang/courses/Algorithm201008/</u>
- Grading : (subject to changes)
  - Homework: (30%), Midterm exam (30%), Final exam (30%), In-class performance (10%)



8, 2010

2

Copyright © All Rights Reserved by Yuan-Hao Chang

October 8, 2010





## **Outline of the Course**

- Background
- Assemblers
- Loaders and linkers
- Macro processors
- Compilers
- Operating systems
- Other system software
- Software engineering issues

3





## Chapter 1 Background







## Outline

- Introduction
- The Simplified Instructional Computer (SIC)
- CISC Machines
- RISC Machines
- References to Addressing Modes and Instruction Set





## Introduction





## **Objectives of This Course**

- This course is an introduction to the design and implementation of system software.
  - System software consists of a variety of programs that support the operation of a computer.
  - System software makes it possible for users to focus on an application or a problem to be solved, without knowing how the machine works internally.
- By understanding the system software, you will
  - Gain a deeper understanding of how computers really work.
  - Learn the relationship between system software and machine architecture.

| ÎNUT |
|------|
| 1550 |



## Examples of System Software

#### Assembler

 Translate assembler-language programs into machine language, and may include *macro processor*.

#### • Loader or Linker

 Load the resulting machine-language program into memory and prepared for execution.

#### Compiler

 Translate programs in a high-level language (that are edited by text editor) into machine language.

#### Operating system

 Control all of the processes running on the machine and take care of all the machine-level details.

#### Debugger

- Help detect errors in programs.





### **System Software and Machine Architecture**

- *Machine dependency* is the main difference between system software and application software.
  - Application programs are concerned with the solution of some problem, using the computer as a tool.
  - System programs are intended to support the operation and use of the computer itself. For example:
    - Assemblers translate mnemonic instructions into machine code.
    - **Compilers** generate machine language code, taking hardware characteristics into account.
    - **Operating systems** are directly concerned with the management of nearly all of the resources of a computing system.
- There are some aspects of system software that do not directly depend upon the computing system. For example:
  - The general design and logic of an assembler.
  - Some code optimization techniques used by compilers.





## The Simplified Instructional Computer (SIC)







## Simplified Instructional Computer (SIC)

- It is difficult to distinguish whether the features of software are truly fundamental or solely depend on a particular machine.
  - To avoid this problem, the fundamental functions of system software are discussed through a Simplified Instructional Computer (SIC).
  - SIC is a hypothetical (假定的) computer that is carefully designed
    - To include the hardware features most often found on real computers.
    - To avoid unusual or irrelevant complexities.
  - SIC provides the reader with a starting point to begin the design of system software for a new computer.
- SIC comes in two versions:
  - The standard model: SIC
  - The extra equipment version: SIC/XE







## SIC Machine Architecture

#### Memory

- -8 bits forms a byte.
- -3 consecutive bytes form a *word* (24 bits).
- All addresses on SIC are byte addresses.
- Words are addressed by the location of their lowest numbered byte.
- There are 32,768 (2<sup>15</sup>) bytes in the computer memory.





#### Registers

- Five registers, all of each have special uses.
- 24 bits long in each register.

| Mnemonic<br>(助記符號) | Number | Special use                                                                                            |
|--------------------|--------|--------------------------------------------------------------------------------------------------------|
| А                  | 0      | Accumulator; used for arithmetic operations                                                            |
| X                  | 1      | IndeX Register; used for (indexed) addressing                                                          |
| L                  | 2      | Linkage register; the Jump to Subroutine (JSUB) instruction stores the return address in this register |
| PC                 | 8      | <u>Program Counter</u> ; contains the address of the next instruction to be fetched for execution      |
| SW                 | 9      | <u>Status</u> <u>Word</u> ; contains a variety of information, including a Condition Code (CC)         |





October 8, 2010

## **SIC Machine Architecture (Cont.)**

#### Data formats

- Integers are stored as 24-bit binary numbers.
- Negative values are represented by 2's complement.
- Characters are stored using 8-bit ASCII codes.
- Floating-point hardware is not supported.

#### Instruction formats







#### Addressing Modes

- Indicated by the setting of the x bit in the instruction.
- The *target address* is calculated from the address given in the instruction.
  - Target address of an instruction is *the address (of the operand)* that will be accessed by the instruction.
- Parentheses are used to indicate the contents of a register or a memory location.

 $\cdot$  E.g., (X) represents the contents of register X.

| Mode    | Indication | Target address (TA) calculation |
|---------|------------|---------------------------------|
| Direct  | x = 0      | TA = address                    |
| Indexed | x = 1      | TA = address + (X)              |





#### Instruction Set

- Instructions that load and store registers
  - E.g., LDA, LDX, STA, STX, etc.
- Integer arithmetic operations
  - All arithmetic operations involve register A and a word in memory with the result left in register A.
  - E.g., ADD, SUB, MUL, DIV

#### - Comparison instructions (COMP)

- COMP compares the value in register A with a word in memory, and sets a *condition code* (*CC*) to indicate the result (<, =, or >).
- Conditional jump instructions (JLT, JEQ, JGT)
  - Test the setting of CC, and jump accordingly.
- Subroutine linkage
  - JSUB jumps to the subroutine, placing the return address in register L.
  - **RSUB** returns by jumping to the address contained in register L.

 $\label{eq:copyright} \ensuremath{\mathbb{C}} \ensuremath{\mathsf{All}} \ensuremath{\mathsf{Rights}} \ensuremath{\mathsf{Reserved}} \ensuremath{\mathsf{by}} \ensuremath{\mathsf{Yuan-Hao}} \ensuremath{\mathsf{Chang}} \ensuremath{\mathsf{hab}} \ensuremath{\mathsf{Chang}} \ensuremath{\mathsf{hab}} \ensuremath{\mathsf{Chang}} \ensuremath{\mathsf{hab}} \ensure$ 

A complete list of instructions are listed in the appendix / references.



#### Input and Output

- Input and output are performed by transferring 1 byte at a time to or from the rightmost 8 bits of register A.
- Each device is assigned a unique 8-bit code.
- There are three I/O instructions, each of which specifies the *device* code as an operand:
  - Test Device (TD) :
    - · Test whether the addressed device is ready to send or received a byte of data.
    - · The condition code is set to indicate the result of this test.
      - » < means the device is ready.
      - » = means the device is not ready.
    - A program cannot transfer data until the device is ready.
  - Read Data (RD): Read a byte from the device
  - Write Data (WD): Write a byte to the device





## **SIC/XE Machine Architecture**

#### Memory

- The memory structure for SIC/XE is the same as SIC.
- The maximum memory available on a SIC/XE system is 1 megabytes (2<sup>20</sup> bytes).
- This increase leads to a change in *instruction formats* and *addressing modes*.

#### Registers

- Four additional registers (compared to SIC) are provided by SIC/XE:

| Mne-<br>monic | Number | Special use                                                 |
|---------------|--------|-------------------------------------------------------------|
| В             | 3      | Base register; used for (base-register relative) addressing |
| S             | 4      | General working register; no special use                    |
| Т             | 5      | General working register; no special use                    |
| F             | 6      | Floating-point accumulator (48 bits)                        |





#### Data formats

- SIC/XE provides the same data formats as the standard version.
- SIC/XE provides a 48-bit floating-point data type:
  - The *fraction* (*f*) is interpreted as a value between 0 and 1.
    - · The assumed binary point is immediately before the high-order bit.
    - · For normalized floating-point, the high-order bit of the fraction must be 1.
  - The *exponent* (*e*) is interpreted as an unsigned binary number between 0 and 2047.
  - The sign of the float-point number is indicated by the value of s
    - $\cdot$  0 = positive, 1 = negative.
  - A value of zero is represented by setting all bits to 0.

| 1 | 11                                            | 36           |  |  |  |
|---|-----------------------------------------------|--------------|--|--|--|
| S | exponent ( <mark>e</mark> )                   | fraction (f) |  |  |  |
|   | The floating-point value = $f * 2^{(e-1024)}$ |              |  |  |  |

Copyright © All Rights Reserved by Yuan-Hao Chang





#### Instruction formats

- The 15-bit address field in SIC is no longer suitable due to the larger memory in SIC/XE.
- Two possible options:
  - Use some form of *relative addressing* or
  - Extend the address field to 20 bits.
- Four instructions formats:
  - Formats 1 and 2 do not reference memory at all.



Copyright © All Rights Reserved by Yuan-Hao Chang



#### Instruction formats (Cont.)

#### Format 3 (3 bytes):



| ÎNUT |
|------|
| 1550 |



#### SIC/XE Machine Architecture (Cont.) • Addressing Modes – Target Address Calculation

(PC), (B), and (X) represent the contents of register PC, B, and X, respectively.

#### Format 3 (e=0)

| TA Calculation Mode | Indication            | Target address calculation Signed integer          |
|---------------------|-----------------------|----------------------------------------------------|
| Program-counter     | x=0, b=0, <b>p</b> =1 | $TA = (PC) + disp (-2048 \le disp \le 2047)$       |
| relative addressing | x=1, b=0, <i>p</i> =1 | $TA = (PC) + disp + (X) (-2048 \le disp \le 2047)$ |
| Base relative       | x=0, <b>b</b> =1, p=0 | $TA = (B) + disp (0 \le disp \le 4095)$            |
| addressing          | x=1, <i>b</i> =1, p=0 | $TA = (B) + disp + (X) (0 \le disp \le 4095)$      |
|                     | x=0, b=0, p=0         | TA = disp                                          |
| Direct addressing   | x=1, b=0, p=0         | TA = disp + (X) Unsigned integer                   |

- For a *Format 4 (e=1)* instruction, bits *b* and *p* are normally set to 0.

| TA Calculation Mode | Indication    | Target address calculation |
|---------------------|---------------|----------------------------|
| Direct addressing   | x=0, b=0, p=0 | TA = addr                  |
| Direct addressing   | x=1, b=0, p=0 | TA = addr + (X)            |





- Addressing Types How The Target Address Is Used
  - Simple addressing: The target address is taken as the address of the operand value.
  - Immediate addressing: The target address is used as the operand value.
  - Indirect addressing: The value of the word at the location given by the target address is the address of the operand value.

| TA Addressing Type   | Indication            | Operand value                                                                                       |
|----------------------|-----------------------|-----------------------------------------------------------------------------------------------------|
|                      | n=0, i=0              | (TA) $\rightarrow$ for SIC machine, because the 8-bit binary opcodes of SIC instructions end in 00. |
| Simple addressing    |                       | b/p/e/disp = 15-bit <u>address</u> field of SIC instruction                                         |
|                      | n=1, i=1              | (TA) $\rightarrow$ for SIC/XE machine                                                               |
| Immediate addressing | n=0, <i>i</i> =1, x=0 | ТА                                                                                                  |
| Indirect addressing  | <i>n</i> =1, i=0, x=0 | ((TA))                                                                                              |

Indexed addressing cannot be used with immediate or indirect addressing modes. (x=0)



- Addressing modes for Format 3 and Format 4 instructions.
- Combinations of addressing bits not in this table are errors.
- Assembler language notation:
  - c indicates a constant between 0 and 4095.
  - *m* indicates a *memory address* or a *constant value* larger than 4095.
  - + indicates extended format (i.e., Format 4)
  - @ indicates a indirect addressing
  - # indicates an *immediate addressing*
  - X indicates register X (using indexed addressing)
- Letters in Notes
  - 4 Format 4 instruction
  - D Direct-addressing instruction
  - A Program-counter relative or base relative mode
  - S Compatible with standard SIC instructions. Operand value can be between 0 and 32,767.

| be                | mode                        | sion                              |                                        |         |       |
|-------------------|-----------------------------|-----------------------------------|----------------------------------------|---------|-------|
| Addressir<br>type | ng Flag bits<br>n i x b p e | Assembler<br>language<br>notation | Calculation<br>of target<br>address TA | Operand | Notes |
| Simple            | 110000                      | op c                              | disp                                   | (TA)    | D     |
|                   | 110001                      | +op m                             | addr                                   | (TA)    | 4 D   |
|                   | 110010                      | op m                              | (PC) + disp                            | (TA)    | А     |
|                   | 110100                      | op m                              | (B) + disp                             | (TA)    | А     |
|                   | 111000                      | op c,X                            | disp + (X)                             | (TA)    | D     |
|                   | 111001                      | +op m,X                           | addr + (X)                             | (TA)    | 4 D   |
|                   | 111010                      | op m,X                            | (PC) + disp + (X)                      | (TA)    | А     |
|                   | 111100                      | op m,X                            | $(B) + \mathrm{disp} + (X)$            | (TA)    | А     |
| with SIC          | ole                         | op m                              | b/p/e/disp                             | (TA)    | DS    |
| instructio        |                             | op m,X                            | b/p/e/disp + (X)                       | (TA)    | D S   |
| Indirect          | 100000                      | op @c                             | disp                                   | ((TA))  | D     |
|                   | $1 \ 0 \ 0 \ 0 \ 1$         | +op @m                            | addr                                   | ((TA))  | 4 D   |
|                   | 100010                      | op @m                             | (PC) + disp                            | ((TA))  | А     |
|                   | 100100                      | op @m                             | (B) + disp                             | ((TA))  | А     |
| Immediate         | 010000                      | op #c                             | disp                                   | TA      | D     |
|                   | 010001                      | +op #m                            | addr                                   | TA      | 4 D   |
|                   | 010010                      | op #m                             | (PC) + disp                            | TA      | А     |
|                   |                             |                                   |                                        |         |       |

Addressing Exten

010100

op #m

(B) + disp

TA

Α

Addressing

typ









#### Instruction Set

- SIC/XE provides all of the instructions that are available on SIC.
- Some extended instructions are supported.
  - Load and store new registers
    - · E.g., *LDB*, *STB*, etc.
  - Floating-point arithmetic operations
    - · E.g., ADDF, SUBF, MULF, DIVF
  - Register-to-register arithmetic operations
    - · E.g., RMO (register move operation), ADDR, SUBR, MULR, DIVR
  - Special supervisor call instruction (SVC)
    - This instruction generates an interrupt that can be used for communication with the operating system.

26





#### Input and Output

- The I/O instructions supported by SIC are also available on SIC/XE.
- I/O channels that can be used to perform input and output while the CPU is executing other instructions.
  - This allows overlap of computing and I/O.
    - **SIO**, **TIO**, and **HIO** are used to *start*, *test*, and *halt* the operation of I/O channels.





### **Expression Convention**

- Parentheses are used to denote the contents of a register or memory location.
  - $-A \leftarrow (m..m+2)$  specifies that the contents of the memory locations *m* through m+2 are loaded into register *A*.
  - m..m+2 (A) specifies that the contents of register A are stored in the word that begins at address m.
  - -(A): (m..m+2) specifies that the contents of register A and memory location m through m+2 are compared.





#### **Sample Data Movement** LOAD CONSTANT 5 INTO REGISTER A $A \leftarrow (FIVE)$ SIC FIVE LDA ALPHA $\leftarrow$ (A) STA ALPHA STORE IN ALPHA LOAD CHARACTER 'Z' INTO REGISTER A A $\leftarrow$ (CHARZ) LDCH CHARZ Load a word STCH C1 STORE IN CHARACTER VARIABLE C1 $C1 \leftarrow (A)$ Reserve one word of storage/variable for use by the program Load a character ONE-WORD VARIABLE ALPHA RESW Reserve one byte of FIVE WORD 5 ONE-WORD CONSTANT storage/*constant* C'Z' CHARZ BYTE ONE-BYTE CONSTANT initialized to 'Z' ONE-BYTE VARIABLE C1 RESB Reserve one byte of storage/variable for use by the program #5 LOAD VALUE 5 INTO REGISTER A $A \leftarrow 5$ LDA SIC/XE STORE IN ALPHA $\leftarrow$ (A) ALPHA STA LOAD ASCII CODE FOR 'Z' INTO REG A $A \leftarrow 90$ LDA #90 STCH C1STORE IN CHARACTER VARIABLE C1 $C1 \leftarrow (A)$ Immediate addressing Reserve one word of storage/variable for use by the program AL PHA RESW ONE-WORD VARIABLE C1ONE-BYTE VARIABLE RESB 1 Hao Chang





## Sample Arithmetic Operations

|                          |                                                | IA = (ALP)                                           | $\Pi A) + (\Pi V C R) -$                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------|------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| comr                     | SIC                                            | LDA<br>ADD<br>SUB<br>STA<br>LDA<br>ADD<br>SUB<br>STA | ALPHA<br>INCR<br>ONE<br>BETA<br>GAMMA<br>INCR<br>ONE<br>DELTA | LOAD ALPHA INTO REGISTER A $A \leftarrow (ALPHA)$<br>ADD THE VALUE OF INCR $A \leftarrow (A) + (INCR)$<br>SUBTRACT 1 $A \leftarrow (A) - (ONE)$<br>STORE IN BETA BETA $\leftarrow (A)$<br>LOAD GAMMA INTO REGISTER A $A \leftarrow (GAMMA)$<br>ADD THE VALUE OF INCR $A \leftarrow (A) + (INCR)$<br>SUBTRACT 1 $A \leftarrow (A) - (ONE)$<br>STORE IN DELTA DELTA $\leftarrow (A)$<br>$\rightarrow$ DELTA = (GAMMA) + (INCR) - 1 |
| constant -<br>variable < | ONE<br>ALPHA<br>BETA<br>GAMMA<br>DELTA<br>INCR | WORD<br>RESW<br>RESW<br>RESW<br>RESW<br>RESW         |                                                               | ONE-WORD CONSTANT<br>ONE-WORD VARIABLES<br>Ogram is to store the value (ALPHA +<br>1) in BETA, and the value (GAMMA<br>-1) in DELTA.                                                                                                                                                                                                                                                                                             |





## **Sample Arithmetic Operations (Cont.)**

|           | LDS      | INCR      | TOAD VALUE OF THE THE AND DECTEMEN $C < (INCD)$          |
|-----------|----------|-----------|----------------------------------------------------------|
| SIC/XE    |          |           | LOAD VALUE OF INCR INTO REGISTER S S $\leftarrow$ (INCR) |
| 1         | LDA      | ALPHA     | LOAD ALPHA INTO REGISTER A $\land \leftarrow$ (ALPHA)    |
| 1         | ADDR     | S,A       | ADD THE VALUE OF INCR $A \leftarrow (A) + (S)$           |
| <br> <br> | SUB      | #1        | SUBTRACT 1 A $\leftarrow$ (A) - 1                        |
|           | STA      | BETA      | STORE IN BETA $\leftarrow$ (A)                           |
|           | LDA      | GAMMA     | LOAD GAMMA INTO REGISTER A A $\leftarrow$ (GAMMA)        |
|           | ADDR     | S,A       | ADD THE VALUE OF INCR $A \leftarrow (A) + (S)$           |
|           | SUB      | #1        | SUBTRACT 1 A $\leftarrow$ (A) - 1                        |
|           | STA      | DELTA     | STORE IN DELTA $\rightarrow$ (A)                         |
|           |          |           |                                                          |
|           |          |           |                                                          |
|           |          |           |                                                          |
| -         |          |           | ONE WORD VARIABLES                                       |
| ALPHA     | RESW     | 1         |                                                          |
| BETA      | RESW     |           | avoids having to fetch INCR from memory                  |
| GAMMA     | RESW     | 1 each    | time it is used in a calculation.                        |
| DELTA     | RESW     | 1 Imm     | adiata addrassing is used for the constant               |
| INCR      | RESW     |           | ediate addressing is used for the constant               |
| TIACL     | 1/12/0/4 | + I I I I | he subtraction operations.                               |





# SIC Indexed addressing

| MOVECH    | LDX<br>LDCH<br>STCH<br>TIX<br>JLT | STR1 X<br>STR2,X<br>ELEVEN | INITIALIZE INDEX REGISTER TO 0 $X \leftarrow (ZERO)$<br>LOAD CHARACTER FROM STR1 INTO REG A $A \leftarrow (STR1 + (X)$<br>STORE CHARACTER INTO STR2 $STR2 + (X) \leftarrow (A)$<br>ADD 1 TO INDEX, COMPARE RESULT TO 11 $X \leftarrow (X) + 1$<br>LOOP IF INDEX IS LESS THAN 11 (X): (ELEVEN)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|-----------|-----------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1         |                                   |                            | PC ← MOVECH if CC set to <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|           |                                   |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| <br> <br> |                                   |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| STR1      | BYTE                              | C'TEST STRING              | G' 11-BYTE STRING CONSTANT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| STR2      | RESB                              | 11                         | 11-BYTE VARIABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|           |                                   |                            | ONE-WORD CONSTANTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| ZERO      | WORD                              | 0                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| ELEVEN    | WORD                              | • The loo                  | p copies one 11-byte character string to another.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| <br> <br> |                                   | • The ind                  | ex register X is initialized to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|           |                                   | • <i>TIX</i> per           | forms two functions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|           |                                   | •                          | t it adds 1 to the value in register X.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|           |                                   | – The                      | The still as a second data as a second state of the state of the second state of the s |  |  |



SIC/XF



#### Sample Looping and Indexing (Cont.) Immediate addressing

|        | LDT  | ( <b>∲</b> 11 | INITIALIZE REGISTER T TO 11 T $\leftarrow$ 1 | 1                    |
|--------|------|---------------|----------------------------------------------|----------------------|
|        | LDX  | #0            | INITIALIZE INDEX REGISTER TO 0               | X ← 0                |
| MOVECH | LDCH | STR1,X        | LOAD CHARACTER FROM STR1 INTO REG            | 3 A                  |
|        | STCH | STR2,X        | STORE CHARACTER INTO STR2                    |                      |
|        | TIXR | т             | ADD 1 TO INDEX, COMPARE RESULT TO            | ) 11                 |
|        | JLT  | MOVECH        | LOOP IF INDEX IS LESS THAN 11                |                      |
|        |      |               |                                              | $X \leftarrow (X) +$ |
|        |      |               |                                              | (X) : (T)            |
|        |      |               |                                              |                      |
| STR1   | BYTE | C'TEST STR    | ING' 11-BYTE STRING CONSTANT                 |                      |
| STR2   | RESB | 11            | 11-BYTE VARIABLE                             |                      |
|        |      |               |                                              |                      |

- **TIXR** allows to compare index register **X** with another register. - This is efficient because the value does not have to be fetched
  - from memory each time the loop is executed.

Copyright © All Rights Reserved by Yuan-Hao Chang





## **Another Sample Indexing and Looping**

|           | SIC       | LDA  | ZERO                | INITIALIZE INDEX VALU                 |                                                                                    |  |
|-----------|-----------|------|---------------------|---------------------------------------|------------------------------------------------------------------------------------|--|
|           |           | STA  | INDEX               | INDEX $\leftarrow$ (A); // initialize |                                                                                    |  |
|           | ADDLP     | LDX  | INDEX               | LOAD INDEX VALUE INTO                 |                                                                                    |  |
| (         | Gamma ← ∫ | LDA  | ALPHA,X             | LOAD WORD FROM ALPHA                  | INTO REGISTER A $\leftarrow$ (ALPHA + (X))                                         |  |
|           | (ALPHA)   | ADD  | BETA, X             | ADD WORD FROM BETA A                  | $\leftarrow$ (A) + (BETA+(X))                                                      |  |
|           | + (BETA)  | STA  | GAMMA, X            | STORE THE RESULT IN A                 | $O_{\Lambda}(M)$                                                                   |  |
|           | Move to   | LDA  | INDEX               | ADD 3 TO INDEX VALUE                  |                                                                                    |  |
|           | next word | ADD  | THREE               | $A \leftarrow (A) + (THREE); // inc$  | prease 3                                                                           |  |
|           |           | STA  | INDEX               | INDEX $\leftarrow$ (A);               |                                                                                    |  |
|           |           | COMP | K300                | COMPARE NEW INDEX VAL                 | JUE TO 300 (A): (K300)                                                             |  |
| - <u></u> |           | JLT  | ADDLP               | LOOP IF INDEX IS LESS                 | G THAN 300 PC ← ADDLP if CC set to <                                               |  |
| 1         |           |      |                     |                                       |                                                                                    |  |
|           |           |      |                     |                                       | Imbersome because register A must be<br>A and BETA, and <i>incrementing</i> INDEX. |  |
|           | INDEX     | RESW | 1                   | ONE-WORD VARIABLE FOR                 | R INDEX VALUE                                                                      |  |
|           |           |      |                     | ARRAY VARIABLES100                    | WORDS EACH                                                                         |  |
|           | ALPHA     | RESW | 100                 |                                       | <ul> <li>This loop adds elements of ALPHA</li> </ul>                               |  |
| i<br>i    | BETA      | RESW | 100 <b>≻100-</b> v  | vord arrays/variables                 | and BETA, and stores the results in                                                |  |
| 1         | GAMMA     | RESW | 100                 |                                       | the elements of GAMMA.                                                             |  |
|           |           |      |                     | ONE-WORD CONSTANTS                    |                                                                                    |  |
|           | ZERO      | WORD | 0                   |                                       | <ul> <li>TIX instruction always adds 1 to</li> </ul>                               |  |
| i<br>i    | K300      | WORD | 300 <b>≻ ONE-</b> \ | word constants                        | register <b>X</b> , so it is not suitable to                                       |  |
|           | THREE     | WORD | 3                   |                                       | this program.                                                                      |  |





# Another Sample Indexing and Looping (Cont.)

| SIC/XE    | LDS<br>LDT | #3<br>#300 | INITIALIZE REGISTER S TO 3 $S \leftarrow 3$<br>INITIALIZE REGISTER T TO 300 $T \leftarrow 300$                                         |  |
|-----------|------------|------------|----------------------------------------------------------------------------------------------------------------------------------------|--|
|           | LDX        | #0         | INITIALIZE INDEX REGISTER TO $0 \times \leftarrow 0$                                                                                   |  |
| ADDLP     | LDA        | ALPHA,     |                                                                                                                                        |  |
| GAMMA ← J | ADD        | BETA, X    |                                                                                                                                        |  |
| (ALPHA)   | STA        | GAMMA,     |                                                                                                                                        |  |
| + (BETA)  |            |            |                                                                                                                                        |  |
|           | ADDR       | S,X        | ADD 3 TO INDEX VALUE $X \leftarrow (X) + (S)$ ; // move to next word                                                                   |  |
|           | COMPR      | Х,Т        | COMPARE NEW INDEX VALUE TO 300 $(\times)$ : (T)                                                                                        |  |
|           | JLT        | ADDLP      | LOOP IF INDEX VALUE IS LESS THAN 300                                                                                                   |  |
|           | •          |            |                                                                                                                                        |  |
|           |            |            |                                                                                                                                        |  |
|           |            |            |                                                                                                                                        |  |
|           |            |            | ARRAY VARIABLES100 WORDS EACH                                                                                                          |  |
| ALPHA     | RESW       | 100        |                                                                                                                                        |  |
| BETA      | RESW       | 100        | <ul> <li>Register S: Store 3 for the one-word increment.</li> <li>Register T: Store 300 for the number of words in an array</li> </ul> |  |
| GAMMA     | RESW       | 100        |                                                                                                                                        |  |
|           |            |            | Register <b>X</b> : Indicate the <b>offset (index value)</b> to the starting of an array.                                              |  |





## **Simple Input and Output**



- This program reads 1 byte of data from *device F1* and copies it to *device 05*.
- **TD** instruction is to test whether the device is ready.
  - If the device is *ready* to transmit data, the condition code is set to "*less than*."
  - If the device is not ready, the condition is set to "equal."

37





### **Sample Subroutine Call**

| SIC             | JSUB                                                 | READ                                                                                                                                                                                                                                                                             | CALL READ SUBROUTINE $L \leftarrow (PC)$ ; PC $\leftarrow$ READ                                                                                                                                                                                                                                        |                              |
|-----------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
|                 |                                                      |                                                                                                                                                                                                                                                                                  | Before value of PC is stored in L, PC is advanced by 3 (pointin to the next instruction)                                                                                                                                                                                                               | ng                           |
| READ<br>RLOOP   | LDX<br>TD<br>JEQ<br>RD<br>STCH<br>TIX<br>JLT<br>RSUB | ZERO<br>INDEV<br>RLOOP<br>INDEV<br>RECORD,X<br>K100<br>RLOOP                                                                                                                                                                                                                     | SUBROUTINE TO READ 100-BYTE RECORD<br>INITIALIZE INDEX REGISTER TO 0<br>TEST INPUT DEVICE<br>LOOP IF DEVICE IS BUSY<br>READ ONE BYTE INTO REGISTER A<br>STORE DATA BYTE INTO RECORD<br>ADD 1 TO INDEX AND COMPARE TO 100<br>LOOP IF INDEX IS LESS THAN 100<br>EXIT FROM SUBROUTINE $PC \leftarrow (L)$ | 1 and<br>a 100-<br>a<br>DRD. |
| INDEV<br>RECORD | BYTE<br>RESB                                         | X'F1'<br>100                                                                                                                                                                                                                                                                     | INPUT DEVICE NUMBER<br>100-BYTE BUFFER FOR INPUT RECORD                                                                                                                                                                                                                                                |                              |
| ZERO<br>K100    | WORD<br>WORD                                         | <ul> <li>This subroutine is called from the main program by the <i>JSUB</i> (<i>Jump to Subroutine</i>) instruction.</li> <li>At the end of the subroutine, an <i>RSUB (Return from Subroutine)</i> instruction returns to the instruction <i>following the JSUB</i>.</li> </ul> |                                                                                                                                                                                                                                                                                                        |                              |





### **Sample Subroutine Call (Cont.)**

| SIC/XE                                                                                         | JSUB | READ      | CALL READ SUBROUTINE $L \leftarrow (PC); PC \leftarrow READ$        |
|------------------------------------------------------------------------------------------------|------|-----------|---------------------------------------------------------------------|
|                                                                                                | •    |           |                                                                     |
| ↓                                                                                              |      |           | SUBROUTINE TO READ 100-BYTE RECORD                                  |
| READ                                                                                           | LDX  | #0        | INITIALIZE INDEX REGISTER TO 0 $X \leftarrow 0$                     |
|                                                                                                | LDT  | #100      | INITIALIZE REGISTER T TO 100 T $\leftarrow$ 100                     |
| RLOOP                                                                                          | TD   | INDEV     | TEST INPUT DEVICE Test device specified by (INDEV)                  |
|                                                                                                | JEQ  | RLOOP     | LOOP IF DEVICE IS BUSY PC   RLOOP if CC set to =                    |
|                                                                                                | RD   | INDEV     | READ ONE BYTE INTO REGISTER A A                                     |
|                                                                                                | STCH | RECORD, X | STORE DATA BYTE INTO RECORD RECORD + (X) $\leftarrow$ (A)           |
|                                                                                                | TIXR | т         | ADD 1 TO INDEX AND COMPARE TO 100 $X \leftarrow (X) + 1; (X) : (T)$ |
|                                                                                                | JLT  | RLOOP     | LOOP IF INDEX IS LESS THAN 100 PC   RLOOP if CC set to <            |
|                                                                                                | RSUB |           | EXIT FROM SUBROUTINE $PC \leftarrow (L)$                            |
|                                                                                                | •    |           |                                                                     |
|                                                                                                |      |           |                                                                     |
|                                                                                                | •    |           |                                                                     |
| INDEV                                                                                          | BYTE | X'F1'     | INPUT DEVICE NUMBER                                                 |
| RECORD                                                                                         | RESB | 100       | 100-BYTE BUFFER FOR INPUT RECORD                                    |
| <ul> <li>Register T: Store 100 for the number of bytes to read.</li> </ul>                     |      |           |                                                                     |
| <ul> <li>Register X: Indicate the offset (index value) to the starting of an array.</li> </ul> |      |           |                                                                     |





# **CISC Machines**







## **CISC Machines**

- Complex instruction set computers (CISC) usually include
  - A relatively large and complicated instruction set.
  - Several different instruction formats and lengths.
  - Many different addressing modes.
- The implementation of CISC architecture in hardware tends to be complex.
- Sample CISC machines
  - -VAX architecture
  - Pentium architecture





### **VAX Architecture**

#### Memory

- Bytes and words
  - 8 bits form a **byte**.
  - 2 bytes form a *word*.
  - 4 bytes form a *longword*.
  - 8 bytes form a *quadward*.
  - 16 bytes form a *octaword*.
- Some operations are more efficient when operands are aligned in a particular way.
  - E.g., a *longword* operand that begins at a byte address that is a multiple of 4.
- Virtual address space: 2<sup>32</sup> bytes
  - This virtual memory allows program to operate as though they have a large memory.
  - One half of virtual address space is **system space** that contains the operating system and is shared by all programs.
  - The other half of the address space is *process space* that is defined *separately for each program*.
    - A part of the process space contains stacks that are available to the program.





### VAX Architecture (Cont.)

### Registers

- 16 general-purpose registers denoted by *R0* through *R15.* 
  - R15 is the program counter (PC).
    - · It is updated during instruction execution to point to the *next instruction*.
  - R14 is the stack pointer (SP).
    - · It points to the *current top of the stack* in the program's *process space*.
  - R13 is the frame pointer (FP).
    - VAX procedure call conventions build a data structure called a stack frame, and place its address in FP.
  - R12 is the argument pointer (AP).
    - The procedure call convention uses AP to pass a *list of arguments* associated with the call.
  - R6 through R11 have no special functions.
  - *R0 through R5* are likewise available for general use, but are also used by some machine instructions.
- A processor status longword (PSL) that contains state variables and flags associated with a process.





## **VAX Architecture (Cont.)**

#### Data Formats

hexadecimal F for positive numbers and hexadecimal D for negative numbers

- Integers are stored as binary numbers in a byte, word, longword, quadword, or octaword.
- 2's complement representation is used for negative values.
- Characters are stored using their 8-bit ASCII codes.
- Four different floating-point data formats, ranging in length from 4 to 16 bytes.
- VAX processors provide a *packed decimal* data format.
  - Each byte represents two decimal digits, with each digit encoded using 4 bits of the byte. (4 bits form a *nibble*.)
  - The sign is encoded in the last 4 bits.
- VAX also provides hardware to support *queues* and *variable-length bit strings*.
  - There are single machine instructions that
    - · Insert and remove entries in queues. (support atomic operations)
    - Perform a variety of operations on bit strings. Copyright © All Rights Reserved by Yuan-Hao Chang





## **VAX Architecture (Cont.)**

#### Instruction formats

- VAX machine instructions use a variable-length instruction format.
- Each instruction consists of
  - An operation code (1 or 2 bytes)
  - Up to six operand specifiers, depending on the type of instruction.
    - Each operand specifier designates one of the VAX addressing modes and gives any additional information to locate the operand.

#### Addressing modes

- Register mode: The operand itself is in a register.
- Register deferred mode: The address of an operand is specified by a register.
  - The register contents may be automatically incremented or decremented by the operand length (*autoincrement* and *autodecrement* modes).
- There are several base relative addressing modes, with displacement fields of different lengths.
  - E.g., PC-relative mode by using register PC for the displacement.
- *Immediate addressing* is to include operands in the instruction itself.
- All of the addressing modes could include an *index register*, and many of them are available in a form that specifies *indirect addressing*.

Copyright © All Rights Reserved by Yuan-Hao Chang





### VAX Architecture (Cont.)

#### Instruction set

- Instruction *mnemonics* are formed by combining the following elements:
  - 1. a prefix that specifies the type of operations,
  - 2. a suffix that specifies the data type of the operands,
  - 3. a *modifier* (on some instructions) that gives *the number of operands involved*.
- E.g.,
  - **ADDW2**: an add operation with *two* operands, and each a word in length.
  - MULL3: a multiply operation with three longword operands.
  - CVTWL: a conversion from word to longword, with two operands.
- Operands may be located in registers, memory, or instruction itself (immediate addressing).
- VAX provides all of the usual types of instructions for *computation*, *data movement and conversion*, *comparison*, *branching*, etc.



### **VAX Architecture (Cont.)**

### Instruction set (Cont.)

- There are a number of operations that are much more complex than the machine instructions found on most computers.
  - These operations are hardware realizations of frequently occurring sequences of codes. E.g.,
    - Instructions to load and store *multiple registers*, and manipulate *queues* and *variable-length bit fields*.
    - · Powerful instruction to call and return from procedures.
    - Single instruction to
      - » Save a designated set of registers,
      - » Pass a list of arguments to the procedure,
      - » Maintain the stack, frame, and argument pointers, and
      - » Set a mask to enable error traps for arithmetic operations.



# VAX Architecture (Cont.)

### Input and output

- Input and output are accomplished by I/O device controllers.
- Each controller has a set of control/status and data registers, which are assigned locations in the *physical* address space.
- The address space mapped by the device controller registers are called **I/O** space.
  - No special instructions are required to access registers in I/O space.
  - An I/O device driver issues commands to the device controller by storing values into the appropriate *registers*, exactly as if there were physical memory locations.
  - The association of an address in I/O space with a physical register in a device controller is handled by the *memory* management routines.

Copyright © All Rights Reserved by Yuan-Hao Chang





### **Pentium Architecture**

### Memory

- At the physical level, memory consists of 8-bit bytes. All addresses used are byte addresses.
- Programmers view the x86 memory as a collection of segments.
  - An address consists of two parts: A segment number and an offset.
    - Segments can be of different sizes, and are often used for different purposes. E.g., a segment for executable instructions or data storage.
    - A segment can be divided into *pages*. Some of the pages of a segment may be in physical memory, while others may be stored on disk.
  - The segment/offset address specified by the programmer is automatically translated into a physical byte address by the x86 *Memory Management Unit (MMU)*.







#### Registers

- Eight general-purpose registers (32 bits):
  - *EAX, EBX, ECX, and EDX* are generally used for data manipulation. It is possible to access individual words or bytes from these registers.
  - ESI, EDI, EBP, and ESP are usually used to hold addresses.
- EIP is a 32-bit register that contains a pointer to the next instruction to be executed. (like program counter (PC))
- FLAGS is a 32-bit register that contains many different bit flags.
  - Some indicates the status of the processor.
  - Others are used to record the results of comparisons and arithmetic operations.
- Six 16-bit segment registers to locate segments in memory.
  - Segment register **CS** contains the address of the *currently executing code segment*.
  - Segment register **SS** contains the address of the *current stack segment*.
  - DS, ES, FS, and GS are used to indicate the addresses of data segment.
- Floating-point computations are performed by a special *floating-point unit* (FPU).

(MUT



October 8, 2010

## **Pentium Architecture (Cont.)**

#### Data formats

- Integers are normally stored as 8-, 16-, or 32-bit binary numbers. Negative values are represented in 2's complement.
- Little-endian byte ordering:
  - The least significant part of a numeric value is stored at the lowestnumbered address.
- Two binary coded decimal (BCD) formats:
  - Unpacked BCD format: Each byte represents one decimal digit.
  - Packed BCD format: Each byte represents two decimal digits.
- Three different floating-point data formats:
  - Single-precision format: 32 bits long (24 significant bits and 7-bit exponent).
  - Double-precision format: 64 bits long (53 significant bits and 10-bit exponent).
  - Extended-precision format: 80 bits long (64 significant bits and 15-bit exponent).
- Characters are stored one per byte.





### Instruction formats

- Basic format:
  - Begin with *optional prefixes* to contain flags that modify the operation of the instruction. E.g.,
    - · Repetition count for an instruction.
    - Specification to a segment register that is used for addressing an operand (to override the normal default assumptions).
  - Following the prefix (if any) is an **opcode** (1 or 2 bytes).
    - $\cdot$  The opcode is the only element that is always present in every instruction.
  - Following the opcode are a number of bytes that specify the operands and addressing modes to be used.
- There are a large number of different potential instruction formats, varying in length from 1 byte to 10 bytes or more.





### Addressing modes

- An operand value may be specified as part of the instruction itself (*immediate mode*), or it may be in a register (*register mode*).
- Operands stored in memory are often specified by the *target* address calculation:

TA = (base register) + (index register) \* (scale factor) + displacement

- Any general-purpose register may be used as a base register.
- Any general-purpose register except ESP can be used as an *index register*.
- The scale factor may have the value 1, 2, 4, or 8.
- The displacement may be an 8-, 16-, or 32-bit value.
- Various combinations of these items may be omitted, resulting in eight different addressing modes.
- The address of an operand in memory may be specified as an absolute location (*direct mode*), or as a location relative to the EIO register (*relative mode*).







#### Instruction set

- The x86 architecture has a large and complex instruction set (more than 400 different machine instructions).
- An instruction may have zero, one, two, or three operands.
- There are register-to-register instruction, register-to-memory instructions, and a few memory-to-memory instructions.
- Most data movement and integer arithmetic instructions can use operands that are 1, 2, or 4 bytes long.
- String manipulation instructions can deal with variable-length strings of bytes, words, or doublewords.
- Many instructions that
  - Perform *logical and bit manipulations*, and
  - Support control of the processor and memory-management systems.
- The x86 architecture includes special-purpose instructions to perform operations frequently required in *high-level programming languages*.
  - E.g., entering and leaving procedures, and checking subscript values against the bounds of an array.





### Input and output

- Input is performed by instructions that transfer one byte, word, or doubleword at a time *from an I/O port into register EAX*.
- Output instructions transfer one byte, word, or doubleword *from EAX to an I/O port*.
- *Repetition prefixes* allow to transfer an entire string in a single operation.
- Special I/O instructions are needed.





# **RISC Machines**





### **RISC Machines**

- Reduced Instruction Set Computers (RISC) have a simplified design that results in
  - Faster and less expensive processor development
  - Greater reliability and
  - Faster instruction execution times.
- A RISC system is characterized by
  - A fixed instruction length, and
  - Single-cycle execution of most instructions.
- Memory access is usually done by *load and store instructions* only.
- All instructions except for load and store are *register-to-register* operations.
- There are typically a large number of general-purpose registers.
- The number of machine instructions, instruction formats, and addressing modes is relatively small.
- Sample CISC machines are UltraSPARC, PowerPC, and Cray T3E.





### **UltraSPARC Architecture**

- The UltraSPARC processor was announced by Sun.
  - SPARC stands for Scalable Processor Architecture.

### • Memory

- Bytes and words
  - 8-bit forms a **byte**.
  - 2 consecutive bytes form a *halfword*.
  - 4 bytes form a *word*.
  - 8 bytes form a *doubleword*.
- Virtual address space is 2<sup>64</sup> bytes.
  - This address space is divided into *pages*.
  - Multiple page sizes are supported.
  - Pages used by a program could be in physical memory or on disk.
  - The virtual address specified by instruction is translated into a physical address by MMU.





### Registers

- SPARC includes a large *register file* that usually contains more than 100 general-purpose registers.
  - Procedures could only access 32 registers designated to r0 through r31.
    - · r0 through r7 are global: They can be accessed by all procedures.
    - The other 24 registers available to a procedure can be visualized as a <u>window</u> through which part of the <u>register file</u> can be seen, so some registers in the register file are shared between procedures.
      - » E.g., Registers r8 through r15 of a calling procedure are physically the same registers as r24 through r31 of the called procedure (for parameter passing).
  - If a set of concurrently running procedures need more windows than available, a "*window overflow*" interrupt occurs to trigger saving the contents of some registers in the file (and restore them later).
- Floating-point computations are performed through FPU.
- In addition, there are a program counter, condition code registers, and a number of other control registers.





#### Data formats

- It provides integers, floating-point values, and characters.
- Integers are 8-,16-, 32-, or 64-bit binary numbers. (2's complement for negative values).
- Big-endian byte ordering is supported: The most significant part of a numeric value is stored at the lowest-numbered address.
- Three different floating-point data formats:
  - **Single-precision format**: 32 bits long (23 significant bits and 8-bit exponent)
  - **Double-precision format:** 64 bits long (52 significant bits and 11-bit exponent)
  - Quad-precision format: 80 bits long (63 significant bits and 15-bit exponent)
- Characters are stored one per byte, using 8-bit ASCII codes.





#### Instruction formats

- Every instruction is 32 bits long.
  - The first 2 bits identify which format is used.
    - Format 1 is used for the call instruction.
    - Format 2 is used for branch instructions.



• Format 3 provides register loads and stores, and three-operand arithmetic operations.

#### Addressing modes

- An operand value is specified as part of the instruction itself (*immediate mode*) or is in a register (*register direct mode*).
- Operands in memory are addressed using one of the following mode:

| Mode                                   | Target address (TA) calculation                 |
|----------------------------------------|-------------------------------------------------|
| PC-relative                            | TA = (PC) + displacement{30 bits, signed}       |
| Register indirect with<br>displacement | TA = (register) + displacement{13 bits, signed} |
| Register indirect indexed              | TA = (register-1) + (register-2)                |





#### Instruction set

- Fewer than 100 machine instructions (reflecting RISC philosophy).
- Load and store architecture: only load and store instructions access memory.
- Instruction execution is *pipelined*.
  - Pipeline means that while one instruction is being executed, the next one is being fetched from memory and decoded.
  - An branch instruction might cause the process to "stall."
    - The instruction following the branch would have to be discarded even if it is fetched and decoded.
  - To make pipeline more efficient, SPARC branch instructions are *delayed branches*.
    - A delayed branch means that the instruction immediately following the branch instruction is actually executed *before* the branch is taken.

 SUB
 %L0, 11, %L1 // %L1 ← (%L0) - 11

 BA
 NEXT // PC ← NEXT

 MOV
 %L1, %O3 // %O3 ← (%L1)

%L1, %O3 // %O3 ← (%L1) ------ In the *delay slot: MOV* is executed before the branch *BA*.

Copyright © All Rights Reserved by Yuan-Hao Chang





#### Instruction set (Cont.)

- High-bandwidth *block load and store* operations.
- Communication in a multi-processor system is facilitated by "atomic" instructions that can execute without allowing other memory accesses to intervene.
- Conditional move instructions may allow a compiler to eliminate many branch instruction.

#### Input and output

- Communication with I/O devices is accomplished through memory.
- A range of memory locations is logically replaced by *device registers*.
  - Each I/O device has a unique set of addresses assigned to it.
  - When a load or store instruction refers to this device register area of memory, the corresponding device is activated. (*No special I/O instructions are needed.*)





### **PowerPC** Architecture

 POWER is an acronym for *P*erformance *O*ptimization *W*ith *E*nhanced **R**ISC.

#### Memory

- Bytes and words
  - 8 bits form a byte.
  - 2 consecutive bytes form a *halfword*.
  - 4 bytes form a *word*.
  - 8 bytes form a *doubleword*.
  - 16 bytes form a *quadword*.
- All addresses are byte addresses.
- If **operands** are aligned at a starting address that is *a multiple of their length*.
- Virtual address space is of 2<sup>64</sup> bytes.
  - This space is divided into fixed-length *segments*, which are 256 MBs long.
  - Each segment is divided into *pages*, which are 4096 bytes long.
  - A page could be in memory or on disk.
  - When an instruction is executed, the hardware and OS make sure the needed page is loaded to physical memory.
  - The virtual address specified by the instruction is automatically translated into a physical address by MMU.





### Registers

- 32 general-purpose registers, designated *GPR0 through GPR31*. Each is 64 bits long.
- Floating-point computations are performed using a special floating-point unit (*FPU*).
- A 32-bit condition register (CR) reflects the result of certain operations such as testing, branching, and arithmetic.
  - This register is divided into *eight 4-bit subfields*, named *CR0 through CR7*.
- Other registers:
  - A *link register (LR)* and a *count register (CR)* for branch instructions.
  - A *machine status register (MSR)* and other control and status registers. Copyright © All Rights Reserved by Yuan-Hao Chang





#### Data formats

- Integers are stored as 8-, 16-, 32-, or 64-bit binary numbers.
- 2's complement is used to store negative values.
- Big-endian byte ordering: The most significant part of a numeric value is stored at the lowest-numbered address. (Little-endian is also supported).
- There are two float-point data formats:
  - **Single-precision format**: 32-bit long (23 significant bits and 8-bit exponent)
  - **Double-precision format:** 64-bit long (52 significant bits and 11-bit exponent)
- Characters are stored one per byte, using 8-bit ASCI codes.





### Instruction formats

- There are seven basic instruction formats (32 bits long).
- Instructions must be aligned at a word boundary.
  - The first 6 bits specify the **opcode**, and some have an additional "**extended opcode**" field.
- The variety and complexity of instruction formats is greater than that on SPARC.
- The fixed length makes instruction decoding faster and simpler than CISC.





## **PowerPC Architecture (Cont.)**

#### Addressing modes

- An operand value is specified as part of the instruction itself (*Immediate mode*) or is in a register (*register direct mode*).
- Only load/store operations and branch operations would access memory.
- Load and store operations use one of the following addressing modes (where the register numbers and displacement are encoded in the instruction):

| Mode                                      | Target address (TA) calculation                  |
|-------------------------------------------|--------------------------------------------------|
| Register indirect                         | TA = (register)                                  |
| Register indirect with index              | TA = (register-1) + (register-2)                 |
| Register indirect with<br>immediate index | TA = (register) + displacement {16 bits, signed} |





### **PowerPC Architecture (Cont.)**

#### Addressing modes

- Branch instructions use one of the following addressing modes:

| Mode           | Target address (TA) calculation                                     |
|----------------|---------------------------------------------------------------------|
| Absolute       | TA = actual address                                                 |
| Relative       | TA = current instruction address +<br>displacement{25 bits, signed} |
| Link Register  | TA = (LR)                                                           |
| Count Register | TA = (CR)                                                           |

The absolute address or displacement is encoded as part of the instruction.





#### Instruction set

- PowerPC has approximately 200 machine instructions.
  - Some are more complex than those in most RISC systems.
  - E.g.,
    - · Load and store instructions may automatically update the index registers.
    - · Instructions could perform multiplication and addition in one instruction.
- Instruction execution on PowerPC is *pipeline*.
- Branch prediction is used to speed execution.

### Input and output

- Two different methods for performing I/O operations.
  - Segments in the virtual address space are mapped onto *an external address space*. (called *direct-store segments*)
  - A reference to an address represents a *normal virtual memory access*.
     I/O is performed using the regular virtual memory management hardware and software.





## Cray T3E Architecture (Alpha)

- Cray T3E is an architecture of supercomputers and is a massively parallel processing (MPP) system.
- A T3E system contains a large number of processing elements (PE), arranged in a three-dimensional network.
  - The network provides a *path* for transferring data between processors.
  - Control functions are provided to synchronize the operation of the PEs used by a program.
  - The interconnect network is *circular* in each dimension.
- Each PE consists of
  - A DEC Alpha EV5 RISC microprocessor,
  - Local memory, and
  - Performance-accelerating control logic.
- A T3E system may contain from 16 to 2048 PEs.



Copyright © All Rights Reserved by Yuan-Hao Chang





## Cray T3E Architecture (Cont.)

### Memory

- Each PE has its own local memory with a capacity of from 64 MB to 2 GB.
  - The local memory within each PE is part of a *physically distributed, logically shared* memory system.
  - One PE could access the memory of another PE.
- Bytes and words
  - 8 bits form a **byte**.
  - 2 consecutive bytes form a word.
  - 4 bytes form a *longword*.
  - 8 bytes form a *quadword*.
- All addresses are byte-addressable.
- Instruction execution could be more efficient if operands are *aligned* at a starting address that is a multiple of their length.





## Cray T3E Architecture (Cont.)

#### Registers

- There are 32 64-bit general-purpose registers (*R0 through R31*). *R31* always contains the value zero.
- There are 32 64-bit floating-point registers (*F0 through F31*). *F31* always contains the value zero.
- Other registers: a 64-bit program counter *PC*, and several *status and control registers*.

#### Data formats

- Integers are stored as lognwords or quadwords.
- 2's complement is used to store negative values.
- There are two types float-point data formats:
  - One group of three formats is included for compatibility with the VAX architecture.
  - The other group consists of four IEEE standard formats.
- Characters are stored one per byte, using 8-bit ASCII codes.
  - There are no byte load or store operations in *Alpha*. Only longwords and quadwords can be transferred between a register and memory.
     → Characters are usually stored one per longword. (Trade-off between performance and space)

| ÎNUT |
|------|
| 1550 |



# Cray T3E Architecture (Cont.)

#### Instruction formats

- There are five basic instruction formats in the Alpha architecture.
- Each instruction is 32 bits long.
  - The first 6 bits specify the opcode.
  - Some instruction have an additional "function" field.

### Addressing modes

- An operand value is specified as part of the instruction itself (*Immediate mode*) or is in a register (*register direct mode*).
- Only load/store operations and branch operations would access memory.

For load and store operations and subroutine calls.

| Mode                                   | Target address (TA) calculation                  |
|----------------------------------------|--------------------------------------------------|
| PC-relative                            | TA = (PC) + displacement {23 bits, signed}       |
| Register indirect with<br>displacement | TA = (register) + displacement {16 bits, signed} |

For conditional and unconditional branches





# Cray T3E Architecture (Cont.)

### Instruction set

- There are approximately 130 machine instruction, reflecting its RISC orientation.
- There are no byte or word load and store instructions.
  - This means that the memory access interface does not need to include *shift-and-mask* operations.

### Input and output

- The T3E system performs I/O through *multiple ports* into one or more *I/O channels*.
- Channels are integrated into the network that interconnects the processing nodes.
- A system may be configured with up to one I/O channel for every eight PEs.
- All channels are accessible and controllable from all PEs.





# **References to Addressing Modes and Instruction Set**





# **Addressing Modes**

- Flag bits
  - Addressing types
    - *n* indicates indirect addressing (Addressing types)
    - *i* indicates immediate addressing
  - Addressing modes
    - **b** indicates base-relative addressing mode (Addressing modes)
    - p indicates PC-relative addressing mode
    - x indicates indexed addressing mode
  - Extension
    - e indicates extended format (i.e., Format 4) (Extension)
- Assembler language notation:
  - c indicates a constant between 0 and 4095.
  - m indicates a memory address or a constant value larger than 4095.
  - + indicates extended format (i.e., Format 4)
  - @ indicates a *indirect addressing*
  - # indicates a immediate addressing
  - X indicates register X (using indexed addressing)
- Letters in Notes
  - 4 Format 4 instruction
  - D Direct-addressing instruction (*b=0, p=0*)
  - A Program-counter relative or base relative mode (**b=1** or **p=1**)
  - **S** Compatible with standard SIC instructions. Operand value is between 0 and 32,767.



|                 |                          | Assembler            | Calculation             | October 8, 2010 |       |  |  |  |
|-----------------|--------------------------|----------------------|-------------------------|-----------------|-------|--|--|--|
| Addressing type | Flag bits<br>n i x b p e | language<br>notation | of target<br>address TA | Operand         | Notes |  |  |  |
| Simple          | 110000                   | op c                 | disp                    | (TA)            | D     |  |  |  |
|                 | 110001                   | +op m                | addr                    | (TA)            | 4 D   |  |  |  |
|                 | 110010                   | op m                 | (PC) + disp             | (TA)            | A     |  |  |  |
|                 | 110100                   | op m                 | (B) + disp              | (TA)            | А     |  |  |  |
|                 | 111000                   | op c,X               | disp + (X)              | (TA)            | D     |  |  |  |
|                 | 111001                   | +op m,X              | addr + (X)              | (TA)            | 4 D   |  |  |  |
|                 | 111010                   | op m,X               | (PC) + disp + (X)       | (TA)            | А     |  |  |  |
|                 | 111100                   | op m,X               | $(B)+\mathrm{disp}+(X)$ | (TA)            | А     |  |  |  |
|                 | 000                      | op m                 | b/p/e/disp              | (TA)            | DS    |  |  |  |
|                 | 001                      | op m,X               | b/p/e/disp + (X)        | (TA)            | D S   |  |  |  |
| Indirect        | 100000                   | op @c                | disp                    | ((TA))          | D     |  |  |  |
|                 | 100001                   | +op @m               | addr                    | ((TA))          | 4 D   |  |  |  |
|                 | 100010                   | op @m                | (PC) + disp             | ((TA))          | A     |  |  |  |
|                 | 100100                   | op @m                | (B) + disp              | ((TA))          | А     |  |  |  |
| Immediate       | 010000                   | op #c                | disp                    | TA              | D     |  |  |  |
|                 | 010001                   | +op #m               | addr                    | TA              | 4 D   |  |  |  |
|                 | 010010                   | op #m                | (PC) + disp             | TA              | А     |  |  |  |
|                 | 010100                   | op #m                | (B) + disp              | TA              | А     |  |  |  |





### Instruct Set of SIC/XE







## Instruction Set Table of SIC/XE

- Mnemonic
  - *m* indicates a memory address.
  - *n* indicates an integer between 1 and 16.
  - r1, r2 represent register identifiers.
- Format :
  - Format indicates which SIC/XE instruction format is to be used in assembling each instruction. (3/4 : means that either Format 3 or Format 4 can be used.)
  - All instructions for the standard SIC are compatible with Format 3 of SIC/XE.
  - Instruction subfields that are not required are set to zero.
- Effect
  - Parentheses are used to denote the contents of a register or memory location.
    - A ← (m..m+2) specifies that the contents of the memory locations m through m+2 are loaded into register A.
    - m.m+2←(A) specifies that the contents of register A are stored in the word that begins at address m.
- Notes
  - **P**: **P**rivileged instruction
  - X : Instruction available only on SIC/XE version
  - F: Floating-point instruction
  - **C**: **C**ondition code CC set to indicate result of operation (<, =, or >)

Copyright © All Rights Reserved by Yuan-Hao Chang

| Mnemonic    | Format | Opcode | Effect                                   | Notes  |
|-------------|--------|--------|------------------------------------------|--------|
| ADD m       | 3/4    | 18     | $A \leftarrow (A) + (mm+2)$              |        |
| ADDF m      | 3/4    | 58     | $F \leftarrow (F) + (mm+5)$              | XF     |
| ADDR r1,r2  | 2      | 90     | $r2 \leftarrow (r2) + (r1)$              | Х      |
| AND m       | 3/4    | 40     | $A \leftarrow (A) \And (mm+2)$           |        |
| CLEAR r1    | 2      | B4     | r1 ← 0                                   | Х      |
| COMP m      | 3/4    | 28     | (A) : (mm+2)                             | С      |
| COMPF m     | 3/4    | 88     | (F) : (mm+5)                             | XFC    |
| COMPR r1,r2 | 2      | A0     | (r1): (r2)                               | X C    |
| DIV m       | 3/4    | 24     | $A \leftarrow (A) / (mm+2)$              |        |
| DIVF m      | 3/4    | 64     | $F \leftarrow (F) / (mm+5)$              | ΧF     |
| DIVR r1,r2  | 2      | 9C     | $r2 \leftarrow (r2) \ / \ (r1)$          | Х      |
| FIX         | 1      | C4     | $A \leftarrow (F)$ [convert to integer]  | ΧF     |
| FLOAT       | 1      | C0     | $F \leftarrow (A)$ [convert to floating] | XF     |
| HIO         | 1      | F4     | Halt I/O channel number (A)              | PX 1/5 |

| Mnemonic | Format | Opcode | Effect                                                                                  | Notes    |
|----------|--------|--------|-----------------------------------------------------------------------------------------|----------|
| Jm       | 3/4    | 3C     | $PC \leftarrow m$                                                                       |          |
| JEQ m    | 3/4    | 30     | $PC \leftarrow m \text{ if } CC \text{ set to } =$                                      |          |
| JGT m    | 3/4    | 34     | $PC \leftarrow m \text{ if } CC \text{ set to } >$                                      |          |
| JLT m    | 3/4    | 38     | $PC \leftarrow m \text{ if } CC \text{ set to } <$                                      |          |
| JSUB m   | 3/4    | 48     | $L \leftarrow (PC); PC \leftarrow m$                                                    | 14.<br>1 |
| LDA m    | 3/4    | 00     | $A \leftarrow (mm+2)$                                                                   | 14       |
| LDB m    | 3/4    | 68     | $B \leftarrow (mm+2)$                                                                   | Х        |
| LDCH m   | 3/4    | 50     | A [rightmost byte] $\leftarrow$ (m)                                                     |          |
| LDF m    | 3/4    | 70     | $F \leftarrow (mm+5)$                                                                   | XF       |
| LDL m    | 3/4    | 08     | $L \leftarrow (mm+2)$                                                                   |          |
| LDS m    | 3/4    | 6C     | $S \leftarrow (mm+2)$                                                                   | Х        |
| LDT m    | 3/4    | 74     | $T \leftarrow (mm+2)$                                                                   | Х        |
| LDX m    | 3/4    | 04     | $X \leftarrow (mm+2)$                                                                   |          |
| LPS m    | 3/4    | D0     | Load processor status from<br>information beginning at<br>address m (see Section 6.2.1) | PX       |
| MUL m    | 3/4    | 20     | $A \leftarrow (A) * (mm+2)$                                                             | 2/5      |

|             |        |        | October 8, 201                                                                                                                                            | 0 82      |
|-------------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Mnemonic    | Format | Opcode | Effect                                                                                                                                                    | Notes     |
| MULF m      | 3/4    | 60     | $F \leftarrow (F) * (mm+5)$                                                                                                                               | ΧF        |
| MULR r1, r2 | 2      | 98     | $r2 \leftarrow (r2) * (r1)$                                                                                                                               | Х         |
| NORM        | 1      | C8     | $F \leftarrow (F)$ [normalized]                                                                                                                           | ΧF        |
| OR m        | 3/4    | 44     | $A \leftarrow (A) \mid (mm+2)$                                                                                                                            |           |
| RD m        | 3/4    | D8     | A [rightmost byte] $\leftarrow$ data<br>from device specified by (m)                                                                                      | Р         |
| RMO r1,r2   | 2      | AC     | $r2 \leftarrow (r1)$                                                                                                                                      | Х         |
| RSUB        | 3/4    | 4C     | $PC \leftarrow (L)$                                                                                                                                       |           |
| SHIFTL r1,n | 2      | A4     | r1 ← (r1); left circular shift<br>n bits. {In assembled<br>instruction, r2 = n–1}                                                                         | Х         |
| SHIFTR r1,n | 2      | A8     | $r1 \leftarrow (r1)$ ; right shift n bits,<br>with vacated bit positions set<br>equal to leftmost bit of (r1).<br>{In assembled instruction,<br>r2 = n-1} | Х         |
| SIO         | 1      | F0     | Start I/O channel number (A);<br>address of channel program<br>is given by (S)                                                                            | РХ<br>3/5 |

| Res    |     | Opcode | Effect                                                            | Notes   |
|--------|-----|--------|-------------------------------------------------------------------|---------|
|        |     | EC     | Protection key for address m $\leftarrow$ (A) (see Section 6.2.4) | РХ      |
| STA m  | 3/4 | 0C     | $mm+2 \leftarrow (A)$                                             |         |
| STB m  | 3/4 | 78     | $mm+2 \leftarrow (B)$                                             | Х       |
| STCH m | 3/4 | 54     | $m \leftarrow (A)$ [rightmost byte]                               |         |
| STF m  | 3/4 | 80     | $mm+5 \leftarrow (F)$                                             | ΧF      |
| STI m  | 3/4 | D4     | Interval timer value $\leftarrow$<br>(mm+2) (see Section 6.2.1)   | РХ      |
| STL m  | 3/4 | 14     | $mm+2 \leftarrow (L)$                                             |         |
| STS m  | 3/4 | 7C     | $mm+2 \leftarrow (S)$                                             | Х       |
| STSW m | 3/4 | E8     | $mm+2 \leftarrow (SW)$                                            | Р       |
| STT m  | 3/4 | 84     | $mm+2 \leftarrow (T)$                                             | Х       |
| STX m  | 3/4 | 10     | $mm+2 \leftarrow (X)$                                             |         |
| SUB m  | 3/4 | 1C     | $A \leftarrow (A) - (mm+2)$                                       |         |
| SUBF m | 3/4 | 5C     | $F \leftarrow (F) - (mm+5)$                                       | X F 4/8 |





| Mnemonic   | Format | Opcode | Effect                                                       | Note | es  |
|------------|--------|--------|--------------------------------------------------------------|------|-----|
| SUBR r1,r2 | 2      | 94     | $r2 \leftarrow (r2) - (r1)$                                  | Х    |     |
| SVC n      | 2      | B0     | Generate SVC interrupt. {In assembled instruction, r1 = n}   | Х    |     |
| TD m       | 3/4    | EO     | Test device specified by (m)                                 | Р    | C   |
| TIO        | 1      | F8     | Test I/O channel number (A)                                  | РХ   | С   |
| TIX m      | 3/4    | 2C     | $X \leftarrow (X) + 1; (X): (mm+2)$                          |      | С   |
| TIXR r1    | 2      | B8     | $X \leftarrow (X) + 1; (X): (r1)$                            | Х    | С   |
| WD m       | 3/4    | DC     | Device specified by $(m) \leftarrow (A)$<br>[rightmost byte] | Р    | 200 |





## **ASCII Character Codes**

| Dec  | Hx   | Oct | Char | ·                        | Dec | Hx | Oct | Html          | Chr   | Dec | Нх | Oct | Html                  | Chr | Dec | : Hx | Oct | Html Ch                | nr  |
|------|------|-----|------|--------------------------|-----|----|-----|---------------|-------|-----|----|-----|-----------------------|-----|-----|------|-----|------------------------|-----|
| 0    | 0 0  | 000 | NUL  | (null)                   |     |    |     |               | Space |     |    |     | <b>∉#64;</b>          |     | 96  | 60   | 140 | <b>∉</b> #96;          | 1   |
| 1    | 1 (  | 001 | SOH  | (start of heading)       |     |    |     | <b>∉#33;</b>  |       |     |    |     | <b>∉#65;</b>          |     |     |      |     | <b></b> #97;           |     |
| 2    |      |     |      | (start of text)          | 34  | 22 | 042 | ∉#34;         | "     | 66  | 42 | 102 | <b>∉#66;</b>          | в   | 98  | 62   | 142 | <b>∉</b> #98;          | b   |
| 3    |      |     |      | (end of text)            |     |    |     | <b>∉#35;</b>  | -     |     |    |     | ¢#67;                 |     |     |      |     |                        | e - |
| 4    |      |     |      | (end of transmission)    |     |    |     | ∉#36;         |       |     |    |     | <b>∉</b> #68;         |     |     |      |     | d                      |     |
| 5    |      |     |      | (enquiry)                |     |    |     | ⊊#37;         |       |     |    |     | <b></b>               |     |     |      |     | e                      |     |
| 6    |      |     |      | (acknowledge)            |     |    |     | <b>∉#38;</b>  |       |     |    |     | ∉#70;                 |     |     |      |     | <b></b> ‰#102;         |     |
| 7    |      |     |      | (bell)                   |     |    |     | <b>∉</b> #39; |       |     |    |     | ⊊#71;                 |     |     |      |     | <b></b> <i>∝</i> #103; |     |
| 8    |      | 010 |      | (backspace)              |     |    |     | ⊊#40;         |       |     |    |     | ∉#72;                 |     |     |      |     | «#104;                 |     |
| 9    |      |     |      | (horizontal tab)         |     |    |     | €#41;         | -     |     |    |     | ∉#73;                 |     |     |      |     | ∝#105;                 |     |
| 10   |      | 012 |      | (NL line feed, new line) |     |    |     | *             |       |     |    |     | ¢#74;                 |     |     |      |     | «#106;                 |     |
| 11   |      | 013 |      | (vertical tab)           |     |    |     | ∉#43;         |       |     | _  |     | ∉#75;                 |     |     |      |     | ≪#107;                 |     |
| 12   |      | 014 |      | (NP form feed, new page) |     |    |     | ,             |       |     |    |     | ⊊#76;                 |     |     |      |     | l                      |     |
| 13   |      | 015 |      | (carriage return)        |     |    |     | ∉#45;         |       |     | _  |     | ∉#77;                 |     |     |      |     | m                      |     |
| 14   |      | 016 |      | (shift out)              |     |    |     | .             |       |     |    |     | ⊊#78;                 |     |     |      |     | n                      |     |
| 15   |      | 017 |      | (shift in)               |     |    |     | ¢#47;         | -     |     |    |     | <i>∝</i> #79;         |     |     |      |     | o                      |     |
|      |      |     |      | (data link escape)       |     |    |     | <b>∉</b> #48; |       |     |    |     | <b></b> <i>∉</i> #80; |     |     |      |     | p                      |     |
|      |      |     |      | (device control 1)       |     |    |     | €#49;         |       |     |    |     | ∉#81;                 |     |     |      |     | q                      |     |
| 1    |      |     |      | (device control 2)       |     |    |     | ∉#50;         |       |     |    |     | ∉#82;                 |     |     |      |     | «#114;                 |     |
|      |      |     |      | (device control 3)       |     |    |     | €#51;         |       |     |    |     | <b>∉#83;</b>          |     |     |      |     | s                      |     |
|      |      |     |      | (device control 4)       |     |    |     | ∉#52;         |       |     |    |     | <i>∝</i> #84;         |     |     |      |     | <b>∉#116;</b>          |     |
| -    |      |     |      | (negative acknowledge)   |     |    |     | <b>∉#53;</b>  |       |     |    |     | <b></b> ∉#85;         |     |     |      |     | u                      |     |
| 1    |      |     |      | (synchronous idle)       |     |    |     | ∉#54;         |       |     |    |     | <b>∉#86;</b>          |     |     |      |     | v                      |     |
|      |      |     |      | (end of trans. block)    |     |    |     | <b>∉</b> #55; |       |     |    |     | <i>4</i> #87;         |     |     |      |     | w                      |     |
|      |      |     |      | (cancel)                 |     |    |     | ∉#56;         |       |     |    |     | <b>∉#88;</b>          |     |     |      |     | «#120;                 |     |
| 25 . |      |     |      | (end of medium)          |     |    |     | ⊊#57;         |       |     |    |     | <b></b> ∉#89;         |     |     |      |     | G#121;                 |     |
|      |      |     |      | (substitute)             |     |    |     | <b>∉</b> #58; |       |     |    |     | <b>∉</b> #90;         |     |     |      |     | z                      |     |
|      |      |     |      | (escape)                 |     |    |     | ∉#59;         |       |     |    |     | ⊊#91;                 | -   |     |      |     | ∝#123;                 |     |
| 28 . | 1C ( | 034 | FS   | (file separator)         |     |    |     | <b>€#60;</b>  |       |     |    |     | ⊊#92;                 |     |     |      |     |                        |     |
| 29 . | 1D ( | 035 |      | (group separator)        |     |    |     | ⊊#6l;         |       |     |    |     | ∉#93;                 | -   |     |      |     | ≪#125;                 |     |
| 30 . | 1E ( | 036 |      | (record separator)       |     |    |     | ⊊#62;         |       |     |    |     | ¢#94;                 |     |     |      |     | ~                      |     |
| 31 . | 1F ( | 037 | US   | (unit separator)         | 63  | ЗF | 077 | <b>∉#63;</b>  | ?     | 95  | 5F | 137 | ∉#95;                 |     | 127 | 7F   | 177 |                        | DEL |

Copyright © All Rights Reserved by Yuan-Hao Chang