[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
NetBSD Security Advisory 2012-003: Intel processors sysret to non-canonical address behaviour
-----BEGIN PGP SIGNED MESSAGE-----
NetBSD Security Advisory 2012-003
Topic: Intel processors sysret to non-canonical address behaviour
Version: NetBSD-current: source prior to June 11, 2012
NetBSD 6.0 Beta: affected
NetBSD 5.1.*: affected
NetBSD 5.1: affected
NetBSD 5.0.*: affected
NetBSD 5.0: affected
NetBSD 4.0.*: affected
NetBSD 4.0: affected
Severity: local DoS, possibly local user privilege escalation
Fixed: NetBSD-current: June 12th, 2012
NetBSD-6 branch: June 12th, 2012
NetBSD-5 branch: June 12th, 2012
NetBSD-5-1 branch: June 12th, 2012
NetBSD-5-0 branch: June 12th, 2012
NetBSD-4 branch: June 12th, 2012
NetBSD-4-0 branch: June 12th, 2012
Please note that NetBSD releases prior to 4.0 are no longer supported.
It is recommended that all users upgrade to a supported release.
On Intel CPUs, the sysret instruction can be manipulated into returning
to specific non-canonical addresses, which may yield a CPU reset.
We cannot currently rule out with utter confidence that this vulnerability
could not also be used to execute code with kernel privilege instead
of crashing the system.
This vulnerability has been assigned CVE-2012-0217.
This is a vulnerability following from a difference of behaviour of
sysret in Intel's version of the amd64 architecture, em64t.
System calls may be implemented as using the em64t syscall/sysret
syscall saves the context of the calling unprivileged process before
executing a system call in kernel mode; sysret restores it and resumes
ordinary operations in user mode.
In the Intel implementation of sysret, if you have invalid information
about the "next instruction" address in your saved context, the sysret
instruction will trigger a trap in kernel space. However the sysret
instruction is executed with the user stack pointer already loaded,
so the kernel fault frame is written to the user stack.
The kernel is unable to safely recover from this, so must ensure
that the trap doesn't happen.
If your invalid "next instruction" address is in kernel space or
in user space (and in the latter case, not where your program is)
the program will segfault.
If it is in the gap between user space and kernel space, the CPU
will reset, except if someone managed to seed the address location
with a valid instruction.
Solutions and Workarounds
The fix in the following versions will disallow sysret to
an invalid address.
Thanks to Manuel Bouyer for providing the fix, and David Laight for
help with writing the advisory. Also, thanks to Rafal Wojtczuk for
bringing the issue to our attention.
2012-06-14 Initial release
Advisories may be updated as new information becomes available.
The most recent version of this advisory (PGP signed) can be found at
Information about NetBSD and NetBSD security can be found at
http://www.NetBSD.org/ and http://www.NetBSD.org/Security/ .
Copyright 2012, The NetBSD Foundation, Inc. All Rights Reserved.
Redistribution permitted only in full, unmodified form.
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.12 (GNU/Linux)
-----END PGP SIGNATURE-----
Main Index |
Thread Index |