ºÝºÝߣ

ºÝºÝߣShare a Scribd company logo
FPGA
Configuration
Majed Roohani
Amirali Sharifian
1
Spring-2013
Introduction
? What is configuration?
? Process for loading data into the FPGA
Configuration
Data
Source
Configuration
Data
Source
FPGAFPGA
Control
Logic
(optional)
Control
Logic
(optional)
2
Introduction
? When does configuration happen?
? On power-up
? On demand
? Why do FPGAs need to be configured?
? FPGA configuration memory is volatile
? What do I need to know about FPGA configuration?
? What happens during configuration
? How to set up various configuration modes and daisy-chains
? How to troubleshoot problems
3
FPGA Configuration Process
? In order to understand the configuration
process, you need to know a little about:
? Configuration modes
? Configuration pins
4
Configuration Modes
? Configuration modes define the specifics of how
the FPGA will interact with:
? The data source
? External control logic (if any)
? Many configuration modes to choose from
? Serial modes (Master and Slave)
? SelectMAP mode (Slave Parallel)
? Boundary scan mode (Slave) - always available
? Other Xilinx FPGA families have more configuration modes
5
Configuration Modes
? Configuration pins (M0, M1, M2))
Note:
6
Configuration Modes:
Serial Modes
? Data is loaded 1 bit per CCLK
? Master serial
? FPGA drives configuration clock
(CCLK)
? FPGA provides all control logic
? Slave serial
? External control logic required to
generate CCLK
? Microprocessor
? Xilinx serial download cable
? Another FPGA
Serial
Data
Serial
Data FPGAFPGA
CCLK
Data
Serial
Data
Serial
Data FPGAFPGA
Control
Logic
Control
Logic
Data
CCLK
7
Configuration Modes:
SelectMAP Mode
? CCLK is driven by
external logic
? Data is loaded 1 byte
per CCLK
Byte-Wide
Data
Byte-Wide
Data FPGAFPGA
Control
Logic
Control
Logic
Data
CCLKControl Signals
Presentation
Name 8
8
Configuration Modes:
Boundary Scan Mode
? External control logic required
? Control signals and data are
presented on the boundary
scan pins (TDI, TMS, TCK)
? Data is loaded 1 bit per TCK
? Always available
(independently on
M0,M1,M2)
Serial
Data
Serial
Data FPGAFPGA
Control
Logic
Control
Logic
Data
Control Signals
9
Configuration Pins
? Specific pins on the FPGA are used during
configuration
? Some pins act differently depending on
configuration mode
? Example: CCLK is an output in some modes
and an input in others
? Some pins are only used in specific configuration
modes
? Example: CCLK is not used for Boundary Scan
mode
10
Configuration Pin Descriptions
? Mode Pins (M0, M1, M2)
? Input pins that select which configuration
mode is being used
? PROGRAM
? Active low input that initiates configuration
? CCLK (Configuration Clock)
? Input or output, depending on configuration
mode
? Frequency up to 10MHz (see Data Book for
your device family)
? DIN
? Serial input for configuration data
11
Configuration Pin Descriptions
? DOUT
? Output to next device in a daisy-chain
? Used in daisy-chains only
? INIT
? Open-drain bi-directional pin
? Error and Power Stabilization Flag
? DONE
? Open-drain bi-directional pin
? Indicates completion of configuration process
? Other pins are used for specific configuration
modes
? (i.e. JTAG Pins)
12
Configuration Process
? Four major phases in the process:
? Configuration memory clear
? Initialization
? Load configuration data
? Start-up
13
Configurati
on Memory
Clear
Configurati
on Memory
Clear
InitializationInitialization
Load
Configurati
on Data
Load
Configurati
on Data
Start-UpStart-Up
Configuration Process
Configuration Memory Clear Phase
? 2 Way to configure
? Non-configuration I/O pins are
disabled with optional pull-up
resistors
? INIT and DONE pins are driven low
? FPGA memory is cleared
? PROGRAM is checked after each
memory pass
? Proceed to initialization
14
Configuration at Power-
Up
Vcc AND Vccnt
High?
No
FPGA
Drives INIT and
DONE low
Configuration During
User Operation
User Pulls
PROGRAM
low
Yes
Clear
Configuration
Memory
User Holding
PROGRAM low?
Yes
Initialization
No
Configuration Process:
Initialization Phase
? INIT pin is released
? INIT may be held low externally to
delay configuration
? Mode pins are sampled
? Appropriate configuration pins
become active
? Proceed to load configuration
data
15
Configuration
Memory
Clear
Release INIT
INIT
High?
Yes
Sample
Mode Pins
Load
Configuration
Data
No
Configuration Process:
Load Configuration Data Phase
? FPGA starts receiving data
? CRC is checked during the
data frames transmission
? If incorrect value received, INIT is
driven low and rest of data is
ignored
? If the CRC checks pass,
proceed to start-up
16
Initialization
Load Data
Frames
CRC
Correct?
Yes
Start-UP
No
Pull INIT
Low
Configuration Process:
Start-up Phase
? Transition phase from configuration to
normal operation
? Order of events is user programmable
? Accessed through software options
? Default sequence is:
? DONE pin is released
? All I/O pins become active
? Global write enable released
? Global reset released
? FPGA is operational
17
Load
Configuration
Data
Release
DONE
Activate
I/O Pins
Release
GWE
Release
GSR
FPGA is
Operational
Configuration Process:
Start-up Phase
? Default sequence is:
? DONE pin is released
? All I/O pins become active
? Global write enable released
? Global reset released
? Another useful sequence is ¡°Sync to
DONE¡±
? Useful for multiple FPGA configuration
(Daisy chain)
? Configuration option
18
Master Serial Mode
? All mode pins tied low
? FPGA drives CCLK as an
output
? Data stream loaded 1 bit at
a time
? Use when data stream is
stored in a serial PROM
19
Slave Serial Mode
? All mode pins tied high
? FPGA receives CCLK as an
input
? Data stream loaded 1 bit at
a time
? Use with the Xilinx serial
download cable
20
What Is a Daisy-Chain?
? Multiple FPGAs connected in series for
configuration
? Allows configuration of many devices from a single data
source
? Minimal board traces
? First device in the chain can be in master serial or
slave serial mode
? All other devices must be in slave serial mode
21
Daisy-Chain Question
? How do you think these FPGAs could be connected to
form a Daisy-chain?
22
Daisy-Chain Answer
? Connect all PROGRAM, CCLK and DONE pins together
? Connect each DOUT to the DIN of next device
? Recommend connecting INIT pins, but not required
23
Creating a Daisy-Chain
? Connect PROGRAM pins
? Required so that all FPGAs will reprogram together
? Connect CCLK pins
? Required so that all FPGAs are synchronized with each other and
with the configuration data
? Connect DONE pins
? Required so that all FPGAs start-up together
? Connect each DOUT to the DIN of next device
? Required to allow each FPGA to receive configuration data
? Connect INIT pins
? Recommended to create a single error flag, but not required
24
How a Daisy-Chain Works
? First FPGA in the chain is configured first
? Keeps DOUT high until its configuration memory is full
? Then data is passed to the next device in the chain
? Start-up sequence occurs after all devices are
configured
? FPGA devices pause after internally releasing DONE, and
continue when DONE externally goes high
25
Xilinx In-System Programming
Using an
Embedded Microcontroller
? Use XAPP 058(v 4.1)
? Virtex? series
? Spartan? series
? CoolRunner? series
? XC9500 series
? Platform Flash PROM family
? XC18V00 family
30
important benefits of in-system
programmability
? Reduces device handling costs and time to market
? Saves the expense of laying out new PC boards
? Allows remote maintenance, modification, and testing
? Increases the life span and functionality of products
? Enables unique, customer-specific features
31
Microcontroller and JTAG
Chain Schematic
32
XSVF File Generation Flow to
Embedded System
33
C-code and header files
? lenval.c
? micro.c
? ports.c
? lenval.h
? micro.h
? ports.h
34
Configuration PROM
Programming File Creation
Storage Flow
35
CPLD Programming File
Creation and Storage Flow
36
FPGA Programming File
Creation and Storage Flow
37
Selected iMPACT Batch
Command
38
Using the iMPACT GUI to
Create XSVF Files
39
Write XSVF file to selected
Device
40
IMPACT batch command
41
Summary
? Field programmable devices are configured on power-up
from an external data source
? The phases of the configuration process are:
? Configuration memory clear
? Initialization
? Load configuration data
? Start-up
? Master serial and slave serial are the simplest configuration
modes
42

More Related Content

What's hot (20)

Clock divider by 3
Clock divider by 3Clock divider by 3
Clock divider by 3
Ashok Reddy
?
Study of inter and intra chip variations
Study of inter and intra chip variationsStudy of inter and intra chip variations
Study of inter and intra chip variations
Rajesh M
?
Programmable asic i/o cells
Programmable asic i/o cellsProgrammable asic i/o cells
Programmable asic i/o cells
Yalagoud Patil
?
Multi mode multi corner (mmmc)
Multi mode multi corner (mmmc)Multi mode multi corner (mmmc)
Multi mode multi corner (mmmc)
shaik sharief
?
FPGA TECHNOLOGY AND FAMILIES
FPGA TECHNOLOGY AND FAMILIESFPGA TECHNOLOGY AND FAMILIES
FPGA TECHNOLOGY AND FAMILIES
revathilakshmi2
?
Contamination delay
Contamination delayContamination delay
Contamination delay
Nima Afraz
?
Fpga
FpgaFpga
Fpga
bharadwajareddy
?
Flip Chip technology
Flip Chip technologyFlip Chip technology
Flip Chip technology
Mantra VLSI
?
Divide by N clock
Divide by N clockDivide by N clock
Divide by N clock
Mantra VLSI
?
Verilog tutorial
Verilog tutorialVerilog tutorial
Verilog tutorial
Maryala Srinivas
?
FPGA DESIGN FLOW.pdf
FPGA DESIGN FLOW.pdfFPGA DESIGN FLOW.pdf
FPGA DESIGN FLOW.pdf
RMDAcademicCoordinat
?
Introduction to FPGAs
Introduction to FPGAsIntroduction to FPGAs
Introduction to FPGAs
Sudhanshu Janwadkar
?
Vlsi physical design-notes
Vlsi physical design-notesVlsi physical design-notes
Vlsi physical design-notes
Dr.YNM
?
FPGA
FPGAFPGA
FPGA
subin mathew
?
Introduction to System verilog
Introduction to System verilog Introduction to System verilog
Introduction to System verilog
Pushpa Yakkala
?
Placement in VLSI Design
Placement in VLSI DesignPlacement in VLSI Design
Placement in VLSI Design
Team-VLSI-ITMU
?
Timing issues in digital circuits
Timing issues in digital circuitsTiming issues in digital circuits
Timing issues in digital circuits
aroosa khan
?
Timing Analysis
Timing AnalysisTiming Analysis
Timing Analysis
rchovatiya
?
Timing and Design Closure in Physical Design Flows
Timing and Design Closure in Physical Design Flows Timing and Design Closure in Physical Design Flows
Timing and Design Closure in Physical Design Flows
Olivier Coudert
?
SPI introduction(Serial Peripheral Interface)
SPI introduction(Serial Peripheral Interface)SPI introduction(Serial Peripheral Interface)
SPI introduction(Serial Peripheral Interface)
SUNODH GARLAPATI
?
Study of inter and intra chip variations
Study of inter and intra chip variationsStudy of inter and intra chip variations
Study of inter and intra chip variations
Rajesh M
?
Programmable asic i/o cells
Programmable asic i/o cellsProgrammable asic i/o cells
Programmable asic i/o cells
Yalagoud Patil
?
Multi mode multi corner (mmmc)
Multi mode multi corner (mmmc)Multi mode multi corner (mmmc)
Multi mode multi corner (mmmc)
shaik sharief
?
FPGA TECHNOLOGY AND FAMILIES
FPGA TECHNOLOGY AND FAMILIESFPGA TECHNOLOGY AND FAMILIES
FPGA TECHNOLOGY AND FAMILIES
revathilakshmi2
?
Contamination delay
Contamination delayContamination delay
Contamination delay
Nima Afraz
?
Flip Chip technology
Flip Chip technologyFlip Chip technology
Flip Chip technology
Mantra VLSI
?
Vlsi physical design-notes
Vlsi physical design-notesVlsi physical design-notes
Vlsi physical design-notes
Dr.YNM
?
Introduction to System verilog
Introduction to System verilog Introduction to System verilog
Introduction to System verilog
Pushpa Yakkala
?
Timing issues in digital circuits
Timing issues in digital circuitsTiming issues in digital circuits
Timing issues in digital circuits
aroosa khan
?
Timing and Design Closure in Physical Design Flows
Timing and Design Closure in Physical Design Flows Timing and Design Closure in Physical Design Flows
Timing and Design Closure in Physical Design Flows
Olivier Coudert
?
SPI introduction(Serial Peripheral Interface)
SPI introduction(Serial Peripheral Interface)SPI introduction(Serial Peripheral Interface)
SPI introduction(Serial Peripheral Interface)
SUNODH GARLAPATI
?

Similar to FPGA Configuration (20)

Steen_Dissertation_March5
Steen_Dissertation_March5Steen_Dissertation_March5
Steen_Dissertation_March5
Steen Larsen
?
Ccna day2
Ccna day2Ccna day2
Ccna day2
Sabiulla Barkathullah
?
Ccna day2
Ccna day2Ccna day2
Ccna day2
AHMED NADIM JILANI
?
Ccna day2
Ccna day2Ccna day2
Ccna day2
Vijay Kumar
?
Ccna day2-140715152313-phpapp02
Ccna day2-140715152313-phpapp02Ccna day2-140715152313-phpapp02
Ccna day2-140715152313-phpapp02
Sachin Morya
?
Ccna 2
Ccna 2Ccna 2
Ccna 2
Reetesh Gupta
?
Ccna day2
Ccna day2Ccna day2
Ccna day2
danishrafiq
?
Ccna PPT2
Ccna PPT2Ccna PPT2
Ccna PPT2
AIRTEL
?
Organisasi dan Arsitektur Komputer MO-06
Organisasi dan Arsitektur Komputer MO-06Organisasi dan Arsitektur Komputer MO-06
Organisasi dan Arsitektur Komputer MO-06
EriekOrlando
?
C C N A Day2
C C N A  Day2C C N A  Day2
C C N A Day2
darulquthni
?
Softcore processor.pptxSoftcore processor.pptxSoftcore processor.pptx
Softcore processor.pptxSoftcore processor.pptxSoftcore processor.pptxSoftcore processor.pptxSoftcore processor.pptxSoftcore processor.pptx
Softcore processor.pptxSoftcore processor.pptxSoftcore processor.pptx
SnehaLatha68
?
Ls catalog thiet bi tu dong gm e_0908_dienhathe.vn
Ls catalog thiet bi tu dong gm e_0908_dienhathe.vnLs catalog thiet bi tu dong gm e_0908_dienhathe.vn
Ls catalog thiet bi tu dong gm e_0908_dienhathe.vn
Dien Ha The
?
Ls catalog thiet bi tu dong gm e_0908
Ls catalog thiet bi tu dong gm e_0908Ls catalog thiet bi tu dong gm e_0908
Ls catalog thiet bi tu dong gm e_0908
Dien Ha The
?
Lcu14 101- coresight overview
Lcu14 101- coresight overviewLcu14 101- coresight overview
Lcu14 101- coresight overview
Linaro
?
SoC Idling for unconf COSCUP 2016
SoC Idling for unconf COSCUP 2016SoC Idling for unconf COSCUP 2016
SoC Idling for unconf COSCUP 2016
Koan-Sin Tan
?
Smart logic
Smart logicSmart logic
Smart logic
P V Krishna Mohan Gupta
?
Ccna Imp Guide
Ccna Imp GuideCcna Imp Guide
Ccna Imp Guide
abhijitgnbbl
?
AD-IP-JESD204 JESD204B Interface Framework
AD-IP-JESD204 JESD204B Interface FrameworkAD-IP-JESD204 JESD204B Interface Framework
AD-IP-JESD204 JESD204B Interface Framework
Analog Devices, Inc.
?
Hpe Proliant DL20 Gen10 Server Datasheet
Hpe Proliant DL20 Gen10 Server DatasheetHpe Proliant DL20 Gen10 Server Datasheet
Hpe Proliant DL20 Gen10 Server Datasheet
ÃÀÀ¼ Ôø
?
Cyclone II FPGA Overview
Cyclone II FPGA OverviewCyclone II FPGA Overview
Cyclone II FPGA Overview
Premier Farnell
?
Steen_Dissertation_March5
Steen_Dissertation_March5Steen_Dissertation_March5
Steen_Dissertation_March5
Steen Larsen
?
Ccna day2-140715152313-phpapp02
Ccna day2-140715152313-phpapp02Ccna day2-140715152313-phpapp02
Ccna day2-140715152313-phpapp02
Sachin Morya
?
Organisasi dan Arsitektur Komputer MO-06
Organisasi dan Arsitektur Komputer MO-06Organisasi dan Arsitektur Komputer MO-06
Organisasi dan Arsitektur Komputer MO-06
EriekOrlando
?
Softcore processor.pptxSoftcore processor.pptxSoftcore processor.pptx
Softcore processor.pptxSoftcore processor.pptxSoftcore processor.pptxSoftcore processor.pptxSoftcore processor.pptxSoftcore processor.pptx
Softcore processor.pptxSoftcore processor.pptxSoftcore processor.pptx
SnehaLatha68
?
Ls catalog thiet bi tu dong gm e_0908_dienhathe.vn
Ls catalog thiet bi tu dong gm e_0908_dienhathe.vnLs catalog thiet bi tu dong gm e_0908_dienhathe.vn
Ls catalog thiet bi tu dong gm e_0908_dienhathe.vn
Dien Ha The
?
Ls catalog thiet bi tu dong gm e_0908
Ls catalog thiet bi tu dong gm e_0908Ls catalog thiet bi tu dong gm e_0908
Ls catalog thiet bi tu dong gm e_0908
Dien Ha The
?
Lcu14 101- coresight overview
Lcu14 101- coresight overviewLcu14 101- coresight overview
Lcu14 101- coresight overview
Linaro
?
SoC Idling for unconf COSCUP 2016
SoC Idling for unconf COSCUP 2016SoC Idling for unconf COSCUP 2016
SoC Idling for unconf COSCUP 2016
Koan-Sin Tan
?
AD-IP-JESD204 JESD204B Interface Framework
AD-IP-JESD204 JESD204B Interface FrameworkAD-IP-JESD204 JESD204B Interface Framework
AD-IP-JESD204 JESD204B Interface Framework
Analog Devices, Inc.
?
Hpe Proliant DL20 Gen10 Server Datasheet
Hpe Proliant DL20 Gen10 Server DatasheetHpe Proliant DL20 Gen10 Server Datasheet
Hpe Proliant DL20 Gen10 Server Datasheet
ÃÀÀ¼ Ôø
?

Recently uploaded (20)

STARLINK-JIO-AIRTEL Security issues to Ponder
STARLINK-JIO-AIRTEL Security issues to PonderSTARLINK-JIO-AIRTEL Security issues to Ponder
STARLINK-JIO-AIRTEL Security issues to Ponder
anupriti
?
Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5
Margaret Maynard-Reid
?
Recruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OGRecruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OG
Matt Charney
?
ºÝºÝߣs from Perth MuleSoft Meetup March 2025
ºÝºÝߣs from Perth MuleSoft Meetup March 2025ºÝºÝߣs from Perth MuleSoft Meetup March 2025
ºÝºÝߣs from Perth MuleSoft Meetup March 2025
Michael Price
?
When Platform Engineers meet SREs - The Birth of O11y-as-a-Service Superpowers
When Platform Engineers meet SREs - The Birth of O11y-as-a-Service SuperpowersWhen Platform Engineers meet SREs - The Birth of O11y-as-a-Service Superpowers
When Platform Engineers meet SREs - The Birth of O11y-as-a-Service Superpowers
Eric D. Schabell
?
I am afraid of no test! The power of BDD
I am afraid of no test! The power of BDDI am afraid of no test! The power of BDD
I am afraid of no test! The power of BDD
Ortus Solutions, Corp
?
The Road to SAP S4HANA Cloud with SAP Activate.pptx
The Road to SAP S4HANA Cloud with SAP Activate.pptxThe Road to SAP S4HANA Cloud with SAP Activate.pptx
The Road to SAP S4HANA Cloud with SAP Activate.pptx
zsbaranyai
?
selection of competencies requiring ICT integration.pptx
selection of competencies requiring ICT integration.pptxselection of competencies requiring ICT integration.pptx
selection of competencies requiring ICT integration.pptx
escuyoscherrymae
?
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
voginip
?
Presentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdfPresentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdf
Mukesh Kala
?
SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...
SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...
SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...
IBsolution GmbH
?
All-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-World
All-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-WorldAll-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-World
All-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-World
Safe Software
?
Packaging your App for AppExchange ¨C Managed Vs Unmanaged.pptx
Packaging your App for AppExchange ¨C Managed Vs Unmanaged.pptxPackaging your App for AppExchange ¨C Managed Vs Unmanaged.pptx
Packaging your App for AppExchange ¨C Managed Vs Unmanaged.pptx
mohayyudin7826
?
Dragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN NB-IoT LTE cat.M1ÉÌÆ·¥ê¥¹¥È
Dragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN  NB-IoT  LTE cat.M1ÉÌÆ·¥ê¥¹¥ÈDragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN  NB-IoT  LTE cat.M1ÉÌÆ·¥ê¥¹¥È
Dragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN NB-IoT LTE cat.M1ÉÌÆ·¥ê¥¹¥È
CRI Japan, Inc.
?
AI-Driven Digital Transformation Using Agentic AI
AI-Driven Digital Transformation Using Agentic AIAI-Driven Digital Transformation Using Agentic AI
AI-Driven Digital Transformation Using Agentic AI
Kris Verlaenen
?
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
jackalen173
?
RBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptx
RBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptxRBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptx
RBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptx
quinlan4
?
UiPath NY AI Series: Session 3: UiPath Autopilot for Everyone with Clipboard AI
UiPath NY AI Series: Session 3:  UiPath Autopilot for Everyone with Clipboard AIUiPath NY AI Series: Session 3:  UiPath Autopilot for Everyone with Clipboard AI
UiPath NY AI Series: Session 3: UiPath Autopilot for Everyone with Clipboard AI
DianaGray10
?
Graphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAIGraphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAI
Neo4j
?
UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8
DianaGray10
?
STARLINK-JIO-AIRTEL Security issues to Ponder
STARLINK-JIO-AIRTEL Security issues to PonderSTARLINK-JIO-AIRTEL Security issues to Ponder
STARLINK-JIO-AIRTEL Security issues to Ponder
anupriti
?
Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5
Margaret Maynard-Reid
?
Recruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OGRecruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OG
Matt Charney
?
ºÝºÝߣs from Perth MuleSoft Meetup March 2025
ºÝºÝߣs from Perth MuleSoft Meetup March 2025ºÝºÝߣs from Perth MuleSoft Meetup March 2025
ºÝºÝߣs from Perth MuleSoft Meetup March 2025
Michael Price
?
When Platform Engineers meet SREs - The Birth of O11y-as-a-Service Superpowers
When Platform Engineers meet SREs - The Birth of O11y-as-a-Service SuperpowersWhen Platform Engineers meet SREs - The Birth of O11y-as-a-Service Superpowers
When Platform Engineers meet SREs - The Birth of O11y-as-a-Service Superpowers
Eric D. Schabell
?
I am afraid of no test! The power of BDD
I am afraid of no test! The power of BDDI am afraid of no test! The power of BDD
I am afraid of no test! The power of BDD
Ortus Solutions, Corp
?
The Road to SAP S4HANA Cloud with SAP Activate.pptx
The Road to SAP S4HANA Cloud with SAP Activate.pptxThe Road to SAP S4HANA Cloud with SAP Activate.pptx
The Road to SAP S4HANA Cloud with SAP Activate.pptx
zsbaranyai
?
selection of competencies requiring ICT integration.pptx
selection of competencies requiring ICT integration.pptxselection of competencies requiring ICT integration.pptx
selection of competencies requiring ICT integration.pptx
escuyoscherrymae
?
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
voginip
?
Presentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdfPresentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdf
Mukesh Kala
?
SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...
SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...
SAP Business Data Cloud: Was die neue SAP-L?sung f¨¹r Unternehmen und ihre Dat...
IBsolution GmbH
?
All-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-World
All-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-WorldAll-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-World
All-Data, Any-AI Integration: FME & Amazon Bedrock in the Real-World
Safe Software
?
Packaging your App for AppExchange ¨C Managed Vs Unmanaged.pptx
Packaging your App for AppExchange ¨C Managed Vs Unmanaged.pptxPackaging your App for AppExchange ¨C Managed Vs Unmanaged.pptx
Packaging your App for AppExchange ¨C Managed Vs Unmanaged.pptx
mohayyudin7826
?
Dragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN NB-IoT LTE cat.M1ÉÌÆ·¥ê¥¹¥È
Dragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN  NB-IoT  LTE cat.M1ÉÌÆ·¥ê¥¹¥ÈDragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN  NB-IoT  LTE cat.M1ÉÌÆ·¥ê¥¹¥È
Dragino¥×¥í¥À¥¯¥È¥«¥¿¥í¥° LoRaWAN NB-IoT LTE cat.M1ÉÌÆ·¥ê¥¹¥È
CRI Japan, Inc.
?
AI-Driven Digital Transformation Using Agentic AI
AI-Driven Digital Transformation Using Agentic AIAI-Driven Digital Transformation Using Agentic AI
AI-Driven Digital Transformation Using Agentic AI
Kris Verlaenen
?
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
jackalen173
?
RBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptx
RBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptxRBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptx
RBM - PIXIAGE - AskPixi Page - Inpixon-MWC 2025.pptx
quinlan4
?
UiPath NY AI Series: Session 3: UiPath Autopilot for Everyone with Clipboard AI
UiPath NY AI Series: Session 3:  UiPath Autopilot for Everyone with Clipboard AIUiPath NY AI Series: Session 3:  UiPath Autopilot for Everyone with Clipboard AI
UiPath NY AI Series: Session 3: UiPath Autopilot for Everyone with Clipboard AI
DianaGray10
?
Graphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAIGraphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAI
Neo4j
?
UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8
DianaGray10
?

FPGA Configuration

  • 2. Introduction ? What is configuration? ? Process for loading data into the FPGA Configuration Data Source Configuration Data Source FPGAFPGA Control Logic (optional) Control Logic (optional) 2
  • 3. Introduction ? When does configuration happen? ? On power-up ? On demand ? Why do FPGAs need to be configured? ? FPGA configuration memory is volatile ? What do I need to know about FPGA configuration? ? What happens during configuration ? How to set up various configuration modes and daisy-chains ? How to troubleshoot problems 3
  • 4. FPGA Configuration Process ? In order to understand the configuration process, you need to know a little about: ? Configuration modes ? Configuration pins 4
  • 5. Configuration Modes ? Configuration modes define the specifics of how the FPGA will interact with: ? The data source ? External control logic (if any) ? Many configuration modes to choose from ? Serial modes (Master and Slave) ? SelectMAP mode (Slave Parallel) ? Boundary scan mode (Slave) - always available ? Other Xilinx FPGA families have more configuration modes 5
  • 6. Configuration Modes ? Configuration pins (M0, M1, M2)) Note: 6
  • 7. Configuration Modes: Serial Modes ? Data is loaded 1 bit per CCLK ? Master serial ? FPGA drives configuration clock (CCLK) ? FPGA provides all control logic ? Slave serial ? External control logic required to generate CCLK ? Microprocessor ? Xilinx serial download cable ? Another FPGA Serial Data Serial Data FPGAFPGA CCLK Data Serial Data Serial Data FPGAFPGA Control Logic Control Logic Data CCLK 7
  • 8. Configuration Modes: SelectMAP Mode ? CCLK is driven by external logic ? Data is loaded 1 byte per CCLK Byte-Wide Data Byte-Wide Data FPGAFPGA Control Logic Control Logic Data CCLKControl Signals Presentation Name 8 8
  • 9. Configuration Modes: Boundary Scan Mode ? External control logic required ? Control signals and data are presented on the boundary scan pins (TDI, TMS, TCK) ? Data is loaded 1 bit per TCK ? Always available (independently on M0,M1,M2) Serial Data Serial Data FPGAFPGA Control Logic Control Logic Data Control Signals 9
  • 10. Configuration Pins ? Specific pins on the FPGA are used during configuration ? Some pins act differently depending on configuration mode ? Example: CCLK is an output in some modes and an input in others ? Some pins are only used in specific configuration modes ? Example: CCLK is not used for Boundary Scan mode 10
  • 11. Configuration Pin Descriptions ? Mode Pins (M0, M1, M2) ? Input pins that select which configuration mode is being used ? PROGRAM ? Active low input that initiates configuration ? CCLK (Configuration Clock) ? Input or output, depending on configuration mode ? Frequency up to 10MHz (see Data Book for your device family) ? DIN ? Serial input for configuration data 11
  • 12. Configuration Pin Descriptions ? DOUT ? Output to next device in a daisy-chain ? Used in daisy-chains only ? INIT ? Open-drain bi-directional pin ? Error and Power Stabilization Flag ? DONE ? Open-drain bi-directional pin ? Indicates completion of configuration process ? Other pins are used for specific configuration modes ? (i.e. JTAG Pins) 12
  • 13. Configuration Process ? Four major phases in the process: ? Configuration memory clear ? Initialization ? Load configuration data ? Start-up 13 Configurati on Memory Clear Configurati on Memory Clear InitializationInitialization Load Configurati on Data Load Configurati on Data Start-UpStart-Up
  • 14. Configuration Process Configuration Memory Clear Phase ? 2 Way to configure ? Non-configuration I/O pins are disabled with optional pull-up resistors ? INIT and DONE pins are driven low ? FPGA memory is cleared ? PROGRAM is checked after each memory pass ? Proceed to initialization 14 Configuration at Power- Up Vcc AND Vccnt High? No FPGA Drives INIT and DONE low Configuration During User Operation User Pulls PROGRAM low Yes Clear Configuration Memory User Holding PROGRAM low? Yes Initialization No
  • 15. Configuration Process: Initialization Phase ? INIT pin is released ? INIT may be held low externally to delay configuration ? Mode pins are sampled ? Appropriate configuration pins become active ? Proceed to load configuration data 15 Configuration Memory Clear Release INIT INIT High? Yes Sample Mode Pins Load Configuration Data No
  • 16. Configuration Process: Load Configuration Data Phase ? FPGA starts receiving data ? CRC is checked during the data frames transmission ? If incorrect value received, INIT is driven low and rest of data is ignored ? If the CRC checks pass, proceed to start-up 16 Initialization Load Data Frames CRC Correct? Yes Start-UP No Pull INIT Low
  • 17. Configuration Process: Start-up Phase ? Transition phase from configuration to normal operation ? Order of events is user programmable ? Accessed through software options ? Default sequence is: ? DONE pin is released ? All I/O pins become active ? Global write enable released ? Global reset released ? FPGA is operational 17 Load Configuration Data Release DONE Activate I/O Pins Release GWE Release GSR FPGA is Operational
  • 18. Configuration Process: Start-up Phase ? Default sequence is: ? DONE pin is released ? All I/O pins become active ? Global write enable released ? Global reset released ? Another useful sequence is ¡°Sync to DONE¡± ? Useful for multiple FPGA configuration (Daisy chain) ? Configuration option 18
  • 19. Master Serial Mode ? All mode pins tied low ? FPGA drives CCLK as an output ? Data stream loaded 1 bit at a time ? Use when data stream is stored in a serial PROM 19
  • 20. Slave Serial Mode ? All mode pins tied high ? FPGA receives CCLK as an input ? Data stream loaded 1 bit at a time ? Use with the Xilinx serial download cable 20
  • 21. What Is a Daisy-Chain? ? Multiple FPGAs connected in series for configuration ? Allows configuration of many devices from a single data source ? Minimal board traces ? First device in the chain can be in master serial or slave serial mode ? All other devices must be in slave serial mode 21
  • 22. Daisy-Chain Question ? How do you think these FPGAs could be connected to form a Daisy-chain? 22
  • 23. Daisy-Chain Answer ? Connect all PROGRAM, CCLK and DONE pins together ? Connect each DOUT to the DIN of next device ? Recommend connecting INIT pins, but not required 23
  • 24. Creating a Daisy-Chain ? Connect PROGRAM pins ? Required so that all FPGAs will reprogram together ? Connect CCLK pins ? Required so that all FPGAs are synchronized with each other and with the configuration data ? Connect DONE pins ? Required so that all FPGAs start-up together ? Connect each DOUT to the DIN of next device ? Required to allow each FPGA to receive configuration data ? Connect INIT pins ? Recommended to create a single error flag, but not required 24
  • 25. How a Daisy-Chain Works ? First FPGA in the chain is configured first ? Keeps DOUT high until its configuration memory is full ? Then data is passed to the next device in the chain ? Start-up sequence occurs after all devices are configured ? FPGA devices pause after internally releasing DONE, and continue when DONE externally goes high 25
  • 26. Xilinx In-System Programming Using an Embedded Microcontroller ? Use XAPP 058(v 4.1) ? Virtex? series ? Spartan? series ? CoolRunner? series ? XC9500 series ? Platform Flash PROM family ? XC18V00 family 30
  • 27. important benefits of in-system programmability ? Reduces device handling costs and time to market ? Saves the expense of laying out new PC boards ? Allows remote maintenance, modification, and testing ? Increases the life span and functionality of products ? Enables unique, customer-specific features 31
  • 29. XSVF File Generation Flow to Embedded System 33
  • 30. C-code and header files ? lenval.c ? micro.c ? ports.c ? lenval.h ? micro.h ? ports.h 34
  • 31. Configuration PROM Programming File Creation Storage Flow 35
  • 32. CPLD Programming File Creation and Storage Flow 36
  • 33. FPGA Programming File Creation and Storage Flow 37
  • 35. Using the iMPACT GUI to Create XSVF Files 39
  • 36. Write XSVF file to selected Device 40
  • 38. Summary ? Field programmable devices are configured on power-up from an external data source ? The phases of the configuration process are: ? Configuration memory clear ? Initialization ? Load configuration data ? Start-up ? Master serial and slave serial are the simplest configuration modes 42

Editor's Notes

  • #31: ????? ?????? ??? ????? xapp
  • #34: ????? ?? ?????? ???? ?? ???? ??????? ? ????? ?? ???? ??