RHEL 10 must implement nonexecutable data to protect its memory from unauthorized code execution.
Overview
| Finding ID | Version | Rule ID | IA Controls | Severity |
| V-281293 | RHEL-10-700900 | SV-281293r1166831_rule | CCI-002824 | medium |
| Description | ||||
| ExecShield uses the segmentation feature on all x86 systems to prevent execution in memory higher than a certain address. It writes an address as a limit in the code segment descriptor, to control where code can be executed, on a per-process basis. When the kernel places a process's memory regions such as the stack and heap higher than this address, the hardware prevents execution in that address range. This is enabled by default on the latest Red Hat and Fedora systems if supported by the hardware. | ||||
| STIG | Date | |||
| Red Hat Enterprise Linux 10 Security Technical Implementation Guide | 2026-03-11 | |||
Details
Check Text (C-281293r1166831_chk)
Verify RHEL 10 implements nonexecutable data to protect its memory from unauthorized code execution.
Run the following command:
$ sudo grep ^flags /proc/cpuinfo | grep -Ev '([^[:alnum:]])(nx)([^[:alnum:]]|$)'
If any output is returned, this is a finding.
Run the following command:
$ sudo grubby --info=ALL | grep args | grep -E '([^[:alnum:]])(noexec)([^[:alnum:]])'
If any output is returned, this is a finding.
Fix Text (F-85759r1166830_fix)
Configure RHEL 10 to implement nonexecutable data to protect its memory from unauthorized code execution.
Update the GRUB 2 bootloader configuration.
Run the following command:
$ sudo grubby --update-kernel=ALL --remove-args=noexec