Commit 3e8d21b9 authored by Shang XiaoJing's avatar Shang XiaoJing Committed by Arnaldo Carvalho de Melo

perf timechart: Add p_state_end helper

Wrap repeated code in helper functions p_state_end, which alloc a new
power_event recording last pstate, and insert to the head of
tchart->power_events.
Signed-off-by: default avatarShang XiaoJing <shangxiaojing@huawei.com>
Acked-by: default avatarNamhyung Kim <namhyung@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: https://lore.kernel.org/r/20220908021141.27134-5-shangxiaojing@huawei.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 569c746b
...@@ -376,16 +376,13 @@ static void c_state_end(struct timechart *tchart, int cpu, u64 timestamp) ...@@ -376,16 +376,13 @@ static void c_state_end(struct timechart *tchart, int cpu, u64 timestamp)
tchart->power_events = pwr; tchart->power_events = pwr;
} }
static void p_state_change(struct timechart *tchart, int cpu, u64 timestamp, u64 new_freq) static struct power_event *p_state_end(struct timechart *tchart, int cpu,
u64 timestamp)
{ {
struct power_event *pwr; struct power_event *pwr = zalloc(sizeof(*pwr));
if (new_freq > 8000000) /* detect invalid data */
return;
pwr = zalloc(sizeof(*pwr));
if (!pwr) if (!pwr)
return; return NULL;
pwr->state = cpus_pstate_state[cpu]; pwr->state = cpus_pstate_state[cpu];
pwr->start_time = cpus_pstate_start_times[cpu]; pwr->start_time = cpus_pstate_start_times[cpu];
...@@ -393,11 +390,23 @@ static void p_state_change(struct timechart *tchart, int cpu, u64 timestamp, u64 ...@@ -393,11 +390,23 @@ static void p_state_change(struct timechart *tchart, int cpu, u64 timestamp, u64
pwr->cpu = cpu; pwr->cpu = cpu;
pwr->type = PSTATE; pwr->type = PSTATE;
pwr->next = tchart->power_events; pwr->next = tchart->power_events;
if (!pwr->start_time) if (!pwr->start_time)
pwr->start_time = tchart->first_time; pwr->start_time = tchart->first_time;
tchart->power_events = pwr; tchart->power_events = pwr;
return pwr;
}
static void p_state_change(struct timechart *tchart, int cpu, u64 timestamp, u64 new_freq)
{
struct power_event *pwr;
if (new_freq > 8000000) /* detect invalid data */
return;
pwr = p_state_end(tchart, cpu, timestamp);
if (!pwr)
return;
cpus_pstate_state[cpu] = new_freq; cpus_pstate_state[cpu] = new_freq;
cpus_pstate_start_times[cpu] = timestamp; cpus_pstate_start_times[cpu] = timestamp;
...@@ -705,22 +714,12 @@ static void end_sample_processing(struct timechart *tchart) ...@@ -705,22 +714,12 @@ static void end_sample_processing(struct timechart *tchart)
#endif #endif
/* P state */ /* P state */
pwr = zalloc(sizeof(*pwr)); pwr = p_state_end(tchart, cpu, tchart->last_time);
if (!pwr) if (!pwr)
return; return;
pwr->state = cpus_pstate_state[cpu];
pwr->start_time = cpus_pstate_start_times[cpu];
pwr->end_time = tchart->last_time;
pwr->cpu = cpu;
pwr->type = PSTATE;
pwr->next = tchart->power_events;
if (!pwr->start_time)
pwr->start_time = tchart->first_time;
if (!pwr->state) if (!pwr->state)
pwr->state = tchart->min_freq; pwr->state = tchart->min_freq;
tchart->power_events = pwr;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment