This is the code repository for FPGA Programming for Beginners, published by Packt.
Learn FPGA Programming, published by Packt
Field Programmable Gate Arrays (FPGAs) have now become a core part of most modern electronic and computer systems. However, to implement your ideas in the real world, you need to get your head around the FPGA architecture, its toolset, and critical design considerations. FPGA Programming for Beginners will help you bring your ideas to life by guiding you through the entire process of programming FPGAs and designing hardware circuits using SystemVerilog.
This book covers the following exciting features:
- Understand the FPGA architecture and its implementation
- Get to grips with writing SystemVerilog RTL
- Make FPGA projects using SystemVerilog programming
- Work with computer math basics, parallelism, and pipelining
- Explore the advanced topics of AXI and serial interfaces
- Discover how you can implement a VGA interface in your projects
If you feel this book is for you, get your copy today!
All of the code is organized into folders. For example, Chapter02.
The code will look like the following:
always @(posedge CK) begin
stage = D;
Q = stage;
end
Following is what you need for this book: This FPGA design book is for embedded system developers, engineers, and programmers who want to learn FPGA and SystemVerilog programming from scratch. FPGA designers looking to gain hands-on experience in working on real-world projects will also find this book useful.
With the following software and hardware list you can run all code files present in the book (Chapter 1-11).
Chapter | Software required | OS required |
---|---|---|
1-11 | Xilinx Vivado 2020.1 | Windows, Linux (Centos 7.4-7.7 or Ubuntu 18.04 or 20.04) |
1-11 | Nexys A7 Board | Windows, Linux (Centos 7.4-7.7 or Ubuntu 18.04 or 20.04) |
We also provide a PDF file that has color images of the screenshots/diagrams used in this book. Click here to download it.
- Page 24 (Paragraph 2, line 4) and Page 34 (Paragraph 1, line 2): Appendix should be github folder /CHx/build/ which contains the tcl file for non-project
Frank Bruno is an experienced high-performance design engineer specializing in FPGAs with some ASIC experience. He has worked for companies such as SpaceX and Number Nine, and currently works as an FPGA engineer for Allstone Trading.