Прошивка загрузчика PXE для сетевых плат RTL8139 в БИОС материнской платы. Эта статья - в некотором роде продолжение другой, про бездисковую загрузку FreeBSD.
Там всё хорошо, но вот имелись две проблемы, решение обеих - тут. Первая, заключалась в том, что большинство машин грузилось с дискет. К тому же, с дискет грузилось очень много инфы - ядро, даже очень урезенное и сжатое, довольно большое. Как итог, через две недели древние дискеты стали сыпаться - новых не было ни дискет, ни флопповодов.
Вторая - до этого стоял линуксовый тонкий клиент - он не выводил загрузочные сообщения, а показывал графическую заставку. Когда первый раз грузилась фря - народ достал звонками, якобы у них у всех резко поломались компы, или мониторы - мол вначале буквы были белые, потом красные, а щас вообще зелёные :))) (У меня цвет букв разный для сообщений ядра и консоли). Собсно, хотелось прикрутить заставку, но - на дискеты её всем не положишь - места мало. В итоге, я вернулся к изысканиям о возможности как-то прикрутить PXE куда угодно - на дискету или в сетевуху. Микросхемы были - от старых первых пней, довольно много - штук 20 - но шится не хотели. Толи все сетевухи были совсем кривые, толи программатор, толи мои руки (больше всего грешу на последнее - но раньше-то у меня получалось, правда давно, лет 6 назад, в 2000 году.
). В процессе изысканий, на каком-то форуме, нашёл интересное высказывание - типа в VIA`вском БИОСе, для одинаковых мам - с разницей лишь в наличии/отсутсвии микросхемы сетевухи, отличие лишь одно - при наличии микросхемы, в образе BIOS`a есть файл *. lom. Из этого было ясно - БИОС можно разобрать и собрать заново, зашив в него нужный файлик - а такие у меня были (тупым поиском по своей коллекции драйверов я нашёл такие для родных сетевух VIA и для RTL8139/RTL8130). Вариант меня вполне устраивал - почти на 80% самосборных тонких клентов стояли именно такие, да в запасе их было штук 6.
Дальнейшие поиски шли по другому пути - надо было найти программу для работы с БИОС - тоже нашлась - называется cbrom. Ограничение есть и у неё - она работает лишь с AWARD`овскими прошивками. Это тоже устраивало - их было большинство. Дальнейшие эксперименты показали - выпадают практически все первые пни - у них слишком маленькая микросхема - 128k, и свободного места нехватает для того, чтобы впихнуть файл загрузки по PXE. (Надо заметить, что cbrom позволяет не только добавлять, но и удалять отдельные файлы из BIOS - но это не спасает, места всё равно выкроить не удалось.
) Зато начиная со вторых пней всё прекрасно - на всех попавшихся машинах не надо было ничего выкидывать - свободное место и так было. Надо было просто добавить. Для удобства работы был подобран мелкий винт на 4 гига (мельче не было), отформатрован в FAT, на него были скинуты системные файлы, Norton Commander (для удобства - DOS я уже изрядно подзабыл), uniflash, cbrom215, rset8139, написны autoexec. bat и config. sys. Поехали.
Грузимся с харда и создаём директорию (по модели материнки, например) для экспериментов:. Лирическое отступление - вообще, рекомендую делать бэкап BIOS, и по возможности (когда микруха на матери съёмная и есть другая флэшка такого же или большего размера), загрузившись и сделав копию БИОСа, наживую выдернуть старую и воткнуть новую. Для удобства выдёргивания-втыкания, микросхемы выдёргивается на выключенной маме, обматывается толстыми нитками, или проволочками (в изоляции!), из них же делается ручка, чтоб удобней дёргать, затем втыкаются. Очень удобно - за проволочки вытащил, вставил другую, также обмотанную.
После чего в неё зашивается тока что сделанная копия, проверяете, перезагрузившись, и если всё пучком - с ней и работайте, отложив родную микруху в сторонку - малоли, загубите (мне, правда, ни одной не удалось загубить, - но я это делаю не первый раз. ). Делаем копию оригинального BIOS:.
Второе лирическое отступление - несколько раз столкнулся с битыми микрухами - не шьются, или шьются но проверку не проходят. С такими лучше не работать, для проверки, зашиваем обратно родной БИОС и смотрим - как оно прошло (Это, если не перетыкаете микросхемы. Если перетыкаете - подберите нормальную). Если хорошо - то хорошо, если плохо - возможны варианты - чаще всего - просто плохой контакт - надо выдернуть и воткнуть микросхему на место. Другой вариант - мне попался второй пень с 512k флэшкой - и забита почти под завязку.
Другой такой у меня не было, дёрганье туда-сюда не помогло. Подумавши - сообразил - битые блоки были в конце флэшки, туда и шился файл загрузчика.
Надо его зашить ближе к началу - и всё будет пучком. Для этого - выкинул пару файликов, которые показались ненужными (вот тут и нужны бэкапы и соображаловка - пояснений оччень мало. ) - по названию были опознаны звук, логотипы, и ещё какая-то мелочёвка (разумеется, не надо выкидывать вещщи со строчкой vga в названии, если на маме встроенное видео - и т. После чего был добавлен загрузчик и всё с криками флэшера о непрохождении проверки зашито на место.
Работает. Тока звука больше никогда не будет :))).