更新日期: 2022/06/01 来源: https://gitee.com/weharmony/kernel_liteos_a_note
perf_stat.c 文件参考

浏览源代码.

函数

static int GetEvents (const char *argv)
 
static int GetTids (const char *argv)
 
static int GetPids (const char *argv)
 
static int PerfStatAttrInit (void)
 
void PerfStat (int fd, int argc, char **argv)
 

变量

static PerfConfigAttr g_statAttr
 
static PerfOption g_statOpts []
 

函数说明

◆ GetEvents()

static int GetEvents ( const char *  argv)
inlinestatic

在文件 perf_stat.c41 行定义.

42{
44}
int ParseEvents(const char *argv, PerfEventConfig *eventsCfg, unsigned int *len)
Definition: option.c:144
static PerfConfigAttr g_statAttr
Definition: perf_stat.c:39
PerfEventConfig eventsCfg
Definition: perf.h:138
unsigned int eventsNr
Definition: perf.h:127
函数调用图:

◆ GetPids()

static int GetPids ( const char *  argv)
inlinestatic

在文件 perf_stat.c51 行定义.

52{
54}
int ParseIds(const char *argv, int *arr, unsigned int *len)
Definition: option.c:102
unsigned int processIdsNr
Definition: perf.h:143
unsigned int processIds[PERF_MAX_FILTER_TSKS]
Definition: perf.h:142
函数调用图:

◆ GetTids()

static int GetTids ( const char *  argv)
inlinestatic

在文件 perf_stat.c46 行定义.

47{
48 return ParseIds(argv, (int *)g_statAttr.taskIds, &g_statAttr.taskIdsNr);
49}
unsigned int taskIds[PERF_MAX_FILTER_TSKS]
Definition: perf.h:139
unsigned int taskIdsNr
Definition: perf.h:140
函数调用图:

◆ PerfStat()

void PerfStat ( int  fd,
int  argc,
char **  argv 
)

在文件 perf_stat.c107 行定义.

108{
109 int ret;
110 int child;
111 SubCmd cmd = {0};
112
113 if (argc < 3) { /* perf stat argc is at least 3 */
114 return;
115 }
116
117 ret = PerfStatAttrInit();
118 if (ret != 0) {
119 printf("perf stat attr init failed\n");
120 return;
121 }
122
123 ret = ParseOptions(argc - 2, &argv[2], g_statOpts, &cmd); /* parse option and cmd begin at index 2 */
124 if (ret != 0) {
125 printf("parse error\n");
126 return;
127 }
128
129 ret = PerfConfig(fd, &g_statAttr);
130 if (ret != 0) {
131 printf("perf config failed\n");
132 return;
133 }
134
135 PerfStart(fd, 0);
136 child = fork();
137 if (child < 0) {
138 printf("fork error\n");
139 goto EXIT;
140 } else if (child == 0) {
141 (void)execve(cmd.path, cmd.params, NULL);
142 exit(0);
143 }
144
145 (void)waitpid(child, 0, 0);
146EXIT:
147 PerfStop(fd);
148}
void PerfStart(int fd, size_t sectionId)
Definition: perf.c:106
int PerfConfig(int fd, PerfConfigAttr *attr)
Definition: perf.c:116
void PerfStop(int fd)
Definition: perf.c:111
int ParseOptions(int argc, char **argv, PerfOption *opt, SubCmd *cmd)
Definition: option.c:71
static int PerfStatAttrInit(void)
Definition: perf_stat.c:65
static PerfOption g_statOpts[]
Definition: perf_stat.c:56
void exit(int status)
Definition: stdlib.c:60
Definition: option.h:61
const char * path
Definition: option.h:62
char * params[CMD_MAX_PARAMS]
Definition: option.h:63
ARG_NUM_3 ARG_NUM_1 ARG_NUM_2 ARG_NUM_2 ARG_NUM_3 ARG_NUM_1 ARG_NUM_4 ARG_NUM_2 ARG_NUM_2 ARG_NUM_5 ARG_NUM_2 void
函数调用图:
这是这个函数的调用关系图:

◆ PerfStatAttrInit()

static int PerfStatAttrInit ( void  )
static

在文件 perf_stat.c65 行定义.

66{
67 PerfConfigAttr attr = {
68 .eventsCfg = {
69#ifdef LOSCFG_PERF_HW_PMU
71 .events = {
72 [0] = {PERF_COUNT_HW_CPU_CYCLES, 0xFFFF},
73 [1] = {PERF_COUNT_HW_INSTRUCTIONS, 0xFFFFFF00},
74 [2] = {PERF_COUNT_HW_ICACHE_REFERENCES, 0xFFFF},
75 [3] = {PERF_COUNT_HW_DCACHE_REFERENCES, 0xFFFF},
76 },
77 .eventsNr = 4, /* 4 events */
78#elif defined LOSCFG_PERF_TIMED_PMU
80 .events = {
81 [0] = {PERF_COUNT_CPU_CLOCK, 100},
82 },
83 .eventsNr = 1, /* 1 event */
84#elif defined LOSCFG_PERF_SW_PMU
85 .type = PERF_EVENT_TYPE_SW,
86 .events = {
89 [2] = {PERF_COUNT_SW_MEM_ALLOC, 1},
90 [3] = {PERF_COUNT_SW_MUX_PEND, 1},
91 },
92 .eventsNr = 4, /* 4 events */
93#endif
94 .predivided = 0,
95 },
96 .taskIds = {0},
97 .taskIdsNr = 0,
98 .processIds = {0},
99 .processIdsNr = 0,
100 .needSample = 0,
101 .sampleType = 0,
102 };
103
104 return memcpy_s(&g_statAttr, sizeof(PerfConfigAttr), &attr, sizeof(PerfConfigAttr)) != EOK ? -1 : 0;
105}
@ PERF_COUNT_CPU_CLOCK
Definition: perf.h:85
@ PERF_EVENT_TYPE_SW
Definition: perf.h:59
@ PERF_EVENT_TYPE_HW
Definition: perf.h:57
@ PERF_EVENT_TYPE_TIMED
Definition: perf.h:58
@ PERF_COUNT_SW_IRQ_RESPONSE
Definition: perf.h:93
@ PERF_COUNT_SW_MUX_PEND
Definition: perf.h:95
@ PERF_COUNT_SW_TASK_SWITCH
Definition: perf.h:92
@ PERF_COUNT_SW_MEM_ALLOC
Definition: perf.h:94
@ PERF_COUNT_HW_DCACHE_REFERENCES
Definition: perf.h:71
@ PERF_COUNT_HW_ICACHE_REFERENCES
Definition: perf.h:73
@ PERF_COUNT_HW_CPU_CYCLES
Definition: perf.h:69
@ PERF_COUNT_HW_INSTRUCTIONS
Definition: perf.h:70
unsigned int type
Definition: perf.h:121
这是这个函数的调用关系图:

变量说明

◆ g_statAttr

PerfConfigAttr g_statAttr
static

在文件 perf_stat.c39 行定义.

◆ g_statOpts

PerfOption g_statOpts[]
static
初始值:
= {
OPTION_CALLBACK("-e", GetEvents),
OPTION_CALLBACK("-t", GetTids),
OPTION_CALLBACK("-P", GetPids),
OPTION_UINT("-p", &g_statAttr.eventsCfg.events[0].period),
OPTION_UINT("-s", &g_statAttr.sampleType),
OPTION_UINT("-d", &g_statAttr.eventsCfg.predivided),
}
static int GetTids(const char *argv)
Definition: perf_stat.c:46
static int GetEvents(const char *argv)
Definition: perf_stat.c:41
static int GetPids(const char *argv)
Definition: perf_stat.c:51
unsigned int sampleType
Definition: perf.h:145
unsigned int period
Definition: perf.h:124
size_t predivided
Definition: perf.h:128
struct PerfEventConfig::@0 events[PERF_MAX_EVENT]

在文件 perf_stat.c56 行定义.