FPGA design from scratch
I have been designing ASICs for more than 15 years. A few years ago I started to realize that there is another player in town and that is the FPGA circuit. With increasing NRE costs and with the long turn-around times, ASIC designs have become high-risk projects. At the same time FPGAs are getting bigger and faster and many companies have therefore decided to only use FPGAs. I also realized that I have to learn how to design using FPGAs, if I were to get any consulting jobs, especially here in Sweden. This is my story of how I hopefully will learn to use FPGAs in my future designs.
Part 1
- Introduction
- Ordering the MicroBlaze development kit
- Installing the Integrated Software Environment (ISE)
- Running a board demo test
Part 2
- Design object description
Part 3
- Setting up the Integrated Software Environment (ISE) design software
- Running the Integrated Software Environment (ISE) design software
Part 4
- Adding Verilog source code
- Generating memories using Coregen
- Synthesizing the design
- Simulating the design (Introduction)
Part 5
- Setting up the simulation environment using Mongoose
Part 6
- The simulation process
- Compiling macro libraries
- Compiling the design
- Compiling the testbench
- Elaborating everything
Part 7
- Testbench description
Part 8
- Using HAL the HDL analysis and linting tool from Cadence
Part 9
- Regression testing using Mongoose
Part 10
- Synthesis using timing constraints (Introduction)
Part 11
- The Field Programmable Gate Array (FPGA) description
Part 12
- Adding synthesis constraints
Part 13
- The MicroBlaze soft processor core
- Compiling simulation libraries using compedklib
Part 14
- Putting everything together
- Installing ISE WebPack 9.1i
- Installing EDK 9.1i
Part 15
- Xilinx Platform Studio XPS
- Software Development Kit SDK
- Create a new project in XPS
- Generate a design report file
Part 16
- Create or import an user peripheral
- The MHS file
- XPS project files
- Xilinx IP center
Part 17
- Adding the ETC IP
- Generate the system netlist using platgen
- What happend during the netlist generation
- Generate simulation HDL files
Part 18
- Putting together a system simulation environment
- The simulation database
- The cds.lib file
- Compiling the ETC IP
- Compiling the block RAM
- Compiling Verilog wrappers
- Compiling VHDL wrappers
- Elaborating the design
- Warning messages
Part 19
- Generating a Verilog testbench
Part 20
- Running our first simulation
- Adding the DDR SDRAM
- Suppressing assert messages in IEEE packages
Part 21
- Debugging the simulation testbench
- The reset logic
Part 22
- Using the XPS software development kit (SDK)
- Software development flow
- GNU compiler collection (gcc)
- Running SDK
- Creating a new C appilcation project
Part 23
- Simulating program execution in the MicroBlaze processor
- Verification strategy
- Verification flow
- Writing a simple c program
- Loading the program
- Running an NCSIM simulation
- Simulation result
- Compile and build the program inside SDK
- Generate assembly code and hex code
- Make a NCSIM memory load file
- Running a simulation
Part 24
- System simulations
- DDR SDRAM controller
- LED displays and push buttons
- OPB GPIO registers
- Embedded test controller
- Debugging the On-Chip Peripheral bus
Part 25
- Implementing the hardware platform
- User constraints file
- Setting up our constraints file
- Specify pin constraints
- Specify timing constraints
- The implementation directory
- Start bitstrem generation
- Bitstream generation flow
- Scriptfile to run XFlow
- Bitstream generation result
- Configuration of the FPGA
- Using the platform cable USB
- ML403 evaluation board
- ML403 block diagram
- Installing cable drivers
- Xilinx JTAG tools on Linux without proprietary kernel modules
- Setting up the USB cable
- iMPACT FPGA configuration tool
- Starting iMPACT
Part 26
- Using the iMPACT configuration tool
- Boundary Scan and JTAG configuration
- IEE standard 1149.1 (JTAG)
- The identification register
- Read IDCODE
- Read the FPGA status register
- Device configuration
- Using Xilinx Platform Studio
Part 27
- Pin assignment closure process
- PACE Pin and Area Constraint Editor
- Running PACE
- Topi the Top Code Generator
- Topi setup
- Using Topi to modify the Xilinx user constraints file
- Xilinx Floorplanner
- Viewing pin placement
- Xilinx PlanAhead
Part 28
- Power calculations
- XPower
- Low power consumption
Part 29
- Hardware setup
- Software setup
- Download and execute a simple program
- Download the bitstream
- Get program size
- Running the program
Part 30
- Running demonstration software applications
- ML403 Reference Systemson the CD
Part 31
- Adding a 16x2 character LCD display
- Set address range
- Connecting ports
- The easy way to add a new block
- Configure the IP block
- The LCD driver
- LCD display timing
- 8-bit write operation
- Programming sequence
- Display setup
- More reading
- Signal wiring on the ML403 board
- Adding constraints
- Generate netlist
- Generate bitstream
Part 32
- Writing the "Hello World" program
- SDK platform settings
- C program build
- C header files
- The GPIO API definitions
- C program examples
- Device configuartion in SDK
Part 33
- Simulating the LCD driver
- C program
- Program execution (Waveform plot)
- Generating the software libraries and BSPs
- GNU compiler tools
- Input files
- Output files
- Output from SDK build process
- Display program size
Part 34
- Program disassembly
- MicroBlaze software reference guide
- System memory layout
- Reset sequence
- ELF file content
- Startup files
- First stage initialization files
- Second stage initialization files
Part 35
- Generate simualtion HDL files
- Simgen
- Data2MEM memory tool
- ETC_system_sim.bmm
- ETC_system_init.vhd
- ETC_system_tb.vhd
- Modifying the testbench file
- Compiling the BRAM initialization file
- Compiling the testbench
- Simulating program execution
Part 36
- The LCD driver (once more)
- Editing the user constraints file
- Generate new bitstream
- Device configuration
- Application program
- Displaying "Hello World"
Part 37
- Debugging our design
- Xilinx microprocessor debugger and GNU software debugging tools
- Xilinx microprocessor debugger (XMD)
- MicroBlaze processor target
- MicroBlaze MDM hardware setup
- Debug session
- Reading registers in MicroBlaze
- Load program
- Set breakpoint
- Remove breakpoint
- Display breakpoints
- Start program execution
- Single step
- Stop program execution
- Display program code
- Getting help
- Using XMD in Xilinx Platform Studio
Part 38
- Writing software for our embedded system
- Writing a software device driver
- Software development overview
- Device driver programmer guide
- Platform specification format reference manual
- Microprocessor Driver Definition (MDD)
- Libraries and driver generation
- Device driver architecture
- xparameters.h
- Software driver source code
- Source code repository
- Software device drivers used
- SDK project directory
- Header source files
Part 39
- Fixing our software driver
- etc_v2_1_0.tcl
- etc_v2_1_0.mdd
- Makefile
- xetc_g.c
- xetc.h
- xetc_l.h
- Writing an application program
- Print statements
- Printout from program
- Generate HDL simulation files
- Generating the BRAM initialization file
- Running a simulation
Related Semiconductor IP
- Gen#2 of 64-bit RISC-V core with out-of-order pipeline based complex
- LLM AI IP Core
- Post-Quantum Digital Signature IP Core
- Compact Embedded RISC-V Processor
- Power-OK Monitor
Related White Papers
- Generate FPGA designs from M-code
- Zynq design from scratch
- Retargeting IP -> Design system compiles silicon straight from C code
- IP vendors making leap from source code to silicon
Latest White Papers
- SPAD: Specialized Prefill and Decode Hardware for Disaggregated LLM Inference
- DRsam: Detection of Fault-Based Microarchitectural Side-Channel Attacks in RISC-V Using Statistical Preprocessing and Association Rule Mining
- ShuffleV: A Microarchitectural Defense Strategy against Electromagnetic Side-Channel Attacks in Microprocessors
- Practical Considerations of LDPC Decoder Design in Communications Systems
- A Direct Memory Access Controller (DMAC) for Irregular Data Transfers on RISC-V Linux Systems