25#define STRINGIZE2(x) #x 
   26#define STRINGIZE(x) STRINGIZE2(x) 
   28#define expandName(name, flags, ignore) {STRINGIZE(name), flags}, 
   29statInfo timeStat::timerInfo[] = {
 
   30    KMP_FOREACH_TIMER(
expandName, 0){
"TIMER_LAST", 0}};
 
   31const statInfo counter::counterInfo[] = {
 
   32    KMP_FOREACH_COUNTER(
expandName, 0){
"COUNTER_LAST", 0}};
 
   35#define expandName(ignore1, ignore2, ignore3) {0.0, 0.0, 0.0}, 
   36kmp_stats_output_module::rgb_color kmp_stats_output_module::timerColorInfo[] = {
 
   37    KMP_FOREACH_TIMER(
expandName, 0){0.0, 0.0, 0.0}};
 
   40const kmp_stats_output_module::rgb_color
 
   41    kmp_stats_output_module::globalColorArray[] = {
 
   70double logHistogram::binMax[] = {1.e1l, 1.e2l, 1.e3l, 1.e4l, 1.e5l, 1.e6l,
 
   71                                 1.e7l, 1.e8l, 1.e9l, 1.e10l, 1.e11l, 1.e12l,
 
   72                                 1.e13l, 1.e14l, 1.e15l, 1.e16l, 1.e17l, 1.e18l,
 
   73                                 1.e19l, 1.e20l, 1.e21l, 1.e22l, 1.e23l, 1.e24l,
 
   74                                 1.e25l, 1.e26l, 1.e27l, 1.e28l, 1.e29l, 1.e30l,
 
   76                                 std::numeric_limits<double>::infinity()};
 
   80void statistic::addSample(
double sample) {
 
   84  double delta = sample - meanVal;
 
   86  sampleCount = sampleCount + 1;
 
   87  meanVal = meanVal + delta / sampleCount;
 
   88  m2 = m2 + delta * (sample - meanVal);
 
   90  minVal = std::min(minVal, sample);
 
   91  maxVal = std::max(maxVal, sample);
 
   93    hist.addSample(sample);
 
   96statistic &statistic::operator+=(
const statistic &other) {
 
   97  if (other.sampleCount == 0)
 
  100  if (sampleCount == 0) {
 
  105  uint64_t newSampleCount = sampleCount + other.sampleCount;
 
  106  double dnsc = 
double(newSampleCount);
 
  107  double dsc = 
double(sampleCount);
 
  108  double dscBydnsc = dsc / dnsc;
 
  109  double dosc = 
double(other.sampleCount);
 
  110  double delta = other.meanVal - meanVal;
 
  118  meanVal = meanVal * dscBydnsc + other.meanVal * (1 - dscBydnsc);
 
  119  m2 = m2 + other.m2 + dscBydnsc * dosc * delta * delta;
 
  120  minVal = std::min(minVal, other.minVal);
 
  121  maxVal = std::max(maxVal, other.maxVal);
 
  122  sampleCount = newSampleCount;
 
  129void statistic::scale(
double factor) {
 
  130  minVal = minVal * factor;
 
  131  maxVal = maxVal * factor;
 
  132  meanVal = meanVal * factor;
 
  133  m2 = m2 * factor * factor;
 
  137std::string statistic::format(
char unit, 
bool total)
 const {
 
  140  if (sampleCount == 0) {
 
  153          result + std::string(
", ") + 
formatSI(meanVal * sampleCount, 9, unit);
 
  162int logHistogram::minBin()
 const {
 
  163  for (
int i = 0; 
i < numBins; 
i++) {
 
  165      return i - logOffset;
 
  171int logHistogram::maxBin()
 const {
 
  172  for (
int i = numBins - 1; 
i >= 0; 
i--) {
 
  174      return i - logOffset;
 
  180uint32_t logHistogram::findBin(
double sample) {
 
  181  double v = std::fabs(sample);
 
  186  for (
int b = 0; 
b < numBins - 1; 
b++)
 
  192void logHistogram::addSample(
double sample) {
 
  202  uint32_t bin = findBin(sample);
 
  205  bins[bin].count += 1;
 
  206  bins[bin].total += sample;
 
  214std::string logHistogram::format(
char unit)
 const {
 
  217  result << 
"Bin,                Count,     Total\n";
 
  221    if (
count(minBin()) == 0)
 
  225  for (
int i = minBin(); 
i <= maxBin(); 
i++) {
 
  226    result << 
"10**" << 
i << 
"<=v<";
 
  227    if (
i + 1 == numBins - 1)
 
  230      result << 
"10**" << (
i + 1) << 
", ";
 
  244  if (timeStat::logEvent(timerEnumValue)) {
 
  245    __kmp_stats_thread_ptr->incrementNestValue();
 
  251                         kmp_stats_list *stats_ptr ) {
 
  252  if (startTime.getValue() == 0)
 
  255  stat->addSample(((tick - startTime) - totalPauseTime).ticks());
 
  257  if (timeStat::logEvent(timerEnumValue)) {
 
  259      stats_ptr = __kmp_stats_thread_ptr;
 
  260    stats_ptr->push_event(
 
  261        startTime.getValue() - __kmp_stats_start_time.getValue(),
 
  262        tick.
getValue() - __kmp_stats_start_time.getValue(),
 
  263        __kmp_stats_thread_ptr->getNestValue(), timerEnumValue);
 
  264    stats_ptr->decrementNestValue();
 
  274partitionedTimers::partitionedTimers() { timer_stack.reserve(8); }
 
  277void partitionedTimers::init(explicitTimer timer) {
 
  279  timer_stack.push_back(timer);
 
  287void partitionedTimers::push(explicitTimer timer) {
 
  292  explicitTimer *current_timer, *new_timer;
 
  295  timer_stack.push_back(timer);
 
  296  stack_size = timer_stack.size();
 
  297  current_timer = &(timer_stack[stack_size - 2]);
 
  298  new_timer = &(timer_stack[stack_size - 1]);
 
  300  current_timer->pause(tick);
 
  301  new_timer->start(tick);
 
  305void partitionedTimers::pop() {
 
  310  explicitTimer *old_timer, *new_timer;
 
  311  size_t stack_size = timer_stack.size();
 
  313  old_timer = &(timer_stack[stack_size - 1]);
 
  314  new_timer = &(timer_stack[stack_size - 2]);
 
  316  old_timer->stop(tick);
 
  317  new_timer->resume(tick);
 
  318  timer_stack.pop_back();
 
  321void partitionedTimers::exchange(explicitTimer timer) {
 
  326  explicitTimer *current_timer, *new_timer;
 
  330  stack_size = timer_stack.size();
 
  331  current_timer = &(timer_stack[stack_size - 1]);
 
  332  current_timer->stop(tick);
 
  333  timer_stack.pop_back();
 
  334  timer_stack.push_back(timer);
 
  335  new_timer = &(timer_stack[stack_size - 1]);
 
  336  new_timer->start(tick);
 
  343void partitionedTimers::windup() {
 
  344  while (timer_stack.size() > 1) {
 
  348  if (timer_stack.size() > 0) {
 
  350    timer_stack.pop_back();
 
  356void kmp_stats_event_vector::deallocate() {
 
  368  const kmp_stats_event *ev1 = 
RCAST(
const kmp_stats_event *, event1);
 
  369  const kmp_stats_event *ev2 = 
RCAST(
const kmp_stats_event *, event2);
 
  371  if (ev1->getStart() < ev2->getStart())
 
  373  else if (ev1->getStart() > ev2->getStart())
 
 
  379void kmp_stats_event_vector::sort() {
 
  386kmp_stats_list *kmp_stats_list::push_back(
int gtid) {
 
  387  kmp_stats_list *newnode =
 
  391  new (newnode) kmp_stats_list();
 
  392  newnode->setGtid(gtid);
 
  393  newnode->prev = this->prev;
 
  394  newnode->next = 
this;
 
  395  newnode->prev->next = newnode;
 
  396  newnode->next->prev = newnode;
 
  399void kmp_stats_list::deallocate() {
 
  400  kmp_stats_list *ptr = this->next;
 
  401  kmp_stats_list *delptr = this->next;
 
  402  while (ptr != 
this) {
 
  406    delptr->_event_vector.deallocate();
 
  407    delptr->~kmp_stats_list();
 
  411kmp_stats_list::iterator kmp_stats_list::begin() {
 
  412  kmp_stats_list::iterator it;
 
  416kmp_stats_list::iterator kmp_stats_list::end() {
 
  417  kmp_stats_list::iterator it;
 
  421int kmp_stats_list::size() {
 
  423  kmp_stats_list::iterator it;
 
  424  for (retval = 0, it = 
begin(); it != 
end(); it++, retval++) {
 
  431kmp_stats_list::iterator::iterator() : ptr(NULL) {}
 
  432kmp_stats_list::iterator::~iterator() {}
 
  433kmp_stats_list::iterator kmp_stats_list::iterator::operator++() {
 
  434  this->ptr = this->ptr->next;
 
  437kmp_stats_list::iterator kmp_stats_list::iterator::operator++(
int dummy) {
 
  438  this->ptr = this->ptr->next;
 
  441kmp_stats_list::iterator kmp_stats_list::iterator::operator--() {
 
  442  this->ptr = this->ptr->prev;
 
  445kmp_stats_list::iterator kmp_stats_list::iterator::operator--(
int dummy) {
 
  446  this->ptr = this->ptr->prev;
 
  449bool kmp_stats_list::iterator::operator!=(
const kmp_stats_list::iterator &rhs) {
 
  450  return this->ptr != rhs.ptr;
 
  452bool kmp_stats_list::iterator::operator==(
const kmp_stats_list::iterator &rhs) {
 
  453  return this->ptr == rhs.ptr;
 
  455kmp_stats_list *kmp_stats_list::iterator::operator*()
 const {
 
  461const char *kmp_stats_output_module::eventsFileName = NULL;
 
  462const char *kmp_stats_output_module::plotFileName = NULL;
 
  463int kmp_stats_output_module::printPerThreadFlag = 0;
 
  464int kmp_stats_output_module::printPerThreadEventsFlag = 0;
 
  468  for (
int i = l - 1; 
i >= 0; --
i) {
 
 
  479  FILE *
f = fopen(
"/proc/self/cmdline", 
"r");
 
  487  size_t n = fread(buffer, 1, buflen, 
f);
 
  493  buffer[buflen - 1] = 
char(0);
 
 
  497static void getTime(
char *buffer, 
size_t buflen, 
bool underscores = 
false) {
 
  502  struct tm *tm_info = localtime(&timer);
 
  504    strftime(buffer, buflen, 
"%Y-%m-%d_%H%M%S", tm_info);
 
  506    strftime(buffer, buflen, 
"%Y-%m-%d %H%M%S", tm_info);
 
 
  511                                    char const *imageName) {
 
  514  for (
int i = 0; prototype[
i] != 
char(0); 
i++) {
 
  515    char ch = prototype[
i];
 
  519      if (prototype[
i] == 
char(0))
 
  522      switch (prototype[
i]) {
 
  526        getTime(date, 
sizeof(date), 
true);
 
  534        std::stringstream ss;
 
 
  550void kmp_stats_output_module::init() {
 
  552  char *statsFileName = getenv(
"KMP_STATS_FILE");
 
  553  eventsFileName = getenv(
"KMP_STATS_EVENTS_FILE");
 
  554  plotFileName = getenv(
"KMP_STATS_PLOT_FILE");
 
  555  char *threadStats = getenv(
"KMP_STATS_THREADS");
 
  556  char *threadEvents = getenv(
"KMP_STATS_EVENTS");
 
  560    char imageName[1024];
 
  563        statsFileName, 
getImageName(&imageName[0], 
sizeof(imageName)));
 
  565  eventsFileName = eventsFileName ? eventsFileName : 
"events.dat";
 
  566  plotFileName = plotFileName ? plotFileName : 
"events.plt";
 
  573  if (printPerThreadEventsFlag) {
 
  578    timeStat::clearEventFlags();
 
  582void kmp_stats_output_module::setupEventColors() {
 
  584  int globalColorIndex = 0;
 
  585  int numGlobalColors = 
sizeof(globalColorArray) / 
sizeof(rgb_color);
 
  586  for (
i = 0; 
i < TIMER_LAST; 
i++) {
 
  587    if (timeStat::logEvent((timer_e)
i)) {
 
  588      timerColorInfo[
i] = globalColorArray[globalColorIndex];
 
  589      globalColorIndex = (globalColorIndex + 1) % numGlobalColors;
 
  594void kmp_stats_output_module::printTimerStats(FILE *statsOut,
 
  595                                              statistic 
const *theStats,
 
  596                                              statistic 
const *totalStats) {
 
  598          "Timer,                             SampleCount,    Min,      " 
  599          "Mean,       Max,     Total,        SD\n");
 
  600  for (timer_e 
s = timer_e(0); 
s < TIMER_LAST; 
s = timer_e(
s + 1)) {
 
  601    statistic 
const *stat = &theStats[
s];
 
  602    char tag = timeStat::noUnits(
s) ? 
' ' : 
'T';
 
  604    fprintf(statsOut, 
"%-35s, %s\n", timeStat::name(
s),
 
  605            stat->format(tag, 
true).c_str());
 
  608  for (timer_e 
s = timer_e(0); 
s < TIMER_LAST; 
s = timer_e(
s + 1)) {
 
  609    char tag = timeStat::noUnits(
s) ? 
' ' : 
'T';
 
  610    if (totalStats && !timeStat::noTotal(
s))
 
  611      fprintf(statsOut, 
"Total_%-29s, %s\n", timeStat::name(
s),
 
  612              totalStats[
s].
format(tag, 
true).c_str());
 
  616  if (theStats[0].haveHist()) {
 
  617    fprintf(statsOut, 
"\nTimer distributions\n");
 
  618    for (
int s = 0; 
s < TIMER_LAST; 
s++) {
 
  619      statistic 
const *stat = &theStats[
s];
 
  621      if (stat->getCount() != 0) {
 
  622        char tag = timeStat::noUnits(timer_e(
s)) ? 
' ' : 
'T';
 
  624        fprintf(statsOut, 
"%s\n", timeStat::name(timer_e(
s)));
 
  625        fprintf(statsOut, 
"%s\n", stat->getHist()->format(tag).c_str());
 
  631void kmp_stats_output_module::printCounterStats(FILE *statsOut,
 
  632                                                statistic 
const *theStats) {
 
  633  fprintf(statsOut, 
"Counter,                 ThreadCount,    Min,      Mean,  " 
  634                    "     Max,     Total,        SD\n");
 
  635  for (
int s = 0; 
s < COUNTER_LAST; 
s++) {
 
  636    statistic 
const *stat = &theStats[
s];
 
  637    fprintf(statsOut, 
"%-25s, %s\n", counter::name(counter_e(
s)),
 
  638            stat->format(
' ', 
true).c_str());
 
  641  if (theStats[0].haveHist()) {
 
  642    fprintf(statsOut, 
"\nCounter distributions\n");
 
  643    for (
int s = 0; 
s < COUNTER_LAST; 
s++) {
 
  644      statistic 
const *stat = &theStats[
s];
 
  646      if (stat->getCount() != 0) {
 
  647        fprintf(statsOut, 
"%s\n", counter::name(counter_e(
s)));
 
  648        fprintf(statsOut, 
"%s\n", stat->getHist()->format(
' ').c_str());
 
  654void kmp_stats_output_module::printCounters(FILE *statsOut,
 
  658  fprintf(statsOut, 
"\nCounter,                    Count\n");
 
  659  for (
int c = 0; c < COUNTER_LAST; c++) {
 
  660    counter const *stat = &theCounters[c];
 
  661    fprintf(statsOut, 
"%-25s, %s\n", counter::name(counter_e(c)),
 
  662            formatSI((
double)stat->getValue(), 9, 
' ').c_str());
 
  666void kmp_stats_output_module::printEvents(FILE *eventsOut,
 
  667                                          kmp_stats_event_vector *theEvents,
 
  671  for (
int i = 0; 
i < theEvents->size(); 
i++) {
 
  672    kmp_stats_event ev = theEvents->at(
i);
 
  673    rgb_color color = getEventColor(ev.getTimerName());
 
  674    fprintf(eventsOut, 
"%d %llu %llu %1.1f rgb(%1.1f,%1.1f,%1.1f) %s\n", gtid,
 
  675            static_cast<unsigned long long>(ev.getStart()),
 
  676            static_cast<unsigned long long>(ev.getStop()),
 
  677            1.2 - (ev.getNestLevel() * 0.2), color.r, color.g, color.b,
 
  678            timeStat::name(ev.getTimerName()));
 
  683void kmp_stats_output_module::windupExplicitTimers() {
 
  687  kmp_stats_list::iterator it;
 
  688  for (it = __kmp_stats_list->begin(); it != __kmp_stats_list->end(); it++) {
 
  689    kmp_stats_list *ptr = *it;
 
  690    ptr->getPartitionedTimers()->windup();
 
  695void kmp_stats_output_module::printPloticusFile() {
 
  697  int size = __kmp_stats_list->size();
 
  699  fprintf(plotOut, 
"#proc page\n" 
  710          "   title: OpenMP Sampling Timeline\n" 
  711          "   titledetails: align=center size=16\n" 
  712          "   rectangle: 1 1 13 9\n" 
  713          "   xautorange: datafield=2,3\n" 
  714          "   yautorange: -1 %d\n\n",
 
  717  fprintf(plotOut, 
"#proc xaxis\n" 
  719                   "   stubdetails: size=12\n" 
  720                   "   label: Time (ticks)\n" 
  721                   "   labeldetails: size=14\n\n");
 
  727          "   stubdetails: size=12\n" 
  729          "   labeldetails: size=14\n\n",
 
  732  fprintf(plotOut, 
"#proc bars\n" 
  733                   "   exactcolorfield: 5\n" 
  736                   "   segmentfields: 2 3\n" 
  737                   "   barwidthfield: 4\n\n");
 
  740  for (
i = 0; 
i < TIMER_LAST; 
i++) {
 
  741    if (timeStat::logEvent((timer_e)
i)) {
 
  742      rgb_color c = getEventColor((timer_e)
i);
 
  744              "#proc legendentry\n" 
  745              "   sampletype: color\n" 
  747              "   details: rgb(%1.1f,%1.1f,%1.1f)\n\n",
 
  748              timeStat::name((timer_e)
i), c.r, c.g, c.b);
 
  752  fprintf(plotOut, 
"#proc legend\n" 
  754                   "   location: max max\n\n");
 
  760  fprintf(statsOut, 
"# %s = %s\n", 
name, 
value ? 
value : 
"*unspecified*");
 
 
  768void kmp_stats_output_module::printHeaderInfo(FILE *statsOut) {
 
  769  std::time_t now = std::time(0);
 
  773  std::strftime(&buffer[0], 
sizeof(buffer), 
"%c", std::localtime(&now));
 
  774  fprintf(statsOut, 
"# Time of run: %s\n", &buffer[0]);
 
  775  if (gethostname(&hostName[0], 
sizeof(hostName)) == 0)
 
  776    fprintf(statsOut, 
"# Hostname: %s\n", &hostName[0]);
 
  777#if KMP_ARCH_X86 || KMP_ARCH_X86_64 
  778  fprintf(statsOut, 
"# CPU:  %s\n", &__kmp_cpuinfo.name[0]);
 
  779  fprintf(statsOut, 
"# Family: %d, Model: %d, Stepping: %d\n",
 
  780          __kmp_cpuinfo.family, __kmp_cpuinfo.model, __kmp_cpuinfo.stepping);
 
  781  if (__kmp_cpuinfo.frequency == 0)
 
  782    fprintf(statsOut, 
"# Nominal frequency: Unknown\n");
 
  784    fprintf(statsOut, 
"# Nominal frequency: %sz\n",
 
  785            formatSI(
double(__kmp_cpuinfo.frequency), 9, 
'H').c_str());
 
  790  fprintf(statsOut, 
"# Production runtime built " __DATE__ 
" " __TIME__ 
"\n");
 
  794void kmp_stats_output_module::outputStats(
const char *heading) {
 
  798  windupExplicitTimers();
 
  800  statistic allStats[TIMER_LAST];
 
  801  statistic totalStats[TIMER_LAST]; 
 
  803  statistic allCounters[COUNTER_LAST];
 
  806  if (!outputFileName.empty()) {
 
  807    statsOut.
open(outputFileName.c_str(), 
"a+");
 
  813  if (eventPrintingEnabled()) {
 
  814    eventsOut.
open(eventsFileName, 
"w+");
 
  817  printHeaderInfo(statsOut);
 
  818  fprintf(statsOut, 
"%s\n", heading);
 
  820  kmp_stats_list::iterator it;
 
  821  for (it = __kmp_stats_list->begin(); it != __kmp_stats_list->end(); it++) {
 
  822    int t = (*it)->getGtid();
 
  824    if (printPerThreadFlag) {
 
  825      fprintf(statsOut, 
"Thread %d\n", t);
 
  826      printTimerStats(statsOut, (*it)->getTimers(), 0);
 
  827      printCounters(statsOut, (*it)->getCounters());
 
  828      fprintf(statsOut, 
"\n");
 
  831    if (eventPrintingEnabled()) {
 
  832      kmp_stats_event_vector events = (*it)->getEventVector();
 
  833      printEvents(eventsOut, &events, t);
 
  837    for (timer_e 
s = timer_e(0); 
s < TIMER_LAST; 
s = timer_e(
s + 1)) {
 
  839      if ((timeStat::masterOnly(
s) && (t != 0)) || 
 
  841          (timeStat::workerOnly(
s) && (t == 0)) 
 
  847      statistic *threadStat = (*it)->getTimer(
s);
 
  848      allStats[
s] += *threadStat;
 
  851      if (!timeStat::noTotal(
s))
 
  852        totalStats[
s].addSample(threadStat->getTotal());
 
  856    for (counter_e c = counter_e(0); c < COUNTER_LAST; c = counter_e(c + 1)) {
 
  857      if (counter::masterOnly(c) && t != 0)
 
  859      allCounters[c].addSample((
double)(*it)->getCounter(c)->getValue());
 
  863  if (eventPrintingEnabled()) {
 
  867  fprintf(statsOut, 
"Aggregate for all threads\n");
 
  868  printTimerStats(statsOut, &allStats[0], &totalStats[0]);
 
  869  fprintf(statsOut, 
"\n");
 
  870  printCounterStats(statsOut, &allCounters[0]);
 
  880  kmp_stats_list::iterator it;
 
  881  for (it = __kmp_stats_list->begin(); it != __kmp_stats_list->end(); it++) {
 
  882    timeStat *timers = (*it)->getTimers();
 
  883    counter *counters = (*it)->getCounters();
 
  885    for (
int t = 0; t < TIMER_LAST; t++)
 
  888    for (
int c = 0; c < COUNTER_LAST; c++)
 
  892    (*it)->resetEventVector();
 
 
  915  __kmp_stats_list = 
new kmp_stats_list();
 
 
  920  __kmp_stats_list->deallocate();
 
  922  delete __kmp_stats_list;
 
 
This class safely opens and closes a C-style FILE* object using RAII semantics.
void set_stderr()
Set the FILE* object to stderr and output there No open call should happen before this call.
void open(const char *filename, const char *mode, const char *env_var=nullptr)
Open filename using mode.
static tsc_tick_count now()
__itt_string_handle * name
void const char const char int ITT_FORMAT __itt_group_sync s
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp __itt_timestamp end
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp begin
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t count
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp __itt_timestamp ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain ITT_FORMAT p const __itt_domain __itt_string_handle unsigned long long value
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t size
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp __itt_timestamp ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain ITT_FORMAT p const __itt_domain __itt_string_handle unsigned long long ITT_FORMAT lu const __itt_domain __itt_string_handle unsigned long long ITT_FORMAT lu const __itt_domain __itt_id __itt_string_handle __itt_metadata_type size_t void ITT_FORMAT p const __itt_domain __itt_id __itt_string_handle const wchar_t size_t ITT_FORMAT lu const __itt_domain __itt_id __itt_relation __itt_id ITT_FORMAT p const wchar_t int ITT_FORMAT __itt_group_mark d int
#define __kmp_allocate(size)
KMP_ARCH_X86 KMP_ARCH_X86 long double
#define KMP_DEBUG_ASSERT(cond)
#define KMP_CHECK_SYSFAIL(func, error)
void __kmp_init_tas_lock(kmp_tas_lock_t *lck)
#define KMP_XCHG_FIXED32(p, v)
int compare_two_events(const void *event1, const void *event2)
void __kmp_stats_init(void)
#define expandName(name, flags, ignore)
static kmp_stats_output_module * __kmp_stats_global_output
static void outputEnvVariable(FILE *statsOut, char const *name)
static void getTime(char *buffer, size_t buflen, bool underscores=false)
void __kmp_stats_fini(void)
void __kmp_output_stats(const char *heading)
static std::string generateFilename(char const *prototype, char const *imageName)
void __kmp_accumulate_stats_at_exit(void)
static char const * getImageName(char *buffer, size_t buflen)
static char const * lastName(char *name)
static uint32_t statsPrinted
Functions for collecting statistics.
std::string formatSI(double interval, int width, char unit)
int __kmp_str_match_true(char const *data)
std::string format(const std::string &Message, FormatOption Option)
Format the given message with the provided option(s) and return it.