[PATCH]add expr_matcher hit pattern statistics
This commit is contained in:
@@ -65,7 +65,7 @@ struct ipport_plugin_runtime {
|
||||
|
||||
long long rule_num;
|
||||
long long update_err_cnt;
|
||||
long long *scan_cnt;
|
||||
long long *scan_times;
|
||||
};
|
||||
|
||||
void *ipport_plugin_schema_new(cJSON *json, struct table_manager *tbl_mgr,
|
||||
@@ -223,7 +223,7 @@ void *ipport_plugin_runtime_new(void *ipport_plugin_schema, size_t max_thread_nu
|
||||
ipport_plugin_rt->n_worker_thread = max_thread_num;
|
||||
ipport_plugin_rt->ref_garbage_bin = garbage_bin;
|
||||
ipport_plugin_rt->logger = logger;
|
||||
ipport_plugin_rt->scan_cnt = alignment_int64_array_alloc(max_thread_num);
|
||||
ipport_plugin_rt->scan_times = alignment_int64_array_alloc(max_thread_num);
|
||||
|
||||
return ipport_plugin_rt;
|
||||
}
|
||||
@@ -245,9 +245,9 @@ void ipport_plugin_runtime_free(void *ipport_plugin_runtime)
|
||||
ipport_plugin_rt->ex_data_rt = NULL;
|
||||
}
|
||||
|
||||
if (ipport_plugin_rt->scan_cnt != NULL) {
|
||||
alignment_int64_array_free(ipport_plugin_rt->scan_cnt);
|
||||
ipport_plugin_rt->scan_cnt = NULL;
|
||||
if (ipport_plugin_rt->scan_times != NULL) {
|
||||
alignment_int64_array_free(ipport_plugin_rt->scan_times);
|
||||
ipport_plugin_rt->scan_times = NULL;
|
||||
}
|
||||
|
||||
FREE(ipport_plugin_rt);
|
||||
@@ -634,26 +634,27 @@ long long ipport_plugin_runtime_update_err_count(void *ipport_plugin_runtime)
|
||||
return ipport_plugin_rt->update_err_cnt;
|
||||
}
|
||||
|
||||
void ipport_plugin_runtime_scan_inc(void *ipport_plugin_runtime, int thread_id)
|
||||
void ipport_plugin_runtime_scan_times_inc(void *ipport_plugin_runtime, int thread_id)
|
||||
{
|
||||
if (NULL == ipport_plugin_runtime || thread_id < 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
struct ipport_plugin_runtime *ipport_plugin_rt = (struct ipport_plugin_runtime *)ipport_plugin_runtime;
|
||||
alignment_int64_array_add(ipport_plugin_rt->scan_cnt, thread_id, 1);
|
||||
alignment_int64_array_add(ipport_plugin_rt->scan_times, thread_id, 1);
|
||||
}
|
||||
|
||||
long long ipport_plugin_runtime_scan_count(void *ipport_plugin_runtime)
|
||||
long long ipport_plugin_runtime_scan_times(void *ipport_plugin_runtime)
|
||||
{
|
||||
if (NULL == ipport_plugin_runtime) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
struct ipport_plugin_runtime *ipport_plugin_rt = (struct ipport_plugin_runtime *)ipport_plugin_runtime;
|
||||
long long sum = alignment_int64_array_sum(ipport_plugin_rt->scan_cnt,
|
||||
long long sum = alignment_int64_array_sum(ipport_plugin_rt->scan_times,
|
||||
ipport_plugin_rt->n_worker_thread);
|
||||
alignment_int64_array_reset(ipport_plugin_rt->scan_cnt, ipport_plugin_rt->n_worker_thread);
|
||||
alignment_int64_array_reset(ipport_plugin_rt->scan_times,
|
||||
ipport_plugin_rt->n_worker_thread);
|
||||
|
||||
return sum;
|
||||
}
|
||||
Reference in New Issue
Block a user