Blame src/papi_vector.c

Packit Service a1973e
/*
Packit Service a1973e
 * File:    papi_vector.c
Packit Service a1973e
 * Author:  Kevin London
Packit Service a1973e
 *          london@cs.utk.edu
Packit Service a1973e
 * Mods:    Haihang You
Packit Service a1973e
 *	       you@cs.utk.edu
Packit Service a1973e
 * Mods:    <Your name here>
Packit Service a1973e
 *          <Your email here>
Packit Service a1973e
 */
Packit Service a1973e
Packit Service a1973e
#include "papi.h"
Packit Service a1973e
#include "papi_internal.h"
Packit Service a1973e
#include "papi_vector.h"
Packit Service a1973e
#include "papi_memory.h"
Packit Service a1973e
Packit Service a1973e
#include <string.h>
Packit Service a1973e
Packit Service a1973e
#ifdef _AIX
Packit Service a1973e
Packit Service a1973e
/* needed because the get_virt_usec() code uses a hardware context */
Packit Service a1973e
/* which is a pmapi definition on AIX.                             */
Packit Service a1973e
#include <pmapi.h>
Packit Service a1973e
#endif
Packit Service a1973e
Packit Service a1973e
Packit Service a1973e
void
Packit Service a1973e
_vectors_error(  )
Packit Service a1973e
{
Packit Service a1973e
	SUBDBG( "function is not implemented in the component!\n" );
Packit Service a1973e
	exit( PAPI_ECMP );
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
int
Packit Service a1973e
vec_int_ok_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return PAPI_OK;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
int
Packit Service a1973e
vec_int_one_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return 1;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
int
Packit Service a1973e
vec_int_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return PAPI_ECMP;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
void *
Packit Service a1973e
vec_void_star_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return NULL;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
void
Packit Service a1973e
vec_void_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
long long
Packit Service a1973e
vec_long_long_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return PAPI_ECMP;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
long long
Packit Service a1973e
vec_long_long_context_dummy( hwd_context_t *ignored )
Packit Service a1973e
{
Packit Service a1973e
        (void) ignored;
Packit Service a1973e
Packit Service a1973e
	return PAPI_ECMP;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
char *
Packit Service a1973e
vec_char_star_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return NULL;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
long
Packit Service a1973e
vec_long_dummy(  )
Packit Service a1973e
{
Packit Service a1973e
	return PAPI_ECMP;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
long long vec_virt_cycles(void)
Packit Service a1973e
{
Packit Service a1973e
  return ((long long) _papi_os_vector.get_virt_usec() * 
Packit Service a1973e
	  _papi_hwi_system_info.hw_info.cpu_max_mhz);
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
long long vec_real_nsec_dummy(void)
Packit Service a1973e
{
Packit Service a1973e
  return ((long long) _papi_os_vector.get_real_usec() * 1000);
Packit Service a1973e
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
long long vec_virt_nsec_dummy(void)
Packit Service a1973e
{
Packit Service a1973e
  return ((long long) _papi_os_vector.get_virt_usec() * 1000);
Packit Service a1973e
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
Packit Service a1973e
int
Packit Service a1973e
_papi_hwi_innoculate_vector( papi_vector_t * v )
Packit Service a1973e
{
Packit Service a1973e
	if ( !v )
Packit Service a1973e
		return ( PAPI_EINVAL );
Packit Service a1973e
Packit Service a1973e
	/* component function pointers */
Packit Service a1973e
	if ( !v->dispatch_timer )
Packit Service a1973e
		v->dispatch_timer =
Packit Service a1973e
			( void ( * )( int, hwd_siginfo_t *, void * ) ) vec_void_dummy;
Packit Service a1973e
	if ( !v->get_overflow_address )
Packit Service a1973e
		v->get_overflow_address =
Packit Service a1973e
			( void *( * )( int, char *, int ) ) vec_void_star_dummy;
Packit Service a1973e
	if ( !v->start )
Packit Service a1973e
		v->start = ( int ( * )( hwd_context_t *, hwd_control_state_t * ) )
Packit Service a1973e
			vec_int_dummy;
Packit Service a1973e
	if ( !v->stop )
Packit Service a1973e
		v->stop = ( int ( * )( hwd_context_t *, hwd_control_state_t * ) )
Packit Service a1973e
			vec_int_dummy;
Packit Service a1973e
	if ( !v->read )
Packit Service a1973e
		v->read = ( int ( * )
Packit Service a1973e
					( hwd_context_t *, hwd_control_state_t *, long long **,
Packit Service a1973e
					  int ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->reset )
Packit Service a1973e
		v->reset = ( int ( * )( hwd_context_t *, hwd_control_state_t * ) )
Packit Service a1973e
			vec_int_dummy;
Packit Service a1973e
	if ( !v->write )
Packit Service a1973e
		v->write =
Packit Service a1973e
			( int ( * )( hwd_context_t *, hwd_control_state_t *, long long[] ) )
Packit Service a1973e
			vec_int_dummy;
Packit Service a1973e
	if ( !v->cleanup_eventset ) 
Packit Service a1973e
		v->cleanup_eventset = ( int ( * )( hwd_control_state_t * ) ) vec_int_ok_dummy;
Packit Service a1973e
	if ( !v->stop_profiling )
Packit Service a1973e
		v->stop_profiling =
Packit Service a1973e
			( int ( * )( ThreadInfo_t *, EventSetInfo_t * ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->init_component )
Packit Service a1973e
		v->init_component = ( int ( * )( int ) ) vec_int_ok_dummy;
Packit Service a1973e
	if ( !v->init_thread )
Packit Service a1973e
		v->init_thread = ( int ( * )( hwd_context_t * ) ) vec_int_ok_dummy;
Packit Service a1973e
	if ( !v->init_control_state )
Packit Service a1973e
		v->init_control_state =
Packit Service a1973e
			( int ( * )( hwd_control_state_t * ptr ) ) vec_void_dummy;
Packit Service a1973e
	if ( !v->update_control_state )
Packit Service a1973e
		v->update_control_state = ( int ( * )
Packit Service a1973e
									( hwd_control_state_t *, NativeInfo_t *,
Packit Service a1973e
									  int, hwd_context_t * ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->ctl )
Packit Service a1973e
		v->ctl = ( int ( * )( hwd_context_t *, int, _papi_int_option_t * ) )
Packit Service a1973e
			vec_int_dummy;
Packit Service a1973e
	if ( !v->set_overflow )
Packit Service a1973e
		v->set_overflow =
Packit Service a1973e
			( int ( * )( EventSetInfo_t *, int, int ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->set_profile )
Packit Service a1973e
		v->set_profile =
Packit Service a1973e
			( int ( * )( EventSetInfo_t *, int, int ) ) vec_int_dummy;
Packit Service a1973e
Packit Service a1973e
	if ( !v->set_domain )
Packit Service a1973e
		v->set_domain =
Packit Service a1973e
			( int ( * )( hwd_control_state_t *, int ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->ntv_enum_events )
Packit Service a1973e
		v->ntv_enum_events = ( int ( * )( unsigned int *, int ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->ntv_name_to_code )
Packit Service a1973e
		v->ntv_name_to_code =
Packit Service a1973e
			( int ( * )( const char *, unsigned int * ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->ntv_code_to_name )
Packit Service a1973e
		v->ntv_code_to_name =
Packit Service a1973e
			( int ( * )( unsigned int, char *, int ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->ntv_code_to_descr )
Packit Service a1973e
		v->ntv_code_to_descr =
Packit Service a1973e
			( int ( * )( unsigned int, char *, int ) ) vec_int_ok_dummy;
Packit Service a1973e
	if ( !v->ntv_code_to_bits )
Packit Service a1973e
		v->ntv_code_to_bits =
Packit Service a1973e
			( int ( * )( unsigned int, hwd_register_t * ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->ntv_code_to_info )
Packit Service a1973e
		v->ntv_code_to_info =
Packit Service a1973e
			( int ( * )( unsigned int, PAPI_event_info_t * ) ) vec_int_dummy;
Packit Service a1973e
Packit Service a1973e
	if ( !v->allocate_registers )
Packit Service a1973e
		v->allocate_registers =
Packit Service a1973e
			( int ( * )( EventSetInfo_t * ) ) vec_int_ok_dummy;
Packit Service a1973e
Packit Service a1973e
	if ( !v->shutdown_thread )
Packit Service a1973e
		v->shutdown_thread = ( int ( * )( hwd_context_t * ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->shutdown_component )
Packit Service a1973e
		v->shutdown_component = ( int ( * )( void ) ) vec_int_ok_dummy;
Packit Service a1973e
	if ( !v->user )
Packit Service a1973e
		v->user = ( int ( * )( int, void *, void * ) ) vec_int_dummy;
Packit Service a1973e
	return PAPI_OK;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
Packit Service a1973e
int
Packit Service a1973e
_papi_hwi_innoculate_os_vector( papi_os_vector_t * v )
Packit Service a1973e
{
Packit Service a1973e
	if ( !v )
Packit Service a1973e
		return ( PAPI_EINVAL );
Packit Service a1973e
Packit Service a1973e
	if ( !v->get_real_cycles )
Packit Service a1973e
		v->get_real_cycles = vec_long_long_dummy;
Packit Service a1973e
	if ( !v->get_real_usec )
Packit Service a1973e
		v->get_real_usec = vec_long_long_dummy;
Packit Service a1973e
	if ( !v->get_real_nsec )
Packit Service a1973e
		v->get_real_nsec = vec_real_nsec_dummy;
Packit Service a1973e
	if ( !v->get_virt_cycles )
Packit Service a1973e
		v->get_virt_cycles = vec_virt_cycles;
Packit Service a1973e
	if ( !v->get_virt_usec )
Packit Service a1973e
		v->get_virt_usec = vec_long_long_dummy;
Packit Service a1973e
	if ( !v->get_virt_nsec )
Packit Service a1973e
		v->get_virt_nsec = vec_virt_nsec_dummy;
Packit Service a1973e
Packit Service a1973e
	if ( !v->update_shlib_info )
Packit Service a1973e
		v->update_shlib_info = ( int ( * )( papi_mdi_t * ) ) vec_int_dummy;
Packit Service a1973e
	if ( !v->get_system_info )
Packit Service a1973e
		v->get_system_info = ( int ( * )(  ) ) vec_int_dummy;
Packit Service a1973e
Packit Service a1973e
	if ( !v->get_memory_info )
Packit Service a1973e
		v->get_memory_info =
Packit Service a1973e
			( int ( * )( PAPI_hw_info_t *, int ) ) vec_int_dummy;
Packit Service a1973e
Packit Service a1973e
	if ( !v->get_dmem_info )
Packit Service a1973e
		v->get_dmem_info = ( int ( * )( PAPI_dmem_info_t * ) ) vec_int_dummy;
Packit Service a1973e
Packit Service a1973e
	return PAPI_OK;
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
/* not used?  debug only? */
Packit Service a1973e
#if 0
Packit Service a1973e
static void *
Packit Service a1973e
vector_find_dummy( void *func, char **buf )
Packit Service a1973e
{
Packit Service a1973e
	void *ptr = NULL;
Packit Service a1973e
Packit Service a1973e
	if ( vec_int_ok_dummy == ( int ( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_int_ok_dummy;
Packit Service a1973e
		if ( buf != NULL )
Packit Service a1973e
			*buf = papi_strdup( "vec_int_ok_dummy" );
Packit Service a1973e
	} else if ( vec_int_one_dummy == ( int ( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_int_one_dummy;
Packit Service a1973e
		if ( buf != NULL )
Packit Service a1973e
			*buf = papi_strdup( "vec_int_one_dummy" );
Packit Service a1973e
	} else if ( vec_int_dummy == ( int ( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_int_dummy;
Packit Service a1973e
		if ( buf != NULL )
Packit Service a1973e
			*buf = papi_strdup( "vec_int_dummy" );
Packit Service a1973e
	} else if ( vec_void_dummy == ( void ( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_void_dummy;
Packit Service a1973e
		if ( buf != NULL )
Packit Service a1973e
			*buf = papi_strdup( "vec_void_dummy" );
Packit Service a1973e
	} else if ( vec_void_star_dummy == ( void *( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_void_star_dummy;
Packit Service a1973e
		if ( buf != NULL )
Packit Service a1973e
			*buf = papi_strdup( "vec_void_star_dummy" );
Packit Service a1973e
	} else if ( vec_long_long_dummy == ( long long ( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_long_long_dummy;
Packit Service a1973e
		if ( buf != NULL )
Packit Service a1973e
			*buf = papi_strdup( "vec_long_long_dummy" );
Packit Service a1973e
	} else if ( vec_char_star_dummy == ( char *( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_char_star_dummy;
Packit Service a1973e
		*buf = papi_strdup( "vec_char_star_dummy" );
Packit Service a1973e
	} else if ( vec_long_dummy == ( long ( * )(  ) ) func ) {
Packit Service a1973e
		ptr = ( void * ) vec_long_dummy;
Packit Service a1973e
		if ( buf != NULL )
Packit Service a1973e
			*buf = papi_strdup( "vec_long_dummy" );
Packit Service a1973e
	} else {
Packit Service a1973e
		ptr = NULL;
Packit Service a1973e
	}
Packit Service a1973e
	return ( ptr );
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
Packit Service a1973e
static void
Packit Service a1973e
vector_print_routine( void *func, char *fname, int pfunc )
Packit Service a1973e
{
Packit Service a1973e
	void *ptr = NULL;
Packit Service a1973e
	char *buf = NULL;
Packit Service a1973e
Packit Service a1973e
	ptr = vector_find_dummy( func, &buf );
Packit Service a1973e
	if ( ptr ) {
Packit Service a1973e
		printf( "DUMMY: %s is mapped to %s.\n",
Packit Service a1973e
				fname, buf );
Packit Service a1973e
		papi_free( buf );
Packit Service a1973e
	} else if ( ( !ptr && pfunc ) )
Packit Service a1973e
		printf( "function: %s is mapped to %p.\n",
Packit Service a1973e
				fname, func );
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
static void
Packit Service a1973e
vector_print_table( papi_vector_t * v, int print_func )
Packit Service a1973e
{
Packit Service a1973e
Packit Service a1973e
	if ( !v )
Packit Service a1973e
		return;
Packit Service a1973e
Packit Service a1973e
	vector_print_routine( ( void * ) v->dispatch_timer,
Packit Service a1973e
						  "_papi_hwd_dispatch_timer", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->get_overflow_address,
Packit Service a1973e
						  "_papi_hwd_get_overflow_address", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->start, "_papi_hwd_start", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->stop, "_papi_hwd_stop", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->read, "_papi_hwd_read", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->reset, "_papi_hwd_reset", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->write, "_papi_hwd_write", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->cleanup_eventset, 
Packit Service a1973e
						  "_papi_hwd_cleanup_eventset", print_func );
Packit Service a1973e
Packit Service a1973e
	vector_print_routine( ( void * ) v->stop_profiling,
Packit Service a1973e
						  "_papi_hwd_stop_profiling", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->init_component,
Packit Service a1973e
						  "_papi_hwd_init_component", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->init_thread, "_papi_hwd_init_thread", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->init_control_state,
Packit Service a1973e
						  "_papi_hwd_init_control_state", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->ctl, "_papi_hwd_ctl", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->set_overflow, "_papi_hwd_set_overflow",
Packit Service a1973e
						  print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->set_profile, "_papi_hwd_set_profile",
Packit Service a1973e
						  print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->set_domain, "_papi_hwd_set_domain",
Packit Service a1973e
						  print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->ntv_enum_events,
Packit Service a1973e
						  "_papi_hwd_ntv_enum_events", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->ntv_name_to_code,
Packit Service a1973e
						  "_papi_hwd_ntv_name_to_code", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->ntv_code_to_name,
Packit Service a1973e
						  "_papi_hwd_ntv_code_to_name", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->ntv_code_to_descr,
Packit Service a1973e
						  "_papi_hwd_ntv_code_to_descr", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->ntv_code_to_bits,
Packit Service a1973e
						  "_papi_hwd_ntv_code_to_bits", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->ntv_code_to_info,
Packit Service a1973e
						  "_papi_hwd_ntv_code_to_info", print_func );
Packit Service a1973e
Packit Service a1973e
	vector_print_routine( ( void * ) v->allocate_registers,
Packit Service a1973e
						  "_papi_hwd_allocate_registers", print_func );
Packit Service a1973e
Packit Service a1973e
	vector_print_routine( ( void * ) v->shutdown_thread, "_papi_hwd_shutdown_thread",
Packit Service a1973e
						  print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->shutdown_component,
Packit Service a1973e
						  "_papi_hwd_shutdown_component", print_func );
Packit Service a1973e
	vector_print_routine( ( void * ) v->user, "_papi_hwd_user", print_func );
Packit Service a1973e
}
Packit Service a1973e
Packit Service a1973e
#endif