По этой причине сотрудники исследовательского центра Microsoft в Кембридже (Англия) совместно со Федеральной политехнической школой в Цюрихе (Швейцария) приступили к разработке новой операционной системы, которая должна обеспечить кардинальное ускорение работы программ на многоядерных компьютерах.
По словам профессора Тимоти Роско, новая система, получившая название Barrelfish, пока еще находится в стадии научно-исследовательских разработок. Тем не менее в сентябре ее код был опубликован на условиях лицензии BSD на программное обеспечение с открытым кодом. Несмотря на то что новая система пока не вышла из фазы эксперимента, разговоры о ней подогрели интерес публики, которая стала интенсивно скачивать код. Роско подчеркивает, что на данном этапе у разработчиков не было цели привлечь чье бы то ни было внимание к ОС.
Проект ведется уже около двух лет и призван воплотить в жизнь многолетние идеи исследователей о том, как должны эволюционировать операционные системы, чтобы не отставать от современного уровня аппаратного обеспечения.
Для каждого ядра в Barrelfish выделена отдельная область памяти — не существует разделяемой памяти, как в Windows или Linux. Такая архитектура основана на обмене сообщениями между ядрами и получила у исследователей название мультиядерной (multikernel).
По утверждению Роско, передача сообщений между ядрами — например, сообщений с данными, имеющими отношение к безопасности, или любыми другими, обеспечивающими надежную работу ОС, оказалась более эффективной, чем использование разделяемой памяти.
Несмотря на то что операционные системы "знают", как использовать многоядерные процессоры, большинство современных приложений написаны без учета многоядерной архитектуры. Поэтому такие компании, как Microsoft, Intel и Sun Microsystems, заняты тем, чтобы выяснить, как создавать распараллеленный код, во время исполнения которого использовались бы преимущества многоядерной архитектуры.
Компания Apple использует механизм параллельного программирования в своей библиотеке Grand Central Dispatch, поставляемой в составе последнего пакета обновлений под названием Snow Leopard к Mac OS X. Библиотеку GCD можно применять для создания приложений, использующих многоядерность, однако, как подчеркивает Роско, библиотека работает поверх Mac OS и не может заменить собой операционную систему.
Barrelfish построена на распределенной архитектуре. Вместо того чтобы пытаться идти на сложные компромиссы и ограничения в разделении ресурсов, характерные для модели с разделяемой памятью, разработчики выбрали в качестве модели для ОС распределенную систему с неразделяемыми ресурсами.
Такой подход позволит Barrelfish работать на самом разнообразном "железе", поскольку в выбранной модели операционная система максимально отделена от аппаратуры. Специфика архитектуры аппаратной части сводится к двум аспектам: механизму доставки сообщений и интерфейсам для работы с аппаратной частью.
Это означает, что отпадет необходимость переписывать код Barrelfish в той степени, какая требуется для Windows или Linux, чтобы работать на более современных аппаратных системах. По словам Роско, для них, исследователей-разработчиков операционных систем, внутреннее устройство системы сейчас чрезвычайно отличается от того, что было еще пять лет назад.
Код Barrelfish доступен для скачивания. В настоящее вреся система работает на 64-разрядной платформе x86. Для новой операционной системы разработчики уже написали Web-сервер и некоторое количество графических приложений. Но не следует ожидать, что обычное приложение из пакета Microsoft Office запустится и будет работать в среде Barrelfish.
По словам Роско, несмотря на серьезность и глубину разработок, в настоящий момент еще рано говорить о готовности Barrelfish для конечных пользователей. Код еще до конца не отлажен, его более зрелая версия ожидается позднее. Кодом Barrelfish совместно владеют Microsoft и Федеральная политехническая школа в Цюрихе. На сегодняшний день никаких заявок на патенты подано не было. Роско подытоживает: цель проекта не в создании частной интеллектуальной собственности, а в возможности заниматься исследовательской работой на долгосрочной основе.