• Martin Storsjö's avatar
    ntdll: Zero-initialize the syscall_frame used for starting threads on ARM/ARM64. · 482b6a6d
    Martin Storsjö authored
    This fixes an inconsistency since
    fed7e7a7 (ntdll: Simulate a syscall
    return when starting a thread); in that commit, on i386 and
    x86_64, the syscall_frame used for starting the thread was
    zeroed with a memset, while it wasn't on arm and arm64.
    
    This had a noticable effect on float maths, where the
    uninitialized frame->restore_flags field could have the
    CONTEXT_FLOATING_POINT bit set. (call_init_thunk only ORs in
    CONTEXT_INTEGER into the restore_flags field, on all architectures).
    If that bit was set, it would restore uninitialized data into the
    fpscr register, possibly setting the FPU in a nondefault rounding
    mode.
    Signed-off-by: 's avatarMartin Storsjö <martin@martin.st>
    Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
    482b6a6d
Name
Last commit
Last update
..
cdrom.c Loading commit data...
debug.c Loading commit data...
env.c Loading commit data...
file.c Loading commit data...
loader.c Loading commit data...
loadorder.c Loading commit data...
process.c Loading commit data...
registry.c Loading commit data...
security.c Loading commit data...
serial.c Loading commit data...
server.c Loading commit data...
signal_arm.c Loading commit data...
signal_arm64.c Loading commit data...
signal_i386.c Loading commit data...
signal_x86_64.c Loading commit data...
socket.c Loading commit data...
sync.c Loading commit data...
system.c Loading commit data...
tape.c Loading commit data...
thread.c Loading commit data...
unix_private.h Loading commit data...
virtual.c Loading commit data...