adi_project_intel: Add support for Quartus Pro

By defualt the supported tool chain is Quartus PRO. If you want to
build the project with Quartus Standard, you need to define an environment
variable called QUARTUS_PRO_ISUSED with the value 0. (e.g. export
QUARTUS_PRO_ISUSED=0 )

Note: Not all projects going to build on Quartus Standard, you should
fix the errors if there is any.
main
Istvan Csomortani 2018-12-13 09:42:40 +00:00 committed by Adrian Costina
parent 054193e083
commit 967a138d0f
1 changed files with 36 additions and 5 deletions

View File

@ -21,6 +21,19 @@ proc adi_project {project_name {parameter_list {}}} {
global version global version
global quartus global quartus
# check $ALT_NIOS_MMU_ENABLED environment variables
set mmu_enabled 1
if [info exists ::env(ALT_NIOS_MMU_ENABLED)] {
set mmu_enabled $::env(ALT_NIOS_MMU_ENABLED)
}
# check $QUARTUS_PRO_ISUSED environment variables
set quartus_pro_isused 1
if [info exists ::env(QUARTUS_PRO_ISUSED)] {
set quartus_pro_isused $::env(QUARTUS_PRO_ISUSED)
}
if [regexp "_a10gx$" $project_name] { if [regexp "_a10gx$" $project_name] {
set family "Arria 10" set family "Arria 10"
set device 10AX115S2F45I1SG set device 10AX115S2F45I1SG
@ -109,11 +122,29 @@ proc adi_project {project_name {parameter_list {}}} {
puts $QFILE "save_system {system_bd.qsys}" puts $QFILE "save_system {system_bd.qsys}"
close $QFILE close $QFILE
# check which type of Quartus is used, to call the qsys utilities with the
# correct attributes
if {$quartus_pro_isused == 1} {
exec -ignorestderr $quartus(quartus_rootpath)/sopc_builder/bin/qsys-script \
--quartus_project=$project_name --script=system_qsys_script.tcl
exec -ignorestderr $quartus(quartus_rootpath)/sopc_builder/bin/qsys-generate \
system_bd.qsys --synthesis=VERILOG --family=$family --part=$device \
--quartus-project=$project_name
} else {
exec -ignorestderr $quartus(quartus_rootpath)/sopc_builder/bin/qsys-script \ exec -ignorestderr $quartus(quartus_rootpath)/sopc_builder/bin/qsys-script \
--script=system_qsys_script.tcl --script=system_qsys_script.tcl
exec -ignorestderr $quartus(quartus_rootpath)/sopc_builder/bin/qsys-generate \ exec -ignorestderr $quartus(quartus_rootpath)/sopc_builder/bin/qsys-generate \
system_bd.qsys --synthesis=VERILOG --output-directory=system_bd \ system_bd.qsys --synthesis=VERILOG --family=$family --part=$device \
--family=$family --part=$device
# I/O Timing Analysis is available just in Quartus Standard
set_global_assignment -name ENABLE_ADVANCED_IO_TIMING ON
}
# default assignments # default assignments