Files
Oliver O'Halloran a382d1638a trace: Add nvram hack to use the old trace export behaviour
Previously we put all the trace buffer exports in the exports/ node.
However, there's one trace buffer for each core so I moved them into a
subdirectory since they were crowding up the place. Most kernels don't
support recursively exporting subnodes though so kernel's don't have
support for recursively exporting subnodes, so add a hack to restore the
old behaviour for now.

Signed-off-by: Oliver O'Halloran <oohall@gmail.com>
[Fixed run-trace test case - Vasant]
Signed-off-by: Vasant Hegde <hegdevasant@linux.vnet.ibm.com>
2021-06-30 15:05:55 +05:30

36 lines
894 B
C

// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
/* Copyright 2013-2019 IBM Corp. */
#ifndef __TRACE_H
#define __TRACE_H
#include <ccan/short_types/short_types.h>
#include <stddef.h>
#include <lock.h>
#include <trace_types.h>
struct cpu_thread;
/* Here's one we prepared earlier. */
void init_boot_tracebuf(struct cpu_thread *boot_cpu);
struct trace_info {
/* Lock for writers. Exposed to kernel. */
struct lock lock;
/* Exposed to kernel. */
struct tracebuf tb;
};
#define TBUF_SZ ((1024 * 1024) - sizeof(struct trace_info) - sizeof(union trace))
/* Allocate trace buffers once we know memory topology */
void init_trace_buffers(void);
void trace_add_dt_props(void);
/* This will fill in timestamp and cpu; you must do type and len. */
void trace_add(union trace *trace, u8 type, u16 len);
/* Put trace node into dt. */
void trace_add_node(void);
#endif /* __TRACE_H */