Blame src/components/rapl/tests/rapl_basic.c

Packit Service a1973e
/****************************/
Packit Service a1973e
/* THIS IS OPEN SOURCE CODE */
Packit Service a1973e
/****************************/
Packit Service a1973e
Packit Service a1973e
/**
Packit Service a1973e
 * @author  Vince Weaver
Packit Service a1973e
 *
Packit Service a1973e
 * test case for RAPL component
Packit Service a1973e
 *
Packit Service a1973e
 * @brief
Packit Service a1973e
 *   Tests basic functionality of RAPL component
Packit Service a1973e
 */
Packit Service a1973e
Packit Service a1973e
#include <stdio.h>
Packit Service a1973e
#include <stdlib.h>
Packit Service a1973e
#include <unistd.h>
Packit Service a1973e
#include <string.h>
Packit Service a1973e
Packit Service a1973e
#include "papi.h"
Packit Service a1973e
#include "papi_test.h"
Packit Service a1973e
Packit Service a1973e
#define MAX_RAPL_EVENTS 64
Packit Service a1973e
Packit Service a1973e
Packit Service a1973e
#ifdef BASIC_TEST
Packit Service a1973e
Packit Service a1973e
void run_test(int quiet) {
Packit Service a1973e
Packit Service a1973e
     if (!quiet) {
Packit Service a1973e
	printf("Sleeping 1 second...\n");
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     /* Sleep */
Packit Service a1973e
     sleep(1);
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
#else
Packit Service a1973e
Packit Service a1973e
#define MATRIX_SIZE 1024
Packit Service a1973e
Packit Service a1973e
     static double a[MATRIX_SIZE][MATRIX_SIZE];
Packit Service a1973e
     static double b[MATRIX_SIZE][MATRIX_SIZE];
Packit Service a1973e
     static double c[MATRIX_SIZE][MATRIX_SIZE];
Packit Service a1973e
Packit Service a1973e
/* Naive matrix multiply */
Packit Service a1973e
void run_test(int quiet) {
Packit Service a1973e
Packit Service a1973e
       double s;
Packit Service a1973e
       int i,j,k;
Packit Service a1973e
Packit Service a1973e
       if (!quiet) {
Packit Service a1973e
	 		printf("Doing a naive %dx%d MMM...\n",MATRIX_SIZE,MATRIX_SIZE);
Packit Service a1973e
       }
Packit Service a1973e
Packit Service a1973e
       for(i=0;i
Packit Service a1973e
	 for(j=0;j
Packit Service a1973e
	   a[i][j]=(double)i*(double)j;
Packit Service a1973e
	   b[i][j]=(double)i/(double)(j+5);
Packit Service a1973e
	 }
Packit Service a1973e
       }
Packit Service a1973e
Packit Service a1973e
       for(j=0;j
Packit Service a1973e
	 for(i=0;i
Packit Service a1973e
	   s=0;
Packit Service a1973e
	   for(k=0;k
Packit Service a1973e
	     s+=a[i][k]*b[k][j];
Packit Service a1973e
	   }
Packit Service a1973e
	   c[i][j] = s;
Packit Service a1973e
	 }
Packit Service a1973e
       }
Packit Service a1973e
Packit Service a1973e
       s=0.0;
Packit Service a1973e
       for(i=0;i
Packit Service a1973e
	 	for(j=0;j
Packit Service a1973e
	   		s+=c[i][j];
Packit Service a1973e
	 	}
Packit Service a1973e
       }
Packit Service a1973e
Packit Service a1973e
       if (!quiet) printf("Matrix multiply sum: s=%lf\n",s);
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
#endif
Packit Service a1973e
Packit Service a1973e
int main (int argc, char **argv)
Packit Service a1973e
{
Packit Service a1973e
Packit Service a1973e
    int retval,cid,rapl_cid=-1,numcmp;
Packit Service a1973e
    int EventSet = PAPI_NULL;
Packit Service a1973e
    long long *values;
Packit Service a1973e
    int num_events=0;
Packit Service a1973e
    int code;
Packit Service a1973e
    char event_names[MAX_RAPL_EVENTS][PAPI_MAX_STR_LEN];
Packit Service a1973e
    char units[MAX_RAPL_EVENTS][PAPI_MIN_STR_LEN];
Packit Service a1973e
    int data_type[MAX_RAPL_EVENTS];
Packit Service a1973e
    int r,i;
Packit Service a1973e
    const PAPI_component_info_t *cmpinfo = NULL;
Packit Service a1973e
    PAPI_event_info_t evinfo;
Packit Service a1973e
    long long before_time,after_time;
Packit Service a1973e
    double elapsed_time;
Packit Service a1973e
Packit Service a1973e
#ifdef WRAP_TEST
Packit Service a1973e
Packit Service a1973e
	int do_wrap=0;
Packit Service a1973e
Packit Service a1973e
	if ( argc > 1 ) {
Packit Service a1973e
		if ( strstr( argv[1], "-w" ) ) {
Packit Service a1973e
			do_wrap = 1;
Packit Service a1973e
		}
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
#endif
Packit Service a1973e
Packit Service a1973e
        /* Set TESTS_QUIET variable */
Packit Service a1973e
     tests_quiet( argc, argv );
Packit Service a1973e
Packit Service a1973e
	/* PAPI Initialization */
Packit Service a1973e
     retval = PAPI_library_init( PAPI_VER_CURRENT );
Packit Service a1973e
     if ( retval != PAPI_VER_CURRENT ) {
Packit Service a1973e
	test_fail(__FILE__, __LINE__,"PAPI_library_init failed\n",retval);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     if (!TESTS_QUIET) {
Packit Service a1973e
		printf("Trying all RAPL events\n");
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     numcmp = PAPI_num_components();
Packit Service a1973e
Packit Service a1973e
     for(cid=0; cid
Packit Service a1973e
Packit Service a1973e
	if ( (cmpinfo = PAPI_get_component_info(cid)) == NULL) {
Packit Service a1973e
	   test_fail(__FILE__, __LINE__,"PAPI_get_component_info failed\n", 0);
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	if (strstr(cmpinfo->name,"rapl")) {
Packit Service a1973e
Packit Service a1973e
	   rapl_cid=cid;
Packit Service a1973e
Packit Service a1973e
	   if (!TESTS_QUIET) {
Packit Service a1973e
	      printf("Found rapl component at cid %d\n",rapl_cid);
Packit Service a1973e
	   }
Packit Service a1973e
Packit Service a1973e
           if (cmpinfo->disabled) {
Packit Service a1973e
	      if (!TESTS_QUIET) {
Packit Service a1973e
		 printf("RAPL component disabled: %s\n",
Packit Service a1973e
                        cmpinfo->disabled_reason);
Packit Service a1973e
	      }
Packit Service a1973e
              test_skip(__FILE__,__LINE__,"RAPL component disabled",0);
Packit Service a1973e
           }
Packit Service a1973e
	   break;
Packit Service a1973e
	}
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     /* Component not found */
Packit Service a1973e
     if (cid==numcmp) {
Packit Service a1973e
       test_skip(__FILE__,__LINE__,"No rapl component found\n",0);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     /* Create EventSet */
Packit Service a1973e
     retval = PAPI_create_eventset( &EventSet );
Packit Service a1973e
     if (retval != PAPI_OK) {
Packit Service a1973e
	test_fail(__FILE__, __LINE__,
Packit Service a1973e
                              "PAPI_create_eventset()",retval);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     /* Add all events */
Packit Service a1973e
Packit Service a1973e
     code = PAPI_NATIVE_MASK;
Packit Service a1973e
Packit Service a1973e
     r = PAPI_enum_cmp_event( &code, PAPI_ENUM_FIRST, rapl_cid );
Packit Service a1973e
Packit Service a1973e
     while ( r == PAPI_OK ) {
Packit Service a1973e
Packit Service a1973e
        retval = PAPI_event_code_to_name( code, event_names[num_events] );
Packit Service a1973e
	if ( retval != PAPI_OK ) {
Packit Service a1973e
	   printf("Error translating %#x\n",code);
Packit Service a1973e
	   test_fail( __FILE__, __LINE__,
Packit Service a1973e
                            "PAPI_event_code_to_name", retval );
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	retval = PAPI_get_event_info(code,&evinfo);
Packit Service a1973e
	if (retval != PAPI_OK) {
Packit Service a1973e
	  test_fail( __FILE__, __LINE__,
Packit Service a1973e
             "Error getting event info\n",retval);
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	strncpy(units[num_events],evinfo.units,sizeof(units[0])-1);
Packit Service a1973e
	// buffer must be null terminated to safely use strstr operation on it below
Packit Service a1973e
	units[num_events][sizeof(units[0])-1] = '\0';
Packit Service a1973e
Packit Service a1973e
	data_type[num_events] = evinfo.data_type;
Packit Service a1973e
Packit Service a1973e
        retval = PAPI_add_event( EventSet, code );
Packit Service a1973e
        if (retval != PAPI_OK) {
Packit Service a1973e
	  break; /* We've hit an event limit */
Packit Service a1973e
	}
Packit Service a1973e
	num_events++;
Packit Service a1973e
Packit Service a1973e
        r = PAPI_enum_cmp_event( &code, PAPI_ENUM_EVENTS, rapl_cid );
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     values=calloc(num_events,sizeof(long long));
Packit Service a1973e
     if (values==NULL) {
Packit Service a1973e
	test_fail(__FILE__, __LINE__,
Packit Service a1973e
                              "No memory",retval);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     if (!TESTS_QUIET) {
Packit Service a1973e
	printf("\nStarting measurements...\n\n");
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     /* Start Counting */
Packit Service a1973e
     before_time=PAPI_get_real_nsec();
Packit Service a1973e
     retval = PAPI_start( EventSet);
Packit Service a1973e
     if (retval != PAPI_OK) {
Packit Service a1973e
	test_fail(__FILE__, __LINE__, "PAPI_start()",retval);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     /* Run test */
Packit Service a1973e
     run_test(TESTS_QUIET);
Packit Service a1973e
Packit Service a1973e
     /* Stop Counting */
Packit Service a1973e
     after_time=PAPI_get_real_nsec();
Packit Service a1973e
     retval = PAPI_stop( EventSet, values);
Packit Service a1973e
     if (retval != PAPI_OK) {
Packit Service a1973e
	test_fail(__FILE__, __LINE__, "PAPI_stop()",retval);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     elapsed_time=((double)(after_time-before_time))/1.0e9;
Packit Service a1973e
Packit Service a1973e
     if (!TESTS_QUIET) {
Packit Service a1973e
        printf("\nStopping measurements, took %.3fs, gathering results...\n\n",
Packit Service a1973e
	       elapsed_time);
Packit Service a1973e
Packit Service a1973e
		printf("Scaled energy measurements:\n");
Packit Service a1973e
Packit Service a1973e
		for(i=0;i
Packit Service a1973e
		   if (strstr(units[i],"nJ")) {
Packit Service a1973e
Packit Service a1973e
			  printf("%-40s%12.6f J\t(Average Power %.1fW)\n",
Packit Service a1973e
				event_names[i],
Packit Service a1973e
				(double)values[i]/1.0e9,
Packit Service a1973e
				((double)values[i]/1.0e9)/elapsed_time);
Packit Service a1973e
		   }
Packit Service a1973e
		}
Packit Service a1973e
Packit Service a1973e
		printf("\n");
Packit Service a1973e
		printf("Energy measurement counts:\n");
Packit Service a1973e
Packit Service a1973e
		for(i=0;i
Packit Service a1973e
		   if (strstr(event_names[i],"ENERGY_CNT")) {
Packit Service a1973e
			  printf("%-40s%12lld\t%#08llx\n", event_names[i], values[i], values[i]);
Packit Service a1973e
		   }
Packit Service a1973e
		}
Packit Service a1973e
Packit Service a1973e
		printf("\n");
Packit Service a1973e
		printf("Scaled Fixed values:\n");
Packit Service a1973e
Packit Service a1973e
		for(i=0;i
Packit Service a1973e
		   if (!strstr(event_names[i],"ENERGY")) {
Packit Service a1973e
			 if (data_type[i] == PAPI_DATATYPE_FP64) {
Packit Service a1973e
Packit Service a1973e
				 union {
Packit Service a1973e
				   long long ll;
Packit Service a1973e
				   double fp;
Packit Service a1973e
				 } result;
Packit Service a1973e
Packit Service a1973e
				result.ll=values[i];
Packit Service a1973e
				printf("%-40s%12.3f %s\n", event_names[i], result.fp, units[i]);
Packit Service a1973e
			  }
Packit Service a1973e
		   }
Packit Service a1973e
		}
Packit Service a1973e
Packit Service a1973e
		printf("\n");
Packit Service a1973e
		printf("Fixed value counts:\n");
Packit Service a1973e
Packit Service a1973e
		for(i=0;i
Packit Service a1973e
		   if (!strstr(event_names[i],"ENERGY")) {
Packit Service a1973e
			  if (data_type[i] == PAPI_DATATYPE_UINT64) {
Packit Service a1973e
				printf("%-40s%12lld\t%#08llx\n", event_names[i], values[i], values[i]);
Packit Service a1973e
			  }
Packit Service a1973e
		   }
Packit Service a1973e
		}
Packit Service a1973e
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
#ifdef WRAP_TEST
Packit Service a1973e
	double max_time;
Packit Service a1973e
	unsigned long long max_value = 0;
Packit Service a1973e
	int repeat;
Packit Service a1973e
Packit Service a1973e
	for(i=0;i
Packit Service a1973e
		if (strstr(event_names[i],"ENERGY_CNT")) {
Packit Service a1973e
			if (max_value < (unsigned) values[i]) {
Packit Service a1973e
				max_value = values[i];
Packit Service a1973e
		  	}
Packit Service a1973e
		}
Packit Service a1973e
	}
Packit Service a1973e
	max_time = elapsed_time * ( (double)0xffffffff / (double)max_value );
Packit Service a1973e
	printf("\n");
Packit Service a1973e
	printf ("Approximate time to energy measurement wraparound: %.3f sec or %.3f min.\n", 
Packit Service a1973e
		max_time, max_time/60);
Packit Service a1973e
Packit Service a1973e
	if (do_wrap) {
Packit Service a1973e
		 printf ("Beginning wraparound execution.");
Packit Service a1973e
	     /* Start Counting */
Packit Service a1973e
		 before_time=PAPI_get_real_nsec();
Packit Service a1973e
		 retval = PAPI_start( EventSet);
Packit Service a1973e
		 if (retval != PAPI_OK) {
Packit Service a1973e
			test_fail(__FILE__, __LINE__, "PAPI_start()",retval);
Packit Service a1973e
		 }
Packit Service a1973e
Packit Service a1973e
		 /* Run test */
Packit Service a1973e
		repeat = (int)(max_time/elapsed_time);
Packit Service a1973e
		for (i=0;i< repeat;i++) {
Packit Service a1973e
			run_test(1);
Packit Service a1973e
			printf("."); fflush(stdout);
Packit Service a1973e
		}
Packit Service a1973e
		printf("\n");
Packit Service a1973e
Packit Service a1973e
		 /* Stop Counting */
Packit Service a1973e
		 after_time=PAPI_get_real_nsec();
Packit Service a1973e
		 retval = PAPI_stop( EventSet, values);
Packit Service a1973e
		 if (retval != PAPI_OK) {
Packit Service a1973e
			test_fail(__FILE__, __LINE__, "PAPI_stop()",retval);
Packit Service a1973e
		 }
Packit Service a1973e
Packit Service a1973e
		elapsed_time=((double)(after_time-before_time))/1.0e9;
Packit Service a1973e
		printf("\nStopping measurements, took %.3fs\n\n", elapsed_time);
Packit Service a1973e
Packit Service a1973e
		printf("Scaled energy measurements:\n");
Packit Service a1973e
Packit Service a1973e
		for(i=0;i
Packit Service a1973e
		   if (strstr(units[i],"nJ")) {
Packit Service a1973e
Packit Service a1973e
			  printf("%-40s%12.6f J\t(Average Power %.1fW)\n",
Packit Service a1973e
				event_names[i],
Packit Service a1973e
				(double)values[i]/1.0e9,
Packit Service a1973e
				((double)values[i]/1.0e9)/elapsed_time);
Packit Service a1973e
		   }
Packit Service a1973e
		}
Packit Service a1973e
		printf("\n");
Packit Service a1973e
		printf("Energy measurement counts:\n");
Packit Service a1973e
Packit Service a1973e
		for(i=0;i
Packit Service a1973e
		   if (strstr(event_names[i],"ENERGY_CNT")) {
Packit Service a1973e
			  printf("%-40s%12lld\t%#08llx\n", event_names[i], values[i], values[i]);
Packit Service a1973e
		   }
Packit Service a1973e
		}
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
#endif
Packit Service a1973e
Packit Service a1973e
     /* Done, clean up */
Packit Service a1973e
     retval = PAPI_cleanup_eventset( EventSet );
Packit Service a1973e
     if (retval != PAPI_OK) {
Packit Service a1973e
	test_fail(__FILE__, __LINE__,
Packit Service a1973e
                              "PAPI_cleanup_eventset()",retval);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     retval = PAPI_destroy_eventset( &EventSet );
Packit Service a1973e
     if (retval != PAPI_OK) {
Packit Service a1973e
	test_fail(__FILE__, __LINE__,
Packit Service a1973e
                              "PAPI_destroy_eventset()",retval);
Packit Service a1973e
     }
Packit Service a1973e
Packit Service a1973e
     test_pass( __FILE__ );
Packit Service a1973e
Packit Service a1973e
     return 0;
Packit Service a1973e
}
Packit Service a1973e