UM C API  6.16.1
Source code for lbmmonfmtcsv.c
/*
All of the documentation and software included in this and any
other Informatica Inc. Ultra Messaging Releases
Copyright (C) Informatica Inc. All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted only as covered by the terms of a
valid software license agreement with Informatica Inc.
(C) Copyright 2004,2023 Informatica Inc. All Rights Reserved.
THE SOFTWARE IS PROVIDED "AS IS" AND INFORMATICA DISCLAIMS ALL WARRANTIES
EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION, ANY IMPLIED WARRANTIES OF
NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR
PURPOSE. INFORMATICA DOES NOT WARRANT THAT USE OF THE SOFTWARE WILL BE
UNINTERRUPTED OR ERROR-FREE. INFORMATICA SHALL NOT, UNDER ANY CIRCUMSTANCES, BE
LIABLE TO LICENSEE FOR LOST PROFITS, CONSEQUENTIAL, INCIDENTAL, SPECIAL OR
INDIRECT DAMAGES ARISING OUT OF OR RELATED TO THIS AGREEMENT OR THE
TRANSACTIONS CONTEMPLATED HEREUNDER, EVEN IF INFORMATICA HAS BEEN APPRISED OF
THE LIKELIHOOD OF SUCH DAMAGES.
*/
#ifdef __VOS__
#define _POSIX_C_SOURCE 200112L
#include <sys/time.h>
#endif
#include <stdio.h>
#include <string.h>
#include <stddef.h>
#include <time.h>
#include <limits.h>
#include <errno.h>
#include <ctype.h>
#ifdef _WIN32
#define strcasecmp stricmp
#define snprintf _snprintf
#else
#endif
#if defined(__TANDEM)
#include <strings.h>
#endif
#include <lbm/lbmmon.h>
#include "lbmmon_int.h"
#include <lbm/lbmmonfmtcsv.h>
#include "lbmcommon.h"
#include "mullog.h"
static const lbmmon_format_func_t LBMMON_FORMAT_CSV =
{
lbmmon_format_csv_init,
NULL, /* lbmmon_format_apply_options_t */
lbmmon_rcv_format_csv_serialize,
lbmmon_src_format_csv_serialize,
lbmmon_rcv_format_csv_deserialize,
lbmmon_src_format_csv_deserialize,
lbmmon_format_csv_finish,
lbmmon_format_csv_errmsg,
lbmmon_evq_format_csv_serialize,
lbmmon_evq_format_csv_deserialize,
lbmmon_ctx_format_csv_serialize,
lbmmon_ctx_format_csv_deserialize,
lbmmon_rcv_topic_format_csv_serialize,
lbmmon_rcv_topic_format_csv_deserialize,
lbmmon_wildcard_rcv_format_csv_serialize,
lbmmon_wildcard_rcv_format_csv_deserialize,
lbmmon_store_format_csv_serialize,
lbmmon_store_format_csv_deserialize,
NULL, /* lbmmon_umestore_filter_options_t */
NULL, /* lbmmon_umestore_free_unpacked_t */
lbmmon_gateway_format_csv_serialize,
lbmmon_gateway_format_csv_deserialize,
NULL /* lbmmon_gateway_free_unpacked_t */
};
typedef struct
{
unsigned char mSeparator;
int mPassthrough;
size_t mBufferSize;
char * mBuffer;
} lbmmon_format_csv_t;
static const char * next_csv_value(const char * String, char * Value, size_t Size, char Separator);
/* Uses LBMMON_FORMAT_CSV_MODULE_ID 1 */
#define LBMMON_FORMAT_CSV_VERSION_1 1
#define LBMMON_FORMAT_CSV_VERSION_2 2
#define LBMMON_FORMAT_CSV_VERSION_3 3
#define LBMMON_FORMAT_CSV_VERSION_4 4
#define LBMMON_FORMAT_CSV_VERSION_5 5
#define LBMMON_FORMAT_CSV_VERSION_CURRENT LBMMON_FORMAT_CSV_VERSION_5
typedef struct
{
const size_t * layout;
size_t count;
} lbmmon_csv_layout_t;
static char ErrorString[1024];
static void lbmmon_format_csv_report_allocation_error(size_t Size)
{
snprintf(ErrorString, sizeof(ErrorString), "Unable to allocate %u bytes", (unsigned) Size);
}
static void lbmmon_format_csv_convert_to_hex(char * Buffer, const lbm_uint8_t * Data, size_t Length)
{
static char hextable[16] =
{ '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
unsigned char c;
char * buf = Buffer;
size_t iidx = 0;
size_t oidx = 0;
while (iidx < Length)
{
c = Data[iidx];
buf[oidx++] = hextable[((c >> 4) & 0x0f)];
buf[oidx++] = hextable[(c & 0x0f)];
iidx++;
}
}
static void lbmmon_format_csv_convert_from_hex(char * Buffer, const lbm_uint8_t * Data, size_t Length)
{
unsigned char c;
char * buf = Buffer;
size_t iidx = 0;
size_t oidx = 0;
unsigned char n1;
unsigned char n2;
unsigned char b;
if ((Length % 2) != 0)
{
memset((void *) Buffer, 0, (Length / 2));
return;
}
while (iidx < Length)
{
b = 0;
c = Data[iidx++];
if (isxdigit(c))
{
if (isdigit(c))
{
n1 = c - '0';
}
else if (isupper(c))
{
n1 = 0x0a + (c - 'A');
}
else
{
n1 = 0x0a + (c - 'a');
}
}
else
{
n1 = 0;
}
c = Data[iidx++];
if (isxdigit(c))
{
if (isdigit(c))
{
n2 = c - '0';
}
else if (isupper(c))
{
n2 = 0x0a + (c - 'A');
}
else
{
n2 = 0x0a + (c - 'a');
}
}
else
{
n2 = 0;
}
b = ((n1 & 0x0f) << 4) | (n2 & 0x0f);
buf[oidx++] = b;
}
}
const lbmmon_format_func_t * lbmmon_format_csv_module(void)
{
return (&LBMMON_FORMAT_CSV);
}
int lbmmon_format_csv_init(void * * FormatClientData, const void * FormatOptions)
{
char key[512];
char value[512];
const char * ptr = (const char *) FormatOptions;
lbmmon_format_csv_t * data;
memset(ErrorString, 0, sizeof(ErrorString));
*FormatClientData = NULL;
data = malloc(sizeof(lbmmon_format_csv_t));
if (data == NULL)
{
lbmmon_format_csv_report_allocation_error(sizeof(lbmmon_format_csv_t));
return (-1);
}
data->mSeparator = ',';
data->mPassthrough = LBMMON_FORMAT_PASSTHROUGH_OFF;
data->mBufferSize = 1024;
data->mBuffer = malloc(data->mBufferSize);
if (data->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(data->mBufferSize);
free(data);
return (-1);
}
while ((ptr = lbmmon_next_key_value_pair(ptr, key, sizeof(key), value, sizeof(value))) != NULL)
{
if (strcasecmp(key, "separator") == 0)
{
data->mSeparator = value[0];
}
else if (strcasecmp(key, "passthrough") == 0)
{
if (strcasecmp(value, "off") == 0) {
data->mPassthrough = LBMMON_FORMAT_PASSTHROUGH_OFF;
}
else if (strcasecmp(value, "on") == 0) {
data->mPassthrough = LBMMON_FORMAT_PASSTHROUGH_ON;
}
else if (strcasecmp(value, "convert") == 0) {
data->mPassthrough = LBMMON_FORMAT_PASSTHROUGH_CONVERT;
}
else {
/*MSGDESC: Invalid value for passthrough
*MSGRES: value must be "off" or "on" */
LBM_EINVAL_RETURN("CoreApi-9778-100: value must be \"off\", \"on\" or \"convert\" for monitor format option \"passthrough\".", -1);
}
}
}
*FormatClientData = (void *)data;
return (0);
}
/*
Format of the CSV receiver statistics data is:
type (one of LBM_TRANSPORT_STAT_* values)
source (as a string)
actual statistics, depending on type....
for LBTRM:
msgs_rcved
bytes_rcved
nak_pckts_sent
naks_sent
lost
ncfs_ignored
ncfs_shed
ncfs_rx_delay
ncfs_unknown
nak_stm_min
nak_stm_mean
nak_stm_max
nak_tx_min
nak_tx_mean
nak_tx_max
duplicate_data
unrecovered_txw
unrecovered_tmo
lbm_msgs_rcved
lbm_msgs_no_topic_rcved
lbm_reqs_rcved
dgrams_dropped_size
dgrams_dropped_type
dgrams_dropped_version
dgrams_dropped_hdr
dgrams_dropped_other
out_of_order
for LBTRU:
msgs_rcved
bytes_rcved
nak_pckts_sent
naks_sent
lost
ncfs_ignored
ncfs_shed
ncfs_rx_delay
ncfs_unknown
nak_stm_min
nak_stm_mean
nak_stm_max
nak_tx_min
nak_tx_mean
nak_tx_max
duplicate_data
unrecovered_txw
unrecovered_tmo
lbm_msgs_rcved
lbm_msgs_no_topic_rcved
lbm_reqs_rcved
dgrams_dropped_size
dgrams_dropped_type
dgrams_dropped_version
dgrams_dropped_hdr
dgrams_dropped_sid
dgrams_dropped_other
for TCP:
bytes_rcved
lbm_msgs_rcved
lbm_msgs_no_topic_rcved
lbm_reqs_rcved
for LBTIPC:
msgs_rcved
bytes_rcved
lbm_msgs_rcved
lbm_msgs_no_topic_rcved
lbm_reqs_rcved
for LBTRDMA:
msgs_rcved
bytes_rcved
lbm_msgs_rcved
lbm_msgs_no_topic_rcved
lbm_reqs_rcved
*/
int lbmmon_rcv_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, const lbm_rcv_transport_stats_t * Statistics, void * FormatClientData)
{
char work[1024];
lbmmon_format_csv_t * fmt;
if ((Destination == NULL) || (Size == NULL) || (*Size == 0) || (Statistics == NULL) || (FormatClientData == NULL))
{
return (-1);
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
*ModuleID = MAKE_MODULE_VERSION(LBMMON_FORMAT_CSV_MODULE_ID,LBMMON_FORMAT_CSV_VERSION_CURRENT);
memset(work, 0, sizeof(work));
snprintf(work, sizeof(work), "%d%c\"",
Statistics->type,
fmt->mSeparator);
strncat(work, Statistics->source, sizeof(work) - strlen(work) - 1);
strncat(work, "\"", sizeof(work) - strlen(work) - 1);
strncpy(Destination, work, *Size);
switch (Statistics->type)
{
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
Statistics->transport.tcp.bytes_rcved,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
Statistics->transport.lbtrm.msgs_rcved,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtrm.naks_sent,
fmt->mSeparator,
Statistics->transport.lbtrm.lost,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtrm.ncfs_shed,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtrm.nak_tx_min,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtrm.nak_tx_max,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
Statistics->transport.lbtru.msgs_rcved,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtru.naks_sent,
fmt->mSeparator,
Statistics->transport.lbtru.lost,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtru.ncfs_shed,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtru.nak_tx_min,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtru.nak_tx_max,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtsmx.reserved1);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
default:
strncpy(ErrorString, "Unknown LBM transport type", sizeof(ErrorString));
return (-1);
}
*Size = strlen(Destination);
return (0);
}
/*
Format of the CSV source statistics data is:
type (one of LBM_TRANSPORT_STAT_* values)
source (as a string)
actual statistics, depending on type....
for LBTRM:
msgs_sent
bytes_sent
txw_msgs
txw_bytes
nak_pckts_rcved
naks_rcved
naks_ignored
naks_shed
naks_rx_delay_ignored
rxs_sent
rctlr_data_msgs
rctlr_rx_msgs
rx_bytes_sent
for LBTRU:
msgs_sent
bytes_sent
nak_pckts_rcved
naks_rcved
naks_ignored
naks_shed
naks_rx_delay_ignored
rxs_sent
num_clients
rx_bytes_sent
for TCP:
num_clients
bytes_buffered
for LBTIPC:
num_clients
msgs_sent
bytes_sent
for LBTRDMA:
num_clients
msgs_sent
bytes_sent
*/
int lbmmon_src_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, const lbm_src_transport_stats_t * Statistics, void * FormatClientData)
{
char work[1024];
lbmmon_format_csv_t * fmt;
if ((Destination == NULL) || (Size == NULL) || (*Size == 0) || (Statistics == NULL) || (FormatClientData == NULL))
{
return (-1);
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
*ModuleID = MAKE_MODULE_VERSION(LBMMON_FORMAT_CSV_MODULE_ID,LBMMON_FORMAT_CSV_VERSION_CURRENT);
memset(work, 0, sizeof(work));
snprintf(work, sizeof(work), "%d%c\"",
Statistics->type,
fmt->mSeparator);
strncat(work, Statistics->source, sizeof(work) - strlen(work) - 1);
strncat(work, "\"", sizeof(work) - strlen(work) - 1);
strncpy(Destination, work, *Size);
switch (Statistics->type)
{
snprintf(work,
sizeof(work),
"%c%lx%c%lx",
fmt->mSeparator,
Statistics->transport.tcp.num_clients,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
Statistics->transport.lbtrm.msgs_sent,
fmt->mSeparator,
Statistics->transport.lbtrm.bytes_sent,
fmt->mSeparator,
Statistics->transport.lbtrm.txw_msgs,
fmt->mSeparator,
Statistics->transport.lbtrm.txw_bytes,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtrm.naks_rcved,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtrm.naks_shed);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtrm.rxs_sent,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
fmt->mSeparator,
Statistics->transport.lbtru.msgs_sent,
fmt->mSeparator,
Statistics->transport.lbtru.bytes_sent,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtru.naks_rcved,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtru.naks_shed,
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtru.rxs_sent);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtipc.msgs_sent,
fmt->mSeparator,
Statistics->transport.lbtipc.bytes_sent);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
Statistics->transport.lbtsmx.msgs_sent,
fmt->mSeparator,
Statistics->transport.lbtsmx.bytes_sent);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx%c%lx",
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
snprintf(work,
sizeof(work),
"%c%lx%c%lx",
fmt->mSeparator,
Statistics->transport.broker.msgs_sent,
fmt->mSeparator,
Statistics->transport.broker.bytes_sent);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
break;
}
*Size = strlen(Destination);
return (0);
}
/*
Format of the CSV event queue statistics data is:
data_msgs
data_msgs_tot
data_msgs_svc_min
data_msgs_svc_mean
data_msgs_svc_max
resp_msgs
resp_msgs_tot
resp_msgs_svc_min
resp_msgs_svc_mean
resp_msgs_svc_max
topicless_im_msgs
topicless_im_msgs_tot
topicless_im_msgs_svc_min
topicless_im_msgs_svc_mean
topicless_im_msgs_svc_max
wrcv_msgs
wrcv_msgs_tot
wrcv_msgs_svc_min
wrcv_msgs_svc_mean
wrcv_msgs_svc_max
io_events
io_events_tot
io_events_svc_min
io_events_svc_mean
io_events_svc_max
timer_events
timer_events_tot
timer_events_svc_min
timer_events_svc_mean
timer_events_svc_max
source_events
source_events_tot
source_events_svc_min
source_events_svc_mean
source_events_svc_max
unblock_events
unblock_events_tot
cancel_events
cancel_events_tot
cancel_events_svc_min
cancel_events_svc_mean
cancel_events_svc_max
context_source_events
context_source_events_tot
context_source_events_svc_min
context_source_events_svc_mean
context_source_events_svc_max
events
events_tot
age_min
age_mean
age_max
callback_events
callback_events_tot
callback_events_svc_min
callback_events_svc_mean
callback_events_svc_max
*/
int lbmmon_evq_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, const lbm_event_queue_stats_t * Statistics, void * FormatClientData)
{
lbmmon_format_csv_t * fmt;
char work[1024];
if ((Destination == NULL) || (Size == NULL) || (*Size == 0) || (Statistics == NULL) || (FormatClientData == NULL))
{
return (-1);
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
*ModuleID = MAKE_MODULE_VERSION(LBMMON_FORMAT_CSV_MODULE_ID,LBMMON_FORMAT_CSV_VERSION_CURRENT);
memset(work, 0, sizeof(work));
memset(Destination, 0, 2048);
snprintf(work,
sizeof(work),
"%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c",
Statistics->data_msgs,
fmt->mSeparator,
Statistics->data_msgs_tot,
fmt->mSeparator,
Statistics->data_msgs_svc_min,
fmt->mSeparator,
Statistics->data_msgs_svc_mean,
fmt->mSeparator,
Statistics->data_msgs_svc_max,
fmt->mSeparator,
Statistics->resp_msgs,
fmt->mSeparator,
Statistics->resp_msgs_tot,
fmt->mSeparator,
Statistics->resp_msgs_svc_min,
fmt->mSeparator,
Statistics->resp_msgs_svc_mean,
fmt->mSeparator,
Statistics->resp_msgs_svc_max,
fmt->mSeparator,
Statistics->topicless_im_msgs,
fmt->mSeparator,
Statistics->topicless_im_msgs_tot,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c",
Statistics->wrcv_msgs,
fmt->mSeparator,
Statistics->wrcv_msgs_tot,
fmt->mSeparator,
Statistics->wrcv_msgs_svc_min,
fmt->mSeparator,
Statistics->wrcv_msgs_svc_mean,
fmt->mSeparator,
Statistics->wrcv_msgs_svc_max,
fmt->mSeparator,
Statistics->io_events,
fmt->mSeparator,
Statistics->io_events_tot,
fmt->mSeparator,
Statistics->io_events_svc_min,
fmt->mSeparator,
Statistics->io_events_svc_mean,
fmt->mSeparator,
Statistics->io_events_svc_max,
fmt->mSeparator,
Statistics->timer_events,
fmt->mSeparator,
Statistics->timer_events_tot,
fmt->mSeparator,
Statistics->timer_events_svc_min,
fmt->mSeparator,
Statistics->timer_events_svc_mean,
fmt->mSeparator,
Statistics->timer_events_svc_max,
fmt->mSeparator);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c",
Statistics->source_events,
fmt->mSeparator,
Statistics->source_events_tot,
fmt->mSeparator,
Statistics->source_events_svc_min,
fmt->mSeparator,
fmt->mSeparator,
Statistics->source_events_svc_max,
fmt->mSeparator,
Statistics->unblock_events,
fmt->mSeparator,
Statistics->unblock_events_tot,
fmt->mSeparator,
Statistics->cancel_events,
fmt->mSeparator,
Statistics->cancel_events_tot,
fmt->mSeparator,
Statistics->cancel_events_svc_min,
fmt->mSeparator,
fmt->mSeparator,
Statistics->cancel_events_svc_max,
fmt->mSeparator);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
Statistics->context_source_events,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->events,
fmt->mSeparator,
Statistics->events_tot,
fmt->mSeparator,
Statistics->age_min,
fmt->mSeparator,
Statistics->age_mean,
fmt->mSeparator,
Statistics->age_max,
fmt->mSeparator,
Statistics->callback_events,
fmt->mSeparator,
Statistics->callback_events_tot,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
*Size = strlen(Destination);
return (0);
}
/*
Format of the CSV context statistics data is:
tr_dgrams_sent
tr_bytes_sent
tr_dgrams_rcved
tr_bytes_rcved
tr_dgrams_dropped_ver
tr_dgrams_dropped_type
tr_dgrams_dropped_malformed
tr_dgrams_send_failed
tr_src_topics
tr_rcv_topics
tr_rcv_unresolved_topics
lbtrm_unknown_msgs_rcved
lbtru_unknown_msgs_rcved
send_blocked
send_would_block
resp_blocked
resp_would_block
uim_dup_msgs_rcved
uim_msg_no_stream_rcved
fragments_lost
fragments_unrecoverably_lost
rcv_cb_svc_time_min
rcv_cb_svc_time_max
rcv_cb_svc_time_mean
*/
int lbmmon_ctx_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, const lbm_context_stats_t * Statistics, void * FormatClientData)
{
lbmmon_format_csv_t * fmt;
char work[1024];
if ((Destination == NULL) || (Size == NULL) || (*Size == 0) || (Statistics == NULL) || (FormatClientData == NULL))
{
return (-1);
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
*ModuleID = MAKE_MODULE_VERSION(LBMMON_FORMAT_CSV_MODULE_ID,LBMMON_FORMAT_CSV_VERSION_CURRENT);
memset(work, 0, sizeof(work));
memset(Destination, 0, 2048);
snprintf(work,
sizeof(work),
"%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c",
Statistics->tr_dgrams_sent,
fmt->mSeparator,
Statistics->tr_bytes_sent,
fmt->mSeparator,
Statistics->tr_dgrams_rcved,
fmt->mSeparator,
Statistics->tr_bytes_rcved,
fmt->mSeparator,
Statistics->tr_dgrams_dropped_ver,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->tr_dgrams_send_failed,
fmt->mSeparator,
Statistics->tr_src_topics,
fmt->mSeparator,
Statistics->tr_rcv_topics,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
fmt->mSeparator,
Statistics->send_blocked,
fmt->mSeparator,
Statistics->send_would_block,
fmt->mSeparator,
Statistics->resp_blocked,
fmt->mSeparator,
Statistics->resp_would_block,
fmt->mSeparator);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
snprintf(work,
sizeof(work),
"%lx%c%lx%c%lx%c%lx%c%lx%c%lx%c%lx",
Statistics->uim_dup_msgs_rcved,
fmt->mSeparator,
fmt->mSeparator,
Statistics->fragments_lost,
fmt->mSeparator,
fmt->mSeparator,
Statistics->rcv_cb_svc_time_min,
fmt->mSeparator,
Statistics->rcv_cb_svc_time_max,
fmt->mSeparator,
Statistics->rcv_cb_svc_time_mean);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
*Size = strlen(Destination);
return (0);
}
/*
Format of the CSV receiver topic statistics data is:
topic
source_count
For each source:
source_string
OTID
topic_idx
*/
int lbmmon_rcv_topic_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, const char * Topic, lbm_ulong_t SourceCount,
const lbm_rcv_topic_stats_t * Sources, void * FormatClientData)
{
lbmmon_format_csv_t * fmt;
char work[1024];
int idx;
if ((Destination == NULL) || (Size == NULL) || (*Size == 0) || (FormatClientData == NULL))
{
return (-1);
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
*ModuleID = MAKE_MODULE_VERSION(LBMMON_FORMAT_CSV_MODULE_ID,LBMMON_FORMAT_CSV_VERSION_CURRENT);
memset(work, 0, sizeof(work));
memset(Destination, 0, 2048);
snprintf(work, sizeof(work),
"\"%s\"%c%lx",
Topic,
fmt->mSeparator,
SourceCount);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
if (SourceCount > 0)
{
for (idx = 0; idx < SourceCount; ++idx)
{
size_t offset;
memset(work, 0, sizeof(work));
snprintf(work, sizeof(work),
"%c\"%s\"%c",
fmt->mSeparator,
Sources[idx].source,
fmt->mSeparator);
offset = strlen(work);
lbmmon_format_csv_convert_to_hex(work + offset, Sources[idx].otid, LBM_OTID_BLOCK_SZ);
offset = strlen(work);
snprintf(work + offset, sizeof(work) - offset,
"%c%x",
fmt->mSeparator,
Sources[idx].topic_idx);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
}
}
*Size = strlen(Destination);
return (0);
}
/*
Format of the CSV wildcard receiver statistics data is:
pattern
type
*/
int lbmmon_wildcard_rcv_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, const lbm_wildcard_rcv_stats_t * Statistics, void * FormatClientData)
{
lbmmon_format_csv_t * fmt;
char work[1024];
if ((Destination == NULL) || (Size == NULL) || (*Size == 0) || (Statistics == NULL) || (FormatClientData == NULL))
{
return (-1);
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
*ModuleID = MAKE_MODULE_VERSION(LBMMON_FORMAT_CSV_MODULE_ID,LBMMON_FORMAT_CSV_VERSION_CURRENT);
memset(work, 0, sizeof(work));
memset(Destination, 0, 2048);
snprintf(work, sizeof(work),
"\"%s\"%c%x",
Statistics->pattern,
fmt->mSeparator,
Statistics->type);
if (strlen(work) >= (*Size - strlen(Destination) - 1))
{
strncpy(ErrorString, "Destination too small for data", sizeof(ErrorString));
return (-1);
}
strncat(Destination, work, *Size - strlen(Destination) - 1);
*Size = strlen(Destination);
return (0);
}
int lbmmon_store_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, Lbmmon__UMPMonMsg * StoreMsg, int Action, void * FormatClientData)
{
strncpy(ErrorString, "CSV format not supported for stores at this time", sizeof(ErrorString));
return (-1);
}
int lbmmon_gateway_format_csv_serialize(char * Destination, size_t * Size, unsigned short * ModuleID,
const lbmmon_packet_attributes_t * Attributes, Lbmmon__DROMonMsg * GatewayMsg, void * FormatClientData)
{
strncpy(ErrorString, "CSV format not supported for gateways at this time", sizeof(ErrorString));
return (-1);
}
const char * next_csv_value(const char * String, char * Value, size_t Size, char Separator)
{
const char * ptr = String;
size_t pos;
if ((ptr == NULL) || (Value == NULL) || (Size == 0))
{
return (NULL);
}
memset(Value, 0, Size);
/* Skip any whitespace */
while ((*ptr != '\0') && (*ptr != Separator) && ((*ptr == ' ') || (*ptr == '\t')))
{
ptr++;
}
pos = 0;
if (*ptr == '\0')
{
return (NULL);
}
else if (*ptr == Separator)
{
ptr++;
return (ptr);
}
else if ((*ptr == '\"') || (*ptr == '\''))
{
char quote = *ptr;
ptr++;
while ((*ptr != '\0') && (*ptr != quote) && (pos < (Size - 1)))
{
Value[pos++] = *ptr++;
}
/* In case we exceeded the Value size, scan for the ending quote. */
while ((*ptr != '\0') && (*ptr != quote))
{
ptr++;
}
/* Finally, scan for the separator */
while ((*ptr != '\0') && (*ptr != Separator))
{
ptr++;
}
}
else
{
/* Copy into Value */
while ((*ptr != '\0') && (*ptr != Separator) && (pos < (Size - 1)))
{
Value[pos++] = *ptr++;
}
/* In case we exceeded the Value size, scan for the separator. */
while ((*ptr != '\0') && (*ptr != Separator))
{
ptr++;
}
}
/* If we're at the separator, advance the pointer */
if (*ptr == Separator)
{
ptr++;
}
return (ptr);
}
static lbm_ulong_t convert_value(const char * Buffer)
{
lbm_ulong_t value = 0;
const char * ptr = Buffer;
while (1)
{
errno = 0;
value = strtoul(ptr, NULL, 16);
if ((value == ULONG_MAX) && (errno == ERANGE))
{
ptr++;
}
else
{
return (value);
}
}
}
/*************************************************************************************************/
/* A note to maintainers: */
/* */
/* Ideally, the code to deserialize statistics would be completely generic. Instead of separate */
/* parsing loops for each of n message types, a single function could parse the string and put */
/* the values into the structure (given the appropriate pointers). Access to the statistics */
/* structure would also be generic, casting a pointer to the actual structure into a char *, */
/* then indexing using the field offset arrays (below) to locate the correct position for the */
/* field within the structure. */
/* */
/* That is, as long as the type of each field in every statistics structure is the same. */
/* Which it currently is... and probably will remain so. But there's no guarantee that it */
/* _will_ remain so. So better to bite the bullet now, and make the possibility of non- */
/* homogeneous structures simple to implement. */
/*************************************************************************************************/
static const size_t csv_rcv_tcp_stat_offset_v1[] =
{
offsetof(lbm_rcv_transport_stats_tcp_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_tcp_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_tcp_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_tcp_t, lbm_reqs_rcved)
};
#define csv_rcv_tcp_stat_offset_v2 csv_rcv_tcp_stat_offset_v1
#define csv_rcv_tcp_stat_offset_v3 csv_rcv_tcp_stat_offset_v2
#define csv_rcv_tcp_stat_offset_v4 csv_rcv_tcp_stat_offset_v3
#define csv_rcv_tcp_stat_offset_v5 csv_rcv_tcp_stat_offset_v4
static const lbmmon_csv_layout_t csv_rcv_tcp_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ csv_rcv_tcp_stat_offset_v1, sizeof(csv_rcv_tcp_stat_offset_v1)/sizeof(csv_rcv_tcp_stat_offset_v1[0]) },
{ csv_rcv_tcp_stat_offset_v2, sizeof(csv_rcv_tcp_stat_offset_v2)/sizeof(csv_rcv_tcp_stat_offset_v2[0]) },
{ csv_rcv_tcp_stat_offset_v3, sizeof(csv_rcv_tcp_stat_offset_v3)/sizeof(csv_rcv_tcp_stat_offset_v3[0]) },
{ csv_rcv_tcp_stat_offset_v4, sizeof(csv_rcv_tcp_stat_offset_v4)/sizeof(csv_rcv_tcp_stat_offset_v4[0]) },
{ csv_rcv_tcp_stat_offset_v5, sizeof(csv_rcv_tcp_stat_offset_v5)/sizeof(csv_rcv_tcp_stat_offset_v5[0]) }
};
static const size_t csv_rcv_lbtrm_stat_offset_v1[] =
{
offsetof(lbm_rcv_transport_stats_lbtrm_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_pckts_sent),
offsetof(lbm_rcv_transport_stats_lbtrm_t, naks_sent),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_ignored),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_shed),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_rx_delay),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_unknown),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_stm_min),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_stm_mean),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_stm_max),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_tx_min),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_tx_mean),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_tx_max),
offsetof(lbm_rcv_transport_stats_lbtrm_t, duplicate_data),
offsetof(lbm_rcv_transport_stats_lbtrm_t, unrecovered_txw),
offsetof(lbm_rcv_transport_stats_lbtrm_t, unrecovered_tmo),
offsetof(lbm_rcv_transport_stats_lbtrm_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, lbm_reqs_rcved)
};
#define csv_rcv_lbtrm_stat_offset_v2 csv_rcv_lbtrm_stat_offset_v1
static const size_t csv_rcv_lbtrm_stat_offset_v3[] =
{
offsetof(lbm_rcv_transport_stats_lbtrm_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_pckts_sent),
offsetof(lbm_rcv_transport_stats_lbtrm_t, naks_sent),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_ignored),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_shed),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_rx_delay),
offsetof(lbm_rcv_transport_stats_lbtrm_t, ncfs_unknown),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_stm_min),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_stm_mean),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_stm_max),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_tx_min),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_tx_mean),
offsetof(lbm_rcv_transport_stats_lbtrm_t, nak_tx_max),
offsetof(lbm_rcv_transport_stats_lbtrm_t, duplicate_data),
offsetof(lbm_rcv_transport_stats_lbtrm_t, unrecovered_txw),
offsetof(lbm_rcv_transport_stats_lbtrm_t, unrecovered_tmo),
offsetof(lbm_rcv_transport_stats_lbtrm_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, lbm_reqs_rcved),
offsetof(lbm_rcv_transport_stats_lbtrm_t, dgrams_dropped_size),
offsetof(lbm_rcv_transport_stats_lbtrm_t, dgrams_dropped_type),
offsetof(lbm_rcv_transport_stats_lbtrm_t, dgrams_dropped_version),
offsetof(lbm_rcv_transport_stats_lbtrm_t, dgrams_dropped_hdr),
offsetof(lbm_rcv_transport_stats_lbtrm_t, dgrams_dropped_other),
offsetof(lbm_rcv_transport_stats_lbtrm_t, out_of_order)
};
#define csv_rcv_lbtrm_stat_offset_v4 csv_rcv_lbtrm_stat_offset_v3
#define csv_rcv_lbtrm_stat_offset_v5 csv_rcv_lbtrm_stat_offset_v4
static const lbmmon_csv_layout_t csv_rcv_lbtrm_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ csv_rcv_lbtrm_stat_offset_v1, sizeof(csv_rcv_lbtrm_stat_offset_v1)/sizeof(csv_rcv_lbtrm_stat_offset_v1[0]) },
{ csv_rcv_lbtrm_stat_offset_v2, sizeof(csv_rcv_lbtrm_stat_offset_v2)/sizeof(csv_rcv_lbtrm_stat_offset_v2[0]) },
{ csv_rcv_lbtrm_stat_offset_v3, sizeof(csv_rcv_lbtrm_stat_offset_v3)/sizeof(csv_rcv_lbtrm_stat_offset_v3[0]) },
{ csv_rcv_lbtrm_stat_offset_v4, sizeof(csv_rcv_lbtrm_stat_offset_v4)/sizeof(csv_rcv_lbtrm_stat_offset_v4[0]) },
{ csv_rcv_lbtrm_stat_offset_v5, sizeof(csv_rcv_lbtrm_stat_offset_v5)/sizeof(csv_rcv_lbtrm_stat_offset_v5[0]) }
};
static const size_t csv_rcv_lbtru_stat_offset_v1[] =
{
offsetof(lbm_rcv_transport_stats_lbtru_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_pckts_sent),
offsetof(lbm_rcv_transport_stats_lbtru_t, naks_sent),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_ignored),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_shed),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_rx_delay),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_unknown),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_stm_min),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_stm_mean),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_stm_max),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_tx_min),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_tx_mean),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_tx_max),
offsetof(lbm_rcv_transport_stats_lbtru_t, duplicate_data),
offsetof(lbm_rcv_transport_stats_lbtru_t, unrecovered_txw),
offsetof(lbm_rcv_transport_stats_lbtru_t, unrecovered_tmo),
offsetof(lbm_rcv_transport_stats_lbtru_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, lbm_reqs_rcved)
};
#define csv_rcv_lbtru_stat_offset_v2 csv_rcv_lbtru_stat_offset_v1
static const size_t csv_rcv_lbtru_stat_offset_v3[] =
{
offsetof(lbm_rcv_transport_stats_lbtru_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_pckts_sent),
offsetof(lbm_rcv_transport_stats_lbtru_t, naks_sent),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_ignored),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_shed),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_rx_delay),
offsetof(lbm_rcv_transport_stats_lbtru_t, ncfs_unknown),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_stm_min),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_stm_mean),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_stm_max),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_tx_min),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_tx_mean),
offsetof(lbm_rcv_transport_stats_lbtru_t, nak_tx_max),
offsetof(lbm_rcv_transport_stats_lbtru_t, duplicate_data),
offsetof(lbm_rcv_transport_stats_lbtru_t, unrecovered_txw),
offsetof(lbm_rcv_transport_stats_lbtru_t, unrecovered_tmo),
offsetof(lbm_rcv_transport_stats_lbtru_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, lbm_reqs_rcved),
offsetof(lbm_rcv_transport_stats_lbtru_t, dgrams_dropped_size),
offsetof(lbm_rcv_transport_stats_lbtru_t, dgrams_dropped_type),
offsetof(lbm_rcv_transport_stats_lbtru_t, dgrams_dropped_version),
offsetof(lbm_rcv_transport_stats_lbtru_t, dgrams_dropped_hdr),
offsetof(lbm_rcv_transport_stats_lbtru_t, dgrams_dropped_sid),
offsetof(lbm_rcv_transport_stats_lbtru_t, dgrams_dropped_other)
};
#define csv_rcv_lbtru_stat_offset_v4 csv_rcv_lbtru_stat_offset_v3
#define csv_rcv_lbtru_stat_offset_v5 csv_rcv_lbtru_stat_offset_v4
static const lbmmon_csv_layout_t csv_rcv_lbtru_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ csv_rcv_lbtru_stat_offset_v1, sizeof(csv_rcv_lbtru_stat_offset_v1)/sizeof(csv_rcv_lbtru_stat_offset_v1[0]) },
{ csv_rcv_lbtru_stat_offset_v2, sizeof(csv_rcv_lbtru_stat_offset_v2)/sizeof(csv_rcv_lbtru_stat_offset_v2[0]) },
{ csv_rcv_lbtru_stat_offset_v3, sizeof(csv_rcv_lbtru_stat_offset_v3)/sizeof(csv_rcv_lbtru_stat_offset_v3[0]) },
{ csv_rcv_lbtru_stat_offset_v4, sizeof(csv_rcv_lbtru_stat_offset_v4)/sizeof(csv_rcv_lbtru_stat_offset_v4[0]) },
{ csv_rcv_lbtru_stat_offset_v5, sizeof(csv_rcv_lbtru_stat_offset_v5)/sizeof(csv_rcv_lbtru_stat_offset_v5[0]) }
};
static const size_t csv_rcv_lbtipc_stat_offset_v2[] =
{
offsetof(lbm_rcv_transport_stats_lbtipc_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtipc_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_lbtipc_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtipc_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_lbtipc_t, lbm_reqs_rcved)
};
#define csv_rcv_lbtipc_stat_offset_v3 csv_rcv_lbtipc_stat_offset_v2
#define csv_rcv_lbtipc_stat_offset_v4 csv_rcv_lbtipc_stat_offset_v3
#define csv_rcv_lbtipc_stat_offset_v5 csv_rcv_lbtipc_stat_offset_v4
static const lbmmon_csv_layout_t csv_rcv_lbtipc_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_rcv_lbtipc_stat_offset_v2, sizeof(csv_rcv_lbtipc_stat_offset_v2)/sizeof(csv_rcv_lbtipc_stat_offset_v2[0]) },
{ csv_rcv_lbtipc_stat_offset_v3, sizeof(csv_rcv_lbtipc_stat_offset_v3)/sizeof(csv_rcv_lbtipc_stat_offset_v3[0]) },
{ csv_rcv_lbtipc_stat_offset_v4, sizeof(csv_rcv_lbtipc_stat_offset_v4)/sizeof(csv_rcv_lbtipc_stat_offset_v4[0]) },
{ csv_rcv_lbtipc_stat_offset_v5, sizeof(csv_rcv_lbtipc_stat_offset_v5)/sizeof(csv_rcv_lbtipc_stat_offset_v5[0]) }
};
static const size_t csv_rcv_lbtsmx_stat_offset_v2[] =
{
offsetof(lbm_rcv_transport_stats_lbtsmx_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtsmx_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_lbtsmx_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtsmx_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_lbtsmx_t, reserved1)
};
#define csv_rcv_lbtsmx_stat_offset_v3 csv_rcv_lbtsmx_stat_offset_v2
#define csv_rcv_lbtsmx_stat_offset_v4 csv_rcv_lbtsmx_stat_offset_v3
#define csv_rcv_lbtsmx_stat_offset_v5 csv_rcv_lbtsmx_stat_offset_v4
static const lbmmon_csv_layout_t csv_rcv_lbtsmx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_rcv_lbtsmx_stat_offset_v2, sizeof(csv_rcv_lbtsmx_stat_offset_v2)/sizeof(csv_rcv_lbtsmx_stat_offset_v2[0]) },
{ csv_rcv_lbtsmx_stat_offset_v3, sizeof(csv_rcv_lbtsmx_stat_offset_v3)/sizeof(csv_rcv_lbtsmx_stat_offset_v3[0]) },
{ csv_rcv_lbtsmx_stat_offset_v4, sizeof(csv_rcv_lbtsmx_stat_offset_v4)/sizeof(csv_rcv_lbtsmx_stat_offset_v4[0]) },
{ csv_rcv_lbtsmx_stat_offset_v5, sizeof(csv_rcv_lbtsmx_stat_offset_v5)/sizeof(csv_rcv_lbtsmx_stat_offset_v5[0]) }
};
static const size_t csv_rcv_lbtrdma_stat_offset_v2[] =
{
offsetof(lbm_rcv_transport_stats_lbtrdma_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtrdma_t, bytes_rcved),
offsetof(lbm_rcv_transport_stats_lbtrdma_t, lbm_msgs_rcved),
offsetof(lbm_rcv_transport_stats_lbtrdma_t, lbm_msgs_no_topic_rcved),
offsetof(lbm_rcv_transport_stats_lbtrdma_t, lbm_reqs_rcved)
};
#define csv_rcv_lbtrdma_stat_offset_v3 csv_rcv_lbtrdma_stat_offset_v2
#define csv_rcv_lbtrdma_stat_offset_v4 csv_rcv_lbtrdma_stat_offset_v3
#define csv_rcv_lbtrdma_stat_offset_v5 csv_rcv_lbtrdma_stat_offset_v4
static const lbmmon_csv_layout_t csv_rcv_lbtrdma_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_rcv_lbtrdma_stat_offset_v2, sizeof(csv_rcv_lbtrdma_stat_offset_v2)/sizeof(csv_rcv_lbtrdma_stat_offset_v2[0]) },
{ csv_rcv_lbtrdma_stat_offset_v3, sizeof(csv_rcv_lbtrdma_stat_offset_v3)/sizeof(csv_rcv_lbtrdma_stat_offset_v3[0]) },
{ csv_rcv_lbtrdma_stat_offset_v4, sizeof(csv_rcv_lbtrdma_stat_offset_v4)/sizeof(csv_rcv_lbtrdma_stat_offset_v4[0]) },
{ csv_rcv_lbtrdma_stat_offset_v5, sizeof(csv_rcv_lbtrdma_stat_offset_v5)/sizeof(csv_rcv_lbtrdma_stat_offset_v5[0]) }
};
static const size_t csv_rcv_broker_stat_offset_v2[] =
{
offsetof(lbm_rcv_transport_stats_broker_t, msgs_rcved),
offsetof(lbm_rcv_transport_stats_broker_t, bytes_rcved)
};
#define csv_rcv_broker_stat_offset_v3 csv_rcv_broker_stat_offset_v2
#define csv_rcv_broker_stat_offset_v4 csv_rcv_broker_stat_offset_v3
#define csv_rcv_broker_stat_offset_v5 csv_rcv_broker_stat_offset_v4
static const lbmmon_csv_layout_t csv_rcv_broker_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_rcv_broker_stat_offset_v2, sizeof(csv_rcv_broker_stat_offset_v2)/sizeof(csv_rcv_broker_stat_offset_v2[0]) },
{ csv_rcv_broker_stat_offset_v3, sizeof(csv_rcv_broker_stat_offset_v3)/sizeof(csv_rcv_broker_stat_offset_v3[0]) },
{ csv_rcv_broker_stat_offset_v4, sizeof(csv_rcv_broker_stat_offset_v4)/sizeof(csv_rcv_broker_stat_offset_v4[0]) },
{ csv_rcv_broker_stat_offset_v5, sizeof(csv_rcv_broker_stat_offset_v5)/sizeof(csv_rcv_broker_stat_offset_v5[0]) }
};
int lbmmon_rcv_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, lbm_rcv_transport_stats_t * Statistics,
const char * Source, size_t Length, unsigned short ModuleID, void * FormatClientData)
{
const char * ptr;
char value[1024];
lbmmon_format_csv_t * fmt;
size_t idx;
unsigned char modid;
unsigned char modver;
const size_t * stat_layout = NULL;
size_t stat_count = 0;
if ((Statistics == NULL) || (Source == NULL) || (*Source == '\0') || (Length == 0) || (FormatClientData == NULL) )
{
strncpy(ErrorString, "Invalid parameter", sizeof(ErrorString));
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_ON)
{
}
modid = MODULE_ID(ModuleID);
modver = MODULE_VERSION(ModuleID);
{
snprintf(ErrorString, sizeof(ErrorString), "Invalid module ID %u", (unsigned)modid);
}
if (fmt->mBuffer == NULL)
{
fmt->mBufferSize = 1024;
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
if (Length >= fmt->mBufferSize)
{
fmt->mBufferSize = 2 * Length;
free(fmt->mBuffer);
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
memset(fmt->mBuffer, 0, fmt->mBufferSize);
memcpy(fmt->mBuffer, Source, Length);
ptr = fmt->mBuffer;
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "No type field found", sizeof(ErrorString));
}
Statistics->type = atoi(value);
ptr = next_csv_value(ptr, Statistics->source, sizeof(Statistics->source), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "No source field found", sizeof(ErrorString));
}
MUL_DEBUG(LBM_DEBUG_LBMMON, ("lbmmon_rcv_format_csv_deserialize (%s) (%d) (%d)\n", Statistics->source, Statistics->type, Length));
switch (Statistics->type)
{
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_rcv_tcp_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_rcv_tcp_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_rcv_tcp_stat_layout[modver].layout;
stat_count = csv_rcv_tcp_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.tcp), 0, sizeof(lbm_rcv_transport_stats_tcp_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.tcp)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_rcv_lbtrm_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_rcv_lbtrm_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_rcv_lbtrm_stat_layout[modver].layout;
stat_count = csv_rcv_lbtrm_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtrm), 0, sizeof(lbm_rcv_transport_stats_lbtrm_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
/* Due to an ambiguous case with version 3 lbtrm rcv stats,
* older releases of lbm may have 26 fields and newer releases may have 27 fields.
* See bug 5002 for more information.
* For version 3, we will not consider it an error if there are only 26 fields.
*/
if(modver == MODULE_VERSION(3) && idx == 26) {
return 0;
}
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtrm)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_rcv_lbtru_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_rcv_lbtru_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_rcv_lbtru_stat_layout[modver].layout;
stat_count = csv_rcv_lbtru_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtru), 0, sizeof(lbm_rcv_transport_stats_lbtru_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtru)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_rcv_lbtipc_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_rcv_lbtipc_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_rcv_lbtipc_stat_layout[modver].layout;
stat_count = csv_rcv_lbtipc_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtipc), 0, sizeof(lbm_rcv_transport_stats_lbtipc_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtipc)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_rcv_lbtsmx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_rcv_lbtsmx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_rcv_lbtsmx_stat_layout[modver].layout;
stat_count = csv_rcv_lbtsmx_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtsmx), 0, sizeof(lbm_rcv_transport_stats_lbtsmx_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtsmx)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_rcv_lbtrdma_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_rcv_lbtrdma_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_rcv_lbtrdma_stat_layout[modver].layout;
stat_count = csv_rcv_lbtrdma_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtrdma), 0, sizeof(lbm_rcv_transport_stats_lbtrdma_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtrdma)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_rcv_broker_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_rcv_broker_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_rcv_broker_stat_layout[modver].layout;
stat_count = csv_rcv_broker_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.broker), 0, sizeof(lbm_rcv_transport_stats_broker_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.broker)) + stat_layout[idx])) = convert_value(value);
}
break;
default:
strncpy(ErrorString, "Invalid LBM transport type", sizeof(ErrorString));
}
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_CONVERT)
{
}
}
static size_t csv_src_tcp_stat_offset_v1[] =
{
offsetof(lbm_src_transport_stats_tcp_t, num_clients),
offsetof(lbm_src_transport_stats_tcp_t, bytes_buffered)
};
#define csv_src_tcp_stat_offset_v2 csv_src_tcp_stat_offset_v1
#define csv_src_tcp_stat_offset_v3 csv_src_tcp_stat_offset_v2
#define csv_src_tcp_stat_offset_v4 csv_src_tcp_stat_offset_v3
#define csv_src_tcp_stat_offset_v5 csv_src_tcp_stat_offset_v4
static const lbmmon_csv_layout_t csv_src_tcp_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ csv_src_tcp_stat_offset_v1, sizeof(csv_src_tcp_stat_offset_v1)/sizeof(csv_src_tcp_stat_offset_v1[0]) },
{ csv_src_tcp_stat_offset_v2, sizeof(csv_src_tcp_stat_offset_v2)/sizeof(csv_src_tcp_stat_offset_v2[0]) },
{ csv_src_tcp_stat_offset_v3, sizeof(csv_src_tcp_stat_offset_v3)/sizeof(csv_src_tcp_stat_offset_v3[0]) },
{ csv_src_tcp_stat_offset_v4, sizeof(csv_src_tcp_stat_offset_v4)/sizeof(csv_src_tcp_stat_offset_v4[0]) },
{ csv_src_tcp_stat_offset_v5, sizeof(csv_src_tcp_stat_offset_v5)/sizeof(csv_src_tcp_stat_offset_v5[0]) }
};
static size_t csv_src_lbtrm_stat_offset_v1[] =
{
offsetof(lbm_src_transport_stats_lbtrm_t, msgs_sent),
offsetof(lbm_src_transport_stats_lbtrm_t, bytes_sent),
offsetof(lbm_src_transport_stats_lbtrm_t, txw_msgs),
offsetof(lbm_src_transport_stats_lbtrm_t, txw_bytes),
offsetof(lbm_src_transport_stats_lbtrm_t, nak_pckts_rcved),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_rcved),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_ignored),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_shed),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_rx_delay_ignored),
offsetof(lbm_src_transport_stats_lbtrm_t, rxs_sent),
offsetof(lbm_src_transport_stats_lbtrm_t, rctlr_data_msgs),
offsetof(lbm_src_transport_stats_lbtrm_t, rctlr_rx_msgs)
};
static size_t csv_src_lbtrm_stat_offset_v2[] =
{
offsetof(lbm_src_transport_stats_lbtrm_t, msgs_sent),
offsetof(lbm_src_transport_stats_lbtrm_t, bytes_sent),
offsetof(lbm_src_transport_stats_lbtrm_t, txw_msgs),
offsetof(lbm_src_transport_stats_lbtrm_t, txw_bytes),
offsetof(lbm_src_transport_stats_lbtrm_t, nak_pckts_rcved),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_rcved),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_ignored),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_shed),
offsetof(lbm_src_transport_stats_lbtrm_t, naks_rx_delay_ignored),
offsetof(lbm_src_transport_stats_lbtrm_t, rxs_sent),
offsetof(lbm_src_transport_stats_lbtrm_t, rctlr_data_msgs),
offsetof(lbm_src_transport_stats_lbtrm_t, rctlr_rx_msgs),
offsetof(lbm_src_transport_stats_lbtrm_t, rx_bytes_sent)
};
#define csv_src_lbtrm_stat_offset_v3 csv_src_lbtrm_stat_offset_v2
#define csv_src_lbtrm_stat_offset_v4 csv_src_lbtrm_stat_offset_v3
#define csv_src_lbtrm_stat_offset_v5 csv_src_lbtrm_stat_offset_v4
static const lbmmon_csv_layout_t csv_src_lbtrm_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ csv_src_lbtrm_stat_offset_v1, sizeof(csv_src_lbtrm_stat_offset_v1)/sizeof(csv_src_lbtrm_stat_offset_v1[0]) },
{ csv_src_lbtrm_stat_offset_v2, sizeof(csv_src_lbtrm_stat_offset_v2)/sizeof(csv_src_lbtrm_stat_offset_v2[0]) },
{ csv_src_lbtrm_stat_offset_v3, sizeof(csv_src_lbtrm_stat_offset_v3)/sizeof(csv_src_lbtrm_stat_offset_v3[0]) },
{ csv_src_lbtrm_stat_offset_v4, sizeof(csv_src_lbtrm_stat_offset_v4)/sizeof(csv_src_lbtrm_stat_offset_v4[0]) },
{ csv_src_lbtrm_stat_offset_v5, sizeof(csv_src_lbtrm_stat_offset_v5)/sizeof(csv_src_lbtrm_stat_offset_v5[0]) }
};
static size_t csv_src_lbtru_stat_offset_v1[] =
{
offsetof(lbm_src_transport_stats_lbtru_t, msgs_sent),
offsetof(lbm_src_transport_stats_lbtru_t, bytes_sent),
offsetof(lbm_src_transport_stats_lbtru_t, nak_pckts_rcved),
offsetof(lbm_src_transport_stats_lbtru_t, naks_rcved),
offsetof(lbm_src_transport_stats_lbtru_t, naks_ignored),
offsetof(lbm_src_transport_stats_lbtru_t, naks_shed),
offsetof(lbm_src_transport_stats_lbtru_t, naks_rx_delay_ignored),
offsetof(lbm_src_transport_stats_lbtru_t, rxs_sent),
offsetof(lbm_src_transport_stats_lbtru_t, num_clients)
};
static size_t csv_src_lbtru_stat_offset_v2[] =
{
offsetof(lbm_src_transport_stats_lbtru_t, msgs_sent),
offsetof(lbm_src_transport_stats_lbtru_t, bytes_sent),
offsetof(lbm_src_transport_stats_lbtru_t, nak_pckts_rcved),
offsetof(lbm_src_transport_stats_lbtru_t, naks_rcved),
offsetof(lbm_src_transport_stats_lbtru_t, naks_ignored),
offsetof(lbm_src_transport_stats_lbtru_t, naks_shed),
offsetof(lbm_src_transport_stats_lbtru_t, naks_rx_delay_ignored),
offsetof(lbm_src_transport_stats_lbtru_t, rxs_sent),
offsetof(lbm_src_transport_stats_lbtru_t, num_clients),
offsetof(lbm_src_transport_stats_lbtru_t, rx_bytes_sent)
};
#define csv_src_lbtru_stat_offset_v3 csv_src_lbtru_stat_offset_v2
#define csv_src_lbtru_stat_offset_v4 csv_src_lbtru_stat_offset_v3
#define csv_src_lbtru_stat_offset_v5 csv_src_lbtru_stat_offset_v4
static const lbmmon_csv_layout_t csv_src_lbtru_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ csv_src_lbtru_stat_offset_v1, sizeof(csv_src_lbtru_stat_offset_v1)/sizeof(csv_src_lbtru_stat_offset_v1[0]) },
{ csv_src_lbtru_stat_offset_v2, sizeof(csv_src_lbtru_stat_offset_v2)/sizeof(csv_src_lbtru_stat_offset_v2[0]) },
{ csv_src_lbtru_stat_offset_v3, sizeof(csv_src_lbtru_stat_offset_v3)/sizeof(csv_src_lbtru_stat_offset_v3[0]) },
{ csv_src_lbtru_stat_offset_v4, sizeof(csv_src_lbtru_stat_offset_v4)/sizeof(csv_src_lbtru_stat_offset_v4[0]) },
{ csv_src_lbtru_stat_offset_v5, sizeof(csv_src_lbtru_stat_offset_v5)/sizeof(csv_src_lbtru_stat_offset_v5[0]) }
};
static size_t csv_src_lbtipc_stat_offset_v2[] =
{
offsetof(lbm_src_transport_stats_lbtipc_t, num_clients),
offsetof(lbm_src_transport_stats_lbtipc_t, msgs_sent),
offsetof(lbm_src_transport_stats_lbtipc_t, bytes_sent)
};
#define csv_src_lbtipc_stat_offset_v3 csv_src_lbtipc_stat_offset_v2
#define csv_src_lbtipc_stat_offset_v4 csv_src_lbtipc_stat_offset_v3
#define csv_src_lbtipc_stat_offset_v5 csv_src_lbtipc_stat_offset_v4
static const lbmmon_csv_layout_t csv_src_lbtipc_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_src_lbtipc_stat_offset_v2, sizeof(csv_src_lbtipc_stat_offset_v2)/sizeof(csv_src_lbtipc_stat_offset_v2[0]) },
{ csv_src_lbtipc_stat_offset_v3, sizeof(csv_src_lbtipc_stat_offset_v3)/sizeof(csv_src_lbtipc_stat_offset_v3[0]) },
{ csv_src_lbtipc_stat_offset_v4, sizeof(csv_src_lbtipc_stat_offset_v4)/sizeof(csv_src_lbtipc_stat_offset_v4[0]) },
{ csv_src_lbtipc_stat_offset_v5, sizeof(csv_src_lbtipc_stat_offset_v5)/sizeof(csv_src_lbtipc_stat_offset_v5[0]) }
};
static size_t csv_src_lbtsmx_stat_offset_v2[] =
{
offsetof(lbm_src_transport_stats_lbtsmx_t, num_clients),
offsetof(lbm_src_transport_stats_lbtsmx_t, msgs_sent),
offsetof(lbm_src_transport_stats_lbtsmx_t, bytes_sent)
};
#define csv_src_lbtsmx_stat_offset_v3 csv_src_lbtsmx_stat_offset_v2
#define csv_src_lbtsmx_stat_offset_v4 csv_src_lbtsmx_stat_offset_v3
#define csv_src_lbtsmx_stat_offset_v5 csv_src_lbtsmx_stat_offset_v4
static const lbmmon_csv_layout_t csv_src_lbtsmx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_src_lbtsmx_stat_offset_v2, sizeof(csv_src_lbtsmx_stat_offset_v2)/sizeof(csv_src_lbtsmx_stat_offset_v2[0]) },
{ csv_src_lbtsmx_stat_offset_v3, sizeof(csv_src_lbtsmx_stat_offset_v3)/sizeof(csv_src_lbtsmx_stat_offset_v3[0]) },
{ csv_src_lbtsmx_stat_offset_v4, sizeof(csv_src_lbtsmx_stat_offset_v4)/sizeof(csv_src_lbtsmx_stat_offset_v4[0]) },
{ csv_src_lbtsmx_stat_offset_v5, sizeof(csv_src_lbtsmx_stat_offset_v5)/sizeof(csv_src_lbtsmx_stat_offset_v5[0]) }
};
static size_t csv_src_lbtrdma_stat_offset_v2[] =
{
offsetof(lbm_src_transport_stats_lbtrdma_t, num_clients),
offsetof(lbm_src_transport_stats_lbtrdma_t, msgs_sent),
offsetof(lbm_src_transport_stats_lbtrdma_t, bytes_sent)
};
#define csv_src_lbtrdma_stat_offset_v3 csv_src_lbtrdma_stat_offset_v2
#define csv_src_lbtrdma_stat_offset_v4 csv_src_lbtrdma_stat_offset_v3
#define csv_src_lbtrdma_stat_offset_v5 csv_src_lbtrdma_stat_offset_v4
static const lbmmon_csv_layout_t csv_src_lbtrdma_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_src_lbtrdma_stat_offset_v2, sizeof(csv_src_lbtrdma_stat_offset_v2)/sizeof(csv_src_lbtrdma_stat_offset_v2[0]) },
{ csv_src_lbtrdma_stat_offset_v3, sizeof(csv_src_lbtrdma_stat_offset_v3)/sizeof(csv_src_lbtrdma_stat_offset_v3[0]) },
{ csv_src_lbtrdma_stat_offset_v4, sizeof(csv_src_lbtrdma_stat_offset_v4)/sizeof(csv_src_lbtrdma_stat_offset_v4[0]) },
{ csv_src_lbtrdma_stat_offset_v5, sizeof(csv_src_lbtrdma_stat_offset_v5)/sizeof(csv_src_lbtrdma_stat_offset_v5[0]) }
};
static size_t csv_src_broker_stat_offset_v2[] =
{
offsetof(lbm_src_transport_stats_broker_t, msgs_sent),
offsetof(lbm_src_transport_stats_broker_t, bytes_sent)
};
#define csv_src_broker_stat_offset_v3 csv_src_broker_stat_offset_v2
#define csv_src_broker_stat_offset_v4 csv_src_broker_stat_offset_v3
#define csv_src_broker_stat_offset_v5 csv_src_broker_stat_offset_v4
static const lbmmon_csv_layout_t csv_src_broker_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_src_broker_stat_offset_v2, sizeof(csv_src_broker_stat_offset_v2)/sizeof(csv_src_broker_stat_offset_v2[0]) },
{ csv_src_broker_stat_offset_v3, sizeof(csv_src_broker_stat_offset_v3)/sizeof(csv_src_broker_stat_offset_v3[0]) },
{ csv_src_broker_stat_offset_v4, sizeof(csv_src_broker_stat_offset_v4)/sizeof(csv_src_broker_stat_offset_v4[0]) },
{ csv_src_broker_stat_offset_v5, sizeof(csv_src_broker_stat_offset_v5)/sizeof(csv_src_broker_stat_offset_v5[0]) }
};
int lbmmon_src_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, lbm_src_transport_stats_t * Statistics,
const char * Source, size_t Length, unsigned short ModuleID, void * FormatClientData)
{
const char * ptr;
char value[1024];
lbmmon_format_csv_t * fmt;
size_t idx;
unsigned char modid;
unsigned char modver;
const size_t * stat_layout = NULL;
size_t stat_count = 0;
if ((Statistics == NULL) || (Source == NULL) || (*Source == '\0') || (Length == 0) || (FormatClientData == NULL) )
{
strncpy(ErrorString, "Invalid parameter", sizeof(ErrorString));
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_ON)
{
}
modid = MODULE_ID(ModuleID);
modver = MODULE_VERSION(ModuleID);
{
snprintf(ErrorString, sizeof(ErrorString), "Invalid module ID %u", (unsigned)modid);
}
if (fmt->mBuffer == NULL)
{
fmt->mBufferSize = 1024;
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
if (Length >= fmt->mBufferSize)
{
fmt->mBufferSize = 2 * Length;
free(fmt->mBuffer);
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
memset(fmt->mBuffer, 0, fmt->mBufferSize);
memcpy(fmt->mBuffer, Source, Length);
ptr = fmt->mBuffer;
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "No type field found", sizeof(ErrorString));
}
Statistics->type = atoi(value);
ptr = next_csv_value(ptr, Statistics->source, sizeof(Statistics->source), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "No source field found", sizeof(ErrorString));
}
MUL_DEBUG(LBM_DEBUG_LBMMON, ("lbmmon_src_format_csv_deserialize (%s) (%d) (%d)\n", Statistics->source, Statistics->type, Length));
switch (Statistics->type)
{
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_src_tcp_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_src_tcp_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_src_tcp_stat_layout[modver].layout;
stat_count = csv_src_tcp_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.tcp), 0, sizeof(lbm_src_transport_stats_tcp_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.tcp)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_src_lbtrm_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_src_lbtrm_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_src_lbtrm_stat_layout[modver].layout;
stat_count = csv_src_lbtrm_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtrm), 0, sizeof(lbm_src_transport_stats_lbtrm_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtrm)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_src_lbtru_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_src_lbtru_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_src_lbtru_stat_layout[modver].layout;
stat_count = csv_src_lbtru_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtru), 0, sizeof(lbm_src_transport_stats_lbtru_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtru)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_src_lbtipc_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_src_lbtipc_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_src_lbtipc_stat_layout[modver].layout;
stat_count = csv_src_lbtipc_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtipc), 0, sizeof(lbm_src_transport_stats_lbtipc_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtipc)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_src_lbtsmx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_src_lbtsmx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_src_lbtsmx_stat_layout[modver].layout;
stat_count = csv_src_lbtsmx_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtsmx), 0, sizeof(lbm_src_transport_stats_lbtsmx_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtsmx)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_src_lbtrdma_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_src_lbtrdma_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_src_lbtrdma_stat_layout[modver].layout;
stat_count = csv_src_lbtrdma_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.lbtrdma), 0, sizeof(lbm_src_transport_stats_lbtrdma_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.lbtrdma)) + stat_layout[idx])) = convert_value(value);
}
break;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_src_broker_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_src_broker_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_src_broker_stat_layout[modver].layout;
stat_count = csv_src_broker_stat_layout[modver].count;
}
memset((void *) &(Statistics->transport.broker), 0, sizeof(lbm_src_transport_stats_broker_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *)&(Statistics->transport.broker)) + stat_layout[idx])) = convert_value(value);
}
break;
default:
strncpy(ErrorString, "Invalid LBM transport type", sizeof(ErrorString));
}
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_CONVERT)
{
}
}
static size_t csv_evq_stat_offset_v2[] =
{
offsetof(lbm_event_queue_stats_t, data_msgs),
offsetof(lbm_event_queue_stats_t, data_msgs_tot),
offsetof(lbm_event_queue_stats_t, data_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, data_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, data_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, resp_msgs),
offsetof(lbm_event_queue_stats_t, resp_msgs_tot),
offsetof(lbm_event_queue_stats_t, resp_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, resp_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, resp_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_tot),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, wrcv_msgs),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_tot),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, io_events),
offsetof(lbm_event_queue_stats_t, io_events_tot),
offsetof(lbm_event_queue_stats_t, io_events_svc_min),
offsetof(lbm_event_queue_stats_t, io_events_svc_mean),
offsetof(lbm_event_queue_stats_t, io_events_svc_max),
offsetof(lbm_event_queue_stats_t, timer_events),
offsetof(lbm_event_queue_stats_t, timer_events_tot),
offsetof(lbm_event_queue_stats_t, timer_events_svc_min),
offsetof(lbm_event_queue_stats_t, timer_events_svc_mean),
offsetof(lbm_event_queue_stats_t, timer_events_svc_max),
offsetof(lbm_event_queue_stats_t, source_events),
offsetof(lbm_event_queue_stats_t, source_events_tot),
offsetof(lbm_event_queue_stats_t, source_events_svc_min),
offsetof(lbm_event_queue_stats_t, source_events_svc_mean),
offsetof(lbm_event_queue_stats_t, source_events_svc_max),
offsetof(lbm_event_queue_stats_t, unblock_events),
offsetof(lbm_event_queue_stats_t, unblock_events_tot),
offsetof(lbm_event_queue_stats_t, cancel_events),
offsetof(lbm_event_queue_stats_t, cancel_events_tot),
offsetof(lbm_event_queue_stats_t, cancel_events_svc_min),
offsetof(lbm_event_queue_stats_t, cancel_events_svc_mean),
offsetof(lbm_event_queue_stats_t, cancel_events_svc_max),
offsetof(lbm_event_queue_stats_t, context_source_events),
offsetof(lbm_event_queue_stats_t, context_source_events_tot),
offsetof(lbm_event_queue_stats_t, context_source_events_svc_min),
offsetof(lbm_event_queue_stats_t, context_source_events_svc_mean),
offsetof(lbm_event_queue_stats_t, context_source_events_svc_max),
offsetof(lbm_event_queue_stats_t, events),
offsetof(lbm_event_queue_stats_t, events_tot),
offsetof(lbm_event_queue_stats_t, age_min),
offsetof(lbm_event_queue_stats_t, age_mean),
offsetof(lbm_event_queue_stats_t, age_max)
};
static size_t csv_evq_stat_offset_v3[] =
{
offsetof(lbm_event_queue_stats_t, data_msgs),
offsetof(lbm_event_queue_stats_t, data_msgs_tot),
offsetof(lbm_event_queue_stats_t, data_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, data_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, data_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, resp_msgs),
offsetof(lbm_event_queue_stats_t, resp_msgs_tot),
offsetof(lbm_event_queue_stats_t, resp_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, resp_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, resp_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_tot),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, topicless_im_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, wrcv_msgs),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_tot),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_svc_min),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_svc_mean),
offsetof(lbm_event_queue_stats_t, wrcv_msgs_svc_max),
offsetof(lbm_event_queue_stats_t, io_events),
offsetof(lbm_event_queue_stats_t, io_events_tot),
offsetof(lbm_event_queue_stats_t, io_events_svc_min),
offsetof(lbm_event_queue_stats_t, io_events_svc_mean),
offsetof(lbm_event_queue_stats_t, io_events_svc_max),
offsetof(lbm_event_queue_stats_t, timer_events),
offsetof(lbm_event_queue_stats_t, timer_events_tot),
offsetof(lbm_event_queue_stats_t, timer_events_svc_min),
offsetof(lbm_event_queue_stats_t, timer_events_svc_mean),
offsetof(lbm_event_queue_stats_t, timer_events_svc_max),
offsetof(lbm_event_queue_stats_t, source_events),
offsetof(lbm_event_queue_stats_t, source_events_tot),
offsetof(lbm_event_queue_stats_t, source_events_svc_min),
offsetof(lbm_event_queue_stats_t, source_events_svc_mean),
offsetof(lbm_event_queue_stats_t, source_events_svc_max),
offsetof(lbm_event_queue_stats_t, unblock_events),
offsetof(lbm_event_queue_stats_t, unblock_events_tot),
offsetof(lbm_event_queue_stats_t, cancel_events),
offsetof(lbm_event_queue_stats_t, cancel_events_tot),
offsetof(lbm_event_queue_stats_t, cancel_events_svc_min),
offsetof(lbm_event_queue_stats_t, cancel_events_svc_mean),
offsetof(lbm_event_queue_stats_t, cancel_events_svc_max),
offsetof(lbm_event_queue_stats_t, context_source_events),
offsetof(lbm_event_queue_stats_t, context_source_events_tot),
offsetof(lbm_event_queue_stats_t, context_source_events_svc_min),
offsetof(lbm_event_queue_stats_t, context_source_events_svc_mean),
offsetof(lbm_event_queue_stats_t, context_source_events_svc_max),
offsetof(lbm_event_queue_stats_t, events),
offsetof(lbm_event_queue_stats_t, events_tot),
offsetof(lbm_event_queue_stats_t, age_min),
offsetof(lbm_event_queue_stats_t, age_mean),
offsetof(lbm_event_queue_stats_t, age_max),
offsetof(lbm_event_queue_stats_t, callback_events),
offsetof(lbm_event_queue_stats_t, callback_events_tot),
offsetof(lbm_event_queue_stats_t, callback_events_svc_min),
offsetof(lbm_event_queue_stats_t, callback_events_svc_mean),
offsetof(lbm_event_queue_stats_t, callback_events_svc_max)
};
#define csv_evq_stat_offset_v4 csv_evq_stat_offset_v3
#define csv_evq_stat_offset_v5 csv_evq_stat_offset_v4
static const lbmmon_csv_layout_t csv_evq_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_evq_stat_offset_v2, sizeof(csv_evq_stat_offset_v2)/sizeof(csv_evq_stat_offset_v2[0]) },
{ csv_evq_stat_offset_v3, sizeof(csv_evq_stat_offset_v3)/sizeof(csv_evq_stat_offset_v3[0]) },
{ csv_evq_stat_offset_v4, sizeof(csv_evq_stat_offset_v4)/sizeof(csv_evq_stat_offset_v4[0]) },
{ csv_evq_stat_offset_v5, sizeof(csv_evq_stat_offset_v5)/sizeof(csv_evq_stat_offset_v5[0]) }
};
int lbmmon_evq_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, lbm_event_queue_stats_t * Statistics,
const char * Source, size_t Length, unsigned short ModuleID, void * FormatClientData)
{
const char * ptr;
char value[1024];
lbmmon_format_csv_t * fmt;
size_t idx;
unsigned char modid;
unsigned char modver;
const size_t * stat_layout = NULL;
size_t stat_count = 0;
if ((Statistics == NULL) || (Source == NULL) || (*Source == '\0') || (Length == 0) || (FormatClientData == NULL) )
{
strncpy(ErrorString, "Invalid parameter", sizeof(ErrorString));
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_ON)
{
}
modid = MODULE_ID(ModuleID);
modver = MODULE_VERSION(ModuleID);
{
snprintf(ErrorString, sizeof(ErrorString), "Invalid module ID %u", (unsigned)modid);
}
if (fmt->mBuffer == NULL)
{
fmt->mBufferSize = 1024;
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
if (Length >= fmt->mBufferSize)
{
fmt->mBufferSize = 2 * Length;
free(fmt->mBuffer);
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
memset(fmt->mBuffer, 0, fmt->mBufferSize);
memcpy(fmt->mBuffer, Source, Length);
ptr = fmt->mBuffer;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_evq_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_evq_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_evq_stat_layout[modver].layout;
stat_count = csv_evq_stat_layout[modver].count;
}
memset((void *) Statistics, 0, sizeof(lbm_event_queue_stats_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *) Statistics) + stat_layout[idx])) = convert_value(value);
}
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_CONVERT)
{
}
}
static size_t csv_ctx_stat_offset_v2[] =
{
offsetof(lbm_context_stats_t, tr_dgrams_sent),
offsetof(lbm_context_stats_t, tr_bytes_sent),
offsetof(lbm_context_stats_t, tr_dgrams_rcved),
offsetof(lbm_context_stats_t, tr_bytes_rcved),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_ver),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_type),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_malformed),
offsetof(lbm_context_stats_t, tr_dgrams_send_failed),
offsetof(lbm_context_stats_t, tr_src_topics),
offsetof(lbm_context_stats_t, tr_rcv_topics),
offsetof(lbm_context_stats_t, tr_rcv_unresolved_topics),
offsetof(lbm_context_stats_t, lbtrm_unknown_msgs_rcved),
offsetof(lbm_context_stats_t, lbtru_unknown_msgs_rcved),
offsetof(lbm_context_stats_t, send_blocked),
offsetof(lbm_context_stats_t, send_would_block),
offsetof(lbm_context_stats_t, resp_blocked),
offsetof(lbm_context_stats_t, resp_would_block)
};
#define csv_ctx_stat_offset_v3 csv_ctx_stat_offset_v2
static size_t csv_ctx_stat_offset_v4[] =
{
offsetof(lbm_context_stats_t, tr_dgrams_sent),
offsetof(lbm_context_stats_t, tr_bytes_sent),
offsetof(lbm_context_stats_t, tr_dgrams_rcved),
offsetof(lbm_context_stats_t, tr_bytes_rcved),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_ver),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_type),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_malformed),
offsetof(lbm_context_stats_t, tr_dgrams_send_failed),
offsetof(lbm_context_stats_t, tr_src_topics),
offsetof(lbm_context_stats_t, tr_rcv_topics),
offsetof(lbm_context_stats_t, tr_rcv_unresolved_topics),
offsetof(lbm_context_stats_t, lbtrm_unknown_msgs_rcved),
offsetof(lbm_context_stats_t, lbtru_unknown_msgs_rcved),
offsetof(lbm_context_stats_t, send_blocked),
offsetof(lbm_context_stats_t, send_would_block),
offsetof(lbm_context_stats_t, resp_blocked),
offsetof(lbm_context_stats_t, resp_would_block),
offsetof(lbm_context_stats_t, uim_dup_msgs_rcved),
offsetof(lbm_context_stats_t, uim_msgs_no_stream_rcved)
};
static size_t csv_ctx_stat_offset_v5[] =
{
offsetof(lbm_context_stats_t, tr_dgrams_sent),
offsetof(lbm_context_stats_t, tr_bytes_sent),
offsetof(lbm_context_stats_t, tr_dgrams_rcved),
offsetof(lbm_context_stats_t, tr_bytes_rcved),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_ver),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_type),
offsetof(lbm_context_stats_t, tr_dgrams_dropped_malformed),
offsetof(lbm_context_stats_t, tr_dgrams_send_failed),
offsetof(lbm_context_stats_t, tr_src_topics),
offsetof(lbm_context_stats_t, tr_rcv_topics),
offsetof(lbm_context_stats_t, tr_rcv_unresolved_topics),
offsetof(lbm_context_stats_t, lbtrm_unknown_msgs_rcved),
offsetof(lbm_context_stats_t, lbtru_unknown_msgs_rcved),
offsetof(lbm_context_stats_t, send_blocked),
offsetof(lbm_context_stats_t, send_would_block),
offsetof(lbm_context_stats_t, resp_blocked),
offsetof(lbm_context_stats_t, resp_would_block),
offsetof(lbm_context_stats_t, uim_dup_msgs_rcved),
offsetof(lbm_context_stats_t, uim_msgs_no_stream_rcved),
offsetof(lbm_context_stats_t, fragments_lost),
offsetof(lbm_context_stats_t, fragments_unrecoverably_lost),
offsetof(lbm_context_stats_t, rcv_cb_svc_time_min),
offsetof(lbm_context_stats_t, rcv_cb_svc_time_max),
offsetof(lbm_context_stats_t, rcv_cb_svc_time_mean)
};
static const lbmmon_csv_layout_t csv_ctx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ csv_ctx_stat_offset_v2, sizeof(csv_ctx_stat_offset_v2)/sizeof(csv_ctx_stat_offset_v2[0]) },
{ csv_ctx_stat_offset_v3, sizeof(csv_ctx_stat_offset_v3)/sizeof(csv_ctx_stat_offset_v3[0]) },
{ csv_ctx_stat_offset_v4, sizeof(csv_ctx_stat_offset_v4)/sizeof(csv_ctx_stat_offset_v4[0]) },
{ csv_ctx_stat_offset_v5, sizeof(csv_ctx_stat_offset_v5)/sizeof(csv_ctx_stat_offset_v5[0]) }
};
int lbmmon_ctx_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, lbm_context_stats_t * Statistics,
const char * Source, size_t Length, unsigned short ModuleID, void * FormatClientData)
{
const char * ptr;
char value[1024];
lbmmon_format_csv_t * fmt;
size_t idx;
unsigned char modid;
unsigned char modver;
const size_t * stat_layout = NULL;
size_t stat_count = 0;
if ((Statistics == NULL) || (Source == NULL) || (*Source == '\0') || (Length == 0) || (FormatClientData == NULL) )
{
strncpy(ErrorString, "Invalid parameter", sizeof(ErrorString));
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_ON)
{
}
modid = MODULE_ID(ModuleID);
modver = MODULE_VERSION(ModuleID);
{
snprintf(ErrorString, sizeof(ErrorString), "Invalid module ID %u", (unsigned)modid);
}
if (fmt->mBuffer == NULL)
{
fmt->mBufferSize = 1024;
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
if (Length >= fmt->mBufferSize)
{
fmt->mBufferSize = 2 * Length;
free(fmt->mBuffer);
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
memset(fmt->mBuffer, 0, fmt->mBufferSize);
memcpy(fmt->mBuffer, Source, Length);
ptr = fmt->mBuffer;
if (modver >= LBMMON_FORMAT_CSV_VERSION_CURRENT)
{
stat_layout = csv_ctx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].layout;
stat_count = csv_ctx_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT].count;
}
else
{
stat_layout = csv_ctx_stat_layout[modver].layout;
stat_count = csv_ctx_stat_layout[modver].count;
}
memset((void *) Statistics, 0, sizeof(lbm_context_stats_t));
for (idx = 0; idx < stat_count; ++idx)
{
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
*((lbm_ulong_t *)(((unsigned char *) Statistics) + stat_layout[idx])) = convert_value(value);
}
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_CONVERT)
{
}
}
int lbmmon_rcv_topic_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, size_t * Count,
lbm_rcv_topic_stats_t * Statistics, const char * Source, size_t Length, unsigned short ModuleID,
void * FormatClientData)
{
const char * ptr;
char value[1024];
lbmmon_format_csv_t * fmt;
size_t idx;
unsigned char modid;
unsigned char modver;
char topic[LBM_MSG_MAX_TOPIC_LEN + 1];
size_t src_count;
if ((Count == NULL) || (*Count == 0) || (Statistics == NULL) || (Source == NULL) || (*Source == '\0') || (Length == 0) || (FormatClientData == NULL) )
{
strncpy(ErrorString, "Invalid parameter", sizeof(ErrorString));
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_ON)
{
}
modid = MODULE_ID(ModuleID);
modver = MODULE_VERSION(ModuleID);
{
snprintf(ErrorString, sizeof(ErrorString), "Invalid module ID %u", (unsigned)modid);
}
if (modver != LBMMON_FORMAT_CSV_VERSION_5)
{
strncpy(ErrorString, "Unknown version", sizeof(ErrorString));
}
if (fmt->mBuffer == NULL)
{
fmt->mBufferSize = 1024;
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
if (Length >= fmt->mBufferSize)
{
fmt->mBufferSize = 2 * Length;
free(fmt->mBuffer);
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
memset(fmt->mBuffer, 0, fmt->mBufferSize);
memcpy(fmt->mBuffer, Source, Length);
ptr = fmt->mBuffer;
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
strncpy(topic, value, sizeof(topic));
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
src_count = (size_t) convert_value(value);
if (*Count < src_count)
{
/* Not enough entries. */
*Count = src_count;
return (-2);
}
if (src_count == 0)
{
memset((void *) &(Statistics[0]), 0, sizeof(lbm_rcv_topic_stats_t));
strncpy(Statistics[0].topic, topic, sizeof(Statistics[idx].topic));
src_count = 1;
}
else
{
for (idx = 0; idx < src_count; ++idx)
{
memset((void *) &(Statistics[idx]), 0, sizeof(lbm_rcv_topic_stats_t));
strncpy(Statistics[idx].topic, topic, sizeof(Statistics[idx].topic));
Statistics[idx].flags |= LBM_RCV_TOPIC_STATS_FLAG_SRC_VALID;
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
strncpy(Statistics[idx].source, (void *) value, sizeof(Statistics[idx].source));
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
lbmmon_format_csv_convert_from_hex((char *) &(Statistics[idx].otid), (lbm_uint8_t *) value, strlen(value));
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
Statistics[idx].topic_idx = (lbm_uint32_t) convert_value(value);
}
}
*Count = src_count;
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_CONVERT)
{
}
}
/* Note: these are currently not used. */
#if 0
static size_t csv_wrcv_stat_offset_v5[] =
{
offsetof(lbm_wildcard_rcv_stats_t, pattern),
offsetof(lbm_wildcard_rcv_stats_t, type)
};
static const lbmmon_csv_layout_t csv_wrcv_stat_layout[LBMMON_FORMAT_CSV_VERSION_CURRENT+1] =
{
{ NULL, 0 },
{ NULL, 0 },
{ NULL, 0 },
{ NULL, 0 },
{ NULL, 0 },
{ csv_wrcv_stat_offset_v5, sizeof(csv_wrcv_stat_offset_v5)/sizeof(csv_wrcv_stat_offset_v5[0]) }
};
#endif
int lbmmon_wildcard_rcv_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, lbm_wildcard_rcv_stats_t * Statistics,
const char * Source, size_t Length, unsigned short ModuleID, void * FormatClientData)
{
const char * ptr;
char value[1024];
lbmmon_format_csv_t * fmt;
unsigned char modid;
unsigned char modver;
if ((Statistics == NULL) || (Source == NULL) || (*Source == '\0') || (Length == 0) || (FormatClientData == NULL) )
{
strncpy(ErrorString, "Invalid parameter", sizeof(ErrorString));
}
fmt = (lbmmon_format_csv_t *) FormatClientData;
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_ON)
{
}
modid = MODULE_ID(ModuleID);
modver = MODULE_VERSION(ModuleID);
{
snprintf(ErrorString, sizeof(ErrorString), "Invalid module ID %u", (unsigned)modid);
}
if (modver != LBMMON_FORMAT_CSV_VERSION_5)
{
strncpy(ErrorString, "Unknown version", sizeof(ErrorString));
}
if (fmt->mBuffer == NULL)
{
fmt->mBufferSize = 1024;
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
if (Length >= fmt->mBufferSize)
{
fmt->mBufferSize = 2 * Length;
free(fmt->mBuffer);
fmt->mBuffer = malloc(fmt->mBufferSize);
if (fmt->mBuffer == NULL)
{
lbmmon_format_csv_report_allocation_error(fmt->mBufferSize);
}
}
memset(fmt->mBuffer, 0, fmt->mBufferSize);
memcpy(fmt->mBuffer, Source, Length);
ptr = fmt->mBuffer;
memset((void *) Statistics, 0, sizeof(lbm_wildcard_rcv_stats_t));
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
strncpy(Statistics->pattern, value, sizeof(Statistics->pattern));
ptr = next_csv_value(ptr, value, sizeof(value), fmt->mSeparator);
if (ptr == NULL)
{
strncpy(ErrorString, "Data contains too few fields", sizeof(ErrorString));
}
Statistics->type = (lbm_uint8_t) convert_value(value);
if (fmt->mPassthrough == LBMMON_FORMAT_PASSTHROUGH_CONVERT)
{
}
}
int lbmmon_store_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, Lbmmon__UMPMonMsg ** StoreMsg,
const char * Source, size_t Length, unsigned short ModuleID, void * FormatClientData)
{
strncpy(ErrorString, "CSV format not supported for stores at this time", sizeof(ErrorString));
}
int lbmmon_gateway_format_csv_deserialize(lbmmon_packet_attributes_t * Attributes, Lbmmon__DROMonMsg ** GatewayMsg,
const char * Source, size_t Length, unsigned short ModuleID, void * FormatClientData)
{
strncpy(ErrorString, "CSV format not supported for gateway stats at this time", sizeof(ErrorString));
}
int lbmmon_format_csv_finish(void * FormatClientData)
{
if (FormatClientData != NULL)
{
lbmmon_format_csv_t * data = (lbmmon_format_csv_t *) FormatClientData;
if (data->mBuffer != NULL)
{
free(data->mBuffer);
data->mBuffer = NULL;
}
free(data);
}
return (0);
}
const char * lbmmon_format_csv_errmsg(void)
{
return (ErrorString);
}