gpt4 book ai didi

android - 在 Cortex-A9 PMU 计数器上取零

转载 作者:太空狗 更新时间:2023-10-29 13:24:54 25 4
gpt4 key购买 nike

不确定这是不是该问的地方,但我真的需要帮助。

我正在尝试在 Galaxy Nexus i9250 Android v4.3 CPU ARMv7 上收集一些数据。我正在尝试使用 ARM Streamline,但它提供了以下错误:

已检测到 ARM 处理器 PMU 事件计数器,但事件计数器的读数为零。事件计数器包括在核心名称下的计数器配置选项对话框中列出的那些计数器,但不包括循环计数器 (Clock:Cycles),因为它由专用计数器控制。 PMU 配置位 DBGEN 可能未启用,随后的计数器值将始终读取为零。要补救,请更新您的固件或 Linux 内核以启用 DBGEN。

经过一番搜索,我发现了类似的问题:https://community.freescale.com/thread/302685

建议对 SDER 安全调试启用寄存器、安全扩展进行一些修改。

我不知道该怎么做,所以我在内核源代码中找到了一个文件 perf_event,但不确定从哪里开始。

我在这里找到了http://infocenter.arm.com/help/topic/com.arm.doc.dai0195b/DAI0195B_arm11_performance_monitor_unit.pdf对于我应该使用的 ARM11

enter code here

// MRC p15, 0, <Rd>, CRn, CRm, opCode_2 ; base

MRC p15, 0, <Rd>, c15, c12, 0 ; Read Performance Monitor Control Register

MCR p15, 0, <Rd>, c15, c12, 0 ; Write Performance Monitor Control Register

这是在 perf_event_v6.c 内核文件夹中,如下所示:

static inline unsigned long
armv6_pmcr_read(void)
{
u32 val;
asm volatile("mrc p15, 0, %0, c15, c12, 0" : "=r"(val));
return val;
}

因为我使用的是 arm7 版本所以我应该修改 perf_event_v7.c我猜我应该使用 c9 而不是 c15,因为这是那里使用的选项,并在 EX 的 Cortex 引用手册中提到:

c9 寄存器当 CRn 为 c9 时,您可以访问的 CP15 系统控制寄存器如表 4-10 所示。表 4-10 c9 寄存器汇总Op1 CRm Op2 名称 类型 复位说明0 c12 0 PMCR RW 0x41093000 性能监视器控制寄存器 1 PMCNTENSET RW 0x00000000 计数使能设置寄存器 2 PMCNTENCLR RW 0x00000000 计数使能清除寄存器 3 PMOVSR RW - 溢出标志状态寄存器 4 PMSWINC WO - 软件增量寄存器 5 PMSELR RW 0x00000000 事件计数器选择寄存器

所以应该是: MRC p15, 0, , c9, c12, 0 ;读取性能监视器控制寄存器

MCR p15, 0, <Rd>, c9, c12, 0 ; Write Performance Monitor Control Register

和 MRC p15, 0, , c9, c12, 5 ;读取 PMSELR 寄存器

MCR p15, 0, <Rd>, c9, c12, 5 ; Write PMSELR Register

并选择事件:

  EXPORT  pmn_config
; Sets the event for a programmable counter to record
; void pmn_config(unsigned counter, uint32_t event)
; counter (in r0) = Which counter to program (e.g. 0 for PMN0, 1 for PMN1)
; event (in r1) = The event code (from appropriate TRM or ARM Architecture Reference Manual)
pmn_config PROC
AND r0, r0, #0x1F ; Mask to leave only bits 4:0
MCR p15, 0, r0, c9, c12, 5 ; Write PMSELR Register
ISB ; Synchronize context
MCR p15, 0, r1, c9, c13, 1 ; Write PMXEVTYPER Register
BX lr
ENDP

我应该遵循的步骤如下:应遵循以下程序:

Disable performance counters
Set what each event counter will count
Set cycle counter tick rate
Reset performance counters
Enable performance counters
Call function to profile
Disable performance counters
Read out performance counters
Check that performance counters did not overflow

但我还是不知道该怎么做。

有什么帮助吗?

最佳答案

此链接可能对您有所帮助 -> https://code.google.com/p/mycodespot/wiki/DirectPMUCodeGCC

此链接包含 PMU header 和汇编代码以及如何使用代码和编译的应用示例。

关于android - 在 Cortex-A9 PMU 计数器上取零,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22567859/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com