162306a36Sopenharmony_ci# Cpu task migration overview toy
262306a36Sopenharmony_ci#
362306a36Sopenharmony_ci# Copyright (C) 2010 Frederic Weisbecker <fweisbec@gmail.com>
462306a36Sopenharmony_ci#
562306a36Sopenharmony_ci# perf script event handlers have been generated by perf script -g python
662306a36Sopenharmony_ci#
762306a36Sopenharmony_ci# This software is distributed under the terms of the GNU General
862306a36Sopenharmony_ci# Public License ("GPL") version 2 as published by the Free Software
962306a36Sopenharmony_ci# Foundation.
1062306a36Sopenharmony_cifrom __future__ import print_function
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ciimport os
1362306a36Sopenharmony_ciimport sys
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_cifrom collections import defaultdict
1662306a36Sopenharmony_citry:
1762306a36Sopenharmony_ci	from UserList import UserList
1862306a36Sopenharmony_ciexcept ImportError:
1962306a36Sopenharmony_ci	# Python 3: UserList moved to the collections package
2062306a36Sopenharmony_ci	from collections import UserList
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_cisys.path.append(os.environ['PERF_EXEC_PATH'] + \
2362306a36Sopenharmony_ci	'/scripts/python/Perf-Trace-Util/lib/Perf/Trace')
2462306a36Sopenharmony_cisys.path.append('scripts/python/Perf-Trace-Util/lib/Perf/Trace')
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_cifrom perf_trace_context import *
2762306a36Sopenharmony_cifrom Core import *
2862306a36Sopenharmony_cifrom SchedGui import *
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_cithreads = { 0 : "idle"}
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_cidef thread_name(pid):
3462306a36Sopenharmony_ci	return "%s:%d" % (threads[pid], pid)
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ciclass RunqueueEventUnknown:
3762306a36Sopenharmony_ci	@staticmethod
3862306a36Sopenharmony_ci	def color():
3962306a36Sopenharmony_ci		return None
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci	def __repr__(self):
4262306a36Sopenharmony_ci		return "unknown"
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ciclass RunqueueEventSleep:
4562306a36Sopenharmony_ci	@staticmethod
4662306a36Sopenharmony_ci	def color():
4762306a36Sopenharmony_ci		return (0, 0, 0xff)
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci	def __init__(self, sleeper):
5062306a36Sopenharmony_ci		self.sleeper = sleeper
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci	def __repr__(self):
5362306a36Sopenharmony_ci		return "%s gone to sleep" % thread_name(self.sleeper)
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ciclass RunqueueEventWakeup:
5662306a36Sopenharmony_ci	@staticmethod
5762306a36Sopenharmony_ci	def color():
5862306a36Sopenharmony_ci		return (0xff, 0xff, 0)
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci	def __init__(self, wakee):
6162306a36Sopenharmony_ci		self.wakee = wakee
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci	def __repr__(self):
6462306a36Sopenharmony_ci		return "%s woke up" % thread_name(self.wakee)
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_ciclass RunqueueEventFork:
6762306a36Sopenharmony_ci	@staticmethod
6862306a36Sopenharmony_ci	def color():
6962306a36Sopenharmony_ci		return (0, 0xff, 0)
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci	def __init__(self, child):
7262306a36Sopenharmony_ci		self.child = child
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_ci	def __repr__(self):
7562306a36Sopenharmony_ci		return "new forked task %s" % thread_name(self.child)
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ciclass RunqueueMigrateIn:
7862306a36Sopenharmony_ci	@staticmethod
7962306a36Sopenharmony_ci	def color():
8062306a36Sopenharmony_ci		return (0, 0xf0, 0xff)
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ci	def __init__(self, new):
8362306a36Sopenharmony_ci		self.new = new
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ci	def __repr__(self):
8662306a36Sopenharmony_ci		return "task migrated in %s" % thread_name(self.new)
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ciclass RunqueueMigrateOut:
8962306a36Sopenharmony_ci	@staticmethod
9062306a36Sopenharmony_ci	def color():
9162306a36Sopenharmony_ci		return (0xff, 0, 0xff)
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci	def __init__(self, old):
9462306a36Sopenharmony_ci		self.old = old
9562306a36Sopenharmony_ci
9662306a36Sopenharmony_ci	def __repr__(self):
9762306a36Sopenharmony_ci		return "task migrated out %s" % thread_name(self.old)
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ciclass RunqueueSnapshot:
10062306a36Sopenharmony_ci	def __init__(self, tasks = [0], event = RunqueueEventUnknown()):
10162306a36Sopenharmony_ci		self.tasks = tuple(tasks)
10262306a36Sopenharmony_ci		self.event = event
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci	def sched_switch(self, prev, prev_state, next):
10562306a36Sopenharmony_ci		event = RunqueueEventUnknown()
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci		if taskState(prev_state) == "R" and next in self.tasks \
10862306a36Sopenharmony_ci			and prev in self.tasks:
10962306a36Sopenharmony_ci			return self
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_ci		if taskState(prev_state) != "R":
11262306a36Sopenharmony_ci			event = RunqueueEventSleep(prev)
11362306a36Sopenharmony_ci
11462306a36Sopenharmony_ci		next_tasks = list(self.tasks[:])
11562306a36Sopenharmony_ci		if prev in self.tasks:
11662306a36Sopenharmony_ci			if taskState(prev_state) != "R":
11762306a36Sopenharmony_ci				next_tasks.remove(prev)
11862306a36Sopenharmony_ci		elif taskState(prev_state) == "R":
11962306a36Sopenharmony_ci			next_tasks.append(prev)
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci		if next not in next_tasks:
12262306a36Sopenharmony_ci			next_tasks.append(next)
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ci		return RunqueueSnapshot(next_tasks, event)
12562306a36Sopenharmony_ci
12662306a36Sopenharmony_ci	def migrate_out(self, old):
12762306a36Sopenharmony_ci		if old not in self.tasks:
12862306a36Sopenharmony_ci			return self
12962306a36Sopenharmony_ci		next_tasks = [task for task in self.tasks if task != old]
13062306a36Sopenharmony_ci
13162306a36Sopenharmony_ci		return RunqueueSnapshot(next_tasks, RunqueueMigrateOut(old))
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci	def __migrate_in(self, new, event):
13462306a36Sopenharmony_ci		if new in self.tasks:
13562306a36Sopenharmony_ci			self.event = event
13662306a36Sopenharmony_ci			return self
13762306a36Sopenharmony_ci		next_tasks = self.tasks[:] + tuple([new])
13862306a36Sopenharmony_ci
13962306a36Sopenharmony_ci		return RunqueueSnapshot(next_tasks, event)
14062306a36Sopenharmony_ci
14162306a36Sopenharmony_ci	def migrate_in(self, new):
14262306a36Sopenharmony_ci		return self.__migrate_in(new, RunqueueMigrateIn(new))
14362306a36Sopenharmony_ci
14462306a36Sopenharmony_ci	def wake_up(self, new):
14562306a36Sopenharmony_ci		return self.__migrate_in(new, RunqueueEventWakeup(new))
14662306a36Sopenharmony_ci
14762306a36Sopenharmony_ci	def wake_up_new(self, new):
14862306a36Sopenharmony_ci		return self.__migrate_in(new, RunqueueEventFork(new))
14962306a36Sopenharmony_ci
15062306a36Sopenharmony_ci	def load(self):
15162306a36Sopenharmony_ci		""" Provide the number of tasks on the runqueue.
15262306a36Sopenharmony_ci		    Don't count idle"""
15362306a36Sopenharmony_ci		return len(self.tasks) - 1
15462306a36Sopenharmony_ci
15562306a36Sopenharmony_ci	def __repr__(self):
15662306a36Sopenharmony_ci		ret = self.tasks.__repr__()
15762306a36Sopenharmony_ci		ret += self.origin_tostring()
15862306a36Sopenharmony_ci
15962306a36Sopenharmony_ci		return ret
16062306a36Sopenharmony_ci
16162306a36Sopenharmony_ciclass TimeSlice:
16262306a36Sopenharmony_ci	def __init__(self, start, prev):
16362306a36Sopenharmony_ci		self.start = start
16462306a36Sopenharmony_ci		self.prev = prev
16562306a36Sopenharmony_ci		self.end = start
16662306a36Sopenharmony_ci		# cpus that triggered the event
16762306a36Sopenharmony_ci		self.event_cpus = []
16862306a36Sopenharmony_ci		if prev is not None:
16962306a36Sopenharmony_ci			self.total_load = prev.total_load
17062306a36Sopenharmony_ci			self.rqs = prev.rqs.copy()
17162306a36Sopenharmony_ci		else:
17262306a36Sopenharmony_ci			self.rqs = defaultdict(RunqueueSnapshot)
17362306a36Sopenharmony_ci			self.total_load = 0
17462306a36Sopenharmony_ci
17562306a36Sopenharmony_ci	def __update_total_load(self, old_rq, new_rq):
17662306a36Sopenharmony_ci		diff = new_rq.load() - old_rq.load()
17762306a36Sopenharmony_ci		self.total_load += diff
17862306a36Sopenharmony_ci
17962306a36Sopenharmony_ci	def sched_switch(self, ts_list, prev, prev_state, next, cpu):
18062306a36Sopenharmony_ci		old_rq = self.prev.rqs[cpu]
18162306a36Sopenharmony_ci		new_rq = old_rq.sched_switch(prev, prev_state, next)
18262306a36Sopenharmony_ci
18362306a36Sopenharmony_ci		if old_rq is new_rq:
18462306a36Sopenharmony_ci			return
18562306a36Sopenharmony_ci
18662306a36Sopenharmony_ci		self.rqs[cpu] = new_rq
18762306a36Sopenharmony_ci		self.__update_total_load(old_rq, new_rq)
18862306a36Sopenharmony_ci		ts_list.append(self)
18962306a36Sopenharmony_ci		self.event_cpus = [cpu]
19062306a36Sopenharmony_ci
19162306a36Sopenharmony_ci	def migrate(self, ts_list, new, old_cpu, new_cpu):
19262306a36Sopenharmony_ci		if old_cpu == new_cpu:
19362306a36Sopenharmony_ci			return
19462306a36Sopenharmony_ci		old_rq = self.prev.rqs[old_cpu]
19562306a36Sopenharmony_ci		out_rq = old_rq.migrate_out(new)
19662306a36Sopenharmony_ci		self.rqs[old_cpu] = out_rq
19762306a36Sopenharmony_ci		self.__update_total_load(old_rq, out_rq)
19862306a36Sopenharmony_ci
19962306a36Sopenharmony_ci		new_rq = self.prev.rqs[new_cpu]
20062306a36Sopenharmony_ci		in_rq = new_rq.migrate_in(new)
20162306a36Sopenharmony_ci		self.rqs[new_cpu] = in_rq
20262306a36Sopenharmony_ci		self.__update_total_load(new_rq, in_rq)
20362306a36Sopenharmony_ci
20462306a36Sopenharmony_ci		ts_list.append(self)
20562306a36Sopenharmony_ci
20662306a36Sopenharmony_ci		if old_rq is not out_rq:
20762306a36Sopenharmony_ci			self.event_cpus.append(old_cpu)
20862306a36Sopenharmony_ci		self.event_cpus.append(new_cpu)
20962306a36Sopenharmony_ci
21062306a36Sopenharmony_ci	def wake_up(self, ts_list, pid, cpu, fork):
21162306a36Sopenharmony_ci		old_rq = self.prev.rqs[cpu]
21262306a36Sopenharmony_ci		if fork:
21362306a36Sopenharmony_ci			new_rq = old_rq.wake_up_new(pid)
21462306a36Sopenharmony_ci		else:
21562306a36Sopenharmony_ci			new_rq = old_rq.wake_up(pid)
21662306a36Sopenharmony_ci
21762306a36Sopenharmony_ci		if new_rq is old_rq:
21862306a36Sopenharmony_ci			return
21962306a36Sopenharmony_ci		self.rqs[cpu] = new_rq
22062306a36Sopenharmony_ci		self.__update_total_load(old_rq, new_rq)
22162306a36Sopenharmony_ci		ts_list.append(self)
22262306a36Sopenharmony_ci		self.event_cpus = [cpu]
22362306a36Sopenharmony_ci
22462306a36Sopenharmony_ci	def next(self, t):
22562306a36Sopenharmony_ci		self.end = t
22662306a36Sopenharmony_ci		return TimeSlice(t, self)
22762306a36Sopenharmony_ci
22862306a36Sopenharmony_ciclass TimeSliceList(UserList):
22962306a36Sopenharmony_ci	def __init__(self, arg = []):
23062306a36Sopenharmony_ci		self.data = arg
23162306a36Sopenharmony_ci
23262306a36Sopenharmony_ci	def get_time_slice(self, ts):
23362306a36Sopenharmony_ci		if len(self.data) == 0:
23462306a36Sopenharmony_ci			slice = TimeSlice(ts, TimeSlice(-1, None))
23562306a36Sopenharmony_ci		else:
23662306a36Sopenharmony_ci			slice = self.data[-1].next(ts)
23762306a36Sopenharmony_ci		return slice
23862306a36Sopenharmony_ci
23962306a36Sopenharmony_ci	def find_time_slice(self, ts):
24062306a36Sopenharmony_ci		start = 0
24162306a36Sopenharmony_ci		end = len(self.data)
24262306a36Sopenharmony_ci		found = -1
24362306a36Sopenharmony_ci		searching = True
24462306a36Sopenharmony_ci		while searching:
24562306a36Sopenharmony_ci			if start == end or start == end - 1:
24662306a36Sopenharmony_ci				searching = False
24762306a36Sopenharmony_ci
24862306a36Sopenharmony_ci			i = (end + start) / 2
24962306a36Sopenharmony_ci			if self.data[i].start <= ts and self.data[i].end >= ts:
25062306a36Sopenharmony_ci				found = i
25162306a36Sopenharmony_ci				end = i
25262306a36Sopenharmony_ci				continue
25362306a36Sopenharmony_ci
25462306a36Sopenharmony_ci			if self.data[i].end < ts:
25562306a36Sopenharmony_ci				start = i
25662306a36Sopenharmony_ci
25762306a36Sopenharmony_ci			elif self.data[i].start > ts:
25862306a36Sopenharmony_ci				end = i
25962306a36Sopenharmony_ci
26062306a36Sopenharmony_ci		return found
26162306a36Sopenharmony_ci
26262306a36Sopenharmony_ci	def set_root_win(self, win):
26362306a36Sopenharmony_ci		self.root_win = win
26462306a36Sopenharmony_ci
26562306a36Sopenharmony_ci	def mouse_down(self, cpu, t):
26662306a36Sopenharmony_ci		idx = self.find_time_slice(t)
26762306a36Sopenharmony_ci		if idx == -1:
26862306a36Sopenharmony_ci			return
26962306a36Sopenharmony_ci
27062306a36Sopenharmony_ci		ts = self[idx]
27162306a36Sopenharmony_ci		rq = ts.rqs[cpu]
27262306a36Sopenharmony_ci		raw = "CPU: %d\n" % cpu
27362306a36Sopenharmony_ci		raw += "Last event : %s\n" % rq.event.__repr__()
27462306a36Sopenharmony_ci		raw += "Timestamp : %d.%06d\n" % (ts.start / (10 ** 9), (ts.start % (10 ** 9)) / 1000)
27562306a36Sopenharmony_ci		raw += "Duration : %6d us\n" % ((ts.end - ts.start) / (10 ** 6))
27662306a36Sopenharmony_ci		raw += "Load = %d\n" % rq.load()
27762306a36Sopenharmony_ci		for t in rq.tasks:
27862306a36Sopenharmony_ci			raw += "%s \n" % thread_name(t)
27962306a36Sopenharmony_ci
28062306a36Sopenharmony_ci		self.root_win.update_summary(raw)
28162306a36Sopenharmony_ci
28262306a36Sopenharmony_ci	def update_rectangle_cpu(self, slice, cpu):
28362306a36Sopenharmony_ci		rq = slice.rqs[cpu]
28462306a36Sopenharmony_ci
28562306a36Sopenharmony_ci		if slice.total_load != 0:
28662306a36Sopenharmony_ci			load_rate = rq.load() / float(slice.total_load)
28762306a36Sopenharmony_ci		else:
28862306a36Sopenharmony_ci			load_rate = 0
28962306a36Sopenharmony_ci
29062306a36Sopenharmony_ci		red_power = int(0xff - (0xff * load_rate))
29162306a36Sopenharmony_ci		color = (0xff, red_power, red_power)
29262306a36Sopenharmony_ci
29362306a36Sopenharmony_ci		top_color = None
29462306a36Sopenharmony_ci
29562306a36Sopenharmony_ci		if cpu in slice.event_cpus:
29662306a36Sopenharmony_ci			top_color = rq.event.color()
29762306a36Sopenharmony_ci
29862306a36Sopenharmony_ci		self.root_win.paint_rectangle_zone(cpu, color, top_color, slice.start, slice.end)
29962306a36Sopenharmony_ci
30062306a36Sopenharmony_ci	def fill_zone(self, start, end):
30162306a36Sopenharmony_ci		i = self.find_time_slice(start)
30262306a36Sopenharmony_ci		if i == -1:
30362306a36Sopenharmony_ci			return
30462306a36Sopenharmony_ci
30562306a36Sopenharmony_ci		for i in range(i, len(self.data)):
30662306a36Sopenharmony_ci			timeslice = self.data[i]
30762306a36Sopenharmony_ci			if timeslice.start > end:
30862306a36Sopenharmony_ci				return
30962306a36Sopenharmony_ci
31062306a36Sopenharmony_ci			for cpu in timeslice.rqs:
31162306a36Sopenharmony_ci				self.update_rectangle_cpu(timeslice, cpu)
31262306a36Sopenharmony_ci
31362306a36Sopenharmony_ci	def interval(self):
31462306a36Sopenharmony_ci		if len(self.data) == 0:
31562306a36Sopenharmony_ci			return (0, 0)
31662306a36Sopenharmony_ci
31762306a36Sopenharmony_ci		return (self.data[0].start, self.data[-1].end)
31862306a36Sopenharmony_ci
31962306a36Sopenharmony_ci	def nr_rectangles(self):
32062306a36Sopenharmony_ci		last_ts = self.data[-1]
32162306a36Sopenharmony_ci		max_cpu = 0
32262306a36Sopenharmony_ci		for cpu in last_ts.rqs:
32362306a36Sopenharmony_ci			if cpu > max_cpu:
32462306a36Sopenharmony_ci				max_cpu = cpu
32562306a36Sopenharmony_ci		return max_cpu
32662306a36Sopenharmony_ci
32762306a36Sopenharmony_ci
32862306a36Sopenharmony_ciclass SchedEventProxy:
32962306a36Sopenharmony_ci	def __init__(self):
33062306a36Sopenharmony_ci		self.current_tsk = defaultdict(lambda : -1)
33162306a36Sopenharmony_ci		self.timeslices = TimeSliceList()
33262306a36Sopenharmony_ci
33362306a36Sopenharmony_ci	def sched_switch(self, headers, prev_comm, prev_pid, prev_prio, prev_state,
33462306a36Sopenharmony_ci			 next_comm, next_pid, next_prio):
33562306a36Sopenharmony_ci		""" Ensure the task we sched out this cpu is really the one
33662306a36Sopenharmony_ci		    we logged. Otherwise we may have missed traces """
33762306a36Sopenharmony_ci
33862306a36Sopenharmony_ci		on_cpu_task = self.current_tsk[headers.cpu]
33962306a36Sopenharmony_ci
34062306a36Sopenharmony_ci		if on_cpu_task != -1 and on_cpu_task != prev_pid:
34162306a36Sopenharmony_ci			print("Sched switch event rejected ts: %s cpu: %d prev: %s(%d) next: %s(%d)" % \
34262306a36Sopenharmony_ci				headers.ts_format(), headers.cpu, prev_comm, prev_pid, next_comm, next_pid)
34362306a36Sopenharmony_ci
34462306a36Sopenharmony_ci		threads[prev_pid] = prev_comm
34562306a36Sopenharmony_ci		threads[next_pid] = next_comm
34662306a36Sopenharmony_ci		self.current_tsk[headers.cpu] = next_pid
34762306a36Sopenharmony_ci
34862306a36Sopenharmony_ci		ts = self.timeslices.get_time_slice(headers.ts())
34962306a36Sopenharmony_ci		ts.sched_switch(self.timeslices, prev_pid, prev_state, next_pid, headers.cpu)
35062306a36Sopenharmony_ci
35162306a36Sopenharmony_ci	def migrate(self, headers, pid, prio, orig_cpu, dest_cpu):
35262306a36Sopenharmony_ci		ts = self.timeslices.get_time_slice(headers.ts())
35362306a36Sopenharmony_ci		ts.migrate(self.timeslices, pid, orig_cpu, dest_cpu)
35462306a36Sopenharmony_ci
35562306a36Sopenharmony_ci	def wake_up(self, headers, comm, pid, success, target_cpu, fork):
35662306a36Sopenharmony_ci		if success == 0:
35762306a36Sopenharmony_ci			return
35862306a36Sopenharmony_ci		ts = self.timeslices.get_time_slice(headers.ts())
35962306a36Sopenharmony_ci		ts.wake_up(self.timeslices, pid, target_cpu, fork)
36062306a36Sopenharmony_ci
36162306a36Sopenharmony_ci
36262306a36Sopenharmony_cidef trace_begin():
36362306a36Sopenharmony_ci	global parser
36462306a36Sopenharmony_ci	parser = SchedEventProxy()
36562306a36Sopenharmony_ci
36662306a36Sopenharmony_cidef trace_end():
36762306a36Sopenharmony_ci	app = wx.App(False)
36862306a36Sopenharmony_ci	timeslices = parser.timeslices
36962306a36Sopenharmony_ci	frame = RootFrame(timeslices, "Migration")
37062306a36Sopenharmony_ci	app.MainLoop()
37162306a36Sopenharmony_ci
37262306a36Sopenharmony_cidef sched__sched_stat_runtime(event_name, context, common_cpu,
37362306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
37462306a36Sopenharmony_ci	common_callchain, comm, pid, runtime, vruntime):
37562306a36Sopenharmony_ci	pass
37662306a36Sopenharmony_ci
37762306a36Sopenharmony_cidef sched__sched_stat_iowait(event_name, context, common_cpu,
37862306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
37962306a36Sopenharmony_ci	common_callchain, comm, pid, delay):
38062306a36Sopenharmony_ci	pass
38162306a36Sopenharmony_ci
38262306a36Sopenharmony_cidef sched__sched_stat_sleep(event_name, context, common_cpu,
38362306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
38462306a36Sopenharmony_ci	common_callchain, comm, pid, delay):
38562306a36Sopenharmony_ci	pass
38662306a36Sopenharmony_ci
38762306a36Sopenharmony_cidef sched__sched_stat_wait(event_name, context, common_cpu,
38862306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
38962306a36Sopenharmony_ci	common_callchain, comm, pid, delay):
39062306a36Sopenharmony_ci	pass
39162306a36Sopenharmony_ci
39262306a36Sopenharmony_cidef sched__sched_process_fork(event_name, context, common_cpu,
39362306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
39462306a36Sopenharmony_ci	common_callchain, parent_comm, parent_pid, child_comm, child_pid):
39562306a36Sopenharmony_ci	pass
39662306a36Sopenharmony_ci
39762306a36Sopenharmony_cidef sched__sched_process_wait(event_name, context, common_cpu,
39862306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
39962306a36Sopenharmony_ci	common_callchain, comm, pid, prio):
40062306a36Sopenharmony_ci	pass
40162306a36Sopenharmony_ci
40262306a36Sopenharmony_cidef sched__sched_process_exit(event_name, context, common_cpu,
40362306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
40462306a36Sopenharmony_ci	common_callchain, comm, pid, prio):
40562306a36Sopenharmony_ci	pass
40662306a36Sopenharmony_ci
40762306a36Sopenharmony_cidef sched__sched_process_free(event_name, context, common_cpu,
40862306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
40962306a36Sopenharmony_ci	common_callchain, comm, pid, prio):
41062306a36Sopenharmony_ci	pass
41162306a36Sopenharmony_ci
41262306a36Sopenharmony_cidef sched__sched_migrate_task(event_name, context, common_cpu,
41362306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
41462306a36Sopenharmony_ci	common_callchain, comm, pid, prio, orig_cpu,
41562306a36Sopenharmony_ci	dest_cpu):
41662306a36Sopenharmony_ci	headers = EventHeaders(common_cpu, common_secs, common_nsecs,
41762306a36Sopenharmony_ci				common_pid, common_comm, common_callchain)
41862306a36Sopenharmony_ci	parser.migrate(headers, pid, prio, orig_cpu, dest_cpu)
41962306a36Sopenharmony_ci
42062306a36Sopenharmony_cidef sched__sched_switch(event_name, context, common_cpu,
42162306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm, common_callchain,
42262306a36Sopenharmony_ci	prev_comm, prev_pid, prev_prio, prev_state,
42362306a36Sopenharmony_ci	next_comm, next_pid, next_prio):
42462306a36Sopenharmony_ci
42562306a36Sopenharmony_ci	headers = EventHeaders(common_cpu, common_secs, common_nsecs,
42662306a36Sopenharmony_ci				common_pid, common_comm, common_callchain)
42762306a36Sopenharmony_ci	parser.sched_switch(headers, prev_comm, prev_pid, prev_prio, prev_state,
42862306a36Sopenharmony_ci			 next_comm, next_pid, next_prio)
42962306a36Sopenharmony_ci
43062306a36Sopenharmony_cidef sched__sched_wakeup_new(event_name, context, common_cpu,
43162306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
43262306a36Sopenharmony_ci	common_callchain, comm, pid, prio, success,
43362306a36Sopenharmony_ci	target_cpu):
43462306a36Sopenharmony_ci	headers = EventHeaders(common_cpu, common_secs, common_nsecs,
43562306a36Sopenharmony_ci				common_pid, common_comm, common_callchain)
43662306a36Sopenharmony_ci	parser.wake_up(headers, comm, pid, success, target_cpu, 1)
43762306a36Sopenharmony_ci
43862306a36Sopenharmony_cidef sched__sched_wakeup(event_name, context, common_cpu,
43962306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
44062306a36Sopenharmony_ci	common_callchain, comm, pid, prio, success,
44162306a36Sopenharmony_ci	target_cpu):
44262306a36Sopenharmony_ci	headers = EventHeaders(common_cpu, common_secs, common_nsecs,
44362306a36Sopenharmony_ci				common_pid, common_comm, common_callchain)
44462306a36Sopenharmony_ci	parser.wake_up(headers, comm, pid, success, target_cpu, 0)
44562306a36Sopenharmony_ci
44662306a36Sopenharmony_cidef sched__sched_wait_task(event_name, context, common_cpu,
44762306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
44862306a36Sopenharmony_ci	common_callchain, comm, pid, prio):
44962306a36Sopenharmony_ci	pass
45062306a36Sopenharmony_ci
45162306a36Sopenharmony_cidef sched__sched_kthread_stop_ret(event_name, context, common_cpu,
45262306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
45362306a36Sopenharmony_ci	common_callchain, ret):
45462306a36Sopenharmony_ci	pass
45562306a36Sopenharmony_ci
45662306a36Sopenharmony_cidef sched__sched_kthread_stop(event_name, context, common_cpu,
45762306a36Sopenharmony_ci	common_secs, common_nsecs, common_pid, common_comm,
45862306a36Sopenharmony_ci	common_callchain, comm, pid):
45962306a36Sopenharmony_ci	pass
46062306a36Sopenharmony_ci
46162306a36Sopenharmony_cidef trace_unhandled(event_name, context, event_fields_dict):
46262306a36Sopenharmony_ci	pass
463