357 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			357 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "Yap.h"
 | |
| #include "myddas_structs.h"
 | |
| #include "myddas_statistics.h"
 | |
| #include <stdlib.h>
 | |
| #include <sys/time.h>
 | |
| 
 | |
| #if defined MYDDAS_STATS
 | |
| 
 | |
| 
 | |
| 
 | |
| /* Documentation: Time Units 
 | |
| ------------------------------------------------------------------------
 | |
| *****| Second(s) | MiliSeconds(ms) | MicroSeconds(us) | NanoSecond(ns) |
 | |
| -----|-----------|-----------------|------------------|----------------|
 | |
|   s  |    1      |    0.001        |   0.000001       |    1e-9        |
 | |
|   ms |  1000     |      1          |     0.001        |  0.000001      |
 | |
|   us | 10000000  |    1000         |       1          |    0.001       |
 | |
|   ns |1000000000 |   1000000       |     1000         |      1         |
 | |
| ------------------------------------------------------------------------
 | |
| 
 | |
| ------
 | |
| 
 | |
| The struct timeval structure represents an elapsed time. It is
 | |
| declared in `sys/time.h' and has the following members:
 | |
| 
 | |
| long int tv_sec -> This represents the number of whole seconds of
 | |
|     elapsed time.
 | |
| 
 | |
| long int tv_usec -> This is the rest of the elapsed time (a fraction
 | |
|     of a second), represented as the number of microseconds. It is
 | |
|     always less than one million.
 | |
| 
 | |
| 
 | |
| ------
 | |
| 
 | |
| The struct timespec structure represents an elapsed time. It is
 | |
| declared in `time.h' and has the following members:
 | |
| 
 | |
| long int tv_sec -> This represents the number of whole seconds of
 | |
|     elapsed time.
 | |
| 
 | |
| long int tv_nsec -> This is the rest of the elapsed time (a fraction
 | |
|     of a second), represented as the number of nanoseconds. It is
 | |
|     always less than one billion.
 | |
| 
 | |
| -----
 | |
| 
 | |
|     The gettimeofday() function shall obtain the current time,
 | |
|     expressed as seconds and microseconds since the Epoch, and store
 | |
|     it in the timeval structure pointed to by tp. The resolution of
 | |
|     the system clock is unspecified.
 | |
| 
 | |
|     If tzp is not a null pointer, the behavior is unspecified.
 | |
| 
 | |
| */
 | |
| 
 | |
| static void
 | |
| myddas_stats_time_subtract (unsigned long *, unsigned long *, MYDDAS_STATS_TIME, MYDDAS_STATS_TIME);
 | |
| static void
 | |
| myddas_stats_add_seconds_time(MYDDAS_STATS_TIME,unsigned long, unsigned long);
 | |
| static void
 | |
| myddas_stats_integrity_of_time(MYDDAS_STATS_TIME);
 | |
| 
 | |
| /* Be shore to delete MYDDAS_STATS_TIME structure */
 | |
| MYDDAS_STATS_TIME
 | |
| myddas_stats_walltime(void) {
 | |
| 
 | |
|   MYDDAS_STATS_TIME myddas_time = NULL;
 | |
|   MYDDAS_MALLOC(myddas_time,struct myddas_stats_time_struct);
 | |
|   myddas_time->type = time_copy;
 | |
| 
 | |
|   struct timeval *time = NULL;
 | |
|   MYDDAS_MALLOC(time,struct timeval);
 | |
|   
 | |
|   gettimeofday(time,NULL);
 | |
|   
 | |
|   myddas_time->u.time_copy.tv_sec = time->tv_sec;
 | |
|   myddas_time->u.time_copy.tv_usec = time->tv_usec;
 | |
|   
 | |
|   MYDDAS_FREE(time,struct timeval);
 | |
| 
 | |
|   return myddas_time;
 | |
| }
 | |
| 
 | |
| void
 | |
| myddas_stats_add_time(MYDDAS_STATS_TIME sum, MYDDAS_STATS_TIME time1,MYDDAS_STATS_TIME time2){
 | |
|   
 | |
|   if (sum->type == time_final){
 | |
|     sum->u.time_final.microseconds =
 | |
|       time1->u.time_final.microseconds +
 | |
|       time2->u.time_final.microseconds;
 | |
|     sum->u.time_final.miliseconds =
 | |
|       time1->u.time_final.miliseconds +
 | |
|       time2->u.time_final.miliseconds;
 | |
|     sum->u.time_final.seconds =
 | |
|       time1->u.time_final.seconds +
 | |
|       time2->u.time_final.seconds;
 | |
|     sum->u.time_final.minutes =
 | |
|       time1->u.time_final.minutes +
 | |
|       time2->u.time_final.minutes;
 | |
|     sum->u.time_final.hours =
 | |
|       time1->u.time_final.hours +
 | |
|       time2->u.time_final.hours;
 | |
|   } else {
 | |
|     sum->u.time_copy.tv_sec =
 | |
|       time1->u.time_copy.tv_sec +
 | |
|       time2->u.time_copy.tv_sec;
 | |
|     sum->u.time_copy.tv_usec =
 | |
|       time1->u.time_copy.tv_usec +
 | |
|       time2->u.time_copy.tv_usec;
 | |
|   }
 | |
|   
 | |
|   myddas_stats_integrity_of_time(sum);
 | |
| }
 | |
| 		       
 | |
| 
 | |
| void
 | |
| myddas_stats_subtract_time(MYDDAS_STATS_TIME result, MYDDAS_STATS_TIME t1,MYDDAS_STATS_TIME t2){
 | |
|   
 | |
|   if (result->type == time_copy){
 | |
|   
 | |
|     unsigned long sec;
 | |
|     unsigned long usec;
 | |
|     myddas_stats_time_subtract(&sec,&usec,t1,t2);
 | |
|     
 | |
|     result->u.time_copy.tv_sec = sec;
 | |
|     result->u.time_copy.tv_usec = usec;
 | |
|     
 | |
|   } else {
 | |
|     
 | |
|   }
 | |
|   
 | |
| }
 | |
| 
 | |
| void
 | |
| myddas_stats_move_time(MYDDAS_STATS_TIME from,
 | |
| 		       MYDDAS_STATS_TIME to)
 | |
| {
 | |
|   if (from->type == time_copy)
 | |
|     {
 | |
|       to->type = time_copy;
 | |
|       to->u.time_copy.tv_sec = from->u.time_copy.tv_sec; 
 | |
|       to->u.time_copy.tv_usec = from->u.time_copy.tv_usec; 
 | |
|     }
 | |
|   else if (from->type == time_final)
 | |
|     {
 | |
|       to->u.time_final.hours = from->u.time_final.hours; 
 | |
|       to->u.time_final.minutes = from->u.time_final.minutes; 
 | |
|       to->u.time_final.seconds = from->u.time_final.seconds; 
 | |
|       to->u.time_final.miliseconds = from->u.time_final.miliseconds; 
 | |
|       to->u.time_final.microseconds = from->u.time_final.microseconds; 
 | |
|     }
 | |
|   MYDDAS_FREE(from,struct myddas_stats_time_struct);
 | |
| }
 | |
| 
 | |
| MYDDAS_STATS_TIME
 | |
| myddas_stats_time_copy_to_final(MYDDAS_STATS_TIME t_copy){
 | |
|   
 | |
|   MYDDAS_STATS_TIME t_final;
 | |
|   MYDDAS_STATS_INITIALIZE_TIME_STRUCT(t_final,time_final);
 | |
|   
 | |
|   myddas_stats_add_seconds_time(t_final,
 | |
| 				t_copy->u.time_copy.tv_sec,
 | |
| 				t_copy->u.time_copy.tv_usec);
 | |
|   
 | |
|   MYDDAS_FREE(t_copy,struct myddas_stats_time_struct);
 | |
|   return t_final;
 | |
| }
 | |
| 
 | |
| static void
 | |
| myddas_stats_add_seconds_time(MYDDAS_STATS_TIME myddas_time,
 | |
| 			      unsigned long sec,
 | |
| 			      unsigned long usec){
 | |
|  
 | |
|   short hours = sec / 3600;					
 | |
|   sec %= 3600;						
 | |
|   short minutes = sec / 60;					
 | |
|   sec %= 60;						
 | |
|   short milisec = usec / 1000;				 
 | |
|   usec %= 1000;
 | |
| 								
 | |
|   myddas_time->u.time_final.microseconds += usec ;			
 | |
|   myddas_time->u.time_final.miliseconds += milisec;			
 | |
|   myddas_time->u.time_final.seconds += sec ;				
 | |
|   myddas_time->u.time_final.minutes += minutes ;			
 | |
|   myddas_time->u.time_final.hours += hours;
 | |
| 
 | |
|   myddas_stats_integrity_of_time(myddas_time);
 | |
| }
 | |
| 
 | |
| 
 | |
| static void
 | |
| myddas_stats_time_subtract(unsigned long *sec,unsigned long *usec,
 | |
| 			   MYDDAS_STATS_TIME start, MYDDAS_STATS_TIME end){
 | |
| 
 | |
|   /* Perform the carry for the later subtraction by updating y. */
 | |
|   if (start->u.time_copy.tv_usec < end->u.time_copy.tv_usec) {
 | |
|     int nsec = (end->u.time_copy.tv_usec - start->u.time_copy.tv_usec) / 1000000 + 1;
 | |
|     end->u.time_copy.tv_usec -= 1000000 * nsec;
 | |
|     end->u.time_copy.tv_sec += nsec;
 | |
|   }
 | |
|   if (start->u.time_copy.tv_usec - end->u.time_copy.tv_usec > 1000000) {
 | |
|     int nsec = (start->u.time_copy.tv_usec - end->u.time_copy.tv_usec) / 1000000;
 | |
|     end->u.time_copy.tv_usec += 1000000 * nsec;
 | |
|     end->u.time_copy.tv_sec -= nsec;
 | |
|   }
 | |
| 
 | |
|   /* Compute the time remaining to wait.
 | |
|      tv_usec is certainly positive. */
 | |
|   *sec = start->u.time_copy.tv_sec - end->u.time_copy.tv_sec;
 | |
|   *usec = start->u.time_copy.tv_usec - end->u.time_copy.tv_usec;
 | |
| }
 | |
| 
 | |
| static void
 | |
| myddas_stats_integrity_of_time(MYDDAS_STATS_TIME myddas_time){
 | |
|   
 | |
|   if (myddas_time->u.time_final.microseconds > 999)			
 | |
|     {
 | |
|       myddas_time->u.time_final.microseconds -= 1000;			
 | |
|       myddas_time->u.time_final.miliseconds++;			
 | |
|     }	
 | |
|   if (myddas_time->u.time_final.miliseconds > 999)			
 | |
|     {								
 | |
|       myddas_time->u.time_final.miliseconds -= 1000;			
 | |
|       myddas_time->u.time_final.seconds++;				
 | |
|     }								
 | |
|   
 | |
|   if (myddas_time->u.time_final.seconds > 59)			
 | |
|     {								
 | |
|       myddas_time->u.time_final.seconds -= 60;			
 | |
|       myddas_time->u.time_final.minutes++;				
 | |
|     }								
 | |
|   
 | |
|   if (myddas_time->u.time_final.minutes > 59)			
 | |
|     {								
 | |
|       myddas_time->u.time_final.minutes -= 60;			
 | |
|       myddas_time->u.time_final.hours++;				
 | |
|     }								
 | |
| }
 | |
| 
 | |
| MYDDAS_GLOBAL
 | |
| myddas_stats_initialize_global_stats(MYDDAS_GLOBAL global){
 | |
|   
 | |
|   MYDDAS_STATS_STRUCT stats = NULL; 
 | |
|   
 | |
|   short i;
 | |
|   
 | |
|   /* For the time statistics */
 | |
|   /*
 | |
|     Stats [1] - Total Time spent on the db_row function 
 | |
|     Stats [2] - Total Time spent on the translate/3 predicate
 | |
|   */
 | |
| 
 | |
|   /* First */
 | |
|   stats = myddas_stats_initialize_stat(stats,time_str);
 | |
|   (global->myddas_statistics)->stats = stats;
 | |
|   for(i=0;i<1;i++){ 
 | |
|     myddas_stats_initialize_stat(stats,time_str);
 | |
|   }
 | |
|   
 | |
|   return global;
 | |
| }
 | |
| 
 | |
| MYDDAS_STATS_STRUCT
 | |
| myddas_stats_initialize_connection_stats(){
 | |
|   /*
 | |
|   Stats [1] - Total of Time Spent by the DB Server processing all the  SQL Querys
 | |
|   Stats [2] - Total of Time Spent by the DB Server processing the last SQL Query
 | |
|   Stats [3] - Total of Time Spent by the DB Server transfering all the results of the  SQL Querys
 | |
|   Stats [4] - Total of Time Spent by the DB Server transfering the result of the last SQL Query 
 | |
|     
 | |
|   Stats [5] - Total number of Rows returned by the server
 | |
|   Stats [6] - Total of Bytes Transfered by the DB Server on all SQL Querys
 | |
|   Stats [7] - Total of Bytes Transfered by the DB Server on the last SQL Query 
 | |
|   Stats [8] - Number of querys made to the DBserver  
 | |
|   */
 | |
| 
 | |
|   short i;
 | |
|   MYDDAS_STATS_STRUCT new = NULL ;
 | |
|   MYDDAS_STATS_STRUCT first;        
 | |
|   /* For the time statistics */ 
 | |
|                
 | |
|   /* First */  
 | |
|   new = myddas_stats_initialize_stat(new,time_str);
 | |
|   first = new;
 | |
|   for(i=0;i<3;i++){                 
 | |
|      new = myddas_stats_initialize_stat(new,time_str);
 | |
|   }                                               
 | |
|                                                   
 | |
|   /* For number statistics*/                      
 | |
|   for (i=0;i<4;i++){                              
 | |
|     new = myddas_stats_initialize_stat(new,integer);  
 | |
|   }
 | |
| 
 | |
|   return first;
 | |
| }
 | |
| 
 | |
| MYDDAS_STATS_STRUCT
 | |
| myddas_stats_initialize_stat(MYDDAS_STATS_STRUCT stat,int type){
 | |
|   
 | |
|   MYDDAS_STATS_STRUCT temp_str = stat;
 | |
| 
 | |
|   if (stat == NULL){
 | |
|     MYDDAS_MALLOC(stat,struct myddas_stats_struct);
 | |
|     temp_str = stat;
 | |
|   } else {
 | |
|     for (;temp_str->nxt != NULL;temp_str = temp_str->nxt);
 | |
|     MYDDAS_MALLOC(temp_str->nxt,struct myddas_stats_struct);
 | |
|     temp_str = temp_str->nxt;
 | |
|   }
 | |
|   
 | |
|   if (type == time_str){
 | |
|     MYDDAS_STATS_INITIALIZE_TIME_STRUCT(temp_str->u.time_str.time_str,time_final);
 | |
|   } else {
 | |
|     temp_str->u.integer.integer = 0;
 | |
|   }
 | |
|   temp_str->type = type;
 | |
|   temp_str->count = 0;
 | |
|   temp_str->nxt = NULL;
 | |
|   return temp_str;
 | |
| }
 | |
| 
 | |
| MYDDAS_STATS_STRUCT
 | |
| myddas_stats_get_stat(MYDDAS_STATS_STRUCT stat,int index){
 | |
|   
 | |
|   MYDDAS_STATS_STRUCT temp = stat;
 | |
| 
 | |
|   for (;index>1;index--){
 | |
|     temp = temp->nxt;
 | |
|   }
 | |
|   return temp;
 | |
| }
 | |
| 
 | |
| void
 | |
| myddas_stats_delete_stats_list(MYDDAS_STATS_STRUCT list){
 | |
|   
 | |
|   MYDDAS_STATS_STRUCT to_delete = list;
 | |
|   
 | |
|   for (;to_delete!=NULL;){
 | |
|     list = list->nxt;
 | |
|  
 | |
|     
 | |
|     if (to_delete->type == time_str){
 | |
|       MYDDAS_FREE(to_delete->u.time_str.time_str,struct myddas_stats_time_struct);
 | |
|     }
 | |
| 
 | |
|     MYDDAS_FREE(to_delete,struct myddas_stats_struct);
 | |
|     
 | |
|     to_delete = list;
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| #endif /* MYDDAS_STATS || MYDDAS_TOP_LEVEL */
 | |
| 
 |