2020-03-14 06:13:17 +08:00
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
* Copyright by The HDF Group. *
|
|
|
|
* All rights reserved. *
|
|
|
|
* *
|
|
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
* terms governing use, modification, and redistribution, is contained in *
|
|
|
|
* the COPYING file, which can be found at the root of the source code *
|
2021-02-17 22:52:36 +08:00
|
|
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
2020-03-14 06:13:17 +08:00
|
|
|
* If you do not have access to either file, you may request a copy from *
|
|
|
|
* help@hdfgroup.org. *
|
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
2023-06-14 23:01:04 +08:00
|
|
|
/*
|
|
|
|
* Common operations for "remote" processes for the mirror VFD
|
2020-03-14 06:13:17 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "mirror_remote.h"
|
|
|
|
|
|
|
|
#ifdef H5_HAVE_MIRROR_VFD
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------
|
|
|
|
* Function: mirror_log
|
|
|
|
*
|
|
|
|
* Purpose: Write message to the logging stream/file.
|
|
|
|
* If logging info pointer is NULL, uses logging defaults.
|
|
|
|
* ----------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
void
|
2020-09-30 22:27:10 +08:00
|
|
|
mirror_log(struct mirror_log_info *info, unsigned int level, const char *format, ...)
|
2020-03-14 06:13:17 +08:00
|
|
|
{
|
2022-07-27 05:45:46 +08:00
|
|
|
FILE *stream = MIRROR_LOG_DEFAULT_STREAM;
|
2020-03-14 06:13:17 +08:00
|
|
|
unsigned int verbosity = MIRROR_LOG_DEFAULT_VERBOSITY;
|
2023-06-14 23:01:04 +08:00
|
|
|
bool custom = false;
|
2020-03-14 06:13:17 +08:00
|
|
|
|
|
|
|
if (info != NULL && info->magic == MIRROR_LOG_INFO_MAGIC) {
|
2020-09-30 22:27:10 +08:00
|
|
|
stream = info->stream;
|
2020-03-14 06:13:17 +08:00
|
|
|
verbosity = info->verbosity;
|
2023-06-14 23:01:04 +08:00
|
|
|
custom = true;
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (level == V_NONE) {
|
|
|
|
return;
|
|
|
|
}
|
2020-09-30 22:27:10 +08:00
|
|
|
else if (level <= verbosity) {
|
2023-06-14 23:01:04 +08:00
|
|
|
if (custom == true && info->prefix[0] != '\0') {
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, "%s", info->prefix);
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
switch (level) {
|
2020-09-30 22:27:10 +08:00
|
|
|
case (V_ERR):
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, "ERROR ");
|
2020-09-30 22:27:10 +08:00
|
|
|
break;
|
|
|
|
case (V_WARN):
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, "WARNING ");
|
2020-09-30 22:27:10 +08:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (format != NULL) {
|
|
|
|
va_list args;
|
2023-06-28 08:43:23 +08:00
|
|
|
va_start(args, format);
|
2023-09-16 06:13:18 +08:00
|
|
|
vfprintf(stream, format, args);
|
2023-06-28 08:43:23 +08:00
|
|
|
va_end(args);
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, "\n");
|
2023-06-29 23:19:31 +08:00
|
|
|
fflush(stream);
|
2020-03-14 06:13:17 +08:00
|
|
|
} /* end if sufficiently verbose to print */
|
|
|
|
} /* end mirror_log() */
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------
|
|
|
|
* Function: session_log_bytes
|
|
|
|
*
|
|
|
|
* Purpose: "Pretty-print" raw binary data to logging stream/file.
|
|
|
|
* If info pointer is NULL, uses logging defaults.
|
|
|
|
* ----------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
void
|
2020-09-30 22:27:10 +08:00
|
|
|
mirror_log_bytes(struct mirror_log_info *info, unsigned int level, size_t n_bytes, const unsigned char *buf)
|
2020-03-14 06:13:17 +08:00
|
|
|
{
|
2022-07-27 05:45:46 +08:00
|
|
|
FILE *stream = MIRROR_LOG_DEFAULT_STREAM;
|
2020-03-14 06:13:17 +08:00
|
|
|
unsigned int verbosity = MIRROR_LOG_DEFAULT_VERBOSITY;
|
|
|
|
|
|
|
|
if (buf == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (info != NULL && info->magic == MIRROR_LOG_INFO_MAGIC) {
|
2020-09-30 22:27:10 +08:00
|
|
|
stream = info->stream;
|
2020-03-14 06:13:17 +08:00
|
|
|
verbosity = info->verbosity;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (level <= verbosity) {
|
2020-09-30 22:27:10 +08:00
|
|
|
size_t bytes_written = 0;
|
|
|
|
const unsigned char *b = NULL;
|
2020-03-14 06:13:17 +08:00
|
|
|
|
|
|
|
/* print whole lines */
|
|
|
|
while ((n_bytes - bytes_written) >= 32) {
|
|
|
|
b = buf + bytes_written; /* point to region in buffer */
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream,
|
|
|
|
"%04zX %02X%02X%02X%02X %02X%02X%02X%02X"
|
|
|
|
" %02X%02X%02X%02X %02X%02X%02X%02X"
|
|
|
|
" %02X%02X%02X%02X %02X%02X%02X%02X"
|
|
|
|
" %02X%02X%02X%02X %02X%02X%02X%02X\n",
|
|
|
|
bytes_written, b[0], b[1], b[2], b[3], b[4], b[5], b[6], b[7], b[8], b[9], b[10], b[11],
|
|
|
|
b[12], b[13], b[14], b[15], b[16], b[17], b[18], b[19], b[20], b[21], b[22], b[23], b[24],
|
|
|
|
b[25], b[26], b[27], b[28], b[29], b[30], b[31]);
|
2020-03-14 06:13:17 +08:00
|
|
|
bytes_written += 32;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* start partial line */
|
|
|
|
if (n_bytes > bytes_written) {
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, "%04zX ", bytes_written);
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* partial line blocks */
|
|
|
|
while ((n_bytes - bytes_written) >= 4) {
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, " %02X%02X%02X%02X", buf[bytes_written], buf[bytes_written + 1],
|
|
|
|
buf[bytes_written + 2], buf[bytes_written + 3]);
|
2020-03-14 06:13:17 +08:00
|
|
|
bytes_written += 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* block separator before partial block */
|
|
|
|
if (n_bytes > bytes_written) {
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, " ");
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* partial block individual bytes */
|
|
|
|
while (n_bytes > bytes_written) {
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, "%02X", buf[bytes_written++]);
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* end partial line */
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(stream, "\n");
|
2020-03-14 06:13:17 +08:00
|
|
|
} /* end if suitably verbose to log */
|
|
|
|
} /* end mirror_log_bytes() */
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------
|
|
|
|
* Function: mirror_log_init
|
|
|
|
*
|
|
|
|
* Purpose: Prepare a loginfo_t structure for use.
|
|
|
|
*
|
|
|
|
* Return: Success: Pointer to newly-ceated info.
|
|
|
|
* Failure: NULL. Either unable to allocate or cannot open file.
|
|
|
|
* ----------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
loginfo_t *
|
2022-02-22 05:32:29 +08:00
|
|
|
mirror_log_init(char *path, const char *prefix, unsigned int verbosity)
|
2020-03-14 06:13:17 +08:00
|
|
|
{
|
|
|
|
loginfo_t *info = NULL;
|
|
|
|
|
2023-06-29 06:48:12 +08:00
|
|
|
info = (loginfo_t *)malloc(sizeof(loginfo_t));
|
2020-03-14 06:13:17 +08:00
|
|
|
if (info != NULL) {
|
2020-09-30 22:27:10 +08:00
|
|
|
info->magic = MIRROR_LOG_INFO_MAGIC;
|
2020-03-14 06:13:17 +08:00
|
|
|
info->verbosity = verbosity;
|
2020-09-30 22:27:10 +08:00
|
|
|
info->stream = MIRROR_LOG_DEFAULT_STREAM;
|
2020-03-14 06:13:17 +08:00
|
|
|
info->prefix[0] = '\0';
|
|
|
|
|
|
|
|
if (prefix && *prefix) {
|
2023-09-16 06:13:18 +08:00
|
|
|
strncpy(info->prefix, prefix, MIRROR_LOG_PREFIX_MAX);
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (path && *path) {
|
|
|
|
FILE *f = NULL;
|
2023-06-29 23:19:31 +08:00
|
|
|
f = fopen(path, "w");
|
2020-03-14 06:13:17 +08:00
|
|
|
if (NULL == f) {
|
2023-06-28 23:31:32 +08:00
|
|
|
fprintf(MIRROR_LOG_DEFAULT_STREAM, "WARN custom logging path could not be opened: %s\n",
|
|
|
|
path);
|
2020-03-14 06:13:17 +08:00
|
|
|
info->magic += 1;
|
2023-06-29 06:48:12 +08:00
|
|
|
free(info);
|
2020-03-14 06:13:17 +08:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
info->stream = f;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} /* end if able to allocate */
|
|
|
|
|
|
|
|
return info;
|
|
|
|
} /* end mirror_log_init() */
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------
|
|
|
|
* Function: mirror_log_term
|
|
|
|
*
|
|
|
|
* Purpose: Shut down and clean up a loginfo_t structure.
|
|
|
|
*
|
|
|
|
* Return: Success: SUCCEED. Resources released.
|
|
|
|
* Failure: FAIL. Indeterminite state.
|
|
|
|
* ----------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
herr_t
|
|
|
|
mirror_log_term(loginfo_t *info)
|
|
|
|
{
|
|
|
|
if (info == NULL || info->magic != MIRROR_LOG_INFO_MAGIC) {
|
|
|
|
return FAIL;
|
|
|
|
}
|
|
|
|
if (info->stream != stderr || info->stream != stdout) {
|
2023-06-29 23:19:31 +08:00
|
|
|
if (fclose(info->stream) < 0) {
|
2020-03-14 06:13:17 +08:00
|
|
|
return FAIL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
info->magic += 1;
|
2023-06-29 06:48:12 +08:00
|
|
|
free(info);
|
2020-03-14 06:13:17 +08:00
|
|
|
return SUCCEED;
|
|
|
|
} /* end mirror_log_term() */
|
|
|
|
|
|
|
|
#endif /* H5_HAVE_MIRROR_VFD */
|