CSCE 312 Lab manual

Lab 4 - Computer Organization and Data path design

Instructor: Dr. Rabi Mahapatra
TA: Dharanidhar Dang

Prepared by

Dr. Rabi Mahapatra
Suneil Mohan & Amitava Biswas

Fall 2014

Department of Computer Science & Engineering
Texas A&M University
Chapter 5: Computer Organization and Data path design

So far you have learnt about digital system designs that are specialized solutions for specific requirements. But as requirements become more complex, we prefer to have more generic solutions that can be rapidly customized and reused to satisfy diverse kind of requirements. This design paradigm exploits the practice of modularization, standardization and reuse in design to reduce labor and time spent. We can perceive hardware components as the generic components of the solution, and the software components as their customization mechanisms.

Various generic and specialized hardware and software components work with each other to make your computer systems run. Conceptually they are often represented in form of a stack (Fig. 1). Each block or layer is actually an abstraction of the layers below it. This means that a layer at the top depends on the layers below it for its materialization and operation. In this course you are learning about all these components and their operations from bottom to top, starting with logic gates and digital circuits. The later advanced courses will teach you about more complex software layers/components in this stack.

In computer systems, hardware component designs have been standardized in form of specific design patterns. Data paths and control blocks refer to two of such classes of design patterns which have well defined functions. Inside the CPU, microprocessor (µP) is a generic hardware block which integrates a sub-set of the required data path and control block components. The software that runs inside (or on) it is the customization mechanism that allows us to apply microprocessors to solve a large variety of problems. All this together makes a microprocessor based system a generic digital system solution for a very wide variety of design problems. Sometimes by the term CPU we may mean the microprocessor.

As the course proceeds you will gradually learn about all these basic data path and control block components, their role, and how they interact with each other to finally make programs (in machine language representation) actually execute on the hardware components. In later labs and lecture classes you will also get to know how the machine language code, which can actually execute on the hardware, is generated from the “C” source code.

![Fig. 1: Hardware and software stack: A conceptual model of the Computer system components.](image-url)
In this chapter, we focus on designing data path components which sit both outside and inside of the microprocessor chip in a computer system. In the previous labs you have designed IO interface circuitry, address/data/control bus, encoders, decoders, counters, registers, latches, etc. These components sit outside the processor and thus they are generally known as “peripheral components”. In industry we use more advanced vocabulary, where the term peripheral denotes more advanced circuitry and functional blocks such as “DMA controller”, “north/south bridge”, “memory controller”, “programmable interrupt controller (PIC)”, etc. All these systems are composed of basic data path components. It is just that these peripherals evolved to become quite complex themselves, therefore they had to be integrated as chips. For time being we will continue to use the term “peripheral” to actually mean the basic components: IO circuitry, bus, etc.

Arithmetic logic units unit (ALU), which is used for integer computation or the floating point unit (FPU), which is used for floating point numbers, are the key data path components that sit inside the processor. Adders, Subtractors, Dividers, Comparators, Shifters, etc. are some components of the ALU/FPU sub-system. In addition to ALU and FPU, there are other data-path components like Register file, Latches, etc., which sit inside the processor chip. Some basic components like Latches/Registers, Bus, Counters, etc., are often used inside and outside the processor chip. The control circuitry that are present inside the processor chip orchestrates and co-ordinates the operation of the data path. This control circuitry is implemented by sequential logic which you learned in last lab. You will learn more about processor control blocks later.

1. **Learning duration:** 2 weeks. **Required Tools:** Logisim 2.5.x

2. **Group size:** This is a group exercise. Ideal group size should be 2 or 3 people. Solo performance is allowed but it is strongly discouraged. If you must work solo, you must meet with both the professor and your TA and get their approval before starting work.

3. **Objective:** To learn -

   **Primary topics**

   1. Application of finite state machine concept to design sequential circuits to generate complex timing requirements.
   2. A basic design pattern (Von Neumann architecture) for digital systems.
   3. How to design basic IO interface and peripheral circuitry for a microprocessor based digital system.
   4. When and how to use memory components (ROM, RAM) in a circuit.
   5. How to design basic ALU components – adder, subtractor, comparator, shifters.
   6. Role of software as the timing and sequence generation mechanism.
   7. Understanding how software will actually work along with the hardware.
   8. What are the basic design considerations for a microprocessor based system.
Secondary topics

9. How to modularize a design.

10. How to design as a team. This is important because different team members will be concurrently designing different parts of the system which has to finally work together in an efficient manner. This will motivate you to modularize and plan the design, break the design work into several smaller design tasks, and then finally integrate the design to an operational system. This is a key skill for the work place.

4. Instructions:

1. Form your lab group for this lab and course project. You will retain the same group for your project work.

2. Use Logisim to design and validate the circuits.

3. The group should submit a single common lab report, but each member individually should submit an additional 1 page report to explain what their individual role and contribution in the design assignment was and must critique the group design process. The format for that 1 page report is given below. For a single person group the individual report is not required.

Format for the individual 1 pg report:

1) Lab number:

2) Date of submission:

3) Your Name:

4) Group member names:

5) Your role in the assignment:

6) List of the parts of the design that you alone did:

7) List of parts of the design which you did along with other group members:
   (Mention their name against the part of the design.)

8) List of the advantages that you perceived in this team based design assignment:

9) List of the disadvantages of team based design assignment:

10) According to you, which your group member’s design was superior (or how their designed parts can be improved):
5. Exercises to do [There are 3 problems in this lab]

5.1 Problem 1: Your manager at Ford wants you to design a sequential circuit to implement the following requirement for the car’s blinker system - “...There will be row of LEDs at the back of the car, when the left blinker switch is activated, the LEDs will start glowing in sequence from right to left to manifest a running light effect. The right blinker switch will show the running light effect from left to right (opposite direction). There would be 20 LEDs in the back of the car. Each LED should be on for half second....”

Activities to do-
1. Draw the finite state machine representation of the required sequential circuit.
2. Use flip-flops and logic gates to implement the required circuit. The design should have a clearly identifiable data bus. Mention the 74xx chip names that you want to use.
3. Instead of a decoder, use a ROM and re-implement the same circuit.
4. Submit the requisite logisim source files.

Notes:
1. To understand running light effect, see [http://www.youtube.com/watch?v=RaEeeaf4ooM](http://www.youtube.com/watch?v=RaEeeaf4ooM)
2. Build the required sequencer with a counter implemented with flip-flops.

Fig.2: LEDs at the back of the car for the running light effect

Fig.3a: System architecture of the required circuit designed with a decoder
3. To learn about implementing a combinational logic with a ROM, read the section under ROM (Lecture 4), here - http://cs.nyu.edu/~gottlieb/courses/2000-01-fall/arch/class-notes.html

4. Do not use the built-in counter or decoder module provided by Logisim. You may use the built-in adder/subtractor modules if you wish, or you could build the adder/subtractor from basic gates as required by problem-3 first and then re-use them to build your counter. You may use the built-in register module.

5.2 Problem 2: So far you have been implementing various features of the car’s control system with combinational and sequential circuits. But for the next generation of the cars, your manager wants you to implement them all with a single small microprocessor based circuit and software code, instead of using a separate hardware logic circuit for each requirement.

Design rationale: According to him this new design paradigm would cut down the design and manufacturing costs and allow design and manufacturing flexibility. Small microprocessors have become very cheap (a few dollars), its cost is comparable to the small scale integration (SSI) logic gate chips. The requirements for which speed is not critical (faster than nanoseconds) can be implemented with microprocessor based systems. One single microprocessor based circuit will be able to do more control jobs, deliver multiple features and thus obviate multiplicity of logic circuits. The other rationale is that any feature can be added later on by simply reloading a new version of the software long after the hardware has been designed and fitted in. He expects you to gradually design a generic multiprocessor circuit designed around an 8 bit microprocessor.

Operation mechanism: The microprocessor will replace the sequential logic which you would traditionally use to generate complex timing and sequential signals (as in Lab 3 and Lab 4, prob # 1). The timing signals will be generated sequentially as each program statement runs sequentially in the processor. To generate a specific timing sequence you have to design the software code appropriately.

Requirements: In addition to “logical I/O” based control requirements as in Lab 1/Chap 2, Prob # 4 and Lab 3/ Chap 4, Prob# 5, your boss has asked to provision the design for “analog I/O”. Such a hardware design will be able to cater to many advanced control requirements that may come up.
in the near future. For example, an intelligent and energy efficient air conditioning (A/C) system will pose such requirements. In this system, there is a need to read the temperatures inside the car, outside the car, the solar insolation and then turn on/off or operate the A/C compressor motor with different speed levels. The microprocessor based system can read temperature sensors which give output in analog form (0 to 5 V to indicate -30 to +70 deg centigrade). The microprocessor based system can also vary the compressor speed by providing a range of analog signal (0 to 5 V).

Model processor to use: A model 8 bit microprocessor to consider is Intel 8088 compatible processor. For data sheet see– http://www.intersil.com/data/fn/fn2949.pdf. Assume that only lower 8 bits of the address bus will be used.

Activities to do-

1. Implement a unidirectional 8 bit address and control bus, and bidirectional 8 bit data bus, which are suitable for the 8 bit microprocessor (8088) whose data sheet is mentioned.

2. Interface these buses with a ROM and RAM as found in Logisim, verify the combined operation of these busses, ROM and RAM.

3. Design and verify the IO system circuitry (an addressable I/O system) for the required microprocessor based system (see the tips). The design should be modular. At this point of time you don’t have to understand in details how the program will actually execute in side the microprocessor. All you have to understand is what signals the microprocessor has to generate to read from the input interface circuitry and to write to the output interface circuitry as part of the control task. List (known as “bill of materials”) the 74xx chip names that you want to use.

4. Integrate these busses to the designed IO system.

5. Provide brief text description, truth table and signal timing diagram to illustrate the operation of each sub-system or modules in your design.

6. The microprocessor will orchestrate the reading, writing from the digital and analog I/O system and the memory. These reading and writing operations are the tasks that have to be executed in the system. Write down the sequence of operations/tasks in- (see tip #13)

   (I) Pseudo-code. (II) Task timing diagram form

   for the following tasks:

   a) Reading from ROM
   b) Reading from RAM
   c) Writing into RAM
   d) Reading from digital input line
   e) Writing to a digital output line
f) Reading digitized input from an analog line (assume an ADC provides a 8 bit word to the data bus when enabled).

  g) Write a digitized output for generating an analog signal (assume a DAC converts the 8 bit word available on data bus to appropriate analog signal).

7. Transform the pseudo code as designed above to a C code-template. The code should be setup to run in an infinite loop to repeatedly execute these tasks. (See tip # 13). Note: While you write appropriate C language statements, since the hardware does not exist in real life, this code will not be executed on the CS machines. You can model your template similar to the templates we provided for Lab-1.

8. Write a brief paragraph (at least 6 sentences) about both synchronous and asynchronous I/O methods, their advantages and disadvantages.

Important tips:

1. Read Chap 1 of Frank Vahid’s book, section 1.4 (only 1.4.1 & 1.4.2) from Byrant’s book.

2. Refer the materials provided for Lab 1.

3. To understand what is “logical I/O” and “analog I/O”, and their differences, ask your peer teacher or TA.

4. Implement the bidirectional data bus by the tri-state buffers as available in Digital works or by employing MUX blocks. To learn about tri-state logic read the following links –
   http://en.wikipedia.org/wiki/Three-state_logic

5. The following reference system architecture for a microprocessor based system will give you the needed big picture (Fig.4) to give a head start. You have to design all the components except the CPU, AD bus DMUX, ROM and RAM, which are showed in dotted lines. The block arrows indicate the direction of data flow.
6. A reference design for an addressable IO system is given below (Fig 5). Correlate this with the figures given in 8088 CPU data sheet. Only one logical o/p and analog i/p are shown.

Fig. 4: System architecture for a microprocessor based system

Fig. 5: System architecture for addressable IO and 8 bit address space representation
7. To educate yourself about standard design patterns (computer organization), go through the first 4 pgs of this link (slides) [http://icgst.com/cc/Lecture_1_2.pdf](http://icgst.com/cc/Lecture_1_2.pdf).

8. For a quick tutorial on embedded system organization that will give some idea about how software codes and hardware work together, see here (go through all the sub topics list to the right) - [http://www.elec.canterbury.ac.nz/PublicArea/Staff/hof/p10-embed/p10-tutorial/index.html](http://www.elec.canterbury.ac.nz/PublicArea/Staff/hof/p10-embed/p10-tutorial/index.html)


10. The actual analog to digital or digital to analog signal conversion is done by analog to digital (ADC) or digital to analog (DAC) converters, which can be interfaced to the microprocessor through the data, address and control bus. Don’t bother about how to exactly interface ADC or DAC with a microprocessor at this point, just provide the address and data bus. Don’t worry about implementing an ADC or DAC.


13. About relationship between “C” code and timing diagram (using hardware as in Fig. 5) –

Example “C” code fragment for the 8 bit system (code for IO permission are not shown) –
(This reads in a value \(i \) through port 0xFF and prints out \(i+1 \) through 0x0A.)

```
unsigned int i, j;
#define INPORT 0xFF
#define OUTPORT 0x0A
....
for(; ; ) {
   i = inb(INPORT);
   j = i + 1;
   outb(j, OUTPORT);
}
```

Example task sequence in low level pseudo code for the “C” code inside the above loop –

.....
Task 1: Read from an in port which is addressable with address “FF”
Task 2: Write the value to memory address corresponding to “i”
Task 3: Read from memory location “i”
Task 4: Read from memory location “j”
Task 5: Add the values received from location “i” to the value got from “j”
Task 6: Write the added value to location “j”
Task 7: Read from memory location “j”
Task 8: Write the value got from “j” to an out port which is addressable with 0x0A

*Example task timing diagram for first 3 tasks of the pseudo code*

<table>
<thead>
<tr>
<th>Port read</th>
<th>Memory write</th>
<th>Memory read</th>
</tr>
</thead>
</table>

*Fig. 6: Task timing diagram*

*Example digital signal timing diagram for the first task (port read, few signals are shown)*

<table>
<thead>
<tr>
<th>IO/M’</th>
<th>RD’</th>
<th>Don’t care</th>
</tr>
</thead>
<tbody>
<tr>
<td>Address bus</td>
<td>Don’t care</td>
<td></td>
</tr>
<tr>
<td>Data bus</td>
<td>Don’t care</td>
<td></td>
</tr>
</tbody>
</table>

*Fig. 7: Signal timing diagram*

14. **Additional reading materials:**

For the big picture:
http://www.ece.eps.hw.ac.uk/Modules/B35dq1/slides/introduction/ppframe.htm
http://www.ece.eps.hw.ac.uk/Modules/B35dq1/slides/Review/

To understand how a program actually gets executed inside the microprocessor:
5.3 Problem 3: Activities to do-

Design and verify the following components. Each component should be able to handle 8-bit inputs. (Use basic logic gates for the design. You may use the built in modules for registers, and mux/demux)

i. Adder.

ii. Subtractor (2’s compliment)

iii. Magnitude comparator.

iv. Left and right - barrel shifter. (A barrel shifter shifts multiple bits at a time)

as discussed in Frank Vahid’s book in Chap 4. These blocks should be designed in way so that they can read data from two (or one) separate 8 bit latched input data buses, and write to a third (or second) latched output data bus. The idea is that you would reuse these designs to implement a small simple microprocessor in future.

Additional material: www-inst.eecs.berkeley.edu/~cs150/fa00/Lectures/04-CombEx.ppt