Blame src/components/powercap/tests/powercap_basic.c

Packit Service a1973e
/**
Packit Service a1973e
 * @author PAPI team UTK/ICL
Packit Service a1973e
 * Test case for powercap component
Packit Service a1973e
 * @brief
Packit Service a1973e
 *   Tests basic functionality of powercap component
Packit Service a1973e
 */
Packit Service a1973e
Packit Service a1973e
#include <stdio.h>
Packit Service a1973e
#include <stdlib.h>
Packit Service a1973e
#include <string.h>
Packit Service a1973e
#include <unistd.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_powercap_EVENTS 64
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
    sleep( 1 );
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
#else  /* NOT BASIC_TEST */
Packit Service a1973e
Packit Service a1973e
#define MATRIX_SIZE 1024
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 ) printf( "Doing a naive %dx%d MMM...\n",MATRIX_SIZE,MATRIX_SIZE );
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
    (void) argv;
Packit Service a1973e
    (void) argc;
Packit Service a1973e
    int retval,cid,powercap_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_powercap_EVENTS][PAPI_MAX_STR_LEN];
Packit Service a1973e
    char event_descrs[MAX_powercap_EVENTS][PAPI_MAX_STR_LEN];
Packit Service a1973e
    char units[MAX_powercap_EVENTS][PAPI_MIN_STR_LEN];
Packit Service a1973e
    int data_type[MAX_powercap_EVENTS];
Packit Service a1973e
    int r,i;
Packit Service a1973e
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
    /* Set TESTS_QUIET variable */
Packit Service a1973e
    tests_quiet( argc, argv );
Packit Service a1973e
Packit Service a1973e
	/* Currently unimplemented? */
Packit Service a1973e
#if 0
Packit Service a1973e
	int do_wrap = 0;
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
#endif
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
    if ( !TESTS_QUIET ) printf( "Trying all powercap events\n" );
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
        if ( strstr( cmpinfo->name,"powercap" ) ) {
Packit Service a1973e
            powercap_cid=cid;
Packit Service a1973e
            if ( !TESTS_QUIET ) printf( "Found powercap component at cid %d\n",powercap_cid );
Packit Service a1973e
            if ( cmpinfo->disabled ) {
Packit Service a1973e
                if ( !TESTS_QUIET ) {
Packit Service a1973e
                    printf( "powercap component disabled: %s\n",
Packit Service a1973e
                            cmpinfo->disabled_reason );
Packit Service a1973e
                }
Packit Service a1973e
                test_skip( __FILE__,__LINE__,"powercap 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 powercap component found\n",0 );
Packit Service a1973e
Packit Service a1973e
    /* Skip if component has no counters */
Packit Service a1973e
    if ( cmpinfo->num_cntrs==0 )
Packit Service a1973e
        test_skip( __FILE__,__LINE__,"No counters in the powercap component\n",0 );
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__, "PAPI_create_eventset()",retval );
Packit Service a1973e
Packit Service a1973e
    /* Add all events */
Packit Service a1973e
    code = PAPI_NATIVE_MASK;
Packit Service a1973e
    r = PAPI_enum_cmp_event( &code, PAPI_ENUM_FIRST, powercap_cid );
Packit Service a1973e
    while ( r == PAPI_OK ) {
Packit Service a1973e
        retval = PAPI_event_code_to_name( code, event_names[num_events] );
Packit Service a1973e
        if ( retval != PAPI_OK )
Packit Service a1973e
            test_fail( __FILE__, __LINE__,"Error from PAPI_event_code_to_name", retval );
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__, "Error getting event info\n",retval );
Packit Service a1973e
Packit Service a1973e
        strncpy( event_descrs[num_events],evinfo.long_descr,sizeof( event_descrs[0] )-1 );
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
        data_type[num_events] = evinfo.data_type;
Packit Service a1973e
        retval = PAPI_add_event( EventSet, code );
Packit Service a1973e
Packit Service a1973e
        if ( retval != PAPI_OK )
Packit Service a1973e
            break; /* We've hit an event limit */
Packit Service a1973e
        num_events++;
Packit Service a1973e
Packit Service a1973e
        r = PAPI_enum_cmp_event( &code, PAPI_ENUM_EVENTS, powercap_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__,"No memory",retval );
Packit Service a1973e
Packit Service a1973e
    if ( !TESTS_QUIET ) printf( "\nStarting measurements...\n\n" );
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
    /* 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
    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", elapsed_time );
Packit Service a1973e
Packit Service a1973e
        printf( "\n" );
Packit Service a1973e
        printf( "scaled energy measurements:\n" );
Packit Service a1973e
        for( i=0; i
Packit Service a1973e
            if ( strstr( event_names[i],"ENERGY_UJ" ) ) {
Packit Service a1973e
                if ( data_type[i] == PAPI_DATATYPE_UINT64 ) {
Packit Service a1973e
                    printf( "%-45s%-20s%4.6f J (Average Power %.1fW)\n",
Packit Service a1973e
                            event_names[i], event_descrs[i],
Packit Service a1973e
                            ( double )values[i]/1.0e6,
Packit Service a1973e
                            ( ( double )values[i]/1.0e6 )/elapsed_time );
Packit Service a1973e
                }
Packit Service a1973e
            }
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
        printf( "\n" );
Packit Service a1973e
        printf( "energy counts:\n" );
Packit Service a1973e
        for( i=0; i
Packit Service a1973e
            if ( strstr( event_names[i],"ENERGY_UJ" ) ) {
Packit Service a1973e
                if ( data_type[i] == PAPI_DATATYPE_UINT64 ) {
Packit Service a1973e
                    printf( "%-45s%-20s%12lld\t%#08llx\n", event_names[i],
Packit Service a1973e
                            event_descrs[i],
Packit Service a1973e
                            values[i], values[i] );
Packit Service a1973e
                }
Packit Service a1973e
            }
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
        printf( "\n" );
Packit Service a1973e
        printf( "long term time window values:\n" );
Packit Service a1973e
        for( i=0; i
Packit Service a1973e
            if ( strstr( event_names[i],"TIME_WINDOW_A_US" ) ) {
Packit Service a1973e
                if ( data_type[i] == PAPI_DATATYPE_UINT64 ) {
Packit Service a1973e
                    printf( "%-45s%-20s%4f (secs)\n",
Packit Service a1973e
                            event_names[i], event_descrs[i],
Packit Service a1973e
                            ( double )values[i]/1.0e6 );
Packit Service a1973e
                }
Packit Service a1973e
            }
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
        printf( "\n" );
Packit Service a1973e
        printf( "short term time window values:\n" );
Packit Service a1973e
        for( i=0; i
Packit Service a1973e
            if ( strstr( event_names[i],"TIME_WINDOW_B_US" ) ) {
Packit Service a1973e
                if ( data_type[i] == PAPI_DATATYPE_UINT64 ) {
Packit Service a1973e
                    printf( "%-45s%-20s%4f (secs)\n",
Packit Service a1973e
                            event_names[i], event_descrs[i],
Packit Service a1973e
                            ( double )values[i]/1.0e6 );
Packit Service a1973e
                }
Packit Service a1973e
            }
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
        printf( "\n" );
Packit Service a1973e
        printf( "long term power limit:\n" );
Packit Service a1973e
        for( i=0; i
Packit Service a1973e
            if ( strstr( event_names[i],"POWER_LIMIT_A_UW" ) ) {
Packit Service a1973e
                if ( data_type[i] == PAPI_DATATYPE_UINT64 ) {
Packit Service a1973e
                    printf( "%-45s%-20s%4f (watts)\n",
Packit Service a1973e
                            event_names[i], event_descrs[i],
Packit Service a1973e
                            ( double )values[i]/1.0e6 );
Packit Service a1973e
                }
Packit Service a1973e
            }
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
        printf( "\n" );
Packit Service a1973e
        printf( "short term power limit:\n" );
Packit Service a1973e
        for( i=0; i
Packit Service a1973e
            if ( strstr( event_names[i],"POWER_LIMIT_B_UW" ) ) {
Packit Service a1973e
                if ( data_type[i] == PAPI_DATATYPE_UINT64 ) {
Packit Service a1973e
                    printf( "%-45s%-20s%4f (watts)\n",
Packit Service a1973e
                            event_names[i], event_descrs[i],
Packit Service a1973e
                            ( double )values[i]/1.0e6 );
Packit Service a1973e
                }
Packit Service a1973e
            }
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
    }
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__,"PAPI_cleanup_eventset()",retval );
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__, "PAPI_destroy_eventset()",retval );
Packit Service a1973e
Packit Service a1973e
    test_pass( __FILE__ );
Packit Service a1973e
Packit Service a1973e
    return 0;
Packit Service a1973e
}
Packit Service a1973e