Preface |
|
xiii | |
Chapter 1 |
|
3 | (26) |
|
DIGITAL COMPUTERS AND INFORMATION |
|
|
3 | (26) |
|
|
3 | (5) |
|
Information Representation |
|
|
5 | (1) |
|
|
6 | (1) |
|
More on the Generic Computer |
|
|
6 | (2) |
|
|
8 | (5) |
|
|
9 | (2) |
|
Octal and Hexadecimal Numbers |
|
|
11 | (2) |
|
|
13 | (1) |
|
1-3 Arithmetic Operations |
|
|
13 | (5) |
|
Conversion from Decimal to Other Bases |
|
|
16 | (2) |
|
|
18 | (3) |
|
|
19 | (1) |
|
|
20 | (1) |
|
|
21 | (2) |
|
|
23 | (2) |
|
|
24 | (1) |
|
|
25 | (4) |
|
|
26 | (1) |
|
|
26 | (3) |
Chapter 2 |
|
29 | (58) |
|
COMBINATIONAL LOGIC CIRCUITS |
|
|
29 | (58) |
|
2-1 Binary Logic and Gates |
|
|
29 | (4) |
|
|
30 | (2) |
|
|
32 | (1) |
|
|
33 | (8) |
|
Basic Identities of Boolean Algebra |
|
|
35 | (2) |
|
|
37 | (3) |
|
|
40 | (1) |
|
|
41 | (6) |
|
|
42 | (3) |
|
|
45 | (1) |
|
|
46 | (1) |
|
2-4 Two-Level Circuit Optimization |
|
|
47 | (11) |
|
|
48 | (1) |
|
|
49 | (1) |
|
|
50 | (5) |
|
|
55 | (3) |
|
|
58 | (7) |
|
Essential Prime Implicants |
|
|
59 | (2) |
|
Nonessential Prime Implicants |
|
|
61 | (1) |
|
Product-of-Sums Optimization |
|
|
62 | (1) |
|
|
63 | (2) |
|
2-6 Multiple-Level Circuit Optimization |
|
|
65 | (5) |
|
|
70 | (5) |
|
2-8 Exclusive-OR Operator and Gates |
|
|
75 | (2) |
|
|
76 | (1) |
|
2-9 High-Impedance Outputs |
|
|
77 | (3) |
|
|
80 | (7) |
|
|
80 | (1) |
|
|
81 | (6) |
Chapter 3 |
|
87 | (54) |
|
COMBINATIONAL LOGIC DESIGN |
|
|
87 | (54) |
|
3-1 Design Concepts and Automation |
|
|
87 | (9) |
|
|
89 | (3) |
|
|
92 | (1) |
|
|
92 | (1) |
|
Hardware Description Languages |
|
|
93 | (2) |
|
|
95 | (1) |
|
|
96 | (8) |
|
|
97 | (1) |
|
|
97 | (1) |
|
|
97 | (1) |
|
|
98 | (3) |
|
Positive and Negative Logic |
|
|
101 | (2) |
|
|
103 | (1) |
|
|
104 | (6) |
|
|
110 | (11) |
|
|
112 | (1) |
|
|
112 | (1) |
|
|
113 | (8) |
|
|
121 | (3) |
|
|
121 | (1) |
|
|
122 | (2) |
|
3-6 Programmable Implementation Technologies |
|
|
124 | (8) |
|
|
121 | (8) |
|
|
129 | (1) |
|
Programmable Array Logic Devices |
|
|
130 | (2) |
|
|
132 | (9) |
|
|
133 | (1) |
|
|
133 | (8) |
Chapter 4 |
|
141 | (60) |
|
COMBINATIONAL FUNCTIONS AND CIRCUITS |
|
|
141 | (60) |
|
4-1 Combinational Circuits |
|
|
141 | (1) |
|
4-2 Rudimentary Logic Functions |
|
|
142 | (5) |
|
Value-Fixing, Transferring, and Inverting |
|
|
142 | (1) |
|
|
143 | (3) |
|
|
146 | (1) |
|
|
147 | (5) |
|
|
148 | (3) |
|
Decoder and Enabling Combinations |
|
|
151 | (1) |
|
|
152 | (4) |
|
|
153 | (2) |
|
|
155 | (1) |
|
|
156 | (5) |
|
|
156 | (2) |
|
|
158 | (1) |
|
Alternative Selection Implementations |
|
|
159 | (2) |
|
4-6 Combinational Function Implementation |
|
|
161 | (15) |
|
|
162 | (2) |
|
|
164 | (2) |
|
|
166 | (3) |
|
Using Programmable Logic Arrays |
|
|
169 | (2) |
|
Using Programmable Array Logic Devices |
|
|
171 | (4) |
|
|
175 | (1) |
|
4-7 HDL Representation for Combinational Circuits-VHDL |
|
|
176 | (8) |
|
4-8 HDL Representations for Combinational Circuits-Verilog |
|
|
184 | (6) |
|
|
190 | (11) |
|
|
191 | (1) |
|
|
191 | (10) |
Chapter 5 |
|
201 | (40) |
|
ARITHMETIC FUNCTIONS AND CIRCUITS |
|
|
201 | (40) |
|
5-1 Iterative Combinational Circuits |
|
|
201 | (1) |
|
|
202 | (8) |
|
|
203 | (1) |
|
|
204 | (1) |
|
Binary Ripple Carry Adder |
|
|
205 | (1) |
|
|
206 | (4) |
|
|
210 | (5) |
|
|
212 | (1) |
|
Subtraction with Complements |
|
|
213 | (2) |
|
5-4 Binary Adder-Subtractors |
|
|
215 | (6) |
|
|
216 | (2) |
|
Signed Binary Addition and Subtraction |
|
|
218 | (2) |
|
|
220 | (1) |
|
5-5 Binary Multiplication |
|
|
221 | (2) |
|
5-6 Other Arithmetic Functions |
|
|
223 | (6) |
|
|
224 | (1) |
|
|
225 | (1) |
|
|
226 | (1) |
|
Multiplication by Constants |
|
|
227 | (1) |
|
|
227 | (1) |
|
|
227 | (2) |
|
5-7 HDL Representations-VHDL |
|
|
229 | (4) |
|
|
231 | (2) |
|
5-8 HDL Representations-Verilog |
|
|
233 | (2) |
|
|
234 | (1) |
|
|
235 | (6) |
|
|
235 | (1) |
|
|
236 | (5) |
Chapter 6 |
|
241 | (68) |
|
|
241 | (68) |
|
6-1 Sequential Circuit Definitions |
|
|
242 | (2) |
|
|
244 | (5) |
|
|
245 | (3) |
|
|
248 | (1) |
|
|
249 | (9) |
|
|
250 | (3) |
|
|
253 | (1) |
|
Standard Graphics Symbols |
|
|
254 | (2) |
|
|
256 | (1) |
|
|
257 | (1) |
|
6-4 Sequential Circuit Analysis |
|
|
258 | (9) |
|
|
258 | (2) |
|
|
260 | (2) |
|
|
262 | (1) |
|
Sequential Circuit Timing |
|
|
263 | (3) |
|
|
266 | (1) |
|
6-5 Sequential Circuit Design |
|
|
267 | (14) |
|
|
268 | (1) |
|
Finding State Diagrams and State Tables |
|
|
268 | (7) |
|
|
275 | (1) |
|
Designing with D Flip-Flops |
|
|
275 | (2) |
|
Designing with Unused States |
|
|
277 | (2) |
|
|
279 | (2) |
|
6-6 Other Flip-Flop Types |
|
|
281 | (3) |
|
|
282 | (2) |
|
6-7 HDL Representation for Sequential Circuits-VHDL |
|
|
284 | (7) |
|
6-8 HDL Representation for Sequential Circuits-Verilog |
|
|
291 | (7) |
|
|
298 | (11) |
|
|
299 | (1) |
|
|
299 | (10) |
Chapter 7 |
|
309 | (54) |
|
REGISTERS AND REGISTER TRANSFERS |
|
|
309 | (54) |
|
7-1 Registers and Load Enable |
|
|
310 | (3) |
|
Register with Parallel Load |
|
|
311 | (2) |
|
|
313 | (2) |
|
7-3 Register Transfer Operations |
|
|
315 | (3) |
|
7-4 A Note for VHDL and Verilog Users Only |
|
|
318 | (1) |
|
|
318 | (6) |
|
Arithmetic Microoperations |
|
|
319 | (2) |
|
|
321 | (2) |
|
|
323 | (1) |
|
7-6 Microoperations on a Single Register |
|
|
324 | (15) |
|
Multiplexer-Based Transfers |
|
|
324 | (2) |
|
|
326 | (5) |
|
|
331 | (2) |
|
Synchronous Binary Counters |
|
|
333 | (4) |
|
|
337 | (2) |
|
|
339 | (6) |
|
7-8 Multiplexer and Bus-Based Transfers for Multiple Registers |
|
|
345 | (3) |
|
|
346 | (2) |
|
7-9 Serial Transfer and Microoperations |
|
|
348 | (3) |
|
|
349 | (2) |
|
7-10 HDL Representation for Shift Registers and Counters -VHDL |
|
|
351 | (2) |
|
7-11 HDL Representation for Shift Registers and Counters-Verilog |
|
|
353 | (1) |
|
|
354 | (9) |
|
|
356 | (1) |
|
|
356 | (7) |
Chapter 8 |
|
363 | (36) |
|
|
363 | (36) |
|
|
364 | (1) |
|
8-2 Algorithmic State Machines |
|
|
365 | (4) |
|
|
365 | (3) |
|
|
368 | (1) |
|
|
369 | (6) |
|
|
369 | (6) |
|
|
375 | (9) |
|
Sequence Register and Decoder |
|
|
378 | (2) |
|
|
380 | (4) |
|
8-5 HDL Representation of the Binary Multiplier-VHDL |
|
|
384 | (3) |
|
8-6 HDL Representation of the Binary Multiplier-Verilog |
|
|
387 | (3) |
|
8-7 Microprogrammed Control |
|
|
390 | (2) |
|
|
392 | (7) |
|
|
392 | (1) |
|
|
393 | (6) |
Chapter 9 |
|
399 | (30) |
|
|
399 | (30) |
|
|
399 | (1) |
|
|
400 | (5) |
|
Write and Read Operations |
|
|
402 | (1) |
|
|
402 | (3) |
|
|
405 | (1) |
|
9-3 SRAM Integrated Circuits |
|
|
405 | (6) |
|
|
408 | (3) |
|
|
411 | (4) |
|
|
415 | (6) |
|
|
415 | (2) |
|
|
417 | (4) |
|
|
421 | (5) |
|
|
421 | (3) |
|
Double Data Rate SDRAM (DDR SDRAM) |
|
|
424 | (1) |
|
|
425 | (1) |
|
9-7 Arrays of Dynamic RAM ICs |
|
|
426 | (1) |
|
|
426 | (3) |
|
|
427 | (1) |
|
|
427 | (2) |
Chapter 10 |
|
429 | (54) |
|
|
429 | (54) |
|
|
430 | (1) |
|
|
430 | (3) |
|
10-3 The Arithmetic/Logic Unit |
|
|
433 | (6) |
|
|
434 | (3) |
|
|
437 | (1) |
|
|
437 | (2) |
|
|
439 | (2) |
|
|
440 | (1) |
|
10-5 Datapath Representation |
|
|
441 | (3) |
|
|
444 | (5) |
|
10-7 A Simple Computer Architecture |
|
|
449 | (7) |
|
Instruction Set Architecture |
|
|
450 | (1) |
|
|
450 | (1) |
|
|
451 | (3) |
|
Instruction Specifications |
|
|
454 | (2) |
|
10-8 Single-Cycle Hardwired Control |
|
|
456 | (8) |
|
|
458 | (2) |
|
Sample Instructions and Program |
|
|
460 | (2) |
|
Single-Cycle Computer Issues |
|
|
462 | (2) |
|
10-9 Multiple-Cycle Hardwired Control |
|
|
464 | (11) |
|
Sequential Control Design |
|
|
467 | (8) |
|
|
475 | (8) |
|
|
475 | (1) |
|
|
476 | (7) |
Chapter 11 |
|
483 | (44) |
|
INSTRUCTION SET ARCHITECTURE |
|
|
483 | (44) |
|
11-1 Computer Architecture Concepts |
|
|
483 | (2) |
|
Basic Computer Operation Cycle |
|
|
484 | (1) |
|
|
485 | (1) |
|
|
485 | (7) |
|
Three-Address Instructions |
|
|
486 | (1) |
|
|
487 | (1) |
|
|
487 | (1) |
|
Zero-Address Instructions |
|
|
488 | (1) |
|
|
489 | (3) |
|
|
492 | (7) |
|
|
493 | (1) |
|
|
493 | (1) |
|
Register and Register-Indirect Modes |
|
|
493 | (1) |
|
|
494 | (2) |
|
|
496 | (1) |
|
|
496 | (1) |
|
|
496 | (1) |
|
Summary of Addressing Modes |
|
|
497 | (2) |
|
11-4 Instruction Set Architectures |
|
|
499 | (1) |
|
11-5 Data Transfer Instructions |
|
|
500 | (3) |
|
|
501 | (1) |
|
Independent versus Memory-Mapped I/O |
|
|
502 | (1) |
|
11-6 Data Manipulation Instructions |
|
|
503 | (4) |
|
|
504 | (1) |
|
Logical and Bit Manipulation Instructions |
|
|
505 | (1) |
|
|
506 | (1) |
|
11-7 Floating-Point Computations |
|
|
507 | (5) |
|
|
508 | (1) |
|
|
509 | (1) |
|
|
510 | (2) |
|
11-8 Program Control Instructions |
|
|
512 | (5) |
|
Conditional Branch Instructions |
|
|
513 | (3) |
|
Procedure Call and Return Instructions |
|
|
516 | (1) |
|
|
517 | (4) |
|
|
518 | (1) |
|
Processing External Interrupts |
|
|
519 | (2) |
|
|
521 | (6) |
|
|
521 | (1) |
|
|
522 | (5) |
Chapter 12 |
|
527 | (52) |
|
RISC AND CISC CENTRAL PROCESSING UNITS |
|
|
527 | (52) |
|
|
528 | (5) |
|
Execution of Pipeline Microoperations |
|
|
532 | (1) |
|
|
533 | (4) |
|
Pipeline Programming and Performance |
|
|
535 | (2) |
|
12-3 The Reduced Instruction Set Computer |
|
|
537 | (20) |
|
Instruction Set Architecture |
|
|
538 | (3) |
|
|
541 | (1) |
|
|
541 | (3) |
|
|
544 | (2) |
|
|
546 | (7) |
|
|
553 | (4) |
|
12-4 The Complex Instruction Set Computer |
|
|
557 | (12) |
|
|
559 | (1) |
|
|
560 | (2) |
|
Control Unit Modifications |
|
|
562 | (1) |
|
|
563 | (3) |
|
Microprograms for Complex Instructions |
|
|
566 | (3) |
|
|
569 | (5) |
|
High-Performance CPU Concepts |
|
|
569 | (3) |
|
Recent Architectural Innovations |
|
|
572 | (1) |
|
|
573 | (1) |
|
|
574 | (5) |
|
|
575 | (1) |
|
|
575 | (4) |
Chapter 13 |
|
579 | (38) |
|
INPUT-OUTPUT AND COMMUNICATION |
|
|
579 | (38) |
|
|
579 | (1) |
|
|
580 | (4) |
|
|
580 | (1) |
|
|
581 | (2) |
|
|
583 | (1) |
|
|
584 | (1) |
|
|
584 | (7) |
|
I/O Bus and Interface Unit |
|
|
585 | (1) |
|
|
586 | (2) |
|
|
588 | (1) |
|
|
589 | (2) |
|
13-4 Serial Communication |
|
|
591 | (7) |
|
Asynchronous Transmission |
|
|
592 | (1) |
|
|
593 | (1) |
|
|
593 | (1) |
|
A Packet-Based Serial I/O Bus |
|
|
594 | (4) |
|
|
598 | (3) |
|
Example of Program-Controlled Transfer |
|
|
599 | (2) |
|
Interrupt-Initiated Transfer |
|
|
601 | (1) |
|
|
601 | (4) |
|
|
602 | (1) |
|
Parallel Priority Hardware |
|
|
603 | (2) |
|
13-7 Direct Memory Access |
|
|
605 | (4) |
|
|
606 | (2) |
|
|
608 | (1) |
|
|
609 | (3) |
|
|
612 | (5) |
Chapter 14 |
|
617 | (30) |
|
|
617 | (30) |
|
|
618 | (2) |
|
14-2 Locality of Reference |
|
|
620 | (2) |
|
|
622 | (14) |
|
|
624 | (5) |
|
|
629 | (2) |
|
|
631 | (1) |
|
|
631 | (1) |
|
|
632 | (3) |
|
Instruction and Data Caches |
|
|
635 | (1) |
|
|
635 | (1) |
|
|
636 | (6) |
|
|
638 | (2) |
|
Translation Lookaside Buffer |
|
|
640 | (2) |
|
|
642 | (1) |
|
|
642 | (5) |
INDEX |
|
647 | |