PAPI通常是这样使用的:
Initialize Lib
Add Event(s)
PAPI_start()
someCalculation()
PAPI_stop()但是,我有一个应用程序,它的代码如下所示:
start = time()
someCalculation()
t = time() - start;我想重写这个时间()函数,它位于另一个文件中。我的代码:
static int INIT=0;
int retval;
static int eventSet = PAPI_NULL;
long long res[1];
if(INIT){
// eventSet is NOT PAPI_NULL here!
if ((retval = PAPI_stop(eventSet, res)) != PAPI_OK)
handle_error(retval);
return res[0]/1e9;
}
INIT = 1;
retval = PAPI_library_init(PAPI_VER_CURRENT);
if ((retval = PAPI_create_eventset(&eventSet)) != PAPI_OK)
handle_error(retval);
if ((retval = PAPI_add_named_event(eventSet, (char *) "rapl:::PP0_ENERGY:PACKAGE0")) != PAPI_OK)
handle_error(retval);
if ((retval = PAPI_start(eventSet)) != PAPI_OK)
handle_error(retval);
return 0.0;在运行应用程序时,我从PAPI_stop()获得PAPI_stop()。
我假设在函数的两次运行之间共享eventSet变量就足够了。不幸的是,当调用PAPI_stop()时,这似乎不起作用,因为事件没有运行。
有机会解决这个问题吗?
发布于 2015-03-09 08:50:13
当你第三次打电话给计时器时会发生什么?你已经停止了。您需要重新考虑您的设计,也许可以使用PAPI_read - Anycorn。
https://stackoverflow.com/questions/23742877
复制相似问题