tracing: Allow boot instances to use reserve_mem boot memory

Allow boot instances to use memory reserved by the reserve_mem boot
option.

  reserve_mem=12M:4096:trace  trace_instance=boot_mapped@trace

The above will allocate 12 megs with 4096 alignment and label it "trace".
The second parameter will create a "boot_mapped" instance and use the
memory reserved and labeled as "trace" as the memory for the ring buffer.

That will create an instance called "boot_mapped":

  /sys/kernel/tracing/instances/boot_mapped

Note, because the ring buffer is using a defined memory ranged, it will
act just like a memory mapped ring buffer. It will not have a snapshot
buffer, as it can't swap out the buffer. The snapshot files as well as any
tracers that uses a snapshot will not be present in the boot_mapped
instance.

Also note that reserve_mem is not reliable in acquiring the same physical
memory at each soft reboot. It is possible that KALSR could map the kernel
at the previous boot memory location forcing the reserve_mem to return a
different memory location. In this case, the previous ring buffer will be
lost.

Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Ross Zwisler <zwisler@google.com>
Cc: Vincent Donnefort <vdonnefort@google.com>
Link: https://lore.kernel.org/20240815082811.669f7d8c@gandalf.local.homeSigned-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
parent 6d02eefe
...@@ -6752,6 +6752,19 @@ ...@@ -6752,6 +6752,19 @@
memory at 0x284500000 that is 12Megs. The per CPU buffers of that memory at 0x284500000 that is 12Megs. The per CPU buffers of that
instance will be split up accordingly. instance will be split up accordingly.
Alternatively, the memory can be reserved by the reserve_mem option:
reserve_mem=12M:4096:trace trace_instance=boot_map@trace
This will reserve 12 megabytes at boot up with a 4096 byte alignment
and place the ring buffer in this memory. Note that due to KASLR, the
memory may not be the same location each time, which will not preserve
the buffer content.
Also note that the layout of the ring buffer data may change between
kernel versions where the validator will fail and reset the ring buffer
if the layout is not the same as the previous kernel.
trace_options=[option-list] trace_options=[option-list]
[FTRACE] Enable or disable tracer options at boot. [FTRACE] Enable or disable tracer options at boot.
The option-list is a comma delimited list of options The option-list is a comma delimited list of options
......
...@@ -10465,22 +10465,20 @@ __init static void enable_instances(void) ...@@ -10465,22 +10465,20 @@ __init static void enable_instances(void)
str = boot_instance_info; str = boot_instance_info;
while ((curr_str = strsep(&str, "\t"))) { while ((curr_str = strsep(&str, "\t"))) {
unsigned long start = 0; phys_addr_t start = 0;
unsigned long size = 0; phys_addr_t size = 0;
unsigned long addr = 0; unsigned long addr = 0;
tok = strsep(&curr_str, ","); tok = strsep(&curr_str, ",");
name = strsep(&tok, "@"); name = strsep(&tok, "@");
if (tok) {
if (tok && isdigit(*tok)) {
start = memparse(tok, &tok); start = memparse(tok, &tok);
if (!start) { if (!start) {
pr_warn("Tracing: Invalid boot instance address for %s\n", pr_warn("Tracing: Invalid boot instance address for %s\n",
name); name);
continue; continue;
} }
}
if (start) {
if (*tok != ':') { if (*tok != ':') {
pr_warn("Tracing: No size specified for instance %s\n", name); pr_warn("Tracing: No size specified for instance %s\n", name);
continue; continue;
...@@ -10492,10 +10490,19 @@ __init static void enable_instances(void) ...@@ -10492,10 +10490,19 @@ __init static void enable_instances(void)
name); name);
continue; continue;
} }
} else if (tok) {
if (!reserve_mem_find_by_name(tok, &start, &size)) {
start = 0;
pr_warn("Failed to map boot instance %s to %s\n", name, tok);
continue;
}
}
if (start) {
addr = map_pages(start, size); addr = map_pages(start, size);
if (addr) { if (addr) {
pr_info("Tracing: mapped boot instance %s at physical memory 0x%lx of size 0x%lx\n", pr_info("Tracing: mapped boot instance %s at physical memory %pa of size 0x%lx\n",
name, start, size); name, &start, (unsigned long)size);
} else { } else {
pr_warn("Tracing: Failed to map boot instance %s\n", name); pr_warn("Tracing: Failed to map boot instance %s\n", name);
continue; continue;
......
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