STIGhubSTIGhub
STIGsRMF ControlsCompare

STIGhub

A free tool to search and browse the entire DISA STIG library. Saves up to 75% in security compliance research time.

Navigation

  • Browse STIGs
  • Search
  • RMF Controls
  • Compare Versions

Resources

  • About
  • Release Notes
  • VPAT
  • DISA STIG Library
STIGs updated 3 hours ago
Powered by Pylon
© 2026 Beacon Cloud Solutions, Inc. All rights reserved.
← Back to Oracle Linux 8 Security Technical Implementation Guide

V-248591

CAT II (Medium)

OL 8 must disable virtual syscalls.

Rule ID

SV-248591r958518_rule

STIG

Oracle Linux 8 Security Technical Implementation Guide

Version

V2R8

CCIs

CCI-001084

Discussion

Syscalls are special routines in the Linux kernel, which userspace applications ask to do privileged tasks. Invoking a system call is an expensive operation because the processor must interrupt the currently executing task and switch context to kernel mode and then back to userspace after the system call completes. Virtual syscalls map into user space a page that contains some variables and the implementation of some system calls. This allows the system calls to be executed in userspace to alleviate the context switching expense. Virtual syscalls provide an opportunity of attack for a user who has control of the return instruction pointer. Disabling vsyscalls help to prevent return-oriented programming (ROP) attacks via buffer overflows and overruns. If the system intends to run containers based on OL 6 components, then virtual syscalls will need enabled so the components function properly.

Check Content

Verify that GRUB 2 is configured to disable vsyscalls with the following commands: 
 
$ sudo grub2-editenv list | grep vsyscall 
 
kernelopts=root=/dev/mapper/ol-root ro crashkernel=auto resume=/dev/mapper/ol-swap rd.lvm.lv=ol/root rd.lvm.lv=ol/swap rhgb quiet fips=1 page_poison=1 vsyscall=none audit=1 audit_backlog_limit=8192 boot=UUID=8d171156-cd61-421c-ba41-1c021ac29e82 
 
If "vsyscall" is not set to "none" or is missing, this is a finding. 
 
Check that vsyscalls are disabled by default to persist in kernel updates:  
 
$ sudo grep vsyscall /etc/default/grub 
 
GRUB_CMDLINE_LINUX="vsyscall=none" 
 
If "vsyscall" is not set to "none", is missing or commented out and is not documented with the Information System Security Officer (ISSO) as an operational requirement, this is a finding.

Fix Text

Document the use of vsyscalls with the ISSO as an operational requirement or disable them with the following command:
 
$ sudo grubby --update-kernel=ALL --args="vsyscall=none" 
 
Add or modify the following line in "/etc/default/grub" to ensure the configuration survives kernel updates: 
 
GRUB_CMDLINE_LINUX="vsyscall=none"