|
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 |
|