diff --git a/etc/scdaq/scdaq.conf b/etc/scdaq/scdaq.conf new file mode 100644 index 0000000000000000000000000000000000000000..214df5552330927da6c37d82138ec1e8216ace19 --- /dev/null +++ b/etc/scdaq/scdaq.conf @@ -0,0 +1,92 @@ +################################################################################ +## +## Input settings +## +################################################################################ + +# Input settings, allowed values are: +# "wzdma" for DMA driver from Wojciech M. Zabolotny +# "dma" for XILINX DMA driver +# "filedma" for reading from file and simulating DMA +# +input:wzdma + +## Settings for DMA input + +# DMA device +dma_dev:/dev/xdma0_c2h_0 + +# Max received packet size in bytes (buffer to reserve) +dma_packet_buffer_size:1048576 + +# Number of packet buffers to allocate +dma_number_of_packet_buffers:1000 + +# Print report each N packets, use 0 to disable +packets_per_report:200000 + + +## Extra settings for "filedma" input + +#input_file:/dev/shm/testdata.bin +input_file:testdata.bin + + +################################################################################ +## +## Stream processor settings +## +################################################################################ + +enable_stream_processor:yes + +# Define processing type (unpacking), allowed values are: +# "PASS_THROUGH" +# "GMT" +# +# Note: When changing the processing type, change also "output_filename_prefix" +# in the file output section. +# +processor_type:PASS_THROUGH + +# Enable software zero-supression +doZS:no + + +################################################################################ +## +## File output settings +## +################################################################################ + +output_filename_prefix:scout_pass_through + +output_filename_base:/fff/BU0/ramdisk/scdaq +max_file_size:8589934592 + +# Always write data to a file regardless of the run status, useful for debugging +output_force_write:no + + +################################################################################ +## +## Elastics processor settings (obsolete) +## +################################################################################ + +enable_elastic_processor:no + +port:8000 +elastic_url:http://something.somewhere +pt_cut:7 +quality_cut:12 + + +################################################################################ +## +## SCDAQ Generic Settings +## +################################################################################ + +# Pipeline settings +threads:8 diff --git a/scripts/reset-firmware.sh b/scripts/reset-firmware.sh index 2522fcdad52cb35dc909d0be09bf50be843cf712..1a9c5c250a3b35e88e05dd83d1d887931986b40b 100755 --- a/scripts/reset-firmware.sh +++ b/scripts/reset-firmware.sh @@ -1,2 +1,2 @@ #!/bin/sh -echo "reset" | nc scoutsrv-s1d12-38-01 12345 +echo "reset" | nc localhost 12345 diff --git a/scripts/run.sh b/scripts/run.sh index 0d6feab404a6393a2b2bc57030f20ebeafdc517b..2500761da695a1449ba7f2454479a94ede1c116b 100755 --- a/scripts/run.sh +++ b/scripts/run.sh @@ -14,7 +14,7 @@ umask 000 # Files and folders we create should be world accessible while true do echo "Starting scdaq..." - ./scdaq 2>&1 | logger --tag scdaq --id -p user.debug + /opt/scdaq/bin/scdaq /etc/scdaq/scdaq.conf 2>&1 | logger --tag scdaq --id -p user.debug echo "Resetting the board..." ../scripts/reset-firmware.sh echo "Clearing caches..." diff --git a/scripts/scdaqrpm.sh b/scripts/scdaqrpm.sh new file mode 100755 index 0000000000000000000000000000000000000000..2596b77dfe6951775677bb701e3c4db91877d121 --- /dev/null +++ b/scripts/scdaqrpm.sh @@ -0,0 +1,216 @@ +#!/bin/bash -e +BUILD_ARCH=x86_64 +SCRIPTDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" +RHEL_MAJOR=`cat /etc/redhat-release | cut -d' ' -f4 | cut -d'.' -f1` + +echo "Checking if necessary build packages are installed..." +if [ "$RHEL_MAJOR" = "7" ]; then + if ! rpm -q rpm-build; then + echo "\nPlease install missing packages."; + exit 1; + fi +else + if ! rpm -q gcc redhat-rpm-config rpm-build zlib-devel; then + echo ""; + echo "Please install missing packages."; + exit 1; + fi +fi +echo "..Build dependencies OK" +echo "" + +cd $SCRIPTDIR/.. +BASEDIR=$PWD +PARAMCACHE="paramcache" +NLINES=1 +ASK="1" + +if [ -n "$1" ]; then + if [ "$1" = "--batch" ]; then + ASK="0" + fi + + if [ "$1" = "-b" ]; then + ASK="0" + fi + + if [ $ASK = "0" ]; then #check $2 if found + if [ -n "$2" ]; then + PARAMCACHE=${2##*/} + fi + fi + if [ $ASK = "1" ]; then #take $1 + PARAMCACHE=${1##*/} + fi +fi + +echo "Using cache file $PARAMCACHE" + +if [ -f $SCRIPTDIR/$PARAMCACHE ]; +then + readarray lines < $SCRIPTDIR/$PARAMCACHE + for (( i=0; i < ${NLINES}; i++ )) + do + lines[$i]=`echo -n ${lines[$i]} | tr -d "\n"` + done +else + for (( i=0; i < ${NLINES}; i++ )) + do + lines[$i]="" + done +fi + +if [ $ASK = "1" ]; then + +echo "This is the scdaq build script. It will now ask for several configuration parameters." +echo "Use -b cmdline parameter to build from cache without waiting for input" +echo " ... press any key to continue ..." +read readin + +echo "Dummy parameter, this will be used to modify/obtain build parameters from cache (press enter for \"${lines[0]}\"):" +readin="" +read readin +if [ ${#readin} != "0" ]; then +lines[0]=$readin +fi + +fi #ask + +#update cache file +if [ -f $SCRIPTDIR/$PARAMCACHE ]; +then + rm -rf -f $SCRIPTDIR/$PARAMCACHE +fi +for (( i=0; i < ${NLINES}; i++ )) +do + echo ${lines[$i]} >> $SCRIPTDIR/$PARAMCACHE +done + +PACKAGENAME="scdaq" + +# set the RPM build architecture +#BUILD_ARCH=$(uname -i) # "i386" for SLC4, "x86_64" for SLC5 + +cd $SCRIPTDIR/.. +BASEDIR=$PWD + +# create a build area +echo "removing old build area" +rm -rf /tmp/$PACKAGENAME-build-tmp +echo "creating new build area" +mkdir /tmp/$PACKAGENAME-build-tmp +cd /tmp/$PACKAGENAME-build-tmp +#mkdir BUILD +#mkdir RPMS +TOPDIR=$PWD +echo "working in $PWD" +#ls + + +# we are done here, write the specs and make the fu***** rpm +cat > scoutdaq.spec << EOF +Name: $PACKAGENAME$pkgsuffix +Version: 0.1.0 +Release: 0%{?dist} +Summary: scouting daq +License: gpl +Group: DAQ +Packager: meschi +Source: none +%define _tmppath $TOPDIR/scdaq-build +BuildRoot: %{_tmppath} +BuildArch: $BUILD_ARCH +AutoReqProv: no +Provides:/opt/scdaq + +Requires: tbb boost-thread libcurl +Obsoletes: scdaq + +%description +scouting daq + +%prep + +echo "PIPPPPPPPPO" +echo $RPM_SOURCE_DIR +echo "PIPPOOOOOOOOO" +echo $BASEDIR +cp -R $BASEDIR/src SOURCES/ + +%build +echo $RPM_SOURCE_DIR +cd SOURCES +pwd +make + +%install +echo $RPM_SOURCE_DIR +rm -rf \$RPM_BUILD_ROOT +mkdir -p \$RPM_BUILD_ROOT +%__install -d "%{buildroot}/var/cache/scdaq" +%__install -d "%{buildroot}/var/log/scdaq" +%__install -d "%{buildroot}/var/log/scdaq/pid" +%__install -d "%{buildroot}/opt/scdaq" +%__install -d "%{buildroot}/opt/scdaq/init.d" +%__install -d "%{buildroot}/opt/scdaq/bin" + + +cd \$RPM_BUILD_ROOT +echo "Creating directories" +mkdir -p opt/scdaq +mkdir -p etc/scdaq +mkdir -p etc/logrotate.d +mkdir -p usr/lib/systemd/system +#mkdir -p %{buildroot}/usr/lib/systemd/system +mkdir -p etc/init.d +#mkdir -p %{buildroot}/opt/scdaq/init.d + +echo "Copying files to their destination" +cp $BASEDIR/init.d/runSCdaq.service usr/lib/systemd/system/runSCdaq.service +cp $BASEDIR/init.d/scoutboardResetServer.service usr/lib/systemd/system/scoutboardResetServer.service +cp -R $BASEDIR/* opt/scdaq +echo "PIPPOOOOOOOOOOO" +pwd +cp $TOPDIR/RPMBUILD/BUILD/SOURCES/scdaq opt/scdaq/bin/ +cp -R $BASEDIR/etc/scdaq/scdaq.conf etc/scdaq/ +#cp -R $BASEDIR/etc/logrotate.d/scdaq etc/logrotate.d/ +#rm -rf opt/hltd/init.d + +#touch opt/scdaq/scratch/new-version + +echo "Deleting unnecessary files" +rm -rf opt/hltd/{bin,rpm,lib} +rm -rf opt/hltd/scripts/paramcache* +rm -rf opt/hltd/scripts/*rpm.sh +#rm -rf opt/hltd/scripts/postinstall.sh + + +%post +#/opt/scdaq/postinstall.sh +systemctl daemon-reload + +%files +%dir %attr(777, -, -) /var/cache/scdaq +%dir %attr(777, -, -) /var/log/scdaq +%dir %attr(777, -, -) /var/log/scdaq/pid +%defattr(-, root, root, -) +/opt/scdaq/ +%config /etc/scdaq/scdaq.conf +#/etc/logrotate.d/scdaq +%attr( 644 ,root, root) /usr/lib/systemd/system/runSCdaq.service +%attr( 644 ,root, root) /usr/lib/systemd/system/scoutboardResetServer.service +#%attr( 755 ,root, root) /opt/scdaq/init.d/ +#%attr( 755 ,root, root) /opt/scdaq/init.d/ + + +%preun +if [ \$1 == 0 ]; then + /usr/bin/systemctl stop runSCdaq || true + /usr/bin/systemctl disable runSCdaq || true + /usr/bin/systemctl stop scoutboardResetServer || true + /usr/bin/systemctl disable scoutboardResetServer || true +fi +EOF +mkdir -p RPMBUILD/{RPMS/{noarch},SPECS,BUILD,SOURCES,SRPMS} +rpmbuild --define "_topdir `pwd`/RPMBUILD" -bb scoutdaq.spec +#rm -rf patch-cmssw-tmp diff --git a/scripts/vivado/reset.sh b/scripts/vivado/reset.sh index 4cbe46ccc0b47a3b90ec365144eae5ee51e815b0..207f824cccafa597f34f056bd36d642ba37c9cf5 100755 --- a/scripts/vivado/reset.sh +++ b/scripts/vivado/reset.sh @@ -1,3 +1,3 @@ #!/bin/sh -source /opt/Xilinx/Vivado/2018.2/settings64.sh -vivado -mode batch -source reset_scouting-proc.tcl +source /opt/Xilinx/Vivado_Lab/2018.3/settings64.sh +vivado_lab -mode batch -source reset_scouting-proc.tcl diff --git a/scripts/vivado/reset_scouting-proc.tcl b/scripts/vivado/reset_scouting-proc.tcl index 7873053e0f45496b22b5e9c2644619c8b2a224ed..d6fb76078972bbf931f1cd2530351a34dfd638c1 100644 --- a/scripts/vivado/reset_scouting-proc.tcl +++ b/scripts/vivado/reset_scouting-proc.tcl @@ -3,9 +3,9 @@ connect_hw_server -url localhost:3121 current_hw_target [get_hw_targets */xilinx_tcf/Xilinx/1234-tulA] set_property PARAM.FREQUENCY 15000000 [get_hw_targets */xilinx_tcf/Xilinx/1234-tulA] open_hw_target -set_property PROGRAM.FILE {/home/scouter/bitfiles/eight_links_zs/top.bit} [get_hw_devices xcku115_0] -set_property PROBES.FILE {/home/scouter/bitfiles/eight_links_zs/top.ltx} [get_hw_devices xcku115_0] -set_property FULL_PROBES.FILE {/home/scouter/bitfiles/eight_links_zs/top.ltx} [get_hw_devices xcku115_0] +set_property PROGRAM.FILE {/home/scouter/bitfiles/currently_used/scouting_build.bit} [get_hw_devices xcku115_0] +set_property PROBES.FILE {/home/scouter/bitfiles/currently_used/scouting_build.ltx} [get_hw_devices xcku115_0] +set_property FULL_PROBES.FILE {/home/scouter/bitfiles/currently_used/scouting_build.ltx} [get_hw_devices xcku115_0] current_hw_device [get_hw_devices xcku115_0] refresh_hw_device [lindex [get_hw_devices xcku115_0] 0] diff --git a/scripts/vivado/reset_server.sh b/scripts/vivado/reset_server.sh index 7ef8fb8ad38c9eda275cc449ee905926b07408ec..0ef4eb699b81c8dfbce523eedab2522735566ea8 100755 --- a/scripts/vivado/reset_server.sh +++ b/scripts/vivado/reset_server.sh @@ -1,3 +1,3 @@ #!/bin/sh -source /opt/Xilinx/Vivado/2018.2/settings64.sh -vivado -mode batch -source reset_server.tcl +source /opt/Xilinx/Vivado_Lab/2018.3/settings64.sh +vivado_lab -mode batch -source reset_server.tcl diff --git a/scripts/vivado/reset_server.tcl b/scripts/vivado/reset_server.tcl index f31dce914a90743f32e0765074d1badfee631d41..e6f5ae0f87087175e7e041390a0168bae1ed0f4c 100644 --- a/scripts/vivado/reset_server.tcl +++ b/scripts/vivado/reset_server.tcl @@ -7,9 +7,9 @@ proc init_hw {} { current_hw_target [get_hw_targets */xilinx_tcf/Xilinx/1234-tulA] set_property PARAM.FREQUENCY 15000000 [get_hw_targets */xilinx_tcf/Xilinx/1234-tulA] open_hw_target - set_property PROGRAM.FILE {/home/scouter/bitfiles/use_with_vivado_2018.2/eight_links_zs_lids_from_protocol/top.bit} [get_hw_devices xcku115_0] - set_property PROBES.FILE {/home/scouter/bitfiles/use_with_vivado_2018.2/eight_links_zs_lids_from_protocol/top.ltx} [get_hw_devices xcku115_0] - set_property FULL_PROBES.FILE {/home/scouter/bitfiles/use_with_vivado_2018.2/eight_links_zs_lids_from_protocol/top.ltx} [get_hw_devices xcku115_0] + set_property PROGRAM.FILE {/home/scouter/bitfiles/currently_used/scouting_build.bit} [get_hw_devices xcku115_0] + set_property PROBES.FILE {/home/scouter/bitfiles/currently_used/scouting_build.ltx} [get_hw_devices xcku115_0] + set_property FULL_PROBES.FILE {/home/scouter/bitfiles/currently_used/scouting_build.ltx} [get_hw_devices xcku115_0] current_hw_device [get_hw_devices xcku115_0] refresh_hw_device [lindex [get_hw_devices xcku115_0] 0] } diff --git a/src/scdaq.cc b/src/scdaq.cc index f3fb4d9313524510e85946ee321c735b8e81f450..a71fd834b2646fd85f5d3fe05caf9d708a163aaf 100644 --- a/src/scdaq.cc +++ b/src/scdaq.cc @@ -100,12 +100,16 @@ int run_pipeline(int nbThreads, ctrl &control, config &conf) { int main(int argc, char *argv[]) { (void)(argc); (void)(argv); - LOG(DEBUG) << "here 0"; + if (argc < 2) { + LOG(ERROR) << "missing argument [conffile] in scdaq invocation"; + exit(-1); + } + LOG(DEBUG) << "scdaq started with argument" << argv[1]; try { - config conf("scdaq.conf"); + config conf(argv[1]); conf.print(); - LOG(DEBUG) << "here 1"; + LOG(DEBUG) << "configuration loaded"; ctrl control; // tbb::tick_count mainStartTime = tbb::tick_count::now(); diff --git a/src/scdaq.conf b/src/scdaq.conf deleted file mode 120000 index 2553a92e74f24353d92f85ce7b8b38f8870e5ebb..0000000000000000000000000000000000000000 --- a/src/scdaq.conf +++ /dev/null @@ -1 +0,0 @@ -scdaq-calo.conf \ No newline at end of file