Sun OpenBoot Prom. Между железом и софтом::Журнал СА 8.2009
www.samag.ru
     
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
  Статьи

Дата-центры  

Дата-центры: есть ли опасность утечки данных?

Российские компании уже несколько лет испытывают дефицит вычислительных мощностей. Рост числа проектов,

 Читать далее...

Книжная полка  

Защиты много не бывает

Среди книжных новинок издательства «БХВ» есть несколько изданий, посвященных методам социальной инженерии

 Читать далее...

Событие  

В банке рассола ждет сисадмина с полей фрактал-кукумбер

Читайте впечатления о слете ДСА 2024, рассказанные волонтером и участником слета

 Читать далее...

Организация бесперебойной работы  

Бесперебойная работа ИТ-инфраструктуры в режиме 24/7 Как обеспечить ее в нынешних условиях?

Год назад ИТ-компания «Крок» провела исследование «Ключевые тренды сервисного рынка 2023». Результаты

 Читать далее...

Книжная полка  

Читайте и познавайте мир технологий!

Издательство «БХВ» продолжает радовать выпуском интересных и полезных, к тому же прекрасно

 Читать далее...

СУБД PostgreSQL  

СУБД Postgres Pro

Сертификация по новым требованиям ФСТЭК и роль администратора без доступа к данным

 Читать далее...

Критическая инфраструктура  

КИИ для оператора связи. Готовы ли компании к повышению уровня кибербезопасности?

Похоже, что провайдеры и операторы связи начали забывать о требованиях законодательства

 Читать далее...

Архитектура ПО  

Архитектурные метрики. Качество архитектуры и способность системы к эволюционированию

Обычно соответствие программного продукта требованиям мы проверяем через скоуп вполне себе понятных

 Читать далее...

Как хорошо вы это знаете  

Что вам известно о разработках компании ARinteg?

Компания ARinteg (ООО «АРинтег») – системный интегратор на российском рынке ИБ –

 Читать далее...

Графические редакторы  

Рисование абстрактных гор в стиле Paper Cut

Векторный графический редактор Inkscape – яркий представитель той прослойки open source, с

 Читать далее...

День сисадмина  

Учите матчасть! Или как стать системным администратором

Лето – время не только отпусков, но и хорошая возможность определиться с профессией

 Читать далее...

День сисадмина  

Живой айтишник – это всегда движение. Остановка смерти подобна

Наши авторы рассказывают о своем опыте и дают советы начинающим системным администраторам.

 Читать далее...

Виртуализация  

Рынок решений для виртуализации

По данным «Обзора российского рынка инфраструктурного ПО и перспектив его развития», сделанного

 Читать далее...

Книжная полка  

Как стать креативным и востребованным

Издательский дом «Питер» предлагает новинки компьютерной литературы, а также книги по бизнесу

 Читать далее...

1001 и 1 книга  
19.03.2018г.
Просмотров: 6414
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7118
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4396
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3086
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3882
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3897
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6386
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3234
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3530
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7364
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10726
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12445
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14097
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9192
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7142
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5447
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4683
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3496
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3213
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3449
Комментарии: 0
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3090
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 Sun OpenBoot Prom. Между железом и софтом

Архив номеров / 2009 / Выпуск №8 (81) / Sun OpenBoot Prom. Между железом и софтом

Рубрика: Администрирование /  Продукты и решения

ВЛАДИМИР ВАСИЛЬКИН, инженер, занимается администрированием информационных систем и сервисов

Sun OpenBoot Prom
Между железом и софтом

Что может скрываться за буквами «ок» на белом экране?

OpenBoot Prom (OBP) – одна из айтишных «вкусностей», рожденная в лабораториях Sun Microsystems и широко используемая в настоящее время разными производителями аппаратного обеспечения. Можно сказать, что OBP – это аналог BIOS на платформах, отличных от x86, таких как sparc, powerpc и, возможно, других [1]. Основное предназначение данной программы – firmware[1] – загрузка и запуск других, более сложных программ и передача этим программам управления системой. «Другими» программами могут являться ОС, средства диагностики, отладки и т.п.

В процессе работы мне практически не приходилось сталкиваться с оборудованием, отличным от sparc и x86-подобных архитектур. OpenBoot на PC-совместимых компьютерах не встречал, все примеры в статье работают на архитектуре sparc sun4u.

В то же время одной из особенностей OBP является кроссплатформенность[2] – на разном аппаратном обеспечении ожидается похожее поведение системы. Чем-то напоминает «написано раз – используешь везде» – лозунг Java. Дело в том, что в компании всегда производились машины нескольких архитектур, отличных от x86. Сейчас это – sun4u (ultrasparc), sun4v (niagara), раньше были и другие.

Загружать операционную систему приходилось с целого ряда устройств: дисков различных типов, по сети через разные адаптеры и т.п. Вместо того чтобы писать свой загрузчик для каждого устройства ввода-вывода (см. пример BIOS), инженеры Sun пошли другим путем. Поставщикам оборудования была предоставлена возможность размещать загрузчики на самих устройствах – так называемые plug-in-драйверы устройств.

Драйверы должны быть написаны на языке Forth – OBP включает в себя интерпретатор этого языка. Храниться драйверы могут как на самих устройствах, так и на свободном месте в OBP. То есть любой сторонний производитель может выпустить свое абсолютно новое устройство и «подружить» его с остальной системой, не перекраивая firmware.

Но OBP – это не только загрузчик ОС. Он может еще использоваться для диагностики и отладки как железа, так и ядра операционной системы. Что является еще одним отличием OBP от BIOS для x86. Средства диагностики еще можно встретить на некоторых материнских платах, но вот с возможностями отладки мне сталкиваться не приходилось.

Наличие интерпретатора forth предоставляет возможность для составления сложных программ из простых, доступных изначально команд. Вообще работа с ОВР происходит в оболочке интерпретатора forth, что напоминает привычный shell.

Приглашение для ввода команд обычно выглядит так:

ok

Далее по тексту это приглашение используется в примерах команд. Внимание – если приглашение выглядит так:

sc>

значит, управление передано не OBP, а сервисному контроллеру. Как работать с сервисным контроллером – отдельная тема [9].

Обычно достаточно помнить, что передать управление к OBP можно командой console. Попасть обратно в sc – сочетанием #., как показано в примере:

sc> console

Enter #. to return to ALOM.

Интерфейс командной строки мне хотелось бы выделить отдельно – это свойство может быть очень полезно в работе для «убийства рутины» – путем программирования часто повторяющихся действий. Например, при отладке. В случае же удаленного управления кучей серверов никакая графика не заменит возможностей expect и интерфейса командной строки OBP.

Пользовательский интерфейс основан на командном интерпретаторе, который предоставляет доступ к обширному набору команд для управления аппаратными средствами, программирования, изоляции проблемных мест и отладки. Набор доступных команд зависит от реализации – версий систем, используемых в ОВР. Эта информация доступна по команде:

ok .version

Release 4.22.33 created 2007/06/18 12:45

OBP 4.22.33 2007/06/18 12:45 Sun Fire V210/V240,Netra 210/240

OBDIAG 4.22.33 2007/06/18 12:58

POST 4.22.33 2007/06/18 13:07

Далее набираем в поиске [2], к примеру, «OBP 4» и смотрим доступные документы. Также может быть полезен поиск по названию сервера.

Начало работы

Начать работать с OBP очень просто – нужно лишь послать сигнал break системе. Как – зависит от настроек консоли.

Часть систем управляется через COM-порт, часть – с помощью монитора и клавиатуры и т.п. В OBP можно переназначить console – управляющее устройство – об этом далее.

Самое популярное средство управления, конечно же, удаленная консоль. В таком случае процедура отправки сигнала break системе зависит от консольного клиента и от всей цепочки устройств до требуемого. Нередко доступ к консоли можно получить, лишь подключившись через цепочку серверов. Некоторые машины в цепочке также могут реагировать на сигнал break – т.е. прерывать свою работу. Следует быть аккуратным – бывают случаи, когда по невнимательности выключаются транзитные серверы.

Внимательно смотрим документацию на свой терминальный клиент (ssh, telnet – нужное подчеркнуть) и жмем соотвествующие клавиши или кнопки мыши.

Например, подключившись через стандартный telnet-клиент, можно нажать <Ctrl>+<]>». После чего ввести два слова: «send break» и нажать <Enter>.

Кроме удаленного управления рабочие станции Sun на платформе sparc могут управляться с клавиатуры. В таком случае сигнал break системе можно послать, нажав одновременно <Stop>+<a> или <Stop>+<q> – в зависимости от типа клавиатуры: qwerty или azerty. На последних USB-клавиатурах порядок действий может отличаться – я с этим не сталкивался, но в документации так написано.

Также в ОВР можно попасть из ОС, например, по команде:

# halt

Отличие от сигнала break в том, что halt прекращает работу ОС и передает управление в OBP, тогда как break прерывает работу ОС или других программ. Во многих случаях после «прерывания» можно опять запустить ОС в том же месте командой go. После команды halt (из ОС) будет работать только команда boot – загрузка ОС заново.

Кроме двух относительно нормальных способов, существует еще парочка.

Первый – отключение и включение питания сервера. Если система не сконфигурирована на автоматическую загрузку, после пропадания питания управление будет передано OBP.

Еще один нестандартный способ – когда OBP в момент загрузки ОС обнаруживает ошибки, которые разрешить не может. Например, часто встречающаяся ошибка – неправильно назначенно загрузочное устройство.

Дерево устройств – адресация

Для понимания работы ОВР стоит разобрать понятие Device Tree – дерево устройств. Устройства могут подключаться к системе разными способами – используя различные шины, контроллеры, протоколы. ОВР представляет все устройства в виде иерархической структуры типа «дерево», что очень похоже на файловую систему. У каждого устройства может быть родительское и ряд дочерних устройств – соответственно к чему подключено устройство и что подключено через него. В основном родительскими являются шины, контроллеры и т.п.

Полный путь к каждому устройству обозначается как перечень родительских, разделенных прямой косой чертой – совсем как в UNIX-подобных файловых системах. Первая черта обозначает саму машину, «корень» всех устройств.

В Solaris тоже можно получить доступ к Device Tree через специальный каталог /devices. Внешний вид дерева устройств будет выглядеть так же, как в OBP.

Вывод команды ls в ОС Solaris на Netra210:

# uname –sir

SunOS 5.10 SUNW,Sun-Fire-V210

# pwd

/devices

# ls -1

iscsi

iscsi:devctl

memory-controller@0,0

memory-controller@0,0:mc-us3i

memory-controller@1,0

memory-controller@1,0:mc-us3i

options

pci@1c,600000

pci@1c,600000:devctl

pci@1c,600000:intr

pci@1c,600000:reg

pci@1d,700000

pci@1d,700000:devctl

pci@1d,700000:intr

pci@1d,700000:reg

pci@1e,600000

pci@1e,600000:devctl

pci@1e,600000:intr

pci@1e,600000:reg

pci@1f,700000

pci@1f,700000:devctl

pci@1f,700000:intr

pci@1f,700000:reg

pseudo

pseudo:devctl

ramdisk-root

ramdisk-root:a

ramdisk-root:a,raw

scsi_vhci

scsi_vhci:devctl

Начало ввывода show-devs на Netra210:

ok show-devs

/pci@1d,700000

/pci@1c,600000

/pci@1e,600000

/pci@1f,700000

/memory-controller@1,0

/SUNW,UltraSPARC-IIIi@1,0

/memory-controller@0,0

/SUNW,UltraSPARC-IIIi@0,0

/virtual-memory

/memory@m0,0

/aliases

/options

/openprom

/chosen

/packages

/pci@1d,700000/network@2,1

/pci@1d,700000/network@2

/pci@1c,600000/LSILogic,sas@1

/pci@1c,600000/scsi@2,1

/pci@1c,600000/scsi@2

/pci@1c,600000/LSILogic,sas@1/disk

/pci@1c,600000/LSILogic,sas@1/tape

/pci@1c,600000/scsi@2,1/tape

/pci@1c,600000/scsi@2,1/disk

 Имя каждого устройства представлено в следующем виде: device-name@unit-address:device-arguments, где:

device-name – имя (название) устройства. В официальной документации сказано «для людей» – human-readable. Я бы подчеркнул, что понятны эти названия будут лишь подготовленным читателям;

unit-address – адрес устройства, текстовая строка, обозначающая физический адрес устройства в родительском пуле адресов. Формат написания зависит от шины (родительского устройства);

device-arguments – аргументы, зависящие уже от конкретного устройства данные, которые могут быть полезны при дальнейшей работе.

Хороший пример адресации устройства:

/sbus@1f,0/esp@0,40000/sd@3,0:a

Эта строчка говорит о том, что шина SBus подключена непосредственно к основной системной шине, адрес 1f,0. 0,40000 – слот в Sbus (в нашем случае – 0), и смещение 40000. Далее можно понять, что подключен SCSI Disk (sd) по адресу 3,0, партиция «а». В документации именование устройств расписано довольно подробно.

Псевдонимы

Все это выглядит очень интересно, но, мягко говоря, нечитабельно, если, конечно, читатель не имеет отношения к поддержке оборудования или разработке драйверов устройств.

Для более простого восприятия ОВР предоставляет систему алиасов – псевдонимов устройств. Так что всем привычное net из команды:

ok boot net

обычно раскладывается во что-нибудь вроде:

/pci@1d,700000/network@2,1

 Управлять псевдонимами устройств можно:

  •  на время текущей сессии – до перезагрузки по питанию или сброса параметров ОВР (не путать с перезагрузкой ОС – на ОВР никак не влияет).
  •  записать в NVRAM – энергонезависимую память ОВР. Если быть более точным, то nvramrc – это часть NVRAM, доступная для хранения пользовательских команд, программ и псевдонимов устройств.

 Команда devalias по своему синтаксису похожа на alias оболочки bash (или подобных интерпретаторов) и имеет три формы:

devalias – показывает список определенных алиасов устройств;

devalias ALIAS – показывает полный путь к устройству, доступному по указанному псевдониму;

devalias ALIAS ПУТЬ_К_УСТРОЙСТВУ – определяет новый псевдоним для указанного устройства.

Поведение команды nvramrc очень напоминает файл .bash_rc или другой подобный, выполняемый при старте системы или пользовательской сессии. Все команды, хранимые в nvramrc, записываются в текстовой форме. Причем может быть использован почти весь набор команд, доступный из командной оболочки. Исключений немного, это команды: banner, boot, nvedit, password, reset, setenv security-mode.

Для создания псевдонима устройства, доступного после перезагрузки, можно воспользоваться командой:

nvalias ALIAS ПУТЬ_К_УСТРОЙСТВУ

Действие команды аналогично devalias, что легко проверить. Набрав nvedit, мы увидим:

devalias ALIAS ПУТЬ_К_УСТРОЙСТВУ

Как нетрудно догадаться, nvedit – встроенный редактор, с помощью которого можно управлять nvramrc. Синтаксис немного похож на синтаксис Emacs. Подробное описание смотрите в документации, отмечу лишь, что выйти из редактора можно по <Ctrl>+<C>. Нужно помнить, что nvedit работает только с временным буфером. Чтобы изменения вступили в силу, после редактирования нужно выполнить команду nvstore. Проверить работу команд в буфере можно, выполнив nvrun.

В nvramrc можно также определять свои программы, как показано в примере:

ok nvedit

0: : hello ( -- )

1: ." Hello, world. " cr

2: ;

3: ^-C

ok nvstore

ok setenv use-nvramrc? true

ok reset

....

ok hello

Hello, world.

Понятно, что напрограммировать в nvramrc можно многое, но я в своей работе ни разу этот функционал не использовал. Похоже, он бывает больше полезен разработчикам и сервисным инженерам, которым приходится диагностировать проблемы в работе оборудования.

От себя добавлю лишь, что отключить использование nvramrc можно командой:

ok setenv use-nvramrc? false

Теперь мы знаем, что такое адресация и псевдонимы устройств, но не знаем, что с ними делать. Все просто.

Работа с устройствами

В терминологии ОВР все устройства называются нодами. Конечные устройства (которые не имеют «потомков») называются «листьями» – leaf. Обычно это и есть «настоящие устройства», а не контроллеры, шины и другие связующие звенья. Каждая нода может предоставлять о себе следующую информацию:

свойства – структура данных, описывающая устройство;

методы – набор команд, доступных при работе с этим устройством;

данные – значения, используемые при инициализации и дальнейшей работе с устройством.

Существуют стандарты на название и наличие свойств и методов в драйверах устройств. Некоторые свойства и методы должны обязательно поддерживаться драйвером устройства, поддержка других – рекомендована. Что-то производители «железа» добавляют самостоятельно.

При работе с ОВР в каждый момент времени у нас есть так называемое текущее устройство – current node.

Мы можем выбирать текущее устройство командой dev c параметром, где параметром может быть:

  •  полное имя устройства;
  •  неполное имя устройства. В таком случае среди всего дерева устройств-потомков ищется совпадающая по имени нода;
  •  «..» и «/» – две точки и слеш ведут себя совсем как в файловой системе и обозначают, соответственно, выбор родительского устройства и корень всех устройств – саму машину.

Чтобы интерфейс стал совсем узнаваемым – используются команды ls и pwd, поведение которых такое же, как в любой UNIX-подобной файловой системе. Они показывают, соответственно, «список потомков» и «текущее устройство».

Более того, во многих реализациях OBP для команды dev используется алиас cd – наверно, чтобы системные администраторы чувствовали себя «совсем как дома».

Вот еще полезные команды для работы с устройствами:

ok device-end – показывает список всех «листьев» «дерева»;

оk show-devs – показывает список всех устройств «дерева»;

ok .properties – показывает различные свойства устройства. Например, производитель, модель и текущие параметры сетевой карты;

ok words – показывает имена методов, применимые к указанному устройству;

ok see WORDNAME – показывает, что означает слово FORTH. Например, из каких команд состоит указанная программа;

ok unselect-dev – делает текущим предыдущее устройство или корень. Подобно cd $OLDPWD в bash.

Каждому устройству рекомендуется иметь работающий метод selftest. Он вызывается командой test и используется для диагностики. Как несложно догадаться, метод должен возвращать сообщение об обнаруженных проблемах в устройстве или не выводить ничего в случае корректной работы. Некоторые несознательные драйверы все же выводят сообщение об успешно проведенных тестах. Славятся подобным поведением драйверы сетевых карт. Если метод selftest не описан – система выведет сообщение об ошибке.

Команда test-all вызовет test для всех устройств в системе.

Кроме команды test, применимой, в принципе, ко всем устройствам, пользователю доступны еще несколько команд диагностики. Они различаются по типам проверяемых устройств и по типу предоставляемой информации. Все команды простые, не вижу смысла заострять внимание на их описании – смотрите документацию к своей версии ОВР.

Если в процессе работы вы забыли название или синтаксис команд – всегда на помощь придет help:

ok help – выдаст список категорий помощи;

ok help КАТЕГОРИЯ – покажет краткое описание всех команд указанной категории. Категория определяется только по первому слову в названии;

ok help КОМАНДА – покажет справочную информацию о конкретной команде.

К сожалению, help доступен не для всех команд. Официальная причина – команд слишком много, и справка доступна лишь для самых популярных. Похоже на правду, если учесть ограниченный объем NVRAM.

Для получения помощи в OBP также можно использовать команду sifting:

ok sifting ARG – выведет все команды, которые содержат последовательность ARG.

ok sifting boot

network-boot-arguments(0x11bd) boot(0x10a2) auto-boot-timeout(0x1075)


auto-boot?(0x1074) boot-command(0x1073) boot-file(0x1070) boot-device(0x106f)


/openprom/client-services:boot(0x120d)

Конфигурация системы

Кроме набора команд и дерева устройств, каждая система имеет ряд настраиваемых параметров конфигурации. На один из них мы уже обращали внимание – use-nvramrc?.

Вопросительный знак в конце имени переменной значит, что значений может быть два: false или true. Значения остальных переменных – текстовые. Пожалуй, исключение составляет oem-logo – логотип, отображаемый командой banner (часто – при загрузке системы).

Логотип – это массив пикселей 64х64, поменять его проще всего командой eeprom из ОС.

Можно и средствами ОВР, немного попрограммировав на FORTH или вбивая массив пикселей руками. В документации есть пример.

В основном вся работа с переменными производится с помощью 5 команд:

printenv [VARIABLE] – показывает значение одной переменной, если указана, или весь список имен и значений – в противном случае;

setenv [VARIABLE] [VALUE] – присваивает указанной переменной заданное значение. Часто вступления изменений в силу потребуется reset системы;

set-default [VARIABLE] – сбрасывает переменную в значение по умолчанию;

set-defaults – присваивает всем переменным значения по умолчанию;

password – присваивает пароль на управление системой.

В Solaris присутствует команда eeprom, которая позволяет менять некоторые переменные OBP. Самые ленивые администраторы переставляют ОС, не подключаясь к консоли – лишь используя eeprom и reboot с аргументами.

Уделим немного внимания встроенным средствам безопасности. ОВР может работать в трех режимах безопасности (значения переменной security-mode):

full – все команды, кроме go, будут требовать ввода пароля;

command – все команды, кроме boot и go, будут требовать ввода пароля. Причем команда boot с аргументами (попытка загрузиться с устройства не по умолчанию) тоже запросит пароль;

none – значение по умолчанию – пароль не будет требоваться в любом случае.

Не удержусь от напоминания, что следует быть внимательным при назначении режима безопасности и при смене пароля – сбросить его своими силами вряд ли получится – придется вызывать сервис-инженера.

Ряд переменных отвечает за параметры ввода-вывода ОВР – их конфигурацию называют еще «управление консолью»:

  •  input-device;
  •  output-device;
  • screen-#columns;
  • screen-#rows.

За что отвечают эти настройки – понятно из названия. Изменять их следует внимательно – можно «потерять консоль», что не светит ничем хорошим. В случае недоступности ввода или вывода после перезагрузки по питанию придется искать консоль на fall-back устройствах.

Основная задача системного администратора в ОВР – загрузить систему. За поведение ОВР в момент загрузки отвечают несколько переменных.

Во-первых, значение переменной auto-boot? говорит нам о том, будет ли система пытаться загрузиться при включении. Если да, то будет проверяться переменная boot-command, значение по умолчанию которой – boot.

Далее проверяется переменная diagnostic-mode?.

Если значение равно false, система будет пытаться загрузиться с устройств, перечисленных в переменной boot-device и искать там файл boot-file для запуска.

В противном случае процедура загрузки системы усложнится. Сначала будет запущен selftest в порядке, зависящем от переменной diag-level. Далее может последовать вывод дополнительной информации о статусе системы – зависит от реализации. Последнее отличие – для загрузки будут использованы другие переменные: diag-device и diag-file.

Нетрудно догадаться, что переменная boot-file – не что иное, как ядро операционной системы. По умолчанию система будет пытаться загрузить Solaris из файла kernel/unix, которому также можно передать параметры.

Подробное рассмотрение процесса загрузки и запуска программ в различных режимах выходит за рамки данной статьи наряду с возможностями отладки (debugging) и программирования на FORTH.

В повседневной работе системный администратор обычно сталкивается с задачами определения и конфигурации устройств, инсталляции и загрузки ОС.

После чего ОВР на настроенной машине используется редко.

Работа с ОВР хорошо документирована, информацию найти легко для всех, даже не самых простых, задач.

  1. http://wikipedia.org.
  2. http://docs.sun.com.
  3. OpenBoot™ 4.x Command Reference Manual, Sun P/N: 816-1177-10.
  4. Writing FCode 3.x Programs, Sun P/N: 806-1379-10.
  5. Working with the Openboot – http://tldp.org/HOWTO/SPARC-HOWTO-14.html.
  6. Questions and answers on OpenBoot – http://www.itworld.com/print/34644.
  7. Справочное руководство по ППЗУ OpenBoot PROM (OBP) – http://www.gentoo.org/doc/ru/gentoo-sparc-obpreference.xml.
  8. TN105 – Sun OpenBoot Prom – http://www.marchansen.com/tn105.
  9. Sun Advanced Lights Out Manager 1.6 (ALOM) – http://www.sun.com/servers/alom.html.


[1] Firmware - «микрокод» - говорит StarDict, или «ППЗУ» - подсказывают на сайте gentoo [7].

[2] Для ряда платформ драйверы могут работать одинаково, но гарантировать полную идентичность поведения ОВР на этих платформах не могу - не проверял.


Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru