Навигация
Главная
Поиск
Форум
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
Реклама
Сейчас на сайте
Гостей: 15
На сайте нет зарегистрированных пользователей

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

Информационная система - транспортный парк на Turbo Pascal (База данных)...
Диплом - база данных поставщиков на Delphi (MS Sql Server)+ Пояснительна...
Выбор наилучших альтернатив с использованием методов оптимизации на Delp...

Структура buf
Структура buf также требуется буферному кэшу для хранения управляющей информации о кэшируемом блоке. В современных системах UNIX, таких как SVR4, буферный кэш нужен только для блоков метаданных файлов (содержащих индексные дескрипторы или блоки косвенной связи, см. раздел 9.2.2). Он кэширует последние использованные блоки, ожидая, что именно они с наибольшей вероятностью потребуются повторно (см. о принципе локальности ссылок в разделе 13.2.6). Структура buf ассоциируется с каждым таким блоком и содержит следующие дополнительные поля, предназначенные для управления кэшированием:
♦ указатель на vnode файла устройства;
♦ флаги, указывающие на занятость или «свободность» буфера, а также «грязность» буфера (наличие изменения);
♦ флаг aged (см. ниже);
♦ указатели на положение буфера в списке свободных буферов;
♦ указатели для размещения буфера в таблице хэширования. Аргументом хэш-функции являются vnode и номер блока.
Флаг aged требует более подробного объяснения. При освобождении «грязного» буфера ядро производит его перемещение в конец списка свободных буферов. Постепенно такой буфер оказывается в начале списка, если к нему не произойдет обращение раньше. После того как буфер достигнет начала списка, процесс может попытаться воспользоваться им повторно и увидит, что его содержимое необходимо сначала сбросить на диск. Процесс устанавливает для такого буфера флаг aged и запускает операцию записи. Флаг показывает, что буфер уже находился в списке свободных буферов. Такой буфер должен быть использован повторно раньше других буферов, попавших в данный список впервые, так как к этому буферу не происходило обращения в течение длительного периода времени. Следовательно, после завершения операции записи обработчик прерывания освободит буфер с флагом aged и сразу поместит его в начало списка свободных буферов.
Взаимодействие с объектом vnode
Ядро обращается к дисковому блоку при помощи указания vnode и смещения внутри этого объекта. Если vnode представляет специальный файл устройства, то смещение является физическим и отсчитывается от «начала» устройства. Если объект vnode представляет обычный файл, его смещение является логической величиной и базируется началом файла.
Из этого следует, что обращение к обычному файлу можно произвести двумя методами: либо по его объекту vnode и смещению в файле, либо по объекту vnode устройства и физическому смещению. Второй метод применяется при осуществлении прямого доступа к устройству. Такое обращение может привести к порождению двух псевдонимов одного и того же блока, что повлечет появление двух копий блока в памяти. Для предупреждения подобных ситуаций прямой доступ к устройству ограничен и разрешен только до монтирования файловой системы.
Так как каждый блок ассоциируется с vnode (файла или устройства), ядро осуществляет все операции блочного ввода-вывода через объекты vnode (кроме случая неформатированного ввода-вывода, о котором можно прочесть в разделе 16.6.4). Объект vnode поддерживает для этой цели две операции, VOP_GЕТPAGЕ (получение страницы) и VOP_PUTPAGE (сброс страницы на диск). Вызов этих операций приводит к запуску spec_putpage() и spec_getpage() в случае файлов устройств, функций ufs_putpage() и ufs_getpage() для файла ufs и так далее.
Представленный выше механизм гарантирует сохранение целостности при обращении нескольких процессов к одному и тому же файлу различными способами. В частности, один процесс может отобразить файл в памяти, в то время как другой процесс обращается к этому же файлу через вызовы read и write. Для того чтобы ядро системы обладало непротиворечивым представлением о таком файле, оба метода осуществляют доступ к нему через vnode.
Для примера опишем работу функции ufs_getpage(), которая сначала проверяет наличие страницы в памяти посредством обращения в глобальной таблице хэширования, используя vnode и смещение в качестве аргумента. Если страница не была обнаружена в памяти, функция вызывает процедуру ufs_ bmap() для преобразования логического номера блока файла в физический номер блока на диске. Затем функция запрашивает страницу памяти, в которую будет считываться блок данных и ассоциирует с ним структуру buf. Функция получает номер устройства диска из индексного дескриптора (который доступен через объект vnode). На последнем этапе работы происходит вызов процедуры d_strategy() дискового драйвера для непосредственно чтения (процедуре передается указатель на buf) и переход процесса в режим сна до завершения операции. По окончании ввода-вывода обработчик прерываний разбудит процесс. Функция ufs_getpage() осуществляет также некоторые дополнительные действия, такие как упреждающее чтение, если это необходимо.


Если блок не содержит данных файла, то он ассоциирован с объектом vnode файла устройства. В этом случае для чтения блока загружается функция spec_getpage(). Она также производит проверку наличия блока в памяти. Если блок не обнаружен, функция загружает операцию чтения с диска. В отличие от случая обычных файлов, операции spec_getpage() не нужно делать преобразование логического номера блока в физический, так как указываемые номера блоков уже относятся к конкретному устройству.
Опубликовал katy June 24 2015 16:39:26 · 0 Комментариев · 2864 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Borland C++Builde...
Print Grid
Пятнашки и крести...
Профессиональное ...
Программа рисует ...
Панель Календарь
MiniChat
Язык программиров...
Стелтинг Стивен, ...
FilesInfo
PDF
Динамические за...
Алгоритмы шифрова...
Autorunner
Flash MP3 Player ...
Графика в проекта...
XPcontrol
Cooltray
Visual Basic for ...
Программирование ...

Топ загрузок
Приложение Клие... 100800
Delphi 7 Enterp... 98062
Converter AMR<-... 20302
GPSS World Stud... 17067
Borland C++Buil... 14261
Borland Delphi ... 10388
Turbo Pascal fo... 7398
Калькулятор [Ис... 6093
Visual Studio 2... 5241
Microsoft SQL S... 3676
Случайные статьи
File variable expe...
Математические фун...
Где батут купить д...
Система SVR4
Дополнительные пар...
, специализирующая...
Игровой клуб Лев а...
Работа с серверами...
Подсписок из списк...
Когда количество э...
Г-слоя в физике пл...
Квартиры на сутки ...
Добавление медиафа...
Тестирование файлов
Модернизация Award...
Программа расчета ...
дополнительные экз...
Возможности дальне...
Приобретение товар...
Смена параметров ТД
Выбор темы и настр...
MissingMappingAction
Официальный сайт J...
В обоих требуется ...
Строки в С++
Статистика



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


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