2 * Copyright 2004, Irene Ruengeler <i.ruengeler [AT] fh-muenster.de>
6 * Wireshark - Network traffic analyzer
7 * By Gerald Combs <gerald@wireshark.org>
8 * Copyright 1998 Gerald Combs
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License
12 * as published by the Free Software Foundation; either version 2
13 * of the License, or (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
35 #include "epan/filesystem.h"
36 #include <epan/strutil.h>
38 #include "../globals.h"
40 #include "../ui_util.h"
41 #include "../simple_dialog.h"
43 #include "gtk/dlg_utils.h"
45 #include "gtk/sctp_stat.h"
48 #define DEFAULT_PIXELS_PER_TICK 2
49 #define MAX_PIXELS_PER_TICK 4
50 #define AUTO_MAX_YSCALE 0
51 #define MAX_TICK_VALUES 5
52 #define DEFAULT_TICK_VALUE 3
54 #define MAX_COUNT_TYPES 3
56 #define COUNT_TYPE_FRAMES 0
57 #define COUNT_TYPE_BYTES 1
58 #define COUNT_TYPE_ADVANCED 2
60 #define LEFT_BORDER 80
61 #define RIGHT_BORDER 10
63 #define BOTTOM_BORDER 50
65 #define SUB_32(a, b) a-b
73 struct data_chunk_header {
83 struct init_chunk_header {
94 struct sack_chunk_header {
110 static gboolean label_set = FALSE;
111 static guint32 max_tsn=0, min_tsn=0;
114 static void sctp_graph_set_title(struct sctp_udata *u_data);
115 static void create_draw_area(GtkWidget *box, struct sctp_udata *u_data);
116 static GtkWidget *zoomout_bt;
118 static void draw_sack_graph(struct sctp_udata *u_data)
120 GdkColor red_color = {0, 65535, 0, 0};
121 GdkColor green_color = {0, 0, 65535, 0};
122 GdkGC *red_gc, *green_gc;
124 GPtrArray *array = NULL;
125 guint32 i, size = 0, start=0, end;
126 gboolean more = FALSE;
129 red_gc = gdk_gc_new(u_data->io->draw_area->window);
130 gdk_gc_set_rgb_fg_color(red_gc, &red_color);
132 green_gc = gdk_gc_new(u_data->io->draw_area->window);
133 gdk_gc_set_rgb_fg_color(green_gc, &green_color);
135 if (u_data->dir == 1)
137 array = u_data->assoc->sort_sack1;
138 size=u_data->assoc->n_sack_chunks_ep1;
139 if (u_data->io->tmp == FALSE)
142 max_tsn = u_data->assoc->max_bytes1;
146 min_tsn = u_data->io->tmp_min_tsn1;
147 max_tsn = u_data->io->tmp_max_tsn1;
150 else if (u_data->dir == 2)
152 array = u_data->assoc->sort_sack2;
153 size = u_data->assoc->n_sack_chunks_ep2;
154 if (u_data->io->tmp == FALSE)
157 max_tsn = u_data->assoc->max_bytes2;
161 min_tsn = u_data->io->tmp_min_tsn2;
162 max_tsn = u_data->io->tmp_max_tsn2;
166 width = u_data->io->max_x - u_data->io->min_x;
168 for (i=0; i<size; i++)
170 if (u_data->io->uoff)
171 diff = (gint)((struct tsn_sort*)(g_ptr_array_index(array, i)))->secs - u_data->io->min_x;
173 diff = (gint)((struct tsn_sort*)(g_ptr_array_index(array, i)))->secs * 1000000 + ((struct tsn_sort*)(g_ptr_array_index(array, i)))->usecs - u_data->io->min_x;
174 end = start + ((struct tsn_sort*)(g_ptr_array_index(array, i)))->length;
181 if (start >= min_tsn && diff > 0 && diff <= width)
183 gdk_draw_line(u_data->io->pixmap,red_gc,
184 (guint32)(LEFT_BORDER+u_data->io->offset+u_data->io->x_interval*diff),
185 (guint32)(u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-((SUB_32(start,min_tsn))*u_data->io->y_interval)),
186 (guint32)(LEFT_BORDER+u_data->io->offset+u_data->io->x_interval*diff),
187 (guint32)(u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-((SUB_32(end,min_tsn))*u_data->io->y_interval)));
190 gdk_draw_line(u_data->io->pixmap,green_gc,
191 (guint32)(LEFT_BORDER+u_data->io->offset+u_data->io->x_interval*diff),
192 (guint32)(u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-((SUB_32(end,min_tsn))*u_data->io->y_interval)),
193 (guint32)(LEFT_BORDER+u_data->io->offset+u_data->io->x_interval*diff),
194 (guint32)(u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-((SUB_32(end+10,min_tsn))*u_data->io->y_interval)));
200 g_object_unref(G_OBJECT(red_gc));
201 g_object_unref(G_OBJECT(green_gc));
205 static void draw_tsn_graph(struct sctp_udata *u_data)
207 GPtrArray *array = NULL;
208 guint32 i, size = 0, start, end;
211 if (u_data->dir == 1)
213 array = u_data->assoc->sort_tsn1;
214 size = u_data->assoc->n_data_chunks_ep1;
215 if (u_data->io->tmp == FALSE)
218 max_tsn = u_data->assoc->max_bytes1;
222 min_tsn = u_data->io->tmp_min_tsn1;
223 max_tsn = u_data->io->tmp_max_tsn1;
226 else if (u_data->dir == 2)
228 array = u_data->assoc->sort_tsn2;
229 size = u_data->assoc->n_data_chunks_ep2;
230 if (u_data->io->tmp == FALSE)
233 max_tsn = u_data->assoc->max_bytes2;
237 min_tsn = u_data->io->tmp_min_tsn2;
238 max_tsn = u_data->io->tmp_max_tsn2;
241 width = u_data->io->max_x - u_data->io->min_x;
243 for (i=0; i<size; i++)
245 if (u_data->io->uoff)
246 diff = (gint)((struct tsn_sort*)(g_ptr_array_index(array, i)))->secs -u_data->io->min_x;
248 diff = (gint)((struct tsn_sort*)(g_ptr_array_index(array, i)))->secs*1000000 + ((struct tsn_sort*)(g_ptr_array_index(array, i)))->usecs-u_data->io->min_x;
249 start = ((struct tsn_sort*)(g_ptr_array_index(array, i)))->offset;
250 end = start + ((struct tsn_sort*)(g_ptr_array_index(array, i)))->length;
251 if (start >= min_tsn && diff > 0 && diff <= width)
252 gdk_draw_line(u_data->io->pixmap,
253 u_data->io->draw_area->style->black_gc,
254 (guint32)(LEFT_BORDER+u_data->io->offset+u_data->io->x_interval*diff),
255 (guint32)(u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-((SUB_32(start,min_tsn))*u_data->io->y_interval)),
256 (guint32)(LEFT_BORDER+u_data->io->offset+u_data->io->x_interval*diff),
257 (guint32)(u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-((SUB_32(end,min_tsn))*u_data->io->y_interval)));
263 static void sctp_graph_draw(struct sctp_udata *u_data)
266 guint32 distance=5, i, e, sec, w, start, a, j, b;
267 gint label_width, label_height;
268 char label_string[15];
270 gboolean write_label = FALSE;
273 if (u_data->io->x1_tmp_sec == 0 && u_data->io->x1_tmp_usec == 0)
274 u_data->io->offset = 0;
276 u_data->io->offset = 5;
278 if (u_data->io->x2_tmp_sec - u_data->io->x1_tmp_sec > 1500)
280 u_data->io->min_x=u_data->io->x1_tmp_sec;
281 u_data->io->max_x=u_data->io->x2_tmp_sec;
282 u_data->io->uoff = TRUE;
286 u_data->io->min_x=((guint32) (u_data->io->x1_tmp_sec*1000000.0))+u_data->io->x1_tmp_usec;
287 u_data->io->max_x=((guint32) (u_data->io->x2_tmp_sec*1000000.0))+u_data->io->x2_tmp_usec;
288 u_data->io->uoff = FALSE;
291 u_data->io->tmp_width = u_data->io->max_x - u_data->io->min_x;
293 if (u_data->dir == 1)
295 if (u_data->io->tmp == FALSE)
297 if (u_data->assoc->sort_tsn1 != NULL)
298 u_data->io->max_y = u_data->io->tmp_max_tsn1 - u_data->io->tmp_min_tsn1;
300 u_data->io->max_y = 0;
301 u_data->io->min_y = 0;
305 u_data->io->max_y = u_data->io->tmp_max_tsn1;
306 u_data->io->min_y = u_data->io->tmp_min_tsn1;
309 else if (u_data->dir == 2)
311 if (u_data->io->tmp == FALSE)
313 if (u_data->assoc->tsn2 != NULL)
314 u_data->io->max_y = u_data->io->tmp_max_tsn2 - u_data->io->tmp_min_tsn2;
316 u_data->io->max_y = 0;
317 u_data->io->min_y = 0;
321 u_data->io->max_y = u_data->io->tmp_max_tsn2;
322 u_data->io->min_y = u_data->io->tmp_min_tsn2;
325 gdk_draw_rectangle(u_data->io->pixmap, u_data->io->draw_area->style->white_gc,
326 TRUE, 0, 0, u_data->io->draw_area->allocation.width,
327 u_data->io->draw_area->allocation.height);
331 gdk_draw_line(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
332 LEFT_BORDER+u_data->io->offset,u_data->io->pixmap_height - BOTTOM_BORDER,
333 u_data->io->pixmap_width - RIGHT_BORDER + u_data->io->offset, u_data->io->pixmap_height - BOTTOM_BORDER);
334 gdk_draw_line(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
335 u_data->io->pixmap_width - RIGHT_BORDER + u_data->io->offset, u_data->io->pixmap_height - BOTTOM_BORDER, u_data->io->pixmap_width - RIGHT_BORDER + u_data->io->offset - 5, u_data->io->pixmap_height - BOTTOM_BORDER - 5);
336 gdk_draw_line(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
337 u_data->io->pixmap_width - RIGHT_BORDER + u_data->io->offset, u_data->io->pixmap_height - BOTTOM_BORDER, u_data->io->pixmap_width - RIGHT_BORDER + u_data->io->offset - 5, u_data->io->pixmap_height - BOTTOM_BORDER + 5);
338 u_data->io->axis_width = u_data->io->pixmap_width - LEFT_BORDER - RIGHT_BORDER - u_data->io->offset;
340 if(u_data->io->tmp_width>0){
341 u_data->io->x_interval = (float)((u_data->io->axis_width*1.0)/u_data->io->tmp_width); /*distance in pixels between 2 data points*/
343 u_data->io->x_interval = (float)(u_data->io->axis_width);
347 if (u_data->io->x_interval < 1)
349 dis = 1 / u_data->io->x_interval;
356 for (i=0; i<=e+1; i++)
362 g_snprintf(label_string, sizeof(label_string), "%d", 0);
363 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), 15);
364 layout = gtk_widget_create_pango_layout(u_data->io->draw_area, label_string);
365 pango_layout_get_pixel_size(layout, &label_width, &label_height);
367 if (u_data->io->x1_tmp_usec == 0)
368 sec = u_data->io->x1_tmp_sec;
370 sec = u_data->io->x1_tmp_sec+1;
372 if (u_data->io->offset != 0)
374 g_snprintf(label_string, sizeof(label_string), "%u", u_data->io->x1_tmp_sec);
375 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), sizeof(label_string));
376 pango_layout_set_text(layout, label_string, -1);
377 pango_layout_get_pixel_size(layout, &lwidth, NULL);
379 gdk_draw_layout(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
381 u_data->io->pixmap_height - BOTTOM_BORDER + 20,
384 w = (guint32)(500 / (guint32)(distance * u_data->io->x_interval));
387 if (w == 4 || w==3 || w==2)
391 b = (guint32)((u_data->io->min_x/100000))%10; /* start for labels*/
399 if (!u_data->io->uoff)
403 start=u_data->io->min_x/1000000*1000000;
409 start=u_data->io->min_x/100000;
413 b = (guint32)((start/100000))%10;
418 start = u_data->io->min_x;
425 for (i=start, j=b; i<=u_data->io->max_x; i+=a, j++)
427 if (!u_data->io->uoff)
428 if (i >= u_data->io->min_x && i % 1000000 != 0)
431 g_snprintf(label_string, sizeof(label_string), "%d", i%1000000);
437 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), sizeof(label_string));
438 pango_layout_set_text(layout, label_string, -1);
439 pango_layout_get_pixel_size(layout, &lwidth, NULL);
440 gdk_draw_layout(u_data->io->pixmap,
441 u_data->io->draw_area->style->black_gc,
442 (guint32)(LEFT_BORDER + u_data->io->offset + (i - u_data->io->min_x) * u_data->io->x_interval - lwidth / 2),
443 u_data->io->pixmap_height - BOTTOM_BORDER + 10,
446 gdk_draw_line(u_data->io->pixmap,
447 u_data->io->draw_area->style->black_gc,
448 (guint32)(LEFT_BORDER + u_data->io->offset + (i - u_data->io->min_x) * u_data->io->x_interval),
449 u_data->io->pixmap_height - BOTTOM_BORDER,
450 (guint32)(LEFT_BORDER + u_data->io->offset + (i - u_data->io->min_x) * u_data->io->x_interval),
451 u_data->io->pixmap_height - BOTTOM_BORDER + length);
454 if (!u_data->io->uoff)
456 if (i%1000000==0 && j%w==0)
472 gdk_draw_line(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
473 (guint32)(LEFT_BORDER + u_data->io->offset + (i - u_data->io->min_x) * u_data->io->x_interval),
474 u_data->io->pixmap_height - BOTTOM_BORDER,
475 (guint32)(LEFT_BORDER + u_data->io->offset + (i - u_data->io->min_x) * u_data->io->x_interval),
476 u_data->io->pixmap_height - BOTTOM_BORDER + 10);
478 g_snprintf(label_string, sizeof(label_string), "%d", sec);
479 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), sizeof(label_string));
480 pango_layout_set_text(layout, label_string, -1);
481 pango_layout_get_pixel_size(layout, &lwidth, NULL);
482 gdk_draw_layout(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
483 (guint32)(LEFT_BORDER + u_data->io->offset + (i - u_data->io->min_x) * u_data->io->x_interval-10),
484 u_data->io->pixmap_height - BOTTOM_BORDER + 20,
490 g_strlcpy(label_string, "sec", sizeof(label_string));
492 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), sizeof(label_string));
493 pango_layout_set_text(layout, label_string, -1);
494 pango_layout_get_pixel_size(layout, &lwidth, NULL);
495 gdk_draw_layout(u_data->io->pixmap,
496 u_data->io->draw_area->style->black_gc,
497 u_data->io->pixmap_width - RIGHT_BORDER - 10,
498 u_data->io->pixmap_height - BOTTOM_BORDER + 30,
503 gdk_draw_line(u_data->io->pixmap,
504 u_data->io->draw_area->style->black_gc,
505 LEFT_BORDER,TOP_BORDER - u_data->io->offset,
507 u_data->io->pixmap_height - BOTTOM_BORDER - u_data->io->offset);
508 gdk_draw_line(u_data->io->pixmap,
509 u_data->io->draw_area->style->black_gc,
511 TOP_BORDER - u_data->io->offset,
513 TOP_BORDER - u_data->io->offset + 5);
514 gdk_draw_line(u_data->io->pixmap,
515 u_data->io->draw_area->style->black_gc,
517 TOP_BORDER - u_data->io->offset,
519 TOP_BORDER - u_data->io->offset + 5);
521 u_data->io->y_interval = (float)(((u_data->io->pixmap_height - TOP_BORDER - BOTTOM_BORDER) * 1.0)/(u_data->io->max_y - u_data->io->min_y));
524 if (u_data->io->y_interval < 1)
526 dis = 1 / u_data->io->y_interval;
534 distance = distance * 10;
536 else if (u_data->io->y_interval<2)
539 if (u_data->io->max_y > 0)
541 for (i=u_data->io->min_y/distance*distance; i<=u_data->io->max_y; i+=distance/5)
543 if (i >= u_data->io->min_y)
546 g_snprintf(label_string, sizeof(label_string), "%d", i);
548 if (i%distance == 0 || (distance <= 5 && u_data->io->y_interval > 10))
552 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), sizeof(label_string));
553 pango_layout_set_text(layout, label_string, -1);
554 pango_layout_get_pixel_size(layout, &lwidth, NULL);
555 gdk_draw_layout(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
556 LEFT_BORDER - length - lwidth - 5,
557 (guint32)(u_data->io->pixmap_height - BOTTOM_BORDER - u_data->io->offset - (i - u_data->io->min_y) * u_data->io->y_interval - 3),
560 gdk_draw_line(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
561 LEFT_BORDER - length,
562 (guint32)(u_data->io->pixmap_height - BOTTOM_BORDER - u_data->io->offset - (i - u_data->io->min_y) * u_data->io->y_interval),
564 (guint32)(u_data->io->pixmap_height - BOTTOM_BORDER - u_data->io->offset - (i - u_data->io->min_y) * u_data->io->y_interval));
569 simple_dialog(ESD_TYPE_INFO, ESD_BTN_OK, "No Data Chunks sent");
573 static void sctp_graph_redraw(struct sctp_udata *u_data)
577 u_data->io->needs_redraw = TRUE;
579 sctp_graph_draw(u_data);
580 switch (u_data->io->graph_type)
583 draw_sack_graph(u_data);
584 draw_tsn_graph(u_data);
587 draw_tsn_graph(u_data);
590 draw_sack_graph(u_data);
593 ios=(sctp_graph_t *)g_object_get_data(G_OBJECT(u_data->io->draw_area), "sctp_graph_t");
600 gdk_draw_pixmap(u_data->io->draw_area->window,
601 u_data->io->draw_area->style->fg_gc[GTK_WIDGET_STATE(u_data->io->draw_area)],
605 u_data->io->draw_area->allocation.width,
606 u_data->io->draw_area->allocation.height);
610 static void on_sack_bt(GtkWidget *widget _U_, struct sctp_udata *u_data)
612 u_data = (struct sctp_udata *) u_data;
613 u_data->io->graph_type = 2;
614 sctp_graph_redraw(u_data);
617 static void on_tsn_bt(GtkWidget *widget _U_, struct sctp_udata *u_data)
619 u_data->io->graph_type = 1;
620 sctp_graph_redraw(u_data);
623 static void on_both_bt(GtkWidget *widget _U_, struct sctp_udata *u_data)
625 u_data->io->graph_type = 0;
626 sctp_graph_redraw(u_data);
630 sctp_graph_close_cb(GtkWidget* widget _U_, gpointer u_data)
632 struct sctp_udata *udata;
635 udata = (struct sctp_udata *)u_data;
636 dir = udata->dir - 1;
637 gtk_grab_remove(GTK_WIDGET(udata->io->window));
638 gtk_widget_destroy(GTK_WIDGET(udata->io->window));
644 configure_event(GtkWidget *widget, GdkEventConfigure *event _U_, struct sctp_udata *u_data)
650 if(u_data->io->pixmap){
651 gdk_pixmap_unref(u_data->io->pixmap);
652 u_data->io->pixmap = NULL;
655 u_data->io->pixmap = gdk_pixmap_new(widget->window,
656 widget->allocation.width,
657 widget->allocation.height,
659 u_data->io->pixmap_width = widget->allocation.width;
660 u_data->io->pixmap_height = widget->allocation.height;
662 gdk_draw_rectangle(u_data->io->pixmap,
663 widget->style->white_gc,
666 widget->allocation.width,
667 widget->allocation.height);
668 sctp_graph_redraw(u_data);
673 expose_event(GtkWidget *widget, GdkEventExpose *event)
677 ios=(sctp_graph_t *)g_object_get_data(G_OBJECT(widget), "sctp_graph_t");
682 gdk_draw_pixmap(widget->window,
683 widget->style->fg_gc[GTK_WIDGET_STATE(widget)],
685 event->area.x, event->area.y,
686 event->area.x, event->area.y,
687 event->area.width, event->area.height);
694 on_zoomin_bt (GtkWidget *widget _U_, struct sctp_udata *u_data)
696 sctp_min_max_t *tmp_minmax;
698 if (u_data->io->rectangle==TRUE)
700 tmp_minmax = g_malloc(sizeof(sctp_min_max_t));
702 u_data->io->tmp_min_tsn1=u_data->io->y1_tmp+u_data->io->min_y;
703 u_data->io->tmp_max_tsn1=u_data->io->y2_tmp+1+u_data->io->min_y;
705 u_data->io->tmp_min_tsn2=u_data->io->tmp_min_tsn1;
706 u_data->io->tmp_max_tsn2=u_data->io->tmp_max_tsn1;
707 tmp_minmax->tmp_min_secs=u_data->io->x1_tmp_sec;
708 tmp_minmax->tmp_min_usecs= u_data->io->x1_tmp_usec;
709 tmp_minmax->tmp_max_secs= u_data->io->x2_tmp_sec;
710 tmp_minmax->tmp_max_usecs= u_data->io->x2_tmp_usec;
711 tmp_minmax->tmp_min_tsn1=u_data->io->tmp_min_tsn1;
712 tmp_minmax->tmp_max_tsn1=u_data->io->tmp_max_tsn1;
713 tmp_minmax->tmp_min_tsn2=u_data->io->tmp_min_tsn2;
714 tmp_minmax->tmp_max_tsn2=u_data->io->tmp_max_tsn2;
715 u_data->assoc->min_max = g_slist_prepend(u_data->assoc->min_max, tmp_minmax);
716 u_data->io->length = g_slist_length(u_data->assoc->min_max);
717 u_data->io->tmp=TRUE;
718 u_data->io->rectangle=FALSE;
719 gtk_widget_set_sensitive(zoomout_bt, TRUE);
720 sctp_graph_redraw(u_data);
724 simple_dialog(ESD_TYPE_ERROR, ESD_BTN_OK, "Please draw a rectangle around the area you want to zoom in!");
729 zoomin_bt (struct sctp_udata *u_data)
731 sctp_min_max_t *tmp_minmax;
733 tmp_minmax = g_malloc(sizeof(sctp_min_max_t));
735 u_data->io->tmp_min_tsn1=u_data->io->y1_tmp+u_data->io->min_y;
736 u_data->io->tmp_max_tsn1=u_data->io->y2_tmp+1+u_data->io->min_y;
738 u_data->io->tmp_min_tsn2=u_data->io->tmp_min_tsn1;
739 u_data->io->tmp_max_tsn2=u_data->io->tmp_max_tsn1;
740 tmp_minmax->tmp_min_secs=u_data->io->x1_tmp_sec;
741 tmp_minmax->tmp_min_usecs=u_data->io->x1_tmp_usec;
742 tmp_minmax->tmp_max_secs=u_data->io->x2_tmp_sec;
743 tmp_minmax->tmp_max_usecs=u_data->io->x2_tmp_usec;
744 tmp_minmax->tmp_min_tsn1=u_data->io->tmp_min_tsn1;
745 tmp_minmax->tmp_max_tsn1=u_data->io->tmp_max_tsn1;
746 tmp_minmax->tmp_min_tsn2=u_data->io->tmp_min_tsn2;
747 tmp_minmax->tmp_max_tsn2=u_data->io->tmp_max_tsn2;
748 u_data->assoc->min_max = g_slist_prepend(u_data->assoc->min_max, tmp_minmax);
749 u_data->io->length = g_slist_length(u_data->assoc->min_max);
750 u_data->io->tmp=TRUE;
751 u_data->io->rectangle=FALSE;
752 gtk_widget_set_sensitive(zoomout_bt, TRUE);
753 sctp_graph_redraw(u_data);
757 on_zoomout_bt (GtkWidget *widget _U_, struct sctp_udata *u_data)
759 sctp_min_max_t *tmp_minmax, *mm;
762 l = g_slist_length(u_data->assoc->min_max);
764 if (u_data->assoc->min_max!=NULL)
766 mm=(sctp_min_max_t *)((u_data->assoc->min_max)->data);
767 u_data->assoc->min_max=g_slist_remove(u_data->assoc->min_max, mm);
772 tmp_minmax = (sctp_min_max_t *)u_data->assoc->min_max->data;
773 u_data->io->x1_tmp_sec=tmp_minmax->tmp_min_secs;
774 u_data->io->x1_tmp_usec=tmp_minmax->tmp_min_usecs;
775 u_data->io->x2_tmp_sec=tmp_minmax->tmp_max_secs;
776 u_data->io->x2_tmp_usec=tmp_minmax->tmp_max_usecs;
777 u_data->io->tmp_min_tsn1=tmp_minmax->tmp_min_tsn1;
778 u_data->io->tmp_max_tsn1=tmp_minmax->tmp_max_tsn1;
779 u_data->io->tmp_min_tsn2=tmp_minmax->tmp_min_tsn2;
780 u_data->io->tmp_max_tsn2=tmp_minmax->tmp_max_tsn2;
781 u_data->io->tmp=TRUE;
785 u_data->io->x1_tmp_sec=u_data->assoc->min_secs;
786 u_data->io->x1_tmp_usec=u_data->assoc->min_usecs;
787 u_data->io->x2_tmp_sec=u_data->assoc->max_secs;
788 u_data->io->x2_tmp_usec=u_data->assoc->max_usecs;
789 u_data->io->tmp_min_tsn1=0;
790 u_data->io->tmp_max_tsn1=u_data->assoc->max_bytes1;
791 u_data->io->tmp_min_tsn2=0;
792 u_data->io->tmp_max_tsn2=u_data->assoc->max_bytes2;
793 u_data->io->tmp=FALSE;
798 u_data->io->x1_tmp_sec=u_data->assoc->min_secs;
799 u_data->io->x1_tmp_usec=u_data->assoc->min_usecs;
800 u_data->io->x2_tmp_sec=u_data->assoc->max_secs;
801 u_data->io->x2_tmp_usec=u_data->assoc->max_usecs;
802 u_data->io->tmp_min_tsn1=0;
803 u_data->io->tmp_max_tsn1=u_data->assoc->max_bytes1;
804 u_data->io->tmp_min_tsn2=0;
805 u_data->io->tmp_max_tsn2=u_data->assoc->max_bytes2;
806 u_data->io->tmp=FALSE;
808 if (g_slist_length(u_data->assoc->min_max)==1)
809 gtk_widget_set_sensitive(zoomout_bt, FALSE);
810 sctp_graph_redraw(u_data);
815 on_button_press (GtkWidget *widget _U_, GdkEventButton *event, struct sctp_udata *u_data)
819 if (u_data->io->rectangle==TRUE)
821 gdk_draw_rectangle(u_data->io->pixmap,u_data->io->draw_area->style->white_gc,
823 (gint)floor(MIN(u_data->io->x_old,u_data->io->x_new)),
824 (gint)floor(MIN(u_data->io->y_old,u_data->io->y_new)),
825 (gint)abs((long)(u_data->io->x_new-u_data->io->x_old)),
826 (gint)abs((long)(u_data->io->y_new-u_data->io->y_old)));
827 ios=(sctp_graph_t *)g_object_get_data(G_OBJECT(u_data->io->draw_area), "sctp_graph_t");
833 gdk_draw_pixmap(u_data->io->draw_area->window,
834 u_data->io->draw_area->style->fg_gc[GTK_WIDGET_STATE(u_data->io->draw_area)],
838 (gint)abs((long)(u_data->io->x_new-u_data->io->x_old)),
839 (gint)abs((long)(u_data->io->y_new-u_data->io->y_old)));
840 sctp_graph_redraw(u_data);
843 u_data->io->x_old=event->x;
844 u_data->io->y_old=event->y;
845 if (u_data->io->y_old>u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset)
846 u_data->io->y_old=u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset;
847 if (u_data->io->x_old<LEFT_BORDER+u_data->io->offset)
848 u_data->io->x_old=LEFT_BORDER+u_data->io->offset;
849 u_data->io->rectangle=FALSE;
856 on_button_release (GtkWidget *widget _U_, GdkEventButton *event, struct sctp_udata *u_data)
859 guint32 helpx, helpy, x1_tmp, x2_tmp, y_value, frame;
860 gint label_width, label_height;
861 gdouble x_value, position, tfirst;
863 char label_string[30];
868 g_snprintf(label_string, 15, "%d", 0);
869 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), 15);
870 layout = gtk_widget_create_pango_layout(u_data->io->draw_area, label_string);
871 pango_layout_get_pixel_size(layout, &label_width, &label_height);
873 if (event->y > u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset)
874 event->y = u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset;
875 if (event->x < LEFT_BORDER+u_data->io->offset)
876 event->x = LEFT_BORDER+u_data->io->offset;
878 if (abs((long)(event->x-u_data->io->x_old))>10 || abs((long)(event->y-u_data->io->y_old))>10)
880 u_data->io->rect_x_min = (guint32) floor(MIN(u_data->io->x_old,event->x));
881 u_data->io->rect_x_max = (guint32) ceil(MAX(u_data->io->x_old,event->x));
882 u_data->io->rect_y_min = (guint32) floor(MIN(u_data->io->y_old,event->y));
883 u_data->io->rect_y_max = (guint32) ceil(MAX(u_data->io->y_old,event->y));
884 gdk_draw_rectangle(u_data->io->pixmap,u_data->io->draw_area->style->black_gc,
886 u_data->io->rect_x_min, u_data->io->rect_y_min,
887 u_data->io->rect_x_max - u_data->io->rect_x_min,
888 u_data->io->rect_y_max - u_data->io->rect_y_min);
889 ios=(sctp_graph_t *)g_object_get_data(G_OBJECT(u_data->io->draw_area), "sctp_graph_t");
895 gdk_draw_pixmap(u_data->io->draw_area->window,
896 u_data->io->draw_area->style->fg_gc[GTK_WIDGET_STATE(u_data->io->draw_area)],
900 u_data->io->draw_area->allocation.width,
901 u_data->io->draw_area->allocation.height);
903 x1_tmp=(guint32) floor(u_data->io->min_x+((u_data->io->x_old-LEFT_BORDER-u_data->io->offset)*u_data->io->tmp_width/u_data->io->axis_width));
904 x2_tmp=(guint32) floor(u_data->io->min_x+((event->x-LEFT_BORDER-u_data->io->offset)*u_data->io->tmp_width/u_data->io->axis_width));
905 helpx=MIN(x1_tmp, x2_tmp);
911 if (u_data->io->uoff)
913 if (x2_tmp - x1_tmp <= 1500)
914 u_data->io->uoff = FALSE;
915 u_data->io->x1_tmp_sec=(guint32)x1_tmp;
916 u_data->io->x1_tmp_usec=0;
917 u_data->io->x2_tmp_sec=(guint32)x2_tmp;
918 u_data->io->x2_tmp_usec=0;
922 u_data->io->x1_tmp_sec=(guint32)x1_tmp/1000000;
923 u_data->io->x1_tmp_usec=x1_tmp%1000000;
924 u_data->io->x2_tmp_sec=(guint32)x2_tmp/1000000;
925 u_data->io->x2_tmp_usec=x2_tmp%1000000;
927 u_data->io->x1_akt_sec = u_data->io->x1_tmp_sec;
928 u_data->io->x1_akt_usec = u_data->io->x1_tmp_usec;
929 u_data->io->x2_akt_sec = u_data->io->x2_tmp_sec;
930 u_data->io->x2_akt_usec = u_data->io->x2_tmp_usec;
932 u_data->io->y1_tmp=(guint32)((u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-u_data->io->y_old)/u_data->io->y_interval);
933 u_data->io->y2_tmp=(guint32)((u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-event->y)/u_data->io->y_interval);
934 helpy = MIN(u_data->io->y1_tmp, u_data->io->y2_tmp);
935 u_data->io->y2_tmp = MAX(u_data->io->y1_tmp, u_data->io->y2_tmp);
936 u_data->io->y1_tmp = helpy;
937 u_data->io->x_new=event->x;
938 u_data->io->y_new=event->y;
939 u_data->io->rectangle=TRUE;
940 u_data->io->rectangle_present=TRUE;
944 if (u_data->io->rectangle_present==TRUE)
946 u_data->io->rectangle_present=FALSE;
947 if (event->x >= u_data->io->rect_x_min && event->x <= u_data->io->rect_x_max &&
948 event->y >= u_data->io->rect_y_min && event->y <= u_data->io->rect_y_max)
952 u_data->io->x1_tmp_sec = u_data->io->x1_akt_sec;
953 u_data->io->x1_tmp_usec = u_data->io->x1_akt_usec;
954 u_data->io->x2_tmp_sec = u_data->io->x2_akt_sec;
955 u_data->io->x2_tmp_usec = u_data->io->x2_akt_usec;
956 sctp_graph_redraw(u_data);
962 sctp_graph_redraw(u_data);
966 x_value = ((event->x-LEFT_BORDER-u_data->io->offset) * ((u_data->io->x2_tmp_sec+u_data->io->x2_tmp_usec/1000000.0)-(u_data->io->x1_tmp_sec+u_data->io->x1_tmp_usec/1000000.0)) / (u_data->io->pixmap_width-LEFT_BORDER-RIGHT_BORDER-u_data->io->offset))+u_data->io->x1_tmp_sec+u_data->io->x1_tmp_usec/1000000.0;
967 y_value = (guint32) floor((u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset-event->y) * (max_tsn - min_tsn) / (u_data->io->pixmap_height-BOTTOM_BORDER-u_data->io->offset)) + min_tsn;
968 text_color = u_data->io->draw_area->style->black_gc;
970 if (u_data->dir == 1)
971 tsnlist = g_list_last(u_data->assoc->tsn1);
973 tsnlist = g_list_last(u_data->assoc->tsn2);
975 tsn = (tsn_t*) (tsnlist->data);
976 tmptsn =(tsn_t*)(tsnlist->data);
977 tfirst = tsn->secs + tsn->usecs/1000000.0;
978 frame = tsn->frame_number;
982 tsnlist = g_list_previous(tsnlist);
983 tsn = (tsn_t*) (tsnlist->data);
984 if (tsn->secs+tsn->usecs/1000000.0<x_value)
986 tfirst = tsn->secs+tsn->usecs/1000000.0;
991 if ((tfirst+tsn->secs+tsn->usecs/1000000.0)/2.0<x_value)
993 x_value = tsn->secs+tsn->usecs/1000000.0;
997 x_value = tmptsn->secs+tmptsn->usecs/1000000.0;
1001 cf_goto_frame(&cfile, tmptsn->frame_number);
1002 g_snprintf(label_string, sizeof(label_string), "(%.6f, %u)", x_value, y_value);
1005 gdk_draw_line(u_data->io->pixmap,text_color, (gint)(event->x-2), (gint)(event->y), (gint)(event->x+2), (gint)(event->y));
1006 gdk_draw_line(u_data->io->pixmap,text_color, (gint)(event->x), (gint)(event->y-2), (gint)(event->x), (gint)(event->y+2));
1007 if (event->x+150>=u_data->io->pixmap_width)
1008 position = event->x - 150;
1010 position = event->x + 5;
1012 memcpy(label_string,(gchar *)g_locale_to_utf8(label_string, -1 , NULL, NULL, NULL), 15);
1013 pango_layout_set_text(layout, label_string, -1);
1014 pango_layout_get_pixel_size(layout, &lwidth, NULL);
1016 gdk_draw_layout(u_data->io->pixmap,text_color,
1018 (gint)(event->y-10),
1020 ios=(sctp_graph_t *)g_object_get_data(G_OBJECT(u_data->io->draw_area), "sctp_graph_t");
1025 gdk_draw_pixmap(u_data->io->draw_area->window,
1026 u_data->io->draw_area->style->fg_gc[GTK_WIDGET_STATE(u_data->io->draw_area)],
1030 u_data->io->draw_area->allocation.width,
1031 u_data->io->draw_area->allocation.height);
1037 static void init_sctp_graph_window(struct sctp_udata *u_data)
1041 GtkWidget *bt_close, *sack_bt, *tsn_bt, *both_bt, *zoomin_bt;
1042 GtkTooltips *tooltip_in, *tooltip_out;
1044 /* create the main window */
1046 u_data->io->window=gtk_window_new(GTK_WINDOW_TOPLEVEL);
1048 gtk_widget_set_name(u_data->io->window, "SCTP Graphics");
1050 vbox=gtk_vbox_new(FALSE, 0);
1051 gtk_container_add(GTK_CONTAINER(u_data->io->window), vbox);
1052 gtk_widget_show(vbox);
1054 create_draw_area(vbox, u_data);
1056 sctp_graph_set_title(u_data);
1058 hbox = gtk_hbutton_box_new();
1059 gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0);
1060 gtk_container_set_border_width(GTK_CONTAINER(hbox), 10);
1061 gtk_button_box_set_layout(GTK_BUTTON_BOX (hbox), GTK_BUTTONBOX_SPREAD);
1062 gtk_box_set_spacing(GTK_BOX (hbox), 0);
1063 gtk_box_set_child_packing(GTK_BOX(vbox), hbox, FALSE, FALSE, 0, GTK_PACK_START);
1064 gtk_widget_show(hbox);
1066 sack_bt = gtk_button_new_with_label ("Adv. Rec. Window");
1067 gtk_box_pack_start(GTK_BOX(hbox), sack_bt, FALSE, FALSE, 0);
1068 gtk_widget_show(sack_bt);
1070 g_signal_connect(sack_bt, "clicked", G_CALLBACK(on_sack_bt), u_data);
1072 tsn_bt = gtk_button_new_with_label ("Data bytes sent");
1073 gtk_box_pack_start(GTK_BOX(hbox), tsn_bt, FALSE, FALSE, 0);
1074 gtk_widget_show(tsn_bt);
1075 g_signal_connect(tsn_bt, "clicked", G_CALLBACK(on_tsn_bt), u_data);
1077 both_bt = gtk_button_new_with_label ("Show both");
1078 gtk_box_pack_start(GTK_BOX(hbox), both_bt, FALSE, FALSE, 0);
1079 gtk_widget_show(both_bt);
1080 g_signal_connect(both_bt, "clicked", G_CALLBACK(on_both_bt), u_data);
1082 zoomin_bt = gtk_button_new_with_label ("Zoom in");
1083 gtk_box_pack_start(GTK_BOX(hbox), zoomin_bt, FALSE, FALSE, 0);
1084 gtk_widget_show(zoomin_bt);
1085 g_signal_connect(zoomin_bt, "clicked", G_CALLBACK(on_zoomin_bt), u_data);
1086 tooltip_in = gtk_tooltips_new();
1087 gtk_tooltips_set_tip(tooltip_in, zoomin_bt, "Zoom in the area you have selected", NULL);
1089 zoomout_bt = gtk_button_new_with_label ("Zoom out");
1090 gtk_box_pack_start(GTK_BOX(hbox), zoomout_bt, FALSE, FALSE, 0);
1091 gtk_widget_show(zoomout_bt);
1092 g_signal_connect(zoomout_bt, "clicked", G_CALLBACK(on_zoomout_bt), u_data);
1093 tooltip_out = gtk_tooltips_new();
1094 gtk_tooltips_set_tip(tooltip_out, zoomout_bt, "Zoom out one step", NULL);
1095 gtk_widget_set_sensitive(zoomout_bt, FALSE);
1097 bt_close = gtk_button_new_from_stock(GTK_STOCK_CLOSE);
1098 gtk_box_pack_start(GTK_BOX(hbox), bt_close, FALSE, FALSE, 0);
1099 gtk_widget_show(bt_close);
1100 g_signal_connect(bt_close, "clicked", G_CALLBACK(sctp_graph_close_cb), u_data);
1102 g_signal_connect(u_data->io->draw_area,"button_press_event",G_CALLBACK(on_button_press), u_data);
1103 g_signal_connect(u_data->io->draw_area,"button_release_event",G_CALLBACK(on_button_release), u_data);
1104 gtk_widget_set_events(u_data->io->draw_area, GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK | GDK_EXPOSURE_MASK);
1105 /* dlg_set_cancel(u_data->io->window, bt_close); */
1108 gtk_widget_show(u_data->io->window);
1111 static void sctp_graph_set_title(struct sctp_udata *u_data)
1115 if(!u_data->io->window)
1119 title = g_strdup_printf("SCTP Data and Adv.Rcv.Window over Time: %s Port1 %u Port2 %u Endpoint %u",
1120 cf_get_display_name(&cfile), u_data->parent->assoc->port1, u_data->parent->assoc->port2, u_data->dir);
1121 gtk_window_set_title(GTK_WINDOW(u_data->io->window), title);
1127 gtk_sctpgraph_init(struct sctp_udata *u_data)
1131 sctp_min_max_t* tmp_minmax;
1133 io=g_malloc(sizeof(sctp_graph_t));
1134 io->needs_redraw=TRUE;
1135 io->x_interval=1000;
1139 io->pixmap_width=800;
1140 io->pixmap_height=600;
1146 u_data->io->x1_tmp_sec=u_data->assoc->min_secs;
1147 u_data->io->x1_tmp_usec=u_data->assoc->min_usecs;
1148 u_data->io->x2_tmp_sec=u_data->assoc->max_secs;
1149 u_data->io->x2_tmp_usec=u_data->assoc->max_usecs;
1150 u_data->io->tmp_min_tsn1=0;
1151 u_data->io->tmp_max_tsn1=u_data->assoc->max_bytes1;
1152 u_data->io->tmp_min_tsn2=0;
1153 u_data->io->tmp_max_tsn2=u_data->assoc->max_bytes2;
1154 u_data->io->tmp=FALSE;
1155 tmp_minmax = g_malloc(sizeof(sctp_min_max_t));
1156 tmp_minmax->tmp_min_secs = u_data->assoc->min_secs;
1157 tmp_minmax->tmp_min_usecs=u_data->assoc->min_usecs;
1158 tmp_minmax->tmp_max_secs=u_data->assoc->max_secs;
1159 tmp_minmax->tmp_max_usecs=u_data->assoc->max_usecs;
1160 tmp_minmax->tmp_min_tsn2=u_data->io->tmp_min_tsn2;
1161 tmp_minmax->tmp_min_tsn1=u_data->io->tmp_min_tsn1;
1162 tmp_minmax->tmp_max_tsn1=u_data->io->tmp_max_tsn1;
1163 tmp_minmax->tmp_max_tsn2=u_data->io->tmp_max_tsn2;
1164 u_data->assoc->min_max = g_slist_prepend(u_data->assoc->min_max, tmp_minmax);
1167 init_sctp_graph_window(u_data);
1168 sctp_graph_redraw(u_data);
1173 quit(GtkObject *object _U_, gpointer user_data)
1175 struct sctp_udata *u_data=(struct sctp_udata*)user_data;
1177 decrease_childcount(u_data->parent);
1178 remove_child(u_data, u_data->parent);
1180 u_data->assoc->min_max = NULL;
1186 static void create_draw_area(GtkWidget *box, struct sctp_udata *u_data)
1188 u_data->io->draw_area=gtk_drawing_area_new();
1189 g_signal_connect(u_data->io->draw_area, "destroy", G_CALLBACK(quit), u_data);
1190 g_object_set_data(G_OBJECT(u_data->io->draw_area), "sctp_graph_t", u_data->io);
1192 gtk_widget_set_size_request(u_data->io->draw_area, u_data->io->pixmap_width, u_data->io->pixmap_height);
1194 /* signals needed to handle backing pixmap */
1195 g_signal_connect(u_data->io->draw_area, "expose_event", G_CALLBACK(expose_event), NULL);
1196 g_signal_connect(u_data->io->draw_area, "configure_event", G_CALLBACK(configure_event), u_data);
1198 gtk_widget_show(u_data->io->draw_area);
1199 gtk_box_pack_start(GTK_BOX(box), u_data->io->draw_area, TRUE, TRUE, 0);
1202 static void insertion(GPtrArray *array, guint32 N)
1206 struct tsn_sort *help=NULL;
1210 v = ((struct tsn_sort*)(g_ptr_array_index(array,i)))->tsnumber;
1212 while (j>=1 && ((struct tsn_sort*)(g_ptr_array_index(array, j-1)))->tsnumber > v)
1214 help=g_ptr_array_index(array, j);
1215 g_ptr_array_index(array, j)=g_ptr_array_index(array, j-1);
1216 g_ptr_array_index(array, j-1)=help;
1219 ((struct tsn_sort*)(g_ptr_array_index(array, j)))->tsnumber=v;
1223 static void set_arw_offsets(struct sctp_udata *u_data)
1225 GPtrArray *s_array=NULL, *t_array=NULL;
1228 if (u_data->dir==1 && u_data->assoc->n_sack_chunks_ep1>0)
1230 s_array=u_data->assoc->sort_sack1;
1231 t_array=u_data->assoc->sort_tsn1;
1232 insertion(s_array,u_data->assoc->n_sack_chunks_ep1);
1234 for (i=0; i<u_data->assoc->n_sack_chunks_ep1; i++)
1236 while (((struct tsn_sort*)(g_ptr_array_index(s_array, i)))->tsnumber > ((struct tsn_sort*)(g_ptr_array_index(t_array, j)))->tsnumber)
1240 ((struct tsn_sort*)(g_ptr_array_index(s_array,i)))->offset = ((struct tsn_sort*)(g_ptr_array_index(t_array, j)))->offset
1241 + ((struct tsn_sort*)(g_ptr_array_index(t_array, j)))->length;
1244 u_data->assoc->sort_sack1=s_array;
1247 if (u_data->dir==2 && u_data->assoc->n_sack_chunks_ep2>0)
1249 s_array=u_data->assoc->sort_sack2;
1250 t_array=u_data->assoc->sort_tsn2;
1251 insertion(s_array,u_data->assoc->n_sack_chunks_ep2);
1253 for (i=0; i<u_data->assoc->n_sack_chunks_ep2; i++)
1255 while (((struct tsn_sort*)(g_ptr_array_index(s_array, i)))->tsnumber > ((struct tsn_sort*)(g_ptr_array_index(t_array,j)))->tsnumber)
1259 ((struct tsn_sort*)(g_ptr_array_index(s_array, i)))->offset = ((struct tsn_sort*)(g_ptr_array_index(t_array, j)))->offset
1260 + ((struct tsn_sort*)(g_ptr_array_index(t_array, j)))->length;
1262 u_data->assoc->sort_sack2=s_array;
1266 static void compute_offsets(struct sctp_udata *u_data)
1268 struct tsn_sort t_sort;
1269 GPtrArray *array=NULL;
1274 if (u_data->dir==1 && u_data->assoc->n_array_tsn1>0)
1276 array=u_data->assoc->sort_tsn1;
1277 insertion(array,u_data->assoc->n_array_tsn1);
1279 for (i=0; i<u_data->assoc->n_array_tsn1; i++)
1281 ((struct tsn_sort*)(g_ptr_array_index(array, i)))->offset=sum;
1282 t_sort.tsnumber=((struct tsn_sort*)(g_ptr_array_index(array, i)))->tsnumber;
1283 if (t_sort.tsnumber>tsntmp)
1284 sum+=((struct tsn_sort*)(g_ptr_array_index(array, i)))->length;
1285 tsntmp=t_sort.tsnumber;
1287 u_data->assoc->max_bytes1= ((struct tsn_sort*)(g_ptr_array_index(array, i-1)))->offset + ((struct tsn_sort*)(g_ptr_array_index(array, i-1)))->length;
1288 u_data->assoc->sort_tsn1=array;
1290 if (u_data->dir==2 && u_data->assoc->n_array_tsn2>0)
1293 array=u_data->assoc->sort_tsn2;
1294 insertion(array,u_data->assoc->n_array_tsn2);
1296 for (i=0; i<u_data->assoc->n_array_tsn2; i++)
1298 ((struct tsn_sort*)(g_ptr_array_index(array,i)))->offset=sum;
1299 t_sort.tsnumber=((struct tsn_sort*)(g_ptr_array_index(array, i)))->tsnumber;
1300 if (t_sort.tsnumber>tsntmp)
1301 sum+=((struct tsn_sort*)(g_ptr_array_index(array, i)))->length;
1302 tsntmp=t_sort.tsnumber;
1305 u_data->assoc->max_bytes2= ((struct tsn_sort*)(g_ptr_array_index(array, u_data->assoc->n_data_chunks_ep2-1)))->offset + ((struct tsn_sort*)(g_ptr_array_index(array, u_data->assoc->n_data_chunks_ep2-1)))->length;
1306 u_data->assoc->sort_tsn2=array;
1310 void create_byte_graph(guint16 dir, struct sctp_analyse* userdata)
1312 struct sctp_udata *u_data;
1314 u_data=g_malloc(sizeof(struct sctp_udata));
1315 u_data->assoc=g_malloc(sizeof(sctp_assoc_info_t));
1316 u_data->assoc=userdata->assoc;
1319 u_data->parent = userdata;
1320 if ((u_data->dir==1 && (u_data->assoc->n_array_tsn1==0))|| (u_data->dir==2 && (u_data->assoc->n_array_tsn2==0)))
1321 simple_dialog(ESD_TYPE_INFO, ESD_BTN_OK, "No Data Chunks sent");
1324 set_child(u_data, u_data->parent);
1325 increase_childcount(u_data->parent);
1326 compute_offsets(u_data);
1327 set_arw_offsets(u_data);
1328 gtk_sctpgraph_init(u_data);