WikiDer > RTLinux

RTLinux
RTLinux
Оригинальный автор (ы)Виктор Йодайкен, Михаил Барабанов
Разработчики)FSMLabs, Системы Wind River
Написано вC
Операционная системаLinux
Доступно ванглийский
ТипЯдро
ЛицензияGPL2

RTLinux это жесткий реалтайм операционная система реального времени (ОСРВ) микроядро что запускает весь Linux Операционная система как полностью упреждающий процесс. Свойство жесткого реального времени позволяет управлять роботами, системами сбора данных, производственными предприятиями и другими чувствительными ко времени приборами и машинами из приложений RTLinux. Несмотря на похожее название, он не имеет отношения к Linux в реальном времени проект Linux Foundation.[1]

RTLinux был разработан Виктором Йодаикеном, Майклом Барабановым, Корт Дуганом и другими на Институт горного дела и технологий Нью-Мексико а затем в качестве коммерческого продукта в FSMLabs. Системы Wind River приобрела встроенную технологию FSMLabs в феврале 2007 года и сделала версию, доступную как Wind River Real-Time Core для Wind River Linux. В августе 2011 года Wind River прекратила выпуск линейки продуктов Wind River Real-Time Core, фактически прекратив коммерческую поддержку продукта RTLinux.

Фон

Ключевая цель разработки RTLinux заключалась в том, чтобы добавить возможности жесткого реального времени в обычную операционную систему, чтобы облегчить разработку сложных программ управления с обоими возможностями.[2][3] Например, кто-то может захотеть разработать контроллер двигателя в реальном времени, который использовал бы базу данных товаров и экспортировал веб-интерфейс оператора. Вместо того, чтобы пытаться создать единую операционную систему, которая могла бы поддерживать возможности как в реальном времени, так и не в реальном времени, RTLinux был разработан для совместного использования вычислительного устройства между операционной системой реального и не реального времени, так что (1) Операционная система реального времени никогда не может быть заблокирована от выполнения операционной системой, не работающей в режиме реального времени, и (2) компоненты, работающие в двух разных средах, могут легко обмениваться данными. Как следует из названия, RTLinux изначально был разработан для использования Linux как системы, не работающей в реальном времени.[4] но со временем оно развилось так, что ядро ​​реального времени RTCore могло работать как с Linux, так и с BSD UNIX.

Мультисреда в реальном времени (MERT) был первым примером сосуществования операционной системы реального времени с системой UNIX. MERT опирался на традиционные методы виртуализации: ядро ​​реального времени было хозяин операционная система (или гипервизор) и Bell Systems UNIX была гость. RTLinux был попыткой обновить концепцию MERT до эпохи ПК и массового оборудования. Это также была попытка преодолеть ограничения производительности MERT, особенно накладные расходы, связанные с виртуализацией.

Этот метод использовался только для виртуализации управления прерываниями гостя. Этот метод позволял ядру реального времени преобразовывать гостевую операционную систему в систему, которая была полностью вытеснена, но при этом могла напрямую управлять, например, устройствами хранения. В частности, стандартные драйверы для гостя работали без модификации исходного кода, хотя их нужно было перекомпилировать для использования «ловушек» виртуализации. Смотрите также паравиртуализация. «Канал» UNIX был адаптирован для обеспечения взаимодействия программ в реальном времени и не в реальном времени, хотя были также добавлены другие методы, такие как общая память.

С точки зрения программиста RTLinux изначально выглядел как небольшая многопоточная среда для задач реального времени плюс стандартная среда Linux для всего остального. Операционная система реального времени была реализована как загружаемый модуль ядра который начался с виртуализации управления прерываниями гостя, а затем запустил планировщик в реальном времени. Задачам назначались статические приоритеты, а планирование изначально основывалось исключительно на приоритетах. Гостевая операционная система была включена как задача с самым низким приоритетом и, по сути, действовала как неактивная задача для системы реального времени. Задачи в реальном времени выполнялись в режиме ядра. Позднее развитие RTLinux приняло Потоки POSIX интерфейс прикладного программирования (API), а затем разрешил создание потоков в пользовательском режиме с потоками в реальном времени, выполняемыми внутри гостевых процессов. В многопроцессорных средах потоки были привязаны к ядрам процессора, и можно было предотвратить запуск гостевого потока на назначенном ядре (эффективно резервируя ядра только для обработки в реальном времени).

Выполнение

RTLinux предоставляет возможность запускать специальные задачи в реальном времени и обработчики прерываний на том же компьютере, что и стандартный Linux. Эти задачи и обработчики выполняются, когда они должны выполняться, независимо от того, что делает Linux. Время наихудшего случая между моментом обнаружения аппаратного прерывания процессором и моментом начала выполнения обработчика прерывания составляет менее 15 микросекунд на RTLinux, работающем на стандартной x86 (около 2000 года). Периодическая задача RTLinux выполняется в течение 35 микросекунд от запланированного времени на том же оборудовании. Это время ограничено оборудованием, и по мере улучшения оборудования RTLinux также будет улучшаться. Стандартный Linux имеет превосходную среднюю производительность и может даже обеспечить точность планирования на уровне миллисекунд для задач, использующих возможности программного обеспечения реального времени POSIX. Стандартный Linux, однако, не предназначен для обеспечения субмиллисекундной точности и надежных гарантий синхронизации. RTLinux был основан на облегченной виртуальной машине, где «гостю» Linux были предоставлены виртуализированный контроллер прерываний и таймер, а все остальное оборудование было прямым. С точки зрения «хоста» реального времени ядро ​​Linux представляет собой поток. Прерывания, необходимые для детерминированной обработки, обрабатываются ядром реального времени, тогда как другие прерывания перенаправляются в Linux, который работает с более низким приоритетом, чем потоки реального времени. Драйверы Linux обрабатывают почти все Ввод / вывод. Трубы в порядке очереди (ФИФО) или разделяемую память можно использовать для обмена данными между операционной системой и RTLinux.

Цель

Ключевая цель дизайна RTLinux - сделать систему прозрачной, модульной и расширяемой. Прозрачность означает, что нет неоткрываемых черных ящиков, и стоимость любой операции должна быть определяемой. Модульность означает, что можно упустить функциональность и расходы на эту функциональность, если она не нужна. А расширяемость означает, что программисты должны иметь возможность добавлять модули и адаптировать систему к своим требованиям. Базовая система RTLinux поддерживает высокоскоростную обработку прерываний и не более того. Он имеет простой планировщик приоритетов, который можно легко заменить на планировщики, более подходящие для нужд конкретного приложения. При разработке RTLinux он был разработан, чтобы максимизировать преимущества, которые мы получаем от наличия Linux и его мощных возможностей.

Основные компоненты

RTLinux имеет структуру небольшого основного компонента и набора дополнительных компонентов. Основной компонент позволяет устанавливать обработчики прерываний с очень малой задержкой, которые не могут быть отложены или вытеснены самим Linux, а также некоторые процедуры синхронизации и управления прерываниями низкого уровня. Этот базовый компонент был расширен для поддержки SMP, и в то же время он был упрощен за счет удаления некоторых функций, которые могут быть предоставлены вне ядра.

Функциональность

Большая часть функциональных возможностей RTLinux представлена ​​набором загружаемых модулей ядра, которые предоставляют дополнительные услуги и уровни абстракции. Эти модули включают:

  1. rtl sched - планировщик приоритетов, который поддерживает как "облегченный" интерфейс POSIX, описанный ниже, так и исходный V1 RTLinux API.
  2. rtl time - управляет тактовой частотой процессора и экспортирует абстрактный интерфейс для подключения обработчиков к часам.
  3. rtl posixio - поддерживает интерфейс чтения / записи / открытия в стиле POSIX для драйверов устройств.
  4. rtl fifo - связывает задачи RT и обработчики прерываний с процессами Linux через уровень устройства, чтобы процессы Linux могли читать / писать в компоненты RT.
  5. semaphore - пакет, предоставленный Джерри Эпплином, который дает RT-задачам блокирующие семафоры.
  6. Планируется, что поддержка мьютексов POSIX будет доступна в следующем обновлении минорной версии RTLinux.
  7. mbuff - это дополнительный пакет, написанный Томашем Мотылевски для обеспечения общей памяти между компонентами RT и процессами Linux.

Задачи в реальном времени

Задачи реального времени RTLinux реализуются как модули ядра аналогичен типу модуля, который Linux использует для драйверов, файловых систем и так далее. Задачи реального времени имеют прямой доступ к оборудованию и не используют виртуальную память. При инициализации задача (модуль) реального времени информирует ядро ​​RTLinux о крайнем сроке, периоде и ограничениях времени выпуска.

Потоки

RT-Linux реализует POSIX API для управления потоком. Поток создается путем вызова pthread_create функция. Третий параметр pthread_create это функция, которая содержит код, выполняемый потоком.

В RTLinux необходимо установить приоритеты потоков. Потоки с более высоким приоритетом могут вытеснять потоки с более низким приоритетом. Например, у нас может быть поток, управляющий шаговым двигателем. Чтобы мотор двигался плавно, необходимо запускать эту нить строго через равные промежутки времени. Это можно гарантировать, назначив этому потоку высокий приоритет. В примере thread2.c устанавливаются разные приоритеты потоков. Установка приоритета потока выполняется с помощью кода, показанного ниже:

int init_module(пустота){pthread_attr_t attr;структура sched_param парам;pthread_attr_init(&attr);парам.sched_priority = 1;pthread_attr_setschedparam(&attr, &парам);pthread_create(&t1, &attr, &thread_code, "это поток 1");rtl_printf("Тема 1 начата п");...}

Вывод программы выглядит следующим образом.

Поток 1 начался Поток 2 Начался Поток 3 Началось Сообщение: это поток 1 Сообщение: это поток 2 Сообщение: это поток 2 Сообщение: это поток 2 Сообщение: это поток 1 Сообщение: это поток 1 Сообщение: это поток 3 Сообщение: это поток 3 Сообщение: это поток 3

Поток 2 имеет наивысший приоритет, а поток 3 - самый низкий. Первое сообщение печатается потоком 1 со средним приоритетом, потому что оно запускается незадолго до потока 2.

Смотрите также

Рекомендации

  1. ^ "realtime: start [Linux Foundation Wiki]". wiki.linuxfoundation.org.
  2. ^ "Манифест RTLinux", Виктор Йодайкен, Материалы 5-й конференции Linux, 1999 г., [1]
  3. ^ «Исследование дешевых операционных систем», Виктор Йодайкен. Опубликовано в Трудах Первой конференции по свободно распространяемым системам, Кембридж, Массачусетс, 1996 г. [2]
  4. ^ "Барабанов, Майкл (1996)." Операционная система реального времени на базе Linux"" (PDF).

Источники

внешняя ссылка