Все о моделировании в Компас-3D LT
   Главная Статьи Файлы Форум Ссылки Категории новостей
July 27 2024 03:25:51   
Навигация
Главная
Статьи
Файлы
FAQ
Форум
Ссылки
Категории новостей
Обратная связь
Фото галерея
Поиск
Разное
Карта Сайта
Популярные статьи
Что необходимо ... 65535
4.12.1 Професси... 33478
Учимся удалять!... 32095
Примеры, синони... 23450
Просмотр готовы... 22723
Декартовы коорд... 22284
FAST (методика ... 21491
содержание - се... 20754
Просмотр готовы... 19415
Работа с инстру... 14874
Сейчас на сайте
Гостей: 6
На сайте нет зарегистрированных пользователей

Пользователей: 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.6.2. Способы кон...
Путь вперед — буде...
2.3.2.3 Факсимильн...
4.6 НАЗНАЧЕНИЕ ИНД...
2.2 ВВЕДЕНИЕ В ОСН...
Механизм создания ...
5.15 LINК
Новая «общественна...
Понятие исключител...
Асинхронное и синх...
9.5 УПРАЖНЕНИЯ
БИБЛИОГРАФИЯ
ГЛАВА 8. ДИСПЕТЧЕР...
6.2.1 Области
Глава 28. GPSMAP 276С
Производители нара...
2.6.2.1 Образовани...
Конфигурация ядра
О чем мы узнали ?
Изменение размеров...
Интернет-система, ...
Продолжение расска...
Процессы подраздел...
СИСТЕМНЫЕ ОПЕРАЦИИ...
ГЛАВА 2. ВВЕДЕНИЕ ...
Глава 26. iFinder
2.2.2.4 «Сон» и пр...
Вместо введения
Глава вторая. СИЛ...
7.4. Организационн...
1.5.1 Прерывания ...
БИБЛИОГРАФИЧЕСКИЙ ...
Недопустимые комби...
6.2.3 Размещение ядра
5.4. Заключение
7.2.2 Группы проце...
Глава 3. Принцип р...
Пользовательские п...
Функциональный пример
От автора
Мини-чат
Вам необходимо залогиниться.

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