# CPE300: Digital System Architecture and Design

Fall 2011 MW 17:30-18:45 CBC C316

Control, Reset, Exceptions 10312011

#### Outline

- Review Datapath/Control
- 2- and 3-Bus SRC Processor Design
- Machine Reset
- Machine Exceptions

## Register Transfer Descriptions

- Abstract RTN
  - Defines "what" not the "how" (Chapter 2)
    - Overall effect of instructions on programmer-visible registers
  - Implementation independent
    - Registers and operations
- Concrete RTN
  - Detailed register transfer steps in datapath to produce overall effect
    - Dependent on implementation details
  - Steps correspond to processor clock pulses

#### 1-Bus SRC Microarchitecture

- 5 classic components of computer
  - Memory, Input, Output
  - CPU Control and Datapath



## More Complete View of 1-Bus SRC Design

Add control signals and gate-level logic



## Control Sequences

- Register transfers are the concrete RTN
- Control sequence are the control signals that cause the RT

| Step | Concrete RTN          | Control Sequence                                             |
|------|-----------------------|--------------------------------------------------------------|
| TO   | MA←PC: C←PC+4;        | PC <sub>out</sub> , MA <sub>in</sub> , Inc4, C <sub>in</sub> |
| T1   | MD←M[MA]: PC←C        | Read, C <sub>out</sub> , PC <sub>in</sub> , Wait             |
| T2   | IR←MD                 | MD <sub>out</sub> , IR <sub>in</sub>                         |
| Т3   | instruction_execution |                                                              |

Wait prevents control sequence from advancing to step T2 until memory asserts Done

### Control Steps, Control Signals, and Timing

- Order control signals are written is irrelevant for a given time step
  - Step To:
    - (Inc4,  $C_{in}$ ,  $PC_{out}$ ,  $MA_{in}$ ) = ( $PC_{out}$ ,  $MA_{in}$ , Inc4,  $C_{in}$ )
- Timing distinction is made between gates and strobes
  - Gates early, strobes late in clock cycle
- Memory read should start as early as possible to reduce wait time
- MA must have correct value before being used for a read

# Clocking the Datapath

- Register transfers result from information processing
  - Register transfer timing –
     register to register
- Level sensitive latch flipflops in example
- t<sub>R2valid</sub> is the period from begin of gate signal till inputs at R2 are valid
- t<sub>comb</sub> is delay through combinational logic, such as ALU or cond logic



## Signal Timing on the Datapath

- Several delays occur in getting data from R1 to R2
  - Gate delay through the 3-state bus driver—t<sub>g</sub>
  - Worst case propagation delay on bus—t<sub>bp</sub>
  - Delay through any logic, such as ALU—t<sub>comb</sub>
  - Set up time for data to affect state of R2—t<sub>su</sub>
- Data can be strobed into R2 after this time

$$t_{R2valid} = t_g + t_{bp} + t_{comb} + t_{su}$$

- Diagram shows strobe signal in the form for a latch. It must be high for a minimum time—t<sub>w</sub>
- There is a hold time, t<sub>h</sub>, for data after strobe ends

#### Signal Timing and Minimum Clock Cycle

A total latch propagation delay is the sum

$$T_l = t_{su} + t_w + t_h$$

- All above times are specified for latch
- t<sub>h</sub> may be very small or zero
- The minimum clock period is determined by finding longest path from flip-flop output to flipflop input
  - This is usually a path through the ALU
  - Conditional signals add a little gate delay
  - Minimum clock period is

$$t_{\min} = t_{g} + t_{bp} + t_{comb} + t_{l}$$

## Consequences of Flip-Flop Type

- Flip-flop types (Appendix A.12)
  - Level-triggered (latch) state can change while clock is high
  - Edge-triggered state changes only on a clock transition (high-to-low or low-to-high)
  - Master-slave breaks feedback from output/input of register allowing on a single state change per clock cycle
- During the high part of a strobe a latch changes its output
  - If this output can affect its input, an error can occur (feeback)
- This can influence even the kind of concrete RTs that can be written for a data path
- If the C register is implemented with latches, then  $C \leftarrow C + MD$ ; is not legal
- If the C register is implemented with master-slave or edge triggered flip-flops, it is OK

### The Control Unit

- Brain of a machine
- Datapath implementation led to control sequences to implement instructions
- Control unit will generate the control sequences
  - Logic to enable control signal
  - Timing of signals
- The control unit's job is to generate the control signals in the proper sequence
- Things the control signals depend on
  - The time step Ti
  - The instruction op code (for steps other than To, T1, T2)
  - Some few datapath signals like CON, n=0, etc.
  - Some external signals: reset, interrupt, etc. (to be covered)
- The components of the control unit are: a time state generator, instruction decoder, and combinational logic to generate control signals

#### Detailed Control Unit



## Control Signal Encoder Logic

- Write equation describing control signal
  - Find all occurrences of control signal in entire set of control sequences
  - Equation implemented by digital logic gates

| Step | Fetch Control Sequence                                       | Step | ADD Control Sequence                          | Step       | ADDI Control Sequence                         |
|------|--------------------------------------------------------------|------|-----------------------------------------------|------------|-----------------------------------------------|
| TO   | PC <sub>out</sub> , MA <sub>in</sub> , Inc4, C <sub>in</sub> | Т3   | Grb, R <sub>out</sub> , A <sub>in</sub>       | Т3         | Grb, R <sub>out</sub> , A <sub>in</sub>       |
| Т1   | Read, C <sub>out</sub> , PC <sub>in</sub> , Wait             | Т4   | Grc, R <sub>out</sub> , ADD, C <sub>in</sub>  | Т4         | c2 <sub>out</sub> , ADD, C <sub>in</sub>      |
| Т2   | MD <sub>out</sub> , IR <sub>in</sub>                         | T5   | C <sub>out</sub> , Gra, R <sub>in</sub> , End | <b>T</b> 5 | C <sub>out</sub> , Gra, R <sub>in</sub> , End |

Cout, Gra, Rin, End

| Step | SHR Control Sequence                                      | Step | ST Control Sequence                              | Step | <b>BR Control Sequence</b>                |
|------|-----------------------------------------------------------|------|--------------------------------------------------|------|-------------------------------------------|
| Т3   | clout, Ld                                                 | Т3   | Grb, BA <sub>out</sub> , A <sub>in</sub>         | Т3   | Grc, R <sub>out</sub> , CON <sub>in</sub> |
| Т4   | $n=0 \rightarrow (Grc, R_{out}, Ld)$                      | T4   | c2 <sub>out</sub> , ADD, C <sub>in</sub>         | Т4   | Grb, R <sub>out</sub> ,                   |
| Т5   | Grb, R <sub>out</sub> , C=B, C <sub>in</sub>              | T5   | C <sub>out</sub> , MA <sub>in</sub>              |      | CON→PC <sub>in</sub> , End                |
| Т6   | $n\neq 0 \rightarrow (C_{out}, SHR, C_{in}, Decr, Goto6)$ | T6   | Gra, R <sub>out</sub> , MD <sub>in</sub> , Write |      |                                           |
|      |                                                           |      |                                                  |      |                                           |

Wait, End

## Control Signal Examples

| Step | Fetch Control Sequence                                       | Step | ADD Control Sequence                          | Step | ADDI Control Sequence                         |
|------|--------------------------------------------------------------|------|-----------------------------------------------|------|-----------------------------------------------|
| ΤO   | PC <sub>out</sub> , MA <sub>in</sub> , Inc4, C <sub>in</sub> | Т3   | Grb, R <sub>out</sub> , A <sub>in</sub>       | Т3   | Grb, R <sub>out</sub> , A <sub>in</sub>       |
| Т1   | Read, C <sub>out</sub> , PC <sub>in</sub> , Wait             | Т4   | Grc, R <sub>out</sub> , ADD, C <sub>in</sub>  | Т4   | c2 <sub>out</sub> , ADD, C <sub>in</sub>      |
| Т2   | MD <sub>out</sub> , IR <sub>in</sub>                         | Т5   | C <sub>out</sub> , Gra, R <sub>in</sub> , End | Т5   | C <sub>out</sub> , Gra, R <sub>in</sub> , End |

| Step | SHR Control Sequence                                      | Step | ST Control Sequence                              | Step | <b>BR Control Sequence</b>                |
|------|-----------------------------------------------------------|------|--------------------------------------------------|------|-------------------------------------------|
| Т3   | clout, Ld                                                 | Т3   | Grb, BA <sub>out</sub> , A <sub>in</sub>         | Т3   | Grc, R <sub>out</sub> , CON <sub>in</sub> |
| Т4   | $n=0 \rightarrow (Grc, R_{out}, Ld)$                      | Т4   | c2 <sub>out</sub> , ADD, C <sub>in</sub>         | Т4   | Grb, R <sub>out</sub> ,                   |
| Т5   | Grb, R <sub>out</sub> , C=B, C <sub>in</sub>              | Т5   | C <sub>out</sub> , MA <sub>in</sub>              |      | CON→PC <sub>in</sub> , End                |
| Т6   | $n\neq 0 \rightarrow (C_{out}, SHR, C_{in}, Decr, Goto6)$ | Т6   | Gra, R <sub>out</sub> , MD <sub>in</sub> , Write |      |                                           |
| Т7   | C <sub>out</sub> , Gra, R <sub>in</sub> , End             | Т7   | Wait, End                                        |      |                                           |

• Gra = 
$$T5 \cdot (add + addi) + T6 \cdot st + T7 \cdot shr + ...$$

#### Use of datapath conditions

• Grc = 
$$T4 \cdot add + T4 \cdot (n=0) \cdot shr + ...$$



## Branching in the Control Unit



- Tri-state gates allow 6 to be applied to counter input
- Reset will synchronously reset counter to step To
- Mck is the master clock oscillator signal

Copyright @ 2004 Pearson Prentice Hall, Inc.

# Clocking Logic

- Generates Run signal
- Generate synchronized done signal SDone
- Generates R, W from Read, Write control
- Generates Enable which controls counter



## Completed 1-Bus Design

- High level architecture block diagram
- Concrete RTN steps
- Hardware design of registers and data path logic
- Revision of concrete RTN steps where needed
- Control sequences
- Register clocking decisions
- Logic equations for control signals
- Time step generator design
- Clock run, stop, and synchronization logic

## Alternate Architectural Design

- Require different RTN than 1-bus design
- More datapaths allow more things to be done in a single step
- 2-bus example that separates input and output of ALU on different buses
  - C register can be eliminated
  - Control steps can be reduced by strobing ALU results directly into their destinations

#### 2-Bus SRC Microarchitecture



- A bus carries data going into registers
- B bus carries data being gated out of registers
- ALU function C=B is used for all simple register transfers
  - $\blacksquare$  R[a]  $\leftarrow$  R[b]
- Allows increment transfers
  - $R[n] \leftarrow R[m] + 1$

#### 2-Bus Control for ADD Instruction

• add(:=op=12) $\rightarrow$ R[ra] $\leftarrow$ R[rb]+R[rc]:

| Step | Concrete RTN      | Control Sequence                                        |
|------|-------------------|---------------------------------------------------------|
| TO   | MA←PC;            | PC <sub>out</sub> , C=B, MA <sub>in</sub> ,             |
| T1   | MD←M[MA]: PC←PC+4 | Read, Wait, PC <sub>out</sub> , INC4, PC <sub>in</sub>  |
| Т2   | IR←MD;            | MD <sub>out</sub> , C=B, IR <sub>in</sub>               |
| Т3   | A←R[rb]           | Grb, R <sub>out</sub> , C=B, A <sub>in</sub>            |
| Т4   | R[ra]=A+R[rc];    | Grc, R <sub>out</sub> , ADD, Sra, R <sub>in</sub> , End |

- Note the appearance of Grc to gate the output of the register rc onto the B bus and Sra to select ra to receive data strobed from the A bus
- Two register select decoders will be needed
- Transparent latches will be required for MA at step To

#### 2-Bus Performance

- Speedup =  $\frac{T_1}{T_2}$
- $T_i$  = execution time =  $IC \times CPI \times \tau$ 
  - *i* is 1- or 2-bus
- Assumptions
  - *IC* and *t* don't change in going from 1 bus to 2 buses
  - *CPI* goes from 8 to 7 clocks (naïve assumption)
- Speedup =  $\frac{T_1}{T_2} = \frac{IC \times 8 \times \tau}{IC \times 7 \times \tau} = \frac{8}{7} = 1.143 = 14.3\%$
- What happens if clock also changes?

## 3-Bus Design

- A 3-bus architecture allows both operand inputs and the output of the ALU to be connected to buses
  - Shortens control sequences even further than 2bus design
- Both the C output register and the A input register are eliminated
- Careful connection of register inputs and outputs can allow multiple RTs in a step

### 3-Bus SRC Microarchitecture



- A-bus is ALU operand 1
- B-bus is ALU operand 2
- C-bus is ALU output
- Note MA input connected to the B-bus
- Allows operations such as
   R[n] ←R[m]+R[k] to
   complete in one cycle.
- What are cost implications?

#### 3-Bus Control for ADD Instruction

• add(:=op=12) $\rightarrow$ R[ra] $\leftarrow$ R[rb]+R[rc]:

| Step | <b>Concrete RTN</b>             | Control Sequence                                                                    |
|------|---------------------------------|-------------------------------------------------------------------------------------|
| ΤO   | MA ← PC: MD ← M [MA]: PC ← PC+4 | PC <sub>out</sub> , MAB <sub>in</sub> , INC4, PC <sub>in</sub> , Read<br>Wait       |
| T1   | IR←MD;                          | MD <sub>out</sub> , C=B, Ir <sub>in</sub>                                           |
| Т2   | R[ra]=R[rb]+R[rc];              | GArc, RA <sub>out</sub> , GBrb, RB <sub>out</sub> , ADD, Sra, R <sub>in</sub> , End |

- Note the use of 3 register selection signals in step T2: GArc, GBrb, and Sra
- In step To, PC moves to MA over bus B and goes through the ALU Inc4 operation to reach PC again by way of bus C
  - PC must be edge triggered or master-slave
- Once more MA must be a transparent latch

#### 3-Bus Performance

- Speedup =  $\frac{T_1}{T_3}$
- $T_i$  = execution time =  $IC \times CPI \times \tau$ 
  - *i* is 1- or 2-bus
- Assumptions
  - *IC* and *t* don't change in going from 1 bus to 3 buses
  - *CPI* goes from 8 to 4 clocks (naïve assumption)
  - $\tau$  increases by 10%
- Speedup =  $\frac{T_1}{T_3} = \frac{IC \times 8 \times \tau}{IC \times 4 \times 1.1 \tau} = \frac{8}{4.4} = 1.818 = 81.8\%$

### Machine Reset

- Reset sets program counter to a fixed value
  - May be a hardwired value
  - Contents of a memory cell whose address is hardwired
- The control step counter is reset
- Pending exceptions are prevented, so initialization code is not interrupted
- It may set condition codes (if any) to known state
- It may clear some processor state registers
- A "soft" reset makes minimal changes
  - PC, T (T-step counter)
- A "hard" reset initializes more processor state

## SRC Reset Capability

- Both hard and soft reset specified
- Strt signal will do a hard reset
  - Effective only when machine is stopped
  - Resets the PC to zero
  - Resets all 32 general registers to zero
- Soft Rst signal is effective when the machine is running
  - Resets PC to zero
  - Restarts instruction fetch
  - Clears the Reset signal
- Actions on reset are described in instruction interpretation

#### Abstract RTN for SRC Reset and Start

#### Processor State

```
Strt
```

Rst

```
;start signal
;external reset signal
```

```
• instruction_interpretation := (
  ¬Run∧Strt→(Run←1: PC, R[0..31]←0);
Run∧¬Rst→(IR←M[PC]: PC←PC+4; instruction_execution):
Run∧Rst→(Rst←0: PC←0); instruction interpretation):
```

#### Resets in the Middle of Instruction Execution

- The abstract RTN implies that reset takes effect after the current instruction is done
- To describe reset during an instruction, we must go from abstract to concrete RTN
- Why might we want to reset in the middle of an instruction?
  - Long instructions
- How would we reset in the middle of an instruction?
  - Check for Rst at each control time step

#### Concrete RTN and Control with Reset

| Step | Concrete RTN                                                                                                                             | Control Sequence                                                                                    |
|------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| TO   | $\neg Rst \rightarrow (MA \leftarrow PC: C \leftarrow PC+4):$<br>$Rst \rightarrow (Rst \leftarrow 0: PC \leftarrow 0: T \leftarrow 0);$  | $\neg Rst \rightarrow (PC_{out}, MA_{in}, Inc4, C_{in})$<br>Rst $\rightarrow (ClrPC, ClrR, Goto0);$ |
| T1   | $\neg Rst \rightarrow (MD \leftarrow M[MA]: PC \leftarrow C):$<br>$Rst \rightarrow (Rst \leftarrow 0: PC \leftarrow 0: T \leftarrow 0);$ | $\neg Rst \rightarrow (Read, C_{out}, PC_{in}, Wait)$<br>Rst $\rightarrow (ClrPC, ClrR, Goto0);$    |
| Т2   | $\neg Rst \rightarrow (IR \leftarrow MD):$<br>$Rst \rightarrow (Rst \leftarrow 0:PC \leftarrow 0: T \leftarrow 0);$                      | $\neg Rst \rightarrow (MD_{out}, IR_{in})$<br>Rst $\rightarrow (ClrPC, ClrR, Goto0);$               |
| Т3   | $\neg Rst \rightarrow (A \leftarrow R[rb]):$<br>$Rst \rightarrow (Rst \leftarrow 0:PC \leftarrow 0: T \leftarrow 0);$                    | $\neg Rst \rightarrow (Grb, R_{out}, A_{in})$<br>Rst $\rightarrow (ClrPC, ClrR, Goto0);$            |
| Т4   | $\neg Rst \rightarrow (C \leftarrow A + R[rc]):$<br>$Rst \rightarrow (Rst \leftarrow 0:PC \leftarrow 0: T \leftarrow 0);$                | $\neg Rst \rightarrow (Grc, R_{out}, ADD, C_{in})$<br>Rst $\rightarrow (ClrPC, ClrR, Goto0);$       |
| T5   | $\neg Rst \rightarrow (R[ra] \leftarrow C)$ :<br>Rst $\rightarrow (Rst \leftarrow 0: PC \leftarrow 0: T \leftarrow 0)$ ;                 | $\neg Rst \rightarrow (C_{out}, Gra, R_{in}, End)$<br>Rst $\rightarrow (ClrPC, ClrR, Goto0);$       |

- Same RTN/control as before but must check Rst
  - Reset actions are the same for every step of every instruction → control signals are independent of time step or opcode
- ClrPC clears the program counter to all zeros
- ClrR clears the one bit Reset flip-flop

## Machine Exceptions

- An exception is an event that causes a change in the program specified flow of control
  - Internal are usually synchronous (overflow)
  - External often asynchronous (keyboard)
- Often called interrupts
  - Normal program execution is interrupted
- No standard naming conventions
  - Exception for general term
  - Interrupt for an exception caused by an external event, such as an I/O device condition

#### Hardware/Software Exception Response

- The system must control the type of exceptions it will process at any given time
- The state of the running program is saved when an allowed exception occurs
- Control is transferred to the correct software routine, or "handler" for this exception
- This exception, and others of less or equal importance are disallowed during the handler
- The state of the interrupted program is restored at the end of execution of the handler

## Hardware Support of Exceptions

- To determine relative importance, a priority number is associated with every exception
- Hardware must save and change the PC
  - Required for program execution
- Hardware must disable the current exception
  - Could interrupt the handler before it can start
- Address of the handler is called the exception vector and is a hardware function of the exception type
- Exceptions must access a save area for PC and other hardware saved items
  - Choices are special registers or a hardware stack

## Instruction Support of Exceptions

- An instruction executed at the end of the handler must reverse the state changes done by hardware when the exception occurred
- There must be instructions to control what exceptions are allowed
  - The simplest of these enable or disable all exceptions
- If processor state is stored in special registers on an exception, instructions are needed to save and restore these registers

## Types of Exceptions

- System reset
- Exceptions associated with memory access
  - Machine check memory failure
  - Data access memory not available
  - Instruction access instruction not available (similar to data access)
  - Alignment improperly aligned access
- Program exceptions
  - Illegal instruction instruction not in IS
  - Unimplemented instruction legal but not in IS
  - Privileged instructions instruction not available
  - Arithmetic errors
- Miscellaneous hardware exceptions (e.g. watchdog)
- Trace and debugging exceptions
- Non-maskable exceptions (NMI) very bad cases
- External exceptions—interrupts

## SRC Exception Processing

- The exception mechanism for SRC handles external interrupts
- There are no priorities
  - Only a simple enable and disable mechanism
- The PC and information about the source of the interrupt are stored in special registers
  - Any other state saving is done by software
- The interrupt source supplies 8 bits that are used to generate the interrupt vector
- It also supplies a 16 bit code carrying information about the cause of the interrupt

## SRC Interrupt Processor State

Processor interrupt mechanism

```
From Dev. →. ireq:
                                          ;interrupt request signal
To Dev. \rightarrow iack:
                                          interrupt acknowledge signal
Internal \rightarrow \cdot TE:
                                          one bit interrupt enable flag
to CPU \rightarrow IPC<31..0>:
                                          ;storage for PC saved upon interrupt
                                          ;info. on source of last interrupt
to CPU \rightarrow II<15...0>:
From Dev. → · Isrc_info<15..0>:
                                          ;information from interrupt source
From Dev → · Isrc_vect<7..0>:
                                          ;type code from interrupt source
            • Ivect<31..0>:= 20@0#Isrc_vect<7..0>#4@0:
Internal
```

| Bits       | 31 | 12 11         | 4 | 3    | 0 |
|------------|----|---------------|---|------|---|
| Ivect<310> | 0  | Isrc_vect<70> |   | 0000 | ) |

#### SRC Instruction Interpretation with Interrupts

- If interrupts are enabled, PC and interrupt info. are stored in IPC and II, respectively
  - With multiple requests, external priority circuit (discussed in later chapter) determines which vector & info. are returned
- Interrupts are disabled
- The acknowledge signal is pulsed

## SRC Instruction to Support Interrupts

- Return from interrupt
  - rfi(:=op=29) → (PC←IPC: IE←1):
  - Two RT actions must occur together
    - Cannot be accomplished with branch and ee instruction combination
- Save and restore interrupt state

```
svi(:=op=16) \rightarrow (R[ra]<15..0>\leftarrowII<15..0>: R[rb] \leftarrowIPC<31..0>);
rvi(:=op=17) \rightarrow (II<15..0>\leftarrow R[ra]<15..0> : IPC<31..0>\leftarrow R[rb]):
```

Enable/disable interrupt system

```
een (:=op=10) \rightarrow (IE \leftarrow 1)
edn (:=op=11) \rightarrow (IE \leftarrow 0)
```

#### Concrete RTN with Interrupt

| Ston            | Concrete RTN                |                                                                                                          |  |  |  |
|-----------------|-----------------------------|----------------------------------------------------------------------------------------------------------|--|--|--|
| Step ¬(ireq∧IE) |                             | (ireq∧IE)                                                                                                |  |  |  |
| TO              | ¬(ireq∧IE)→(MA←PC: C←PC+4): | <pre>(ireq∧IE) → (IPC←PC: II←Isrc_info: IE←0: PC←20@#Isrc_vect&lt;70&gt;#00: iack←1; iack←0; End);</pre> |  |  |  |
| Т1              | MD←M[MA]: PC←C;             |                                                                                                          |  |  |  |
| Т2              | IR←MD;                      |                                                                                                          |  |  |  |
| Т3              | instruction_execution       |                                                                                                          |  |  |  |

- PC could be transferred to IPC over the bus
- II and IPC probably have separate inputs for the externally supplied values
- Iack is pulsed, described as ←1; ←0, which is easier as a control signal than in RTN

#### **Exceptions During Instruction Execution**

- Some exceptions occur in the middle of instructions
  - Some CISCs have very long instructions (string move)
  - Some exception conditions prevent instruction completion (uninstalled memory)
- CPU must make special provision for restarting
  - Partially completed actions must be reversed so the instruction can be re-executed after exception handling
  - Information about the internal CPU state must be saved so that the instruction can resume where it left off
- We will see that this problem is acute with pipeline designs—always in middle of instructions.

## Recap of Design Process

Informal description Formal RTN description Block diagram architecture Concrete RTN steps Hardware design of blocks Control sequences Control unit and timing



## Chapter 4 Summary

- Chapter 4 has done a non pipelined data path, and a hardwired controller design for SRC
- The concepts of data path block diagrams, concrete RTN, control sequences, control logic equations, step counter control, and clocking have been introduced
- The effect of different data path architectures on the concrete RTN was briefly explored
- We have begun to make simple, quantitative estimates of the impact of hardware design on performance
- Hard and soft resets were designed
- A simple exception mechanism was supplied for SRC