10

我正在比较一些我从/向内存读取/写入的系统调用。是否定义了任何 API 来测量页面错误(页面输入/输出)C

我找到了这个库 libperfstat.a但它是AIX用于 linux 的,我找不到任何东西。

编辑: 我知道 linux 中的time&perf-stat命令,只是探索是否有任何东西可供我在C程序中使用。

4

3 回答 3

6

如果您在 Linux 上运行,则可以使用perf_event_open系统调用(由 perf stat 使用)。获取正确的参数有点棘手,请查看手册页http://web.eece.maine.edu/~vweaver/projects/perf_events/perf_event_open.html并查看下面的代码。

没有 lib C 包装器,因此您必须按以下方式调用它:

static long perf_event_open(struct perf_event_attr *hw_event,
                pid_t pid,
                int cpu,
                int group_fd,
                unsigned long flags) {
  int ret = syscall(__NR_perf_event_open, hw_event, pid, cpu,
            group_fd, flags);
  return ret;
}

然后计算页面错误:

  struct perf_event_attr pe_attr_page_faults;
  memset(&pe_attr_page_faults, 0, sizeof(pe_attr_page_faults));
  pe_attr_page_faults.size = sizeof(pe_attr_page_faults);
  pe_attr_page_faults.type =   PERF_TYPE_SOFTWARE;
  pe_attr_page_faults.config = PERF_COUNT_SW_PAGE_FAULTS;
  pe_attr_page_faults.disabled = 1;
  pe_attr_page_faults.exclude_kernel = 1;
  int page_faults_fd = perf_event_open(&pe_attr_page_faults, 0, CPU, -1, 0);
  if (page_faults_fd == -1) {
    printf("perf_event_open failed for page faults: %s\n", strerror(errno));
    return -1;
  }

  // Start counting
  ioctl(page_faults_fd, PERF_EVENT_IOC_RESET, 0);
  ioctl(page_faults_fd, PERF_EVENT_IOC_ENABLE, 0);

  // Your code to be profiled here 
  .....

  // Stop counting and read value
  ioctl(page_faults_fd, PERF_EVENT_IOC_DISABLE, 0);
  uint64_t page_faults_count;
  read(page_faults_fd, &page_faults_count, sizeof(page_faults_count));
于 2014-04-26T08:49:58.193 回答
3

它本身不是一个 API,但是我通过滚动自己的 API 并从我的 C 程序中读取 /proc/myPID/stat 取得了很大的成功,其中包括我的进程的页面错误统计信息,这使我能够实时监控计数我的程序运行和存储这些我喜欢的时间。

请记住,这样做本身可能会导致页面错误,因此会有一些不准确之处,但您会得到一个大致的了解。

有关文件格式的详细信息,请参见此处:https ://access.redhat.com/site/documentation/en-US/Red_Hat_Enterprise_MRG/1.3/html/Realtime_Reference_Guide/chap-Realtime_Reference_Guide-Memory_allocation.html

于 2014-04-25T22:43:15.650 回答
3

getrusage功能(SVr4,4.3BSD。POSIX.1-2001;但并非所有字段都在标准中定义)。在 linux 中有几个损坏的字段,但man getrusage列出了几个有趣的字段:

long   ru_minflt;        /* page reclaims (soft page faults) */
long   ru_majflt;        /* page faults (hard page faults) */

long   ru_inblock;       /* block input operations */
long   ru_oublock;       /* block output operations */

rusage也报告在(wait4仅在外部程序中可用)。这个由/usr/bin/time程序使用(它打印次要/主要页面错误计数)。

于 2014-04-27T00:07:22.167 回答