|
Packit |
577717 |
/* This file performs the following test: start, stop and
|
|
Packit |
577717 |
timer functionality for L1 related events
|
|
Packit |
577717 |
|
|
Packit |
577717 |
- They are counted in the default counting domain and default
|
|
Packit |
577717 |
granularity, depending on the platform. Usually this is
|
|
Packit |
577717 |
the user domain (PAPI_DOM_USER) and thread context (PAPI_GRN_THR).
|
|
Packit |
577717 |
|
|
Packit |
577717 |
- Start counters
|
|
Packit |
577717 |
- Do iterations
|
|
Packit |
577717 |
- Stop and read counters
|
|
Packit |
577717 |
*/
|
|
Packit |
577717 |
|
|
Packit |
577717 |
#include <stdio.h>
|
|
Packit |
577717 |
#include <stdlib.h>
|
|
Packit |
577717 |
|
|
Packit |
577717 |
#include "papi.h"
|
|
Packit |
577717 |
#include "papi_test.h"
|
|
Packit |
577717 |
|
|
Packit |
577717 |
#include "do_loops.h"
|
|
Packit |
577717 |
|
|
Packit |
577717 |
#define OUT_FMT "%12d\t%12lld\t%12lld\t%.2f\n"
|
|
Packit |
577717 |
|
|
Packit |
577717 |
|
|
Packit |
577717 |
int
|
|
Packit |
577717 |
main( int argc, char **argv )
|
|
Packit |
577717 |
{
|
|
Packit |
577717 |
int retval, i, j;
|
|
Packit |
577717 |
int EventSet = PAPI_NULL;
|
|
Packit |
577717 |
long long values[2];
|
|
Packit |
577717 |
const PAPI_hw_info_t *hwinfo = NULL;
|
|
Packit |
577717 |
char descr[PAPI_MAX_STR_LEN];
|
|
Packit |
577717 |
PAPI_event_info_t evinfo;
|
|
Packit |
577717 |
PAPI_mh_level_t *L;
|
|
Packit |
577717 |
|
|
Packit |
577717 |
|
|
Packit |
577717 |
const int eventlist[] = {
|
|
Packit |
577717 |
PAPI_L1_DCA,
|
|
Packit |
577717 |
PAPI_L1_DCM,
|
|
Packit |
577717 |
PAPI_L1_DCH,
|
|
Packit |
577717 |
PAPI_L2_DCA,
|
|
Packit |
577717 |
PAPI_L2_DCM,
|
|
Packit |
577717 |
PAPI_L2_DCH,
|
|
Packit |
577717 |
#if 0
|
|
Packit |
577717 |
PAPI_L1_LDM,
|
|
Packit |
577717 |
PAPI_L1_STM,
|
|
Packit |
577717 |
PAPI_L1_DCR,
|
|
Packit |
577717 |
PAPI_L1_DCW,
|
|
Packit |
577717 |
PAPI_L1_ICM,
|
|
Packit |
577717 |
PAPI_L1_TCM,
|
|
Packit |
577717 |
PAPI_LD_INS,
|
|
Packit |
577717 |
PAPI_SR_INS,
|
|
Packit |
577717 |
PAPI_LST_INS,
|
|
Packit |
577717 |
PAPI_L2_DCR,
|
|
Packit |
577717 |
PAPI_L2_DCW,
|
|
Packit |
577717 |
PAPI_CSR_TOT,
|
|
Packit |
577717 |
PAPI_MEM_SCY,
|
|
Packit |
577717 |
PAPI_MEM_RCY,
|
|
Packit |
577717 |
PAPI_MEM_WCY,
|
|
Packit |
577717 |
PAPI_L1_ICH,
|
|
Packit |
577717 |
PAPI_L1_ICA,
|
|
Packit |
577717 |
PAPI_L1_ICR,
|
|
Packit |
577717 |
PAPI_L1_ICW,
|
|
Packit |
577717 |
PAPI_L1_TCH,
|
|
Packit |
577717 |
PAPI_L1_TCA,
|
|
Packit |
577717 |
PAPI_L1_TCR,
|
|
Packit |
577717 |
PAPI_L1_TCW,
|
|
Packit |
577717 |
PAPI_L2_DCM,
|
|
Packit |
577717 |
PAPI_L2_ICM,
|
|
Packit |
577717 |
PAPI_L2_TCM,
|
|
Packit |
577717 |
PAPI_L2_LDM,
|
|
Packit |
577717 |
PAPI_L2_STM,
|
|
Packit |
577717 |
PAPI_L2_DCH,
|
|
Packit |
577717 |
PAPI_L2_DCA,
|
|
Packit |
577717 |
PAPI_L2_DCR,
|
|
Packit |
577717 |
PAPI_L2_DCW,
|
|
Packit |
577717 |
PAPI_L2_ICH,
|
|
Packit |
577717 |
PAPI_L2_ICA,
|
|
Packit |
577717 |
PAPI_L2_ICR,
|
|
Packit |
577717 |
PAPI_L2_ICW,
|
|
Packit |
577717 |
PAPI_L2_TCH,
|
|
Packit |
577717 |
PAPI_L2_TCA,
|
|
Packit |
577717 |
PAPI_L2_TCR,
|
|
Packit |
577717 |
PAPI_L2_TCW,
|
|
Packit |
577717 |
#endif
|
|
Packit |
577717 |
0
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
tests_quiet( argc, argv ); /* Set TESTS_QUIET variable */
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval =
|
|
Packit |
577717 |
PAPI_library_init( PAPI_VER_CURRENT ) ) != PAPI_VER_CURRENT )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_library_init", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( hwinfo = PAPI_get_hardware_info( ) ) == NULL ) {
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_get_hardware_info", 2 );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval = PAPI_create_eventset( &EventSet ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_create_eventset", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Extract and report the cache information */
|
|
Packit |
577717 |
L = ( PAPI_mh_level_t * ) ( hwinfo->mem_hierarchy.level );
|
|
Packit |
577717 |
for ( i = 0; i < hwinfo->mem_hierarchy.levels; i++ ) {
|
|
Packit |
577717 |
for ( j = 0; j < 2; j++ ) {
|
|
Packit |
577717 |
int tmp;
|
|
Packit |
577717 |
|
|
Packit |
577717 |
tmp = PAPI_MH_CACHE_TYPE( L[i].cache[j].type );
|
|
Packit |
577717 |
if ( tmp == PAPI_MH_TYPE_UNIFIED ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "L%d Unified ", i + 1 );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_DATA ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "L%d Data ", i + 1 );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_INST ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "L%d Instruction ", i + 1 );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_VECTOR ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "L%d Vector ", i + 1 );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_TRACE ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "L%d Trace ", i + 1 );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_EMPTY ) {
|
|
Packit |
577717 |
break;
|
|
Packit |
577717 |
} else {
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__,
|
|
Packit |
577717 |
"PAPI_get_hardware_info",
|
|
Packit |
577717 |
PAPI_EBUG );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
tmp = PAPI_MH_CACHE_WRITE_POLICY( L[i].cache[j].type );
|
|
Packit |
577717 |
if ( tmp == PAPI_MH_TYPE_WB ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "Write back " );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_WT ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "Write through " );
|
|
Packit |
577717 |
} else {
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_get_hardware_info",
|
|
Packit |
577717 |
PAPI_EBUG );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
tmp = PAPI_MH_CACHE_REPLACEMENT_POLICY( L[i].cache[j].type );
|
|
Packit |
577717 |
if ( tmp == PAPI_MH_TYPE_PSEUDO_LRU ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "Pseudo LRU policy " );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_LRU ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "LRU policy " );
|
|
Packit |
577717 |
} else if ( tmp == PAPI_MH_TYPE_UNKNOWN ) {
|
|
Packit |
577717 |
if (!TESTS_QUIET) printf( "Unknown policy " );
|
|
Packit |
577717 |
} else {
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_get_hardware_info",
|
|
Packit |
577717 |
PAPI_EBUG );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if (!TESTS_QUIET) {
|
|
Packit |
577717 |
printf( "Cache:\n" );
|
|
Packit |
577717 |
if ( L[i].cache[j].type ) {
|
|
Packit |
577717 |
printf( " Total size: %dKB\n"
|
|
Packit |
577717 |
" Line size: %dB\n"
|
|
Packit |
577717 |
" Number of Lines: %d\n"
|
|
Packit |
577717 |
" Associativity: %d\n\n",
|
|
Packit |
577717 |
( L[i].cache[j].size ) >> 10,
|
|
Packit |
577717 |
L[i].cache[j].line_size,
|
|
Packit |
577717 |
L[i].cache[j].num_lines,
|
|
Packit |
577717 |
L[i].cache[j].associativity );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
for ( i = 0; eventlist[i] != 0; i++ ) {
|
|
Packit |
577717 |
if (PAPI_event_code_to_name( eventlist[i], descr ) != PAPI_OK)
|
|
Packit |
577717 |
continue;
|
|
Packit |
577717 |
if ( PAPI_add_event( EventSet, eventlist[i] ) != PAPI_OK )
|
|
Packit |
577717 |
continue;
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( PAPI_get_event_info( eventlist[i], &evinfo ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_get_event_info", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if (!TESTS_QUIET) {
|
|
Packit |
577717 |
printf( "\nEvent: %s\nShort: %s\nLong: %s\n\n",
|
|
Packit |
577717 |
evinfo.symbol, evinfo.short_descr,
|
|
Packit |
577717 |
evinfo.long_descr );
|
|
Packit |
577717 |
printf( " Bytes\t\tCold\t\tWarm\tPercent\n" );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval = PAPI_start( EventSet ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_start", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
for ( j = 512; j <= 16 * ( 1024 * 1024 ); j = j * 2 ) {
|
|
Packit |
577717 |
do_misses( 1, j );
|
|
Packit |
577717 |
do_flush( );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval = PAPI_reset( EventSet ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_reset", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
do_misses( 1, j );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval = PAPI_read( EventSet, &values[0] ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_read", retval );
|
|
Packit |
577717 |
if ( ( retval = PAPI_reset( EventSet ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_reset", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
do_misses( 1, j );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval = PAPI_read( EventSet, &values[1] ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_read", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if (!TESTS_QUIET) {
|
|
Packit |
577717 |
printf( OUT_FMT, j,
|
|
Packit |
577717 |
values[0], values[1],
|
|
Packit |
577717 |
( ( float ) values[1] /
|
|
Packit |
577717 |
( float ) ( ( values[0] !=0 ) ?
|
|
Packit |
577717 |
values[0] : 1 ) * 100.0 ) );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval = PAPI_stop( EventSet, NULL ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_stop", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval =
|
|
Packit |
577717 |
PAPI_remove_event( EventSet, eventlist[i] ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_remove_event", retval );
|
|
Packit |
577717 |
}
|
|
Packit |
577717 |
|
|
Packit |
577717 |
if ( ( retval = PAPI_destroy_eventset( &EventSet ) ) != PAPI_OK )
|
|
Packit |
577717 |
test_fail( __FILE__, __LINE__, "PAPI_destroy_eventset", retval );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
test_pass( __FILE__ );
|
|
Packit |
577717 |
|
|
Packit |
577717 |
return 0;
|
|
Packit |
577717 |
}
|