pm_start_pthread 和 pm_tstart_pthread 子例程

用途

对目标 pthread 启动性能监视器计数。

性能监视器 API 库 (libpmapi.a)

语法

#include <pmapi.h>

int pm_start_pthread ( pid,  tid,  ptid)
pid_t pid;
tid_t tid;
ptid_t ptid;  

int pm_start_pthread ( pid,  tid,  ptid, *time)
pid_t pid;
tid_t tid;
ptid_t ptid;  
timebasestruct_t *time

描述

pm_start_pthread 子例程对目标 pthread 启动性能监视器计数。 pthread 必须停止,并且必须是 debuggee 进程的一部分,在调用进程的控制下。 除非线程位于组中并且组计数当前未设置为 On ,否则计数将立即生效。 通过将线程计数状态与组状态进行 AND 运算来获得组中线程的计数状态。

pm_tstart_pthread 子例程对目标 pthread 启动 "性能监视器" 计数,并返回指示计数开始时间的时间戳记。

如果 pthread 以 1: 1 方式运行,那么必须仅指定 tid 参数。 如果 pthread 以 m: n 方式运行,那么必须仅指定 ptid 参数。 如果同时指定了 ptidtid 参数,那么它们必须引用具有指定的 ptid 参数的单个 pthread ,并且当前正在具有指定的 tid 参数的内核线程上运行。

参数

描述
pid 目标 pthread 的进程标识。 目标进程必须是调用者进程的调试器。
tid 目标 pthread 的线程标识。 要忽略此参数,请将其设置为 0。
ptid 目标 pthread 的 pthread 标识。 要忽略此参数,请将其设置为 0。
* 时间 指向包含启动计数时的时间基准值的结构的指针。 这可以使用 time_base_to_time 子例程转换为时间。

返回值

描述
0 操作成功完成。
Positive error code 请参阅 pm_error 子例程 以解码错误代码。

错误代码

请参阅 pm_error 子例程

文件

描述
/usr/include/pmapi.h 定义标准宏,数据类型和子例程。