templeos-info/public/Wb/Demo/TimeIns.HC

36 lines
677 B
HolyC
Executable File

/*Allows you to time insts.
Results vary because the CPU does
parallel and out-of-order execution.
*/
#define SAMPLE_SIZE 10000000
U0 TimeIns()
{
I64 i,start,end,overhead_time,test_time;
F64 d=5.0;
//Measure Loop Overhead
start=GetTSC;
for (i=0;i<SAMPLE_SIZE;i++);
end=GetTSC;
overhead_time=end-start;
"\nOverhead Cycles:%12.6f\n",ToF64(overhead_time)/SAMPLE_SIZE;
start=GetTSC;
for (i=0;i<SAMPLE_SIZE;i++) {
#exe {PassTrace(0b10000000000);};
//Time these insts
d*=1.00001;
#exe {PassTrace(0);};
}
end=GetTSC;
test_time=end-start;
"Measured Cycles:%12.6f\n",ToF64(test_time-overhead_time)/SAMPLE_SIZE;
}
TimeIns;
TimeIns;
TimeIns;