} AppLayerCounters;
/* counter names. Only used at init. */
-AppLayerCounterNames applayer_counter_names[FLOW_PROTO_APPLAYER_MAX][ALPROTO_MAX];
+AppLayerCounterNames (*applayer_counter_names)[FLOW_PROTO_APPLAYER_MAX];
/* counter id's. Used that runtime. */
-AppLayerCounters applayer_counters[FLOW_PROTO_APPLAYER_MAX][ALPROTO_MAX];
+AppLayerCounters (*applayer_counters)[FLOW_PROTO_APPLAYER_MAX];
/* Exception policy global counters ids */
ExceptionPolicyCounters eps_error_summary;
*/
static void AppLayerIncFlowCounter(ThreadVars *tv, Flow *f)
{
- const uint16_t id = applayer_counters[f->protomap][f->alproto].counter_id;
+ const uint16_t id = applayer_counters[f->alproto][f->protomap].counter_id;
if (likely(tv && id > 0)) {
StatsIncr(tv, id);
}
void AppLayerIncTxCounter(ThreadVars *tv, Flow *f, uint64_t step)
{
- const uint16_t id = applayer_counters[f->protomap][f->alproto].counter_tx_id;
+ const uint16_t id = applayer_counters[f->alproto][f->protomap].counter_tx_id;
if (likely(tv && id > 0)) {
StatsAddUI64(tv, id, step);
}
void AppLayerIncGapErrorCounter(ThreadVars *tv, Flow *f)
{
- const uint16_t id = applayer_counters[f->protomap][f->alproto].gap_error_id;
+ const uint16_t id = applayer_counters[f->alproto][f->protomap].gap_error_id;
if (likely(tv && id > 0)) {
StatsIncr(tv, id);
}
void AppLayerIncAllocErrorCounter(ThreadVars *tv, Flow *f)
{
- const uint16_t id = applayer_counters[f->protomap][f->alproto].alloc_error_id;
+ const uint16_t id = applayer_counters[f->alproto][f->protomap].alloc_error_id;
if (likely(tv && id > 0)) {
StatsIncr(tv, id);
}
void AppLayerIncParserErrorCounter(ThreadVars *tv, Flow *f)
{
- const uint16_t id = applayer_counters[f->protomap][f->alproto].parser_error_id;
+ const uint16_t id = applayer_counters[f->alproto][f->protomap].parser_error_id;
if (likely(tv && id > 0)) {
StatsIncr(tv, id);
}
void AppLayerIncInternalErrorCounter(ThreadVars *tv, Flow *f)
{
- const uint16_t id = applayer_counters[f->protomap][f->alproto].internal_error_id;
+ const uint16_t id = applayer_counters[f->alproto][f->protomap].internal_error_id;
if (likely(tv && id > 0)) {
StatsIncr(tv, id);
}
return;
}
#endif
- uint16_t id = applayer_counters[f->protomap][f->alproto].eps_error.eps_id[policy];
+ uint16_t id = applayer_counters[f->alproto][f->protomap].eps_error.eps_id[policy];
/* for the summary values */
uint16_t g_id = eps_error_summary.eps_id[policy];
g_applayerparser_error_policy != EXCEPTION_POLICY_NOT_SET) {
for (enum ExceptionPolicy i = EXCEPTION_POLICY_NOT_SET + 1; i < EXCEPTION_POLICY_MAX; i++) {
if (IsAppLayerErrorExceptionPolicyStatsValid(i)) {
- snprintf(applayer_counter_names[ipproto_map][alproto].eps_name[i],
- sizeof(applayer_counter_names[ipproto_map][alproto].eps_name[i]),
+ snprintf(applayer_counter_names[alproto][ipproto_map].eps_name[i],
+ sizeof(applayer_counter_names[alproto][ipproto_map].eps_name[i]),
"app_layer.error.%s%s.exception_policy.%s", alproto_str, ipproto_suffix,
ExceptionPolicyEnumToString(i, true));
}
const char *str = "app_layer.flow.";
const char *estr = "app_layer.error.";
+ applayer_counter_names =
+ SCCalloc(ALPROTO_MAX, sizeof(AppLayerCounterNames[FLOW_PROTO_APPLAYER_MAX]));
+ if (unlikely(applayer_counter_names == NULL)) {
+ FatalError("Unable to alloc applayer_counter_names.");
+ }
+ applayer_counters = SCCalloc(ALPROTO_MAX, sizeof(AppLayerCounters[FLOW_PROTO_APPLAYER_MAX]));
+ if (unlikely(applayer_counters == NULL)) {
+ FatalError("Unable to alloc applayer_counters.");
+ }
/* We don't log stats counters if exception policy is `ignore`/`not set` */
if (g_applayerparser_error_policy != EXCEPTION_POLICY_NOT_SET) {
/* Register global counters for app layer error exception policy summary */
AppLayerProtoDetectSupportedIpprotos(alproto, ipprotos_all);
if ((ipprotos_all[IPPROTO_TCP / 8] & (1 << (IPPROTO_TCP % 8))) &&
(ipprotos_all[IPPROTO_UDP / 8] & (1 << (IPPROTO_UDP % 8)))) {
- snprintf(applayer_counter_names[ipproto_map][alproto].name,
- sizeof(applayer_counter_names[ipproto_map][alproto].name),
- "%s%s%s", str, alproto_str, ipproto_suffix);
- snprintf(applayer_counter_names[ipproto_map][alproto].tx_name,
- sizeof(applayer_counter_names[ipproto_map][alproto].tx_name),
- "%s%s%s", tx_str, alproto_str, ipproto_suffix);
+ snprintf(applayer_counter_names[alproto][ipproto_map].name,
+ sizeof(applayer_counter_names[alproto][ipproto_map].name), "%s%s%s",
+ str, alproto_str, ipproto_suffix);
+ snprintf(applayer_counter_names[alproto][ipproto_map].tx_name,
+ sizeof(applayer_counter_names[alproto][ipproto_map].tx_name), "%s%s%s",
+ tx_str, alproto_str, ipproto_suffix);
if (ipproto == IPPROTO_TCP) {
- snprintf(applayer_counter_names[ipproto_map][alproto].gap_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].gap_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].gap_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].gap_error),
"%s%s%s.gap", estr, alproto_str, ipproto_suffix);
}
- snprintf(applayer_counter_names[ipproto_map][alproto].alloc_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].alloc_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].alloc_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].alloc_error),
"%s%s%s.alloc", estr, alproto_str, ipproto_suffix);
- snprintf(applayer_counter_names[ipproto_map][alproto].parser_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].parser_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].parser_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].parser_error),
"%s%s%s.parser", estr, alproto_str, ipproto_suffix);
- snprintf(applayer_counter_names[ipproto_map][alproto].internal_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].internal_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].internal_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].internal_error),
"%s%s%s.internal", estr, alproto_str, ipproto_suffix);
AppLayerSetupExceptionPolicyPerProtoCounters(
ipproto_map, alproto, alproto_str, ipproto_suffix);
} else {
- snprintf(applayer_counter_names[ipproto_map][alproto].name,
- sizeof(applayer_counter_names[ipproto_map][alproto].name),
- "%s%s", str, alproto_str);
- snprintf(applayer_counter_names[ipproto_map][alproto].tx_name,
- sizeof(applayer_counter_names[ipproto_map][alproto].tx_name),
- "%s%s", tx_str, alproto_str);
+ snprintf(applayer_counter_names[alproto][ipproto_map].name,
+ sizeof(applayer_counter_names[alproto][ipproto_map].name), "%s%s", str,
+ alproto_str);
+ snprintf(applayer_counter_names[alproto][ipproto_map].tx_name,
+ sizeof(applayer_counter_names[alproto][ipproto_map].tx_name), "%s%s",
+ tx_str, alproto_str);
if (ipproto == IPPROTO_TCP) {
- snprintf(applayer_counter_names[ipproto_map][alproto].gap_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].gap_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].gap_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].gap_error),
"%s%s.gap", estr, alproto_str);
}
- snprintf(applayer_counter_names[ipproto_map][alproto].alloc_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].alloc_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].alloc_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].alloc_error),
"%s%s.alloc", estr, alproto_str);
- snprintf(applayer_counter_names[ipproto_map][alproto].parser_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].parser_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].parser_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].parser_error),
"%s%s.parser", estr, alproto_str);
- snprintf(applayer_counter_names[ipproto_map][alproto].internal_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].internal_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].internal_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].internal_error),
"%s%s.internal", estr, alproto_str);
AppLayerSetupExceptionPolicyPerProtoCounters(
ipproto_map, alproto, alproto_str, "");
}
} else if (alproto == ALPROTO_FAILED) {
- snprintf(applayer_counter_names[ipproto_map][alproto].name,
- sizeof(applayer_counter_names[ipproto_map][alproto].name),
- "%s%s%s", str, "failed", ipproto_suffix);
+ snprintf(applayer_counter_names[alproto][ipproto_map].name,
+ sizeof(applayer_counter_names[alproto][ipproto_map].name), "%s%s%s", str,
+ "failed", ipproto_suffix);
if (ipproto == IPPROTO_TCP) {
- snprintf(applayer_counter_names[ipproto_map][alproto].gap_error,
- sizeof(applayer_counter_names[ipproto_map][alproto].gap_error),
+ snprintf(applayer_counter_names[alproto][ipproto_map].gap_error,
+ sizeof(applayer_counter_names[alproto][ipproto_map].gap_error),
"%sfailed%s.gap", estr, ipproto_suffix);
}
}
for (AppProto alproto = 0; alproto < ALPROTO_MAX; alproto++) {
if (alprotos[alproto] == 1) {
- applayer_counters[ipproto_map][alproto].counter_id =
- StatsRegisterCounter(applayer_counter_names[ipproto_map][alproto].name, tv);
+ applayer_counters[alproto][ipproto_map].counter_id =
+ StatsRegisterCounter(applayer_counter_names[alproto][ipproto_map].name, tv);
- applayer_counters[ipproto_map][alproto].counter_tx_id =
- StatsRegisterCounter(applayer_counter_names[ipproto_map][alproto].tx_name, tv);
+ applayer_counters[alproto][ipproto_map].counter_tx_id = StatsRegisterCounter(
+ applayer_counter_names[alproto][ipproto_map].tx_name, tv);
if (ipproto == IPPROTO_TCP) {
- applayer_counters[ipproto_map][alproto].gap_error_id = StatsRegisterCounter(
- applayer_counter_names[ipproto_map][alproto].gap_error, tv);
+ applayer_counters[alproto][ipproto_map].gap_error_id = StatsRegisterCounter(
+ applayer_counter_names[alproto][ipproto_map].gap_error, tv);
}
- applayer_counters[ipproto_map][alproto].alloc_error_id = StatsRegisterCounter(
- applayer_counter_names[ipproto_map][alproto].alloc_error, tv);
- applayer_counters[ipproto_map][alproto].parser_error_id = StatsRegisterCounter(
- applayer_counter_names[ipproto_map][alproto].parser_error, tv);
- applayer_counters[ipproto_map][alproto].internal_error_id = StatsRegisterCounter(
- applayer_counter_names[ipproto_map][alproto].internal_error, tv);
+ applayer_counters[alproto][ipproto_map].alloc_error_id = StatsRegisterCounter(
+ applayer_counter_names[alproto][ipproto_map].alloc_error, tv);
+ applayer_counters[alproto][ipproto_map].parser_error_id = StatsRegisterCounter(
+ applayer_counter_names[alproto][ipproto_map].parser_error, tv);
+ applayer_counters[alproto][ipproto_map].internal_error_id = StatsRegisterCounter(
+ applayer_counter_names[alproto][ipproto_map].internal_error, tv);
/* We don't log stats counters if exception policy is `ignore`/`not set` */
if (g_stats_eps_per_app_proto_errors &&
g_applayerparser_error_policy != EXCEPTION_POLICY_NOT_SET) {
for (enum ExceptionPolicy i = EXCEPTION_POLICY_NOT_SET + 1;
i < EXCEPTION_POLICY_MAX; i++) {
if (IsAppLayerErrorExceptionPolicyStatsValid(i)) {
- applayer_counters[ipproto_map][alproto]
+ applayer_counters[alproto][ipproto_map]
.eps_error.eps_id[i] = StatsRegisterCounter(
- applayer_counter_names[ipproto_map][alproto].eps_name[i], tv);
+ applayer_counter_names[alproto][ipproto_map].eps_name[i], tv);
}
}
}
} else if (alproto == ALPROTO_FAILED) {
- applayer_counters[ipproto_map][alproto].counter_id =
- StatsRegisterCounter(applayer_counter_names[ipproto_map][alproto].name, tv);
+ applayer_counters[alproto][ipproto_map].counter_id =
+ StatsRegisterCounter(applayer_counter_names[alproto][ipproto_map].name, tv);
if (ipproto == IPPROTO_TCP) {
- applayer_counters[ipproto_map][alproto].gap_error_id = StatsRegisterCounter(
- applayer_counter_names[ipproto_map][alproto].gap_error, tv);
+ applayer_counters[alproto][ipproto_map].gap_error_id = StatsRegisterCounter(
+ applayer_counter_names[alproto][ipproto_map].gap_error, tv);
}
}
}
void AppLayerDeSetupCounters(void)
{
- memset(applayer_counter_names, 0, sizeof(applayer_counter_names));
- memset(applayer_counters, 0, sizeof(applayer_counters));
+ SCFree(applayer_counter_names);
+ SCFree(applayer_counters);
}
/***** Unittests *****/