Scroll to navigation

VM86(2) Руководство программиста Linux VM86(2)

ИМЯ

vm86old, vm86 - войти в виртуальный режим 8086

ОБЗОР

#include <sys/vm86.h>

int vm86old(struct vm86_struct *info);

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

ОПИСАНИЕ

Системный вызов vm86() был введён в Linux 0.97p2. В Linux 2.1.15 и 2.0.28 он был переименован в vm86old() и был введён новый vm86(). Описание структуры struct vm86_struct было изменено в 1.1.8 и 1.1.9.

Данные вызовы заставляют вызывающий процесс войти в режим VM86 (виртуальный режим 8086 в литературе по Intel) и используются dosemu.

Режим VM86 — это эмуляция реального режима внутри задачи, которая работает в защищённом режиме.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении возвращается 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.

ОШИБКИ

Возвращённое значение является специфичным для i386 и указывает на проблему получения данных из пространства пользователя.
Возвращённое значение указывает что вызов не реализован на данной архитектуре.
Существует сохранённый стек ядра. (Это проверка ядра; сохранённый стек должен существовать только внутри самого режима vm86).

СООТВЕТСТВИЕ СТАНДАРТАМ

Данный вызов является специфичным для Linux на 32-битных процессорах Intel и не должен использоваться в программах, которые задумываются как переносимые на другие платформы.

2009-02-20 Linux