Учебное пособие: Операционные системы "тонких" клиентов
Учебное пособие: Операционные системы "тонких" клиентов
Глава 7. Операционные
системы "тонких" клиентов
7.1 Карманные
персональные компьютеры
Под "тонкими"
клиентами понимают вычислительные устройства, обладающие неполной
функциональностью. Вообще говоря, спектр таких устройств достаточно велик - от
специализированных вычислителей, встраиваемых в бытовую аппаратуру, до
"сетевых" компьютеров, обладающих практическими всеми аппаратными
возможностями ПК, кроме жесткого диска. Мы в этой главе рассматриваем в
основном класс тонких клиентов, называемых карманными персональными
компьютерами или PDA - Personal Digital Assistant (персональный цифровой
помощник). Такие устройства используются в качестве интеллектуальных
органайзеров или/и в качестве мобильных устройств доступа к серверам
информационных систем. По оценкам некоторых экспертов число мобильных клиентов
во всем мире к 2003 г. достигнет 80 млн. Производство карманных ПК является
перспективным направлением, и на этом направлении действует большое число фирм.
Многие из них разрабатывают собственные ОС для своих PDA, однако многие
используют и ОС от других производителей. Практически каждая фирма - производитель
карманных ПК придает своей модели некоторые уникальные свойства, дающие ей
какие-то конкурентные преимущества. Однако все многообразие карманных ПК,
по-видимому, можно свести к двум типам: ПК без клавиатуры, ввод данных в
которых - рукописный или с виртуальной клавиатуры, в обоих случаях - при помощи
светового пера, и ПК с клавиатурой. Второй тип приближается к настольным ПК, в
частности, в его функциональность включается и обработка мультимедийной
информации. Первый тип беднее (точнее говоря, специфичнее) по функциональности,
однако отличается меньшими размерами и энергопотреблением. Задача ОС для ПК
первого типа - обеспечить максимальную экономию ресурсов, задача ОС для ПК
второго типа - обеспечить максимальную функциональность. Среди универсальных ОС
для карманных ПК первого типа лидирует PalmOS, для второго типа - Windows CE.
7.2 Операционная система
PalmOS
Операционная система
PalmOS [31] предназначена для управления PDA на базе микропроцессора Motorolla
Dragon Ball VZ, за которыми закрепилось название PalmPilot (хотя правильное
название их - просто Palm). Однако архитектура устройства Palm - открытая, и
многие фирмы выпускают собственные PDA, подобные Palm, но с теми или иными
отличиями - Sony, HandEra, Kyocera, Symbol и другие. Все эти PDA работают под
управлением PalmOS.
Специфика
функционирования приложений в PalmOS, а, следовательно, и самой PalmOS
заключается в следующем:
малый размер экрана
(160х160 точек) не позволяет приложению иметь сложный интерфейс; при
проектировании интерфейса следует соблюдать баланс между информационной
достаточностью и перегруженностью экрана;
приложение должно иметь
простую и быструю навигацию, выбор требуемого действия должен производиться
одной-двумя операциями пользователя, а не длинным диалогом, как бывает в
настольных ПК;
ОС и приложения
функционируют в условиях очень ограниченного объема ресурсов, прежде всего -
памяти;
одним из важнейших
требований является эффективное управление питанием.
ОС должна быть рассчитана
на быстрый рост вычислительных возможностей - как собственных базовых
возможностей PDA, так и расширения номенклатуры, возможностей и форматов
подключаемых к PDA карт.
Обязательным компонентом
платформы Palm является синхронизационная приставка (cradle), которая
обеспечивает соединение с настольным ПК и синхронизацию данных, находящихся на
ПК и на PDA. Многие приложения для PalmOS имеют аналоги для настольного ПК. Для
синхронизации данных, разделяемых ПК и PDA, используется технология HotSync,
которая предусматривает создание специальных каналов (conduit) для
синхронизации данных. Существуют специальные инструментальные средства для
программирования таких каналов, и многие популярные программные продукты
(Netscape Communicator, Oracle, IBM DB2, etc.) имеют в своем составе такие
каналы.
Архитектура PalmOS
показана на рисунке 7.1.
PalmOS базируется на
микроядре. Вокруг микроядра построены системные службы - менеджеры PalmOS,
представляющие собой наборы модулей, обеспечивающих определенные функции. К
таким менеджерам относятся, например:
Менеджер Graffiti -
система рукописного ввода;
Менеджер Событий;
Менеджер Памяти;
Менеджер Данных;
Менеджер Ресурсов;
Менеджер Звука;
и т.д.
Библиотеки (системные или
от других производителей) обеспечивают высокоуровневый доступ к системным
функциям. Хотя для PalmOS и существуют стандартные библиотеки языка C, в
системных библиотеках имеются собственные функциональные аналоги стандартных
функций C, которые оптимизированы для PalmOS, поэтому их использование
предпочтительнее.
Микроядро и управление
задачами
Само микроядро не
является собственностью фирмы Palm, используется микроядро AMX RTOS [13],
разработанное фирмой Kadak. Микроядро AMX RTOS представляет собой микроядро
реального времени, адаптированное для нескольких аппаратных платформ и
приспособленное для размещения в ПЗУ. Микроядро обеспечивает вытесняющую
многозадачность с абсолютными приоритетами. В каждый момент времени выполняется
только задача с наивысшим приоритетом. Переключение задач может происходить
по инициативе самой
задачи - задача переходит в состояние ожидания или запраштвает выполнение
операции, вызывающей выполнение задачи с более высоким приоритетом;
по внешнему событию -
прерыванию, обработка которого может запустить или "разбудить" задачи
с более высоким приоритетом;
по событию таймера,
которое также может "разбудить" задачи с более высоким приоритетом.
Микроядро AMX RTOS
оптимизировано с целью минимизации времени переключения задач и минимизации
нереентерабельных участков кода. Как правило, прерывания могут обрабатываться
даже во время переключения задач. Служба обработки прерывания микроядра
обеспечивает прием прерывания и вызов пользовательской процедуры обработки
прерывания. AMX RTOS обеспечивает также вложенную обработку прерываний для тех
аппаратных платформ, на которых вложенные прерывания поддерживаются
процессором.
Микроядро обеспечивает
также богатые средства синхронизации процессов:
события - события могут
образовывать группы до 16 событий, и ожидаться может любая заданная
конфигурация совершенности событий в группе;
семафоры - традиционные
общие семафоры, используемые как счетчики ресурсов;
очереди сообщений -
"почтовые ящики" (одна очередь) и "коммуникационные каналы"
(4 очереди с разными приоритетами).
Также микроядро
обеспечивает ряд сервисных функций, таких как выделение/освобождение памяти,
работу с пулом буферов и работу со связными списками.
Микроядро написано на
языке C и, следовательно, может быть реализовано для любой аппаратной платформы.
Средства конфигурирования позволяют включать в микроядро только те функции,
которые необходимы заказчику.
Микроядро само по себе
обеспечивает вытесняющую многозадачность. Но по условиям лицензионного
соглашения на использование микроядра API микроядра является закрытым, и
разработчики не могут создавать программы, напрямую использующие функции
микроядра, в том числе и многозадачность. Поэтому приложения PalmOS -
однозадачные. В PalmOS в каждый момент времени может выполняться только одно
приложение, имеющее доступ к пользовательскому интерфейсу, это приложение -
главное, приоритетное. Параллельно с ним может быть запущено фоновое (не
имеющее доступа к интерфейсу) приложение, которое получает процессорное время
только, когда главное приложение бездействует. Поскольку главное приложение
работает во взаимодействии с пользователем, фоновое приложение занимает почти
все процессорное время, но оно немедленно прерывается, при появлении событий,
требующих активизации главного приложения.
Обработка событий
Интерфейсные приложения
PalmOS управляются событиями. Такое приложение представляет собой единственный
цикл, каждая итерация которого начинается с получения очередного события.
Системный вызов EvtGetEvent обеспечивает ожидание и прием события. Полученное
событие передается ряду обработчиков в такой последовательности:
обработчик системных
событий;
обработчик событий меню;
обработчик событий
приложения;
обработчик
диспетчеризации экранных форм;
обработчик экранных форм.
Если вызванный обработчик
распознает событие как подлежащее его обработке, он эту обработку выполняет. В
процессе этой обработки он может генерировать и направлять в очередь другие
события. Если обработчик выполнил полную обработку события, то он возвращает
true, и тогда приложение прерывает цепочку вызовов обработчиков. Алгоритм
функционирования приложения, таким образом, выглядит примерно так, как показано
на рисунке 7.2.
Рисунок 7.2 Обработка
событий в приложении PalmOS
Управление
энергопотреблением
PDA Palm являются
рекордсменами среди устройств такого типа по низкому энергопотреблению, что
обеспечивается. аппаратными средствами совместно с ОС. Это достигается наличием
в PDA нескольких режимов энергопотребления и их управлением со стороны ОС.
Режимы эти следующие:
Рабочий режим. В рабочем
режиме процессор выполняет инструкции. Процессор и вся аппаратура ввода-вывода
потребляют энергию в полном объеме. Типичное приложение, переводящее систему в
рабочий режим, использует около 5% процессорного времени.
Ждущий режим. PDA
выглядит включенным, процессорные часы активны, но инструкции не выполняютcя.
Процессор работает на пониженном энергопотреблении. Когда процессор получает
прерывание, он переходит из ждущего режима в рабочий. Также переключение
происходит, когда пользователь начинает вводить информацию световым пером.
PalmOS программно переводит устройство в ждущий режим в системном вызове
EvtGetEvent, если очередь событий пуста. Поступление нового события начнется с
прерывания, которое вернет PDA в рабочий режим.
Спящий режим. PDA
выглядит выключенным: дисплей пуст, процессор неактивен, а главные часы
остановлены. Активны только часы реального времени и генератор прерываний.
PalmOS включает этот режим, когда нет активных действий пользователя в течение
некоторого интервала времени или когда пользователь нажимает кнопку выключения.
Вход из спящего режима происходит по прерыванию, например, если пользователь
нажал на любую кнопку или сработали часы реального времени по заданной
программе. Когда система получает одно из этих прерываний в спящем режиме, она
переходит в рабочий режим.
Управление памятью и
данными
Память является одним из
наиболее критических ресурсов PDA, и в то же время - наиболее быстро
наращиваемым. За время существования PDA Palm и PalmOS доступные объемы памяти
в устройстве возросли от 512 Кбайт до 8 Мбайт. Память в устройстве Palm есть
оперативная (RAM) и постоянная (ROM). Вся память расположена на карте памяти,
на карте может размещаться как ROM, так и RAM-память или обе вместе. Содержимое
обоих видов памяти сохраняется даже при "выключении" PDA (переводе
его в спящий режим). Архитектура памяти Palm 32-битная. Каждой карте памяти
отводится адресное пространство 256 Мбайт. ROM и RAM-память карты разбита на
"кучи", размер каждой кучи - не менее 64 Кбайт. Деление памяти на
кучи - условное, оно производится ОС и никак не отражается на аппаратной
архитектуре памяти. В каждой куче содержится либо ROM, либо RAM-память, но не
обе вместе. В RAM-памяти на внутренней карте памяти PDA реализована
"динамическая куча". Фактически, это и есть оперативная память. В
этой куче ОС размещает динамические данные: глобальные переменные, динамические
системные области памяти, стек, кучу приложения и сами коды приложений,
загружаемых из дополнительных карт. Размер динамической кучи зависит от объема
памяти на внутренней карте PDA и от предустановленного программного
обеспечения. Каждая куча имеет свой номер-идентификатор. Динамическая куча
имеет номер 0. Эта куча инициализируется автоматически всякий раз при рестарте
системы. Все другие кучи инициализируются собственными циклами переустановки.
Память распределяется
порциями (chunk) переменной длины. Порция располагается в одной куче,
выравнивается по границе 2-байтного слова и занимает непрерывную область памяти
- от 1 байта до 64 Кбайт. Порции в RAM-памяти бывают динамическими или
хранимыми, перемещаемыми или неперемещаемыми. Порции в ROM-памяти бывают только
неперемещаемыми и хранимыми.
Управление памятью
(прежде всего - динамической, перемещаемой памятью) ведется Менеджером Памяти
ОС. Управление хранимой памятью ведется надстройкой над Менеджером Памяти,
называемой Менеджером Данных.
Когда Менеджер Памяти
выделяет неперемещаемую порцию, он возвращает указатель на нее. Этот указатель
сохраняет свое начальное значение все время существования порции. Когда
Менеджер Памяти выделяет перемещаемую порцию, он возвращает ее манипулятор
(handle). Манипулятор является номером элемента в Главной таблице указателей.
Главная таблица указателей содержит указатели на порции. Поскольку обращения к
перемещаемым порциям происходит через манипуляторы, ОС имеет возможность
переместить порцию в памяти и изменить указатель на нее в Главной таблице,
манипулятор же порции, которым оперирует приложение, не изменяется.
Перемещение, однако, возможно только в те моменты, когда это
"позволяет" приложение. Поскольку в системе не предусматривается
аппаратное преобразование виртуальных адресов в реальные, для того, чтобы
работать с данными памяти, приложение должно иметь указатель на данные.
Системный вызов MemHandeLock фиксирует порцию в памяти, то есть запрещает ее
перемещение. Этот вызов возвращает указатель на начало порции, через который
приложение осуществляет доступ к данным порции. После окончания работы с данными
приложение должно снять фиксацию с порции. ОС применяет перемещение порций для
борьбы с фрагментацией памяти (внешними дырами). Процедура сжатия памяти
вызывается всякий раз при нехватке памяти. Естественно, что чем больше порций
будет зафиксировано в памяти, тем менее эффективна будет такая процедура.
Поэтому эффективность управления памятью в значительной степени зависит от
"грамотного" поведения приложения. В целях снижения фрагментации ОС
выделяет память для перемещаемых порций в начале кучи, а для неперемещаемых - в
конце кучи.
Каждая порция памяти
имеет свой локальный (в пределах данной карты памяти) идентификатор. Для
неперемещаемой порции этот идентификатор - ее смещение относительно начала
карты, для перемещаемой - смещение относительно начала карты соответствующего
ей элемента Главной таблицы указателей. Таким образом, обработка данных не
зависит от того, в какой слот будет вставляться карта. Специальный системный
вызов превращает номер слота и локальный идентификатор порции в указатель или манипулятор.
Каждая куча начинается с
заголовка кучи, который содержит размер кучи и информацию о ее состоянии.
Главная таблица указателей располагается сразу вслед за заголовком. Если
размера таблицы недостаточно, выделяется память для ее расширения. Последнее
поле таблицы содержит указатель на расширение. Таким образом может быть
выделено сколько угодно расширений, и они связываются в однонаправленный
линейный список. Расширения Главной таблицы указателей размещаются в конце
кучи. Память, выделяемая для перемещаемых порций, находится сразу за Главной
таблицей.
Заголовок кучи не
подлежит изменению, поэтому куча может располагаться в ROM-памяти. Поскольку
порции в ROM-памяти не могут быть перемещаемыми, Главная таблица кучи в
ROM-памяти содержит 0 элементов.
Каждой порции памяти
предшествует 8-байтный заголовок, в котором содержится признак
свободной/занятой порции, размер порции, счетчик фиксаций и обратная ссылка на
Главную таблицу указателей. Свободные участки памяти также имеют формат порций,
таким образом, ОС может отследить все распределение памяти, начиная от первой
порции и прибавляя к ее адресу размер. Каждая порция может быть зафиксирована в
памяти до 16 раз, каждая новая фиксация просто прибавляет единицу к счетчику
фиксаций, а снятие фиксации - вычитает единицу. Порция становится перемещаемой
только, когда ее счетчик фиксаций обнулится. Для порций хранимой памяти счетчик
фиксаций сразу устанавливается в максимальное значение и не уменьшается при
попытках снять фиксацию.
Хранимые области памяти в
Palm играют ту же роль, что файлы на внешней памяти в других вычислительных
системах. Однако в отличие от "традиционных" вычислительных систем, в
которых данные для обработки перемещаются в буфер в оперативной памяти, в
PalmOS хранимые данные обрабатываются на месте, прямо в постоянной памяти.
Работа с хранимыми данными обеспечивается Менеджером Данных, представляющим
собой надстройку над Менеджером Памяти.
Данные хранятся в памяти
в виде записей. Каждая запись представляет собой порцию памяти. Для выделения,
освобождения, изменения размера записи Менеджер Данных обращается к Менеджеру
Памяти. Логически связанные записи объединяются в базу данных, база данных
является аналогом файла как именованная совокупность данных. Записи базы данных
не обязательно располагаются в смежных порциях памяти, они могут быть даже
рассредоточены по разным кучам в пределах одной карты памяти.
Каждая база данных имеет
заголовок, в котором записано имя базы данных, количество записей в ней и
другая управляющая информация. В заголовке же находится и план размещения базы
данных, представляющий собой массив дескрипторов записей, входящих в базу. Если
весь массив не помещается в заголовке, то последний его элемент содержит
указатель (локальный идентификатор) продолжения списка. Каждый дескриптор
записи представляет собой 4-байтную структуру, в первом байте которой находятся
атрибуты записи (признаки: защиты, удаления, изменения, занятости), а в
оставшихся трех - локальный идентификатор - адрес записи.
API Менеджера Данных
представляет собой как бы "гибрид" традиционного файлового API и API
памяти. Для того, чтобы работать с базой данных, приложение должно сначала ее
"найти" - по символьному имени базы данных определить ее
идентификатор (локальный идентификатор заголовка базы данных). Это
обеспечивается специальным системным вызовом DmFindDatabase(). Затем база
данных открывается, при этом в динамической куче создается для нее структура
данных - аналог дескриптора открытого файла. С открытой базой данных приложение
может работать. Основной системный вызов доступа к данным - DmGetRecord() -
возвращает указатель на данные записи с заданным номером, выборка и изменение
данных записи производится через этот указатель.
Особый вид базы данных
называется ресурсом. Ресурсы служат для хранения специальных данных -
программных кодов, изображений, интерфейсных элементов и т.д. Структура ресурса
отличается от структуры обычной базы данных только тем, что дескриптор записи
ресурса имеет размер 10 байтов, два дополнительных байта описывают свойства ресурса.
Еще одна надстройка над Менеджером данных - Менеджер Ресурсов - обеспечивает
работу с этой дополнительной информацией. API Менеджера Ресурсов функционально
аналогичен API Менеджера Данных.
Кроме того, PalmOS
обеспечивает интерфейс файлового потока. При использовании этого API хранимые
данные представляются в виде потока байтов, не разделенного на записи.
Ограничение 64 Кбайт на размер порции отсутствует. Системные вызовы этого
интерфейса (FileOpen(), FileClose(), FileRead(), FileWrite(), etc.) аналогичны
функциям стандартной библиотеки языка C. Файловый поток является только
интерфейсной надстройкой, с одними и теми же данными можно работать и как с
файловым потоком, и как с базой данных.
Расширения и файловая
система
Начиная с версии 4.0,
PalmOS содержит единообразную поддержку новых карт, которые могут расширять
возможности PDA. В предыдущих версиях карты, вставляемые в слоты расширения,
должны были обязательно соответствовать спецификациям памяти Palm и
рассматривались OS как дополнительная память. В слоты расширения могут
вставляться:
карты RAM-памяти (не
обязательно соответствующие спецификациям Palm), содержащие приложения и данные
к ним или используемые для специальных целей (например, для создания архивных
копий);
карты ROM-памяти (не
обязательно соответствующие спецификациям Palm), содержащие приложения и данные
к ним;
карты ввода-вывода для
специальных устройств (например, модема);
комбинированные карты,
содержащие как возможности ввода вывода, так и RAM и ROM-память.
Новая версия ОС рассматривает
все эти карты расширения как вторичную память и обеспечивает единообразную
работу с ними. Основными компонентами архитектуры расширения PalmOS являются:
драйверы слота;
файловые системы;
Менеджер Виртуальной
файловой системы (VFS);
Менеджер Расширения.
Драйвер слота аналогичен
традиционному драйверу устройства, он инкапсулирует детали управления
оборудованием карты расширения данного типа и предоставляет Менеджеру
Расширения единый интерфейс для управления картами разных типов. Добавление поддержки
нового аппаратного расширения требует включения в системную библиотеку нового
драйвера слота.
Файловые системы
аналогичны драйверам файловых систем в ОС с инсталлируемыми файловыми
системами, они обеспечивают работу с конкретными файловыми системами ПК или
других устройств. Обычно в PalmOS предустанавливается файловая система FAT,
другие файловые системы могут быть добавлены при необходимости.
Менеджер VFS обеспечивает
единый интерфейс системных вызовов (VFSFileOpen(), VFSFileClose(),
VFSFileRead(), VFSFileWrite(), etc.) для всех файловых систем. Он обеспечивает
также возможность работы с памятью на картах расширения с использованием API,
подобного тому, который применяется для работы с базами данных в основной
памяти.
Наконец, Менеджер
Расширения обеспечивает отслеживание вставки/удаления карт расширения и
управление драйверами слота.
Взаимодействие с
пользователем
Три менеджера в составе
PalmOS поддерживают взаимодействие с пользователем "по инициативе
системы":
Менеджер Внимания
(attention);
Менеджер Тревоги (alarm);
Менеджер Извещения
(notification).
Менеджер Внимания
отвечает за взаимодействие с пользователем в тех случаях, когда требуется
привлечь его внимание. Этот менеджер обеспечивает выдачу сигнала пользователю
(звуком, вибрацией, другими специальными эффектами), индикацию события,
требующего внимания, на экране (в виде всплывающего окна или маленького
индикатора события), управление со стороны пользователя списком таких событий.
Менеджер Тревоги посылает
событие приложению при достижении определенного момента времени. Приложение
затем может обратиться к Менеджеру Внимания, чтобы привлечь внимание
пользователя.
Менеджер Извещения
информирует приложения о наступлении некоторого события. Извещение получают те
приложения, которые зарегистрировали свой интерес к данному событию. Приложение
затем может обратиться к Менеджеру Внимания.
Пользовательский
интерфейс PalmOS позволяет увеличить производительность, благодаря уменьшению
навигации между окнами, открытию новых диалогов. Размещение структур управления
приложением (меню, кнопки и т. д.) упрощено настолько, что пользователь может
быстро и эффективно управлять ими. Всего интерфейс обеспечивает 10 основных
управляющих структур: формы, диалоги, кнопки, триггеры, переключатели,
ползунки, поля, меню, списки, линейки прокрутки. Система также дает возможность
разработчикам создавать свои собственные компактные пользовательские интерфейсы
размером 160x160 пикселов (размер экрана Palm).
Упрощение навигации
достигается также за счет упрощения структуры каталогов VFS PalmOS.
Пользователь в большинстве случаев просто не видит этой структуры, он видит на
экране иконки доступных для запуска приложений. Эти приложения размещаются в
каталоге \PALM\Launcher. Обеспечена автоматическая установка приложения в этом
каталоге при добавлении новой карты. Имеется также возможность автоматического
запуска приложения при вставке его карты в слот.
Хотя "девизом"
PDA Palm и PalmOS является экономия ресурсов, существуют и PDA других фирм,
также работающие под управлением PalmOS,которые предоставляют своим владельцам
гораздо более широкие возможности, прежде всего - в части обработки
мультимедийной информации (лидером в этом отношении, по-видимому, является
фирма Cassio). "Карманная" работа с мультимедийной информацией является
объективной тенденцией, и игнорировать ее фирма Palm не сможет. Возможно, в
скором времени и облик PalmOS претерпит значительные изменения.
7.3. Операционная система
Windows CE
Управление процессами и
памятью
ОС Windows CE [39]
рассчитана на значительно большие объемы ресурсов, чем PalmOS, но,
соответственно, обеспечивает гораздо больший объем возможностей. Windows CE
является членом семейства ОС Windows и в большей части функций обеспечивает
общий cтандартный API Win32 этого семейства и общий с остальными членами
семейства интерфейс пользователя, но в некоторых случаях принятые в Windows CE
решения являются специфичными.
Windows CE является
многозадачной системой с вытесняющей многозадачностью. Определенные свойства
Windows CE дают основание говорить о ней как о системе реального времени. В
системе обеспечиваются абсолютные приоритеты, выполняется только процесс (нить)
с наивысшим приоритетом. Если два или более процессов имеют высший приоритет,
то квант времени (по умолчанию размер кванта - 100 мсек) делится между ними
поровну. Всего имеется 256 градаций приоритета, но только 8 самых низших из них
возможны для пользовательских процессов, остальные зарезервированы за
системными процессами. Windows CE поддерживает вложенные прерывания и "инверсию"
приоритетов - повышение приоритета нити, если она захватывает критический
ресурс. Windows CE является 32-разрядной системой и обеспечивает в основном тот
же API Win32, что и другие ОС Windows. Ядро Windows CE может адресовать до 256
Мбайт физической памяти, но в виртуальном адресном пространстве объем которого
- 4 Гбайт, физическая память отображается в младшие 2 Гбайт, как показано на
рисунке 7.3.
Рисунок 7.3 Виртуальное
адресное пространство Windows CE
В старшей части памяти
адресное пространство от 2 до 3 Гбайт отводится для совместно используемой
памяти (в терминологии Windows - файлов, отображаемых в память), а пространство
от 3 до 4 Гбайт делится на "слоты" с номерами от 1 до 32, каждый из
которых представляет адресное пространство одного из процессов. Таким образом,
в системе может выполняться одновременно до 32 процессов, частное адресное
пространство каждого процесса - 32 Мбайт (не считая файлов, отображаемых в
память). "Слот" 0 отображается на физическую память, он отдается
активному в текущий момент процессу. В адресном пространстве каждого процесса,
помимо кодов процесса, создаются области памяти для статических данных, куча и
стек для каждой нити процесса. Для статических данных выделяются отдельные
области памяти - для изменяемых и для неизменяемых данных. Для каждого процесса
создается куча по умолчанию (384 страницы по 1 Кбайт), но процесс может
создавать новые кучи в пределах своего адресного пространства. Выделенные в куче
блоки памяти не перемещаются, что может приводить к фрагментации памяти в куче.
Размер стека для нити - 1 Мбайт, и он не может быть изменен. Количество нитей в
процессе ограничено только возможностью выделения памяти для стеков нитей.
Память для стека выделяется по мере необходимости, постранично. Если для
растущего стека нити не хватает страниц памяти, нить блокируется.
Программы, выполняемые в
Windows CE, могут находиться в RAM- или в ROM-памяти. Если программа находится
в ROM-памяти, но не содержит изменяемых данных, она выполняется "на
месте". Если же программа содержит изменяемые данные, она для выполнения
копируется в RAM-память. Копирование происходит постранично, по требованию.
Общие области памяти,
называемые в Windows файлами, отображаемыми в память, в адресное пространство
процесса не входят. Они могут использоваться для получения процессом
дополнительной памяти сверх лимита 32 Мбайт.
Управление внешними
данными
Управление внешними
данными в Windows CE основывается на концепции "хранилища объектов"
(object store). Хранилище объектов играет ту же роль, что и дисковая память в
настольных вычислительных системах: оно обеспечивает постоянную память для
хранения приложений и их сохраняемых данных. Хранилища объектов могут быть трех
типов: файловые системы, базы данных и реестры (registry), причем все они могут
разделять одну и ту же физическую память. Однако, первые два типа могут также
размещаться и в ROM-памяти, на внешних устройствах или в отдельных системах,
реестры же - только в RAM-памяти. Объектами, находящимися в хранилище, могут
быть:
ключ реестра;
значение реестра;
файл (метаинформация
файла);
порция (chunk) данных
файла (размер порции - 4 Кбайт);
запись базы данных (до 4
Кбайт);
расширение записи базы
данных (до 4 Кбайт);
база данных
(метаинформация базы данных).
Каждый объект имеет
уникальный (в пределах тома) идентификатор, который используется для доступа к
объектам.
Windows CE работает с
тремя типами файловых систем: файловая система в ROM-памяти, файловая система в
RAM-памяти и файловая система FAT на внешних устройствах, картах расширения
памяти и PC Card. Разработчики могут создавать и регистрировать и другие
файловые системы. Независимо от того, на каком физическом типе памяти
располагается файловая система, работа с нею выполняется через стандартный
файловый API Win32. Для упрощения операций с памятью Windows CE не применяет
концепцию текущего каталога, но все ссылки на объекты содержат полный маршрут.
База данных в Windows CE
представляет собой нечто, являющееся упрощенным вариантом СУБД. API баз данных
в Windows CE оригинальный. База данных состоит из записей. Каждая запись
состоит из полей (свойств). Запись может состоять из переменного количества
полей, память выделяется только под реально существующие поля. Каждое поле предваряется
4-байтным заголовком, в котором содержится идентификатор поля и код типа данных
в поле. Каждая запись предваряется 20-байтным заголовком, содержащим метаданные
записи. Вся база данных имеет символьное имя (до 32 символов) и тип (целое
число).
Для базы данных может
быть создано до 4 индексов быстрого поиска - каждый по значению какого-либо
одного поля. При открытии базы данных (системный вызов CeOpenDatabaseEx) может
быть указан один из этих четырех индексов, и в течение этого сеанса работы с базой
данных используется только индекс, заданный при открытии. Прежде, чем читать
или писать запись базы данных, ее следует найти. Системный вызов CeSeekDatabase
ищет в базе данных запись, поиск может задаваться: по абсолютному или
относительному значению поля, по абсолютному или относительному номеру в
заданном при открытии базы данных индексе, по идентификатору объекта-записи.
Если запись найдена, указатель поиска устанавливается на эту запись.
Последующие операции чтения или записи оперируют с той записью, на которую
установлен указатель поиска. Работа с содержимым базы данных выполняется при
помощи системных вызовов CeReadRecordPropsEx и CeWriteRecordProps. Эти вызовы
позволяют соответственно читать поля записи или записывать поля в запись. Для
определения того, с какими именно полями работает системный вызов, должен быть
определен массив идентификаторов полей. Чтение значений полей записи может
выполняться не только в локальную кучу программы, но и в любую доступную
программе область памяти.
Реестры Windows CE хранят
конфигурационные установки: данные о приложениях, драйверах, настройки
пользователей и т.п. Реестры организованы в иерархическую структуру с ключами и
значениями. Ключ может содержать значение или другие ключи - в этом ключ
подобен каталогу файловой системы. В иерархической структуре ключей возможно не
более 16 уровней. Windows CE поддерживает три "корневых" ключа, в
которые записываются другие ключи, задающие параметры соответствующего типа:
HKEY_LOCAL_MACHINE -
данные о конфигурации аппаратуры и о драйверах;
HKEY_CURRENT_USER -
конфигурационные данные пользователя;
HKEY_CLASSES_ROOT -
конфигурационные данные приложений.
Ограничение на длину
ключа - 255 символов, ограничение на размер значения - 4 Кбайт. Для работы с
реестрами используется API Win32.
Windows CE продолжает
развиваться, но наряду с этой ОС фирма Microsoft предлагает также Windows NT
Embedded. Последняя обеспечивает примерно ту же функциональность, но
ориентированную не на карманные ПК, а на вычислительные устройства, встраиваемые
в различную аппаратуру и строится на ядре Windows NT. Эта технология
развивается в новой версии ОС для встроенных применений - Windows XP Embedded.
Эта ОС строится на базе ядра Windows 2000 (Windows NT 5) и обеспечивает
функциональность, аналогичную Windows CE и Windows NT Embedded. Основное
нововведение в Windows XP Embedded - развитая библиотека компонентов и средства
разработки приложений.
7.4 Новые тенденции
встроенных ОС
Ограниченность ресурсов
тонких клиентов определила то обстоятельство, что ОС таких устройств,
во-первых, чрезвычайно экономны в потреблении ресурсов, во-вторых, являются ОС
реального времени. Основным признаком ОС реального времени является иерархия
приоритетов прерываний и возможность приостанова обработки текущего прерывания при
поступлении прерывания с более высоким приоритетом. Поскольку прерывания
сигнализируют о внешних событиях, указанное свойство позволяет ОС реального
времени своевременно реагировать на такие события. И PalmOS, и Windows CE
являются ОС реального времени. Большинство других ОС, используемых как
встроенные, также подходят под это определение (например, QNX). Однако,
развитие аппаратных средств - увеличение быстродействия, разрядности, объемов
памяти приводит к тому, что в качестве встроенных начинают использоваться
"облегченные" версии стандартных ОС [33]. При высоком быстродействии
аппаратуры эти ОС позволяют обеспечить приемлемое время реакции даже не для
приоритетных прерываний. Использование большей ОС и большего количества памяти,
чем требует ОС реального времени, обходится дороже, но, во-первых, позволяет
добавлять в системы больше возможностей, а во-вторых, позволяет сократить сроки
разработки за счет применения инструментальных средств стандартных ОС и
привлечения разработчиков, не обладающих специфическим опытом разработок для ОС
реального времени.
Например, технология
Microsoft Windows NT Embedded для встроенных ОС развивается в новой версии ОС
для встроенных применений - Windows XP Embedded. Эта ОС строится на базе ядра
Windows 2000 (Windows NT 5) и обеспечивает функциональность, аналогичную
Windows CE и Windows NT Embedded. Основное нововведение в Windows XP Embedded -
развитая библиотека компонентов и средства разработки приложений. Хотя по
некоторым сообщениям от фирмы Microsoft Windows XP Embedded должна быть
основным предложением фирмы для мобильных и встроенных систем, еще до конца
2002 года фирма планирует выпустить ОС Windows CE .Net.
Заметной фигурой на рынке
встроенных ОС стала также ОС Linux. ОС Linux модульная в своей основе. Ядро
(фундаментальные элементы ОС, такие как управление памятью и файлами) занимает
примерно один 1 Мбайт. Оно может быть легко выделено и дополнено модулями,
подходящими для встроенных систем. Linux как ОС Открытого Кода предоставляет
множество привлекательных возможностей для производителей и разработчиков и,
конечно же, рассматривается ими как альтернатива Microsoft.
Таким образом, можно
указать на две тенденции в развитии встроенных ОС. Одна, представляемая PalmOS,
характеризуется прежде всего экономичностью и некоторым аскетизмом в
возможностях, другая, представляемая, например, Windows XP, - более затратным
отношением к ресурсам, но и большими возможностями для пользователя,
выражающимися прежде всего в широком использовании мультимедийных средств.
Естественно, развитие аппаратных средств делает более перспективной вторую
тенденцию. Очевидно, что фирма Palm также не собирается оставаться в стороне от
общего потока, о чем свидетельствует, например, приобретение ею в 2001 г. технологии BeOS, известной своими мультимедийными возможностями, апробированными также и во
встроенных применениях. Однако, как бы интенсивно не развивались аппаратные
ресурсы, всегда на рынке будет сохраняться устойчивый спрос на более дешевые и
более экономичные решения, таким образом, опыт и технологии PalmOS не останутся
невостребованными.
Глава 8. Операционные
системы фирмы Apple
8.1 Фирма Apple и
компьютеры Macintosh
История Apple является
хрестоматийным примером того, как талант и предприимчивость приносят успех.
Персональный компьютер, собранный в гараже Стивом Возняком и Стивом Джобсом,
послужил основой для создания в 1976 г. фирмы Apple Computer Company и
компьютера Macintosh. Хотя более чем 25-летняя история фирмы далеко не
безоблачна, она переживала взлеты и падения, можно утверждать, что во все
периоды своей деятельности фирма имела собственную концепцию персональных
вычислений, и продукция Apple по качеству и по функциональным возможностям
опережала конкурентов. Фирма выжила в конкурентной борьбе как с супергигантами
компьютерной индустрии, так и с конкурентами, чей стиль борьбы на рынке никак
нельзя назвать честным, и в настоящее время компьютеры Apple являются
единственной реальной альтернативой платформе Wintel в настольных вычислениях.
Хотя компьютеры Apple
являются компьютерами универсального назначения, их аппаратное и программное
оснащение средствами обработки мультимедийной информации всегда было несколько
избыточным для "рядового" покупателя. Конечно, это утверждение можно
оспаривать, но то, что большинство таких пользователей предпочли более дешевую
платформу Intel+Windows - очевидный факт. Как и то, что пользователи,
профессионально работающие в области дизайна, издательской деятельности и в
других областях, связанных с обработкой мультимедийной информации, предпочитают
Macintosh. Следует отметить, что при более высокой стартовой цене компьютеры
Apple в итоге обходятся своим покупателям дешевле, так как дольше сохраняют
свою пригодность, и их пользователи избавлены от того беличьего колеса
непрерывных модернизаций, в котором вынуждены крутиться пользователи Wintel.
Компьютеры Macintosh
первоначально базировались на процессорах Motorola 680x0 (M68K), внедряя новые
поколения этих процессоров. В 1992 г. в результате совместного проекта фирм
Apple, IBM и Motorola был разработан процессор PowerPC, и семейство компьютеров
Macintosh разделилось на две ветви - одна на процессорах M68K, другая -
процессорах PowerMac, также выпускаемых фирмой Motorolla. В настоящее время все
новые модели Macintosh базируются на PowerMac.
Программное обеспечение
Macintosh, как и аппаратное, в значительной степени ориентировано на
предоставление пользователям развитых мультимедийных возможностей. Графический
пользовательский интерфейс компьютеров Apple служит образцом для всех других
систем. Операционная система Mac OS эволюционировала на протяжении долгих лет и
лишь в 1998 г. уступила место ОС Mac OS X.
8.2 Mac OS
Хотя в оригинальной
документации [28] нам не удалось найти определения архитектуры Mac OS, мы
возьмем на себя смелость определить ее как модульно-иерархическую, как
представлено на рисунке 8.1.
Рисунок 8.1 Архитектура
Mac OS
Систему, по-видимому,
можно разделить на несколько подсистем, каждая из которых выполняет управление
определенным видом ресурсов (памятью, задачами, файлами, средствами
коммуникаций и т.д.). Подсистема состоит из нескольких Менеджеров, каждый их
которых обеспечивает более высокий уровень абстракции ресурсов. Менеджеры более
высокого уровня используют средства Менеджеров низкого уровня своей подсистемы,
а также и других подсистем. API же системы предоставляет доступа к возможностям
практически любого уровня абстракции. На рисунке 8.2, например, показана
структура подсистемы управления взаимодействием процессов.
Управление памятью
При работе с реальной
памятью Mac OS обеспечивает работу с адресным пространством размером 16 Мбайт
(24-разрядный адрес). Разумеется, все адресное пространство не обязательно
поддерживается реальной памятью, заполнение адресного пространства реальной
памятью может быть фрагментировано. До 8 Майт в верхней части адресного
пространства составляет пространство ввода-вывода.
Память в такой модели
выделяется разделами. Нижняя часть памяти (от адреса 0) составляет системный
раздел. В нем размещены глобальные переменные системы и системная куча. В
системной куче выделяется память для буферов, системных структур данных и
системных кодовых сегментов.
Каждому приложению
выделяется раздел приложения. В разделе приложения содержится:
управляющая информация
приложения, так называемый "мир A5" (A5 world);
стек приложения;
куча приложения.
"Мир A5"
(название происходит от имени регистра микропроцессора M 68К, который
используется для адресации) содержит:
глобальные переменные
приложения;
глобальные переменные
QuickDraw (подсистемы экранного отображения);
параметры приложения;
таблицу переходов.
Стек приложения используется
для сохранения адресов возврата и выделения памяти для локальных переменных. В
куче размещаются коды и данные приложения. Кроме того, приложению могут
выделяться по запросу блоки памяти вне его раздела.
Память в куче выделяется
блоками переменной длины. Блоки могут быть перемещаемыми или неперемещаемыми.
Обращение к неперемещаемому блоку производится по прямому адресу. Обращение к
перемещаемому блоку производится с применением косвенной адресации через, так
называемый, главный блок указателей (master pointer block). Для каждого
приложения система создает такой блок определенного по умолчанию размера,
размер блока может быть увеличен самим приложением. Такой способ выделения
памяти приводит к образованию "внешних дыр", которые могут уменьшать
объем доступной для приложения памяти. Для борьбы с этим явлением система
производит (при нехватке памяти) дефрагментацию кучи - переписывает в памяти
все перемещаемые блоки таким образом, чтобы внешние дыры слились в одну
свободную область в верхней части кучи. При переносе блоков корректируется
главный блок указателей, таким образом, перенос остается прозрачным для
приложения. Наличие в куче неперемещаемых блоков снижает эффективность сжатия
кучи, поэтому система стремится разместить все перемещаемые блоки в нижней
части кучи. Если при размещении перемещаемого блока оказывается, что то место в
нижней части кучи, на которое он претендует, занято перемещаемым блоком,
система переносит перемещаемый блок в другое место и освобождает место для
неперемещаемого.
Перемещаемый блок может
также быть объявлен удаляемым: системе разрешается удалять его при нехватке
памяти в куче приложения. Работая с удаляемым блоком, программист должен всякий
раз, начиная работу с ним, проверить его наличие в памяти и отменить признак, разрешающий
удаление.
Введение в компьютеры
фирмы Apple динамической трансляции адресов позволило перейти к 32-разрядному
размеру адреса и, таким образом, обеспечивать виртуальное адресное пространство
размером в 4 Гбайт. Динамическая трансляция адресов использует страничную
модель виртуальной памяти для расширения адресного пространства. Страничный
обмен использует алгоритм LRU. Структура нижней части адресного пространства
(до границы 16 Мбайт) - такая же, как и в 24-разрядной модели, что обеспечивает
прозрачное выполнение 24-разрядных приложений в новой среде. Для 32-разрядных
приложений могут выделяться дополнительные разделы выше 16-Мбайтной границы.
Страницы: 1, 2, 3, 4, 5, 6
|