- Let’s take a Simulink module compatible with HDL Coder. Run the following command in MATLAB's Command Window and open “hdlcoder_led_blinking.slx”.
- Right-click on the “led_counter” block, go to HDL Code > HDL Workflow Advisor. Refer to this MathWorks documentation for more information on HDL Workflow Advisor: https://www.mathworks.com/help/hdlcoder/ug/using-the-hdl-workflow-advisor-window.html
- The following image shows the configuration setup for a generic FPGA/ASIC. You can select the synthesis tool and family of FPGAs and explore more with different combinations that fit the need.
data:image/s3,"s3://crabby-images/fd858/fd8587ef4983af5ffaa6b15b9bae13825c0aaf68" alt=""
- In the left pane, right-click on “Generate RTL Code and Testbench” option and select “Run to Selected Task”.
data:image/s3,"s3://crabby-images/4f4a2/4f4a2ea531d7605c81615560d30760625ed322c1" alt=""
- This will open a “Code Generation Report” where you can see a “High-level Resource Report” section, giving the summary of various digital circuit components used. For further information on reports generation, refer to the following link: https://www.mathworks.com/help/hdlcoder/ug/creating-and-using-code-generation-reports.html
data:image/s3,"s3://crabby-images/ad822/ad822a4e06509bccc93b8807a8c0515a9941eb11" alt=""
- Run the following command to connect Vivado to MATLAB:
- Select the following configuration options. I have assumed Xilinx Vivado as the synthesis tool with the Zynq family of processing system.
data:image/s3,"s3://crabby-images/68291/68291daf839dd1e89a11be738e632c6d3d913d89" alt=""
- Set Target Frequency to the model’s requirement, I have assumed it to be 300 MHz.
- Follow the steps mentioned before and run till ‘Run Synthesis”.
- This will offer a more detailed and precise utilization report that you can reference to compare the FPGA's maximum limits with its current usage.
data:image/s3,"s3://crabby-images/4578f/4578f89aa5cda782cd47e97f22925bcd42bf3f34" alt=""
data:image/s3,"s3://crabby-images/6cd60/6cd603bc201338c20aa70ed3a3b7ca54f22e23e4" alt=""
- For more information on FPGA Synthesis from Simulink, refer the following MathWorks documentation link: https://www.mathworks.com/help/hdlcoder/gs/fpga-synthesis-and-analysis-using-the-hdl-workflow-advisor.html
- https://www.mathworks.com/help/hdlcoder/ug/get-started-with-simscape-hardware-in-the-loop-workflow.html
- https://www.mathworks.com/help/simscape/ug/generate-hdl-code-using-the-simscape-hdl-workflow-advisor.html
- https://www.mathworks.com/help/hdlcoder/ug/generate-hdl-code-from-simscape-model.html