aboutsummaryrefslogtreecommitdiffstats
path: root/ui/gtk/sctp_assoc_analyse.c
diff options
context:
space:
mode:
authorJörg Mayer <jmayer@loplof.de>2012-01-15 21:59:11 +0000
committerJörg Mayer <jmayer@loplof.de>2012-01-15 21:59:11 +0000
commitbe706c63801fb98d42fb743b27b16cc36273651e (patch)
tree62ed0b552191eb0753d26a3edcbab73459a15f7f /ui/gtk/sctp_assoc_analyse.c
parent6d69ef093cd6868ab51f8b52477a510172033353 (diff)
Move gtk to ui/gtk.
This looses the last checkin to gtk, will add this manually back. svn path=/trunk/; revision=40518
Diffstat (limited to 'ui/gtk/sctp_assoc_analyse.c')
-rw-r--r--ui/gtk/sctp_assoc_analyse.c984
1 files changed, 984 insertions, 0 deletions
diff --git a/ui/gtk/sctp_assoc_analyse.c b/ui/gtk/sctp_assoc_analyse.c
new file mode 100644
index 0000000000..27e1352294
--- /dev/null
+++ b/ui/gtk/sctp_assoc_analyse.c
@@ -0,0 +1,984 @@
+/*
+ * Copyright 2004, Irene Ruengeler <i.ruengeler [AT] fh-muenster.de>
+ *
+ * $Id$
+ *
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.org>
+ * 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
+
+#include <gtk/gtk.h>
+
+#include <epan/epan_dissect.h>
+#include "epan/filesystem.h"
+#include <epan/strutil.h>
+
+#include "../globals.h"
+#include "../simple_dialog.h"
+#include "../stat_menu.h"
+
+#include "ui/gtk/gui_stat_menu.h"
+#include "ui/gtk/dlg_utils.h"
+#include "ui/gtk/gui_utils.h"
+#include "ui/gtk/main.h"
+#include "ui/gtk/sctp_stat.h"
+#include "ui/gtk/gtkglobals.h"
+
+static sctp_assoc_info_t static_assoc;
+
+void
+decrease_childcount(struct sctp_analyse *parent)
+{
+ if (parent->num_children > 0)
+ parent->num_children--;
+}
+
+void
+increase_childcount(struct sctp_analyse *parent)
+{
+ parent->num_children++;
+}
+
+void
+set_child(struct sctp_udata *child, struct sctp_analyse *parent)
+{
+ parent->children = g_list_append(parent->children, child);
+}
+
+void
+remove_child(struct sctp_udata *child, struct sctp_analyse *parent)
+{
+ parent->children = g_list_remove(parent->children, child);
+}
+
+static void
+on_destroy(GObject *object _U_, gpointer user_data)
+{
+ struct sctp_analyse *u_data;
+ guint16 i, j;
+ GList *list;
+ struct sctp_udata *child_data;
+
+ u_data = (struct sctp_analyse*)user_data;
+
+ if (u_data->window)
+ {
+ gtk_grab_remove(GTK_WIDGET(u_data->window));
+ gtk_widget_destroy(GTK_WIDGET(u_data->window));
+ }
+ if (u_data->num_children>0)
+ {
+ j = u_data->num_children;
+ for (i=0; i<j; i++)
+ {
+ list = g_list_last(u_data->children);
+ child_data = (struct sctp_udata *)list->data;
+ gtk_grab_remove(GTK_WIDGET(child_data->io->window));
+ gtk_widget_destroy(GTK_WIDGET(child_data->io->window));
+ list = g_list_previous(list);
+ }
+ g_list_free(u_data->children);
+ u_data->children = NULL;
+ }
+
+ g_free(u_data->analyse_nb->page2);
+ g_free(u_data->analyse_nb->page3);
+ g_free(u_data->analyse_nb);
+ if (sctp_stat_get_info()->children != NULL)
+ {
+ remove_analyse_child(u_data);
+ decrease_analyse_childcount();
+ }
+ g_free(u_data);
+}
+
+static void
+on_notebook_switch_page(void)
+{
+}
+
+static void on_chunk_stat_bt(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+ sctp_assoc_info_t* assinfo = NULL;
+ int i;
+
+ assinfo = &static_assoc;
+ assinfo->addr_chunk_count = (static_assoc.addr_chunk_count);
+ for (i=0; i<NUM_CHUNKS; i++)
+ {
+ assinfo->chunk_count[i] = static_assoc.chunk_count[i];
+ assinfo->ep1_chunk_count[i] = static_assoc.ep1_chunk_count[i];
+ assinfo->ep2_chunk_count[i] = static_assoc.ep2_chunk_count[i];
+ }
+ u_data->assoc = assinfo;
+ sctp_chunk_dlg_show(u_data);
+}
+
+static void on_close_dlg(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+
+ if (u_data->window)
+ {
+ gtk_grab_remove(GTK_WIDGET(u_data->window));
+ gtk_widget_destroy(GTK_WIDGET(u_data->window));
+ }
+}
+
+static void on_chunk1_dlg(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+sctp_assoc_info_t* assinfo = NULL;
+
+ assinfo = &static_assoc;
+ assinfo->addr_chunk_count = (static_assoc.addr_chunk_count);
+ u_data->assoc = assinfo;
+ sctp_chunk_stat_dlg_show(1, u_data);
+}
+
+static void on_chunk2_dlg(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+sctp_assoc_info_t* assinfo=NULL;
+
+ assinfo = &static_assoc;
+ assinfo->addr_chunk_count = (static_assoc.addr_chunk_count);
+ u_data->assoc = assinfo;
+ sctp_chunk_stat_dlg_show(2, u_data);
+}
+
+static void on_graph1_dlg(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+ create_graph(1, u_data);
+}
+
+static void on_graph2_dlg(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+ create_graph(2, u_data);
+}
+
+static void on_graph_byte1_dlg(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+ create_byte_graph(1, u_data);
+}
+
+static void on_graph_byte2_dlg(GtkWidget *widget _U_, struct sctp_analyse* u_data)
+{
+ create_byte_graph(2, u_data);
+}
+
+void
+update_analyse_dlg(struct sctp_analyse* u_data)
+{
+ gchar label_txt[50];
+ gchar field[1][MAX_ADDRESS_LEN];
+ GList *list;
+ address *store = NULL;
+ GtkListStore *list_store = NULL;
+ GtkTreeIter iter;
+
+ if (u_data->assoc == NULL)
+ return;
+
+ if (u_data->window != NULL)
+ {
+ gtk_list_store_clear(GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW
+ (u_data->analyse_nb->page2->clist))));
+ gtk_list_store_clear(GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW
+ (u_data->analyse_nb->page3->clist))));
+ }
+
+
+ g_snprintf(label_txt, sizeof(label_txt),"Checksum Type: %s",u_data->assoc->checksum_type);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->checktype), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Checksum Errors: %u",u_data->assoc->n_checksum_errors);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->checksum), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Bundling Errors: %u",u_data->assoc->n_bundling_errors);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->bundling), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Padding Errors: %u",u_data->assoc->n_padding_errors);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->padding), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Length Errors: %u",u_data->assoc->n_length_errors);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->length), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Value Errors: %u",u_data->assoc->n_value_errors);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->value), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"No of Data Chunks from EP1 to EP2: %u",u_data->assoc->n_data_chunks_ep1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->chunks_ep1), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"No of Data Bytes from EP1 to EP2: %u",u_data->assoc->n_data_bytes_ep1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->bytes_ep1), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"No of Data Chunks from EP2 to EP1: %u",u_data->assoc->n_data_chunks_ep2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->chunks_ep2), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"No of Data Bytes from EP2 to EP1: %u",u_data->assoc->n_data_bytes_ep2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->bytes_ep2), label_txt);
+
+ if (u_data->assoc->init == TRUE)
+ gtk_frame_set_label(GTK_FRAME (u_data->analyse_nb->page2->addr_frame), "Complete list of IP-Addresses as provided in the INIT-Chunk");
+ else if (u_data->assoc->initack == TRUE && u_data->assoc->initack_dir == 1)
+ gtk_frame_set_label(GTK_FRAME (u_data->analyse_nb->page2->addr_frame), "Complete list of IP-Addresses as provided in the INITACK-Chunk");
+ else
+ gtk_frame_set_label(GTK_FRAME (u_data->analyse_nb->page2->addr_frame), "List of used IP-Addresses");
+
+
+
+ if (u_data->assoc->addr1 != NULL)
+ {
+ list = g_list_first(u_data->assoc->addr1);
+ while (list)
+ {
+ store = (address *) (list->data);
+ if (store->type == AT_IPv4)
+ {
+ g_snprintf(field[0], 30, "%s", ip_to_str((const guint8 *)(store->data)));
+ }
+ else if (store->type == AT_IPv6)
+ {
+ g_snprintf(field[0], 40, "%s", ip6_to_str((const struct e_in6_addr *)(store->data)));
+ }
+ list_store = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW (u_data->analyse_nb->page2->clist))); /* Get store */
+
+ gtk_list_store_insert_with_values( list_store , &iter, G_MAXINT,
+ 0, field[0], -1);
+ list = g_list_next(list);
+ }
+ }
+ else
+ {
+ return;
+ }
+ g_snprintf(label_txt, sizeof(label_txt),"Port: %u",u_data->assoc->port1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->port), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Sent Verification Tag: 0x%x",u_data->assoc->verification_tag1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->veritag), label_txt);
+
+ if (u_data->assoc->init == TRUE || (u_data->assoc->initack == TRUE && u_data->assoc->initack_dir == 1))
+ {
+ g_snprintf(label_txt, sizeof(label_txt),"Requested Number of Inbound Streams: %u",u_data->assoc->instream1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->max_in), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Minimum Number of Inbound Streams: %u",((u_data->assoc->instream1>u_data->assoc->outstream2)?u_data->assoc->outstream2:u_data->assoc->instream1));
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->min_in), label_txt);
+
+ g_snprintf(label_txt, sizeof(label_txt),"Provided Number of Outbound Streams: %u",u_data->assoc->outstream1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->max_out), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Minimum Number of Outbound Streams: %u",((u_data->assoc->outstream1>u_data->assoc->instream2)?u_data->assoc->instream2:u_data->assoc->outstream1));
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->max_out), label_txt);
+ }
+ else
+ {
+ g_snprintf(label_txt, sizeof(label_txt),"Used Number of Inbound Streams: %u",u_data->assoc->instream1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->max_in), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Used Number of Outbound Streams: %u",u_data->assoc->outstream1);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page2->max_out), label_txt);
+ }
+
+ if (u_data->assoc->initack == TRUE && u_data->assoc->initack_dir == 2)
+ gtk_frame_set_label(GTK_FRAME (u_data->analyse_nb->page3->addr_frame), "Complete list of IP-Addresses as provided in the INITACK-Chunk");
+ else
+ gtk_frame_set_label(GTK_FRAME (u_data->analyse_nb->page3->addr_frame), "List of used IP-Addresses");
+
+
+ if (u_data->assoc->addr2 != NULL)
+ {
+
+ list = g_list_first(u_data->assoc->addr2);
+
+ while (list)
+ {
+ store = (address *) (list->data);
+ if (store->type == AT_IPv4)
+ {
+ g_snprintf(field[0], 30, "%s", ip_to_str((const guint8 *)(store->data)));
+ }
+ else if (store->type == AT_IPv6)
+ {
+ g_snprintf(field[0], 40, "%s", ip6_to_str((const struct e_in6_addr *)(store->data)));
+ }
+ list_store = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW (u_data->analyse_nb->page3->clist))); /* Get store */
+
+ gtk_list_store_insert_with_values( list_store , &iter, G_MAXINT,
+ 0, field[0], -1);
+ list = g_list_next(list);
+ }
+ }
+ else
+ {
+ return;
+ }
+
+ g_snprintf(label_txt, sizeof(label_txt),"Port: %u",u_data->assoc->port2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->port), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Sent Verification Tag: 0x%x",u_data->assoc->verification_tag2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->veritag), label_txt);
+
+ if (u_data->assoc->initack == TRUE)
+ {
+ g_snprintf(label_txt, sizeof(label_txt),"Requested Number of Inbound Streams: %u",u_data->assoc->instream2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->max_in), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Minimum Number of Inbound Streams: %u",((u_data->assoc->instream2>u_data->assoc->outstream1)?u_data->assoc->outstream1:u_data->assoc->instream2));
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->min_in), label_txt);
+
+ g_snprintf(label_txt, sizeof(label_txt),"Provided Number of Outbound Streams: %u",u_data->assoc->outstream2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->max_out), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Minimum Number of Outbound Streams: %u",((u_data->assoc->outstream2>u_data->assoc->instream1)?u_data->assoc->instream1:u_data->assoc->outstream2));
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->min_out), label_txt);
+ }
+ else
+ {
+ g_snprintf(label_txt, sizeof(label_txt),"Used Number of Inbound Streams: %u",u_data->assoc->instream2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->max_in), label_txt);
+ g_snprintf(label_txt, sizeof(label_txt),"Used Number of Outbound Streams: %u",u_data->assoc->outstream2);
+ gtk_label_set_text(GTK_LABEL(u_data->analyse_nb->page3->min_out), label_txt);
+ }
+}
+
+
+static void
+sctp_set_filter (GtkButton *button _U_, struct sctp_analyse* u_data)
+{
+ gchar *f_string = NULL;
+ GList *srclist, *dstlist;
+ gchar *str=NULL;
+ GString *gstring=NULL;
+ struct sockaddr_in *infosrc=NULL;
+ struct sockaddr_in *infodst=NULL;
+ sctp_assoc_info_t *selected_stream;
+ gchar *filter_string = NULL;
+ selected_stream=u_data->assoc;
+
+ if (selected_stream->check_address==FALSE)
+ {
+ f_string = g_strdup_printf("((sctp.srcport==%u && sctp.dstport==%u && ((sctp.verification_tag==0x%x && sctp.verification_tag!=0x0) || "
+ "(sctp.verification_tag==0x0 && sctp.initiate_tag==0x%x) || "
+ "(sctp.verification_tag==0x%x && (sctp.abort_t_bit==1 || sctp.shutdown_complete_t_bit==1)))) ||"
+ "(sctp.srcport==%u && sctp.dstport==%u && ((sctp.verification_tag==0x%x && sctp.verification_tag!=0x0) || "
+ "(sctp.verification_tag==0x0 && sctp.initiate_tag==0x%x) ||"
+ "(sctp.verification_tag==0x%x && (sctp.abort_t_bit==1 || sctp.shutdown_complete_t_bit==1)))))",
+ selected_stream->port1,
+ selected_stream->port2,
+ selected_stream->verification_tag1,
+ selected_stream->initiate_tag,
+ selected_stream->verification_tag2,
+ selected_stream->port2,
+ selected_stream->port1,
+ selected_stream->verification_tag2,
+ selected_stream->initiate_tag,
+ selected_stream->verification_tag1);
+ filter_string = f_string;
+ }
+ else
+ {
+ srclist = g_list_first(selected_stream->addr1);
+ infosrc=(struct sockaddr_in *) (srclist->data);
+ gstring = g_string_new(g_strdup_printf("((sctp.srcport==%u && sctp.dstport==%u && (ip.src==%s",
+ selected_stream->port1, selected_stream->port2, ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr))));
+ srclist= g_list_next(srclist);
+
+ while (srclist)
+ {
+ infosrc=(struct sockaddr_in *) (srclist->data);
+ str =g_strdup_printf("|| ip.src==%s",ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr)));
+ g_string_append(gstring, str);
+ srclist= g_list_next(srclist);
+ }
+
+ dstlist = g_list_first(selected_stream->addr2);
+ infodst=(struct sockaddr_in *) (dstlist->data);
+ str = g_strdup_printf(") && (ip.dst==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
+ g_string_append(gstring, str);
+ dstlist= g_list_next(dstlist);
+ while (dstlist)
+ {
+ infodst=(struct sockaddr_in *) (dstlist->data);
+ str =g_strdup_printf("|| ip.dst==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
+ g_string_append(gstring, str);
+ dstlist= g_list_next(dstlist);
+ }
+
+ srclist = g_list_first(selected_stream->addr1);
+ infosrc=(struct sockaddr_in *) (srclist->data);
+ str = g_strdup_printf(")) || (sctp.dstport==%u && sctp.srcport==%u && (ip.dst==%s",
+ selected_stream->port1, selected_stream->port2, ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr)));
+ g_string_append(gstring, str);
+ srclist= g_list_next(srclist);
+
+ while (srclist)
+ {
+ infosrc=(struct sockaddr_in *) (srclist->data);
+ str =g_strdup_printf("|| ip.dst==%s",ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr)));
+ g_string_append(gstring, str);
+ srclist= g_list_next(srclist);
+ }
+
+ dstlist = g_list_first(selected_stream->addr2);
+ infodst=(struct sockaddr_in *) (dstlist->data);
+ str = g_strdup_printf(") && (ip.src==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
+ g_string_append(gstring, str);
+ dstlist= g_list_next(dstlist);
+ while (dstlist)
+ {
+ infodst=(struct sockaddr_in *) (dstlist->data);
+ str =g_strdup_printf("|| ip.src==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
+ g_string_append(gstring, str);
+ dstlist= g_list_next(dstlist);
+ }
+ str = g_strdup_printf(")))");
+ g_string_append(gstring, str);
+ filter_string = gstring->str;
+ g_string_free(gstring,FALSE);
+ }
+
+ if (filter_string != NULL) {
+ gtk_entry_set_text(GTK_ENTRY(main_display_filter_widget), filter_string);
+ } else {
+ g_assert_not_reached();
+ }
+}
+
+static void analyse_window_set_title(struct sctp_analyse *u_data)
+{
+ char *title;
+
+ if(!u_data->window){
+ return;
+ }
+ title = g_strdup_printf("SCTP Analyse Association: %s Port1 %u Port2 %u", cf_get_display_name(&cfile), u_data->assoc->port1, u_data->assoc->port2);
+ gtk_window_set_title(GTK_WINDOW(u_data->window), title);
+ g_free(title);
+}
+
+static
+GtkWidget *create_list(void)
+{
+ GtkListStore *list_store;
+ GtkWidget * list;
+ GtkTreeViewColumn *column;
+ GtkCellRenderer *renderer;
+ GtkTreeView *list_view;
+ list_store = gtk_list_store_new(1,
+ G_TYPE_STRING /* IP address */
+ );
+
+ /* Create a view */
+ list = gtk_tree_view_new_with_model (GTK_TREE_MODEL (list_store));
+
+ list_view = GTK_TREE_VIEW(list);
+
+ /* Speed up the list display */
+ gtk_tree_view_set_fixed_height_mode(list_view, TRUE);
+
+ /* The view now holds a reference. We can get rid of our own reference */
+ g_object_unref (G_OBJECT (list_store));
+
+ /*
+ * Create the first column packet, associating the "text" attribute of the
+ * cell_renderer to the first column of the model
+ */
+ renderer = gtk_cell_renderer_text_new ();
+ column = gtk_tree_view_column_new_with_attributes ("Address", renderer,
+ "text", 0,
+ NULL);
+
+ gtk_tree_view_column_set_resizable(column, TRUE);
+ gtk_tree_view_column_set_sizing(column, GTK_TREE_VIEW_COLUMN_FIXED);
+ gtk_tree_view_column_set_min_width(column, 300);
+
+ /* Add the column to the view. */
+ gtk_tree_view_append_column (list_view, column);
+
+ gtk_tree_view_set_headers_visible(list_view, FALSE);
+ return list;
+}
+
+static void create_analyse_window(struct sctp_analyse* u_data)
+{
+ GtkWidget *window = NULL;
+ GtkWidget *notebook;
+ GtkWidget *main_vb, *page1, *page2, *page3, *hbox, *vbox_l, *vbox_r, *addr_hb, *stat_fr;
+ GtkWidget *hbox_l1, *hbox_l2,*label, *h_button_box;
+ GtkWidget *chunk_stat_bt, *close_bt, *graph_bt1, *graph_bt2, *chunk_bt1, *bt_filter;
+
+ u_data->analyse_nb = g_malloc(sizeof(struct notes));
+ window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_CENTER);
+ g_signal_connect(window, "destroy", G_CALLBACK(on_destroy), u_data);
+
+ /* Container for each row of widgets */
+ main_vb = gtk_vbox_new(FALSE, 2);
+ gtk_container_set_border_width(GTK_CONTAINER(main_vb), 2);
+ gtk_container_add(GTK_CONTAINER(window), main_vb);
+ gtk_widget_show(main_vb);
+
+ /* Start a notebook for flipping between sets of changes */
+ notebook = gtk_notebook_new();
+ gtk_container_add(GTK_CONTAINER(main_vb), notebook);
+ g_object_set_data(G_OBJECT(window), "notebook", notebook);
+ g_signal_connect(notebook, "switch_page", G_CALLBACK(on_notebook_switch_page), NULL);
+
+ page1 = gtk_vbox_new(FALSE, 8);
+ gtk_container_set_border_width(GTK_CONTAINER(page1), 8);
+
+ u_data->analyse_nb->checktype = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->checktype, TRUE, TRUE, 0);
+
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->checktype),0,0);
+
+ u_data->analyse_nb->checksum = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->checksum, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->checksum),0,0);
+
+ u_data->analyse_nb->bundling = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->bundling, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->bundling),0,0);
+
+ u_data->analyse_nb->padding = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->padding, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->padding),0,0);
+
+ u_data->analyse_nb->length = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->length, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->length),0,0);
+
+ u_data->analyse_nb->value = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->value, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->value),0,0);
+
+
+ u_data->analyse_nb->chunks_ep1 = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->chunks_ep1, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->chunks_ep1),0,0);
+ u_data->analyse_nb->bytes_ep1 = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->bytes_ep1, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->bytes_ep1),0,0);
+ u_data->analyse_nb->chunks_ep2 = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->chunks_ep2, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->chunks_ep2),0,0);
+ u_data->analyse_nb->bytes_ep2 = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(page1), u_data->analyse_nb->bytes_ep2, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->bytes_ep2),0,0);
+
+ hbox = gtk_hbutton_box_new();
+ gtk_box_pack_start(GTK_BOX(page1), hbox, FALSE, FALSE, 0);
+ gtk_container_set_border_width(GTK_CONTAINER(hbox), 10);
+ gtk_button_box_set_layout(GTK_BUTTON_BOX (hbox), GTK_BUTTONBOX_SPREAD);
+ gtk_box_set_spacing(GTK_BOX (hbox), 0);
+ gtk_widget_show(hbox);
+
+ chunk_stat_bt = gtk_button_new_with_label ("Chunk Statistics");
+ gtk_box_pack_start(GTK_BOX(hbox), chunk_stat_bt, FALSE, FALSE, 0);
+ gtk_widget_show(chunk_stat_bt);
+ g_signal_connect(chunk_stat_bt, "clicked", G_CALLBACK(on_chunk_stat_bt), u_data);
+
+ bt_filter = gtk_button_new_with_label ("Set filter");
+ gtk_box_pack_start(GTK_BOX(hbox), bt_filter, FALSE, FALSE, 0);
+ gtk_widget_show (bt_filter);
+ g_signal_connect(bt_filter, "clicked", G_CALLBACK(sctp_set_filter), u_data);
+
+ close_bt = gtk_button_new_from_stock(GTK_STOCK_CLOSE);
+ gtk_box_pack_start(GTK_BOX(hbox), close_bt, FALSE, FALSE, 0);
+ gtk_widget_show(close_bt);
+ g_signal_connect(close_bt, "clicked", G_CALLBACK(on_close_dlg), u_data);
+
+ /* tab */
+ label = gtk_label_new(" Statistics ");
+ gtk_notebook_append_page(GTK_NOTEBOOK(notebook), page1, label);
+
+
+ /* page for endpoint 1 */
+ page2 = gtk_vbox_new(FALSE, 8);
+ gtk_container_set_border_width(GTK_CONTAINER(page2), 8);
+
+ u_data->analyse_nb->page2 = g_malloc(sizeof(struct page));
+
+ u_data->analyse_nb->page2->addr_frame = gtk_frame_new(NULL);
+ gtk_container_add(GTK_CONTAINER(page2), u_data->analyse_nb->page2->addr_frame);
+
+ addr_hb = gtk_hbox_new(FALSE, 3);
+ gtk_container_set_border_width(GTK_CONTAINER(addr_hb), 5);
+ gtk_container_add(GTK_CONTAINER(u_data->analyse_nb->page2->addr_frame), addr_hb);
+
+ u_data->analyse_nb->page2->scrolled_window = scrolled_window_new(NULL, NULL);
+ gtk_widget_set_size_request(u_data->analyse_nb->page2->scrolled_window, 560, 100);
+
+ u_data->analyse_nb->page2->clist = create_list();
+ gtk_widget_show(u_data->analyse_nb->page2->clist);
+
+ gtk_container_add(GTK_CONTAINER(u_data->analyse_nb->page2->scrolled_window), u_data->analyse_nb->page2->clist);
+
+ gtk_box_pack_start(GTK_BOX(addr_hb), u_data->analyse_nb->page2->scrolled_window, TRUE, TRUE, 0);
+ gtk_widget_show(u_data->analyse_nb->page2->scrolled_window);
+
+ stat_fr = gtk_frame_new(NULL);
+ gtk_container_add(GTK_CONTAINER(page2), stat_fr);
+
+ hbox = gtk_hbox_new(FALSE,3);
+ gtk_container_set_border_width(GTK_CONTAINER(hbox), 5);
+ gtk_container_add(GTK_CONTAINER(stat_fr), hbox);
+
+ vbox_l = gtk_vbox_new(FALSE, 3);
+ gtk_box_pack_start(GTK_BOX(hbox), vbox_l, TRUE, TRUE, 0);
+
+
+
+ hbox_l1 = gtk_hbox_new(FALSE,3);
+ gtk_box_pack_start(GTK_BOX(vbox_l), hbox_l1, TRUE, TRUE, 0);
+
+ u_data->analyse_nb->page2->port = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(hbox_l1), u_data->analyse_nb->page2->port, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page2->port),0,0);
+
+ hbox_l2 = gtk_hbox_new(FALSE,3);
+ gtk_box_pack_start(GTK_BOX(vbox_l), hbox_l2, TRUE, TRUE, 0);
+
+
+ u_data->analyse_nb->page2->veritag = gtk_label_new("");
+
+ gtk_box_pack_start(GTK_BOX(hbox_l2), u_data->analyse_nb->page2->veritag, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page2->veritag),0,0);
+ gtk_widget_show(vbox_l);
+
+ vbox_r = gtk_vbox_new(FALSE, 3);
+ gtk_box_pack_start(GTK_BOX(hbox), vbox_r, TRUE, TRUE, 0);
+
+ u_data->analyse_nb->page2->max_in = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page2->max_in, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page2->max_in),0,0);
+ u_data->analyse_nb->page2->min_in = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page2->min_in, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page2->min_in),0,0);
+
+ u_data->analyse_nb->page2->max_out = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page2->max_out, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page2->max_out),0,0);
+ u_data->analyse_nb->page2->min_out = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page2->min_out, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page2->min_out),0,0);
+
+
+ gtk_widget_show(vbox_r);
+
+ h_button_box=gtk_hbutton_box_new();
+ gtk_box_pack_start(GTK_BOX(page2), h_button_box, FALSE, FALSE, 0);
+ gtk_container_set_border_width(GTK_CONTAINER(h_button_box), 10);
+ gtk_button_box_set_layout(GTK_BUTTON_BOX (h_button_box), GTK_BUTTONBOX_SPREAD);
+ gtk_box_set_spacing(GTK_BOX (h_button_box), 0);
+ gtk_widget_show(h_button_box);
+
+ chunk_bt1 = gtk_button_new_with_label("Chunk Statistics");
+ gtk_box_pack_start(GTK_BOX(h_button_box), chunk_bt1, FALSE, FALSE, 0);
+ gtk_widget_show(chunk_bt1);
+ g_signal_connect(chunk_bt1, "clicked", G_CALLBACK(on_chunk1_dlg), u_data);
+
+ graph_bt1 = gtk_button_new_with_label("Graph TSN");
+ gtk_box_pack_start(GTK_BOX(h_button_box), graph_bt1, FALSE, FALSE, 0);
+ gtk_widget_show(graph_bt1);
+ g_signal_connect(graph_bt1, "clicked", G_CALLBACK(on_graph1_dlg), u_data);
+
+ graph_bt2 = gtk_button_new_with_label("Graph Bytes");
+ gtk_box_pack_start(GTK_BOX(h_button_box), graph_bt2, FALSE, FALSE, 0);
+ gtk_widget_show(graph_bt2);
+ g_signal_connect(graph_bt2, "clicked", G_CALLBACK(on_graph_byte1_dlg), u_data);
+ if (u_data->assoc->n_array_tsn1==0)
+ {
+ gtk_widget_set_sensitive(graph_bt1, FALSE);
+ gtk_widget_set_sensitive(graph_bt2, FALSE);
+ }
+ close_bt = gtk_button_new_from_stock(GTK_STOCK_CLOSE);
+ gtk_box_pack_start(GTK_BOX(h_button_box), close_bt, FALSE, FALSE, 0);
+ gtk_widget_show(close_bt);
+ g_signal_connect(close_bt, "clicked", G_CALLBACK(on_close_dlg), u_data);
+
+ label = gtk_label_new(" Endpoint 1 ");
+ gtk_notebook_append_page(GTK_NOTEBOOK(notebook), page2, label);
+
+ /* same page for endpoint 2*/
+
+ page3 = gtk_vbox_new(FALSE, 8);
+ gtk_container_set_border_width(GTK_CONTAINER(page3), 8);
+ u_data->analyse_nb->page3 = g_malloc(sizeof(struct page));
+ u_data->analyse_nb->page3->addr_frame = gtk_frame_new(NULL);
+
+ gtk_container_add(GTK_CONTAINER(page3), u_data->analyse_nb->page3->addr_frame);
+
+ addr_hb = gtk_hbox_new(FALSE, 3);
+ gtk_container_set_border_width(GTK_CONTAINER(addr_hb), 5);
+ gtk_container_add(GTK_CONTAINER(u_data->analyse_nb->page3->addr_frame), addr_hb);
+
+ u_data->analyse_nb->page3->scrolled_window = scrolled_window_new(NULL, NULL);
+ gtk_widget_set_size_request(u_data->analyse_nb->page3->scrolled_window, 560, 100);
+
+ u_data->analyse_nb->page3->clist = create_list();
+ gtk_widget_show(u_data->analyse_nb->page3->clist);
+
+ gtk_container_add(GTK_CONTAINER(u_data->analyse_nb->page3->scrolled_window),
+ u_data->analyse_nb->page3->clist);
+
+ gtk_box_pack_start(GTK_BOX(addr_hb), u_data->analyse_nb->page3->scrolled_window, TRUE, TRUE, 0);
+ gtk_widget_show(u_data->analyse_nb->page3->scrolled_window);
+
+ stat_fr = gtk_frame_new(NULL);
+ gtk_container_add(GTK_CONTAINER(page3), stat_fr);
+
+ hbox = gtk_hbox_new(FALSE,3);
+ gtk_container_set_border_width(GTK_CONTAINER(hbox), 5);
+ gtk_container_add(GTK_CONTAINER(stat_fr), hbox);
+
+ vbox_l = gtk_vbox_new(FALSE, 3);
+ gtk_box_pack_start(GTK_BOX(hbox), vbox_l, TRUE, TRUE, 0);
+
+ hbox_l1 = gtk_hbox_new(FALSE,3);
+ gtk_box_pack_start(GTK_BOX(vbox_l), hbox_l1, TRUE, TRUE, 0);
+
+ u_data->analyse_nb->page3->port = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(hbox_l1), u_data->analyse_nb->page3->port, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page3->port),0,0);
+
+ hbox_l2 = gtk_hbox_new(FALSE,3);
+ gtk_box_pack_start(GTK_BOX(vbox_l), hbox_l2, TRUE, TRUE, 0);
+
+
+ u_data->analyse_nb->page3->veritag = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(hbox_l2), u_data->analyse_nb->page3->veritag, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page3->veritag),0,0);
+ gtk_widget_show(vbox_l);
+
+ vbox_r=gtk_vbox_new(FALSE, 3);
+ gtk_box_pack_start(GTK_BOX(hbox), vbox_r, TRUE, TRUE, 0);
+
+ u_data->analyse_nb->page3->max_in = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page3->max_in, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page3->max_in),0,0);
+ u_data->analyse_nb->page3->min_in = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page3->min_in, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page3->min_in),0,0);
+
+ u_data->analyse_nb->page3->max_out = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page3->max_out, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page3->max_out),0,0);
+ u_data->analyse_nb->page3->min_out = gtk_label_new("");
+ gtk_box_pack_start(GTK_BOX(vbox_r), u_data->analyse_nb->page3->min_out, TRUE, TRUE, 0);
+ gtk_misc_set_alignment (GTK_MISC(u_data->analyse_nb->page3->min_out),0,0);
+
+ gtk_widget_show(vbox_r);
+
+ h_button_box=gtk_hbutton_box_new();
+ gtk_box_pack_start(GTK_BOX(page3), h_button_box, FALSE, FALSE, 0);
+ gtk_container_set_border_width(GTK_CONTAINER(h_button_box), 10);
+ gtk_button_box_set_layout(GTK_BUTTON_BOX (h_button_box), GTK_BUTTONBOX_SPREAD);
+ gtk_box_set_spacing(GTK_BOX (h_button_box), 0);
+ gtk_widget_show(h_button_box);
+
+ chunk_bt1 = gtk_button_new_with_label("Chunk Statistics");
+ gtk_box_pack_start(GTK_BOX(h_button_box), chunk_bt1, FALSE, FALSE, 0);
+ gtk_widget_show(chunk_bt1);
+ g_signal_connect(chunk_bt1, "clicked", G_CALLBACK(on_chunk2_dlg), u_data);
+
+ graph_bt1 = gtk_button_new_with_label("Graph TSN");
+ gtk_box_pack_start(GTK_BOX(h_button_box), graph_bt1, FALSE, FALSE, 0);
+ gtk_widget_show(graph_bt1);
+ g_signal_connect(graph_bt1, "clicked", G_CALLBACK(on_graph2_dlg), u_data);
+ graph_bt2 = gtk_button_new_with_label("Graph Bytes");
+ gtk_box_pack_start(GTK_BOX(h_button_box), graph_bt2, FALSE, FALSE, 0);
+ gtk_widget_show(graph_bt2);
+ g_signal_connect(graph_bt2, "clicked", G_CALLBACK(on_graph_byte2_dlg), u_data);
+ if (u_data->assoc->n_array_tsn2==0)
+ {
+ gtk_widget_set_sensitive(graph_bt1, FALSE);
+ gtk_widget_set_sensitive(graph_bt2, FALSE);
+ }
+ close_bt = gtk_button_new_from_stock(GTK_STOCK_CLOSE);
+ gtk_box_pack_start(GTK_BOX(h_button_box), close_bt, FALSE, FALSE, 0);
+ gtk_widget_show(close_bt);
+ g_signal_connect(close_bt, "clicked", G_CALLBACK(on_close_dlg), u_data);
+
+ label = gtk_label_new(" Endpoint 2 ");
+ gtk_notebook_append_page(GTK_NOTEBOOK(notebook), page3, label);
+
+ /* show all notebooks */
+ gtk_widget_show_all(notebook);
+
+ gtk_widget_show(window);
+
+ u_data->window = window;
+ analyse_window_set_title(u_data);
+
+ update_analyse_dlg(u_data);
+}
+
+
+
+void assoc_analyse(sctp_assoc_info_t* assoc)
+{
+ struct sctp_analyse* u_data;
+ int i;
+
+ u_data = g_malloc(sizeof(struct sctp_analyse));
+ u_data->assoc = assoc;
+ u_data->assoc->addr_chunk_count = assoc->addr_chunk_count;
+ u_data->window = NULL;
+ u_data->analyse_nb = NULL;
+ u_data->children = NULL;
+ u_data->num_children = 0;
+ static_assoc.addr_chunk_count =assoc->addr_chunk_count;
+ static_assoc.port1 = assoc->port1;
+ static_assoc.port2 = assoc->port2;
+ for (i=0; i<NUM_CHUNKS; i++)
+ {
+ static_assoc.chunk_count[i] = assoc->chunk_count[i];
+ static_assoc.ep1_chunk_count[i] = assoc->ep1_chunk_count[i];
+ static_assoc.ep2_chunk_count[i] = assoc->ep2_chunk_count[i];
+ }
+ set_analyse_child(u_data);
+ increase_analyse_childcount();
+ static_assoc.addr_chunk_count = assoc->addr_chunk_count;
+ create_analyse_window(u_data);
+}
+
+
+static void sctp_analyse_cb(struct sctp_analyse* u_data, gboolean ext)
+{
+ GList *list, *framelist;
+ dfilter_t *sfcode;
+ capture_file *cf;
+ epan_dissect_t edt;
+ gboolean frame_matched, frame_found = FALSE;
+ frame_data *fdata;
+ gchar filter_text[256];
+ sctp_assoc_info_t* assoc = NULL;
+ int i;
+ guint32 *fn;
+
+ g_strlcpy(filter_text,"sctp",250);
+ if (!dfilter_compile(filter_text, &sfcode)) {
+ simple_dialog(ESD_TYPE_ERROR, ESD_BTN_OK, "%s", dfilter_error_msg);
+ return;
+ }
+
+ cf = &cfile;
+ fdata = cf->current_frame;
+
+ /* we are on the selected frame now */
+ if (fdata == NULL)
+ return; /* if we exit here it's an error */
+
+ /* dissect the current frame */
+ if (!cf_read_frame(cf, fdata))
+ return; /* error reading the frame */
+
+ epan_dissect_init(&edt, TRUE, FALSE);
+ epan_dissect_prime_dfilter(&edt, sfcode);
+ epan_dissect_run(&edt, &cf->pseudo_header, cf->pd, fdata, NULL);
+ frame_matched = dfilter_apply_edt(sfcode, &edt);
+
+ /* if it is not an sctp frame, show the dialog */
+
+ if (frame_matched != 1) {
+ epan_dissect_cleanup(&edt);
+ simple_dialog(ESD_TYPE_ERROR, ESD_BTN_OK,
+ "Please choose an SCTP packet!");
+ return;
+ }
+
+ list = g_list_first(sctp_stat_get_info()->assoc_info_list);
+
+ while (list)
+ {
+ assoc = (sctp_assoc_info_t*)(list->data);
+ framelist = g_list_first(assoc->frame_numbers);
+ while(framelist)
+ {
+ fn = (guint32 *)framelist->data;
+ if (*fn == fdata->num)
+ {
+ frame_found = TRUE;
+ break;
+ }
+ framelist = g_list_next(framelist);
+ }
+ if (frame_found)
+ {
+ u_data->assoc = assoc;
+ u_data->assoc->addr_chunk_count = assoc->addr_chunk_count;
+ static_assoc.addr_chunk_count = assoc->addr_chunk_count;
+ static_assoc.port1 = assoc->port1;
+ static_assoc.port2 = assoc->port2;
+ for (i=0; i<NUM_CHUNKS; i++)
+ {
+ static_assoc.chunk_count[i] = assoc->chunk_count[i];
+ static_assoc.ep1_chunk_count[i] = assoc->ep1_chunk_count[i];
+ static_assoc.ep2_chunk_count[i] = assoc->ep2_chunk_count[i];
+ }
+ if (ext == FALSE)
+ create_analyse_window(u_data);
+ return;
+ }
+ else
+ list = g_list_next(list);
+
+ }
+ if (!frame_found)
+ simple_dialog(ESD_TYPE_ERROR, ESD_BTN_OK, "Assoc not found!");
+}
+
+void sctp_set_assoc_filter(void)
+{
+struct sctp_analyse * u_data;
+
+ /* Register the tap listener */
+ if (sctp_stat_get_info()->is_registered == FALSE)
+ register_tap_listener_sctp_stat();
+ /* (redissect all packets) */
+
+ sctp_stat_scan();
+ u_data = g_malloc(sizeof(struct sctp_analyse));
+ u_data->assoc = NULL;
+ u_data->children = NULL;
+ u_data->analyse_nb = NULL;
+ u_data->window = NULL;
+ u_data->num_children = 0;
+ cf_retap_packets(&cfile);
+ sctp_analyse_cb(u_data, TRUE);
+ sctp_set_filter(NULL, u_data);
+}
+
+void sctp_analyse_start(GtkAction *action _U_, gpointer user_data _U_)
+{
+ struct sctp_analyse * u_data;
+
+ /* Register the tap listener */
+ if (sctp_stat_get_info()->is_registered == FALSE)
+ register_tap_listener_sctp_stat();
+ /* (redissect all packets) */
+
+ sctp_stat_scan();
+
+ u_data = g_malloc(sizeof(struct sctp_analyse));
+ u_data->assoc = NULL;
+ u_data->children = NULL;
+ u_data->analyse_nb = NULL;
+ u_data->window = NULL;
+ u_data->num_children = 0;
+
+ cf_retap_packets(&cfile);
+ sctp_analyse_cb(u_data, FALSE);
+}
+
+
+void
+register_tap_listener_sctp_analyse(void)
+{
+}
+