HPCToolkit
start-stop.c
Go to the documentation of this file.
1 // -*-Mode: C++;-*- // technically C99
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 //***************************************************************************
48 //
49 // File:
50 // $HeadURL$
51 //
52 // Purpose:
53 // This file provides an API for the application to start and stop
54 // sampling with explicit function calls in the application source.
55 //
56 // Note:
57 // (1) The actions are process-wide.
58 //
59 // (2) The start and stop functions turn the sample sources on and off
60 // in the current thread. The sources in the other threads continue
61 // to run but don't unwind and don't record samples. Stopping
62 // sampling in all threads is more complicated because it would have
63 // to be done in a signal handler which can't really be done safely.
64 //
65 // (3) Sampling is initally on. If you want it initially off, then
66 // set HPCRUN_DELAY_SAMPLING in the environment.
67 //
68 //***************************************************************************
69 
70 #include <stdlib.h>
71 
72 #include "sample_sources_all.h"
73 #include "start-stop.h"
74 
75 static int sampling_is_active = 1;
76 static int dont_reinit = 0;
77 
78 
79 //***************************************************************************
80 // interface functions
81 //***************************************************************************
82 
83 void
85 {
86  // Make sure we don't run init twice. This is for the case that the
87  // application turns sampling on/off and then forks. We want to
88  // preserve the state across fork and not reset it in the child.
89  if (dont_reinit) {
90  return;
91  }
92  if (getenv("HPCRUN_DELAY_SAMPLING") != NULL) {
94  }
95  dont_reinit = 1;
96 }
97 
98 
99 int
101 {
102  return sampling_is_active;
103 }
104 
105 
106 void
108 {
109  sampling_is_active = 1;
110  dont_reinit = 1;
111  if (! SAMPLE_SOURCES(started)) {
112  SAMPLE_SOURCES(start);
113  }
114 }
115 
116 
117 void
119 {
120  sampling_is_active = 0;
121  dont_reinit = 1;
122  if (SAMPLE_SOURCES(started)) {
123  SAMPLE_SOURCES(stop);
124  }
125 }
126 
127 
128 // Fortran aliases
129 
130 // FIXME: The Fortran functions really need a separate API with
131 // different names to handle arguments and return values. But
132 // hpctoolkit_sampling_start() and _stop() are void->void, so they're
133 // a special case.
134 
135 void hpctoolkit_sampling_start_ (void) __attribute__ ((alias ("hpctoolkit_sampling_start")));
136 void hpctoolkit_sampling_start__(void) __attribute__ ((alias ("hpctoolkit_sampling_start")));
137 
138 void hpctoolkit_sampling_stop_ (void) __attribute__ ((alias ("hpctoolkit_sampling_stop")));
139 void hpctoolkit_sampling_stop__(void) __attribute__ ((alias ("hpctoolkit_sampling_stop")));
#define SAMPLE_SOURCES(op,...)
static int sampling_is_active
Definition: start-stop.c:75
static int dont_reinit
Definition: start-stop.c:76
int hpctoolkit_sampling_is_active(void)
Definition: start-stop.c:100
void __attribute__((weak))
Definition: hpctoolkit.c:64
void hpcrun_start_stop_internal_init(void)
Definition: start-stop.c:84
void hpctoolkit_sampling_stop(void)
Definition: start-stop.c:118
#define NULL
Definition: ElfHelper.cpp:85
void hpctoolkit_sampling_start(void)
Definition: start-stop.c:107