Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

Пользователей: 13,372
новичок: vausoz
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Моделирование автомойки на GPSS + Отчет + Блок схемы
Обучающая и тестирующая программа по здаче экзамена ПДД на Turbo Pascal ...
Расчет мер близости на отношениях на Delphi + Пояснительная записка

Система SVR4/MP и ядро
Как и в системе SVR4/MP, в новой реализации ОС ядро полностью управляет собственным адресным пространством и, следовательно, всецело отвечает за невозможность доступа к недействительным отображениям ядра (например, освобожденным сегментом seg_map). Отсюда следует, что ядро может применять правила отложенной перезагрузки вхождений TLB, отображающих адреса ядра.




Однако система SVR4.2/MP поддерживает легковесные процессы (или LWP, см. раздел 3.2.2). Несколько LWP одного и того же процесса могут выполняться в этой ОС одновременно на нескольких процессорах машины. Это говорит о том, что ядро не в состоянии манипулировать правилами обращений к памяти прикладных процессов и должно применять принцип немедленной перезагрузки потерявших актуальность вхождений TLB, принадлежащих прикладным процессам.
Средства глобальной перезагрузки TLB, заложенные в SVR4/MP, не могут эффективно работать в системах с большим количеством процессоров, так как их применение приводит к простою всей системы во время операции перезагрузки. В SVR4.2/MP поддерживается список процессоров для каждой структуры hat. Структура hat адресного пространства ядра включает в себя список всех работоспособных процессоров машины, следовательно, ядро потенциально может выполняться на любом из них. Структура hat прикладного процесса содержит список только тех процессоров, на которых этот процесс активен (то есть выполняется один из LWP этого процесса). Доступ к списку осуществляется при помощи интерфейсных функций, представленных ниже:
♦ hat_online() и hat_offline() — операции предназначены для добавления или удаления процессоров из списка структуры hat ядра;
♦ hat_asload(as) — добавляет процессор в список структуры hat адресного пространства as и загружает это адресное пространство в MMU;
♦ hat_asunload(as, flags) — выгружает отображения процесса и удаляет процессор из списка адресного пространства as. Параметр flags поддерживает единственный флаг, указывающий на необходимость сброса информации из локального буфера TLB после выгрузки отображения1.
Ядро системы также использует объект под названием cookie, видимый только на уровне НАТ. Этот объект может быть реализован как временная метка (в формате timestamp), либо как счетчик (порт ссылок использует временную метку). Объект должен удовлетворять следующему условию: значение нового объекта cookie должно быть всегда выше предыдущего. Для получения нового объекта cookie используется процедура hat_getshootcookie(), возвращающая значение, равное «возрасту» TLB. Ядро передает cookie процедуре hat_ shootdown(), ответственной за перезагрузку вхождения ядра в буферах TLB. Если на каком-то процессоре остается прежний объект cookie, это означает, что информация буфера TLB может быть устаревшей и должна быть сброшена.
В следующих разделах будут обсуждаться алгоритмы отложенной и немедленной перезагрузки TLB.
Отложенная перезагрузка
Как и в SVR4/MP, ядро применяет алгоритм отложенной перезагрузки для страниц драйвера seg_map. В ОС SVR4.2/MP это правило эффективно также и по отношению к драйверу seg_kmem, отвечающему за динамическую память ядра. Если драйверы seg_map или seg_kmem сбрасывают атрибут корректности страницы, операция перезагрузки TLB будет отсрочена до тех пор, пока ядро не соберется использовать страницу повторно. Например, драйвер seg_ map объявляет страницу устаревшей только тогда, когда ее счетчик ссылок станет равным нулю (это означает, что ни один процесс не может обратиться к странице).


Следовательно, продолжение хранения потерявших значимость данных о преобразовании адреса такой страницы не производит никакого отрицательного воздействия на систему. Ядро возвращает страницу в свободный список и затем вызывает процедуру hat_getshootcookie() для связывания со страницей нового объекта cookie1.
Опубликовал katy June 23 2015 06:15:06 · 0 Комментариев · 2117 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

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

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

Пароль



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

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
45 уроков по дельфи
Пример клиента ФТ...
Цветной Grid
ProLIB18
C++ Builder 6 СПР...
Мод "проверочный ...
De Knop
C++ Стандартная б...
VksButton
TDBF
Современное проек...
Архив Апгрейтов с...
Dbgridpack
Borland C++Builde...
Proeffectimage
Visual Studio 200...
Платформа програм...
С. Г. Горнаков - ...
Фундаментальные а...
Развивающийся фла...

Топ загрузок
Приложение Клие... 100779
Delphi 7 Enterp... 97934
Converter AMR<-... 20285
GPSS World Stud... 17037
Borland C++Buil... 14206
Borland Delphi ... 10334
Turbo Pascal fo... 7381
Калькулятор [Ис... 6050
Visual Studio 2... 5214
Microsoft SQL S... 3667
Случайные статьи
Что подкоманда мар...
Ошибки неоднозначн...
Работа с базами да...
Восходящий граммат...
ROX casino
TERMINATE (ЗАВЕРШИТЬ)
Основные сведения ...
Типовые операции н...
Параллелизм и инст...
Веселый отдых
Планирование глоба...
Применяйте AsyBEUI...
Объектная модель W...
Планирование трафи...
Полная пропускная ...
Заключение
Успешная проверка
Visual Studio. Ком...
Ограничение объясн...
Рекурсивные методы...
Установка программ...
Обеспечение требуе...
Объектно-ориентиро...
Ассоциативные массивы
подкаталог Ех73
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?