arm64: fpsimd: Avoid FPSIMD context leakage for the init task
authorDave Martin <Dave.Martin@arm.com>
Thu, 24 May 2018 14:54:30 +0000 (15:54 +0100)
committerMarc Zyngier <marc.zyngier@arm.com>
Fri, 25 May 2018 11:27:55 +0000 (12:27 +0100)
The init task is started with thread_flags equal to 0, which means
that TIF_FOREIGN_FPSTATE is initially clear.

It is theoretically possible (if unlikely) that the init task could
reach userspace without ever being scheduled out.  If this occurs,
data left in the FPSIMD registers by the kernel could be exposed.

This patch fixes this anomaly by ensuring that the init task's
initial TIF_FOREIGN_FPSTATE is set.

Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Fixes: 005f78cd8849 ("arm64: defer reloading a task's FPSIMD state to userland resume")
Reviewed-by: Catalin Marinas <catalin.marinas@arm.com>
Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
Cc: Will Deacon <will.deacon@arm.com>
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
arch/arm64/include/asm/thread_info.h

index 740aa03c5f0dc8bd6ead32b57453e4537895f56e..af271f9a6c9f2c07d6e27b3bfcb9d09e16bf26a6 100644 (file)
@@ -45,12 +45,6 @@ struct thread_info {
        int                     preempt_count;  /* 0 => preemptable, <0 => bug */
 };
 
-#define INIT_THREAD_INFO(tsk)                                          \
-{                                                                      \
-       .preempt_count  = INIT_PREEMPT_COUNT,                           \
-       .addr_limit     = KERNEL_DS,                                    \
-}
-
 #define thread_saved_pc(tsk)   \
        ((unsigned long)(tsk->thread.cpu_context.pc))
 #define thread_saved_sp(tsk)   \
@@ -117,5 +111,12 @@ void arch_release_task_struct(struct task_struct *tsk);
                                 _TIF_SYSCALL_TRACEPOINT | _TIF_SECCOMP | \
                                 _TIF_NOHZ)
 
+#define INIT_THREAD_INFO(tsk)                                          \
+{                                                                      \
+       .flags          = _TIF_FOREIGN_FPSTATE,                         \
+       .preempt_count  = INIT_PREEMPT_COUNT,                           \
+       .addr_limit     = KERNEL_DS,                                    \
+}
+
 #endif /* __KERNEL__ */
 #endif /* __ASM_THREAD_INFO_H */