Объект vnode является абстрактным. Он не может существовать в изоляции, новый экземпляр vnode всегда в контексте конкретного файла.
Файловая система, к которой относится конкретный файл, предлагает собственную реализацию интерфейса абстрактного объекта vnode. Поля данных v_op и v_data связывают его с зависимой от файловой системы частью кода.
Также может иметь смысл заглянуть на сайт vacma.ru, ведь именно там можно узнать много нового на тему http://vacma.ru/products/. Тема купить вакуумный насос может показаться на первый взгляд незначительной и даже не тематичной. Но стоит посетить сайт vacma.ru, и тема купить вакуумный насос начинает проявлять себя с неожиданной стороны и вызывает всё больший интерес. Дело в том, что тема купить вакуумный насос очень подробно представлена на сайте vacma.ru. Трудно найти более детальное освещение темы купить вакуумный насос чем это сделано на сайте vacma.ru. Спасибо сайту vacma.ru за такое доскональное преподнесение темы купить вакуумный насос.
Поле v_data указывает на закрытую структуру данных, хранящую информацию о файле, зависящую от файловой системы. Структуры данных используются по-раз- ному в зависимости от конкретной файловой системы, к которой относится обрабатываемый файл.
Например, файлы s5fs или ufs используют структуры индексных дескрипторов1, в NFS применяется modes и т. д.
Поле v_data является непрозрачным указателем. Это означает, что участок кода, не зависящий от файловой системы, не может иметь прямого доступа к объекту, зависимому от нее. Однако зависящий от системы код вправе иметь доступ к базовому объекту vnode и использует эту возможность. В любом случае необходим способ нахождения vnode через закрытый объект данных. Так как оба объекта всегда размещаются вместе, более эффективно скомбинировать их в одном. В реализации ссылок на уровне vnode объект vnode просто-напросто является частью объекта, зависящего от файловой системы.
Заметим, что описанный метод является превалирующим в существующих реализациях файловых систем.
Он подходит для поддержания отдельных структур данных vnode и участка кода, зависящего от файловой системы, если произвести соответствующим образом инициализацию поля v_data.
Вектор vnodeops
Интерфейс vnode определяет набор операций над типовым файлом. Независимый от файловой системы код производит манипуляции с файлом, используя только эти операции. Он не может получить прямой доступ к объектам, зависящим от системы. Структура vnodeops, используемая для определения набора операций, описана ниже.
ных в нем. Например, в файловой системе ufs операция V0P_READ реализована как чтение файла с локального диска, в то время как в NFS эта команда производит запрос к удаленному файл-серверу для получения данных. Таким образом, каждая файловая система поддерживает собственный экземпляр структуры vnodeops. Например, в системе ufs определен объект
struct vnodeops ufs_vnodeops = { ufs_open; ufs_close;
}:
Поле v_op структуры vnode указывает на структуру vnodeops для типа файловой системы, ассоциированной с файлом. Как показано, все файлы одной файловой системы разделяют между собой единственный экземпляр структуры и обладают доступом к одному и тому же набору функций.
Зависящая от файловой системы часть уровня vfs
Как и vnode, объект vfs имеет указатели на свои закрытые данные и на вектор операций. Поле vfs_data указывает на непрозрачную структуру данных файловой системы. В отличие от vnode сам объект vfs и его закрытая структура данных обычно размещаются отдельно.
Поле vfs_op указывает на структуру vfsops, описываемую следующим образом:
struct vfsops {
int (*vfs_mount)(); int (*vfs_unmount)(): int (*vfs_root)(): int (*vfs_statvfs)(); int (*
Базовые элементы и интерфейс файловой системы
Каждый тип файловой системы имеет собственную реализацию перечисленных функций. Таким образом, используется один экземпляр структуры vfsops для каждого типа файловой системы: ufs_vfsops для ufs, nfs_vfsops для NFS и т. д.
Ранее показаны структуры данных уровня vfs для системы, содержащей две файловые системы ufs и одну NFS.
Монтирование файловой системы
Разработчики интерфейса vfs изменили системный вызов mount для поддержки существования нескольких файловых систем одновременно. Синтаксис вызова mount в SVR4 выглядит следующим образом:
mount (spec, dir, flags, type, dataptr, datalen);
где spec является именем файла устройства, представляющим файловую систему, dir — задает полное имя каталога, являющегося точкой монтирования, type — строка, определяющая типа файловой системы, dataptr — указатель на дополнительные аргументы, зависящие от файловой системы, a datalen является общей длиной блока этих дополнительных параметров. В данном разделе мы опишем, как системный вызов mount реализуется ядром.
Если в системе сконфигурированы файловые системы различных типов, то встает вопрос корректного соединения vnode и vfs в таких реализациях. Ядру необходим некий механизм, подсказывающий ему, как правильно осуществлять доступ к интерфейсным функциям каждой файловой системы.
Опубликовал katy
July 08 2015 09:24:49 ·
0 Комментариев ·
2889 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.