Blame src/components/infiniband/tests/infiniband_values_by_code.c

Packit 577717
/****************************/
Packit 577717
/* THIS IS OPEN SOURCE CODE */
Packit 577717
/****************************/
Packit 577717
Packit 577717
/**
Packit 577717
 * @author  Jose Pedro Oliveira
Packit 577717
 *
Packit 577717
 * test case for the linux-infiniband component
Packit 577717
 * Adapted from its counterpart in the net component.
Packit 577717
 *
Packit 577717
 * @brief
Packit 577717
 *   Prints the value of every native event (by code)
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
#include "papi_test.h"
Packit 577717
Packit 577717
int main (int argc, char **argv)
Packit 577717
{
Packit 577717
    int retval,cid,numcmp;
Packit 577717
    int EventSet = PAPI_NULL;
Packit 577717
    long long *values = 0;
Packit 577717
    int *codes = 0;
Packit 577717
    char *names = 0;
Packit 577717
    int code, i;
Packit 577717
    int total_events=0;
Packit 577717
    int r;
Packit 577717
    const PAPI_component_info_t *cmpinfo = NULL;
Packit 577717
Packit 577717
    /* Set TESTS_QUIET variable */
Packit 577717
    tests_quiet( argc, argv );
Packit 577717
Packit 577717
    /* PAPI Initialization */
Packit 577717
    retval = PAPI_library_init( PAPI_VER_CURRENT );
Packit 577717
    if ( retval != PAPI_VER_CURRENT ) {
Packit 577717
        test_fail(__FILE__, __LINE__,"PAPI_library_init failed\n",retval);
Packit 577717
    }
Packit 577717
Packit 577717
    if (!TESTS_QUIET) {
Packit 577717
        printf("Trying all infiniband events\n");
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
            test_fail(__FILE__, __LINE__,"PAPI_get_component_info failed\n",-1);
Packit 577717
        }
Packit 577717
Packit 577717
        if (!TESTS_QUIET) {
Packit 577717
            printf("Component %d - %d events - %s\n", cid,
Packit 577717
                cmpinfo->num_native_events, cmpinfo->name);
Packit 577717
        }
Packit 577717
Packit 577717
        if ( strstr(cmpinfo->name, "infiniband") == NULL) {
Packit 577717
            continue;
Packit 577717
        }
Packit 577717
        if (cmpinfo->disabled) {
Packit 577717
            test_skip(__FILE__,__LINE__,"Component infiniband is disabled", 0);
Packit 577717
            continue;
Packit 577717
        }
Packit 577717
Packit 577717
        values = (long long*) malloc(sizeof(long long) * cmpinfo->num_native_events);
Packit 577717
        codes = (int*) malloc(sizeof(int) * cmpinfo->num_native_events);
Packit 577717
        names = (char*) malloc(PAPI_MAX_STR_LEN * cmpinfo->num_native_events);
Packit 577717
Packit 577717
        EventSet = PAPI_NULL;
Packit 577717
Packit 577717
        retval = PAPI_create_eventset( &EventSet );
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
            test_fail(__FILE__, __LINE__, "PAPI_create_eventset()", retval);
Packit 577717
        }
Packit 577717
Packit 577717
        code = PAPI_NATIVE_MASK;
Packit 577717
Packit 577717
        r = PAPI_enum_cmp_event( &code, PAPI_ENUM_FIRST, cid );
Packit 577717
        i = 0;
Packit 577717
        while ( r == PAPI_OK ) {
Packit 577717
Packit 577717
            retval = PAPI_event_code_to_name( code, &names[i*PAPI_MAX_STR_LEN] );
Packit 577717
            if ( retval != PAPI_OK ) {
Packit 577717
                test_fail( __FILE__, __LINE__, "PAPI_event_code_to_name", retval );
Packit 577717
            }
Packit 577717
            codes[i] = code;
Packit 577717
Packit 577717
            retval = PAPI_add_event( EventSet, code );
Packit 577717
            if (retval != PAPI_OK) {
Packit 577717
                test_fail(__FILE__, __LINE__, "PAPI_add_event()", retval);
Packit 577717
            }
Packit 577717
Packit 577717
            total_events++;
Packit 577717
Packit 577717
            r = PAPI_enum_cmp_event( &code, PAPI_ENUM_EVENTS, cid );
Packit 577717
            i += 1;
Packit 577717
        }
Packit 577717
Packit 577717
        retval = PAPI_start( EventSet );
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
            test_fail(__FILE__, __LINE__, "PAPI_start()", retval);
Packit 577717
        }
Packit 577717
Packit 577717
        /* XXX figure out a general method to  generate some traffic 
Packit 577717
         * for infiniband
Packit 577717
         * the operation should take more than one second in order
Packit 577717
         * to guarantee that the network counters are updated */
Packit 577717
        /* For now, just sleep for 10 seconds */
Packit 577717
        sleep(10);
Packit 577717
Packit 577717
        retval = PAPI_stop( EventSet, values);
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
            test_fail(__FILE__, __LINE__, "PAPI_stop()", retval);
Packit 577717
        }
Packit 577717
Packit 577717
        if (!TESTS_QUIET) {
Packit 577717
           for (i=0 ; i<cmpinfo->num_native_events ; ++i)
Packit 577717
               printf("%#x %-24s = %lld\n", codes[i], names+i*PAPI_MAX_STR_LEN, values[i]);
Packit 577717
        }
Packit 577717
Packit 577717
        retval = PAPI_cleanup_eventset( EventSet );
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
            test_fail(__FILE__, __LINE__, "PAPI_cleanup_eventset()", retval);
Packit 577717
        }
Packit 577717
Packit 577717
        retval = PAPI_destroy_eventset( &EventSet );
Packit 577717
        if (retval != PAPI_OK) {
Packit 577717
            test_fail(__FILE__, __LINE__, "PAPI_destroy_eventset()", retval);
Packit 577717
        }
Packit 577717
Packit 577717
        free(names);
Packit 577717
        free(codes);
Packit 577717
        free(values);
Packit 577717
    }
Packit 577717
Packit 577717
    if (total_events==0) {
Packit 577717
        test_skip(__FILE__,__LINE__,"No infiniband events found", 0);
Packit 577717
    }
Packit 577717
Packit 577717
    test_pass( __FILE__ );
Packit 577717
Packit 577717
    return 0;
Packit 577717
}
Packit 577717
Packit 577717
// vim:set ai ts=4 sw=4 sts=4 et: