pmemobj_log_set_threshold - Man Page
set the logging threshold value
Synopsis
#include <libpmemobj.h> enum pmemobj_log_level { PMEMOBJ_LOG_LEVEL_HARK, PMEMOBJ_LOG_LEVEL_FATAL, PMEMOBJ_LOG_LEVEL_ERROR, PMEMOBJ_LOG_LEVEL_WARNING, PMEMOBJ_LOG_LEVEL_NOTICE, PMEMOBJ_LOG_LEVEL_INFO, PMEMOBJ_LOG_LEVEL_DEBUG }; enum pmemobj_log_threshold { PMEMOBJ_LOG_THRESHOLD, PMEMOBJ_LOG_THRESHOLD_AUX }; int pmemobj_log_set_threshold(enum pmemobj_log_threshold threshold, enum pmemobj_log_level value);
Description
pmemobj_log_set_threshold() sets the logging threshold value.
Available thresholds are:
- PMEMOBJ_LOG_THRESHOLD - the main threshold used to filter out undesired logging messages. Messages less severe than indicated by this threshold’s value are ignored so they won’t make it to the logging function (please see pmemobj_log_set_function(3)). The default value is PMEMOBJ_LOG_WARNING.
- PMEMOBJ_LOG_THRESHOLD_AUX - the auxiliary threshold intended for use inside the logging function (please see pmemobj_log_get_threshold(3)). A custom logging function may or may not take this threshold into consideration depending on the developer’s needs. For the default logging function behaviour please see pmemobj_log_set_function(3). The initial value of this threshold is PMEMOBJ_LOG_LEVEL_HARK.
Available threshold values are defined by enum pmemobj_log_level. They are listed in descending order of severity:
- PMEMOBJ_LOG_LEVEL_HARK - only basic library info. Shall be used to effectively suppress the logging since it is used just for a few messages when the program is started and whenever a new logging function is set. Please see pmemobj_log_set_function(3).
- PMEMOBJ_LOG_LEVEL_FATAL - an error that causes the program to stop working immediately. Sorry.
- PMEMOBJ_LOG_LEVEL_ERROR - an error that causes the current operation or transaction to fail
- PMEMOBJ_LOG_LEVEL_WARNING - an unexpected situation that does NOT cause the current operation to fail
- PMEMOBJ_LOG_LEVEL_NOTICE - non-massive info mainly related to public API function completions
- PMEMOBJ_LOG_LEVEL_INFO - massive info e.g. every write operation indication
- PMEMOBJ_LOG_LEVEL_DEBUG - debug info e.g. write operation dump
Return Value
pmemobj_log_set_threshold() function returns 0 on success or returns a non-zero value and sets errno on failure. On failure, the threshold value remains unchanged.
Errors
pmemobj_log_set_threshold() can set the following errno values on fail:
- EINVAL - threshold is not PMEMOBJ_LOG_THRESHOLD nor PMEMOBJ_LOG_THRESHOLD_AUX
- EINVAL - value is not defined by enum pmemobj_log_level type
- EAGAIN - multiple threads attempted to change the threshold value concurrently. A retry may fix the problem. This error is not expected when the function is called from just one thread at a time.
See Also
Referenced By
libpmemobj(7), pmemobj_log_get_threshold(3), pmemobj_log_set_function(3).
2024-07-18 PMDK - PMDK Programmer's Manual