On 6/19/2020 3:41 PM, Peter Zijlstra wrote:
On Fri, Jun 19, 2020 at 07:04:08AM -0700, [email protected] wrote:
The XSAVE instruction requires 64-byte alignment for state buffers. A
64-byte aligned kmem_cache is created for architecture LBR.

+               pmu->task_ctx_cache = create_lbr_kmem_cache(size,
+                                                           XSAVE_ALIGNMENT);

+struct x86_perf_task_context_arch_lbr_xsave {
+       struct x86_perf_task_context_opt        opt;
+       union {
+               struct xregs_state              xsave;

Due to x86_perf_task_context_opt, what guarantees you're actually at the
required alignment here?

Now it relies on the compiler. The struct xregs_state has 'aligned(64)' attribute applied. I think we probably need a padding to get rid of the dependency for the compiler.

+       union {
+               struct x86_perf_task_context_opt        opt;
+               u8 padding[64];
+       };

Thanks,
Kan


+               struct {
+                       struct fxregs_state     i387;
+                       struct xstate_header    header;
+                       struct arch_lbr_state   lbr;
+               };
+       };
+};

Reply via email to