Blame src/ctests/all_events.c

Packit Service a1973e
/* This file tries to add,start,stop, and remove all pre-defined events.
Packit Service a1973e
 * It is meant not to test the accuracy of the mapping but to make sure
Packit Service a1973e
 * that all events in the component will at least start (Helps to
Packit Service a1973e
 * catch typos).
Packit Service a1973e
 *
Packit Service a1973e
 * Author: Kevin London
Packit Service a1973e
 *         london@cs.utk.edu
Packit Service a1973e
 */
Packit Service a1973e
Packit Service a1973e
#include <stdio.h>
Packit Service a1973e
#include <stdlib.h>
Packit Service a1973e
Packit Service a1973e
#include "papi.h"
Packit Service a1973e
#include "papi_test.h"
Packit Service a1973e
Packit Service a1973e
int
Packit Service a1973e
main( int argc, char **argv )
Packit Service a1973e
{
Packit Service a1973e
	int retval, i;
Packit Service a1973e
	int EventSet = PAPI_NULL, count = 0, err_count = 0;
Packit Service a1973e
	long long values;
Packit Service a1973e
	PAPI_event_info_t info;
Packit Service a1973e
	int quiet=0;
Packit Service a1973e
	char error_message[BUFSIZ];
Packit Service a1973e
Packit Service a1973e
	/* Set TESTS_QUIET variable */
Packit Service a1973e
	quiet=tests_quiet( argc, argv );
Packit Service a1973e
Packit Service a1973e
	if (!quiet) {
Packit Service a1973e
		printf("\nTrying all pre-defined events:\n");
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	/* Initialize PAPI */
Packit Service a1973e
	retval = PAPI_library_init( PAPI_VER_CURRENT );
Packit Service a1973e
	if ( retval != PAPI_VER_CURRENT ) {
Packit Service a1973e
		test_fail( __FILE__, __LINE__, "PAPI_library_init", retval );
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	/* Create an EventSet */
Packit Service a1973e
	retval = PAPI_create_eventset( &EventSet );
Packit Service a1973e
	if ( retval != PAPI_OK ) {
Packit Service a1973e
		test_fail( __FILE__, __LINE__, "PAPI_create_eventset", retval );
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	/* Add all preset events */
Packit Service a1973e
	for ( i = 0; i < PAPI_MAX_PRESET_EVENTS; i++ ) {
Packit Service a1973e
Packit Service a1973e
		if ( PAPI_get_event_info( PAPI_PRESET_MASK | i, &info ) != PAPI_OK )
Packit Service a1973e
			continue;
Packit Service a1973e
Packit Service a1973e
		if ( !( info.count ) )
Packit Service a1973e
			continue;
Packit Service a1973e
Packit Service a1973e
		if (!quiet) printf( "Adding %-14s", info.symbol );
Packit Service a1973e
Packit Service a1973e
		retval = PAPI_add_event( EventSet, ( int ) info.event_code );
Packit Service a1973e
		if ( retval != PAPI_OK ) {
Packit Service a1973e
			if (!quiet) {
Packit Service a1973e
				printf("Error adding event %s\n",info.symbol);
Packit Service a1973e
				if (retval==PAPI_ECNFLCT) {
Packit Service a1973e
					printf("Probably NMI watchdog related\n");
Packit Service a1973e
				}
Packit Service a1973e
			}
Packit Service a1973e
			if (retval==PAPI_ECNFLCT) {
Packit Service a1973e
				sprintf(error_message,"Problem adding %s (probably NMI Watchdog related)",info.symbol);
Packit Service a1973e
			}
Packit Service a1973e
			else {
Packit Service a1973e
				sprintf(error_message,"Problem adding %s",info.symbol);
Packit Service a1973e
			}
Packit Service a1973e
			test_warn( __FILE__, __LINE__, error_message, retval );
Packit Service a1973e
			err_count++;
Packit Service a1973e
		} else {
Packit Service a1973e
			retval = PAPI_start( EventSet );
Packit Service a1973e
			if ( retval != PAPI_OK ) {
Packit Service a1973e
				PAPI_perror( "PAPI_start" );
Packit Service a1973e
				err_count++;
Packit Service a1973e
			} else {
Packit Service a1973e
				retval = PAPI_stop( EventSet, &values );
Packit Service a1973e
				if ( retval != PAPI_OK ) {
Packit Service a1973e
					PAPI_perror( "PAPI_stop" );
Packit Service a1973e
					err_count++;
Packit Service a1973e
				} else {
Packit Service a1973e
					if (!quiet) printf( "successful\n" );
Packit Service a1973e
					count++;
Packit Service a1973e
				}
Packit Service a1973e
			}
Packit Service a1973e
			retval = PAPI_remove_event( EventSet, ( int ) info.event_code );
Packit Service a1973e
			if ( retval != PAPI_OK )
Packit Service a1973e
				test_fail( __FILE__, __LINE__, "PAPI_remove_event", retval );
Packit Service a1973e
		}
Packit Service a1973e
	}
Packit Service a1973e
	retval = PAPI_destroy_eventset( &EventSet );
Packit Service a1973e
	if ( retval != PAPI_OK )
Packit Service a1973e
		test_fail( __FILE__, __LINE__, "PAPI_destroy_eventset", retval );
Packit Service a1973e
Packit Service a1973e
	if (!quiet) {
Packit Service a1973e
		printf( "Successfully added, started and stopped %d events.\n", count );
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	if ( err_count ) {
Packit Service a1973e
		if (!quiet) printf( "Failed to add, start or stop %d events.\n", err_count );
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	if (count<=0) {
Packit Service a1973e
		test_fail( __FILE__, __LINE__, "No events added", 1 );
Packit Service a1973e
	}
Packit Service a1973e
Packit Service a1973e
	test_pass( __FILE__ );
Packit Service a1973e
Packit Service a1973e
	return 0;
Packit Service a1973e
Packit Service a1973e
}