data:image/s3,"s3://crabby-images/547f9/547f9dd40ad9e7dbb898a8efe7e898893d556eae" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Project Components
-
Hardware
Spartan-7 SP701 FPGA with MIPI interface implemented using resistor network
data:image/s3,"s3://crabby-images/70c14/70c14cde408f5d86f762f4196d225c6388e47be0" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
OV5640 MIPI interface
-
Software
AMD Vivado version 2020 or above
AMD Vitis 2020
Introduction
MIPI interface is very popular now, and domestic FPGAs generally come with MIPI interfaces. AMD-Xilinx started supporting MIPI levels from the U+ series. From the usage in China, the Spartan-7 FPGA is the most widely used device, so this example uses the Spartan-7 FPGA to implement MIPI levels using a resistor network. For specific hardware solutions, see:
Xilinx FPGA MIPI Interface Simple Explanation
Setting Up the Project
For this project, it is recommended to use Vivado version 2020 or above, as MIPI IP is now free.
Step 1: Create a Vivado Project
Run Vivado
data:image/s3,"s3://crabby-images/fee4b/fee4b8fc4b17ae7d1c426ffcdbbfd9723d1863f2" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) “Create Project” –> (2) Click “Next”
data:image/s3,"s3://crabby-images/4d753/4d753cc5476b974085408be65f3844a0c169be98" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Specify (1) “Project Name” –> (2) Specify Project Directory –> (3) Set Checkboxes –> (4) Click “Next”
data:image/s3,"s3://crabby-images/474bf/474bf35da39e5eff4616f050dfbdbddcea3c84e5" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Select Project Type –> (2) Set Checkboxes –> (3) Click “Next”
data:image/s3,"s3://crabby-images/a327f/a327faafa286922023e3efe3e5f993f03882950f" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Select the “Boards” tab –> (2) Find and select SP701 –> (3) Click “Next”
data:image/s3,"s3://crabby-images/73153/731538532920232b231d832dddea859116c642a3" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Click “Finish”
data:image/s3,"s3://crabby-images/9d07e/9d07e02fab9a1c3277467b3927f5760906d14c20" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Step 2: Generate Example Design
In Vivado, (1) “Create Block Design” –> (2) Click “OK”
data:image/s3,"s3://crabby-images/8956a/8956a9e02667e1b7a61060894c84758a5418e75a" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Click “+” or “Ctrl+I” –> (2) Type “mipi” in “Search” –> (3) Double-click “MIPI CSI-2 Rx Subsystem” IP core
(1) Right-click on IP –> (2) Select “Customize Block”
data:image/s3,"s3://crabby-images/82802/82802d7e977b8a32fc7a1cdcfc2d4d22eafaab70" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Open the “Application Example Design” tab –> (2) Select “SP701” –> (3) Click “OK”
data:image/s3,"s3://crabby-images/15a6c/15a6c9607e86ad6878538ac969da7fad3f247a8d" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Right-click on IP –> (2) Select “Open Example Design”
data:image/s3,"s3://crabby-images/99280/99280d0501442d37c0e89df3bc012a1ad4194ed7" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Click “OK” to save design changes
data:image/s3,"s3://crabby-images/dd782/dd782db41e381e1dd5247258e9459f44b297b916" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Specify the directory for the example project (Note: Path on Windows must be as short as possible) –> (2) Set Checkboxes –> (3) Click “OK” –> (4) Click “OK”
data:image/s3,"s3://crabby-images/41bcf/41bcfc16e36b94f42dd1a83b8334ba63bd1295f4" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
The example project will open in a new Vivado window. Wait a few minutes for the project to build.
data:image/s3,"s3://crabby-images/ea3ca/ea3ca22a8b1e113e92bb4a7b8a8b488141a2dcc8" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
In the example project Vivado, (1) “Generate Bitstream” –> (2) Click “YES”
data:image/s3,"s3://crabby-images/395f7/395f703050a23002330b3fec5bfcdee124bb8dfd" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Wait for the bitstream to generate
Step 3: Hardware Testing
Connect the OV5640 sensor to the MIPI CSI interface on the FPGA board. Connect an HDMI display or MIPI display to the development board.
Step 4: Running Debugging
Open VITIS software from Vivado. (1) “Tools” –> (2) “Launch VITIS”
data:image/s3,"s3://crabby-images/2856c/2856cf557e8724f41a0cb8cb89dfcdd57f15bfac" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Specify workspace (Select the provided mipi_csi2_rx_subsystem_0_ex :: SW :: xmipi_app) –> (2) “Launch”
data:image/s3,"s3://crabby-images/cf245/cf24585522dece3fcde2b001de28c559242fc879" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Close the VITIS “Welcome” tab
data:image/s3,"s3://crabby-images/f2751/f2751635911e63e267efc523c7b2d756806fd56f" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Now you will see the software part of the project. Code for the MicroBlaze soft processor.
data:image/s3,"s3://crabby-images/b6a8d/b6a8d123aae46bdd4877e707fc8d335adc66451a" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Follow the arrow –> (2) Click “Debug Configurations”
data:image/s3,"s3://crabby-images/0654f/0654fd945662614c6d182a2a25e79570878e609b" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
(1) Double-click “Single Application Debug (GDB)” –> (2) Select “Debugger Executable” –> (3) Specify the bitstream.bit file generated by Vivado –> (4) Set Checkbox –> (5) Click “Debug”
data:image/s3,"s3://crabby-images/0cdb0/0cdb0cc3cd770b1b09211193bdc9bc83205a045c" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Press the run button and follow the messages on the serial terminal
data:image/s3,"s3://crabby-images/7f13a/7f13a13edc4e969f9d380936ee836cf7c1698065" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
data:image/s3,"s3://crabby-images/f07c4/f07c42ec0631e146162c2833f5850d000240059d" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"
Conclusion
Generating an example project for the MIPI interface on the FPGA board from Vivado is very simple.
❝
https://www.xilinx.com/products/boards-and-kits/sp701.html#resources
❞
data:image/s3,"s3://crabby-images/66e77/66e775b1ee54f6d9ca9db1e09a2f41b8fd576ecc" alt="Building a MIPI Camera Interface with Spartan-7 FPGA and OV5640 in 15 Minutes Using VITIS"