Commit 60af388d authored by Eric Dumazet's avatar Eric Dumazet Committed by Peter Zijlstra

rseq: Optimize rseq_update_cpu_id()

Two put_user() in rseq_update_cpu_id() are replaced
by a pair of unsafe_put_user() with appropriate surroundings.

This removes one stac/clac pair on x86 in fast path.
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: default avatarMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Link: https://lkml.kernel.org/r/20210413203352.71350-2-eric.dumazet@gmail.com
parent 4bad58eb
...@@ -84,13 +84,20 @@ ...@@ -84,13 +84,20 @@
static int rseq_update_cpu_id(struct task_struct *t) static int rseq_update_cpu_id(struct task_struct *t)
{ {
u32 cpu_id = raw_smp_processor_id(); u32 cpu_id = raw_smp_processor_id();
struct rseq __user *rseq = t->rseq;
if (put_user(cpu_id, &t->rseq->cpu_id_start)) if (!user_write_access_begin(rseq, sizeof(*rseq)))
return -EFAULT; goto efault;
if (put_user(cpu_id, &t->rseq->cpu_id)) unsafe_put_user(cpu_id, &rseq->cpu_id_start, efault_end);
return -EFAULT; unsafe_put_user(cpu_id, &rseq->cpu_id, efault_end);
user_write_access_end();
trace_rseq_update(t); trace_rseq_update(t);
return 0; return 0;
efault_end:
user_write_access_end();
efault:
return -EFAULT;
} }
static int rseq_reset_rseq_cpu_id(struct task_struct *t) static int rseq_reset_rseq_cpu_id(struct task_struct *t)
......
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