From a9784f13c32ad97260e19bf1cb2e3dc8820c00b7 Mon Sep 17 00:00:00 2001 From: Erik Kooistra <kooistra@astron.nl> Date: Tue, 28 Nov 2017 14:27:53 +0000 Subject: [PATCH] Added section 10) with some useful commands to work on a SVN branch. --- tools/oneclick/doc/hdltool_readme.txt | 122 +++++++++++++++++++++++++- 1 file changed, 119 insertions(+), 3 deletions(-) diff --git a/tools/oneclick/doc/hdltool_readme.txt b/tools/oneclick/doc/hdltool_readme.txt index 6718c8c6e8..b1bb5365ee 100644 --- a/tools/oneclick/doc/hdltool_readme.txt +++ b/tools/oneclick/doc/hdltool_readme.txt @@ -52,6 +52,9 @@ Contents: e) tools f) sub directories +10) SVN trunk or branch + + 100) To do 101) More ideas 102) Know errors @@ -182,11 +185,12 @@ e) Quartus user_components.ipx The user_components.ipx tells QSYS and SOPC where to search for MM components. The user_components.ipx is kept in SVN at: - https://svn.astron.nl/UniBoard_FP7/UniBoard/trunk/Firmware/synth/quartus/user_components.ipx + https://svn.astron.nl/UniBoard_FP7/RadioHDL/trunk/tools/quartus/user_components.ipx -In a Unix system this goes to the personal folder at ~ (= $HOME): +In a Unix system manually copy this user_components.ipx to the personal folder at ~ (= $HOME), because this is not (yet) done automatically in +setup_radiohdl.sh: - ~/.altera.quartus/ip/15.0/ip_search_path/user_components.ipx + ~/.altera.quartus/ip/<quartus version>/ip_search_path/user_components.ipx It appears that copying the user_components.ipx from SVN location to the personal ~ location avoids having to copy it into the installation location. The version part of the directory name needs to match the Quartus version (eg. 11.1sp2, 14.1, 15.0). The ${RADIOHDL}/tools/quartus/check_ipx_content bash script @@ -1082,6 +1086,118 @@ at the hdl_lib_uses_sim key are not needed for synthesis and could even confuse file IO ignored because it is not possible to synthesize). +10) SVN trunk and branching + +a) Useful commands + + > svn up -r # # update to -r + > svn up # update to HEAD + + > svn status -q # status of working copy compared to last svn up -r # + > svn status -u -q # status of working copy compared to HEAD + + > svn revert -R . + > svn commit -m "#<Redmine number> comment" files + +# Define simple editor for SVN commit message editing +export SVN_EDITOR=vim +echo $SVN_EDITOR + +# Kill many GUI editors at once (e.g. in case svn diff on directory opened them all) +cntr-alt-F1 +killall -9 gvimdiff +cntr-alt-F7 + + +b) Choose between trunk or a branch +Default all firmware development is done on the HEAD of the trunk. We rely on regression tests and regular +synthesis (and validation on hardware) to ensure that the trunk remains intact. + +Sometimes it can be useful though to be able to try a parallel development on a branch. Therefore it is useful +to setup a branches/ directory next to the trunk/ directory. + +It is important to use $RADIOHDL in scripts instead of $SVN, because then $RADIOHDL can be set to point to the +desired trunk or branch tree. The $RADIOHDL is defined in the .bashrc. Using a startup choice the $RADIOHDL +variable can be set per terminal window e.g. using this in the .bashrc: + + # when in scp abort: + if [ -z "$PS1" ]; then + return + fi + + # SVN checkout root directory + echo -n "RADIOHDL='1' (default) or LOWCBF='2' or another tree='3': " + read choice + case $choice in + 2) + echo "LOWCBF trunk is selected" + export SVN=${HOME}/svnroot/LOWCBF + . ${SVN}/Firmware/tools/bin/setup_radiohdl.sh + ;; + 3) + echo "RADIOHDL branch is selected" + export SVN=${HOME}/svnroot/UniBoard_FP7 + # Setup RadioHDL environment for UniBoard2 and and new Uniboard1 applications + . ${SVN}/RadioHDL/trunk/tools/setup_radiohdl.sh branches/Task_1275 + ;; + *) + echo "RADIOHDL trunk is selected" + export SVN=${HOME}/svnroot/UniBoard_FP7 + # Setup RadioHDL environment for UniBoard2 and and new Uniboard1 applications + . ${SVN}/RadioHDL/trunk/tools/setup_radiohdl.sh + # Support old UniBoard environment (including Aarfaac and Paasar) + #. ${SVN}/RadioHDL/trunk/tools/setup_unb.sh + ;; + esac + + +c) Working on a branch + + > cd $SVN/RadioHDL/ + > mkdir branches + > svn add branches/ + > commit -m "Start branching." branches/ + > svn info . + > svn ls ^/RadioHDL # The ^ is the root of the repository in SVN + branches/ + trunk/ + + # For example create branch from revison 16579 of the trunk and call it Task_<Redmine issue number> + # Start the commit message with Task #<Redmine issue number>: to provide link for Redmine. + # Optional use r<SVN revision number> in the commit message + > svn cp ^/RadioHDL/trunk@16579 ^/RadioHDL/branches/Task_1275 + > cd branches + > svn up Task_1275 + + # Merge changes from revisions to branch + > cd branches/Task_1275/ + > svn log -v -r 16588:HEAD ^/RadioHDL/trunk | more + > svn merge -c 16592 ^/RadioHDL/trunk # merge changes + > svn merge -r 16596:16658 ^/RadioHDL/trunk # merge a range of revisions + > svn diff --diff-cmd diff # show Merged /RadioHDL/trunk:r16580-16592 + + # Merge entire directory from HEAD to branch + > cd technology + > svn merge ^/RadioHDL/trunk/libraries/technology + # or similar + > cd Task_1275/ + > svn merge ^/RadioHDL/trunk/libraries/technology libraries/technology/ + + # Remove and recreate branch + > svn rm ^/RadioHDL/branches/Task_1275 # remove branch directly in SVN, so no need to do svn commit afterwards + > cd RadioHDL/branches + > rm -rf Task_1275/ # remove the working copy with all its local dir and files (e.g. build) + > svn cp ^/RadioHDL/trunk@16579 ^/RadioHDL/branches/Task_1275/ # recreate the branch + + # Create FPGA image on branch ($RADIOHDL points to the branch) + > cd $RADIOHDL/libraries/technology/ip_stratixiv + > ./generate-all-ip.sh + > python $RADIOHDL/tools/oneclick/base/modelsim_config.py -t unb1 + > python $RADIOHDL/tools/oneclick/base/quartus_config.py -t unb1 + > run_sopc unb1 apertif_unb1_bn_filterbank + > run_qcomp unb1 apertif_unb1_bn_filterbank --seed=1;run_rbf unb1 apertif_unb1_bn_filterbank + + 100) To do a) quartus_* keys and synth_top_level_entity -- GitLab