This comprehensive course is a thorough introduction to the Verilog language. The emphasis is on writing Register Transfer Level (RTL) and behavioral source code. This class addresses targeting Xilinx devices specifically and FPGA devices in general. The information gained can be applied to any digital design by using a top-down synthesis design approach. This course combines insightful lectures with practical lab exercises to reinforce key concepts. You will also learn advanced coding techniques that will increase your overall Verilog proficiency and enhance your FPGA optimization. This course covers Verilog 1995 and 2001.
In this three-day course, you will gain valuable hands-on experience. Incoming students with little or no Verilog knowledge will finish this course empowered with the ability to write efficient hardware designs and perform high-level HDL simulations.
Who Should Attend?
Engineers who want to use Verilog effectively for modeling, design, and synthesis of digital designs
- Basic digital design knowledge
- Vivado® Design or System Edition 2016.1
- Architecture: N/A*
- Demo board: Kintex®-7 FPGA KC705 board*
* This course does not focus on any particular architecture. Check with your local Authorized Training Provider for the specifics of the in-class lab board or other customizations.
After completing this training, you will know how to:
- Write RTL Verilog code for synthesis
- Write Verilog test fixtures for simulation
- Create a Finite State Machine (FSM) by using Verilog
- Target and optimize Xilinx FPGAs by using Verilog
- Use enhanced Verilog file I/O capability
- Run a timing simulation by using Xilinx Simprim libraries
- Create and manage designs within the Vivado Design Suite environment
- Download to the evaluation demo board
- Hardware Modeling Overview
- Verilog Language Concepts
- Modules and Ports
- Demo: Multiplexer
- Lab 1: Building Hierarchy
- Introduction to Testbenches
- Lab 2: Verilog Simulation and RTL Verification
- Verilog Operators and Expressions
- Continuous Assign Statements
- Lab 3: Creating a Simple Memory
- Verilog Procedural Statements
- Lab 4: Building the Clock Divider and Address Counter
- Controlled Operation Statements
- Lab 5: Creating an n-bit Binary Counter
- Verilog Tasks and Functions
- Advanced Language Concepts
- Finite State Machines
- Lab 6 Building a Finite State Machine
- Targeting Xilinx FPGAs
- Lab 7: Implementing and Downloading the Design
- Advanced Verilog Testbenches
- Lab 8: Using Verilog File I/O
The labs for this course provide a practical foundation for creating synthesizable RTL code. All aspects of the design flow are covered in the labs. The labs are written, synthesized, behaviorally simulated, and implemented by the student. The focus of the labs is to write code that will optimally infer reliable and high-performance circuits. The labs culminate in a functional calculator that students verify in simulation.
- Absolutely. The instructor for this course was extremely knowledgable, and presented the material very very well. This was one of the best courses I have taken in a very long time, and it was completely due to the instructor's capabilities and presentation style. I was very impressed. If I was going to recommend this course to anyone, it would be specifically in conjunction with this instructor. Nice job!
- Instructor was excellent. He has 1st hand real world exprience which makes all the difference.
- This instructor really, really knows his Verilog. I don't know anyone else with this in-depth knowledge of Verilog. Impressive.
- A great course taught by an extremely knowledgable teacher. I was amazed by how much I learnt within such a short time of just 24 hours!
- Instructor was excellent. His overall presentaion style and ability to understand and answer questions was outstanding.
For class schedules as well as tuition and registration information, please contact one of our Authorized Training Providers: