pmc_configure_logfile
,
pmc_flush_logfile
,
pmc_writelog
,
pmc_close_logfile
— log file
management
Performance Counters Library (libpmc,
-lpmc)
#include
<pmc.h>
int
pmc_configure_logfile
(int
fd);
int
pmc_flush_logfile
(void);
int
pmc_writelog
(uint32_t
userdata);
int
pmc_close_logfile
(void);
The functions manage logging of
hwpmc(4)
events.
Function
pmc_configure_logfile
()
is used to turn on and turn off logging. If argument
fd is a valid file handle returned by a prior call to
open(2)
or
socket(2)
then performance events will be logged to the file corresponding to the
specified handle. If the value of argument fd is -1
then logging will be stopped after any pending data is flushed.
Function
pmc_flush_logfile
()
will force all log data queued inside the
hwpmc(4)
driver to be written out.
Function
pmc_writelog
()
will append a log entry containing the value of argument
userdata to the log file.
Function
pmc_close_logfile
()
will flush all pending log data and close
hwpmc(4)'s
side of the stream.
Upon successful completion, the value 0 is returned;
otherwise the value -1 is returned and the global variable
errno is set to indicate the error.
A call to pmc_configure_logfile
() may fail
with the following errors:
- [
EAGAIN
]
- The
hwpmc(4)
driver was not able to create a helper process due to system limits being
reached.
- [
EBUSY
]
- Function
pmc_configure_logfile
() was called with a
log file already configured.
- [
EINVAL
]
- Function
pmc_configure_logfile
() was called with
an argument of -1 without a log file being previously configured.
- [
ENOMEM
]
- The system encountered a memory shortage when servicing this request.
A call to pmc_flush_logfile
() may fail
with the following errors:
- [
EINVAL
]
- Function
pmc_flush_logfile
() was called without a
log file being previously configured.
A call to pmc_writelog
() may fail with the
following errors:
- [
EINVAL
]
- Function
pmc_writelog
() was called without a log
file being previously configured.
- [
ENOMEM
]
- The system encountered a memory shortage when servicing this request.