This introduces the new ARCHER_OPTIONS flag ignore_serial=0|1 to disable analysis and logging of memory accesses in the sequential part of the OpenMP application.
In the sequential part of an OpenMP program no data race is possible, unless there is non-OpenMP concurrency (such as pthreads, MPI, ...). For the latter reason, this is not active by default.
Besides reducing the runtime overhead for the sequential part of the program, this reduces the memory overhead for sequential initialization. In combination with flush_shadow=1 this can allow analysis of applications, which run close to the limit of available memory, but only access smaller parts of shared memory during each OpenMP parallel region.
The problem is that Archer only gets active, when the OpenMP runtime gets initialized, which might be after serial initialization of the application. In such case, it helps to call for example omp_get_max_threads() at the beginning of main.
clang-tidy: warning: invalid case style for member 'print_max_rss' [readability-identifier-naming]
not useful