+ if(Event_Viewer_Data->current_period+1 == Event_Viewer_Data->time_period->len){
+ new_time_period = TRUE;
+ time_period = g_new(TimePeriod, 1);
+ raw_data = g_ptr_array_index(second_data,second_data->len-1);
+ time_period->start = raw_data->time;
+ time_period->start.tv_nsec++;
+ time_period->end.tv_sec = G_MAXULONG;
+ time_period->end.tv_nsec = G_MAXULONG;
+ time_period->start_event_number = Event_Viewer_Data->end_event_number + 1;
+ g_ptr_array_add(Event_Viewer_Data->time_period,time_period);
+ }
+
+ time_period = g_ptr_array_index(Event_Viewer_Data->time_period,
+ Event_Viewer_Data->current_period+1);
+
+ get_events(Event_Viewer_Data,time_period->start, time_period->end, RESERVE_SIZE);
+ Event_Viewer_Data->end_event_number += Event_Viewer_Data->raw_trace_data->len;
+ if(new_time_period){
+ raw_data = g_ptr_array_index(Event_Viewer_Data->raw_trace_data,0);
+ time_period->start = raw_data->time;
+ raw_data = g_ptr_array_index(Event_Viewer_Data->raw_trace_data,
+ Event_Viewer_Data->raw_trace_data->len-1);
+ time_period->end = raw_data->time;
+ time_period->end_event_number = Event_Viewer_Data->end_event_number;
+ }
+ Event_Viewer_Data->raw_trace_data = second_data;
+
+ if(Event_Viewer_Data->end_event_number > Event_Viewer_Data->Number_Of_Events){
+ Event_Viewer_Data->Number_Of_Events = Event_Viewer_Data->end_event_number;
+ Event_Viewer_Data->VAdjust_C->upper = Event_Viewer_Data->Number_Of_Events;
+ }
+ }else{//direction = SCROLL_DOWN_MORE_PERIOD
+ free_ptr_array(second_data);
+ free_ptr_array(Event_Viewer_Data->raw_trace_data);
+ Event_Viewer_Data->raw_trace_data_first = g_ptr_array_sized_new(RESERVE_SIZE);
+ Event_Viewer_Data->raw_trace_data_second = g_ptr_array_sized_new(RESERVE_SIZE);
+
+ if(Event_Viewer_Data->current_period+1 == Event_Viewer_Data->time_period->len){
+ new_time_period = TRUE;
+ time_period = g_new(TimePeriod, 1);
+ time_period1 = g_ptr_array_index(Event_Viewer_Data->time_period,
+ Event_Viewer_Data->time_period->len-1);
+ time_period->start = time_period1->end;
+ time_period->start.tv_nsec++;
+ time_period->end.tv_sec = G_MAXULONG;
+ time_period->end.tv_nsec = G_MAXULONG;
+ time_period->start_event_number = time_period1->end_event_number + 1;
+ g_ptr_array_add(Event_Viewer_Data->time_period,time_period);
+ }
+
+ Event_Viewer_Data->raw_trace_data = Event_Viewer_Data->raw_trace_data_first;
+ time_period = g_ptr_array_index(Event_Viewer_Data->time_period,
+ Event_Viewer_Data->current_period);
+ get_events(Event_Viewer_Data,time_period->start, time_period->end, RESERVE_SIZE);
+ Event_Viewer_Data->start_event_number = time_period->start_event_number;
+ Event_Viewer_Data->end_event_number = time_period->end_event_number;
+
+ Event_Viewer_Data->raw_trace_data = Event_Viewer_Data->raw_trace_data_second;
+ time_period = g_ptr_array_index(Event_Viewer_Data->time_period,
+ Event_Viewer_Data->current_period+1);
+ get_events(Event_Viewer_Data,time_period->start, time_period->end, RESERVE_SIZE);
+ Event_Viewer_Data->end_event_number += Event_Viewer_Data->raw_trace_data->len;
+ if(new_time_period){
+ raw_data = g_ptr_array_index(Event_Viewer_Data->raw_trace_data,0);
+ time_period->start = raw_data->time;
+ raw_data = g_ptr_array_index(Event_Viewer_Data->raw_trace_data,
+ Event_Viewer_Data->raw_trace_data->len-1);
+ time_period->end = raw_data->time;
+ time_period->end_event_number = Event_Viewer_Data->end_event_number;
+ }
+ Event_Viewer_Data->raw_trace_data = Event_Viewer_Data->raw_trace_data_first;
+ }
+ }
+
+ second_data = Event_Viewer_Data->raw_trace_data == Event_Viewer_Data->raw_trace_data_first
+ ? Event_Viewer_Data->raw_trace_data_second : Event_Viewer_Data->raw_trace_data_first;
+
+ gtk_list_store_clear(Event_Viewer_Data->Store_M);
+ for(i=Event_Number; i<Event_Number+List_Height; i++)
+ {
+ guint64 real_data;
+
+ if(i>=Event_Viewer_Data->Number_Of_Events) break;
+
+ j = i - Event_Viewer_Data->start_event_number;
+
+ if(j < Event_Viewer_Data->raw_trace_data->len)
+ raw_data = g_ptr_array_index(Event_Viewer_Data->raw_trace_data, j);
+ else
+ raw_data = g_ptr_array_index(second_data, j - Event_Viewer_Data->raw_trace_data->len);
+
+ /* Add a new row to the model */
+ real_data = raw_data->time.tv_sec;
+ real_data *= 1000000000;
+ real_data += raw_data->time.tv_nsec;
+ gtk_list_store_append (Event_Viewer_Data->Store_M, &iter);
+ gtk_list_store_set (Event_Viewer_Data->Store_M, &iter,
+ CPUID_COLUMN, raw_data->cpu_id,
+ EVENT_COLUMN, raw_data->event_name,
+ TIME_COLUMN, real_data,
+ PID_COLUMN, raw_data->pid,
+ ENTRY_LEN_COLUMN, raw_data->entry_length,
+ EVENT_DESCR_COLUMN, raw_data->event_description,
+ -1);
+/*
+ gtk_list_store_set (Event_Viewer_Data->Store_M, &iter,
+ CPUID_COLUMN, 0,
+ EVENT_COLUMN, "event irq",
+ TIME_COLUMN, i,
+ PID_COLUMN, 100,
+ ENTRY_LEN_COLUMN, 17,
+ EVENT_DESCR_COLUMN, "Detailed information",
+ -1);
+*/
+ }
+ }
+#ifdef DEBUG //do not use this, it's slower and broken
+ // } else {
+ /* Some events will be reused */
+ if(Event_Number < Event_Viewer_Data->First_Event)
+ {
+ /* scrolling up, prepend events */
+ Tree_Path = gtk_tree_path_new_from_indices
+ (Event_Number+List_Height-1 -
+ Event_Viewer_Data->First_Event + 1,
+ -1);
+ for(i=0; i<Event_Viewer_Data->Last_Event-(Event_Number+List_Height-1);
+ i++)
+ {
+ /* Remove the last events from the list */
+ if(gtk_tree_model_get_iter(model, &iter, Tree_Path))
+ gtk_list_store_remove(Event_Viewer_Data->Store_M, &iter);
+ }
+
+ for(i=Event_Viewer_Data->First_Event-1; i>=Event_Number; i--)
+ {
+ if(i>=Event_Viewer_Data->Number_Of_Events) break;
+ /* Prepend new events */
+ gtk_list_store_prepend (Event_Viewer_Data->Store_M, &iter);
+ gtk_list_store_set (Event_Viewer_Data->Store_M, &iter,
+ CPUID_COLUMN, 0,
+ EVENT_COLUMN, "event irq",
+ TIME_COLUMN, i,
+ PID_COLUMN, 100,
+ ENTRY_LEN_COLUMN, 17,
+ EVENT_DESCR_COLUMN, "Detailed information",
+ -1);
+ }
+ } else {
+ /* Scrolling down, append events */
+ for(i=Event_Viewer_Data->First_Event; i<Event_Number; i++)
+ {
+ /* Remove these events from the list */
+ gtk_tree_model_get_iter_first(model, &iter);
+ gtk_list_store_remove(Event_Viewer_Data->Store_M, &iter);
+ }
+ for(i=Event_Viewer_Data->Last_Event+1; i<Event_Number+List_Height; i++)