40 int l1_size,l2_size,l1_linesize,l2_linesize,l2_entries;
51 printf(
"Testing the PAPI_L2_DCA event\n");
76 if ((l2_size==0) || (l2_linesize==0)) {
78 printf(
"Unable to determine size of L2 cache!\n");
84 printf(
"\tDetected %dk L1 DCache, %dB linesize\n",
85 l1_size/1024,l1_linesize);
86 printf(
"\tDetected %dk L2 DCache, %dB linesize, %d entries\n",
87 l2_size/1024,l2_linesize,l2_entries);
90 arraysize=l2_size/
sizeof(double);
93 printf(
"\tAllocating %zu bytes of memory (%d doubles)\n",
94 arraysize*
sizeof(
double),arraysize);
97 array=calloc(arraysize,
sizeof(
double));
99 test_fail(__FILE__,__LINE__,
"Can't allocate memory",0);
107 printf(
"\nWrite Test: Initializing an array of %d doubles:\n",
111 high=0; low=0;
total=0;
113 for(
i=0;
i<num_runs;
i++) {
124 "reading PAPI_L2_DCA",
retval );
132 average=(
total/num_runs);
134 expected=arraysize/(l2_linesize/
sizeof(double));
137 printf(
"\tShould be roughly " 138 "arraysize/L2_linesize/double_size (%d/%d/%zu): " 140 arraysize,l2_linesize,
sizeof(
double),
146 if ((error > 1.0) || (error<-1.0)) {
147 if (!
quiet) printf(
"Instruction count off by more than 1%%\n");
151 if (!
quiet) printf(
"\n");
158 printf(
"\nRead Test: Summing an array of %d doubles:\n",
162 high=0; low=0;
total=0;
164 for(
i=0;
i<num_runs;
i++) {
175 "reading PAPI_L2_DCA",
retval );
183 average=(
total/num_runs);
185 expected=arraysize/(l2_linesize/
sizeof(double));
188 printf(
"\tShould be roughly " 189 "arraysize/L2_linesize/double_size (%d/%d/%zu): " 191 arraysize,l2_linesize,
sizeof(
double),
197 if ((error > 1.0) || (error<-1.0)) {
198 if (!
quiet) printf(
"Instruction count off by more than 1%%\n");
209 test_warn( __FILE__, __LINE__,
"Error too high", 1 );
int PAPI_stop(int EventSet, long long *values)
void test_pass(const char *filename)
static int expected[NUM_THREADS]
int PAPI_reset(int EventSet)
double display_error(long long average, long long high, long long low, long long expected, int quiet)
static double array[ARRAYSIZE]
void test_warn(const char *file, int line, const char *call, int retval)
void test_skip(const char *file, int line, const char *call, int retval)
int PAPI_add_named_event(int EventSet, const char *EventName)
int PAPI_library_init(int version)
int cache_write_test(double *array, int size)
long long get_linesize(int type)
int PAPI_create_eventset(int *EventSet)
long long get_cachesize(int type)
int tests_quiet(int argc, char **argv)
void test_fail(const char *file, int line, const char *call, int retval)
int PAPI_start(int EventSet)
long long get_entries(int type)
double cache_read_test(double *array, int size)