






Devices, Tools and Flows
AMSTERDAM- BOSTON " HEIDELBERG " LONDON
NEW YORK " OXFORD " PARIS " SAN DIEGO
SAN FRANCISCO " SINGAPORE " SYDNEY " TOKYO
Neames is an imprintof Elsevier
dive "Max" Maxfield
Newnes
Preface . . . . . . . . . . . . . . . ix
Acknowledgments . . . . . . . . . . xi
Chapter X
Introduction . . . . . . . . . . X
What are FPGAs? . . . . . . . . . 1
Why are FPGAs of interest? . . . . 1
What can FPGAs be used for? . . . 4
What's in this book? . . . . . . . . 6
What's not in this book?. . . . . . 7
Who's this book for? . . . . . . . . 8
Chapter 2
Fundamental Concepts . . . . . 9
The key thing about FPGAs. . . . 9
A simple programmable function . 9
Fusible link technologies . . . . . 10
Antifuse technologies . . . . . . 12
Mask-programmed devices . . . . 14
PROMs . . . . . . . . . . . . . .15
EPROM-based technologies . . . 17
EEPROM-based technologies . . 19
FLASH-based technologies . . . 20
SRAM-based technologies . . . . 21
Summary . . . . . . . . . . . . . 22
Chapter 3
The Origin ofFPGAs . . . . . . 25
Related technologies . . . . . . 25
Transistors . . . . . . . . . . . . 26
Integrated circuits
	
. . . . . . . . 27
Contents
SRAMs, DRAMS, and
microprocessors . . . . . . . . . 28
SPLDs and CPLDs . . . . . . . . 28
ASICs (gate arrays, etc.) . . . . . 42
FPGAs . . . . . . . . . . . . . . 49
Chapter 4
Alternative FPGA Architectures 57
Aword of warning . . . . . . . . 57
A little background information . 57
Antifuse versus SRAM
versus . . . . . . . . . . . . . . . 59
Fine-, medium-, and coarse-grained
architectures . . . . . . . . . . 66
MUX- versus LUT-based
logic blocks . . . . . . . . . . . 68
CLBs versus LABS versus slices . . 73
Fast carry chains . . . . . . . . . 77
Embedded RAMs . . . . . . . . . 78
Embedded multipliers, adders,
MACS, etc. . . . . . . . . . . . 79
Embedded processor cores
(hard and soft) . . . . . . . . . 80
Clock trees and clock managers . 84
General-purpose 1/0 . . . . . . . 89
Gigabit transceivers . . . . . . . 92
Hard 1P, soft IP, and firm IP . . . 93
System gates versus real gates . . 95
FPGA years . . . . . . . . . . . . 98
viii m The Design Warrior's Guide to FPGAs
Chapter 5
Programming (Configuring)
an FPGA . . . . . . . . . . . . 99
Weasel words . . . . . . . . . . . 99
Configuration files, etc. . . . . . 99
Configuration cells . . . . . . . 100
Antifuse-based FPGAs . . . . . 101
SRAM-based FPGAs . . . . . . 102
Using the configuration port . . 105
Using the JTAG port . . . . . . 111
Using an embedded processor . . 113
Chapter &
Schematic-Based Design Flows 133
In the days of yore .
	
. . . . . . . 133
The early days of FDA . . . . . 134
A simple (early) schematic-driven
ASIC flow . . . . . . . . . . . 141
Asimple (early) schematic-driven
FPGA flow . . . . . . . . . . 143
Flat versus hierarchical schematics
. . . . . . . . . . . . . . . . 148
Schematic-driven FPGA
design flows today . . . . . . . 151
Chapter 6
Who Are All the Players? . . . 115 Chapter 9
Introduction . . . . . . . . . . . 115 HDL-Based Design Flows . . . 153
FPGA and FPAA vendors . . . 115 Schematic-based flows
FPNA vendors . . . . . . . . . 116 grind to a halt . . . . . . . . . 153
Full-line EDA vendors . . . . . 116 The advent of HDL-based flows 153
FPGA"specialist and independent EDA Graphical design entry lives on . 161
vendors . . . . . . . . . . . . 117 A positive plethora of HDLs . . 163
FPGA design consultants with special Points to ponder . . . . . , . . , 172
tools . . . . . . . . . . . . . .118 Chapter 10
Open-source, free, and low-cost design Silicon Virtual Prototyping
tools . . . . . . . . . . . . . . 118 for FPGAs . . . . . . . . . . 179
Just what is an SVP? . . . . . . 179
Chapter 7
FPGA Versus ASIC ASIC-based SVP approaches . . 180
Design Styles. . . . . . . . . 121 FPGA-based SVPs . . . . , . . 187
Introduction . . . . . . . . . . . 121
Chaperll
Coding styles . . . . . . . . . . 122 CC++ etc.-Based Design Flows
Pipelining and levels of logic . . 122 . . . . . . . . . . . " . . . . 193
Asynchronous design practices . 126 Problems with traditional
Clock considerations . . . . . . 127 HDL-based flows . . . . . . . 193
Register and latch considerations 129 C versus C++ and concurrent
Resource sharing (time-division multi- versus sequential . . . . . . . 196
plexing) . . . . . . . . . . . . 130 SystemC-based flows . . . . . . 198
State machine encoding . . . . 131 Augmented C/C++-based flows 205
Test methodologies . . . . . . . 131 Pure C/C++-based flows . . . . 209
Different levels of synthesis





verification environments . . 214 Nigh-Speed Design and Other
PCB Considerations . . . . . 267
Chapter 12 Before we start. . . . . . . . . . 267
DSP-Based Design Flows . . . 217 We were all so much younger
Introducing DSP . . . . . . . . 217 then . . . . . . . . . . . . . . 267
Alternative DSP implementations The times they are a-changing . 269
' 218 Other things to think about . . 272
FPGA-centric design flows
for DSPs . . . . . . . . . . . . 225 Chapter 16
Mixed DSP and VHDL/
Observing Internal Nodes fn
an FPGA . . . . 277
Verilog etc. environments . . 236
Lack of visibility . . . . . . . . . 277
Chapter 13 Multiplexing as a solution . . . 278
Embedded Processor-Based Special debugging circuitry . . . 280
Design Flows . . . . . . . . . 239
Introduction . . . . , . . , , , , 23g
Virtual logic analyzers . . . . . . 280
Hard versus soft cores . . . . . . 241
VirtualWires . . . . . . . , . . 282
Partitioning a design into its Chapter 17
hardware and software components intellectual Property . . . , . 287
245 Sources of IP . . . . . . . . . . 287
Hardware versus software views Handcrafted IP . . . . . . . . . 287
of the world . . . . . . . . . . 247 IP core generators . . . . . . . . 290
Using an FPGA as its own Miscellaneous stuff . . . . . . . 291
development environment . . 249
Improving visibility in
chapter 1S
Migrating ASIC Designs to FPGAs
the design . . . . . . . . . . . 250 and Vice Versa . . . . . . . . 293
A few coverification alternatives 251 Alternative design scenarios . . 293
A rather cunning design
environment . , . . , , , , , 257
Chapter 19
Simulation, Synthesis, Verification,
Chapter 14 etc. Design
Tools. . . . . . . 299
Modular and Incremental Introduction . . . . . . . . . . . 299
Design . . . . . . . . . . . . 259 Simulation (cycle-based,
Handling things as one event-driven, etc.) . . . . . . 299
big chunk . . . . . . . . . . . 259 Synthesis (logic/HDL versus
Partitioning things into physically aware) . . . . . . . 314
smaller chunks . . . . . . . . 261 Timing analysis (static
There's always another way . . . 264 versus dynamic) . . . . . . . . 319
Verification in general . . . . . 322
Formal verification . . . . . . . 326
x m
	
The Design Warrior's Guide to FPGAs
Miscellaneous . . . . . . . . . . 338 Introduction . . . . . . . . . . . 381
Chapter 20
Algorithmic evaluation . . . . . 383
Choosing the Right Device . . 343 picoChip's picoArray technology384
So many choices . . . . . . . . 343 Quicksilver's ACM technology 388
If only there were a tool . . . . . 343 It's silicon, Jim, but not
Technology . . . . . . . . . . , 345 as we know id . . . . . . . . . 395
Basic resources and packaging . 346 Chapter 24
General-purpose 1/O interfaces . 347 Independent Design Tools . . 397
Embedded multipliers, Introduction . . . . . . . . . . . 397
RAMs, etc. . . . . . . . . . . 348 ParaCore Architect . . . . . . . 397
Embedded processor cores. . . . 348 The Confluence system
Gigabit 1/O capabilities . . . . . 349 design language . . . . . . . . 401
IP availability . . . . . . . . . . 349 Do you have a tool? . . . . . . . 406
Speed grades . . . . . . . . . . . 350 Chapter 25
On a happier note . . . . . . . . 351 Creating an Open-Source-Based
Design Flow . . . . . . . . . 407
Chapter 21 How to start an FPGA design
Gigabit Transceivers . . , . r 353 shop for next to nothing . - . 407
Introduction . . . . . . . . 353 The development platform : Linux
Differential pairs . . . . . . . . 354 , , , . , , , , , . . . . . . . 407
Multiple standards . . . . . . 357 The verification environment . 411
8-bit/10-bit encoding, etc . . . . 358 Formal verification . . , . . . . 413
Delving into the transceiver Access to common I1' components
Mocks . . . . . . . . . . . . . 361 . . . . . . . . . . . . . . . .416
Ganging multiple transceiver Synthesis and implementation
blocks together . . . . . , . . 362 tools . . . . . . . . . . . . . . 417
Configurable stuff . . . . . . . . 364 FPGA development hoards . . . 418
Clock recovery, j itter, and Miscellaneous stuff . . . . . . . 418eye diagrams . . . . . . . . . . 367
Chapel 2,2
Reconfigurable Computing . . 373
Dynamically reconfigurable logic 373
Dynamically reconfigurable
interconnect . . . . . . , . . 373
Reconfigurable computing . . . 374
Chapter 2.3
Field-Programmable
Node Arrays . . . , . . . . , 381
Chapter 26
Future FPGA Developments . 419
Be afraid, be very afraid . . . . . 419
Next-generation architectures
and technologies . . . . . . . 420
Don't forget the design tools . . 426
Expect the unexpected . . , . . 427
Appendix A:
Signal Integrity 101 . , . , . 429
Before we start. . . . . . . . . . 429
Contents m xi
Capacitive and inductive coupling
	
More taps than you know
(crosstalk) . . . . . . . . . . 430 what to do with . . . . . . . . 468
Chip-level effects . . . . . . . . 431 Seeding an LFSR . . . . . . . . 470
Board-level effects. . . . . . . . 438 FIFO applications . . . . . . . . 472
Appendix B.
Modifying LFSRs to sequence
Deep-Submicron Delay Effects 101 2" values . . . . . . . . . . . . 474
. . . . . . . . . . . . . . . . 44,E Accessing the previous value . . 475
Introduction . . . . . . . . . . . 443 Encryption and decryption
The evolution of delay applications . . . . . . . . . . 476
specifications . . . . . . . . . 443 Cyclic redundancy check
A potpourri of definitions . . . . 445 applications . . . . . . . . . . 477
Alternative interconnect models 449 Data compression applications . 479
DSM delay effects . . . . . . . . 452 Built-in self-test applications . . 480
Summary . . . . . . . . . . . . 464 Pseudorandom-number-generation
applications . . . . . . . . . . 482
Appendix C:
Linear Feedback Shift Last but not least . . . . . . . . 482
Registers 101 . . . . . . . . 465 Glossary. . . . . . . . . . . . . . 485
The Ouroboras . . . . . . . . . 465
Many-to-one implementations . 465 About the Author . . . . . . . . . 525
Index . . . . . . . . . . . . . . . 527
