Skip to content

Compiling and running under v2.0.0

jcfreeman2 edited this page Jan 8, 2021 · 17 revisions

Getting started

System requirements

To get set up, you'll need access to the ups product area /cvmfs/dune.opensciencegrid.org/dunedaq/DUNE/products, as is the case, e.g., on the lxplus machines at CERN.

Setup daq-buildtools

daq-buildtools is a simple package that provides environment and building utilities for the DAQ Suite. Each cloned daq-buildtools can serve as many work areas as the developer wishes.

The repository can simply be cloned via

git clone https://github.com/DUNE-DAQ/daq-buildtools.git -b dunedaq-v2.0.0

This step doesn't have to be run more than once per daq-buildtools version.

The dbt setup script has to be sourced to make the dbt scripts available in the commandline regardless of the current work directory. Run:

source daq-buildtools/setup_dbt.sh

..and you'll see something like:

Added /your/path/to/daq-buildtools/bin to PATH
Added /your/path/to/daq-buildtools/scripts to PATH
DBT setuptools loaded

After this step daq-buildtools scripts and aliases will be accessible from your commandline regardless of the current working directory. They include quick-start.sh, build_daq_software.sh and the aliases setup_build_environment and setup_runtime_environment which are used in the following sections.

Each time that you want to work with a dunedaq-v2.0.0 software area in a fresh Linux shell, you'll need to set up daq-buildtools using the setup_dbt.sh script, as described above.

Creating a development area (AKA work area)

Once you've sourced setup_dbt.sh, you're now ready to create a development area. Create an empty directory (give it any name, but we'll refer to it as "MyTopDir" on this wiki) and 'cd' into it. Then run:

quick-start.sh

which will set up an area to place the repos you wish to build.

MyTopDir/
├── .dunedaq_area
├── build
├── dbt-pyvenv
├── log
└── sourcecode
    └── CMakeLists.txt

For the purposes of instruction, let's build the listrev package. Downloading it is simple:

cd sourcecode
git clone https://github.com/DUNE-DAQ/listrev.git -b dunedaq-v2.0.0
cd ..

Note the assumption above is that you aren't developing listrev; if you were, then you'd want to replace -b dunedaq-v2.0.0 with -b <branch you want to work on>.

Adding extra UPS products and product pools

Sometimes it is necessary to tweak the baseline list of UPS products or even UPS product pools to add extra dependencies. This can be easily done by editing the .dunedaq_area file generated by quick-start.sh and adding the new entries to dune_products_dirs and dune_products as needed. See "/example/of/additional/user/declared/product/pool" and "package_declared_by_user v1_2_3 e19:prof" in the example of an edited .dunedaq_area file, below:

dune_products_dirs=(
    "/cvmfs/dune.opensciencegrid.org/dunedaq/DUNE/products"
    "/example/of/additional/user/declared/product/pool" 
)

dune_products=(
    "cmake v3_17_2"
    "gdb v9_2"
    "gcc v8_2_0 e19:prof"
    "boost v1_70_0 e19:prof"
    "cetlib v3_10_00 e19:prof"
    "TRACE v3_16_02"
    "folly v2020_05_25 e19:prof"
    "ers v0_26_00c e19:prof"
    "nlohmann_json v3_9_0b e19:prof"
    "ninja v1_10_0"
    "pistache v2020_10_07 e19:prof"
    "cmdlib v1_0_1 e19:prof"
    "restcmd v1_0_1 e19:prof"
    "daq_cmake v1_1_0 e19:prof"
    "appfwk v2_0_0 e19:prof"
    "listrev v2_0_0 e19:prof"
    "package_declared_by_user v1_2_3 e19:prof"
)

dune_python="v3_8_3b"

As the names suggest, dune_products_dirs contains the list of UPS product pools and dune_products contains the list of UPS products sourced by setup_build_environment (described below). If you've already sourced setup_build_environment before editing the .dunedaq-area file, you'll need to log into a fresh shell and source setup_dbt.sh and setup_build_environment again.

Compiling

We're about to build and install the listrev package. (🔴 Note: if you are working with other packages, have a look at the Working with more repos subsection before running the following build command.) By default, the scripts will create a subdirectory of MyTopDir called ./install and install any packages you build off your repos there. If you wish to install them in another location, you'll want to set the environment variable DBT_INSTALL_DIR to the desired installation path after the setup_build_environment command described below, but before the build_daq_software.sh command.

Now, do the following:

setup_build_environment  # Only needs to be done once in a given shell
build_daq_software.sh --install

...and this will build listrev in the local ./build subdirectory and then install it as a package either in the local ./install subdirectory or in whatever you pointed DBT_INSTALL_DIR to.

Working with more repos

To work with more repos, add them to the ./sourcecode subdirectory as we did with listrev. Be aware, though: if you're developing a new repo which itself depends on another new repo, daq-buildtools may not already know about this dependency. "New" in this context means "not found on https://github.com/DUNE-DAQ as of ~Nov-10-2020". If this is the case, you have one of two options:

  • (Recommended) Add the names of your new packages to the build_order list found near the bottom of ./sourcecode/CMakeLists.txt, placing them in the list in the relative order in which you want them to be built.
  • First clone, build and install your new base repo, and THEN clone, build and install your other new repo which depends on your new base repo.

build_daq_software.sh will by default skip CMake's config+generate stages and go straight to the build stage unless either the CMakeCache.txt file isn't found in ./build or you've just added a new repo to ./sourcecode. If you want to remove all the contents of ./build and run config+generate+build, all you need to do is add the --clean option, i.e.

build_daq_software.sh --clean --install

And if, after the build, you want to run the unit tests, just add the --unittest option. Note that it can be used with or without --clean, so, e.g.:

build_daq_software.sh --clean --install --unittest  # Blow away the contents of ./build, run config+generate+build, and then run the unit tests

..where in the above case, you blow away the contents of ./build, run config+generate+build, install the result in ./install and then run the unit tests. Be aware that for many packages, unit tests will only (fully) work if you've also set up their runtime environment; how to do this is described below in the "Running" section of this document.

To check for deviations from the coding rules described in the DUNE C++ Style Guide, run with the --lint option:

build_daq_software.sh --lint

...though be aware that some guideline violations (e.g., having a function which tries to do unrelated things) can't be picked up by the automated linter.

If you want to see verbose output from the compiler, all you need to do is add the --verbose option:

build_daq_software.sh --verbose 

You can see all the options listed if you run the script with the --help command, i.e.

build_daq_software.sh --help

Finally, note that both the output of your builds and your unit tests are logged to files in the ./log subdirectory. These files may have ASCII color codes which make them difficult to read with some tools; more or cat, however, will display the colors and not the codes themselves.

Running

In order to run the applications built during the above procedure, the system needs to be instructed on where to look for the libraries that can be used to instantiate objects. This is handled by the setup_runtime_environment script which was placed in MyTopDir when you ran quick-start.sh; all you need to do is the following:

setup_runtime_environment

Note that if you add a new repo to your development area, after building your new code you'll need to run the script again.

Once the runtime environment is set, just run the application you need. listrev, however, has no applications; it's just a DAQ module plugin which get added to CET_PLUGIN_PATH.

We're now going to go through a demo in which we'll use a DAQ module from listrev called RandomDataListGenerator to generate vectors of random numbers and then reverse them with listrev's ListReverser module.

One of the packages that's part of the standard DUNE DAQ package suite which gets set up when you run setup_build_environment is cmdlib. This package comes with a basic implementation that is capable of sending available command objects from a pre-loaded file, by typing their command IDs to standard input. This command facility is useful for local, test oriented use-cases. In the same runtime area, launch the application like this:

daq_application -c stdin://sourcecode/listrev/test/list-reversal-app.json

and (keeping in mind that you'll want to scroll the contents below horizontally to see the full output) you'll see something like

2020-Dec-18 14:44:44,621 INFO [stdinCommandFacility::stdinCommandFacility(...) at /scratch/workdir2/sourcecode/cmdlib/plugins/stdinCommandFacility.cpp:40] Loading commands from file: sourcecode/listrev/test/list-reversal-app.json
2020-Dec-18 14:44:44,626 INFO [stdinCommandFacility::run(...) at /scratch/workdir2/sourcecode/cmdlib/plugins/stdinCommandFacility.cpp:63] Entered commands will be launched on CommandedObject...
2020-Dec-18 14:44:44,626 INFO [stdinCommandFacility::run(...) at /scratch/workdir2/sourcecode/cmdlib/plugins/stdinCommandFacility.cpp:66] Available commands: | init | conf | start | stop

What you want to do first is type init. Next, type conf to execute the configuration, and then start to begin the actual process of moving vectors between the two modules. You should see output like the following:

2020-Dec-18 14:46:39,574 DEBUG_0 [dunedaq::listrev::RandomDataListGenerator::do_work(...) at /home/jcfree/daqbuild_ipm_develop/sourcecode/listrev/plugins/RandomDataListGenerator.cpp:143] Generated list #8 with contents {168, 394, 457, 12, 43} and size 5.  DAQModule: rdlg
2020-Dec-18 14:46:39,574 DEBUG_0 [dunedaq::listrev::ListReverser::do_work(...) at /home/jcfree/daqbuild_ipm_develop/sourcecode/listrev/plugins/ListReverser.cpp:135] Reversed list #8, new contents {43, 12, 457, 394, 168} and size 5.  DAQModule: lr
2020-Dec-18 14:46:39,575 DEBUG_0 [dunedaq::listrev::ReversedListValidator::do_work(...) at /home/jcfree/daqbuild_ipm_develop/sourcecode/listrev/plugins/ReversedListValidator.cpp:160] Validating list #8, original contents {168, 394, 457, 12, 43} and reversed contents {43, 12, 457, 394, 168}.  DAQModule: rlv

To stop this, type the stop command. Ctrl-c will exit you out.

For a more realistic use-case where you can send commands to the application from other services and applications, the restcmd package provides a command handling implementation through HTTP. To use this plugin, we call daq_application in the following manner:

daq_application --commandFacility rest://localhost:12345

To control it, let's open up a second terminal, set up the daq-buildtools' setup_dbt.sh script as you did in the first terminal, and start sending daq_application commands:

cd MyTopDir
setup_runtime_environment
curl -O https://raw.githubusercontent.com/DUNE-DAQ/restcmd/dunedaq-v2.0.0/scripts/send-restcmd.py
python ./send-restcmd.py --interactive --file ./sourcecode/listrev/test/list-reversal-app.json

You'll now see

Target url: http://localhost:12345/command
This is a list of commands.
Interactive mode. Type the ID of the next command to send, or type 'end' to finish.

Available commands: [u'init', u'conf', u'start', u'stop']
Press enter a command to send next: 

And you can again send init, conf, etc., except you'll want to type quotes around the commands (so, e.g., "init" rather than init). Unlike previously, now you'll want to look in the other terminal running daq_application to see it responding to the commands. As before, Ctrl-c will exit you out of these applications.

daq_application Command Line Arguments

Use daq_application --help to see all of the possible options:

bash$ daq_application --help
daq_application known arguments (additional arguments will be stored and passed on):
  -c [ --commandFacility ] arg CommandFacility URI
  -h [ --help ]                produce help message
Some additional information

TRACE Messages

To enable the sending of TRACE messages to a memory buffer, you can set one of several TRACE environmental variables before running appfwk/apps/simple_test_app. One example is to use a command like export TRACE_NAME=TRACE. (For more details, please see the TRACE package documentation. For example, the Circular Memory Buffer section in the TRACE Quick Start talks about the env vars that you can use to enable tracing.)

To view the TRACE messages in the memory buffer, you can use the following additional steps:

  • [if not done already] export SPACK_ROOT=<your spack root> ; source $SPACK_ROOT/setup-env.sh
  • [if not done already] spack load trace
  • trace_cntl show or trace_cntl show | trace_delta -ct 1 (The latter displays the timestamps in human-readable format. Note that the messages are listed in reverse chronological order in both cases.)

Next Step

Clone this wiki locally