First published: Wed Mar 07 2018(Updated: )
The kernel packages contain the Linux kernel, the core of any Linux operating system.<br>Security Fix(es):<br>An industry-wide issue was found in the way many modern microprocessor designs have implemented speculative execution of instructions (a commonly used performance optimization). There are three primary variants of the issue which differ in the way the speculative execution can be exploited.<br>Note: This issue is present in hardware and cannot be fully fixed via software update. The updated kernel packages provide software mitigation for this hardware issue at a cost of potential performance penalty. Please refer to References section for further information about this issue and the performance impact.<br>In this update mitigations for x86-64 architecture are provided.<br><li> Variant CVE-2017-5753 triggers the speculative execution by performing a bounds-check bypass. It relies on the presence of a precisely-defined instruction sequence in the privileged code as well as the fact that memory accesses may cause allocation into the microprocessor's data cache even for speculatively executed instructions that never actually commit (retire). As a result, an unprivileged attacker could use this flaw to cross the syscall boundary and read privileged memory by conducting targeted cache side-channel attacks. (CVE-2017-5753, Important)</li> <li> Variant CVE-2017-5754 relies on the fact that, on impacted microprocessors, during speculative execution of instruction permission faults, exception generation triggered by a faulting access is suppressed until the retirement of the whole instruction block. In a combination with the fact that memory accesses may populate the cache even when the block is being dropped and never committed (executed), an unprivileged local attacker could use this flaw to read privileged (kernel space) memory by conducting targeted cache side-channel attacks. (CVE-2017-5754, Important)</li> Red Hat would like to thank Google Project Zero for reporting these issues.<br>Bug Fix(es):<br><li> Previously, the page table isolation feature was able to modify the kernel Page Global Directory (PGD) entries with the _NX bit even for CPUs without the capability to use the "no execute" (NX) bit technology. Consequently, the page tables got corrupted, and the kernel panicked at the first page-fault occurrence. This update adds the check of CPU capabilities before modifying kernel PGD entries with _NX. As a result, the operating system no longer panics on boot due to corrupted page tables under the described circumstances. (BZ#1538169)</li> <li> When booting the operating system with the Kernel Page Table Isolation option enabled, the HPET VSYSCALL shadow mapping was not placed correctly. Consequently, the High Precision Event Timer (HPET) feature was not available early enough, and warnings on boot time occurred. This update fixes the placement of HPET VSYSCALL, and the warnings on boot time due to this behavior no longer occur. (BZ#1541281)</li> <li> Previously, the routine preparing the kexec crashkernel area did not properly clear the page allocated to be kexec's Page Global Directory (PGD). Consequently, the page table isolation shadow mapping routines failed with a warning message when setting up page table entries. With this update, the underlying source code has been fixed to clear the kexec PGD allocated page before setting up its page table entries. As a result, warnings are no longer issued when setting up kexec. (BZ#1541285)</li> <li> When changing a kernel page mapping from Read Only (RO) to Read Write (RW), the Translation Lookaside Buffer (TLB) entry was previously not updated. Consequently, a protection fault on a write operation occurred, which led to a kernel panic. With this update, the underlying source code has been fixed to handle such kind of fault properly, and the kernel no longer panics in the described situation. (BZ#1541892)</li>
Affected Software | Affected Version | How to fix |
---|---|---|
redhat/kernel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debug | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debug-debuginfo | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debug-devel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debuginfo | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debuginfo-common | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-devel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-doc | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-headers | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-xen | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-xen-debuginfo | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-xen-devel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debug | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debug-debuginfo | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debug-devel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debuginfo | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-debuginfo-common | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-devel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-headers | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-xen | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-xen-debuginfo | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
redhat/kernel-xen-devel | <2.6.18-348.35.1.el5 | 2.6.18-348.35.1.el5 |
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.