Commit 9a98e778 authored by Thomas Gleixner's avatar Thomas Gleixner Committed by Ingo Molnar

x86/asm: Replace access to desc_struct:a/b fields

The union inside of desc_struct which allows access to the raw u32 parts of
the descriptors. This raw access part is about to go away.

Replace the few code parts which access those fields.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Reviewed-by: default avatarBoris Ostrovsky <boris.ostrovsky@oracle.com>
Cc: Andy Lutomirski <luto@kernel.org>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Brian Gerst <brgerst@gmail.com>
Cc: Denys Vlasenko <dvlasenk@redhat.com>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Josh Poimboeuf <jpoimboe@redhat.com>
Cc: Juergen Gross <jgross@suse.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/r/20170828064958.120214366@linutronix.deSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
parent 718f5d00
...@@ -552,6 +552,8 @@ static inline void ...@@ -552,6 +552,8 @@ static inline void
MULTI_update_descriptor(struct multicall_entry *mcl, u64 maddr, MULTI_update_descriptor(struct multicall_entry *mcl, u64 maddr,
struct desc_struct desc) struct desc_struct desc)
{ {
u32 *p = (u32 *) &desc;
mcl->op = __HYPERVISOR_update_descriptor; mcl->op = __HYPERVISOR_update_descriptor;
if (sizeof(maddr) == sizeof(long)) { if (sizeof(maddr) == sizeof(long)) {
mcl->args[0] = maddr; mcl->args[0] = maddr;
...@@ -559,8 +561,8 @@ MULTI_update_descriptor(struct multicall_entry *mcl, u64 maddr, ...@@ -559,8 +561,8 @@ MULTI_update_descriptor(struct multicall_entry *mcl, u64 maddr,
} else { } else {
mcl->args[0] = maddr; mcl->args[0] = maddr;
mcl->args[1] = maddr >> 32; mcl->args[1] = maddr >> 32;
mcl->args[2] = desc.a; mcl->args[2] = *p++;
mcl->args[3] = desc.b; mcl->args[3] = *p;
} }
trace_xen_mc_entry(mcl, sizeof(maddr) == sizeof(long) ? 2 : 4); trace_xen_mc_entry(mcl, sizeof(maddr) == sizeof(long) ? 2 : 4);
......
...@@ -93,7 +93,7 @@ static void set_tls_desc(struct task_struct *p, int idx, ...@@ -93,7 +93,7 @@ static void set_tls_desc(struct task_struct *p, int idx,
while (n-- > 0) { while (n-- > 0) {
if (LDT_empty(info) || LDT_zero(info)) { if (LDT_empty(info) || LDT_zero(info)) {
desc->a = desc->b = 0; memset(desc, 0, sizeof(*desc));
} else { } else {
fill_ldt(desc, info); fill_ldt(desc, info);
......
...@@ -494,7 +494,7 @@ static void __init xen_load_gdt_boot(const struct desc_ptr *dtr) ...@@ -494,7 +494,7 @@ static void __init xen_load_gdt_boot(const struct desc_ptr *dtr)
static inline bool desc_equal(const struct desc_struct *d1, static inline bool desc_equal(const struct desc_struct *d1,
const struct desc_struct *d2) const struct desc_struct *d2)
{ {
return d1->a == d2->a && d1->b == d2->b; return !memcmp(d1, d2, sizeof(*d1));
} }
static void load_TLS_descriptor(struct thread_struct *t, static void load_TLS_descriptor(struct thread_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