Commit 24203036 authored by Anton Vorontsov's avatar Anton Vorontsov

pstore/ram: Mark ramoops_pstore_write_buf() as notrace

write_buf() should be marked as notrace, otherwise it is prone to
recursion.

Though, yet the issue is never triggered in real life, because we run
inside the function tracer, where ftrace does its own recurse protection.

But it's still no good, plus soon we might switch to our own tracer ops,
and then the issue will be fatal. So, let's fix it.
Signed-off-by: default avatarAnton Vorontsov <anton.vorontsov@linaro.org>
parent 0427193b
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
#include <linux/ioport.h> #include <linux/ioport.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/compiler.h>
#include <linux/pstore_ram.h> #include <linux/pstore_ram.h>
#define RAMOOPS_KERNMSG_HDR "====" #define RAMOOPS_KERNMSG_HDR "===="
...@@ -181,12 +182,11 @@ static size_t ramoops_write_kmsg_hdr(struct persistent_ram_zone *prz) ...@@ -181,12 +182,11 @@ static size_t ramoops_write_kmsg_hdr(struct persistent_ram_zone *prz)
return len; return len;
} }
static int notrace ramoops_pstore_write_buf(enum pstore_type_id type,
static int ramoops_pstore_write_buf(enum pstore_type_id type, enum kmsg_dump_reason reason,
enum kmsg_dump_reason reason, u64 *id, unsigned int part,
u64 *id, unsigned int part, const char *buf, size_t size,
const char *buf, size_t size, struct pstore_info *psi)
struct pstore_info *psi)
{ {
struct ramoops_context *cxt = psi->data; struct ramoops_context *cxt = psi->data;
struct persistent_ram_zone *prz = cxt->przs[cxt->dump_write_cnt]; struct persistent_ram_zone *prz = cxt->przs[cxt->dump_write_cnt];
......
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