2004-04-21 17:57:31 +00:00
|
|
|
/* gsm_map_summary.c
|
|
|
|
* Routines for GSM MAP Statictics summary window
|
|
|
|
*
|
|
|
|
* Copyright 2004, Michael Lum <mlum [AT] telostech.com>
|
|
|
|
* In association with Telos Technology Inc.
|
|
|
|
*
|
|
|
|
* Modified from summary_dlg.c
|
|
|
|
*
|
2004-07-18 00:24:25 +00:00
|
|
|
* $Id$
|
2004-04-21 17:57:31 +00:00
|
|
|
*
|
2006-05-21 05:12:17 +00:00
|
|
|
* Wireshark - Network traffic analyzer
|
|
|
|
* By Gerald Combs <gerald@wireshark.org>
|
2004-04-21 17:57:31 +00:00
|
|
|
* Copyright 1998 Gerald Combs
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
|
|
|
|
2007-08-30 00:24:40 +00:00
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
#include <sys/types.h>
|
|
|
|
#endif
|
|
|
|
|
2004-04-21 17:57:31 +00:00
|
|
|
#include <gtk/gtk.h>
|
|
|
|
|
2008-04-13 01:54:20 +00:00
|
|
|
#include <wiretap/wtap.h>
|
2004-04-21 17:57:31 +00:00
|
|
|
|
2008-04-13 01:54:20 +00:00
|
|
|
#include <epan/epan.h>
|
|
|
|
#include <epan/packet.h>
|
|
|
|
#include <epan/packet_info.h>
|
|
|
|
#include <epan/value_string.h>
|
2004-09-29 00:06:36 +00:00
|
|
|
#include <epan/tap.h>
|
2007-05-13 20:58:29 +00:00
|
|
|
#include <epan/asn1.h>
|
2004-07-18 18:06:47 +00:00
|
|
|
#include <epan/dissectors/packet-gsm_map.h>
|
2008-04-13 01:54:20 +00:00
|
|
|
|
|
|
|
#include "../stat_menu.h"
|
|
|
|
#include "../globals.h"
|
|
|
|
#include "../file.h"
|
|
|
|
#include "../summary.h"
|
|
|
|
|
2012-01-15 21:59:11 +00:00
|
|
|
#include "ui/gtk/gui_stat_menu.h"
|
|
|
|
#include "ui/gtk/dlg_utils.h"
|
|
|
|
#include "ui/gtk/gui_utils.h"
|
|
|
|
#include "ui/gtk/gsm_map_stat.h"
|
2008-04-13 01:54:20 +00:00
|
|
|
|
2004-04-21 17:57:31 +00:00
|
|
|
|
|
|
|
#define SUM_STR_MAX 1024
|
|
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
add_string_to_box(gchar *str, GtkWidget *box)
|
|
|
|
{
|
|
|
|
GtkWidget *lb;
|
|
|
|
lb = gtk_label_new(str);
|
2009-04-21 16:57:52 +00:00
|
|
|
gtk_misc_set_alignment(GTK_MISC(lb), 0.0f, 0.5f);
|
2004-04-21 17:57:31 +00:00
|
|
|
gtk_box_pack_start(GTK_BOX(box), lb,FALSE,FALSE, 0);
|
|
|
|
gtk_widget_show(lb);
|
|
|
|
}
|
|
|
|
|
2011-05-12 15:17:28 +00:00
|
|
|
void gsm_map_stat_gtk_sum_cb(GtkAction *action _U_, gpointer user_data _U_)
|
2004-04-21 17:57:31 +00:00
|
|
|
{
|
|
|
|
summary_tally summary;
|
|
|
|
GtkWidget *sum_open_w,
|
|
|
|
*main_vb, *file_fr, *data_fr, *file_box,
|
|
|
|
*data_box, *bbox, *close_bt,
|
|
|
|
*invoke_fr, *invoke_box,
|
|
|
|
*rr_fr, *rr_box,
|
|
|
|
*tot_fr, *tot_box;
|
|
|
|
|
|
|
|
gchar string_buff[SUM_STR_MAX];
|
|
|
|
double seconds;
|
|
|
|
int i;
|
|
|
|
int tot_invokes, tot_rr;
|
|
|
|
double tot_invokes_size, tot_rr_size;
|
|
|
|
|
|
|
|
/* initialize the tally */
|
2005-02-04 19:29:27 +00:00
|
|
|
summary_fill_in(&cfile, &summary);
|
2004-04-21 17:57:31 +00:00
|
|
|
|
|
|
|
/* initial compututations */
|
|
|
|
seconds = summary.stop_time - summary.start_time;
|
|
|
|
|
2009-06-21 20:42:07 +00:00
|
|
|
sum_open_w = dlg_window_new("GSM MAP Statistics: Summary"); /* transient_for top_level */
|
|
|
|
gtk_window_set_destroy_with_parent (GTK_WINDOW(sum_open_w), TRUE);
|
2004-04-21 17:57:31 +00:00
|
|
|
|
|
|
|
/* Container for each row of widgets */
|
|
|
|
main_vb = gtk_vbox_new(FALSE, 3);
|
2008-06-29 15:51:43 +00:00
|
|
|
gtk_container_set_border_width(GTK_CONTAINER(main_vb), 5);
|
2004-04-21 17:57:31 +00:00
|
|
|
gtk_container_add(GTK_CONTAINER(sum_open_w), main_vb);
|
|
|
|
gtk_widget_show(main_vb);
|
|
|
|
|
|
|
|
/* File frame */
|
|
|
|
file_fr = gtk_frame_new("File");
|
|
|
|
gtk_container_add(GTK_CONTAINER(main_vb), file_fr);
|
|
|
|
gtk_widget_show(file_fr);
|
|
|
|
|
|
|
|
file_box = gtk_vbox_new(FALSE, 3);
|
|
|
|
gtk_container_add(GTK_CONTAINER(file_fr), file_box);
|
|
|
|
gtk_widget_show(file_box);
|
|
|
|
|
|
|
|
/* filename */
|
2005-03-05 20:52:03 +00:00
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Name: %s", ((summary.filename) ? summary.filename : "None"));
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, file_box);
|
|
|
|
|
|
|
|
/* length */
|
2007-05-29 06:56:07 +00:00
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Length: %" G_GINT64_MODIFIER "d", summary.file_length);
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, file_box);
|
|
|
|
|
|
|
|
/* format */
|
2008-10-14 22:55:16 +00:00
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Format: %s", wtap_file_type_string(summary.file_type));
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, file_box);
|
|
|
|
|
|
|
|
if (summary.has_snap) {
|
|
|
|
/* snapshot length */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Snapshot length: %u", summary.snap);
|
|
|
|
add_string_to_box(string_buff, file_box);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Data frame */
|
|
|
|
data_fr = gtk_frame_new("Data");
|
|
|
|
gtk_container_add(GTK_CONTAINER(main_vb), data_fr);
|
|
|
|
gtk_widget_show(data_fr);
|
|
|
|
|
|
|
|
data_box = gtk_vbox_new(FALSE, 3);
|
|
|
|
gtk_container_add(GTK_CONTAINER(data_fr), data_box);
|
|
|
|
gtk_widget_show(data_box);
|
|
|
|
|
|
|
|
/* seconds */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Elapsed time: %.3f seconds", summary.elapsed_time);
|
|
|
|
add_string_to_box(string_buff, data_box);
|
|
|
|
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Between first and last packet: %.3f seconds", seconds);
|
|
|
|
add_string_to_box(string_buff, data_box);
|
|
|
|
|
|
|
|
/* Packet count */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Packet count: %i", summary.packet_count);
|
|
|
|
add_string_to_box(string_buff, data_box);
|
|
|
|
|
|
|
|
tot_invokes = 0;
|
|
|
|
tot_invokes_size = 0;
|
|
|
|
for (i=0; i < GSM_MAP_MAX_NUM_OPR_CODES; i++)
|
|
|
|
{
|
|
|
|
tot_invokes += gsm_map_stat.opr_code[i];
|
|
|
|
tot_invokes_size += gsm_map_stat.size[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
tot_rr = 0;
|
|
|
|
tot_rr_size = 0;
|
|
|
|
for (i=0; i < GSM_MAP_MAX_NUM_OPR_CODES; i++)
|
|
|
|
{
|
|
|
|
tot_rr += gsm_map_stat.opr_code_rr[i];
|
|
|
|
tot_rr_size += gsm_map_stat.size_rr[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Invoke frame */
|
|
|
|
invoke_fr = gtk_frame_new("Invokes");
|
|
|
|
gtk_container_add(GTK_CONTAINER(main_vb), invoke_fr);
|
|
|
|
gtk_widget_show(invoke_fr);
|
|
|
|
|
|
|
|
invoke_box = gtk_vbox_new(FALSE, 3);
|
|
|
|
gtk_container_add(GTK_CONTAINER(invoke_fr), invoke_box);
|
|
|
|
gtk_widget_show(invoke_box);
|
|
|
|
|
|
|
|
/* Total number of invokes */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes: %u", tot_invokes);
|
|
|
|
add_string_to_box(string_buff, invoke_box);
|
|
|
|
|
|
|
|
/* Total number of invokes per second */
|
2005-03-05 20:52:03 +00:00
|
|
|
if (seconds)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes per second: %.2f", tot_invokes/seconds);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of Invokes per second: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, invoke_box);
|
|
|
|
|
|
|
|
/* Total size of invokes */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for Invokes: %.0f", tot_invokes_size);
|
|
|
|
add_string_to_box(string_buff, invoke_box);
|
|
|
|
|
|
|
|
/* Average size of invokes */
|
2005-03-05 20:52:03 +00:00
|
|
|
if (tot_invokes)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Invoke: %.2f", tot_invokes_size/tot_invokes);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Invoke: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, invoke_box);
|
|
|
|
|
|
|
|
/* Average size of invokes per second */
|
2005-03-05 20:52:03 +00:00
|
|
|
if (seconds)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: %.2f", tot_invokes_size/seconds);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, invoke_box);
|
|
|
|
|
|
|
|
/* Return Results frame */
|
|
|
|
rr_fr = gtk_frame_new("Return Results");
|
|
|
|
gtk_container_add(GTK_CONTAINER(main_vb), rr_fr);
|
|
|
|
gtk_widget_show(rr_fr);
|
|
|
|
|
|
|
|
rr_box = gtk_vbox_new(FALSE, 3);
|
|
|
|
gtk_container_add(GTK_CONTAINER(rr_fr), rr_box);
|
|
|
|
gtk_widget_show(rr_box);
|
|
|
|
|
|
|
|
/* Total number of return results */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results: %u", tot_rr);
|
|
|
|
add_string_to_box(string_buff, rr_box);
|
|
|
|
|
|
|
|
/* Total number of return results per second */
|
2005-03-05 20:52:03 +00:00
|
|
|
if (seconds)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results per second: %.2f", tot_rr/seconds);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of Return Results per second: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, rr_box);
|
|
|
|
|
|
|
|
/* Total size of return results */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for Return Results: %.0f", tot_rr_size);
|
|
|
|
add_string_to_box(string_buff, rr_box);
|
|
|
|
|
|
|
|
/* Average size of return results */
|
2005-03-05 20:52:03 +00:00
|
|
|
if (tot_rr)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Return Result: %.2f", tot_rr_size/tot_rr);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per Return Result: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, rr_box);
|
|
|
|
|
|
|
|
/* Average size of return results per second */
|
2005-03-05 20:52:03 +00:00
|
|
|
if (seconds)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: %.2f", tot_rr_size/seconds);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per second: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, rr_box);
|
|
|
|
|
|
|
|
/* Totals frame */
|
|
|
|
tot_fr = gtk_frame_new("Totals");
|
|
|
|
gtk_container_add(GTK_CONTAINER(main_vb), tot_fr);
|
|
|
|
gtk_widget_show(tot_fr);
|
|
|
|
|
|
|
|
tot_box = gtk_vbox_new(FALSE, 3);
|
|
|
|
gtk_container_add(GTK_CONTAINER(tot_fr), tot_box);
|
|
|
|
gtk_widget_show(tot_box);
|
|
|
|
|
|
|
|
/* Total number of return results */
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages: %u", tot_invokes + tot_rr);
|
|
|
|
add_string_to_box(string_buff, tot_box);
|
|
|
|
|
2005-03-05 20:52:03 +00:00
|
|
|
if (seconds)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages per second: %.2f",
|
|
|
|
(tot_invokes + tot_rr)/seconds);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of GSM MAP messages per second: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, tot_box);
|
|
|
|
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Total number of bytes for GSM MAP messages: %.0f", tot_invokes_size + tot_rr_size);
|
|
|
|
add_string_to_box(string_buff, tot_box);
|
|
|
|
|
2005-03-05 20:52:03 +00:00
|
|
|
if (tot_invokes + tot_rr)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per GSM MAP messages: %.2f",
|
|
|
|
(tot_invokes_size + tot_rr_size)/(tot_invokes + tot_rr));
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes per GSM MAP messages: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, tot_box);
|
|
|
|
|
2005-03-05 20:52:03 +00:00
|
|
|
if (seconds)
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes second: %.2f",
|
|
|
|
(tot_invokes_size + tot_rr_size)/seconds);
|
|
|
|
else
|
|
|
|
g_snprintf(string_buff, SUM_STR_MAX, "Average number of bytes second: N/A");
|
2004-04-21 17:57:31 +00:00
|
|
|
add_string_to_box(string_buff, tot_box);
|
|
|
|
|
|
|
|
|
|
|
|
/* Button row. */
|
|
|
|
bbox = dlg_button_row_new(GTK_STOCK_CLOSE, NULL);
|
|
|
|
gtk_container_add(GTK_CONTAINER(main_vb), bbox);
|
|
|
|
gtk_widget_show(bbox);
|
|
|
|
|
2008-04-11 17:14:11 +00:00
|
|
|
close_bt = g_object_get_data(G_OBJECT(bbox), GTK_STOCK_CLOSE);
|
2004-05-23 23:24:07 +00:00
|
|
|
window_set_cancel_button(sum_open_w, close_bt, window_cancel_button_cb);
|
2004-04-21 17:57:31 +00:00
|
|
|
|
2008-04-11 23:16:06 +00:00
|
|
|
g_signal_connect(sum_open_w, "delete_event", G_CALLBACK(window_delete_event_cb), NULL);
|
2004-04-21 17:57:31 +00:00
|
|
|
|
|
|
|
gtk_widget_show(sum_open_w);
|
2004-05-23 23:24:07 +00:00
|
|
|
window_present(sum_open_w);
|
2004-04-21 17:57:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
register_tap_listener_gtkgsm_map_summary(void)
|
|
|
|
{
|
|
|
|
}
|