EE 231 Fall 2014

#### EE 231 Lab 8

# Registers

In this lab we are going to investigate and build several sequential circuits. The behavior of sequential systems depends not only on the current values of the input variables, but also on the sequence of input values that occurred in the past. Such systems have some kind of storage of memory elements. In this lab we are going to design a couple types of registers.

#### 1. Prelab

- 1.1. Design an eight-bit synchronous latch in Verilog.
- 1.2. Design an eight-bit PC register in Verilog.
- 1.3. Write a program which uses the above two designs as functions to test that they function properly.

### 2. Lab

# 2.1. Objective

2.1.1. You will implement five different 8-bit registers: PC (Program Counter), MAR (Memory Addressing Register), OUT (Output), ACCA (Accumulator A), and INST (Instruction Register). In addition, you will design two single one-bit registers: C and Z. What simple circuit elements are C and Z?

### 2.2. Information

- 2.2.1. MAR, OUT, ACCA, and INST are all 8-bit registers with synchronous parallel load. These registers all have a clock input, an 8-bit data input, and an active low load/enable input, as well as an 8-bit output.
  - When MAR\_L (Memory Addressing Register Load) is VCC the MAR register is not enables. When MAR\_L goes low the MAR register is enabled. Then on the next clock pulse the 8-bit data on the input line is loaded into the MAR register.
- 2.2.2. The PC is an 8-bit register with synchronous parallel load capability, synchronous count, and an asynchronous reset. The PC has a clock input, an 8-bit data input, and 3 additional inputs: PC\_L, PC\_I, and RESET. These three inputs are all active low. PC\_L loads the program counter, PC\_I increments the program counter by 1, and RESET resets the program counter to 0.
- 2.2.3. Implement these registers (synchronous load and synchronous load/count) as Altera functions in Verilog. Include each on in a higher-level design file. Use a DIP switch for the input data, and switches on the evaluation board for LOAD, INC, and

EE 231 Fall 2014

CLOCK. Verify that the load function works correctly for the parallel load register, and that the load and increment functions work correctly for the load/increment register.

# 3. Supplementary Material

## 3.1. Registers

In this lab we will investigate two types of registers.

# 3.1.1. Simple Latch

One type of register is a simple latch as shown in Figure 1. When LOAD is high, the output data D\_OUT will not change. When LOAD is low, the input data D\_IN should be latched into the register on the rising edge of CLOCK.



Figure 1: Register Using Simple Latch

# 3.1.2. Program Counter

The second type of register is called a program counter (PC). This keeps track of which instruction in memory to execute. Usually programs are executed sequentially, so after executing the instruction at address 0x0123, the program will then execute the instruction at address 0x0124. In this case, the PC needs to increment after each instruction is executed. Sometimes the program needs to execute code in a different area of memory – flow control statements such as *for* and *while* do this. In this case, the PC needs to be loaded with a new address. In order for the program to start, you will need to reset the program counter to zero to start execution at the first instruction of the program.



**Figure 2:** PC Register

EE 231 Fall 2014

Normally, INCREMENT, LOAD, and RESET will be high. When INCREMENT is low, the PC should increment D\_OUT to D\_OUT + 1 on the rising edge of CLOCK. When LOAD is low, the input data D\_IN should be latched into the register on the rising edge of CLOCK. The system, which controls PC, will ensure that LOAD and INCREMENT are never low at the same time (in your program, you should have PC do something sensible, like latch D\_IN, if both happen to be low simultaneously). When RESET is low, PC should immediately reset to 0x00; it shouldn't wait for a clock edge. This is normally called an asynchronous counter with synchronous load and asynchronous reset.