Blame src/components/mx/tests/mx_basic.c

Packit 577717
/**
Packit 577717
 * @author  Vince Weaver
Packit 577717
 *
Packit 577717
 * test case for mx myrinet component
Packit 577717
 *
Packit 577717
 *
Packit 577717
 * @brief
Packit 577717
 *   Tests basic mx myrinet functionality
Packit 577717
 */
Packit 577717
Packit 577717
#include <stdio.h>
Packit 577717
#include <stdlib.h>
Packit 577717
#include <string.h>
Packit 577717
Packit 577717
#include "papi.h"
Packit 577717
#include "papi_test.h"
Packit 577717
Packit 577717
#define NUM_EVENTS 1
Packit 577717
Packit 577717
int main (int argc, char **argv)
Packit 577717
{
Packit 577717
Packit 577717
        int retval,cid,numcmp;
Packit 577717
	int EventSet = PAPI_NULL;
Packit 577717
	long long values[NUM_EVENTS];
Packit 577717
	int code;
Packit 577717
	char event_name[PAPI_MAX_STR_LEN];
Packit 577717
	int total_events=0;
Packit 577717
	int r;
Packit 577717
	const PAPI_component_info_t *cmpinfo = NULL;
Packit 577717
	int quiet=0;
Packit 577717
Packit 577717
        /* Set TESTS_QUIET variable */
Packit 577717
	quiet=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 (!quiet) {
Packit 577717
	   printf("Trying all MX 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", 0);
Packit 577717
	   }
Packit 577717
Packit 577717
	   if (strstr(cmpinfo->name,"mx")) {
Packit 577717
	     if (!quiet) printf("\tFound Myrinet component %d - %s\n", cid, cmpinfo->name);
Packit 577717
	   }
Packit 577717
	   else {
Packit 577717
	     continue;
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
Packit 577717
	   while ( r == PAPI_OK ) {
Packit 577717
	      retval = PAPI_event_code_to_name( code, event_name );
Packit 577717
	      if ( retval != PAPI_OK ) {
Packit 577717
		 printf("Error translating %#x\n",code);
Packit 577717
	         test_fail( __FILE__, __LINE__,
Packit 577717
                            "PAPI_event_code_to_name", retval );
Packit 577717
	      }
Packit 577717
Packit 577717
	      if (!quiet) printf("  %s ",event_name);
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__,
Packit 577717
                              "PAPI_create_eventset()",retval);
Packit 577717
	      }
Packit 577717
Packit 577717
	      retval = PAPI_add_event( EventSet, code );
Packit 577717
	      if (retval != PAPI_OK) {
Packit 577717
	            test_fail(__FILE__, __LINE__,
Packit 577717
                                 "PAPI_add_event()",retval);
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
	      retval = PAPI_stop( EventSet, values);
Packit 577717
	      if (retval != PAPI_OK) {
Packit 577717
	            test_fail(__FILE__, __LINE__, "PAPI_start()",retval);
Packit 577717
	      }
Packit 577717
Packit 577717
	      if (!quiet) printf(" value: %lld\n",values[0]);
Packit 577717
Packit 577717
	      retval = PAPI_cleanup_eventset( EventSet );
Packit 577717
	      if (retval != PAPI_OK) {
Packit 577717
	            test_fail(__FILE__, __LINE__,
Packit 577717
                              "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__,
Packit 577717
                              "PAPI_destroy_eventset()",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
	   }
Packit 577717
        }
Packit 577717
Packit 577717
	if (total_events==0) {
Packit 577717
	   test_skip(__FILE__,__LINE__,"No myrinet events found",0);
Packit 577717
	}
Packit 577717
Packit 577717
	if (!quiet) {
Packit 577717
	  printf("Note: for this test the values are expected to all be 0 as no I/O happens during the test.\n");
Packit 577717
	}
Packit 577717
Packit 577717
	test_pass( __FILE__ );
Packit 577717
Packit 577717
	return 0;
Packit 577717
}
Packit 577717