Quartus Project setup
Last Update: 2023-10-28
The starter code for the quartus project is available below. This already does the device selection and pin assignment but is otherwise empty. Feel free to do this yourself if you want the experience or are using a different device from the MAX 10 DE10-lite boards.
de10_lite.zip starter files
> Getting Started
In the starter code directory, locate the .qpf file. This is a Quartus Project File which is used for configuring the project, the asspicated pins, soure files, etc. We will open this with Quartus.
The first time that you launch Quartus, you’ll have to tell if you have a license—you don’t (if you're on your own machine).
data:image/s3,"s3://crabby-images/e0d57/e0d57e4aa8adce1326fb7dc896f8aa4a88085325" alt="Click on image for higher resolution version. License choice"
Press “OK” then once the full window opens, select “Open Project”
data:image/s3,"s3://crabby-images/74945/7494532999c22c5ea2aae489ff953aa71f98e22c" alt="Click on image for higher resolution version. Quartus home page"
Navigate to the location that you generated the project from the System Builder and select the “.qpf” file.
data:image/s3,"s3://crabby-images/6d0f5/6d0f5e194f708a8c005f7f15ea816206693f2445" alt="Click on image for higher resolution version. Newly opened project with no reports yet generated."
On the left-hand pane, the image shows a de10_lite file. Double click on it and the text editor should open it. This is your project’s top-level module file. You can use this for connecting each of your modules to the IO pins.
To add more modules, create a separate Verilog for for each then add them to the project.
> Adding Your Code
To add your modules (in files) to the project, go to Project > Add/Remove Files in Project…
data:image/s3,"s3://crabby-images/a79bc/a79bc6c3fd605759a54ebb4813a113810ec6f369" alt="Click on image for higher resolution version. Add/Remove Files from Project submenu"
The next window that open should have a “File Name” field. Press the “…” button and browse to where your Verilog source files are located.
data:image/s3,"s3://crabby-images/83590/835904242b021554c270af4bcf7949cec7edc28a" alt="Click on image for higher resolution version. Project settings window, displaying files currently selected to be part of the project."
Once added, the files should appear in the file list:
data:image/s3,"s3://crabby-images/23734/23734721ce2fbfd3ee40e222fb2781016dc0a361" alt="Click on image for higher resolution version. List of (HDL) project files."
Press “OK” to close the file window.
> Instantiating Your Modules
With your top level module opened (double click it in the left-hand pane), add an instantiation of your module under the “Structural Coding” section. (This looks like an ordinary Verilog instantiation of any other module.)
data:image/s3,"s3://crabby-images/96744/96744f5bcce73e3fe2e0ac6f0c7e688c815b78aa" alt="Click on image for higher resolution version. Verilog instantiation of a simple adder."
Note how the IO ports of the top-level module are connected the instantiated module through the array indexing of each of the vectors.
> Synthesizing Your Design
Once you believe that your design is functional (you should test it with a sim – it will save you a lot of time), press the Start Compilation (Ctrl+L) button.
data:image/s3,"s3://crabby-images/9655e/9655e882a793f23306162d5622795ea520fcfd5b" alt="Click on image for higher resolution version. Compilation button."
Compilation messages will be listed in the bottom message pane. If there are any errors during the process, they will show up here.
data:image/s3,"s3://crabby-images/d42af/d42af986fc18a0125cb685a482e49bd4c929f3e0" alt="Click on image for higher resolution version. Message window showing compilation progress."
You can tell that compilation is complete when the left-hand tasks pane has all green checkmarks.
> Programming (Uploading) the Bitstream Configuration
First, make sure the board is plugged into your computer and is detected. To upload the synthesized bit stream, you should click on the Programmer button in the top toolbar.
data:image/s3,"s3://crabby-images/4cd81/4cd81e70101c10d107353252ea5f637159399e75" alt="Click on image for higher resolution version. Hilighted programmer button"
Then the programmer window should pop up.
data:image/s3,"s3://crabby-images/88b2c/88b2c4264819239c5d2c41f513bcba2f0602bb16" alt="Click on image for higher resolution version. Programmer window showing scanchain and detected devices."
Click on the “Hardware Setup” button and in the new window, select the USB-Blaster from the drop-down menu.
Click “Close” when done.
data:image/s3,"s3://crabby-images/68c42/68c42e87e8fff961ce80fa79dbc6a7dd164569fd" alt="Click on image for higher resolution version. Selection of the usb FPGA programmer device"
Next, press “Auto Detect” on the programmer window.
Right click the 10M50DAF484 and select “Change File…”. Browse to the project folder and locate the .sof file.
data:image/s3,"s3://crabby-images/6d2f7/6d2f78fc25a93dee2e26e469b2b327a722f91e29" alt="Click on image for higher resolution version. Select "Change File" from the programmer context menu"
Your programmer window should now look like this:
data:image/s3,"s3://crabby-images/c1a42/c1a42520713809d73ee97415e608ee2f6cc1cf55" alt="Click on image for higher resolution version. Programmer window showing scanchain and detected devices with file selected for Program/Configure."
Make sure that the 10M50DAF484 has a checkmark in the Program/Configure column but none of the other boxes are checked. At this point, you should be able to press “Start” and your code will upload. (If Quartus crashes—and it often does at this step—just reopen and try again.)