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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

02.12.2013г.
Просмотров: 3164
Комментарии: 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