Scroll to navigation

PR_GET_SPECULATION_CTRL(2const) PR_GET_SPECULATION_CTRL(2const)

NAME

PR_GET_SPECULATION_CTRL - get the state of a speculation misfeature for the calling thread

LIBRARY

Standard C library (libc, -lc)

SYNOPSIS

#include <linux/prctl.h>  /* Definition of PR_* constants */
#include <sys/prctl.h>
int prctl(PR_GET_SPECULATION_CTRL, long misfeature, 0L, 0L, 0L);

DESCRIPTION

Return the state of the speculation misfeature specified in misfeature.

Currently, misfeature must be one of:

Get the state of the speculative store bypass misfeature.
Get the state of the indirect branch speculation misfeature.

The return value uses bits 0-4 with the following meaning:

Mitigation can be controlled per thread by PR_SET_SPECULATION_CTRL(2const).
The speculation feature is enabled, mitigation is disabled.
The speculation feature is disabled, mitigation is enabled.
Same as PR_SPEC_DISABLE but cannot be undone.
Same as PR_SPEC_DISABLE, but the state will be cleared on execve(2).

If all bits are 0, then the CPU is not affected by the speculation misfeature.

If PR_SPEC_PRCTL is set, then per-thread control of the mitigation is available. If not set, PR_SET_SPECULATION_CTRL(2const) for the speculation misfeature will fail.

RETURN VALUE

On success, PR_GET_SPECULATION_CTRL returns the nonnegative value described above. On error, -1 is returned, and errno is set to indicate the error.

ERRORS

The kernel or CPU does not support the requested speculation misfeature.

STANDARDS

Linux.

HISTORY

Linux 4.17.

SEE ALSO

prctl(2), PR_SET_SPECULATION_CTRL(2const)

2024-06-01 Linux man-pages (unreleased)