From a2034926f8609de02980abe45d57e524b94bad56 Mon Sep 17 00:00:00 2001 From: Egor Tsyganchuk Date: Tue, 17 Feb 2026 08:17:21 +0300 Subject: [PATCH] Add README with project documentation for ARM uClinux FDPIC cross-compiler toolchain --- README.md | 118 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 118 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..9ce60a8 --- /dev/null +++ b/README.md @@ -0,0 +1,118 @@ +# Build Toolchain — кросс-компилятор для ARM uClinux FDPIC + +Набор скриптов для сборки кросс-компилятора под целевую платформу **ARM uClinux FDPIC (Thumb, ARMv7-m)**. + +Целевой триплет: `arm-uclinuxfdpiceabi` + +## Состав тулчейна + +| Компонент | Версия | Назначение | +|-----------------|----------|-------------------------------------| +| Binutils | 2.42 | Ассемблер, линковщик, утилиты | +| GCC | 13.4.0 | Компилятор C/C++ | +| Linux (headers) | 4.9.224 | Заголовочные файлы ядра | +| uClibc-ng | 1.0.55 | Стандартная библиотека C | + +### Дополнительные библиотеки + +| Библиотека | Версия | Назначение | +|--------------|--------|---------------------------| +| zlib | 1.2.13 | Сжатие данных | +| OpenSSL | 3.0.13 | Криптография | +| LibVNCServer | 0.9.14 | VNC-сервер | +| FreeType | 2.13.2 | Рендеринг шрифтов | + +Все библиотеки собираются статически. + +## Характеристики целевой платформы + +- **Архитектура:** ARM 32-bit (ARMv7-m) +- **Набор инструкций:** Thumb +- **ABI:** EABI с поддержкой FDPIC +- **Плавающая точка:** программная (soft float) +- **Потоки:** отключены +- **TLS:** отключён + +## Зависимости хостовой системы + +- bash +- make +- gcc (или другой C-компилятор для хоста) +- cmake +- wget +- tar +- стандартные утилиты (grep, sed и т.д.) + +## Использование + +### 1. Загрузка исходников + +```bash +./download_prerequisites.sh +``` + +Скрипт загружает архивы исходного кода всех компонентов в каталоги `src/toolchain/` и `src/libs/`. Уже загруженные архивы пропускаются. + +### 2. Сборка тулчейна + +```bash +./build-toolchain.sh +``` + +Сборка выполняется поэтапно: + +1. Распаковка архивов +2. Сборка Binutils +3. Сборка GCC (этап 1 — минимальный компилятор C без libc) +4. Установка заголовочных файлов ядра Linux +5. Сборка uClibc-ng +6. Сборка GCC (этап 2 — полный компилятор C/C++ с поддержкой FDPIC) +7. Сборка дополнительных библиотек +8. Упаковка результата в архив + +На выходе создаётся архив `toolset-jlv-armv7-m-gcc13.4.0-uclibc1.0.55.tar.xz`. + +### 3. Настройка окружения + +Активация переменных окружения для работы с тулчейном: + +```bash +source ./env.sh --register /путь/к/install/bin +``` + +Скрипт устанавливает переменные `CC`, `CXX`, `LD`, `AR`, `RANLIB`, `STRIP`, `CFLAGS`, `LDFLAGS`, `SYSROOT` и добавляет путь к тулчейну в `PATH`. + +Деактивация: + +```bash +source ./env.sh --unregister +``` + +## Флаги компиляции + +| Переменная | Значение | Назначение | +|------------|----------|------------| +| `CFLAGS` | `-Os -mthumb` | Оптимизация по размеру, Thumb-инструкции | +| `LDFLAGS` | `-Wl,--fdpic` | Линковка с поддержкой FDPIC | + +## Структура каталогов + +``` +build-toolchain/ +├── build-toolchain.sh # Основной скрипт сборки +├── build-libraries.sh # Сборка дополнительных библиотек +├── download_prerequisites.sh # Загрузка исходников +├── env.sh # Настройка окружения +├── config/ # Конфигурации uClibc +│ ├── config-uClibc-ng-1.0.34 +│ └── config-uClibc-ng-1.0.55 +├── src/ # Исходный код (после загрузки) +│ ├── toolchain/ # Архивы компонентов тулчейна +│ └── libs/ # Архивы библиотек +├── build/ # Каталог сборки (создаётся автоматически) +└── install/ # Каталог установки (создаётся автоматически) +``` + +## Лицензия + +Компоненты тулчейна распространяются под собственными лицензиями (GPL, LGPL и др.).