2023-07-10 15:43:08 +00:00
|
|
|
|
---
|
|
|
|
|
title: Побудова з джерельного коду
|
|
|
|
|
x-toc-enable: true
|
|
|
|
|
...
|
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
WARNING: Flash from bin/, NOT elf/
|
|
|
|
|
==================================
|
|
|
|
|
|
|
|
|
|
TODO: translate this section into ukrainian language
|
|
|
|
|
|
|
|
|
|
**WARNING: When you build a ROM image from the Canoeboot build system, please
|
|
|
|
|
ensure that you flash the appropriate ROM image from `bin/`, NOT `elf/`.
|
|
|
|
|
The `elf/` coreboot ROMs do not contain payloads. Canoeboot's build system
|
|
|
|
|
builds no-payload ROMs under `elf/`, and payloads separately under `elf/`. Then
|
|
|
|
|
it copies from `elf/` and inserts payloads from `elf/`, and puts the final ROM
|
|
|
|
|
images (containing payloads) in `bin/`. This design is more efficient, and
|
|
|
|
|
permits many configurations without needless duplication of work. More info
|
|
|
|
|
is available in the [cbmk maintenance manual](../maintain/)**
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
Introduction
|
|
|
|
|
============
|
|
|
|
|
|
|
|
|
|
Система побудови libreboot, називається `lbmk`, скорочення від `LibreBoot MaKe`, і цей
|
|
|
|
|
документ описує те, як використовувати її. З цим керівництвом ви можете узнати те, як побудувати
|
|
|
|
|
libreboot з доступного джерельного коду.
|
|
|
|
|
Ця версія, якщо розміщена наживо на libreboot.org, передбачає, що ви використовуєте
|
|
|
|
|
сховище git `lbmk`, яке
|
|
|
|
|
ви можете завантажити, використовуючи інструкції на [сторінці огляду коду](../../git.uk.md).
|
|
|
|
|
|
|
|
|
|
Якщо ви використовуєте архів випуску libreboot, будь ласка, зверніться до
|
|
|
|
|
документації, включеної до *того* випуску. Випуски libreboot розраховані тільки,
|
|
|
|
|
як *знімки*, не для розробки. Для належної розробки ви маєте завжди
|
|
|
|
|
працювати безпосередньо в сховищі git libreboot.
|
|
|
|
|
|
|
|
|
|
Наступний документ описує те, як працює `lbmk`, і як ви можете робити зміни
|
|
|
|
|
до нього: [керівництво обслуговування libreboot](../maintain/)
|
|
|
|
|
|
|
|
|
|
Release status
|
|
|
|
|
==============
|
|
|
|
|
|
|
|
|
|
Information about status will be reported during builds; if a board is
|
|
|
|
|
marked as stable, the build proceeds without further input. If the board is
|
|
|
|
|
marked anything other, a warning appears asking if you wish to proceed; to
|
|
|
|
|
disable these warnings, do this before building (not recommended):
|
|
|
|
|
|
|
|
|
|
export XBMK_STATUS=n
|
|
|
|
|
|
|
|
|
|
In Libreboot, we specify: `stable`, `unstable`, `broken` or `untested`.
|
|
|
|
|
The "unstable" marking means that the board boots mostly/entirely reliably
|
|
|
|
|
annd should be safe to use, but may have a few issues, but nothing which would,
|
|
|
|
|
for example, cause safety issues e.g. thermal, data reliability etc.
|
|
|
|
|
|
|
|
|
|
The `broken` setting means that a given board will likely brick if flashed.
|
|
|
|
|
The `untested` setting means untested.
|
|
|
|
|
|
|
|
|
|
Release status is always set with regards to the current lbmk revision, on
|
|
|
|
|
the theory that the current revision is being used to generate a full release.
|
|
|
|
|
The setting is decided on a board-by-board basis, taking its various quirks
|
|
|
|
|
and idiosynrasies into account.
|
|
|
|
|
>>>>>>> a2164297 (snip)
|
|
|
|
|
|
2024-05-27 23:08:08 +00:00
|
|
|
|
Multi-threaded builds
|
|
|
|
|
=====================
|
|
|
|
|
|
|
|
|
|
Canoeboot's build system defaults to a single build thread, but you can change
|
|
|
|
|
it by doing e.g.
|
|
|
|
|
|
|
|
|
|
export XBMK_THREADS=4
|
|
|
|
|
|
|
|
|
|
This would make cbmk run on 4 threads.
|
|
|
|
|
|
|
|
|
|
More specifically: when compiling source trees via `script/trees`, `-jTHREADS`
|
|
|
|
|
is passed, where THREADS is the number of threads. This is also set when running
|
|
|
|
|
xz commands for compression, using the `-t` option.
|
|
|
|
|
|
2024-05-01 04:53:28 +00:00
|
|
|
|
Environmental variables
|
|
|
|
|
=======================
|
|
|
|
|
|
|
|
|
|
Please read about environmental variables in [the build
|
|
|
|
|
instructions](../maintain/), before running cbmk. You should set
|
|
|
|
|
your variables accordingly, though you do not technically need to; some
|
2024-05-27 23:08:08 +00:00
|
|
|
|
of them may be useful, e.g. `XBMK_THREADS` (sets the number of build threads).
|
2024-05-01 04:53:28 +00:00
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
Introduction
|
|
|
|
|
============
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
Please read about environmental variables in [the build
|
|
|
|
|
instructions](../maintain/), before running lbmk. You should set
|
|
|
|
|
your variables accordingly, though you do not technically need to; some
|
|
|
|
|
of them may be useful, e.g. `XBMK_THREADS` (sets the number of build threads).
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
|
|
Git
|
|
|
|
|
===
|
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
Система побудови Canoeboot використовує Git, обширно. Ви маєте виконати кроки
|
2023-07-10 15:43:08 +00:00
|
|
|
|
знизу, *навіть, якщо ви використовуєте архів випуску*.
|
|
|
|
|
|
|
|
|
|
Перед тим, як вам використовувати систему побудови, будь ласка, знайте: система побудови, сама по собі,
|
|
|
|
|
використовує Git обширно, коли завантажує програмне забезпечення, таке як coreboot, та проводить застосування виправлень.
|
|
|
|
|
|
|
|
|
|
Ви маєте переконатись в тому, щоб ініціалізувати ваш Git належним чином, перед тим, як почати, або інакше
|
|
|
|
|
система побудови не буде працювати належно. Зробіть це:
|
|
|
|
|
|
|
|
|
|
git config --global user.name "John Doe"
|
|
|
|
|
git config --global user.email johndoe@example.com
|
|
|
|
|
|
|
|
|
|
Змініть ім'я та адресу електронної пошти на будь-яку, що забажаєте, коли робите це.
|
|
|
|
|
|
|
|
|
|
Ви також можете захотіти прослідувати більшій кількості етапів тут:
|
|
|
|
|
<https://git-scm.com/book/en/v2/Getting-Started-First-Time-Git-Setup>
|
|
|
|
|
|
|
|
|
|
Python
|
|
|
|
|
======
|
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
Python2 не використовується cbmk або будь-чим, що завантажується в якості модулів. Ви
|
2023-07-10 15:43:08 +00:00
|
|
|
|
маєте переконатись, що команда `python` виконує python 3 на вашій системі.
|
|
|
|
|
|
2024-01-25 19:50:24 +00:00
|
|
|
|
Zero..st, check time/date
|
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
|
|
Make sure date/hwclock report the correct time and date on your system,
|
|
|
|
|
because parts of the build process download from HTTPS servers and wrong
|
|
|
|
|
time or date can cause connections to be dropped during negotiation.
|
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
Побудова з джерельного коду
|
2023-07-10 15:43:08 +00:00
|
|
|
|
============================
|
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
Фактична розробка/тестування завжди виконується безпосередньо за допомогою `cbmk`, і це також
|
2023-07-10 15:43:08 +00:00
|
|
|
|
стосується збирання з джерельного коду. Ось кілька інструкцій, щоб
|
|
|
|
|
почати:
|
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
canoeboot включає сценарій, який автоматично встановлює apt-get залежності
|
2023-07-10 15:43:08 +00:00
|
|
|
|
в Ubuntu 20.04:
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
sudo ./mk dependencies ubuntu2004
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
|
|
Окремі сценарії також існують:
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
sudo ./mk dependencies debian
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
sudo ./mk dependencies arch
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
sudo ./mk dependencies void
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
Check: `config/dependencies/` for list of supported distros.
|
|
|
|
|
|
|
|
|
|
Технічно, будь-який дистрибутив Linux може бути використано для побудови canoeboot.
|
2023-07-10 15:43:08 +00:00
|
|
|
|
Однак, вам потрібно буде написано свій власний сценарій для встановлення залежностей
|
|
|
|
|
побудови.
|
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
|
Canoeboot Make (cbmk) автоматично виконує всі необхідні команди; наприклад,
|
|
|
|
|
`./build roms` автоматично виконає `./build grub`,
|
2023-07-10 15:43:08 +00:00
|
|
|
|
якщо затребувані утиліти для GRUB не збудовано, для виготовлення корисних навантажень.
|
|
|
|
|
|
|
|
|
|
В якості результату, ви тепер можете (після встановлення правильних залежностей побудови) виконати
|
|
|
|
|
лише одну команду, з свіжого Git clone, для побудови образів ROM:
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
./mk -b coreboot
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
|
|
або навіть побудувати конкретні образи ROM, такі як:
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
./mk -b coreboot x60
|
2023-10-26 00:10:41 +00:00
|
|
|
|
|
|
|
|
|
or get a list of supported build targets:
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
./mk -b coreboot list
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
|
|
Якщо ви бажаєте побудувати корисні навантаження, можете зробити це. Наприклад:
|
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
./mk -b grub
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
./mk -b seabios
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
2024-08-23 00:28:08 +00:00
|
|
|
|
./mk -b u-boot
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
|
|
Попередні кроки буде виконано автоматично. Однак, ви можете *досі* виконати
|
|
|
|
|
окремі частини системи побудови власноруч, якщо виберете. Це може бути
|
|
|
|
|
вигідно, коли ви робите зміни, та бажаєте протестувати конкретну частину
|
2023-10-26 00:10:41 +00:00
|
|
|
|
cbmk.
|