LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 232|回复: 0

对 Perf Maps 的支持

[复制链接]
发表于 2024-1-25 17:52:44 | 显示全部楼层 |阅读模式


在受支持的平台上(在撰写本文档时,只有 Linux),运行时可以利用 perf map 文件 来使得 Python 函数对于外部性能分析工具可见(例如 perf 等)。 正在运行的进行可以在 /tmp 目录中创建一个文件,其中包含可将部分可执行代码映射到特定名称的条目。 本接口的描述参见 Linux Perf 工具文档。

在 Python 中,这些辅助 API 可供依赖于动态生成机器码的库和特性使用。

请注意这些 API 并不要求持有全局解释器锁(GIL)。

int PyUnstable_PerfMapState_Init(void)
这是 不稳定 API。 它可能在微发布版中不带警告地改变。
打开 /tmp/perf-$pid.map 文件,除非它已经被打开,并创建一个锁来确保线程安全地写入该文件(如果写入是通过 PyUnstable_WritePerfMapEntry() 执行的)。 通常,没有必要显式地调用此函数;只需使用 PyUnstable_WritePerfMapEntry() 这样它将在第一次调用时初始化状态。

成功时返回 0,创建/打开 perf map 文件失败时返回 -1,或者创建锁失败时返回 -2。 可检查 errno 获取有关失败原因的更多信息。

int PyUnstable_WritePerfMapEntry(const void *code_addr, unsigned int code_size, const char *entry_name)
这是 不稳定 API。 它可能在微发布版中不带警告地改变。
向 /tmp/perf-$pid.map 文件写入一个单独条目。 此函数是线程安全的。 下面显示了一个示例条目:

# address      size  name
7f3529fcf759 b     py::bar:/run/t.py
将在写入条目之前调用 PyUnstable_PerfMapState_Init(),如果 perf map 文件尚未打开。 成功时返回 0,或者在失败时返回与 PyUnstable_PerfMapState_Init() 相同的错误代码。

void PyUnstable_PerfMapState_Fini(void)
这是 不稳定 API。 它可能在微发布版中不带警告地改变。
关闭 PyUnstable_PerfMapState_Init() 所打开的 perf map 文件。 此函数会在解释器关闭期间由运行时本身调用。 通常,应该没有理由显式地调用此函数,除了处理特殊场景例如分叉操作。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表