Blame src/components/host_micpower/utils/host_micpower_plot.c

Packit 577717
/** 
Packit 577717
 * @author  Vince Weaver, Heike McCraw 
Packit 577717
 */
Packit 577717
Packit 577717
#include <stdio.h>
Packit 577717
#include <stdlib.h>
Packit 577717
#include <string.h>
Packit 577717
#include <unistd.h>
Packit 577717
Packit 577717
#include "papi.h"
Packit 577717
Packit 577717
#define MAX_DEVICES (32)
Packit 577717
#define EVENTS_PER_DEVICE 10
Packit 577717
Packit 577717
#define MAX_EVENTS (MAX_DEVICES*EVENTS_PER_DEVICE)
Packit 577717
Packit 577717
char events[MAX_EVENTS][BUFSIZ];
Packit 577717
char filenames[MAX_EVENTS][BUFSIZ];
Packit 577717
Packit 577717
FILE *fff[MAX_EVENTS];
Packit 577717
Packit 577717
static int num_events=0;
Packit 577717
Packit 577717
int main (int argc, char **argv)
Packit 577717
{
Packit 577717
Packit 577717
    int retval,cid,host_micpower_cid=-1,numcmp;
Packit 577717
    int EventSet = PAPI_NULL;
Packit 577717
    long long values[MAX_EVENTS];
Packit 577717
    int i,code,enum_retval;
Packit 577717
    const PAPI_component_info_t *cmpinfo = NULL;
Packit 577717
    long long start_time,before_time,after_time;
Packit 577717
    double elapsed_time,total_time;
Packit 577717
	double energy = 0.0;
Packit 577717
    char event_name[BUFSIZ];
Packit 577717
Packit 577717
	/* PAPI Initialization */
Packit 577717
     retval = PAPI_library_init( PAPI_VER_CURRENT );
Packit 577717
     if ( retval != PAPI_VER_CURRENT ) {
Packit 577717
        fprintf(stderr,"PAPI_library_init failed\n");
Packit 577717
	exit(1);
Packit 577717
     }
Packit 577717
Packit 577717
     numcmp = PAPI_num_components();
Packit 577717
Packit 577717
     for(cid=0; cid
Packit 577717
Packit 577717
	if ( (cmpinfo = PAPI_get_component_info(cid)) == NULL) {
Packit 577717
	   fprintf(stderr,"PAPI_get_component_info failed\n");
Packit 577717
	   exit(1);
Packit 577717
	}
Packit 577717
Packit 577717
	if (strstr(cmpinfo->name,"host_micpower")) {
Packit 577717
	   host_micpower_cid=cid;
Packit 577717
	   printf("Found host_micpower component at cid %d\n", host_micpower_cid);
Packit 577717
Packit 577717
           if (cmpinfo->disabled) {
Packit 577717
	     fprintf(stderr,"No host_micpower events found: %s\n",
Packit 577717
		     cmpinfo->disabled_reason);
Packit 577717
	     exit(1);
Packit 577717
           }
Packit 577717
	   break;
Packit 577717
	}
Packit 577717
     }
Packit 577717
Packit 577717
     /* Component not found */
Packit 577717
     if (cid==numcmp) {
Packit 577717
        fprintf(stderr,"No host_micpower component found\n");
Packit 577717
        exit(1);
Packit 577717
     }
Packit 577717
Packit 577717
     /* Find Events */
Packit 577717
     code = PAPI_NATIVE_MASK;
Packit 577717
Packit 577717
     enum_retval = PAPI_enum_cmp_event( &code, PAPI_ENUM_FIRST, cid );
Packit 577717
Packit 577717
     while ( enum_retval == PAPI_OK ) {
Packit 577717
Packit 577717
       retval = PAPI_event_code_to_name( code, event_name );
Packit 577717
       if ( retval != PAPI_OK ) {
Packit 577717
	  printf("Error translating %#x\n",code);
Packit 577717
	  exit(1);
Packit 577717
       }
Packit 577717
Packit 577717
       printf("Found: %s\n",event_name);
Packit 577717
       strncpy(events[num_events],event_name,BUFSIZ);
Packit 577717
       sprintf(filenames[num_events],"results.%s",event_name);
Packit 577717
       num_events++;
Packit 577717
       
Packit 577717
       if (num_events==MAX_EVENTS) {
Packit 577717
	  printf("Too many events! %d\n",num_events);
Packit 577717
	  exit(1);
Packit 577717
       }
Packit 577717
Packit 577717
       enum_retval = PAPI_enum_cmp_event( &code, PAPI_ENUM_EVENTS, cid );
Packit 577717
Packit 577717
     }
Packit 577717
Packit 577717
     if (num_events==0) {
Packit 577717
        printf("Error!  No host_micpower events found!\n");
Packit 577717
	exit(1);
Packit 577717
     }
Packit 577717
Packit 577717
     /* Open output files */
Packit 577717
     for(i=0;i
Packit 577717
        fff[i]=fopen(filenames[i],"w");
Packit 577717
	if (fff[i]==NULL) {
Packit 577717
	   fprintf(stderr,"Could not open %s\n",filenames[i]);
Packit 577717
	   exit(1);
Packit 577717
	}
Packit 577717
     }
Packit 577717
				   
Packit 577717
Packit 577717
     /* Create EventSet */
Packit 577717
     retval = PAPI_create_eventset( &EventSet );
Packit 577717
     if (retval != PAPI_OK) {
Packit 577717
        fprintf(stderr,"Error creating eventset!\n");
Packit 577717
     }
Packit 577717
Packit 577717
     for(i=0;i
Packit 577717
	
Packit 577717
        retval = PAPI_add_named_event( EventSet, events[i] );
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
	   fprintf(stderr,"Error adding event %s\n",events[i]);
Packit 577717
	}
Packit 577717
     }
Packit 577717
Packit 577717
  
Packit 577717
Packit 577717
     start_time=PAPI_get_real_nsec();
Packit 577717
Packit 577717
     while(1) {
Packit 577717
Packit 577717
        /* Start Counting */
Packit 577717
        before_time=PAPI_get_real_nsec();
Packit 577717
        retval = PAPI_start( EventSet);
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
           fprintf(stderr,"PAPI_start() failed\n");
Packit 577717
	   exit(1);
Packit 577717
        }
Packit 577717
Packit 577717
Packit 577717
        usleep(100000);
Packit 577717
Packit 577717
        /* Stop Counting */
Packit 577717
        after_time=PAPI_get_real_nsec();
Packit 577717
        retval = PAPI_stop( EventSet, values);
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
           fprintf(stderr, "PAPI_start() failed\n");
Packit 577717
        }
Packit 577717
Packit 577717
        total_time=((double)(after_time-start_time))/1.0e9;
Packit 577717
        elapsed_time=((double)(after_time-before_time))/1.0e9;
Packit 577717
Packit 577717
        for(i=0;i
Packit 577717
		if( (strstr(events[i],"vccp") != NULL) || 
Packit 577717
			(strstr(events[i],"vddg") != NULL) || 
Packit 577717
			(strstr(events[i],"vddq") != NULL) ) {
Packit 577717
Packit 577717
		   fprintf(fff[i],"%.4f %.1f (* Average Voltage (Volt) for %s *)\n",
Packit 577717
			   total_time,
Packit 577717
			   ((double)values[i]/1.0e6),
Packit 577717
			   events[i]);
Packit 577717
		} else {
Packit 577717
			if( strstr(events[i],"tot0") != NULL ){
Packit 577717
			energy += elapsed_time*((double)values[i]/1.0e6);
Packit 577717
			fprintf(fff[i],"%.4f %.1f %.1f (* Average Power (Watt) and Energy consumption (kWs) for %s *)\n",
Packit 577717
				total_time,
Packit 577717
				((double)values[i]/1.0e6),
Packit 577717
				energy/1.0e3,
Packit 577717
				events[i]);
Packit 577717
			} else {
Packit 577717
				fprintf(fff[i],"%.4f %.1f (* Average Power (Watt) for %s *)\n",
Packit 577717
						total_time,
Packit 577717
						((double)values[i]/1.0e6),
Packit 577717
						events[i]);
Packit 577717
			}
Packit 577717
		}
Packit 577717
		fflush(fff[i]);
Packit 577717
		}
Packit 577717
	 }
Packit 577717
Packit 577717
	 return 0;
Packit 577717
}
Packit 577717