From Michael Mann:
Add a preference for the packet length statistics. Fixes bug 3239. svn path=/trunk/; revision=43597
This commit is contained in:
parent
ef825ec6d3
commit
85f219be2e
@ -158,6 +158,7 @@ stats_tree_create_node_by_pname(st, name, parent_name, with_children);
|
|||||||
|
|
||||||
|
|
||||||
stats_tree_create_range_node(st, name, parent_id, ...)
|
stats_tree_create_range_node(st, name, parent_id, ...)
|
||||||
|
stats_tree_create_range_node_string(st, name, parent_id, num_str_ranges, str_ranges)
|
||||||
stats_tree_range_node_with_pname(st, name, parent_name, ...)
|
stats_tree_range_node_with_pname(st, name, parent_name, ...)
|
||||||
Creates a node in the tree, that will contain a ranges list.
|
Creates a node in the tree, that will contain a ranges list.
|
||||||
example:
|
example:
|
||||||
|
@ -738,6 +738,7 @@ prefs_register_modules
|
|||||||
prefs_register_obsolete_preference
|
prefs_register_obsolete_preference
|
||||||
prefs_register_protocol
|
prefs_register_protocol
|
||||||
prefs_register_protocol_subtree
|
prefs_register_protocol_subtree
|
||||||
|
prefs_register_stat
|
||||||
prefs_register_range_preference
|
prefs_register_range_preference
|
||||||
prefs_register_static_text_preference
|
prefs_register_static_text_preference
|
||||||
prefs_register_string_preference
|
prefs_register_string_preference
|
||||||
@ -1008,6 +1009,7 @@ stats_tree_create_node_by_pname
|
|||||||
stats_tree_create_pivot_by_pname
|
stats_tree_create_pivot_by_pname
|
||||||
stats_tree_create_pivot
|
stats_tree_create_pivot
|
||||||
stats_tree_create_range_node
|
stats_tree_create_range_node
|
||||||
|
stats_tree_create_range_node_string
|
||||||
stats_tree_free
|
stats_tree_free
|
||||||
stats_tree_get_abbr
|
stats_tree_get_abbr
|
||||||
stats_tree_get_cfg_by_abbr
|
stats_tree_get_cfg_by_abbr
|
||||||
|
32
epan/prefs.c
32
epan/prefs.c
@ -319,7 +319,6 @@ prefs_register_module_or_subtree(module_t *parent, const char *name,
|
|||||||
* Register that a protocol has preferences.
|
* Register that a protocol has preferences.
|
||||||
*/
|
*/
|
||||||
module_t *protocols_module = NULL;
|
module_t *protocols_module = NULL;
|
||||||
module_t *stats_module = NULL;
|
|
||||||
|
|
||||||
module_t *
|
module_t *
|
||||||
prefs_register_protocol(int id, void (*apply_cb)(void))
|
prefs_register_protocol(int id, void (*apply_cb)(void))
|
||||||
@ -427,6 +426,37 @@ prefs_register_protocol_obsolete(int id)
|
|||||||
return module;
|
return module;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Register that a statistical tap has preferences.
|
||||||
|
*
|
||||||
|
* "name" is a name for the tap to use on the command line with "-o"
|
||||||
|
* and in preference files.
|
||||||
|
*
|
||||||
|
* "title" is a short human-readable name for the tap.
|
||||||
|
*
|
||||||
|
* "description" is a longer human-readable description of the tap.
|
||||||
|
*/
|
||||||
|
module_t *stats_module = NULL;
|
||||||
|
|
||||||
|
module_t *
|
||||||
|
prefs_register_stat(const char *name, const char *title,
|
||||||
|
const char *description, void (*apply_cb)(void))
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Have we yet created the "Statistics" subtree?
|
||||||
|
*/
|
||||||
|
if (stats_module == NULL) {
|
||||||
|
/*
|
||||||
|
* No. Register Statistics subtree as well as any preferences
|
||||||
|
* for non-dissector modules.
|
||||||
|
*/
|
||||||
|
prefs_register_modules();
|
||||||
|
}
|
||||||
|
|
||||||
|
return prefs_register_module(stats_module, name, title, description,
|
||||||
|
apply_cb);
|
||||||
|
}
|
||||||
|
|
||||||
module_t *
|
module_t *
|
||||||
prefs_find_module(const char *name)
|
prefs_find_module(const char *name)
|
||||||
{
|
{
|
||||||
|
14
epan/prefs.h
14
epan/prefs.h
@ -220,6 +220,20 @@ extern module_t *prefs_register_subtree(module_t *parent, const char *title,
|
|||||||
*/
|
*/
|
||||||
extern module_t *prefs_register_protocol(int id, void (*apply_cb)(void));
|
extern module_t *prefs_register_protocol(int id, void (*apply_cb)(void));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Register that a statistical tap has preferences.
|
||||||
|
*
|
||||||
|
* "name" is a name for the tap to use on the command line with "-o"
|
||||||
|
* and in preference files.
|
||||||
|
*
|
||||||
|
* "title" is a short human-readable name for the tap.
|
||||||
|
*
|
||||||
|
* "description" is a longer human-readable description of the tap.
|
||||||
|
*/
|
||||||
|
extern module_t *prefs_register_stat(const char *name, const char *title,
|
||||||
|
const char *description,
|
||||||
|
void (*apply_cb)(void));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Register that a protocol has preferences and group it under a single
|
* Register that a protocol has preferences and group it under a single
|
||||||
* subtree
|
* subtree
|
||||||
|
@ -648,6 +648,23 @@ stats_tree_create_range_node(stats_tree *st, const gchar *name, int parent_id, .
|
|||||||
return rng_root->id;
|
return rng_root->id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern int
|
||||||
|
stats_tree_create_range_node_string(stats_tree *st, const gchar *name,
|
||||||
|
int parent_id, int num_str_ranges,
|
||||||
|
gchar** str_ranges)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
stat_node *rng_root = new_stat_node(st, name, parent_id, FALSE, TRUE);
|
||||||
|
stat_node *range_node = NULL;
|
||||||
|
|
||||||
|
for (i = 0; i < num_str_ranges; i++) {
|
||||||
|
range_node = new_stat_node(st, str_ranges[i], rng_root->id, FALSE, FALSE);
|
||||||
|
range_node->rng = get_range(str_ranges[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return rng_root->id;
|
||||||
|
}
|
||||||
|
|
||||||
/****/
|
/****/
|
||||||
extern int
|
extern int
|
||||||
stats_tree_parent_id_by_name(stats_tree *st, const gchar *parent_name)
|
stats_tree_parent_id_by_name(stats_tree *st, const gchar *parent_name)
|
||||||
|
@ -113,6 +113,12 @@ extern int stats_tree_create_range_node(stats_tree *st,
|
|||||||
int parent_id,
|
int parent_id,
|
||||||
...);
|
...);
|
||||||
|
|
||||||
|
extern int stats_tree_create_range_node_string(stats_tree *st,
|
||||||
|
const gchar *name,
|
||||||
|
int parent_id,
|
||||||
|
int num_str_ranges,
|
||||||
|
gchar** str_ranges);
|
||||||
|
|
||||||
extern int stats_tree_range_node_with_pname(stats_tree *st,
|
extern int stats_tree_range_node_with_pname(stats_tree *st,
|
||||||
const gchar *name,
|
const gchar *name,
|
||||||
const gchar *parent_name,
|
const gchar *parent_name,
|
||||||
|
@ -29,6 +29,9 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <epan/stats_tree.h>
|
#include <epan/stats_tree.h>
|
||||||
|
#include <epan/prefs.h>
|
||||||
|
#include <epan/uat.h>
|
||||||
|
#include <epan/uat-int.h>
|
||||||
|
|
||||||
#include "pinfo_stats_tree.h"
|
#include "pinfo_stats_tree.h"
|
||||||
|
|
||||||
@ -45,10 +48,70 @@ static const gchar* port_type_to_str (port_type type) {
|
|||||||
case PT_DDP: return "DDP";
|
case PT_DDP: return "DDP";
|
||||||
case PT_SBCCS: return "FICON SBCCS";
|
case PT_SBCCS: return "FICON SBCCS";
|
||||||
case PT_IDP: return "IDP";
|
case PT_IDP: return "IDP";
|
||||||
default: return "[Unknown]";
|
default: return "[Unknown]";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*-------------------------------------
|
||||||
|
* UAT for Packet Lengths
|
||||||
|
*-------------------------------------
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
range_t *packet_range;
|
||||||
|
} uat_plen_record_t;
|
||||||
|
|
||||||
|
static range_t default_range[10] = {
|
||||||
|
{1, {{0, 19}}},
|
||||||
|
{1, {{20, 39}}},
|
||||||
|
{1, {{40, 79}}},
|
||||||
|
{1, {{80, 159}}},
|
||||||
|
{1, {{160, 319}}},
|
||||||
|
{1, {{320, 639}}},
|
||||||
|
{1, {{640, 1279}}},
|
||||||
|
{1, {{1280, 2559}}},
|
||||||
|
{1, {{2560, 5119}}},
|
||||||
|
{1, {{5120, 0xFFFFFFFF}}}
|
||||||
|
};
|
||||||
|
static uat_plen_record_t *uat_plen_records = NULL;
|
||||||
|
static uat_t * plen_uat = NULL;
|
||||||
|
static guint num_plen_uat = 0;
|
||||||
|
|
||||||
|
static void* uat_plen_record_copy_cb(void* n, const void* o, size_t siz _U_) {
|
||||||
|
const uat_plen_record_t *r = o;
|
||||||
|
uat_plen_record_t *rn = n;
|
||||||
|
|
||||||
|
if (r->packet_range)
|
||||||
|
rn->packet_range = range_copy(r->packet_range);
|
||||||
|
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void uat_plen_record_free_cb(void*r) {
|
||||||
|
uat_plen_record_t* record = (uat_plen_record_t*)r;
|
||||||
|
|
||||||
|
if (record->packet_range)
|
||||||
|
g_free(record->packet_range);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void uat_plen_record_post_update_cb(void) {
|
||||||
|
guint i, num_default;
|
||||||
|
uat_plen_record_t rec;
|
||||||
|
|
||||||
|
/* If there are no records, create default list */
|
||||||
|
if (num_plen_uat == 0) {
|
||||||
|
num_default = sizeof(default_range)/sizeof(range_t);
|
||||||
|
|
||||||
|
/* default values for packet lengths */
|
||||||
|
for (i = 0; i < num_default; i++)
|
||||||
|
{
|
||||||
|
rec.packet_range = &default_range[i];
|
||||||
|
uat_add_record(plen_uat, &rec);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
UAT_RANGE_CB_DEF(uat_plen_records, packet_range, uat_plen_record_t)
|
||||||
|
|
||||||
/* ip host stats_tree -- basic test */
|
/* ip host stats_tree -- basic test */
|
||||||
static int st_node_ip = -1;
|
static int st_node_ip = -1;
|
||||||
static const gchar* st_str_ip = "IP Addresses";
|
static const gchar* st_str_ip = "IP Addresses";
|
||||||
@ -88,7 +151,15 @@ static int st_node_plen = -1;
|
|||||||
static const gchar* st_str_plen = "Packet Lengths";
|
static const gchar* st_str_plen = "Packet Lengths";
|
||||||
|
|
||||||
static void plen_stats_tree_init(stats_tree* st) {
|
static void plen_stats_tree_init(stats_tree* st) {
|
||||||
st_node_plen = stats_tree_create_range_node(st, st_str_plen, 0, "0-19","20-39","40-79","80-159","160-319","320-639","640-1279","1280-2559","2560-5119","5120-",NULL);
|
guint i;
|
||||||
|
char **str_range_array = ep_alloc(num_plen_uat*sizeof(char*));
|
||||||
|
|
||||||
|
/* Convert the ranges to strings for the stats tree API */
|
||||||
|
for (i = 0; i < num_plen_uat; i++) {
|
||||||
|
str_range_array[i] = range_convert_range(uat_plen_records[i].packet_range);
|
||||||
|
}
|
||||||
|
|
||||||
|
st_node_plen = stats_tree_create_range_node_string(st, st_str_plen, 0, num_plen_uat, str_range_array);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int plen_stats_tree_packet(stats_tree* st, packet_info* pinfo, epan_dissect_t *edt _U_, const void *p _U_) {
|
static int plen_stats_tree_packet(stats_tree* st, packet_info* pinfo, epan_dissect_t *edt _U_, const void *p _U_) {
|
||||||
@ -130,9 +201,35 @@ static int dsts_stats_tree_packet(stats_tree* st, packet_info* pinfo, epan_disse
|
|||||||
|
|
||||||
/* register all pinfo trees */
|
/* register all pinfo trees */
|
||||||
void register_pinfo_stat_trees(void) {
|
void register_pinfo_stat_trees(void) {
|
||||||
|
module_t *stat_module;
|
||||||
|
|
||||||
|
static uat_field_t plen_uat_flds[] = {
|
||||||
|
UAT_FLD_RANGE(uat_plen_records, packet_range, "Packet Range", 0xFFFFFFFF, "Range of packet sizes to count"),
|
||||||
|
UAT_END_FIELDS
|
||||||
|
};
|
||||||
|
|
||||||
stats_tree_register("ip","ip_hosts",st_str_ip, 0, ip_hosts_stats_tree_packet, ip_hosts_stats_tree_init, NULL );
|
stats_tree_register("ip","ip_hosts",st_str_ip, 0, ip_hosts_stats_tree_packet, ip_hosts_stats_tree_init, NULL );
|
||||||
stats_tree_register("ip","ptype",st_str_ptype, 0, ptype_stats_tree_packet, ptype_stats_tree_init, NULL );
|
stats_tree_register("ip","ptype",st_str_ptype, 0, ptype_stats_tree_packet, ptype_stats_tree_init, NULL );
|
||||||
stats_tree_register_with_group("frame","plen",st_str_plen, 0, plen_stats_tree_packet, plen_stats_tree_init, NULL, REGISTER_STAT_GROUP_GENERIC );
|
stats_tree_register_with_group("frame","plen",st_str_plen, 0, plen_stats_tree_packet, plen_stats_tree_init, NULL, REGISTER_STAT_GROUP_GENERIC );
|
||||||
stats_tree_register("ip","dests",st_str_dsts, 0, dsts_stats_tree_packet, dsts_stats_tree_init, NULL );
|
stats_tree_register("ip","dests",st_str_dsts, 0, dsts_stats_tree_packet, dsts_stats_tree_init, NULL );
|
||||||
|
|
||||||
|
stat_module = prefs_register_stat("stat_tree", "Stats Tree", "Stats Tree", NULL);
|
||||||
|
|
||||||
|
plen_uat = uat_new("Packet Lengths",
|
||||||
|
sizeof(uat_plen_record_t), /* record size */
|
||||||
|
"packet_lengths", /* filename */
|
||||||
|
TRUE, /* from_profile */
|
||||||
|
(void*) &uat_plen_records, /* data_ptr */
|
||||||
|
&num_plen_uat, /* numitems_ptr */
|
||||||
|
UAT_CAT_GENERAL, /* category */
|
||||||
|
NULL, /* help */
|
||||||
|
uat_plen_record_copy_cb, /* copy callback */
|
||||||
|
NULL, /* update callback */
|
||||||
|
uat_plen_record_free_cb, /* free callback */
|
||||||
|
uat_plen_record_post_update_cb, /* post update callback */
|
||||||
|
plen_uat_flds); /* UAT field definitions */
|
||||||
|
|
||||||
|
prefs_register_uat_preference(stat_module, "packet_lengths",
|
||||||
|
"Packet Lengths", "Delineated packet sizes to count", plen_uat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user