{
int retval, tmp;
int EventSet = PAPI_NULL;
int i;
PAPI_event_info_t info;
long long values;
char event_name[PAPI_MAX_STR_LEN], add_event_str[PAPI_MAX_STR_LEN];
tests_quiet( argc, argv );
retval = PAPI_library_init( PAPI_VER_CURRENT );
if ( retval != PAPI_VER_CURRENT )
test_fail( __FILE__, __LINE__, "PAPI_library_init", retval );
QUIETPRINTF( "Test case %s: start, stop with a derived counter.\n",
__FILE__ );
QUIETPRINTF( "------------------------------------------------\n" );
tmp = PAPI_get_opt( PAPI_DEFDOM, NULL );
QUIETPRINTF( "Default domain is: %d (%s)\n", tmp,
stringify_all_domains( tmp ) );
tmp = PAPI_get_opt( PAPI_DEFGRN, NULL );
QUIETPRINTF( "Default granularity is: %d (%s)\n\n", tmp,
stringify_granularity( tmp ) );
i = PAPI_PRESET_MASK;
do {
if ( PAPI_get_event_info( i, &info ) == PAPI_OK ) {
if ( info.count > 1 ) {
PAPI_events[0] = ( unsigned int ) info.event_code;
break;
}
}
} while ( PAPI_enum_event( &i, 0 ) == PAPI_OK );
if ( PAPI_events[0] == 0 )
CPP_TEST_SKIP( );
retval = PAPI_create_eventset( &EventSet );
if ( retval != PAPI_OK )
CPP_TEST_FAIL( "PAPI_create_eventset", retval );
for ( i = 0; i < PAPI_events_len; i++ ) {
PAPI_event_code_to_name( ( int ) PAPI_events[i], event_name );
if ( !TESTS_QUIET )
QUIETPRINTF( "Adding %s\n", event_name );
retval = PAPI_add_event( EventSet, ( int ) PAPI_events[i] );
if ( retval != PAPI_OK )
CPP_TEST_FAIL( "PAPI_add_event", retval );
}
retval = PAPI_start( EventSet );
if ( retval != PAPI_OK )
test_fail( __FILE__, __LINE__, "PAPI_start", retval );
QUIETPRINTF( "Running do_stuff().\n" );
do_stuff( );
retval = PAPI_stop( EventSet, &values );
if ( retval != PAPI_OK )
test_fail( __FILE__, __LINE__, "PAPI_stop", retval );
sprintf( add_event_str, "%-12s : \t", event_name );
QUIETPRINTF( TAB1, add_event_str, values );
QUIETPRINTF( "------------------------------------------------\n" );
retval = PAPI_cleanup_eventset( EventSet );
if ( retval != PAPI_OK )
CPP_TEST_FAIL( "PAPI_cleanup_eventset", retval );
retval = PAPI_destroy_eventset( &EventSet );
if ( retval != PAPI_OK )
CPP_TEST_FAIL( "PAPI_cleanup_eventset", retval );
#ifndef OLD_TEST_DRIVER
PAPI_shutdown( );
#endif
QUIETPRINTF( "Verification: Does it produce a non-zero value?\n" );
if ( values != 0 ) {
QUIETPRINTF( "Yes: " );
QUIETPRINTF( LLDFMT, values );
QUIETPRINTF( "\n" );
}
CPP_TEST_PASS( );
}