|  | /* 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 */ |