unplugged-kernel/drivers/misc/mediatek/performance/resym/rs_trace.c

110 lines
1.8 KiB
C

// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (C) 2020 MediaTek Inc.
*/
#include <linux/preempt.h>
#include <linux/trace_events.h>
#include "rs_trace.h"
#define LOGSIZE 32
static unsigned long __read_mostly mark_addr;
static int rs_update_tracemark(void)
{
if (mark_addr)
return 1;
mark_addr = kallsyms_lookup_name("tracing_mark_write");
if (unlikely(!mark_addr))
return 0;
return 1;
}
void __rs_systrace_c(pid_t pid, int val, const char *fmt, ...)
{
char log[LOGSIZE];
va_list args;
int len;
if (unlikely(!rs_update_tracemark()))
return;
va_start(args, fmt);
len = vsnprintf(log, LOGSIZE, fmt, args);
va_end(args);
if (len == LOGSIZE)
log[LOGSIZE - 1] = '\0';
preempt_disable();
event_trace_printk(mark_addr, "C|%d|%s|%d\n", pid, log, val);
preempt_enable();
}
void __rs_systrace_c_uint64(pid_t pid, uint64_t val, const char *fmt, ...)
{
char log[LOGSIZE];
va_list args;
int len;
if (unlikely(!rs_update_tracemark()))
return;
va_start(args, fmt);
len = vsnprintf(log, LOGSIZE, fmt, args);
va_end(args);
if (len == LOGSIZE)
log[LOGSIZE - 1] = '\0';
preempt_disable();
event_trace_printk(mark_addr, "C|%d|%s|%llu\n", pid, log, val);
preempt_enable();
}
void __rs_systrace_b(pid_t tgid, const char *fmt, ...)
{
char log[LOGSIZE];
va_list args;
int len;
if (unlikely(!rs_update_tracemark()))
return;
va_start(args, fmt);
len = vsnprintf(log, LOGSIZE, fmt, args);
va_end(args);
if (len == LOGSIZE)
log[LOGSIZE - 1] = '\0';
preempt_disable();
event_trace_printk(mark_addr, "B|%d|%s\n", tgid, log);
preempt_enable();
}
void __rs_systrace_e(void)
{
if (unlikely(!rs_update_tracemark()))
return;
preempt_disable();
event_trace_printk(mark_addr, "E\n");
preempt_enable();
}
int rs_trace_init(void)
{
if (!rs_update_tracemark())
return -1;
return 0;
}