Blame src/components/infiniband_umad/tests/infiniband_umad_values_by_code.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  Jose Pedro Oliveira
Packit Service a1973e
 *
Packit Service a1973e
 * test case for the linux-infiniband component
Packit Service a1973e
 * Adapted from its counterpart in the net component.
Packit Service a1973e
 *
Packit Service a1973e
 * @brief
Packit Service a1973e
 *   Prints the value of every net event (by code)
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
Packit Service a1973e
#include "papi.h"
Packit Service a1973e
#include "papi_test.h"
Packit Service a1973e
Packit Service a1973e
#define PINGADDR   "127.0.0.1"
Packit Service a1973e
Packit Service a1973e
int main (int argc, char **argv)
Packit Service a1973e
{
Packit Service a1973e
    int retval,cid,numcmp;
Packit Service a1973e
    int EventSet = PAPI_NULL;
Packit Service a1973e
    long long value;
Packit Service a1973e
    int code;
Packit Service a1973e
    char event_name[PAPI_MAX_STR_LEN];
Packit Service a1973e
    int total_events=0;
Packit Service a1973e
    int r;
Packit Service a1973e
    const PAPI_component_info_t *cmpinfo = NULL;
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 net 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",-1);
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
        if (!TESTS_QUIET) {
Packit Service a1973e
            printf("Component %d - %d events - %s\n", cid,
Packit Service a1973e
                cmpinfo->num_native_events, cmpinfo->name);
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
        if ( strstr(cmpinfo->name, "infiniband") == NULL) {
Packit Service a1973e
            continue;
Packit Service a1973e
        }
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, cid );
Packit Service a1973e
        while ( r == PAPI_OK ) {
Packit Service a1973e
Packit Service a1973e
            retval = PAPI_event_code_to_name( code, event_name );
Packit Service a1973e
            if ( retval != PAPI_OK ) {
Packit Service a1973e
                test_fail( __FILE__, __LINE__, "PAPI_event_code_to_name", retval );
Packit Service a1973e
            }
Packit Service a1973e
Packit Service a1973e
            if (!TESTS_QUIET) {
Packit Service a1973e
                printf("%#x %-24s = ", code, event_name);
Packit Service a1973e
            }
Packit Service a1973e
Packit Service a1973e
            EventSet = PAPI_NULL;
Packit Service a1973e
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
Packit Service a1973e
            retval = PAPI_add_event( EventSet, code );
Packit Service a1973e
            if (retval != PAPI_OK) {
Packit Service a1973e
                test_fail(__FILE__, __LINE__, "PAPI_add_event()", retval);
Packit Service a1973e
            }
Packit Service a1973e
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
            if (strcmp(event_name, "_recv") == 0) {
Packit Service a1973e
                /* XXX figure out a general method to  generate some traffic 
Packit Service a1973e
                 * for infiniband
Packit Service a1973e
                 * the operation should take more than one second in order
Packit Service a1973e
                 * to guarantee that the network counters are updated */
Packit Service a1973e
                retval = system("ping -c 4 " PINGADDR " > /dev/null");
Packit Service a1973e
                if (retval < 0) {
Packit Service a1973e
					test_fail(__FILE__, __LINE__, "Unable to start ping", retval);
Packit Service a1973e
				}
Packit Service a1973e
            }
Packit Service a1973e
Packit Service a1973e
            retval = PAPI_stop( EventSet, &value );
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
            if (!TESTS_QUIET) printf("%lld\n", value);
Packit Service a1973e
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
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
Packit Service a1973e
            total_events++;
Packit Service a1973e
Packit Service a1973e
            r = PAPI_enum_cmp_event( &code, PAPI_ENUM_EVENTS, cid );
Packit Service a1973e
        }
Packit Service a1973e
Packit Service a1973e
    }
Packit Service a1973e
Packit Service a1973e
    if (total_events==0) {
Packit Service a1973e
        test_skip(__FILE__,__LINE__,"No net events found", 0);
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
Packit Service a1973e
// vim:set ai ts=4 sw=4 sts=4 et: