ch01 An Introduction To Digital Computer Logic

Download as pdf or txt
Download as pdf or txt
You are on page 1of 12

sc01.

qxd

11/23/2002

12:11 PM

Page 648

SUPPLEMENTARY CHAPTER 1

AN INTRODUCTION TO DIGITAL COMPUTER LOGIC

J Q

K Q Q Q

FREE O C MPUTER C H IP S

FR CHOC EE OLA CHIPS TE

I keep telling you Gwendolyth, youll never attract todays kids that way.

sc01.qxd

11/23/2002

12:11 PM

Page 649

S1.0 INTRODUCTION
Many students are curious about the inner workings of the computer. Although understanding the computers circuitry is not essential to working with computers, doing so is satisfying, for it reduces the mystery of computers; it also eliminates any idea that the computer is a magical box to be feared and respected. Instead, you get to see that the computer is actually nothing more than a rather simple collection of digital switchesmore like a toy for adults to play with! Computers are built up from integrated circuits. Each integrated circuit in a computer serves a specialized purpose within the computer. For example, there is an integrated circuit that represents the CPU, another that provides an interface to the external bus, another that manages memory, another that manages DMA (see Chapter 9), and so forth. The integrated circuits themselves are made up of transistors, resistors, capacitors, and other electronic components that are combined into circuits. The primary component of interest to us is the transistor. A single integrated circuit may have thousands, or even millions of transistors. The CPU chip in the Motorola MPC 7400 PowerPC module, shown in Figure S1.1, contains approximately 6.5 million transistors in an area of less than 1/2 square inch. Transistors can act as amplifiers or switches. The transistors in your television set and stereo are used mostly as amplifiers. Except for a few specialized devices such as modems, virtually all the circuitry in computers is digital in nature: the ON and OFF positions of transistor switches serve to represent the 1s and 0s of binary digital circuits. In the computer, these transistor switches are combined to form logic gates, which represent values in Boolean algebra. Boolean algebra is the basis for computer logic design and transistors the means for implementation. Digital circuits are used to perform arithmetic, to control the movement of data within the computer, to compare values for decision making, and to accomplish many other functions. The digital logic that performs these functions is called combinatorial logic. Combinatorial logic is logic in which the results of an operation depend only on the present inputs to the operation. For the same set of inputs, combinatorial logic will always yield the same result. As an example, arithmetic operations are combinatorial. For a given set of inputs and the add operation, the resulting sum will always be the same, regardless of any previous operations that were performed. Digital circuits can also be used to perform operations that depend on both the inputs to the operation and the result of the previous operation. Digital circuits can store the result or state of an operation and use that result as a factor the next time the operation is performed. Each time the operation is performed, the result will be a function of the present inputs and the previous state of the circuit. Digital logic that is dependent on the previous state of an operation is called sequential logic. An example of sequential logic is a counter. Each time the counter operation is performed, the

649

sc01.qxd

11/23/2002

12:11 PM

Page 650

650

SUPPLEMENTS

FIGURE S1.1
The Motorola MPC 7400 PowerPC CPU

result is the sum of the previous result plus the counting factor. The counter continues to hold the statein this case, the current countfor use the next time the operation is performed. Computers incorporate both combinatorial and sequential logic.

S1.1 BOOLEAN ALGEBRA


The digital computer is based on Boolean algebra. Boolean algebra describes rules that govern constants and variables that can take on two values. These can be represented in many different ways: true or false, on or off, yes or no, 1 or 0, light or dark, water valve open or shut, to indicate a few possible representations. (Yes, there have been attempts to build hydraulic water-based computers!) The rules that govern the ways in which Boolean constants and variables are combined are called Boolean logic. There are a number of logical rules, but these can all be derived from three fundamental operations, the operations of AND, OR, and NOT. Boolean logic rules can be described as a formula, or by a truth table, which specifies the result for all possible combinations of inputs. Truth tables are the Boolean equivalent to additions and multiplication tables in arithmetic.

sc01.qxd

11/23/2002

12:11 PM

Page 651

SUPPLEMENTARY CHAPTER 1

AN INTRODUCTION TO DIGITAL COMPUTER LOGIC

651

The Boolean AND operation can be stated as follows: The result of an AND operation is TRUE if and only if both (or all, if there are more than two) input operands are TRUE. This is shown in the truth table in Figure S1.2. Arbitrarily, we have assigned the value 0 to FALSE and the value 1 to TRUE. This is a normal way of describing Boolean algebra. If you prefer, you could use the value GREEN for true and RED for false, and note that the AND operation says that you can only go if both lights are green. The Boolean symbol for the AND operation is a center dot: (). The Boolean equation
C = A B

states that the Boolean variable C is true if and only if both A and B are true. The Boolean or operation, or more accurately, INCLUSIVE-OR, is stated as follows. The result of an INCLUSIVE-OR operation is TRUE if the values of any (one or more) of the input operands are true. The truth table for the INCLUSIVE-OR operation is shown in Figure S1.3. The Boolean symbol for the OR operation is a plus sign (+). Therefore,
C = A + B

states that C is true if either A or B or both are true. The Boolean NOT operation states that the result is TRUE if and only if the single input operand is FALSE. Thus, the state of the result of a NOT operation is always the opposite state from the input operand. Figure S1.4 shows the truth table for the not operation. The symbol for the not operation is a bar over the symbol:
C = A

There is a fourth operation, the EXCLUSIVE-OR. The truth table for the EXCLUSIVE-OR operation is shown in Figure S1.5. The symbol for the EXCLUSIVE-OR operation is a plus sign within a circle:
C = A B

The EXCLUSIVE-OR operation is used less frequently than the others. It can be derived from the INCLUSIVE-OR, AND, and NOT operations as follows: the result of the EXCLUSIVE-OR operation is TRUE if either A or B is TRUE, but not both. Two ways to express this equivalence are
A B = (A + B) (A B)

which can be read A or B and not both A and B, or alternatively FIGURE S1.2
Truth Table for AND Operation A 0 0 1 1 B 0 1 0 1 C 0 0 0 1

FIGURE S1.3
Truth Table for INCLUSIVE OR Operation A 0 0 1 1 B 0 1 0 1 C 0 1 1 1

FIGURE S1.4
Truth Table for NOT Operation A 0 1 C 1 0

FIGURE S1.5
Truth Table for EXCLUSIVE OR Operation A 0 0 1 1 B 0 1 0 1 C 0 1 1 0

sc01.qxd

11/23/2002

12:11 PM

Page 652

652

SUPPLEMENTS

A B = (A B) + (B A)

which reads either A and not B or B and not A. It is useful to study this example for practice in the manipulation and reasoning of Boolean algebra. There are a number of useful laws and identities that help to manipulate Boolean equations. Boolean algebra operations are associative, distributive, and commutative, which means that
A + (B + C) = (A + B) + C A (B + C) = A B + A C A + B = B + A (associative) (distributive) (commutative)

These laws are valid for INCLUSIVE-OR, AND, and EXCLUSIVE-OR operations. Perhaps most useful are a pair of theorems called DeMorgans theorems, which state the following:
A + B = A B and A B = A + B

These laws and theorems are important because it is frequently necessary or convenient to modify the form of an Boolean equation to make it simpler to understand or to implement.

S1.2 GATES AND COMBINATORIAL LOGIC


Many functions in a computer are defined in terms of their Boolean equations. For example, the sum of two single-digit binary numbers is represented by a pair of truth tables, one for the actual column sum, the other for the carry bit. The truth tables are shown in Figure S1.6. You should recognize the truth table for the sum as the EXCLUSIVE-OR operation and the carry as the AND operation. Similarly, the complement operation that is used in subtraction is just a Boolean NOT operation. These operations are combinatorial. They are true regardless of any previous additions or complements performed. Complementary Boolean logic in a computer is implemented by using electronic circuits called gates or logical gates. Gates are constructed from transistor switches and other electronic components, formed into integrated circuits. A small-scale integrated circuit may contain half a dozen gates or so for building special Boolean logic circuits. The gates in a CPU are organized into a very-large-scale integrated circuit or VLSI chip. The drawn representations for logical gates are shown in Figure S1.7.

FIGURE S1.6
Truth Tables for the Sum of Two Binary Numbers A 0 0 1 1 B 0 1 0 1 sum S 0 1 1 0 A 0 0 1 1 B 0 1 0 1 carry C 0 0 0 1

FIGURE S1.7
Standard Logic Gate Representations A B AND gate A B EXCLUSIVE-OR gate C A B OR gate A A

NOT gate

sc01.qxd

11/23/2002

12:11 PM

Page 653

SUPPLEMENTARY CHAPTER 1

AN INTRODUCTION TO DIGITAL COMPUTER LOGIC

653

It is not difficult to manipulate the Boolean algebra to show that combinatorial Boolean logic can be implemented entirely with a single type of gate, appropriately combined. Either of the two gates shown in Figure S1.8 will fill the bill. The NAND gate is an AND operation followed by a NOT operation. The NOR operation is an INCLUSIVE-OR operation followed by a NOT operation. The small circle is used to indicate the NOT operation. We can use DeMorgans theorem to show that a NAND operation is the same as an or operation performed on inverted inputs. For convenience, the NAND gate may also be drawn in the alternative form shown in the figure. (The same thing can be done with the NOR gate.) The advantage of doing so is shown in Figure S1.9. This logic drawing represents a pair of ANDs followed by an OR. Since two NOTs in succession cancel each other, the pair of circles in succession make it clear what is actually happening. The result in algebraic form is
Y = A B + C D

EXAMPLE

Just for fun, lets consider a practical application for the circuit in Figure S1.9. Figure S1.10 shows the same circuit with one modification: an additional NAND gate has been used to perform a NOT operation, so that only one of the AND gates in the AND-OR combination can be active at a time. If the select line is a 1, then the output of the upper NAND gate will reflect the inverse of whatever input is present at A. On the other hand, if the select line is a 0, the output of the lower NAND gate will reflect the inverse of whatever is present at B. Since the final NAND gate generates the OR operation of the inverted inputs, only the active AND operation gets passed through to the output. Therefore, Y represents either A or B, depending on the value of the select line. For obvious reasons, this circuit is called a selector. Since it can be used to switch the input back and forth between A and B, it is also sometimes called a multiplexer. If we

FIGURE S1.8
NAND

and

NOR

Gate Representations C A B
NOR gate C=A+B

A B
NAND

A B

gate C=AB

alternative form for NAND gate C=A+B

FIGURE S1.9
AND - OR

FIGURE S1.10
Selector Circuit A select Y Y

from A B

NAND

Operation Made up Gates

C D B

sc01.qxd

11/23/2002

12:11 PM

Page 654

654

SUPPLEMENTS

wanted to switch between two bytes of data, we would use eight identical selector circuits, one for each bit. One byte would be placed on the A input, the other on the B input. The same select signal would be connected to the select line on every circuit. What this shows you is that the logic circuits that make up a computer are relatively simple, but they look complicated because so many circuits are required to perform useful work.
I I I

Another important example of a combinatorial logic circuit is the arithmetic adder. In Figure S1.6 we showed you the truth tables for a simple adder. The NAND logic circuit that produces the desired outputs for a single bit is shown in Figure S1.11. This circuit is called a half adder. For practice, you should make sure that you can correlate the circuit to the formulas for a half adder. The circuit in Figure S1.11 is called a half adder because in most cases a complete adder circuit must also handle a possible carry from the previous bit. Figure S1.12 shows a logic circuit for one bit of a full adder. To simplify the circuit, we have used the modified half adder enclosed in the dotted line; the use of instead of C reduces the number of gates somewhat. The half adder circuit is represented in Figure S1.12 as a block in this drawing. This approach is a common solution to the problem of making logic drawings readable. A 32-bit adder would be made up of 32 of these circuits. Because the carry ripples through each of the 32 bits, the adder is called a ripple adder. Modern logic designers use some tricks to speed up the adder by reducing the ripple effect of the carry bits, but the basic design of the 32-bit adder in a computer is as you see it here.

S1.3 SEQUENTIAL LOGIC CIRCUITS


Sequential logic circuits are circuits whose output is dependent not only on the input and the configuration of gates that make up the circuit, but on the previous state of the circuit as well. In other words, the state of the circuit is somehow stored within the circuit and used as a factor in determining the new output. The key to sequential logic circuits is the presence of memory within the circuitnot memory as you think of computer memory, but individual bits of memory that form part of the circuit itself. The state of the circuit is stored in these memory bits. The basic memory element in a sequential logic circuit is called a flip-flop. The simplest flip-flop is made up of two NAND logic gates connected as shown in Figure S1.13. S This circuit is called a set-reset flip-flop. A similar flip-flop can be built from NOR gates. Suppose that and are both initially set to 1. Can you determine the two outputs? It turns out that you cant. All you can say is C that one of them will be a 0 and the other will be a 1. You can see this by assuming the value C

FIGURE S1.11
Half Adder

sc01.qxd

11/23/2002

12:11 PM

Page 655

SUPPLEMENTARY CHAPTER 1

AN INTRODUCTION TO DIGITAL COMPUTER LOGIC

655

FIGURE S1.12
Full Adder previous carry (Ck-1) half adder Ak half adder Bk S C carryk S C sumk

FIGURE S1.13
Set-Reset Flip-flop S Q

for one output, determining the other output, and then verifying that everything in the circuit is self-consistent. For example, assume that the upper output in the figure is a 1. Then both inputs for the lower gate are 1s, and the output is a 0. This means that one of the inputs to the upper gate is a 0, which verifies that the upper output is a 1. Everything is self-consistent, and the circuit is stable as long as the and inputs remain at 1. (You might need to review the truth table for the NAND gate to convince yourself that the flip-flop works as we claim.) Now suppose that the input momentarily becomes a 0. This forces the output of the lower gate to a 1. The two upper inputs are now both 1s, so the Q output becomes a 0. The Q output will hold the lower output at 1, even after the input returns to a 1. The flip-flop has switched states. It is now stable in the alternate state to the one that we began with. In other words, the flip-flop remembers which input was momentarily set to 0. (One ground rule: the logic surrounding this flip-flop must avoid situations where both and are 0 at the same time.) There are other types of flip-flops as well. Some are designed to work on the basis of the 1 and 0 levels at the input. These types of flip-flops are sometimes called latches. Other flip-flops work on an input transition, called an edge trigger, the instantaneous change from 1 to 0 at an input, for example. A D flip-flop has a single data input. When the input marked Ck, for clock, is momentarily changed to 0 the Q output will take on the value present at the D input. The preset (P) and clear (Clr) inputs are used to initialize the flip-flop to a known value; they work independently of the D and clock inputs. A toggle flip-flop switches states whenever the T input momentarily goes to 0. The equivalent of a truth table for a sequential circuit is called a state table or behavior table. The state table shows the output for all combinations of input and previous states. For edge-triggered flip-flops, the clock acts as a control signal. The new output occurs when the clock is pulsed except for preset and clear inputs, which affect the output immediately. The symbols and state tables for several types of flip-flops are shown in Figure S1.14. Flip-flops of various types have many uses throughout the computer. Registers are made up of flip flops. They hold the results of intermediate arithmetic and logic operations. Flipflops are used as counters, for the steps of a fetch-execute cycle, and for the program counter. Flip-flops control the timing of various operations. Flip-flops serve as buffers. Static RAM is also made up of flip flops, although dynamic RAM uses a different storage technique.

EXAMPLE

This example is a simple illustration of the use of both sequential and combinatorial logic in a computer. The text in Chapter 7 points out that the copying of data from one register to

sc01.qxd

11/23/2002

12:11 PM

Page 656

656

SUPPLEMENTS

FIGURE S1.14
Several Types of Flip-flops
set-reset S Q T R R 0 1 0 1 Q T 0 1 Q Q QPREV QPREV toggle Q JK P Q D P Q

J Ck

D Ck

K Cir Q J 0 0 1 1 K Q 0 QPREV 1 0 0 1 1 QPREV D 0 1

Cir Q Q 0 1

S Q 0 ? 0 0 1 1 1 QPREV

preset = 1, Q = 1 clear = 1, Q = 0

preset = 1, Q = 1 clear = 1, Q = 0

another is an essential operation in the fetchexecute cycle. The logic shown in Figure S1.15 represents the essential part of implementing a register copying operation. Flipflops A1 through A4 represent four bits of a register. Flip-flops B1 through B4 represent the corresponding bits of a second register. This circuit can be used to copy the data from register A to register B. If the signal marked copy-A-to-B is a 1 when the clock is pulsed, data will be copied from A to B. The copy-Ato-B signal would be controlled from a circuit that counts the steps in a particular instruction fetch-execute cycle, then turns on the signal when the copy is required.

FIGURE S1.15
Logic to Copy Data from One Register to Another
register A register B Q A1 Q D B1 Ck Q A2 Q D B2 Ck Q A3 Q D B3 Ck Q A4 Q D B4 Ck

copy-A-to-B

clock

To carry this discussion a step further, consider the simplified hardware implementation of a LOAD instruction, shown in Figure S1.16. For this instruction, the clock pulse is directed to four different lines, each of which carries one of the clock pulses, in sequence, controlled by an instruction step counter. The first line, called t1 in the diagram, closes the switches that transfer the data from the program counter to the memory address register for the first step of the fetch phase. The same pulse is delayed, then used to activate memory for a READ. The next clock pulse, t2, connects the memory data register to the instruction register, completing the fetch phase. Lines t3 and t4 will perform different operations depending on the instruction. The combination of bits in the op code portion of the instruction register determine the instruction being performed, and these are used together with the clock lines to determine which switches are closed for the execution portion of the instruction. The remainder of the operation can be seen in the diagram. (The incrementing of the program counter has been omitted in the diagram for simplicity.) The last time pulse is also used to reset the instruction step counter for the next instruction. As you can see, the basic hardware implementation of the CPU is relatively straightforward and simple. Although the addition of pipelining and other features complicates the design, it is possible, with careful design, to implement and produce an extremely fast and efficient CPU at low cost and in large quantities.

sc01.qxd

11/23/2002

12:11 PM

Page 657

SUPPLEMENTARY CHAPTER 1

AN INTRODUCTION TO DIGITAL COMPUTER LOGIC

657

FIGURE S1.16
Simplified Implementation of the Steps in a
clock reset t4 counter t3 t2 t1 PC to MAR switch control IR instruction logic t3(LOAD) other t3 and t4 instruction lines delay t4(LOAD) delay turn on memory read MDR to IR control IR[add] to MAR control turn on memory read MDR to A control
LOAD

Instruction

SUMMARY AND REVIEW


The circuitry in a computer is made up of a combination of combinatorial and sequential logic. Computer logic is based on the rules of Boolean algebra, as implemented with logic gates. Sequential logic uses logic gates to provide memory. The output and state of a sequential logic circuit depends on its previous state as well as the current sets of inputs.

KEY CONCEPTS AND TERMS


AND

Boolean algebra Boolean logic combinatorial logic DeMorgans theorems EXCLUSIVE-OR flip-flop full adder

gates half adder INCLUSIVE-OR logic gate multiplexer circuit


NAND NOR NOT

sequential logic selector circuit state state table truth table very-large-scale integrated (VLSI) circuit

FOR FURTHER READING


Most general computer architecture textbooks have at least brief discussion of digital logic circuits. Reasonable discussions can be found, for example, in Stallings [STAL02], Patterson and Hennesey [PATT97], and Tanenbaum [TAN99]. More detailed discussions can be found in Lewin [LEW83], Wakerly [WAKE00], Proser and Winkel [PROS87], or Mano [MANO91]. There are many other excellent choices as well.

sc01.qxd

11/23/2002

12:11 PM

Page 658

658

SUPPLEMENTS

EXERCISES
S1.1 Verify using truth tables that both equivalence equations for the EXCLUSIVEOR operations are valid. b. Do the same using DeMorgans theorem. Show the truth table for the following Boolean equation:
Y = A + A B

a.

S1.2

S1.3

S1.4 S1.5

Look at the result. What general rule for reducing Boolean equations can you deduce from the result? Reduce the following equations to a simpler form a. Y = A + 1 b. Y = A + 0 c. Y = A 1 d. Y = A 0 Show the truth table for the following Boolean equation:
Y = A + A B C + A B C

One easy way to construct a logic gate implementation from a truth table is to recognize that the output is the OR of every row that has a 1 as the result. Each row is the AND of every column that has a 1 in it. Given the following Boolean expression:
Y = ((A B + C) + B (A B C)) (B + C)

S1.6 S1.7

determine the truth table; then implement the result using NAND gates. You may use three input NAND gates if necessary. Show a selector circuit implementation made up of NOR gates. The sum output from the half adder in Figure S1.11 is implemented from the equation
S = A B + A B

An alternate representation for the sum is


S = ((A B) + A) ((A B) + B)

a.

S1.8

S1.9

Show using either truth tables or algebraic manipulation that these two representations are equivalent. b. Use the latter form to develop a NAND gate implementation that requires only five gates to produce both the sum and carry. A decoder is a combinatorial logic circuit that produces a separate output for every possible combination of inputs. Each output is a 1 only for that particular combination. A decoder with three inputs, A, B, and C, would have eight outputs, for 000, 001, 010, .... Implement a logic decoder circuit for three inputs. Consider the sequential logic circuit shown in the accompanying figure together with an input that consists of an alternating sequence of 0s and 1s as shown. Assume that the initial state of this circuit produces an output that is all 0s. Show the next six output states. In one word, what does this circuit do?

sc01.qxd

11/23/2002

12:11 PM

Page 659

SUPPLEMENTARY CHAPTER 1

AN INTRODUCTION TO DIGITAL COMPUTER LOGIC

659

Q0 Q T Q

Q1 Q T Q

Q2 Q T Q

Q3

S1.10 Design a circuit that would serve as a four-stage shift register. A shift register shifts the input bits one bit at a time, so that the output from each stage represents the previous output from the previous stage.

You might also like