blob: 08b814273d6c0141b2c4a8b2c1dda46d6f6b5bc0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
#include <stdio.h>
#include "inlineasm.h"
#include <stdlib.h>
#define MEASURE_METHOD optmemmeasure
#define FIELD_SIZE 20000
int main(int argc, char* argv[]) {
char *field = malloc(FIELD_SIZE);
int i,j;
uint64_t time=0;
// fill array with crap
for (i=0;i < FIELD_SIZE; ++i) {
field[i]=(i+2342) % 255;
}
for(i=0; i<FIELD_SIZE; ++i) {
time=optmemmeasure(field,i);
if (time < 1000)
fprintf(stdout,"%d %lld\n",i,time);
// scrambeled eggs
for (j=0;j<FIELD_SIZE-1;++j) {
field[i]=(field[i]*field[i+1]) % 255;
}
field[FIELD_SIZE-1] = (field[FIELD_SIZE-1]*field[0]) % 255;
}
return 0;
}
|