mirror of
https://github.com/torvalds/linux.git
synced 2024-11-27 06:31:52 +00:00
14a8644d4f
Add the mm_cid field to the rseq_update event, allowing tracers to follow which mm_cid is observed by user-space, and whether negative mm_cid values are visible in case of internal scheduler implementation issues. Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Link: https://lore.kernel.org/r/20221122203932.231377-22-mathieu.desnoyers@efficios.com
63 lines
1.4 KiB
C
63 lines
1.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
#undef TRACE_SYSTEM
|
|
#define TRACE_SYSTEM rseq
|
|
|
|
#if !defined(_TRACE_RSEQ_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
#define _TRACE_RSEQ_H
|
|
|
|
#include <linux/tracepoint.h>
|
|
#include <linux/types.h>
|
|
|
|
TRACE_EVENT(rseq_update,
|
|
|
|
TP_PROTO(struct task_struct *t),
|
|
|
|
TP_ARGS(t),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(s32, cpu_id)
|
|
__field(s32, node_id)
|
|
__field(s32, mm_cid)
|
|
),
|
|
|
|
TP_fast_assign(
|
|
__entry->cpu_id = raw_smp_processor_id();
|
|
__entry->node_id = cpu_to_node(__entry->cpu_id);
|
|
__entry->mm_cid = task_mm_cid(t);
|
|
),
|
|
|
|
TP_printk("cpu_id=%d node_id=%d mm_cid=%d", __entry->cpu_id,
|
|
__entry->node_id, __entry->mm_cid)
|
|
);
|
|
|
|
TRACE_EVENT(rseq_ip_fixup,
|
|
|
|
TP_PROTO(unsigned long regs_ip, unsigned long start_ip,
|
|
unsigned long post_commit_offset, unsigned long abort_ip),
|
|
|
|
TP_ARGS(regs_ip, start_ip, post_commit_offset, abort_ip),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(unsigned long, regs_ip)
|
|
__field(unsigned long, start_ip)
|
|
__field(unsigned long, post_commit_offset)
|
|
__field(unsigned long, abort_ip)
|
|
),
|
|
|
|
TP_fast_assign(
|
|
__entry->regs_ip = regs_ip;
|
|
__entry->start_ip = start_ip;
|
|
__entry->post_commit_offset = post_commit_offset;
|
|
__entry->abort_ip = abort_ip;
|
|
),
|
|
|
|
TP_printk("regs_ip=0x%lx start_ip=0x%lx post_commit_offset=%lu abort_ip=0x%lx",
|
|
__entry->regs_ip, __entry->start_ip,
|
|
__entry->post_commit_offset, __entry->abort_ip)
|
|
);
|
|
|
|
#endif /* _TRACE_SOCK_H */
|
|
|
|
/* This part must be outside protection */
|
|
#include <trace/define_trace.h>
|