Preface |
|
xi | |
Acknowledgment |
|
xiii | |
Part I: Design |
|
1 | (122) |
|
|
3 | (30) |
|
Architecture of the Present-Day SoC |
|
|
5 | (3) |
|
|
8 | (6) |
|
Hardware--Software Codesign |
|
|
14 | (7) |
|
|
15 | (3) |
|
|
18 | (3) |
|
Core Libraries, EDA Tools, and Web Pointers |
|
|
21 | (12) |
|
|
21 | (2) |
|
|
23 | (5) |
|
|
28 | (1) |
|
|
29 | (4) |
|
Design Methodology for Logic Cores |
|
|
33 | (24) |
|
|
34 | (2) |
|
General Guidelines for Design Reuse |
|
|
36 | (7) |
|
|
36 | (1) |
|
Memory and Mixed-Signal Design |
|
|
36 | (2) |
|
|
38 | (1) |
|
|
39 | (1) |
|
|
40 | (1) |
|
|
40 | (2) |
|
|
42 | (1) |
|
Design Process for Soft and Firm Cores |
|
|
43 | (4) |
|
|
43 | (2) |
|
Development Process for Soft/Firm Cores |
|
|
45 | (1) |
|
|
46 | (1) |
|
Soft/Firm Cores Productization |
|
|
47 | (1) |
|
Design Process for Hard Cores |
|
|
47 | (4) |
|
Unique Design Issues in Hard Cores |
|
|
47 | (2) |
|
Development Process for Hard Cores |
|
|
49 | (2) |
|
Sign-Off Checklist and Deliverables |
|
|
51 | (2) |
|
|
51 | (1) |
|
|
52 | (1) |
|
|
53 | (1) |
|
|
53 | (4) |
|
Designing With Hard Cores |
|
|
53 | (1) |
|
Designing With Soft Cores |
|
|
54 | (1) |
|
|
54 | (1) |
|
|
55 | (2) |
|
Design Methodology for Memory and Analog Cores |
|
|
57 | (28) |
|
Why Large Embedded Memories |
|
|
57 | (2) |
|
Design Methodology for Embedded Memories |
|
|
59 | (13) |
|
|
61 | (5) |
|
|
66 | (4) |
|
|
70 | (2) |
|
Specifications of Analog Circuits |
|
|
72 | (7) |
|
Analog-to-Digital Converter |
|
|
72 | (3) |
|
Digital-to-Analog Converter |
|
|
75 | (3) |
|
|
78 | (1) |
|
|
79 | (6) |
|
|
79 | (1) |
|
IEEE 1394 Serial Bus (Firewire) PHY Layer |
|
|
80 | (1) |
|
|
81 | (1) |
|
|
81 | (4) |
|
|
85 | (20) |
|
|
86 | (7) |
|
|
86 | (2) |
|
|
88 | (2) |
|
Core-Level Timing Verification |
|
|
90 | (3) |
|
Core Interface Verification |
|
|
93 | (2) |
|
|
94 | (1) |
|
|
95 | (1) |
|
|
95 | (10) |
|
|
97 | (4) |
|
|
101 | (1) |
|
|
101 | (2) |
|
|
103 | (2) |
|
Core and SoC Design Examples |
|
|
105 | (18) |
|
|
105 | (7) |
|
V830R/AV Superscaler RISC Core |
|
|
109 | (1) |
|
Design of PowerPC 603e G2 Core |
|
|
110 | (2) |
|
Comments on Memory Core Generators |
|
|
112 | (1) |
|
Core Integration and On-Chip Bus |
|
|
113 | (2) |
|
|
115 | (8) |
|
|
116 | (5) |
|
Testability of Set-Top Box SoC |
|
|
121 | (1) |
|
|
122 | (1) |
Part II: Test |
|
123 | (134) |
|
Testing of Digital Logic Cores |
|
|
125 | (30) |
|
|
126 | (2) |
|
Access, Control, and Isolation |
|
|
128 | (1) |
|
|
129 | (9) |
|
Cores Without Boundary Scan |
|
|
132 | (3) |
|
|
135 | (1) |
|
|
135 | (3) |
|
Core Test and IP Protection |
|
|
138 | (4) |
|
Test Methodology for Design Reuse |
|
|
142 | (2) |
|
Guidelines for Core Testability |
|
|
142 | (1) |
|
High-Level Test Synthesis |
|
|
143 | (1) |
|
Testing of Microprocessor Cores |
|
|
144 | (11) |
|
Built-in-Self-Test Method |
|
|
144 | (3) |
|
Example: Testability Features of ARM Processor Core |
|
|
147 | (3) |
|
Debug Support for Microprocessor Cores |
|
|
150 | (2) |
|
|
152 | (3) |
|
Testing of Embedded Memories |
|
|
155 | (26) |
|
Memory Fault Models and Test Algorithms |
|
|
156 | (5) |
|
|
156 | (1) |
|
|
157 | (3) |
|
Effectiveness of Test Algorithms |
|
|
160 | (1) |
|
Modification With Multiple Data Background |
|
|
161 | (1) |
|
Modification for Multiport Memories |
|
|
161 | (1) |
|
Algorithm for Double-Buffered Memories |
|
|
161 | (1) |
|
Test Methods for Embedded Memories |
|
|
161 | (10) |
|
Testing Through ASIC Functional Test |
|
|
163 | (1) |
|
Test Application by Direct Access |
|
|
164 | (1) |
|
Test Application by Scan or Collar Register |
|
|
164 | (1) |
|
Memory Built-in Self-Test |
|
|
164 | (5) |
|
Testing by On-Chip Microprocessor |
|
|
169 | (2) |
|
Summary of Test Methods for Embedded Memories |
|
|
171 | (1) |
|
Memory Redundancy and Repair |
|
|
171 | (4) |
|
|
171 | (4) |
|
|
175 | (1) |
|
Error Detection and Correction Codes |
|
|
175 | (1) |
|
Production Testing of SoC With Large Embedded Memory |
|
|
176 | (5) |
|
|
177 | (4) |
|
Testing of Analog and Mixed-Signal Cores |
|
|
181 | (26) |
|
Analog Parameters and Characterization |
|
|
182 | (9) |
|
Digital-to-Analog Converter |
|
|
182 | (2) |
|
Analog-to-Digital Converter |
|
|
184 | (4) |
|
|
188 | (3) |
|
Design-for-Test and Built-in Self-Test Methods for Analog Cores |
|
|
191 | (9) |
|
Fluence Technology's Analog BIST |
|
|
192 | (1) |
|
Logic Vision's Analog BIST |
|
|
192 | (3) |
|
Testing by On-Chip Microprocessor |
|
|
195 | (2) |
|
|
197 | (3) |
|
Testing of Specific Analog Circuits |
|
|
200 | (7) |
|
|
200 | (1) |
|
Testing of 1394 Serial Bus/Firewire |
|
|
201 | (3) |
|
|
204 | (3) |
|
|
207 | (32) |
|
|
207 | (11) |
|
|
208 | (4) |
|
|
212 | (1) |
|
|
213 | (2) |
|
Effectiveness of Iddq Testing |
|
|
215 | (3) |
|
Iddq Testing Difficulties in SoC |
|
|
218 | (6) |
|
|
224 | (4) |
|
Design Rules for Iddq Testing |
|
|
228 | (2) |
|
Iddq Test Vector Generation |
|
|
230 | (9) |
|
|
234 | (5) |
|
|
239 | (12) |
|
|
239 | (2) |
|
|
241 | (5) |
|
|
241 | (2) |
|
|
243 | (2) |
|
|
245 | (1) |
|
Production Throughput and Material Handling |
|
|
246 | (5) |
|
|
246 | (1) |
|
|
247 | (1) |
|
|
248 | (1) |
|
|
249 | (2) |
|
|
251 | (6) |
|
|
251 | (3) |
|
|
254 | (3) |
Appendix: RTL Guidelines for Design Reuse |
|
257 | (8) |
|
|
257 | (1) |
|
A.2 General Coding Guidelines |
|
|
258 | (2) |
|
A.3 RTL Development for Synthesis |
|
|
260 | (2) |
|
|
262 | (3) |
About the Author |
|
265 | (2) |
Index |
|
267 | |