Все о моделировании в Компас-3D LT
   Главная Статьи Файлы Форум Ссылки Категории новостей
October 30 2025 08:23:19   
Навигация
Главная
Статьи
Файлы
FAQ
Форум
Ссылки
Категории новостей
Обратная связь
Фото галерея
Поиск
Разное
Карта Сайта
Популярные статьи
Что необходимо ... 65535
4.12.1 Професси... 35981
Учимся удалять!... 32819
Примеры, синони... 24087
Просмотр готовы... 23377
Декартовы коорд... 23354
FAST (методика ... 22120
содержание - се... 21461
Просмотр готовы... 20313
Работа с инстру... 15858
Сейчас на сайте
Гостей: 2
На сайте нет зарегистрированных пользователей

Пользователей: 9,955
новичок: Logyattella
Друзья сайта
Ramblers Top100
Рейтинг@Mail.ru

Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ по Delphi
Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog
6.4.5 Копирование данных между адресным пространством системы и адресным пространством задачи
До сих пор речь шла о том, что процесс выполняется в режиме ядра или в режиме задачи без каких-либо перекрытий (пересечений) между режимами. Однако, при выполнении большинства системных функций, рассмотренных в последней главе, между пространством ядра и пространством задачи осуществляется пересылка данных, например, когда идет копирование параметров вызываемой функции из пространства задачи в пространство ядра или когда производится передача данных из буферов ввода-вывода в процессе выполнения функции read. На многих машинах ядро системы может непосредственно ссылаться на адреса, принадлежащие адресному пространству задачи. Ядро должно убедиться в том, что адрес, по которому производится запись или считывание, доступен, как будто бы работа ведется в режиме задачи; в противном случае произошло бы нарушение стандартных методов защиты и ядро, пусть неумышленно, стало бы обращаться к адресам, которые находятся за пределами адресного пространства задачи (и, возможно, принадлежат структурам данных ядра). Поэтому передача данных между пространством ядра и пространством задачи является «дорогим предприятием», требующим для своей реализации нескольких команд.
fubyte: # пересылка байта из пространства задачи
prober $3, $1, *4(ap) # байт доступен?
beql eret # нет
movzbl *4(ap), r0
ret
eret:
mnegl $1, r0 # возврат ошибки (-1)
ret
Рисунок 6.17. Пересылка данных из пространства задачи в пространство ядра в системе VAX
На Рисунке 6.17 показан пример реализованной в системе VAX программы пересылки символа из адресного пространства задачи в адресное пространство ядра. Команда prober проверяет, может ли байт по адресу, равному (регистр указателя аргумента + 4), быть считан в режиме задачи (режиме 3), и если нет, ядро передает управление по адресу eret, сохраняет в нулевом регистре -1 и выходит из программы; при этом пересылки символа не происходит. В противном случае ядро пересылает один байт, находящийся по указанному адресу, в регистр 0 и возвращает его в вызывающую программу. Пересылка 1 символа потребовала пяти команд (включая вызов функции с именем fubyte).
Комментарии
Нет комментариев.
Добавить комментарий
Пожалуйста залогиньтесь для добавления комментария.
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Случайные статьи
Отображение модели...
Технология совмест...
Вспомогательные:
Подтип сущности
8. При выделении п...
Как правильно уста...
Creative MegaWorks...
содержание - сетев...
Представление атри...
Глава 6. Подключен...
Глава 3. Как выбр...
О чем мы узнали ?
Примеры и идентифи...
Управление програм...
3. Обзор концепции...
Уникальный идентиф...
Изображение связи
Группа 2 — програм...
3.7 Сеть NetWare ...
Опции поддержки IPv6
Какую информацию с...
О легальности испо...
По законам джунглей
Горизонтальное ска...
ВТОРОЙ ПРИМЕР
11.5 ВЫВОДЫ
9.1.2.1 Выгрузка п...
3.2. Уровни зрелости
Основные характери...
13.3 "ПРОЗРАЧНЫЕ" ...
Коммутация пакетов
Глава 4. ROADINFORMER
Определение связи
Использование един...
3. Декомпозиция пр...
Реализация в базе ...
Метод доступа в се...
ГЛАВА 10. ПОДСИСТЕ...
4.2 Распределение ...
Глава 2. GARMIN ST...
Мини-чат
Вам необходимо залогиниться.

Нет присланных сообщений.
Copyright © 2009