Commit 89c6c1fe authored by Andrey Filippov's avatar Andrey Filippov

Merge branch 'altera'

parents 3968e7c4 97b1bfc2
<?xml version="1.0" encoding="UTF-8"?>
<!--
/*******************************************************************************
* Copyright (c) 2015 Elphel, Inc.
* This file is a part of VDT plug-in.
* VDT plug-in is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* VDT plug-in is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Additional permission under GNU GPL version 3 section 7:
* If you modify this Program, or any covered work, by linking or combining it
* with Eclipse or Eclipse plugins (or a modified version of those libraries),
* containing parts covered by the terms of EPL/CPL, the licensors of this
* Program grant you additional permission to convey the resulting work.
* {Corresponding Source for a non-source form of such a combination shall
* include the source code for the parts of Eclipse or Eclipse plugins used
* as well as that of the covered work.}
*******************************************************************************/
-->
<vdt-project>
<interface name="QuartusInterface" extends="FPGAPprojectInterface">
<syntax name="GrepFilterProblemSyntax" format='| grep --line-buffered -v "\[%%ParamName"' />
<syntax name="GrepFilterProblemOtherSyntax" format='%(| grep --line-buffered -v "\[%%ParamValue"%|\n%)' />
<typedef name="ParserModeType">
<paramtype kind= "enum" base="String">
<item value="0" label="Tool output is parsed immediately"/>
<item value="1" label="Tool output is delayed by not more than 1 line when consolidating bits"/>
<item value="2" label="As '1', but do not show same bits again"/>
<item value="3" label="All tool output containg hierarchical output is delayed to the very end"/>
</paramtype>
</typedef>
</interface>
<!-- Abstract tools to be inherited by instances used for various Quartus tools -->
<!-- Restore tool for Quartus -->
<tool name="RestoreQuartus" label="Restore state after Quartus tool"
project="FPGA_project"
interface="QuartusInterface"
package="FPGA_package"
shell="/bin/bash"
abstract="true">
<output>
<line name="quartus_pre_restore">
"-c"
<!-- Create project directory on remote server if it did not exist -->
"ssh"
"-oBatchMode=yes"
"-l %RemoteUser %RemoteHost"
"'"
"mkdir -p"
"%QuartusProjectRoot"
"' ;"
<!-- Copy snapshot generated after synthesis from local to remote -->
"rsync -avr -e ssh"
<!-- from: -->
"%QuartusLocalDir/%%StateFile"
<!-- to: -->
"%RemoteUser@%RemoteHost:%QuartusProjectRoot"
";"
</line>
<line name="quartus_restore"
dest="QuartusConsole"
mark="``"
sep="\n"
failure="ERROR"
prompt="@@FINISH@@"
log="">
"puts \"\Restoring snapshot %%StateFile""
"cd ~/%QuartusProjectRoot"
"set outputDir ~/%QuartusProjectRoot/%QuartusRemoteDir"
"file mkdir $outputDir"
"project_restore %QuartusRemoteDir/%%StateFile"
"puts \"@@FINISH@@\""
</line>
</output>
</tool>
<!-- Save tool for Quartus tool -->
<tool name="SaveQuartus"
label="SaveQuartus"
project="FPGA_project"
interface="QuartusInterface"
package="FPGA_package"
shell="/bin/bash"
abstract="true">
<output>
<line name="quartus_save"
dest="QuartusConsole"
mark="``"
sep="\n"
prompt="@@FINISH@@"
failure="ERROR"
log="">
"puts \"Saving snapshot %%StateFile\""
"cd ~/%QuartusProjectRoot"
"set outputDir ~/%QuartusProjectRoot/%QuartusRemoteDir"
"file mkdir $outputDir"
"project_archive -overwrite %QuartusRemoteDir/%%StateFile"
"puts \"@@FINISH@@\""
</line>
<line name="quartus_copy_after_save">
"-c"
"mkdir -p %QuartusLocalDir ;"
"rsync -avr -e ssh"
"%RemoteUser@%RemoteHost:%QuartusProjectRoot/%QuartusRemoteDir/%%StateFile"
"%%StateDir/"
</line>
</output>
</tool>
</vdt-project>
<?xml version="1.0" encoding="UTF-8"?>
<!--
/*******************************************************************************
* Copyright (c) 2015 Elphel, Inc.
* This file is a part of VDT plug-in.
* VDT plug-in is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* VDT plug-in is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Additional permission under GNU GPL version 3 section 7:
* If you modify this Program, or any covered work, by linking or combining it
* with Eclipse or Eclipse plugins (or a modified version of those libraries),
* containing parts covered by the terms of EPL/CPL, the licensors of this
* Program grant you additional permission to convey the resulting work.
* {Corresponding Source for a non-source form of such a combination shall
* include the source code for the parts of Eclipse or Eclipse plugins used
* as well as that of the covered work.}
*******************************************************************************/
-->
<vdt-project>
<tool name="Quartus"
label="Launch Quartus"
project="FPGA_project"
package="FPGA_package"
shell="/bin/bash" interface="QuartusInterface" description="Launching remote Quartus in console">
<action-menu>
<action label="Launch Quartus" resource="" icon="door_in.png" />
<action label="Generate public key" resource="" icon="key.png" />
<action label="Setup connection to" resource="%RemoteUser@%RemoteHost"
check-extension="false" check-existence="false" icon="setup.png" />
</action-menu>
<parameter id="command" label="Shell command" default="bash"
type="String" format="CopyValue" visible="true" readonly="false" />
<parameter id="actionIndex" default="%%ChosenActionIndex"
type="String" format="CopyValue" visible="false" />
<input>
<group name="General">
"QuartusRemoteCommand"
</group>
<group name="Shell">
"command"
</group>
</input>
<output>
<if actionIndex="0">
<line name="Quartus"
timeout="1"
keep-open= "true">
"%QuartusShellSwitches"
"%QuartusPreSSH"
"ssh"
"-oBatchMode=yes"
<if TerminalMode = "true">
"-t -t"
</if>
"%QuartusSSHSwitches"
"-l"
"%RemoteUser"
"%RemoteHost"
"'"
"%QuartusRemoteCommand"
"'"
"%QuartusSSHExtra"
"|| { echo '*** ssh connection to the server %RemoteUser@%RemoteHost failed ***';"
"echo 'You may need to configure connection - it is done in \"Package Setup\"';"
"echo 'Then generate a public key (if it is not done already), and post it to';"
"echo 'the remote server (currently set as %RemoteUser@%RemoteHost)';"
"exit 1; } ;"
</line>
<line name="quartus_check"
dest="QuartusConsole"
mark="``"
sep=""
success="All rights reserved."
prompt="@@FINISH@@">
<!--success="Finished parsing RTL primitives"-->
"puts \"@@FINISH@@\"\n"
</line>
</if>
<if actionIndex="1">
<line name="Keygen">
"%QuartusShellSwitches"
"echo \"Generating public key with command:\";"
"echo \"ssh-keygen -t rsa -q -f ~/.ssh/id_rsa -N ''\";"
"ssh-keygen -t rsa -q -f ~/.ssh/id_rsa -N ''"
</line>
</if>
<if actionIndex="2">
<line name="SSHCopyID">
"%QuartusShellSwitches"
"echo \"*********************************************\";"
"echo \"** **\";"
"echo \"** This command requires you to be able **\";"
"echo \"** to login to the remote system and enter **\";"
"echo \"** a password once to post your public key **\";"
"echo \"** there. **\";"
"echo \"** **\";"
"echo \"** For this you need 'ssh-askpass' to be **\";"
"echo \"** installed in your system. **\";"
"echo \"** **\";"
"echo \"** If the command will fail, you need to **\";"
"echo \"** install 'ssh-askpass' and try again or **\";"
"echo \"** just manually run: **\";"
"echo \"\n ssh-copy-id %RemoteUser@%RemoteHost\n\";"
"echo \"** from the system terminal and enter your **\";"
"echo \"** password when prompted. **\";"
"echo \"** **\";"
"echo \"** If you see nothing below this box, that **\";"
"echo \"** likely means that Eclipse is launched **\";"
"echo \"** from the terminal, and the system asks **\";"
"echo \"** your password (or permission to add **\";"
"echo \"** key of the remote host first) in that **\";"
"echo \"** terminal - just switch to it and **\";"
"echo \"** complete the setup. **\";"
"echo \"** **\";"
"echo \"*********************************************\";"
"ssh-copy-id %RemoteUser@%RemoteHost;"
</line>
</if>
</output>
</tool>
</vdt-project>
<?xml version="1.0" encoding="UTF-8"?>
<!--
/*******************************************************************************
* Copyright (c) 2015 Elphel, Inc.
* This file is a part of VDT plug-in.
* VDT plug-in is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* VDT plug-in is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Additional permission under GNU GPL version 3 section 7:
* If you modify this Program, or any covered work, by linking or combining it
* with Eclipse or Eclipse plugins (or a modified version of those libraries),
* containing parts covered by the terms of EPL/CPL, the licensors of this
* Program grant you additional permission to convey the resulting work.
* {Corresponding Source for a non-source form of such a combination shall
* include the source code for the parts of Eclipse or Eclipse plugins used
* as well as that of the covered work.}
*******************************************************************************/
-->
<vdt-project>
<interface name="QuartusPlaceInterface" extends="QuartusInterface">
<typedef name="PackRegisters">
<paramtype kind="enum" base="String">
<item value="off" label="The Fitters does not attempt to place a pair of logic functions in a single logic cell"/>
<item value="normal" label="The Fitter places both a combinational and a sequential operation in logic cell when it is expected that the
placement will not affect performance"/>
<item value="minimize area" label="The Fitter agressively combines unrelated combinational and sequential functions into a single logic cell to reduce the
logic element count, even at the expence of performance"/>
<item value="minimize with chains" label="The Fitter agressively combines sequential and combinational functions that are part of arithmetic or
register cascade chains, or that can be converted to register cascade chains"/>
<item value="auto" label="The Fitter automatically chooses the best method to fit the design"/>
</paramtype>
</typedef>
<typedef name="QuartusPlaceEffort">
<paramtype kind="enum" base="String">
<item value="auto" label="Directs the Fitter to reduce effort after meeting timing requirements. Decreases compilation time only when
timing and fitting requirements can be met"/>
<item value="standard" label="Directs the Fitter not to decrease effort. Preserves fmax but does not decrease compilation time"/>
<item value="fast" label="Directs the Fitter to descrease effort. Descreases compilation time by up to 50%, with a possible reduction in fmax"/>
</paramtype>
</typedef>
<typedef name="QuartusRegPack">
<paramtype kind="enum" base="String">
<item value="auto" label="The Fitter automatically chooses the best method to fit the design"/>
<item value="off" label="The Fitter does not attempt to place a pair of logic functions in a single logic cell"/>
<item value="normal" label="The fitter places both a combinational and a sequential operation in a logic cell when
it is expected that the placement will not affect performance"/>
<item value="minimize_area" label="The Fitter agressively combines unrelated sequential and combinational functions into a single
logic cell to reduce the logic element count, even at the expense of performance"/>
<item value="minimize_area_with_chains" label="The Fitter aggressively combines combinational and sequential functions that are part of arithmetic or
register cascade chains, or that can be converted to register cascade chains"/>
</paramtype>
</typedef>
</interface>
<tool name="QuartusPlace" label="Place and route design"
project="FPGA_project"
interface="QuartusPlaceInterface"
package="FPGA_package"
shell="/bin/bash"
ignore="%QuartusIgnoreSource"
description="Quartus place and route design"
result="QuartusSnapshotPlace"
log-dir="QuartusLogDir"
state-dir="QuartusLocalDir"
restore="RestoreQuartusPlace"
disable="DisableQuartusPlace"
save="SaveQuartusPlace"
autosave="AutosaveQuartusPlace"
inherits="QuartusToolPrototype"
>
<action-menu>
<action lable="Place" resource="" icon="mondrian2x2.png"/>
</action-menu>
<depends-list>
<depends state="QuartusSnapshotSynth"/>
</depends-list>
<!-- Interfce parameters -->
<parameter id="AutosaveQuartusPlace" label="Create snapshot" tooltip="Automaticaly create snapshot after fitter"
default="true" type="Boolean" format="None"/>
<!-- Command line parameters -->
<!-- TODO: consider moving this option to separate design menu item -->
<parameter id="check_netlist" label="Run legality checking" tooltip="Option to run only legality checking on the current netlist.
Analysis and synthesis must be run successfully before you use this option."
default="false" visible="true" omit="false" readonly="false" type="Boolean" format="DoubleDashName"/>
<parameter id="par_effort" outid="effort" label="Placement effort" tooltip="Option to specify the level of effor you want the Fitter to use"
default="auto" visible="true" omit="auto" readonly="false" type="QuartusPlaceEffort" format="DoubleDash"/>
<parameter id="incremental_signaltap" label="Incremental SignalTap" tooltip="Option to perform an incremental SignalTap(R) II compilation.
Use this option when only SignalTap settings have changed since the last compilation"
default="false" visible="true" omit="false" readonly="false" type="Boolean" format="DoubleDashName"/>
<parameter id="inner_num" label="Placement effort multiplier" tooltip="Option to specify a value for the loop multiplier
used during placement. Use of a higher value increases compilation time, but may increase the quality of placement"
default="1" visible="true" omit="1" readonly="false" type="Cardinal" format="DoubleDash"/>
<parameter id="lower_priority" label="Lower priority" tooltip="Option to lower priority of the current process."
default="false" visible="true" readonly="false" omit="false" type="Boolean" format="DoubleDashName"/>
<parameter id="one_fit_attempt" label="One fit attempt" tooltip="Option to perform only one fitting attempt, giving a no fit if that
attempt fails. When this option is turned off, the fitter may perform additional attemps"
default="false" visible="true" readonly="false" omit="false" type="Bool_on_off" format="DoubleDash"/>
<parameter id="optimize_io_register_for_timing" label="Optimize IO registers" tooltip="Option to optimize I/O register placement for timing.
This option is used for timing-driven compilation"
default="false" visible="true" readonly="false" omit="false" type="Bool_on_off" format="DoubleDash"/>
<parameter id="pack_register" label="Pack registers" tooltip="Option to implement register packing for appropriate pairs of
registers and logic functions"
default="auto" visible="true" readonly="false" omit="auto" type="QuartusRegPack" format="DoubleDash"/>
<parameter id="parallel" label="# of processors to use" tooltip="Controls parallel compilation. If 0 is specified, the Quartus software
uses all processors detected on the system. Otherwise, the software attempts to use the specified number of processors.
Note: this feature is not licenced for the Web Edition and this parameter should be set to 1"
default="1" visible="true" readonly="false" omit="0" type="Cardinal" format="DoubleDash"/>
<parameter id="part_par" outid="part" label="Part (see Project)" tooltip="Altera device to use (configured in 'project' dialog)"
default="%part" visible="true" readonly="true" omit="" type="String" format="DoubleDash"/>
<parameter id="plan" label="Plan" tooltip="This flow will place all periphery elements (such as IOs and PLLs) and determine a legal
clock plan. No core placement or routing will be performed"
default="false" visible="true" readonly="false" omit="false" type="Boolean" format="DoubleDashName"/>
<parameter id="recompile" label="Rapid recompile" tooltip="Option to run Quartus Fit in Rapid Recompile mode"
default="false" visible="true" readonly="false" omit="false" type="Bool_on_off" format="DoubleDash"/>
<parameter id="seed" label="Seed" tooltip="Option to used the specified seed value. The Fitter uses this value as the initial placement configuration
when attempting to optimize the design timing requirements, including fmax"
default="1" visible="true" omit="1" readonly="false" type="Cardinal" format="DoubleDash"/>
<parameter id="tdc" label="Timing-driven compilation" tooltip="Option to use timing-driven compilation. This option optimizes place and route based on
timing information"
default="false" visible="true" readonly="false" omit="false" type="Bool_on_off" format="DoubleDash"/>
<input>
<group name="General">
<!-- Same as in project settings-->
"AutosaveQuartusPlace"
"QuartusSnapshotPlace"
</group>
<group name="Placement">
"check_netlist"
"par_effort"
"incremental_signaltap"
"inner_num"
"lower_priority"
"one_fit_attempt"
"optimize_io_register_for_timing"
"pack_register"
"parallel"
"part_par"
"plan"
"recompile"
"seed"
"tdc"
</group>
</input>
<output>
<!-- Assemble quartus_fit arguments line -->
<line name="quartus_assemble_args"
dest="QuartusConsole"
sep=" ">
"set par_args \""
"%check_netlist"
"%par_effort"
"%incremental_signaltap"
"%inner_num"
"%lower_priority"
"%one_fit_attempt"
"%optimize_io_register_for_timing"
"%pack_register"
"%parallel"
"%part_par"
"%plan"
"%recompile"
"%seed"
"%tdc"
"\"\n"
</line>
<!-- Start fitter -->
<line name="quartus_run_synth"
dest="QuartusConsole"
mark="``"
sep="\n"
prompt="@@FINISH@@"
success="@@FINISH@@"
log=""
stdout="parser_Quartus">
"cd ~/%QuartusProjectRoot"
"set projectName %%ProjectName"
"set outputDir ~/%QuartusProjectRoot/%QuartusRemoteDir"
"file mkdir $outputDir"
"load_package flow"
<!-- Reopen project if it was closed somehow -->
"if [is_project_open] {"
"puts \"Project is open, starting fitter\""
"} else {"
"project_open $projectName"
"}"
"if {[catch {execute_module -tool fit -args $par_args} result]} {"
"puts \"Result: $result\""
"puts \"ERROR: Place and route faild. See the report file.\""
"} else {"
"puts \"INFO: Place and route was successful.\""
"}"
"puts \"@@FINISH@@\""
</line>
</output>
</tool>
<!-- Restore tool for QuartusSynthesis -->
<tool name="RestoreQuartusPlace"
project="FPGA_project"
interface="QuartusInterface"
package="FPGA_package"
inherits="RestoreQuartus"/>
<!-- Save tool for QuartusSynthesis -->
<tool name="SaveQuartusPlace"
project="FPGA_project"
interface="QuartusInterface"
package="FPGA_package"
inherits="SaveQuartus"/>
</vdt-project>
<?xml version="1.0" encoding="UTF-8"?>
<!--
/*******************************************************************************
* Copyright (c) 2015 Elphel, Inc.
* This file is a part of VDT plug-in.
* VDT plug-in is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* VDT plug-in is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Additional permission under GNU GPL version 3 section 7:
* If you modify this Program, or any covered work, by linking or combining it
* with Eclipse or Eclipse plugins (or a modified version of those libraries),
* containing parts covered by the terms of EPL/CPL, the licensors of this
* Program grant you additional permission to convey the resulting work.
* {Corresponding Source for a non-source form of such a combination shall
* include the source code for the parts of Eclipse or Eclipse plugins used
* as well as that of the covered work.}
*******************************************************************************/
-->
<vdt-project>
<tool name="QuartusToolPrototype" label="QuartusToolPrototype"
project="FPGA_project"
interface="QuartusInterface"
package="FPGA_package"
shell="/bin/bash"
description="Quartus tool prototype"
abstract="true"
>
</tool>
</vdt-project>
<?xml version="1.0" encoding="UTF-8"?>
<!--
/*******************************************************************************
* Copyright (c) 2015 Elphel, Inc.
* This file is a part of VDT plug-in.
* VDT plug-in is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* VDT plug-in is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Additional permission under GNU GPL version 3 section 7:
* If you modify this Program, or any covered work, by linking or combining it
* with Eclipse or Eclipse plugins (or a modified version of those libraries),
* containing parts covered by the terms of EPL/CPL, the licensors of this
* Program grant you additional permission to convey the resulting work.
* {Corresponding Source for a non-source form of such a combination shall
* include the source code for the parts of Eclipse or Eclipse plugins used
* as well as that of the covered work.}
*******************************************************************************/
-->
<vdt-project>
<interface name="QuartusSynthesisInterface" extends="QuartusInterface">
<syntax name="read_qdc_syntax" format="%(read_qdc %%ParamValue%|\n%)" />
<typedef name="FSMType">
<paramtype kind="enum" base="String">
<item value="auto" label="Allows Analysis and Synthesis to choose the best encoding for the state machine."/>
<item value="one_hot" label="Encodes the state machine in one-hot style."/>
<item value="minimal_bits" label="Uses the minimal number of bits to encode a state machine."/>
<item value="user_encoded" label="Encodes the state machine in the manner specified by user."/>
</paramtype>
</typedef>
<typedef name="SynthesisEffort">
<paramtype kind="enum" base="String">
<item value="auto" label="Maximum synthesis effort."/>
<item value="fast" label="Synthesis process is streamlined to improve the runtime at the cost of design performance and/or resource usage.
Use this option when the FItter early_timing_estimate mode is used or when fast-synthesis compilation is needed
whitout the need to run the Fitter. When this option is used with the regular Fitter, Fitter performance
may decrease as fast-synthesis netlists take longer to route."/>
</paramtype>
</typedef>
<typedef name="OptimizeDesign">
<paramtype kind="enum" base="String">
<item value="area" label="Makes the design as small as possible in order to minimize resource usage."/>
<item value="speed" label="Chooses a design implementation that has the fastest fmax."/>
<item value="balanced" label="Chooses a design implementation that has a high-speed performance with minimal logic usage."/>
</paramtype>
</typedef>
<typedef name="IncrementalCompilation">
<paramtype kind="enum" base="String">
<item value="off" label="Turn off incremental compilation" />
<item value="full_incremental_compilation" label="Turn on full incremental compilaation" />
</paramtype>
</typedef>
</interface>
<tool name="QuartusSynthesis" label="Load Source files to Quartus and Synthesize"
project="FPGA_project"
interface="QuartusSynthesisInterface"
package="FPGA_package"
shell="/bin/bash"
ignore="%QuartusIgnoreSource"
description="Quartus Synthesis"
result="QuartusSnapshotSynth"
log-dir="QuartusLogDir"
state-dir="QuartusLocalDir"
restore="RestoreQuartusSynthesis"
disable="DisableQuartusSynth"
save="SaveQuartusSynthesis"
autosave="AutosaveQuartusSynthesis"
inherits="QuartusToolPrototype"
>
<extensions-list>
<extension mask="v"/>
<extension mask="tf"/>
</extensions-list>
<depends-list>
<depends files="FilteredSourceListPar"/>
<depends files="FilteredIncludesListPar"/>
<depends files="ConstraintsFiles"/>
</depends-list>
<parameter id="analysis_and_elaboration" label="Analysis and elaboration" tooltip= "Option to check all the design files in a design for syntax and
semantec errors, and perform a netlist exraction."
default="false" visible="true" readonly="false" omit="false" type="Boolean" format="DoubleDashName"/>
<parameter id="effort" label="Synthesis effort" tooltip="Option to select synthesis effort level"
default="auto" visible="true" readonly="false" omit="auto" type="SynthesisEffort" format="DoubleDash"/>
<parameter id="family" outid="family" label="Device family" tooltip= "Option to target the specified device family. The family name should not contain any
spaces. If you need to add space between words in the family name, make sure that you enclose the family name in double quotation marks."
default="CycloneV" visible="true" readonly="false" omit="" type="String" format="DoubleDash"/>
<parameter id="ignore_carry_buffers" label="Ignore CARRY_SUM buffers" tooltip="Ignore CARRY_SUM buffers that are instantiated in the design."
default="false" visible="true" omit="false" type="Bool_on_off" format="DoubleDash"/>
<parameter id="ignore_cascade_buffers" label="Ignore CASCADE buffers" tooltip="Ignore CASCADE buffers that are instantiated in the design."
default="false" visible="true" omit="false" type="Bool_on_off" format="DoubleDash"/>
<parameter id="incremental_compilation" label="Incremental compilation" tooltip="Option to specify the incremental compilation mode."
default="off" visible="true" omit="off" type="IncrementalCompilation" format="DoubleDash"/>
<parameter id="lower_priority" label="Lower priority" tooltip="Option to lower priority of the current process."
default="false" visible="true" readonly="false" omit="false" type="Boolean" format="DoubleDashName"/>
<parameter id="optimize" label="Optimize design" tooltip="Option to optimeze the design to achieve maximum speed performance,
minimum area usage or high speed performance with minimal area cost during synthesis."
default="balanced" visible="true" readonly="false" omit="balanced" type="OptimizeDesign" format="DoubleDash"/>
<parameter id="parallel" label="# of processors to use" tooltip="Controls parallel compilation. If 0 is specified, the Quartus software
uses all processors detected on the system. Otherwise, the software attempts to use the specified number of processors.
Note: this feature is not licenced for the Web Edition and this parameter should be set to 1"
default="1" visible="true" readonly="false" omit="0" type="Cardinal" format="DoubleDash"/>
<parameter id="part_synth" outid="part" label="Part (see Project)" tooltip="Altera device to use (configured in 'project' dialog)"
default="%part" visible="true" readonly="true" omit="" type="String" format="DoubleDash"/>
<parameter id="state_machine_encoding" label="FSM encoding" tooltip="Finite state machine encoding."
default="auto" visible="true" readonly="false" omit="auto" type="FSMType" format="DoubleDash"/>
<parameter id="top" label="Design top module" tooltip= "Top module of the design, determined by the project top file"
default="%%TopModule" visible="true" omit="" readonly="true" type="String" format="Dash"/>
<parameter id="read_qdc" type="Filelist"
format="read_qdc_syntax" default="%ConstraintsFiles" visible="false" />
<parameter id="FilteredSourceListPar" type="Filelist" label="FilteredSourceListPar"
format="ParamListSyntax" default="%%FilteredSourceList" readonly="false" visible="true" />
<parameter id="FilteredIncludesListPar" type="Filelist" label="FilteredIncludesListPar"
format="ParamListSyntax" default="%%FilteredIncludesList" readonly="false" visible="true" />
<parameter id="QuartusSynthActionIndex" default="%%ChosenActionIndex"
type="String" format="CopyValue" visible="false" />
<parameter id="ConstraintsFiles" type="Filelist" format="ParamListSyntax"
default="" label="Constraints files" tooltip="Select constraint files to load to Quartus" readonly="false"
visible="true" />
<parameter id="AutosaveQuartusSynthesis" label="Create snapshot" tooltip="Automatically create snapshot after successful synthesis"
default="true" type= "Boolean" format="None"/>
<parameter id="ResetProject" label="Reset project" tooltip="Reset project before loading source files"
default="true" type= "Boolean" format="None"/>
<parameter id="SkipPreSynth" label="Skip pre-synthesis" tooltip="Do not run pre-synthesis TCL commands"
default="false" type= "Boolean" format="None"/>
<parameter id="PreTCL" label="Pre-synthesis TCL commands" tooltip="TCL commands to run before synthesis"
type="Stringlist" format="ProgramSyntax" default="" omit=""
readonly="false" visible="true" />
<input>
<group name="General">
"FilteredSourceListPar"
"FilteredIncludesListPar"
"ConstraintsFiles"
"AutosaveQuartusSynthesis"
"QuartusSnapshotSynth" <!-- same as in project -->
"ResetProject"
"---"
"SkipPreSynth"
"PreTCL"
</group>
<group name="Synthesis">
"analysis_and_elaboration"
"effort"
"family"
"part_synth"
"ignore_carry_buffers"
"ignore_cascade_buffers"
"incremental_compilation"
"lower_priority"
"optimize"
"parallel"
"state_machine_encoding"
</group>
</input>
<output>
<!-- mkdir -p vdt/npmtest -->
<line name="quartus_copy_pre_synth">
"-c"
"ssh"
"-oBatchMode=yes"
"-l %RemoteUser %RemoteHost"
"'"
"mkdir -p"
"%QuartusProjectRoot"
"' ;"
"rsync -avrR -e ssh"
"%FilteredSourceListPar"
"%FilteredIncludesListPar"
<if QuartusSynthActionIndex="0">
"%ConstraintsFiles"
</if>
"%RemoteUser@%RemoteHost:%QuartusProjectRoot"
</line>
<!-- Assemble quartus_map arguments line -->
<line name="quartus_assemble_args"
dest="QuartusConsole"
sep=" ">
"set synth_args \""
"%part_synth"
"%family"
"%analysis_and_elaboration"
"%effort"
"%ignore_carry_buffers"
"%ignore_cascade_buffers"
"%incremental_compilation"
"%lower_priority"
"%optimize"
"%parallel"
"%state_machine_encoding"
"\"\n"
</line>
<line name="quartus_run_synth"
dest="QuartusConsole"
mark="``"
sep="\n"
prompt="@@FINISH@@"
success="@@FINISH@@"
log=""
stdout="parser_Quartus">
"cd ~/%QuartusProjectRoot"
"load_package flow"
"set projectName %%ProjectName"
"set outputDir ~/%QuartusProjectRoot/%QuartusRemoteDir"
"file mkdir $outputDir"
<!-- Load all project files -->
<if ResetProject="true">
"if [is_project_open] { project_close }"
</if>
"if [project_exists $projectName] {"
"project_open $projectName"
"} else {"
"project_new $projectName }"
"foreach file [list %FilteredSourceListPar] {"
"puts \"Adding $file to project\""
"set_global_assignment -name VERILOG_FILE $file }"
<if QuartusSynthActionIndex="0">
<if ConstraintsFiles="">
"puts \"No constraints files specified, skipping read_qdc command\";"
</if>
<if-not ConstraintsFiles="">
"%read_qdc"
</if-not>
</if>
<!-- Run pre-synthesis TCL commands (if specified) -->
<if SkipPreSynth="false">
<if-not PreTCL="">
"%PreTCL"
</if-not>
<if PreTCL="">
"puts \"No pre-synthesis TCL commands specified\""
</if>
</if>
<!-- Start synthesizer -->
"if {[catch {execute_module -tool map -args $synth_args} result]} {"
"puts \"Result: $result\""
"puts \"ERROR: Analysis and Synthesis faild. See the report file.\""
"} else {"
"puts \"INFO: Analysis and Synthesis was successful.\""
"}"
"puts \"@@FINISH@@\""
</line>
</output>
</tool>
<!-- Restore tool for QuartusSynthesis -->
<tool name="RestoreQuartusSynthesis"
project="FPGA_project"
interface="QuartusInterface"
package="FPGA_package"
inherits="RestoreQuartus"/>
<!-- Save tool for QuartusSynthesis -->
<tool name="SaveQuartusSynthesis"
project="FPGA_project"
interface="QuartusInterface"
package="FPGA_package"
inherits="SaveQuartus"/>
</vdt-project>
...@@ -123,6 +123,8 @@ ...@@ -123,6 +123,8 @@
<syntax name="DashName" format=" -%%ParamName" /> <syntax name="DashName" format=" -%%ParamName" />
<syntax name="QuotedDash" format=' -%%ParamName "%%ParamValue"' /> <syntax name="QuotedDash" format=' -%%ParamName "%%ParamValue"' />
<syntax name="NameValue" format=" %%ParamName %%ParamValue" /> <syntax name="NameValue" format=" %%ParamName %%ParamValue" />
<syntax name="DoubleDash" format="--%%ParamName=%%ParamValue" />
<syntax name="DoubleDashName" format="--%%ParamName" />
<!-- <!--
Does not work according to 2.2.1. "Inside text-repetitor, one and only one pattern-generator is mandatory". Does not work according to 2.2.1. "Inside text-repetitor, one and only one pattern-generator is mandatory".
......
...@@ -27,247 +27,261 @@ ...@@ -27,247 +27,261 @@
*******************************************************************************/ *******************************************************************************/
--> -->
<vdt-project> <vdt-project>
<menu name="MainDesignMenu" <menu name="MainDesignMenu"
label="Design Menu" label="Design Menu"
icon="sample.gif" icon="sample.gif"
tip="This is a common menu that contains common items"> tip="This is a common menu that contains common items">
<menu name="Verilog" <menu name="Verilog"
label="Verilog Development Tools" label="Verilog Development Tools"
icon="newmod_wiz.gif"> icon="newmod_wiz.gif">
<menuitem name="IVerilog" <menuitem name="IVerilog"
label="Icarus Verilog Simulator" label="Icarus Verilog Simulator"
icon="iverilog.ico" icon="iverilog.ico"
call="iverilog"/> call="iverilog"/>
<menuitem name="GTKWave" <menuitem name="GTKWave"
label="GTKWave (Waves viewer)" label="GTKWave (Waves viewer)"
icon="gtkwave.ico" icon="gtkwave.ico"
call="iverilog"/> call="iverilog"/>
</menu> </menu>
<menu name="ISE" <menu name="ISE"
label="ISE Tools" label="ISE Tools"
icon="xilinx.png"> icon="xilinx.png">
<menu name="ISE_utils" <menu name="ISE_utils"
label="ISE utilities" label="ISE utilities"
icon="setup.png"> icon="setup.png">
<menuitem name="ISECopyUnisims" <menuitem name="ISECopyUnisims"
label="Copy Xilinx ISE primitives library to the local project" label="Copy Xilinx ISE primitives library to the local project"
icon="copy.png" icon="copy.png"
call="ISEUnisims"/> call="ISEUnisims"/>
<menuitem name="ISEPartgen" <menuitem name="ISEPartgen"
label="Run ISE partgen" label="Run ISE partgen"
icon="bitstream.png" icon="bitstream.png"
call="ISEPartgen"/> call="ISEPartgen"/>
</menu> </menu>
<menuitem name="ISE Server" <menuitem name="ISE Server"
label="Start remote ISE session" label="Start remote ISE session"
icon="door_in.png" icon="door_in.png"
call="ISE"/> call="ISE"/>
<menuitem name="ISESynthesis" <menuitem name="ISESynthesis"
label="Synthesize design" label="Synthesize design"
icon="Retort.png" icon="Retort.png"
call="ISExst"/> call="ISExst"/>
<menuitem name="ISENGDBuild" <menuitem name="ISENGDBuild"
label="Run NGDBuild" label="Run NGDBuild"
icon="opt_blue.png" icon="opt_blue.png"
call="ISENGDBuild"/> call="ISENGDBuild"/>
<menuitem name="ISEMap" <menuitem name="ISEMap"
label="Map design" label="Map design"
icon="map_icon.png" icon="map_icon.png"
call="ISEMap"/> call="ISEMap"/>
<menuitem name="ISETraceMap" <menuitem name="ISETraceMap"
label="Report post-map timing" label="Report post-map timing"
icon="clock.png" icon="clock.png"
call="ISETraceMap"/> call="ISETraceMap"/>
<menuitem name="ISEPAR" <menuitem name="ISEPAR"
label="Place &amp; route design" label="Place &amp; route design" icon="route66.png"
icon="route66.png" call="ISEPAR"/>
call="ISEPAR"/> <menuitem name="ISETracePAR"
<menuitem name="ISETracePAR" label="Report post-implementation timing"
label="Report post-implementation timing" icon="clock.png"
icon="clock.png" call="ISETracePAR"/>
call="ISETracePAR"/> <menuitem name="ISEBitgen"
<menuitem name="ISEBitgen" label="Generate bitstream file(s)n"
label="Generate bitstream file(s)n" icon="bitstream.png"
icon="bitstream.png" call="ISEBitgen"/>
call="ISEBitgen"/> </menu>
</menu>
<menu name="Vivado"
<menu name="Vivado" label="Vivado Tools"
label="Vivado Tools" icon="xilinx.png">
icon="xilinx.png"> <menu name="VivadoUtils"
<menu name="VivadoUtils" label="Vivado utilities"
label="Vivado utilities" icon="setup.png">
icon="setup.png"> <menuitem name="CopyUnisims"
<menuitem name="CopyUnisims" label="Copy Xilinx Vivado primitives library to the local project"
label="Copy Xilinx Vivado primitives library to the local project" icon="copy.png"
icon="copy.png" call="VivadoUnisims"/>
call="VivadoUnisims"/> <menuitem name="Vivado Test"
<menuitem name="Vivado Test" label="Send a 'Hello World' command to the remote Vivado session"
label="Send a 'Hello World' command to the remote Vivado session" icon="my_tool.gif"
icon="my_tool.gif" call="VivadoTest"/>
call="VivadoTest"/> </menu>
</menu>
<menuitem name="Vivado Server"
<menuitem name="Vivado Server" label="Start remote Vivado session"
label="Start remote Vivado session" icon="door_in.png"
icon="door_in.png" call="Vivado"/>
call="Vivado"/> <menu name="VivadoSynthesisTools"
<menu name="VivadoSynthesisTools" label="Synthesis Tools"
label="Synthesis Tools" icon="Retort.png">
icon="Retort.png"> <menuitem name="VivadoSynthesis"
<menuitem name="VivadoSynthesis" label="Synthesize design"
label="Synthesize design" icon="Retort.png"
icon="Retort.png" call="VivadoSynthesis"/>
call="VivadoSynthesis"/> <menuitem name="VivadoTimingReportSynthesis"
<menuitem name="VivadoTimingReportSynthesis" label="Timing report"
label="Timing report" icon="clock.png"
icon="clock.png" call="VivadoTimingReportSynthesis"/>
call="VivadoTimingReportSynthesis"/> <menuitem name="VivadoTimimgSummaryReportSynthesis"
<menuitem name="VivadoTimimgSummaryReportSynthesis" label="Timing summary"
label="Timing summary" icon="clock_sum.png"
icon="clock_sum.png" call="VivadoTimimgSummaryReportSynthesis"/>
call="VivadoTimimgSummaryReportSynthesis"/> </menu>
</menu> <!-- <menuitem name="VivadoOptPlace"
<!-- <menuitem name="VivadoOptPlace" label="Optimize and place design"
label="Optimize and place design" icon="mondrian2x2.png"
icon="mondrian2x2.png" call="VivadoOptPlace"/> -->
call="VivadoOptPlace"/> --> <menu name="VivadoImplementationTools"
<menu name="VivadoImplementationTools" label="Implementation tools"
label="Implementation tools" icon="process.gif">
icon="process.gif">
<menuitem name="VivadoOpt"
<menuitem name="VivadoOpt" label="Optimize design"
label="Optimize design" icon="opt_blue.png"
icon="opt_blue.png" call="VivadoOpt"/>
call="VivadoOpt"/>
<menuitem name="VivadoOptPower"
<menuitem name="VivadoOptPower" label="Reduce power"
label="Reduce power" icon="fire.png"
icon="fire.png" call="VivadoOptPower"/>
call="VivadoOptPower"/>
<menuitem name="VivadoPlace"
<menuitem name="VivadoPlace" label="Place design"
label="Place design" icon="mondrian2x2.png"
icon="mondrian2x2.png" call="VivadoPlace"/>
call="VivadoPlace"/>
<menuitem name="VivadoOptPhys"
<menuitem name="VivadoOptPhys" label="Post-placement optimize"
label="Post-placement optimize" icon="opt_yellow.png"
icon="opt_yellow.png" call="VivadoOptPhys"/>
call="VivadoOptPhys"/>
<menuitem name="VivadoRoute"
<menuitem name="VivadoRoute" label="Route design"
label="Route design" icon="route66.png"
icon="route66.png" call="VivadoRoute"/>
call="VivadoRoute"/>
<menuitem name="VivadoTimingReportImplemented"
<menuitem name="VivadoTimingReportImplemented" label="Timing report"
label="Timing report" icon="clock.png"
icon="clock.png" call="VivadoTimingReportImplemented"/>
call="VivadoTimingReportImplemented"/>
<menuitem name="VivadoTimimgSummaryReportImplemented"
<menuitem name="VivadoTimimgSummaryReportImplemented" label="Timing summary"
label="Timing summary" icon="clock_sum.png"
icon="clock_sum.png" call="VivadoTimimgSummaryReportImplemented"/>
call="VivadoTimimgSummaryReportImplemented"/> </menu>
</menu> <menuitem name="VivadoBitstream"
<menuitem name="VivadoBitstream" label="Generate bitstream"
label="Generate bitstream" icon="bitstream.png"
icon="bitstream.png" call="VivadoBitstream"/>
call="VivadoBitstream"/> </menu>
<menu name="Quartus"
label="Quartus tools"
</menu> icon="xilinx.png">
<menuitem name="Quartus Server"
</menu> label="Start remote Quartus session"
icon="door_in.png"
<menu name="MainDesignMenu2" call="Quartus"/>
label="Design Menu 2" <menuitem name="QuartusSynthesis"
icon="sample.gif" label="Synthesize design"
tip="This is an user menu" icon="Retort.png"
inherits="MainDesignMenu"> call="QuartusSynthesis"/>
<menu name="Python tests" <menuitem name="QuartusFitter"
label="Tests with remote Python console" label="Place and route design"
icon="python.png"> icon="route66.png"
call="QuartusPlace"/>
<menuitem name="RemotePython" </menu>
label="Run remote Python session"
icon="python.png"
call="RemotePython"/> </menu>
<menuitem name="RemotePythonCommand"
label="Send a command to the remote Python session" <menu name="MainDesignMenu2"
icon="my_tool.gif" label="Design Menu 2"
call="RemotePythonCommand"/> icon="sample.gif"
</menu> tip="This is an user menu"
inherits="MainDesignMenu">
<menu name="OtherStuff" <menu name="Python tests"
label="Various Sample Tools"> label="Tests with remote Python console"
icon="python.png">
<menuitem name="tool1"
label="MyTool_exe" <menuitem name="RemotePython"
icon="my_tool.gif" label="Run remote Python session"
call="MyTool_exe"/> icon="python.png"
call="RemotePython"/>
<menuitem name="tool2" <menuitem name="RemotePythonCommand"
label="MyTool2_exe" label="Send a command to the remote Python session"
icon="my_tool.gif" icon="my_tool.gif"
call="MyTool2_exe"/> call="RemotePythonCommand"/>
</menu>
<menuitem name="tool3"
label="MyTool" <menu name="OtherStuff"
icon="my_tool.gif" label="Various Sample Tools">
call="MyTool"/>
<menuitem name="Test VDT" <menuitem name="tool1"
label="Testing some VDT features" label="MyTool_exe"
icon="sample.gif" icon="my_tool.gif"
call="VDTTest"/> call="MyTool_exe"/>
<!--
<menuitem name="Test VDT-A" <menuitem name="tool2"
label="Testing some VDT features" label="MyTool2_exe"
icon="sample.gif" icon="my_tool.gif"
tool-instance="VDTTest_inst2" call="MyTool2_exe"/>
call="VDTTest"/>
--> <menuitem name="tool3"
<menuitem name="Test VDT1" label="MyTool"
label="Testing some VDT features - variant 1" icon="my_tool.gif"
icon="sample.gif" call="MyTool"/>
call="VDTTest1"/> <menuitem name="Test VDT"
</menu> label="Testing some VDT features"
icon="sample.gif"
</menu> call="VDTTest"/>
<!--
<menu name="MainDesignMenu3" <menuitem name="Test VDT-A"
label="Design Menu 3" label="Testing some VDT features"
icon="sample.gif" icon="sample.gif"
tip="This is another custom user menu" tool-instance="VDTTest_inst2"
inherits="MainDesignMenu2"> call="VDTTest"/>
-->
<menu name="JustAnotherStuff" <menuitem name="Test VDT1"
label="Just Another Stuff" label="Testing some VDT features - variant 1"
icon="sample.gif" icon="sample.gif"
inherits="MainDesignMenu2" call="VDTTest1"/>
after="Python tests"/> </menu>
<menuitem name="GREP" </menu>
label="Run GREP"
call="grep"/> <menu name="MainDesignMenu3"
<menu name="Python tests" label="Design Menu 3"
label="Tests with remote Python console" icon="sample.gif"
icon="python.png"> tip="This is another custom user menu"
inherits="MainDesignMenu2">
<menuitem name="RemotePython"
label="Run remote Python session" <menu name="JustAnotherStuff"
icon="python.png" label="Just Another Stuff"
call="RemotePython"/> icon="sample.gif"
<menuitem name="RemotePythonCommand" inherits="MainDesignMenu2"
label="Send a command to the remote Python session" after="Python tests"/>
icon="my_tool.gif"
call="RemotePythonCommand"/> <menuitem name="GREP"
</menu> label="Run GREP"
call="grep"/>
</menu> <menu name="Python tests"
label="Tests with remote Python console"
</vdt-project> icon="python.png">
<menuitem name="RemotePython"
label="Run remote Python session"
icon="python.png"
call="RemotePython"/>
<menuitem name="RemotePythonCommand"
label="Send a command to the remote Python session"
icon="my_tool.gif"
call="RemotePythonCommand"/>
</menu>
</menu>
</vdt-project>
...@@ -29,8 +29,6 @@ ...@@ -29,8 +29,6 @@
<vdt-project> <vdt-project>
<interface name="FPGAPprojectInterface"> <interface name="FPGAPprojectInterface">
<syntax name="RemoteRootSyntax" format="%%ParamValue/%%ProjectName" /> <syntax name="RemoteRootSyntax" format="%%ParamValue/%%ProjectName" />
<!-- <syntax name="SourceListSyntax" format="%(%%SourceList%| %)" />
<syntax name="FilteredSourceListSyntax" format="%(%%FilteredSourceList%| %)" /> -->
<syntax name="ProgramSyntax" format="%(%%ParamValue%|\n%)" /> <syntax name="ProgramSyntax" format="%(%%ParamValue%|\n%)" />
<!-- typedef --> <!-- typedef -->
</interface> </interface>
...@@ -44,7 +42,7 @@ ...@@ -44,7 +42,7 @@
<parameter id="RemoteUser" label="Remote user name" tooltip="Remote user name" type="String" <parameter id="RemoteUser" label="Remote user name" tooltip="Remote user name" type="String"
format="CopyValue" default="%%UserName" readonly="false" visible="true" /> format="CopyValue" default="%%UserName" readonly="false" visible="true" />
<!-- Vivado options --> <!-- Vivado options -->
<parameter id="VivadoRelease" label="Vivado release" tooltip="Vivado release number (part of the path)" <parameter id="VivadoRelease" label="Vivado release" tooltip="Vivado release number (part of the path)"
type="String" format="CopyValue" default="2013.4" readonly="false" type="String" format="CopyValue" default="2013.4" readonly="false"
visible="true" /> visible="true" />
...@@ -53,7 +51,7 @@ ...@@ -53,7 +51,7 @@
type="String" format="CopyValue" default="/opt/Xilinx/Vivado" readonly="false" type="String" format="CopyValue" default="/opt/Xilinx/Vivado" readonly="false"
visible="true" /> visible="true" />
<!-- ISE options --> <!-- ISE options -->
<parameter id="ISERelease" label="ISE release" tooltip="ISE release number (part of the path)" <parameter id="ISERelease" label="ISE release" tooltip="ISE release number (part of the path)"
type="String" format="CopyValue" default="14.7" readonly="false" type="String" format="CopyValue" default="14.7" readonly="false"
visible="true" /> visible="true" />
...@@ -62,8 +60,16 @@ ...@@ -62,8 +60,16 @@
type="String" format="CopyValue" default="/opt/Xilinx" readonly="false" type="String" format="CopyValue" default="/opt/Xilinx" readonly="false"
visible="true" /> visible="true" />
<!-- Quartus options -->
<parameter id="QuartusRelease" label="Quartus release" tooltip="Quartus release number (part of the path)"
type="String" format="CopyValue" default="15.0" readonly="false"
visible="true" />
<parameter id="QuartusInstallationRoot" label="Quartus root" tooltip="Quartus Installation Root"
type="String" format="CopyValue" default="/opt/Altera" readonly="false"
visible="true" />
<!-- Vivado advanced parameters --> <!-- Vivado advanced parameters -->
<parameter id="TerminalMode" type="BoolYesNo" format="None" <parameter id="TerminalMode" type="BoolYesNo" format="None"
default="false" label="Force terminal mode" tooltip="Force terminal mode for the remote program" /> default="false" label="Force terminal mode" tooltip="Force terminal mode for the remote program" />
...@@ -102,7 +108,7 @@ ...@@ -102,7 +108,7 @@
readonly="true" readonly="true"
visible="true" /> visible="true" />
<!-- ISE advanced parameters --> <!-- ISE advanced parameters -->
<parameter id="ISETerminalMode" type="BoolYesNo" format="None" <parameter id="ISETerminalMode" type="BoolYesNo" format="None"
default="false" label="Force terminal mode" tooltip="Force terminal mode for the remote program" /> default="false" label="Force terminal mode" tooltip="Force terminal mode for the remote program" />
...@@ -147,9 +153,36 @@ ...@@ -147,9 +153,36 @@
readonly="true" readonly="true"
visible="true" /> visible="true" />
<!-- Quartus advanced parameters -->
<parameter id="QuartusTerminalMode" type="BoolYesNo" format="None"
default="false" label="Force terminal mode" tooltip="Force terminal mode for the remote program" />
<!-- /opt/Xilinx/Vivado/2013.4/bin/vivado -mode tcl --> <parameter id="QuartusShellSwitches" label="Shell switch" tooltip="Shell switches" type="String"
format="CopyValue" default="-c" readonly="false" visible="true" />
<parameter id="QuartusPreSSH" label="pre-ssh" tooltip="pre-ssh shell parameters"
type="String" format="CopyValue" default="" readonly="false" visible="true" />
<parameter id="QuartusSSHSwitches" label="ssh switches" tooltip="Other ssh switches"
type="String" format="CopyValue" default="" readonly="false" visible="true" />
<parameter id="QuartusSSHExtra" label="ssh extra parameters" tooltip="ssh extra parameters" type="String"
format="CopyValue" default="" readonly="false" visible="true" />
<parameter id="QuartusConsole" default="Quartus" label="Quartus console name" tooltip="Quartus console name in Eclipse, used by other tools"
type="String" format="CopyValue" visible="true" readonly="false"/>
<parameter id="QuartusRelativeExeOptions" label="Quartus launch command" tooltip="Quartus relative executable path and command options"
type="String" format="CopyValue" default="quartus/bin/quartus_sh -s" readonly="false"
visible="true" />
<parameter id="QuartusRemoteCommand" label="Remote command" tooltip="Remote ssh command"
type="String" format="CopyValue"
default="%QuartusInstallationRoot/%QuartusRelease/%QuartusRelativeExeOptions"
readonly="true"
visible="true" />
<!-- /opt/Xilinx/Vivado/2013.4/bin/vivado -mode tcl -->
<parameter id="NoBabyTalk" label="No Baby talk" tooltip= "Remove licensing baby talk from INFO messages." <parameter id="NoBabyTalk" label="No Baby talk" tooltip= "Remove licensing baby talk from INFO messages."
default="true" visible="true" omit="false" type="Boolean" format="DashName"/> default="true" visible="true" omit="false" type="Boolean" format="DashName"/>
...@@ -161,6 +194,8 @@ ...@@ -161,6 +194,8 @@
"VivadoInstallationRoot" "VivadoInstallationRoot"
"ISERelease" "ISERelease"
"ISEInstallationRoot" "ISEInstallationRoot"
"QuartusRelease"
"QuartusInstallationRoot"
</group> </group>
<group name="AdvancedVivado" label="Vivado server advanced setup"> <group name="AdvancedVivado" label="Vivado server advanced setup">
"TerminalMode" "TerminalMode"
...@@ -186,6 +221,16 @@ ...@@ -186,6 +221,16 @@
"ISEBinDirectory" "ISEBinDirectory"
"ISEUnisimsAbsolutePath" "ISEUnisimsAbsolutePath"
</group> </group>
<group name="AdvancedQuartus" label="Quartus server advanced setup">
"QuartusTerminalMode"
"QuartusShellSwitches"
"QuartusPreSSH"
"QuartusSSHSwitches"
"QuartusSSHExtra"
"QuartusConsole"
"QuartusRelativeExeOptions"
"QuartusRemoteCommand"
</group>
</input> </input>
</package> </package>
...@@ -223,7 +268,7 @@ ...@@ -223,7 +268,7 @@
<parameter id="VivadoIgnoreSource" label="Ignore source files" tooltip="Pattern to ignore source files that match this regular expression" <parameter id="VivadoIgnoreSource" label="Ignore source files" tooltip="Pattern to ignore source files that match this regular expression"
type="String" default=".*unisims.*" format="CopyValue" readonly="false" /> type="String" default=".*unisims.*" format="CopyValue" readonly="false" />
<!-- ISE parameters --> <!-- ISE parameters -->
<parameter id="ISEProjectRoot" label="Workspace directory" tooltip="Relative (to user home directory) path of the workspace on ISE server" <parameter id="ISEProjectRoot" label="Workspace directory" tooltip="Relative (to user home directory) path of the workspace on ISE server"
type="String" default="vdt_ise" format="RemoteRootSyntax" readonly="false" /> type="String" default="vdt_ise" format="RemoteRootSyntax" readonly="false" />
...@@ -242,163 +287,192 @@ ...@@ -242,163 +287,192 @@
<parameter id="ISEIgnoreSource" label="Ignore source files" tooltip="Pattern to ignore source files that match this regular expression" <parameter id="ISEIgnoreSource" label="Ignore source files" tooltip="Pattern to ignore source files that match this regular expression"
type="String" default=".*unisims.*" format="CopyValue" readonly="false" /> type="String" default=".*unisims.*" format="CopyValue" readonly="false" />
<!-- Quartus parameters -->
<parameter id="part" label="Device" tooltip= "FPGA part number (device) to use"
default="" visible="true" omit="" type="String" format="CopyValue"/>
<parameter id="QuartusProjectRoot" label="Workspace directory" tooltip="Relative (to user home directory) path of the workspace on Quartus server"
type="String" default="vdt" format="RemoteRootSyntax" readonly="false" />
<parameter id="QuartusRemoteDir" label="Remote Quartus directory" tooltip="Remote Quartus output subdirectroy for snapshot and result files"
type="Pathname" default="quartus_build" format="CopyValue" readonly="false" />
<parameter id="QuartusLocalDir" label="Local Quartus directory" tooltip="Local project subdirectroy for Quartus snapshot files"
type="Pathname" default="quartus_state" format="CopyValue" readonly="false" />
<parameter id="QuartusLocalResultDir" label="Local Quartus results directory"
tooltip="Local project subdirectroy for Xilinx Quartus generated result files"
type="Pathname" default="quartus_results" format="CopyValue" readonly="false" />
<parameter id="QuartusLogDir" label="Local Quartus tool logs directory" tooltip="Local project subdirectroy for Quartus tools log files"
type="Pathname" default="quartus_logs" format="CopyValue" readonly="false" />
<parameter id="QuartusIgnoreSource" label="Ignore source files" tooltip="Pattern to ignore source files that match this regular expression"
type="String" default="" format="CopyValue" readonly="false" />
<!-- Calculated --> <!-- Calculated -->
<!-- <parameter id="VivadoProjectRoot" label="" tooltip="Relative (to user home directory) path of the project on Vivado server" <parameter id="SnapshotSynth"
type="String" default="vdt" format="RemoteRootSyntax" readonly="false" /> --> label="Synthesis snapshot" tooltip="Name of Vivado snapshot archive after synthesis"
default="%%ProjectName-synth.dcp"
<parameter id="SnapshotSynth"
label="Synthesis snapshot" tooltip="Name of Vivado snapshot archive after synthesis"
default="%%ProjectName-synth.dcp"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="SnapshotOptPlace" <parameter id="SnapshotOptPlace"
label="Placement snapshot" tooltip="Name of Vivado snapshot archive after optimization/placement" label="Placement snapshot" tooltip="Name of Vivado snapshot archive after optimization/placement"
default="%%ProjectName-opt-place.dcp" default="%%ProjectName-opt-place.dcp"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="SnapshotOpt" <parameter id="SnapshotOpt"
label="Optimization snapshot" tooltip="Name of Vivado snapshot archive after optimization" label="Optimization snapshot" tooltip="Name of Vivado snapshot archive after optimization"
default="%%ProjectName-opt.dcp" default="%%ProjectName-opt.dcp"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="SnapshotOptPower" <parameter id="SnapshotOptPower"
label="Power optimization snapshot" tooltip="Name of Vivado snapshot archive after power optimization" label="Power optimization snapshot" tooltip="Name of Vivado snapshot archive after power optimization"
default="%%ProjectName-opt-power.dcp" default="%%ProjectName-opt-power.dcp"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="SnapshotPlace" <parameter id="SnapshotPlace"
label="Placement snapshot" tooltip="Name of Vivado snapshot archive after placement" label="Placement snapshot" tooltip="Name of Vivado snapshot archive after placement"
default="%%ProjectName-place.dcp" default="%%ProjectName-place.dcp"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="SnapshotOptPhys" <parameter id="SnapshotOptPhys"
label="Physical optimization snapshot" tooltip="Name of Vivado snapshot archive after physical optimization" label="Physical optimization snapshot" tooltip="Name of Vivado snapshot archive after physical optimization"
default="%%ProjectName-opt-phys.dcp" default="%%ProjectName-opt-phys.dcp"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="SnapshotRoute" <parameter id="SnapshotRoute"
label="Routing snapshot" tooltip="Name of Vivado snapshot archive after routing" label="Routing snapshot" tooltip="Name of Vivado snapshot archive after routing"
default="%%ProjectName-route.dcp" default="%%ProjectName-route.dcp"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="DisableVivadoSynth" <parameter id="DisableVivadoSynth"
label="Disable Vivado synthesis" tooltip="Disable tool Vivado Synthesis" label="Disable Vivado synthesis" tooltip="Disable tool Vivado Synthesis"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
<parameter id="DisableVivadoOptPlace" <parameter id="DisableVivadoOptPlace"
label="Disable Vivado opt/place" tooltip="Disable tool Vivado Optimize and Place" label="Disable Vivado opt/place" tooltip="Disable tool Vivado Optimize and Place"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
<parameter id="DisableVivadoOpt" <parameter id="DisableVivadoOpt"
label="Disable Vivado optimization" tooltip="Disable tool Vivado Optimize" label="Disable Vivado optimization" tooltip="Disable tool Vivado Optimize"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
<parameter id="DisableVivadoOptPower" <parameter id="DisableVivadoOptPower"
label="Disable Vivado power optimization" tooltip="Disable reduction of power consumption" label="Disable Vivado power optimization" tooltip="Disable reduction of power consumption"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
<parameter id="DisableVivadoPlace" <parameter id="DisableVivadoPlace"
label="Disable placement" tooltip="Disable tool Vivado Place" label="Disable placement" tooltip="Disable tool Vivado Place"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
<parameter id="DisableVivadoOptPhys" <parameter id="DisableVivadoOptPhys"
label="Disable phys. optimization" tooltip="Disable tool Vivado Physical (post-placement) Optimization" label="Disable phys. optimization" tooltip="Disable tool Vivado Physical (post-placement) Optimization"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
<parameter id="DisableVivadoRoute" <parameter id="DisableVivadoRoute"
label="Disable Vivado route" tooltip="Disable tool Vivado route" label="Disable Vivado route" tooltip="Disable tool Vivado route"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
<parameter id="DisableVivadoBitsteam" <parameter id="DisableVivadoBitsteam"
label="Disable Vivado bitstream" tooltip="Disable tool Vivado bitstream generator" label="Disable Vivado bitstream" tooltip="Disable tool Vivado bitstream generator"
default="false" default="false"
type="Boolean" format="None" /> type="Boolean" format="None" />
"" <!-- same as in project --> "" <!-- same as in project -->
<!-- Invisible (calculated) project-wide parameters --> <!-- Invisible (calculated) project-wide parameters -->
<parameter id="SimulDirSlash" type="Pathname" visible="false" <parameter id="SimulDirSlash" type="Pathname" visible="false"
default="?%SimulDir=:,%SimulDir/" format="CopyValue"/> default="?%SimulDir=:,%SimulDir/" format="CopyValue"/>
<parameter id="VivadoSedPaths" type="String" format="CopyValue" <parameter id="VivadoSedPaths" type="String" format="CopyValue"
label="sed command line" tooltip="Remote file prefix to be removed for the local error parser when running Vivado tools" label="sed command line" tooltip="Remote file prefix to be removed for the local error parser when running Vivado tools"
default="sed -u 's@/home/%RemoteUser/%VivadoProjectRoot/%%ProjectName/@@'"/> default="sed -u 's@/home/%RemoteUser/%VivadoProjectRoot/%%ProjectName/@@'"/>
<parameter id="ISESedPaths" type="String" format="CopyValue" <parameter id="ISESedPaths" type="String" format="CopyValue"
label="sed command line" tooltip="Remote file prefix to be removed for the local error parser when running ISE tools" label="sed command line" tooltip="Remote file prefix to be removed for the local error parser when running ISE tools"
default="sed -u 's@/home/%RemoteUser/%ISEProjectRoot/%%ProjectName/@@'"/> default="sed -u 's@/home/%RemoteUser/%ISEProjectRoot/%%ProjectName/@@'"/>
<parameter id="QuartusSedPaths" type="String" format="CopyValue"
label="sed command line" tooltip="Remote file prefix to be removed for the local error parser when running Quartus tools"
default="sed -u 's@/home/%RemoteUser/%QuartusProjectRoot/%%ProjectName/@@'"/>
<parameter id="ISEWorkspace" label="Workspace directory" tooltip="Relative (to user home directory) path of the workspace on ISE server" <parameter id="ISEWorkspace" label="Workspace directory" tooltip="Relative (to user home directory) path of the workspace on ISE server"
type="String" default="%ISEProjectRoot" format="CopyValue" readonly="true" /> type="String" default="%ISEProjectRoot" format="CopyValue" readonly="true" />
<parameter id="ISESnapshotSynth" <parameter id="ISESnapshotSynth"
label="Synthesis snapshot" tooltip="Name of ISE snapshot archive after synthesis" label="Synthesis snapshot" tooltip="Name of ISE snapshot archive after synthesis"
default="%%ProjectName-synth.tgz" default="%%ProjectName-synth.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotNGDBuild" <parameter id="ISESnapshotNGDBuild"
label="NGDBuild snapshot" tooltip="Name of ISE snapshot archive after NGDBuild" label="NGDBuild snapshot" tooltip="Name of ISE snapshot archive after NGDBuild"
default="%%ProjectName-ngdbuild.tgz" default="%%ProjectName-ngdbuild.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotMap" <parameter id="ISESnapshotMap"
label="NGDBuild snapshot" tooltip="Name of ISE snapshot archive after map" label="NGDBuild snapshot" tooltip="Name of ISE snapshot archive after map"
default="%%ProjectName-map.tgz" default="%%ProjectName-map.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotPAR" <parameter id="ISESnapshotPAR"
label="NGDBuild snapshot" tooltip="Name of ISE snapshot archive after PAR" label="NGDBuild snapshot" tooltip="Name of ISE snapshot archive after PAR"
default="%%ProjectName-par.tgz" default="%%ProjectName-par.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotOptPlace" <parameter id="ISESnapshotOptPlace"
label="Placement snapshot" tooltip="Name of ISE snapshot archive after optimization/placement" label="Placement snapshot" tooltip="Name of ISE snapshot archive after optimization/placement"
default="%%ProjectName-opt-place.tgz" default="%%ProjectName-opt-place.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotOpt" <parameter id="ISESnapshotOpt"
label="Optimization snapshot" tooltip="Name of ISE snapshot archive after optimization" label="Optimization snapshot" tooltip="Name of ISE snapshot archive after optimization"
default="%%ProjectName-opt.tgz" default="%%ProjectName-opt.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotOptPower" <parameter id="ISESnapshotOptPower"
label="Power optimization snapshot" tooltip="Name of ISE snapshot archive after power optimization" label="Power optimization snapshot" tooltip="Name of ISE snapshot archive after power optimization"
default="%%ProjectName-opt-power.tgz" default="%%ProjectName-opt-power.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotPlace" <parameter id="ISESnapshotPlace"
label="Placement snapshot" tooltip="Name of ISE snapshot archive after placement" label="Placement snapshot" tooltip="Name of ISE snapshot archive after placement"
default="%%ProjectName-place.tgz" default="%%ProjectName-place.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotOptPhys" <parameter id="ISESnapshotOptPhys"
label="Physical optimization snapshot" tooltip="Name of ISE snapshot archive after physical optimization" label="Physical optimization snapshot" tooltip="Name of ISE snapshot archive after physical optimization"
default="%%ProjectName-opt-phys.tgz" default="%%ProjectName-opt-phys.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISESnapshotRoute" <parameter id="ISESnapshotRoute"
label="Routing snapshot" tooltip="Name of ISE snapshot archive after routing" label="Routing snapshot" tooltip="Name of ISE snapshot archive after routing"
default="%%ProjectName-route.tgz" default="%%ProjectName-route.tgz"
type="String" format="CopyValue" /> type="String" format="CopyValue" />
<parameter id="ISECleanRestore" label="ISE Clean restore" <parameter id="ISECleanRestore" label="ISE Clean restore"
tooltip= "Remove remote ISE project files before unpacking snapshot archives" tooltip= "Remove remote ISE project files before unpacking snapshot archives"
default="true" visible="true" type="Boolean" format="None"/> default="true" visible="true" type="Boolean" format="None"/>
<parameter id="QuartusSnapshotSynth"
label="Synthesis snapshot" tooltip="Name of Quartus snapshot archive"
default="%%ProjectName-synth.qar"
type="String" format="CopyValue" />
<parameter id="QuartusSnapshotPlace"
label="Place and route snapshot" tooltip="Name of Quartus snapshot archive"
default="%%ProjectName-par.qar"
type="String" format="CopyValue" />
<input> <input>
<group name="Genaral" label="General parameters"> <group name="General" label="General parameters">
"part" "part"
"ImplementationTopFile" "ImplementationTopFile"
</group> </group>
...@@ -459,8 +533,15 @@ ...@@ -459,8 +533,15 @@
"ISESnapshotOptPhys" "ISESnapshotOptPhys"
"ISESnapshotRoute" "ISESnapshotRoute"
</group> </group>
<group name="Quartus" label="Quartus general properties">
"QuartusProjectRoot"
"QuartusRemoteDir"
"QuartusLocalDir"
"QuartusLocalResultDir"
"QuartusLogDir"
"QuartusIgnoreSource"
"QuartusSedPaths"
</group>
</input> </input>
<output>
</output>
</project> </project>
</vdt-project> </vdt-project>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment