Commit c6dfce27 authored by Zebediah Figura's avatar Zebediah Figura Committed by Alexandre Julliard

server: Fix pointer arithmetic in get_selector_entry().

The selector table is exclusively 32-bit, so trying to get selector entries with a 64-bit wineserver will return the wrong values due to the different size of (long *). Signed-off-by: 's avatarZebediah Figura <z.figura12@gmail.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 67d7eb98
...@@ -517,13 +517,13 @@ void get_selector_entry( struct thread *thread, int entry, unsigned int *base, ...@@ -517,13 +517,13 @@ void get_selector_entry( struct thread *thread, int entry, unsigned int *base,
} }
if (suspend_for_ptrace( thread )) if (suspend_for_ptrace( thread ))
{ {
unsigned char flags_buf[sizeof(long)]; unsigned char flags_buf[4];
long *addr = (long *)(unsigned long)thread->process->ldt_copy + entry; unsigned long addr = (unsigned long)thread->process->ldt_copy + (entry * 4);
if (read_thread_long( thread, addr, (long *)base ) == -1) goto done; if (read_thread_long( thread, (long *)addr, (long *)base ) == -1) goto done;
if (read_thread_long( thread, addr + 8192, (long *)limit ) == -1) goto done; if (read_thread_long( thread, (long *)(addr + (8192 * 4)), (long *)limit ) == -1) goto done;
addr = (long *)(unsigned long)thread->process->ldt_copy + 2*8192 + (entry / sizeof(long)); addr = (unsigned long)thread->process->ldt_copy + (2 * 8192 * 4) + (entry & ~3);
if (read_thread_long( thread, addr, (long *)flags_buf ) == -1) goto done; if (read_thread_long( thread, (long *)addr, (long *)flags_buf ) == -1) goto done;
*flags = flags_buf[entry % sizeof(long)]; *flags = flags_buf[entry % 4];
done: done:
resume_after_ptrace( thread ); resume_after_ptrace( thread );
} }
......
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