Поле ksetобъекта kobjectуказывает на связанное с данным объектом множество kset. Множество объектов ksetпредставляется с помощью структуры kset, которая определена в файле следующим образом.
struct kset {
struct subsystem *subsys;
struct kobj_type *ktype;
struct list_head list;
struct kobject kobj;
struct kset_hotplug_ops *hotplug_ops;
};
Указатель ktypeуказывает на структуру ktype, которая определяет тип всех объектов данного множества, поле list— список всех объектов kobjectданного множества, поле kobj— объект kobject, который представляет базовый класс для всех объектов данного множества, а поле hotplug_opsуказывает на структуру, которая определяет поведение объектов kobjectпри горячем подключении устройств, связанных с данным множеством.
Наконец, поле subsysуказывает на структуру struct subsystem, которая связана с данным множеством kset.
Подсистемы используются для представления высокоуровневых концепций ядра и являются коллекцией одного или нескольких множеств kset. Множества ksetсодержат объекты kobject, подсистемы — множества kset, но связь между множествами в подсистеме значительно более слабая, чем связь между объектами kobjectв множестве. Множества ksetодной подсистемы могут иметь только наиболее общие объединяющие факторы.
Несмотря на их важную роль, подсистемы представляются с помощью очень простой структуры данных — struct subsystem.
struct subsystem {
struct kset kset;
struct rw_semaphore rwsem;
};
Структура subsystemсодержит только одно множество kset, тем не менее несколько множеств ksetмогут указывать на общую структуру subsystemс помощью поля subsys. Такие однонаправленные взаимоотношения означают, что нет возможности определить все множества подсистемы, только имея ее структуру subsystem.
Поле kset, которое содержится в структуре subsystem, — это множество ksetподсистемы, которое используется по умолчанию, чтобы зафиксировать положение этой подсистемы в иерархии объектов.
Поле rwsemструктуры subsystem— это семафор чтения-записи (см. главу 9, "Средства синхронизации в ядре"), который используется для защиты подсистемы и ее множеств ksetот конкурентного доступа. Все множества ksetдолжны принадлежать какой-нибудь подсистеме, поскольку они используют семафор подсистемы для защиты своих данных от конкурентного доступа.
Те несколько структур, которые только что были описаны, приводят к путанице не потому, что их много (только четыре) или они сложные (все они достаточно просты), а потому что они сильно друг с другом переплетаются. При использовании объектов kobjectдостаточно сложно рассказать об одной структуре, не упоминая другие. Тем не менее, на основании рассмотренных особенностей этих структур можно построить прочное понимание их взаимоотношений.
Самым важным является объект kobject, который представляется с помощью структуры struct kobject. Структура kobjectиспользуется для представления наиболее общих объектных свойств структур данных ядра, таких как счетчик ссылок, взаимоотношения родитель-порожденный и имя объекта. С помощью структуры kobjectэти свойства можно обеспечить одинаковым для всех стандартным способом. Сами по себе структуры kobjectне очень полезны, они обычно встраиваются в другие структуры данных.
С каждым объектом kobjectсвязан один определенный тип данных — ktype, который представляется с помощью структуры struct kobj_type. На экземпляр такой структуры указывает поле ktypeкаждого объекта kobject. С помощью типов ktypeопределяются некоторые общие свойства объектов: поведение при удалении объекта, поведение, связанное с файловой системой sysfs, а также атрибуты объекта.
Объекты kobjectгруппируются в множества, которые называются kset. Множества ksetпредставляются с помощью структур данных struct kset. Эти множества предназначены для двух целей. Во-первых, они позволяют использовать встроенный в них объект kobjectв качестве базового класса для группы других объектов kobject. Во-вторых, они позволяют объединять вместе несколько связанных между собой объектов kobject. На файловой системе sysfs объекты kobjectпредставляются отдельными каталогами файловой системы. Связанные между собой каталоги, например все подкаталоги одного каталога, могут быть включены в одно множество kset.
Читать дальше