Все о моделировании в Компас-3D LT
   Главная Статьи Файлы Форум Ссылки Категории новостей
March 28 2024 12:10:01   
Навигация
Главная
Статьи
Файлы
FAQ
Форум
Ссылки
Категории новостей
Обратная связь
Фото галерея
Поиск
Разное
Карта Сайта
Популярные статьи
Что необходимо ... 65535
4.12.1 Професси... 32586
Учимся удалять!... 31844
Примеры, синони... 23248
Просмотр готовы... 22438
Декартовы коорд... 21971
FAST (методика ... 21283
содержание - се... 20519
Просмотр готовы... 19048
Работа с инстру... 14537
Сейчас на сайте
Гостей: 1
На сайте нет зарегистрированных пользователей

Пользователей: 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).
Комментарии
Нет комментариев.
Добавить комментарий
Пожалуйста залогиньтесь для добавления комментария.
Рейтинги
Рейтинг доступен только для пользователей.

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

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

Пароль



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

Забыли пароль?
Запросите новый здесь.
Случайные статьи
2.2.3 Спектральное...
Глава 2. GARMIN ST...
Измерения и анализ
1.6 Технология “...
4.9 Технология ISDN
Спрашивай – Отвечаем
4. Особенности выд...
Общение
Общая информация о...
Глава 8. HUMMINBIR...
«Ты прав, но это ...
Немного о КПК Mita...
12.3.3 Примеры ал...
3. Переосмысление ...
6.4 СОХРАНЕНИЕ КОН...
От автора
Функциональный пример
БИБЛИОГРАФИЧЕСКИЙ ...
1. Общий обзор мет...
2.4. Продуктивност...
2.3.2.4 Телеграфны...
Недопустимые комби...
6.5 УПРАВЛЕНИЕ АД...
Производители нара...
8.3.3 Построение п...
Контактная информация
7.4 ОЖИДАНИЕ ЗАВЕР...
ГЛАВА 10. ПОДСИСТЕ...
Квадратурно-амплит...
Выполняемые операции
6.4.2 Взаимодейст...
3.3 Адаптеры и пр...
TDK XS-iV Tremor M...
Аннотация
9.5. Инженерия ра...
Асинхронное и синх...
Использование подт...
Настройка параметр...
Страница «Навигация»
10.1.2.4 Стратегич...
Мини-чат
Вам необходимо залогиниться.

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