我正在使用的处理器架构有一个时间标签计数器,我想读取它来进行性能测量。时间标签计数器的内存映射到
地址0x90000008。我用了下面的程序来读取
不过,打印输出中的差异始终为零。任何人一个主意
我错过了什么?

char* const ADDR = (char *) 0x90000008;

unsigned long cycle_count_val() {

   unsigned long res;

   asm volatile (

   "set ADDR, %%l0           \n\t"
   "ld [%%l0], %0            \n\t"

   : "=r" (res)
   :
   : "%l0"
  );

  return res;
}

....
unsigned long start = cycle_count_val();
execute_benchmark();
unsigned long end = cycle_count_val();

printf("Benchmark performance(in clock cycles) = %ld \r\n", end-start);

非常感谢你的帮助,
菲尔

最佳答案

我不认为你需要求助于阿塞姆伯——为什么你不能直接阅读:

uint32_t tbr = (*((uint32_t volatile *) 0x90000008))

10-05 21:09
查看更多