/*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;