vm86 - Man Page

enter virtual 8086 mode

Library

Standard C library (libc, -lc)

Synopsis

#include <sys/vm86.h>

int vm86old(struct vm86_struct *info);
int vm86(unsigned long fn, struct vm86plus_struct *v86);

Description

The system call vm86() was introduced in Linux 0.97p2. In Linux 2.1.15 and 2.0.28, it was renamed to vm86old(), and a new vm86() was introduced. The definition of struct vm86_struct was changed in 1.1.8 and 1.1.9.

These calls cause the process to enter VM86 mode (virtual-8086 in Intel literature), and are used by dosemu.

VM86 mode is an emulation of real mode within a protected mode task.

Return Value

On success, zero is returned. On error, -1 is returned, and errno is set to indicate the error.

Errors

EFAULT

This return value is specific to i386 and indicates a problem with getting user-space data.

ENOSYS

This return value indicates the call is not implemented on the present architecture.

EPERM

Saved kernel stack exists. (This is a kernel sanity check; the saved stack should exist only within vm86 mode itself.)

Standards

Linux on 32-bit Intel processors.

Referenced By

capabilities(7), modify_ldt(2), syscalls(2), systemd.exec(5), unimplemented(2).

The man page vm86old(2) is an alias of vm86(2).

2024-05-02 Linux man-pages 6.9.1