| /* Copyright (C) 2021-2024 Free Software Foundation, Inc. |
| Contributed by Oracle. |
| |
| This file is part of GNU Binutils. |
| |
| This program is free software; you can redistribute it and/or modify |
| it under the terms of the GNU General Public License as published by |
| the Free Software Foundation; either version 3, or (at your option) |
| any later version. |
| |
| This program is distributed in the hope that it will be useful, |
| but WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| GNU General Public License for more details. |
| |
| You should have received a copy of the GNU General Public License |
| along with this program; if not, write to the Free Software |
| Foundation, 51 Franklin Street - Fifth Floor, Boston, |
| MA 02110-1301, USA. */ |
| |
| #ifndef _LIBCOLLECTOR_H |
| #define _LIBCOLLECTOR_H |
| |
| typedef struct |
| { |
| unsigned int offset; |
| unsigned int lineno; |
| } Lineno; |
| |
| #ifdef __cplusplus |
| extern "C" |
| { |
| #endif |
| |
| /* This file contains function prototypes for the user-callable API |
| routines in libcollector for C and C++ codes. */ |
| |
| /* Routine to record a sample in the experiment. */ |
| void collector_sample (char *name); |
| |
| /* Routine to suspend data collection during an experiment. */ |
| void collector_pause (void); |
| |
| /* Routine to resume data collection during an experiment. */ |
| void collector_resume (void); |
| |
| /* Routine to suspend per-thread data collection during an experiment. */ |
| void collector_thread_pause (unsigned int tid); |
| |
| /* Routine to resume per-thread data collection during an experiment. */ |
| void collector_thread_resume (unsigned int tid); |
| |
| /* Routine to close the experiment, and stop all data collection. */ |
| void collector_terminate_expt (void); |
| |
| /* Routines to let libcollector know about a dynamically loaded function. */ |
| void collector_func_load (char *name, char *alias, char *sourcename, |
| void *vaddr, int size, int lntsize, Lineno *lntable); |
| void collector_func_unload (void *vaddr); |
| |
| /* Define the weak symbols for the API. */ |
| void collector_sample () __attribute__ ((weak)); |
| void collector_pause () __attribute__ ((weak)); |
| void collector_resume () __attribute__ ((weak)); |
| void collector_thread_pause () __attribute__ ((weak)); |
| void collector_thread_resume () __attribute__ ((weak)); |
| void collector_terminate_expt () __attribute__ ((weak)); |
| void collector_func_load () __attribute__ ((weak)); |
| void collector_func_unload () __attribute__ ((weak)); |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| /* Define the macros that actually get inserted in the caller's code. */ |
| #define collector_sample(x) (collector_sample ? collector_sample(x), 0 : 0) |
| #define collector_pause() (collector_pause ? collector_pause(), 0 : 0) |
| #define collector_resume() (collector_resume ? collector_resume(),0 : 0 |
| #define collector_thread_pause(tid) \ |
| (collector_thread_pause ? collector_thread_pause(tid), 0 : 0) |
| #define collector_thread_resume(tid) \ |
| (collector_thread_resume ? collector_thread_resume(tid), 0 : 0) |
| #define collector_terminate_expt() \ |
| (collector_terminate_expt ? collector_terminate_expt(), 0 : 0) |
| #define collector_func_load(x0,x1,x2,x3,x4,x5,x6) \ |
| collector_func_load ? collector_func_load(x0,x1,x2,x3,x4,x5,x6), 0 : 0) |
| #define collector_func_unload(x) \ |
| (collector_func_unload ? collector_func_unload(x), 0 : 0) |
| #endif /* _LIBCOLLECTOR_H */ |