Blob Blame History Raw
/* This file performs the following test: event_code_to_name */

#include <stdio.h>
#include <stdlib.h>

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

static void
test_continue( const char *call, int retval )
{
	if (!TESTS_QUIET) {
		printf( "Expected error in %s: %s\n", call,
			PAPI_strerror(retval) );
	}
}

int
main( int argc, char **argv )
{
	int retval;
	int code = PAPI_TOT_CYC, last;
	char event_name[PAPI_MAX_STR_LEN];
	const PAPI_component_info_t *cmp_info;
	int quiet;

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


	retval = PAPI_library_init( PAPI_VER_CURRENT );
	if ( retval != PAPI_VER_CURRENT )
		test_fail( __FILE__, __LINE__, "PAPI_library_init", retval );

	if (!quiet) {
		printf( "Test case code2name.c: "
			"Check limits and indexing of event tables.\n");
		printf( "Looking for PAPI_TOT_CYC...\n" );
	}

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

	if (!quiet) printf( "Found |%s|\n", event_name );

	code = PAPI_FP_OPS;

	if (!quiet) {
		printf( "Looking for highest defined preset event "
			"(PAPI_FP_OPS): %#x...\n",code );
	}

	retval = PAPI_event_code_to_name( code, event_name );
	if ( retval != PAPI_OK )
		test_fail( __FILE__, __LINE__, "PAPI_event_code_to_name", retval );

	if (!quiet) printf( "Found |%s|\n", event_name );

	code = PAPI_PRESET_MASK | ( PAPI_MAX_PRESET_EVENTS - 1 );

	if (!quiet) {
		printf( "Looking for highest allocated preset event:"
			" %#x...\n", code );
	}

	retval = PAPI_event_code_to_name( code, event_name );
	if ( retval != PAPI_OK ) {
		test_continue( "PAPI_event_code_to_name", retval );
	}
	else {
		if (!quiet) printf( "Found |%s|\n", event_name );
	}

	code = PAPI_PRESET_MASK | ( unsigned int ) PAPI_NATIVE_AND_MASK;

	if (!quiet) {
		printf( "Looking for highest possible preset event:"
			" %#x...\n", code );
	}

	retval = PAPI_event_code_to_name( code, event_name );

	if ( retval != PAPI_OK ) {
		test_continue( "PAPI_event_code_to_name", retval );
	}
	else {
		if (!quiet) printf( "Found |%s|\n", event_name );
	}

	/* Find the first defined native event in component 0 */
	/* For platform independence, always ASK FOR the first event */
	/* Don't just assume it'll be the first numeric value */
	code = PAPI_NATIVE_MASK;
	PAPI_enum_event( &code, PAPI_ENUM_FIRST );

	if (!quiet) {
		printf( "Looking for first native event: %#x...\n", code );
	}

	retval = PAPI_event_code_to_name( code, event_name );
	if ( retval != PAPI_OK ) {
		if (!quiet) printf("Could not find first native event\n");
		test_skip( __FILE__, __LINE__, "PAPI_event_code_to_name", retval );
	}
	else {
	  if (!quiet) printf( "Found |%s|\n", event_name );
	}

	/* Find the last defined native event */

	/* FIXME: hardcoded cmp 0 */
	cmp_info = PAPI_get_component_info( 0 );
	if ( cmp_info == NULL ) {
	   test_fail( __FILE__, __LINE__,
                      "PAPI_get_component_info", PAPI_ECMP );
	}

	code = PAPI_NATIVE_MASK;
	last = code;
	PAPI_enum_event( &code, PAPI_ENUM_FIRST );

	while ( PAPI_enum_event( &code, PAPI_ENUM_EVENTS ) == PAPI_OK ) {
	  last=code;
	}

	code = last;
	if (!quiet) printf( "Looking for last native event: %#x...\n", code );
	retval = PAPI_event_code_to_name( code, event_name );
	if ( retval != PAPI_OK ) {
		test_fail( __FILE__, __LINE__, "PAPI_event_code_to_name", retval );
	}
	else {
	   if (!quiet) printf( "Found |%s|\n", event_name );
	}

	/* Highly doubtful we have this many natives */
	/* Turn on all bits *except* PRESET bit and COMPONENT bits */
	code = PAPI_PRESET_AND_MASK;
	if (!quiet) printf( "Looking for highest definable native event: %#x...\n", code );
	retval = PAPI_event_code_to_name( code, event_name );
	if ( retval != PAPI_OK ) {
		test_continue( "PAPI_event_code_to_name", retval );
	}
	else {
		if (!quiet) printf( "Found |%s|\n", event_name );
	}

	if ( ( retval == PAPI_ENOCMP) || ( retval == PAPI_ENOEVNT ) || ( retval == PAPI_OK ) ) {
		test_pass( __FILE__ );
	}

	test_fail( __FILE__, __LINE__, "PAPI_event_code_to_name", PAPI_EBUG );

	return 1;
}