2

全部。

我尝试使用 Krait CPU 在第二个 Nexus7 上获取 PMU 信息,例如指令、周期、缓存未命中等。

perf 工具无法正常工作。

因此,我正在使用 perf_event 教程中的示例源代码。

#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <sys/ioctl.h>
#include <linux/perf_event.h>
#include <asm/unistd.h>

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

    ret = syscall(__NR_perf_event_open, hw_event, pid, cpu,
           group_fd, flags);
    return ret;
}

int
main(int argc, char **argv)
{
    struct perf_event_attr pe;
    long long count;
    int fd;

    memset(&pe, 0, sizeof(struct perf_event_attr));
    pe.type = PERF_TYPE_HARDWARE;
    pe.size = sizeof(struct perf_event_attr);
    pe.config = PERF_COUNT_HW_CPU_CYCLES;
    pe.disabled = 1;
    pe.exclude_kernel = 1;
    pe.exclude_hv = 1;

    fd = perf_event_open(&pe, 0, -1, -1, 0);
    if (fd == -1) {
       fprintf(stderr, "Error opening leader %llx\n", pe.config);
       exit(EXIT_FAILURE);
    }

    ioctl(fd, PERF_EVENT_IOC_RESET, 0);
    ioctl(fd, PERF_EVENT_IOC_ENABLE, 0);

    printf("Measuring Cycles for this printf\n");

    ioctl(fd, PERF_EVENT_IOC_DISABLE, 0);
    read(fd, &count, sizeof(long long));

    printf("Used %lld Cycles", count);

    close(fd);
}

我试图在 x86 linux 机器上运行这段代码。结果显示“Used 123123 Cycles”。

但是,我无法在第二个 nexus7 上获得任何 PMU 事件。它总是返回“Used 0 Cycles”。

PMU 驱动程序启用如下。

<6>[0.152832] hw perfevents:启用 ARMv7 Krait PMU 驱动程序,5 个计数器可用

此外,我可以在用于我的 Nexus7 的 flo 内核 3.4 中找到 perf_event_msm_krait.c。(我找到了一个支持 Krait CPU 的补丁;http://www.serverphorums.com/read.php ?12,850329 。其中包括 perf_event_cpu.c 文件,但我在内核源代码中找不到它。这样是否正确为了支持带有 Krait 的 Nexus7 的 PMU?)

先感谢您。

4

0 回答 0