Blame src/components/example/tests/example_multiple_components.c

Packit 577717
/****************************/
Packit 577717
/* THIS IS OPEN SOURCE CODE */
Packit 577717
/****************************/
Packit 577717
Packit 577717
/**
Packit 577717
 * @file    example_multiple_components.c
Packit 577717
 * @author  Vince Weaver
Packit 577717
 *	    vweaver1@eecs.utk.edu
Packit 577717
 * test if multiple components can be used at once
Packit 577717
 *
Packit 577717
 *
Packit 577717
 * @brief
Packit 577717
 *  This tests to see if the CPU component and Example component
Packit 577717
 *   can be used simultaneously.
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;
Packit 577717
	int EventSet1 = PAPI_NULL, EventSet2 = PAPI_NULL;
Packit 577717
	long long values1[NUM_EVENTS];
Packit 577717
	long long values2[NUM_EVENTS];
Packit 577717
	const PAPI_component_info_t *cmpinfo = NULL;
Packit 577717
	int numcmp,cid,example_cid=-1;
Packit 577717
	int code;
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( "Testing simultaneous component use with PAPI %d.%d.%d\n",
Packit 577717
			PAPI_VERSION_MAJOR( PAPI_VERSION ),
Packit 577717
			PAPI_VERSION_MINOR( PAPI_VERSION ),
Packit 577717
			PAPI_VERSION_REVISION( PAPI_VERSION ) );
Packit 577717
	}
Packit 577717
Packit 577717
	/* Find our component */
Packit 577717
Packit 577717
	numcmp = PAPI_num_components();
Packit 577717
	for( cid=0; cid
Packit 577717
	   if ( (cmpinfo = PAPI_get_component_info(cid)) == NULL) {
Packit 577717
	      test_fail(__FILE__, __LINE__,
Packit 577717
                           "PAPI_get_component_info failed\n", 0);
Packit 577717
	   }
Packit 577717
	   if (!quiet) {
Packit 577717
	      printf("\tComponent %d - %d events - %s\n", cid,
Packit 577717
		     cmpinfo->num_native_events,
Packit 577717
		     cmpinfo->name);
Packit 577717
	   }
Packit 577717
	   if (strstr(cmpinfo->name,"example")) {
Packit 577717
	      /* FOUND! */
Packit 577717
	      example_cid=cid;
Packit 577717
	   }
Packit 577717
	}
Packit 577717
Packit 577717
Packit 577717
	if (example_cid<0) {
Packit 577717
	   test_skip(__FILE__, __LINE__,
Packit 577717
		     "Example component not found\n", 0);
Packit 577717
	}
Packit 577717
Packit 577717
	if (!quiet) {
Packit 577717
	  printf("\nFound Example Component at id %d\n",example_cid);
Packit 577717
	}
Packit 577717
Packit 577717
Packit 577717
	/* Create an eventset for the Example component */
Packit 577717
Packit 577717
	retval = PAPI_create_eventset( &EventSet1 );
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail( __FILE__, __LINE__,
Packit 577717
		      "PAPI_create_eventset() failed\n", retval );
Packit 577717
	}
Packit 577717
Packit 577717
	retval = PAPI_event_name_to_code("EXAMPLE_CONSTANT", &code);
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail( __FILE__, __LINE__,
Packit 577717
		      "EXAMPLE_ZERO not found\n",retval );
Packit 577717
	}
Packit 577717
Packit 577717
	retval = PAPI_add_event( EventSet1, code);
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail( __FILE__, __LINE__,
Packit 577717
		      "PAPI_add_events failed\n", retval );
Packit 577717
	}
Packit 577717
Packit 577717
Packit 577717
	/* Create an eventset for the CPU component */
Packit 577717
Packit 577717
	retval = PAPI_create_eventset( &EventSet2 );
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail( __FILE__, __LINE__,
Packit 577717
		      "PAPI_create_eventset() failed\n", retval );
Packit 577717
	}
Packit 577717
Packit 577717
	retval = PAPI_event_name_to_code("PAPI_TOT_CYC", &code);
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	  test_skip( __FILE__, __LINE__,
Packit 577717
		      "PAPI_TOT_CYC not available\n",retval );
Packit 577717
	}
Packit 577717
Packit 577717
	retval = PAPI_add_event( EventSet2, code);
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_skip( __FILE__, __LINE__,
Packit 577717
		      "NO CPU component found\n", retval );
Packit 577717
	}
Packit 577717
Packit 577717
	if (!quiet) printf("\nStarting EXAMPLE_CONSTANT and PAPI_TOT_CYC at the same time\n");
Packit 577717
Packit 577717
	/* Start CPU component event */
Packit 577717
	retval = PAPI_start( EventSet2 );
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail( __FILE__, __LINE__,
Packit 577717
		      "PAPI_start failed\n",retval );
Packit 577717
	}
Packit 577717
Packit 577717
	/* Start example component */
Packit 577717
	retval = PAPI_start( EventSet1 );
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail( __FILE__, __LINE__,
Packit 577717
		      "PAPI_start failed\n",retval );
Packit 577717
	}
Packit 577717
Packit 577717
Packit 577717
Packit 577717
Packit 577717
	/* Stop example component */
Packit 577717
	retval = PAPI_stop( EventSet1, values1 );
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail(  __FILE__, __LINE__, "PAPI_stop failed\n", retval);
Packit 577717
	}
Packit 577717
Packit 577717
	/* Stop CPU component */
Packit 577717
	retval = PAPI_stop( EventSet2, values2 );
Packit 577717
	if ( retval != PAPI_OK ) {
Packit 577717
	   test_fail(  __FILE__, __LINE__, "PAPI_stop failed\n", retval);
Packit 577717
	}
Packit 577717
Packit 577717
	if (!quiet) printf("Stopping EXAMPLE_CONSTANT and PAPI_TOT_CYC\n\n");
Packit 577717
Packit 577717
Packit 577717
	if (!quiet) printf("Results from EXAMPLE_CONSTANT: %lld\n",values1[0]);
Packit 577717
Packit 577717
	if (values1[0]!=42) {
Packit 577717
	   test_fail(  __FILE__, __LINE__, "Result should be 42!\n", 0);
Packit 577717
	}
Packit 577717
Packit 577717
	if (!quiet) printf("Results from PAPI_TOT_CYC: %lld\n\n",values2[0]);
Packit 577717
Packit 577717
	if (values2[0]<1) {
Packit 577717
	   test_fail(  __FILE__, __LINE__, "Result should greater than 0\n", 0);
Packit 577717
	}
Packit 577717
Packit 577717
	/* Cleanup EventSets */
Packit 577717
	retval = PAPI_cleanup_eventset(EventSet1);
Packit 577717
	if (retval != PAPI_OK) {
Packit 577717
	   test_fail(  __FILE__, __LINE__, "PAPI_cleanup_eventset!\n", retval);
Packit 577717
	}
Packit 577717
Packit 577717
	retval = PAPI_cleanup_eventset(EventSet2);
Packit 577717
	if (retval != PAPI_OK) {
Packit 577717
	   test_fail(  __FILE__, __LINE__, "PAPI_cleanup_eventset!\n", retval);
Packit 577717
	}
Packit 577717
Packit 577717
	/* Destroy EventSets */
Packit 577717
	retval = PAPI_destroy_eventset(&EventSet2);
Packit 577717
	if (retval != PAPI_OK) {
Packit 577717
	   test_fail(  __FILE__, __LINE__, "PAPI_destroy_eventset!\n", retval);
Packit 577717
	}
Packit 577717
Packit 577717
	test_pass( __FILE__ );
Packit 577717
Packit 577717
	return 0;
Packit 577717
}
Packit 577717