7

我正在使用 Exynos 3110 处理器(1 GHz 单核 ARM Cortex-A8,例如用于 Nexus S)并尝试测量特定功能的执行时间。我在 Nexus S 上运行了 Android 4.0.3。我尝试了以下方法

[1]如何测量 ARM Cortex-A8 处理器中的程序执行时间?

我加载了内核模块以允许在用户模式下读取寄存器值。我正在使用以下程序来测试计数器:

static inline unsigned int get_cyclecount (void)
{
    unsigned int value;
    // Read CCNT Register
    asm volatile ("MRC p15, 0, %0, c9, c13, 0\t\n": "=r"(value));
    return value;
}


static inline void init_perfcounters (int do_reset, int enable_divider)
{
    // in general enable all counters (including cycle counter)
    int value = 1;

    // peform reset:  
    if (do_reset)
    {
        value |= 2;     // reset all counters to zero.
        value |= 4;     // reset cycle counter to zero.
    } 

    if (enable_divider)
        value |= 8;     // enable "by 64" divider for CCNT.

    value |= 16;

    // program the performance-counter control-register:
    asm volatile ("MCR p15, 0, %0, c9, c12, 0\t\n" :: "r"(value));  

    // enable all counters:  
    asm volatile ("MCR p15, 0, %0, c9, c12, 1\t\n" :: "r"(0x8000000f));  

    // clear overflows:
    asm volatile ("MCR p15, 0, %0, c9, c12, 3\t\n" :: "r"(0x8000000f));
}


int main(int argc, char **argv)
{
    int i = 0;
    unsigned int start = 0;
    unsigned int end = 0;

    printf("Hello Counter\n");

    init_perfcounters(1,0);

    for(i=0;i<10;i++)
    {
        start = get_cyclecount();
        sleep(1); // sleep one second
        end = get_cyclecount();

        printf("%u %u %u\n", start, end, end - start);
    }

    return 0;
}

根据[1],计数器随着每个时钟周期递增。我将 scaling_governor 切换到用户空间并将 CPU 频率设置为 1GHz,以确保 Android 不会更改时钟频率。

如果我运行程序,则会执行 1 秒的睡眠,但计数器值在 ~200e6 的范围内,而不是预期的 1e9。我在这里缺少任何特定于处理器的东西吗?计数器的时钟频率是否与处理器的时钟频率不同?

4

2 回答 2

1

查看这位教授的页面:http ://users.ece.utexas.edu/~valvano/arm/ 他有多个与 time/periodic-timers/measuring-execution-time 相关的完整示例程序,它们是为基于 ARM Cortex-M3 的微控制器。我希望这与您的工作没有太大不同。我想你会对Performance.c感兴趣

于 2012-04-23T05:27:03.030 回答
0

您确定在 Android 中使用调控器进行性能管理的方式与在标准 Linux 中使用的方式相同吗?您使用的是自定义 Android 图像还是制造商提供的图像?我会假设制造商提供的图像中有较低级别的策略(与睡眠或调制解调器活动等相关)。也可能是睡眠代码直接缩放电压和频率。禁用整个 CPUFreq 可能是值得的,而不仅仅是策略(或调控器)。

于 2013-12-09T07:39:34.067 回答