Blob Blame History Raw
#include <stdio.h>
#include <stdlib.h>

#include "papi.h"
#include "papi_test.h"

#include "do_loops.h"

int
main( int argc, char **argv )
{
	int FPEventSet = PAPI_NULL;
	long long values;
	int PAPI_event, retval;
	char event_name[PAPI_MAX_STR_LEN];
	int quiet;

	/* Set TESTS_QUIET variable */
	quiet=tests_quiet( argc, argv );

        /* init PAPI */
	retval = PAPI_library_init( PAPI_VER_CURRENT );
	if (retval != PAPI_VER_CURRENT ) {
		test_fail( __FILE__, __LINE__, "PAPI_library_init", retval );
	}

	/* Use PAPI_FP_INS if available, otherwise use PAPI_TOT_INS */
	if ( PAPI_query_event( PAPI_FP_INS ) == PAPI_OK )
		PAPI_event = PAPI_FP_INS;
	else
		PAPI_event = PAPI_TOT_INS;

	retval = PAPI_query_event( PAPI_event );
	if (retval != PAPI_OK ) {
		if (!quiet) printf("Trouble querying event\n");
		test_skip( __FILE__, __LINE__, "PAPI_query_event", retval );
	}

        /* Create the eventset */
	if ( ( retval = PAPI_create_eventset( &FPEventSet ) ) != PAPI_OK )
		test_fail( __FILE__, __LINE__, "PAPI_create_eventset", retval );

        /* Add event to the eventset */
	if ( ( retval = PAPI_add_event( FPEventSet, PAPI_event ) ) != PAPI_OK )
		test_fail( __FILE__, __LINE__, "PAPI_add_event", retval );

	/* Start counting */
	if ( ( retval = PAPI_start( FPEventSet ) ) != PAPI_OK )
		test_fail( __FILE__, __LINE__, "PAPI_start", retval );

	/* Try to cleanup while running */
        /* Fail test if this isn't refused */
	if ( ( retval = PAPI_cleanup_eventset( FPEventSet ) ) != PAPI_EISRUN )
		test_fail( __FILE__, __LINE__, "PAPI_cleanup_eventset", retval );

	/* Try to destroy eventset while running */
	/* Fail test if this isn't refused */
	if ( ( retval = PAPI_destroy_eventset( &FPEventSet ) ) != PAPI_EISRUN )
		test_fail( __FILE__, __LINE__, "PAPI_destroy_eventset", retval );

	/* do some work */
	do_flops( 1000000 );

	/* stop counting */
	if ( ( retval = PAPI_stop( FPEventSet, &values ) ) != PAPI_OK )
		test_fail( __FILE__, __LINE__, "PAPI_stop", retval );

	/* Try to destroy eventset without cleaning first */
	/* Fail test if this isn't refused */
	if ( ( retval = PAPI_destroy_eventset( &FPEventSet ) ) != PAPI_EINVAL )
		test_fail( __FILE__, __LINE__, "PAPI_destroy_eventset", retval );

	/* Try to cleanup eventset.  */
	/* This should pass.         */
	if ( ( retval = PAPI_cleanup_eventset( FPEventSet ) ) != PAPI_OK )
		test_fail( __FILE__, __LINE__, "PAPI_cleanup_eventset", retval );

	/* Try to destroy eventset.  */
	/* This should pass.         */
	if ( ( retval = PAPI_destroy_eventset( &FPEventSet ) ) != PAPI_OK )
		test_fail( __FILE__, __LINE__, "PAPI_destroy_eventset", retval );

	/* Make sure eventset was set to PAPI_NULL */
	if ( FPEventSet != PAPI_NULL )
		test_fail( __FILE__, __LINE__, "FPEventSet != PAPI_NULL", retval );

	if ( !quiet ) {
		if ( ( retval =
			   PAPI_event_code_to_name( PAPI_event, event_name ) ) != PAPI_OK )
			test_fail( __FILE__, __LINE__, "PAPI_event_code_to_name", retval );

		printf( "Test case John May 2: cleanup / destroy eventset.\n" );
		printf( "-------------------------------------------------\n" );
		printf( "Test run    : \t1\n" );
		printf( "%s : \t", event_name );
		printf( LLDFMT, values );
		printf( "\n" );
		printf( "-------------------------------------------------\n" );
		printf( "The following messages will appear if PAPI is compiled with debug enabled:\n" );
		printf
			( "\tPAPI Error Code -10: PAPI_EISRUN: EventSet is currently counting\n" );
		printf
			( "\tPAPI Error Code -10: PAPI_EISRUN: EventSet is currently counting\n" );
		printf( "\tPAPI Error Code -1: PAPI_EINVAL: Invalid argument\n" );
	}
	test_pass( __FILE__ );

	return 0;
}