1 / 49

Introduction to Programmable Logic Devices

Explore the evolution of Programmable Logic Devices in Particle Physics experiments, from trigger systems to custom electronics, ASICs, PCBs, and FPGA architectures. Understand the basics, design flow, and hardware description languages.

johnramirez
Download Presentation

Introduction to Programmable Logic Devices

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Introduction toProgrammable Logic Devices Edward Freeman STFC Technology Department Detector & Electronics Division

  2. PPD Lectures Programmable Logic is a Key Underlying Technology for PP Experiments. • First-Level and High-Level Triggering • DataTransport (Networks) • Computers interacting with Hardware (Networks) • Silicon Trackers (Millions of Data Channels) Commercial Devices. Developments driven by Industry. Telecomms, Gaming, Aerospace, Automotive, Set-top boxes….

  3. Particle Physics Electronics CMS Custom Electronics Chips ASICs ANALOGUE $$$ Rad Hard, Low Power CERN LHC

  4. Particle Physics Electronics CMS Custom Electronics Chips ASICs ANALOGUE $$$ Rad Hard, Low Power CERN LHC Electronics Rooms Trigger Systems. DAQ Systems. DIGITAL Custom Digital Processing Boards VMEBus Crates

  5. Particle Physics Electronics • Special Dedicated Logic Functions (not possible in CPUs) • Ultra Fast Trigger Systems (Trigger Algorithms) Clock Accurate Timing • Massively Parallel Data Processing (Silicon Trackers with Millions of Channels) Custom Designed Printed Circuit Boards PCBs. Commercial Programmable Logic Devices, FPGAs

  6. CMS DAQ/Trigger Architectures CMS Fully custom PP ASICs Programmable Logic DIGITAL CPUs Commodity PCs “Telecoms Network” ~ 1 Tbps

  7. Lecture Outline • Programmable Logic Devices • Basics • Evolution • FPGA Field Programmable Gate Array • Architecture • Design Flow • Hardware Description Languages • Design Tools

  8. Digital Logic Logic Gates

  9. Digital Logic Logic Gates Transistor Switches

  10. Digital Logic Logic Gates MOORE’S LAW Transistor Switches < 40 nm ! $$$

  11. Digital Logic Digital Logic Function Product AND (&) Sum OR (|) 3 Inputs SUM of PRODUCTS Black Box Truth Table (Look Up Table LUT)

  12. Digital Logic Function Product AND (&) Sum OR (|) 3 Inputs SUM of PRODUCTS Black Box Truth Table (Look Up Table LUT) Digital Logic

  13. Digital Logic Function Product AND (&) Sum OR (|) 3 Inputs SUM of PRODUCTS Black Box Truth Table (Look Up Table LUT) Digital Logic

  14. Programmable Logic Devices PLDs Inputs • SUM of PRODUCTS • (Re-)Programmble Links • Reconfigurable • GLUE LOGIC Un-programmed State ANDs Planes of ANDs, ORs ORs Outputs Logic Functions

  15. Programmable Logic Devices PLDs Inputs • SUM of PRODUCTS • (Re-)Programmble Links • Reconfigurable • GLUE LOGIC Un-programmed State ANDs Planes of ANDs, ORs ORs Outputs Logic Functions

  16. Programmable Logic Devices PLDs Inputs • SUM of PRODUCTS • (Re-)Programmble Links • Reconfigurable • GLUE LOGIC Un-programmed State ANDs Planes of ANDs, ORs ORs Outputs Logic Functions

  17. Programmable Logic Devices PLDs Inputs • SUM of PRODUCTS • (Re-)Programmble Links • Reconfigurable • GLUE LOGIC Un-programmed State ANDs Planes of ANDs, ORs ORs Outputs Logic Functions Sums Programmed PLD Product Terms

  18. Programmable Logic Devices PLDs Logic Functions Programmed PLD Sums Product Terms

  19. Programmable Logic Devices PLDs Logic Functions x x x Programmed PLD x x Sums Product Terms

  20. Programmable Logic Devices PLDs • GLUE LOGIC Logic Functions x x x x Programmed PLD x x x Sums Product Terms

  21. CPLD Architecture Complex PLDs • CPLDs • Programmable PLD Blocks • Programmable Interconnects • Electrically Erasable links Feedback Outputs

  22. Sequential Circuits • Combinational Logic (Larger circuits difficult to predict) • Synchronous Logic driven by a CLOCK • Registers, Flip Flops (Memory) Inputs

  23. Sequential Circuits • Combinational Logic (Larger circuits difficult to predict) • Synchronous Logic driven by a CLOCK • Registers, Flip Flops (Memory) Intermediate New Output every clock edge Inputs Register CLOCK EDGES

  24. Sequential Circuits • Combinational Logic (Larger circuits difficult to predict) • Synchronous Logic driven by a CLOCK • Registers, Flip Flops (Memory) Intermediate New Output every clock edge Inputs Clock Rate determines speed Comb Logic Must meet Timing => Predictable circuits Register CLOCK Shift Registers, Pipelines, Finite State Machines … EDGES

  25. Field Programmable Gate Arrays FPGA • FieldProgrammable Gate Array • ‘Simple’ Programmable Logic Blocks • Massive Fabric of Programmable Interconnects • Standard CMOS Integrated Circuit fabrication processas for memory chips (Moore’s Law)

  26. Field Programmable Gate Arrays FPGA • FieldProgrammable Gate Array • ‘Simple’ Programmable Logic Blocks • Massive Fabric of Programmable Interconnects • Standard CMOS Integrated Circuit fabrication processas for SRAM memory chips (Moore’s Law) Huge Density of Logic Block ‘Islands’ 1,000 … 100,000’s in a ‘Sea’ of Interconnects FPGA Architecture

  27. Field Programmable Gate Arrays FPGA

  28. Logic Blocks • Logic Functions implemented in Look Up Table LUTs. • Flip-Flops. Registers. Clocked Storage elements. • Multiplexers (select 1 of N inputs) FPGA Fabric Logic Block

  29. Look Up Tables LUTs • LUT contains Memory Cells to implement small logic functions • Each cell holds ‘0’ or ‘1’ . • Programmed with outputs of Truth Table • Inputs select content of one of the cells as output 3 Inputs LUT -> 8 Memory Cells 3 – 6 Inputs Static Random Access Memory SRAM cells Multiplexer MUX

  30. Look Up Tables LUTs • LUT contains Memory Cells to implement small logic functions • Each cell holds ‘0’ or ‘1’ . • Programmed with outputs of Truth Table • Inputs select content of one of the cells as output • Configured by re-programmable SRAM memory cells 3 Inputs LUT -> 8 Memory Cells 3 – 6 Inputs Static Random Access Memory SRAM cells Multiplexer MUX

  31. Logic Blocks • Larger Logic Functions built up by connecting many Logic Blocks together

  32. Logic Blocks • Larger Logic Functions built up by connecting many Logic Blocks together • Determined by SRAM cells SRAM cells

  33. Clocked Logic • Registers on outputs. CLOCKED storage elements. • Synchronous FPGA Logic Design, Pipelined Logic. • FPGA Fabric Pulse from Global Clock (e.g. LHC BX frequency) FPGA Fabric Special Routing for Clocks Clock from Outside world (eg LHC bunch frequency)

  34. Input Output I/O Getting data in and out Up to > 1,000 I/O “pins” (several 100 MHz)

  35. Input Output I/O Getting data in and out Up to > 1,000 I/O “pins” (several 100 MHz) Special I/O SERIALISERS ~ 10 Gbps transfer rates Optical TRx

  36. Designing Logic with FPGAs • Design Capture. • High level Description of Logic Design. • Graphical descriptions • Hardware Description Language (Textual)

  37. Hardware Description Languages • Language describing hardware (Engineers call it FIRMWARE) • Doesn’t behave like “normal” programming language ‘C/C++’ • Describe Logic as collection of Processes operating in Parallel • Language Constructs for Synchronous Logic • Compiler (Synthesis) Tools recognise certain code constructs and generates appropriate logic • Not all constructs can be implemented in FPGA! • 2 Popular languages are VHDL , VERILOG • Easy to start learning… Hard to master!

  38. VHDL ENTITY Declaration Input Output to Module (STD LOGIC) SIGNALS Declaration WIRES CONCURRENT ASSIGNMENTS CONDITIONAL ASSIGNMENTS => MULTIPLEXERS

  39. VHDL PROCESS Declaration. CONCURRENT functions. Synchronous Logic. COMPONENT Declaration

  40. Designing Logic with FPGAs • High level Description of Logic Design • Hardware Description Language (Textual) • Compile (Synthesis) into NETLIST. • Boolean Logic Gates. • Target FPGA Device • Mapping • Routing • Bit File for FPGA • Commercial CAE Tools (Complex & Expensive) • Logic Simulation Design Flow

  41. Designing Logic with FPGAs • High level Description of Logic Design • Hardware Description Language (Textual) • Compile (Synthesis) into NETLIST. • Boolean Logic Gates. • Target FPGA Device • Mapping • Routing • Bit File for FPGA • Commercial CAE Tools (Complex & Expensive) • Logic Simulation Design Flow

  42. Designing Logic with FPGAs • High level Description of Logic Design • Hardware Description Language (Textual) • Compile (Synthesis) into NETLIST. • Boolean Logic Gates. • Target FPGA Device • Mapping • Routing • Bit File for FPGA • Commercial CAE Tools (Complex & Expensive) • Logic Simulation Design Flow

  43. Configuring an FPGA • Millions of SRAMcells holding LUTs and Interconnect Routing • Volatile Memory. Lose configuration when board power is turned off. • Keep Bit Pattern describing the SRAM cells in non-Volatile Memory e.g. PROM or Digital Camera card • Configuration takes ~ secs JTAG Port

  44. Configuring an FPGA • Millions of SRAMcells holding LUTs and Interconnect Routing • Volatile Memory. Lose configuration when board power is turned off. • Keep Bit Pattern describing the SRAM cells in non-Volatile Memory e.g. PROM or Digital Camera card • Configuration takes ~ secs JTAG Port Programming Bit File JTAG Testing

  45. Field Programmable Gate Arrays FPGA • Large Complex Functions • Re-Programmability, Flexibility. • Massively Parallel Architecture • Processing many channels simultaneously cf MicroProcessor • Fast Turnaround Designs  • Standard IC Manufacturing Processes. Moore’s Law • Mass produced. Inexpensive.  • Many variants. Sizes. Features.  • PP Not Radiation Hard  • Power Hungry  • No Analogue 

  46. FPGA Trends • State of Art is 40nm on 300 mm wafers • Top of range >500,000 Logic Blocks • >1,000 pins (Fine Pitched BGA) • Logic Block cost ~ 1$ in 1990 • Today < 0.1 cent • Problems • Power. Leakage currents. • Design Gap • CAE Tools

  47. Summary • Programmable Logic Devices • Basics • Evolution • FPGA Field Programmable Gate Arrays • Architecture • Design Flow • Hardware Description Languages • Design Tools Importance for Particle Physics Experiments

  48. References • The Design Warrior’s Guide to FPGAs • Clive Maxfield, Newnes Elsevier • VHDL for Logic Synthesis • Andrew Rushden, Wiley • FPGA manufacturer web sites • www.xilinx.com • www.altera.com • FPGA Online • www.pldesignline.com • www.fpgajournal.com • www.doulos.com

  49. Spare Slides library IEEE; -- call some library's use IEEE.STD_LOGIC_1164.ALL; -- “--” is a comment USE ieee.std_logic_arith.all; -- define a black box for the component needed entity counter is -- what is the component called port( -- what IO dose it have clk : in std_logic; -- clk = Clock. All synchronous logic has a clock rst : in std_logic; -- rst = reset. Most synchronous logic has a reset. count : out std_logic_vector(7 downto 0) -- 8 wires in a bundle with no interpretation. ); end counter; -- what logic should be in the black box architecture RTL of counter is -- this version on the content of the black box is called “RTL” begin -- start the logic that is inside the black box process (clk,rst) -- start a process i.e. Sequential logic. The list in brackets is a sensitivity list variable v_count : unsigned ( 7 downto 0); -- declare a local variable called v_count begin -- start logic process if rst = '1' then -- async reset i.e. It dose not wait for a clock edge count <= (others => '0'); -- set all the bits of count to zero v_count := (others => '0'); -- set all bits to zero note variable assignment not signal assignment. elsif clk'event and clk = '1' then -- wait for the rising edge of clock v_count := v_count + 1; -- add one to current value of count and asign to end if; end process; count <= conv_std_logic_vector(v_count,8); end RTL;

More Related