====== Компиляция загрузчиков для SBC-9263 и SBC-9263i ======
//Данное руководство в основном применимо ко всем платам, основанным на процессорном модуле **SBC-9263** и **SBC-9263i**//
//Данное руководство проверено в дистрибутиве **Fedora Core 7**, **Fedora Core 11**, **Ubuntu 9.04**//
//Сборка файловой системы проверена на Ubuntu 8.10 без загрузки на платформу//
===== Необходимые утилиты =====
Для компиляции Bootstrap, u-boot и ядра Linux требуется кросс-компилятор GNU GCC. Процедуры установки GNU GCC описаны [[arm-gcc|здесь]].
===== Последовательность старта процессора =====
При подаче питания на процессор он вначале ищет таблицу прерываний в различных источниках: Dataflash, NOR, NAND. Таблица прерываний содержится в bootstrap, это загрузчик первого уровня (хотя, более корректно загрузчиком первого уровня считать BOOT-ROM процессора, т.к. именно он выполняет первичную инициализацию процессора). Как только bootstrap загружен он выполняет инициализацию SDRAM и загружает загрузчик второго уровня **u-boot** из Dataflash или NAND в SDRAM. u-boot уже имеет весь необходимый функционал и командную строку, чтобы выполнять любые действия с периферией и загружать ядро Linux.
===== Компиляция Bootstrap =====
* Исходные коды Bootstrap скачивают со страницы [[http://atmel.com/dyn/products/product_card.asp?part_id=4093]].\\
Проверено в версии Bootstrap'а - 1.16.
* Bootstrap распаковывают в любую директорию, например, домашнюю для вашего пользователя:
unzip AT91Bootstrap1.16.zip
* Скачайте патч для SBC-9263, который меняет настройки PLL для кварца 16.0 МГЦ, установленного на модуле.
[[http://www.mentorel.com/downloads/sbc-9263/bstrap-1.16.patch]]
* Войдите в директорию Bootstrap-v1.16 и примените [[http://www.mentorel.com/downloads/sbc-9263/bstrap-1.16.patch|патч]] для процессорного модуля:
patch -p1 < bstrap-1.16.patch
==== для Dataflash ====
* Затем перейдите в директорию Bootstrap-v1.16/board/at91sam9263ek/dataflash/ и наберите команду:
make CROSS_COMPILE=/путь к копилятору/arm-2008q1/bin/arm-none-linux-gnueabi-
* Файл dataflash_at91sam9263ek.bin необходимо записать в Dataflash на плату с помощью утилиты SAM-BA.
//Примечание: для модулей с разным объемом SDRAM необходимо изменить значение **JUMP_ADDR** в файле "board/at91sam9263ek/dataflash/at91sam9263ek.h" в соответствии с таблицей: (см. примечание для u-boot)//
| Переменная ^ SDRAM 32M ^ SDRAM 64M ^
^JUMP_ADDR|0x21f00000|0x23f00000|
Это необходимо для корректного расположения образа u-boot в верхних адресах SDRAM.
==== для NOR-flash ====
* Перейдите в директорию Bootstrap-v1.14/board/at91sam9263ek/norflash/ и наберите команду:
make CROSS_COMPILE=/путь к копилятору/arm-2008q1/bin/arm-none-linux-gnueabi-
* Файл norflash_at91sam9263ek.bin необходимо записать в Spansion NOR с помощью утилиты SAM-BA по нулевому смещению для NOR флеш.
//Примечание: для модулей с разным объемом SDRAM необходимо изменить значение **JUMP_ADDR** в файле "board/at91sam9263ek/dataflash/at91sam9263ek.h" в соответствии с таблицей: (см. примечание для u-boot)//
| Переменная ^ SDRAM 32M ^ SDRAM 64M ^
^JUMP_ADDR|0x21f00000|0x23f00000|
Это необходимо для корректного расположения образа u-boot в верхних адресах SDRAM.
===== Компиляция u-boot =====
* Скачайте исходные коды u-boot-1.3.4 [[http://www.mentorel.com/downloads/sbc-9263/u-boot-at91-cd82919e6c8a73b363a26f34b734923844e52d1c.tar.gz]]
* Распакуйте u-boot и войдите в директорию u-boot-at91
* Скачайте патч [[ftp://www.at91.com/pub/uboot/u-boot-1.3.4-exp.4/u-boot-1.3.4-exp.4.diff|u-boot-1.3.4-exp.4.diff]] и примените его к u-boot:
cat u-boot-1.3.4-exp.4.diff | patch -p1
* Для SBC-9263(i) скачайте патч [[http://www.mentorel.com/downloads/sbc-9263/uboot1p3p4.patch|uboot1p3p4.patch]] и примените его к u-boot:
patch -p1 < uboot1p3p4.patch
Далее необходимо выбрать где будут хранится переменные окружения:
==== Env в Dataflash ====
make at91sam9263ek_dataflash_config
==== Env в Nandflash ====
make at91sam9263ek_nandflash_config
==== Env в Norflash ====
make at91sam9263ek_norflash_config
* Компиляция кода
make CROSS_COMPILE=/путь к копилятору/arm-2008q1/bin/arm-none-linux-gnueabi-
* Полученный файл uboot.bin необходимо записать в Dataflash/Nandflash/Norflash на плату с помощью утилиты [[SAM-BA]].
//Примечание: для модулей с разным объемом SDRAM необходимы измения в соответствии с таблицей://
| Переменная ^ SDRAM 32M ^ SDRAM 64M ^ имя файла ^
^TEXT_BASE |0x21f00000|0x23f00000|board/atmel/at91sam9263ek/config.mk |
^PHYS_SDRAM_SIZE |0x02000000|0x04000000|include/configs/at91sam9263ek.h |
^CFG_LOAD_ADDR |0x21000000|0x22000000|include/configs/at91sam9263ek.h |
===== Пресобранные образы bootstrap и u-boot =====
| ^ SDRAM 32M ^ SDRAM 64M ^
^NOR-flash Bootstrap 1.16|[[http://mentorel.com/downloads/sbc-9263/norflash_at91sam9263ek.bin|norflash_at91sam9263ek.bin]]|[[http://mentorel.com/downloads/sbc-9263/norflash_at91sam9263ek.bin|norflash_at91sam9263ek.bin]]|
^Dataflash Bootstrap 1.11|[[http://mentorel.com/downloads/sbc-9263/dataflash_at91sam9263ek_32M.zip|dataflash_at91sam9263ek.bin]]|[[http://mentorel.com/downloads/dataflash_at91sam9263ek_64M.zip|dataflash_at91sam9263ek.bin]]|
^SBC-9263 u-boot 1.3.4|[[http://mentorel.com/downloads/sbc-9263/u-boot1p3p4_32M.zip|u-boot1p3p4.bin]]|[[http://mentorel.com/downloads/sbc-9263/u-boot1p3p4_64M.zip|u-boot1p3p4.bin]]|
^SBC-9263i u-boot 1.3.4||[[http://mentorel.ru/downloads/sbc-9263/uboot1p3p4_i.zip|u-boot1p3p4_i.bin]]|
===== Компиляция ядра Linux Embedded =====
Компиляция ядра выполняется с помощью скрипта, процесс описан в пункте [[#Сборка файловой системы]]\\
//Примечание: Ядро одинаковое для обоих модулей SBC-9263 и SBC-9263i//
Запись ядра в NOR флеш модуля SBC-9263 выполняют следующими командами:
U-Boot> tftp 22000000 uImage
U-Boot> erase 1:0-16
U-Boot> cp.b 22000000 10000000
Старт ядра с NOR флеш выполняют со следующими значениями переменных окружения U-Boot:\\
U-Boot> setenv bootcmd cp.b 10000000 22000000 <размер в байтах> \; bootm 22000000
===== Пресобранные ядра версии 2.6.27 для разных TFT дисплеев =====
| Тип экрана ^ Адрес ^
^ ME-TFT37SH | [[http://mentorel.com/downloads/sbc-9263/ui27-sh37.zip]] |
^ ME-TFT8OSD | [[http://mentorel.com/downloads/sbc-9263/ui27-8osd.zip]] |
^ ME-MTF7TTS | [[http://mentorel.ru/downloads/sbc-9263/ui27-7mtf.zip]] |
^ ME-TFT8SHCFL | [[http://mentorel.com/downloads/sbc-9263/ui27-8shcfl.zip]] |
===== Сборка файловой системы =====
В этом разделе описана процедура сборки минимальной конфигурации файловой системы с работой через консоль без графической оболочки.
Процедура проверена в дистрибутиве:
* Fedora Core 7
* Fedora Core 11
1) Для компиляции требуется установит кросс-компилятор от CodeSourcery, процедура описана здесь: [[arm-gcc|arm-gcc]]
2) Скачивают [[http://www.mentorel.ru/downloads/sbc-9263/me_rootfs.tar.bz2|архив]], содержащий набор скриптов для сборки файловой системы.
Архив распаковывают в домашнюю директорию пользователя.
3) Далее необходимо настроить переменные окружения для сборочных скриптов.
Переменные окружения находятся в файле build.sh:
* TOOLCHAIN_DIR\\
это путь к директории, в которой находится компилятор и его библиотеки. Например, ''/opt/arm-2008q1''
* TARGET_NAME\\
Для компилятора 2008q1-126 для ARM GNU/Linux это значение всегда arm-none-linux-gnueabi, т.е. TARGET_NAME=arm-none-linux-gnueabi
* LINUX_KERNEL_VER
Это значение может быть может содержать либо только основную версию ядра 2.6: 25, 26, 27, 28, либо основную + дробную: 25.10, 26.8 и т.п.
//примечание: данный скрипт проверен на ядре 2.6.25 и 2.6.25.10. Для ядра другой версии может потребоваться доработка.//
* LINUX_PATCH_VER
Эта переменая должна содержать только номер основной версии ядра 2.6: 25, 26, 27, 28, 29, потому как патчи делают для основной версии и они подходят к дробным.
4) Запуск компиляции файловой системы
Для компиляции файловой системы необходимы права суперпользователя (root), т.к. в процессе сборки создается статическое дерево устройств (/dev/xxx). Для удобства компиляции устанавливают пакет sudoers в линукс и разрешают в нем применение команд с правами суперпользователя для вашего пользователя.
Выполняют команду:
sudo ./build.sh
выполнение которой занимает порядка нескольких минут на процессоре Intel Core 2 Duo.
После завершения работы скрипта вам доступно дерево файловой системы в директории "target". Эту директорию можно либо сделать доступной по NFS, для загрузки на целевую платформу, либо из нее создать образ файловой системы JFFS2.
* Чтобы добавить директорию файловой системы в NFS, добавляют следующую строку в файл "/etc/exports":
FULL_PATH/target *(rw, sync, no_root_squash)
//Примечание: NFS не допускает применение символьных ссылок//
* Чтобы создать образ JFFS2 для загрузки в NOR выполняют следующую команду:
mkfs.jffs2 --root=YOUR_DIR --eraseblock=0x20000 -m none -o your_image.jffs2
Для NAND флеш также может понадобится опция "-n".
===== Загрузка файловой системы на платформу =====
Инструкции как выполнять загрузку ПО на платформу вы найдете [[sam-ba|здесь]].
Для модуля SBC-9263 ядро имеет следующую таблицу разделов для NOR-флеш:\\
0x10000000 - 0x10400000 - пространство для хранения ядра\\
0x10400000 - 0x40000000 - пространство для файловой системы
Чтобы загрузить файловую систему в NOR-флеш модуля SBC-9263 выполняют следующие команды:\\
U-Boot> erase 1:32-320 (эта команды полностью стирает флеш по адресам 0x10400000 - 0x40000000)\\
U-Boot> tftp 21000000 rootfs.jffs2\\
U-Boot> cp.b 21000000 10400000
Ядру Linux необходимо сообщить с какого раздела вы будете выполнять загрузку. Для этого в окружении u-boot определяют значение переменной bootargs следующего содержания:
U-Boot> setenv bootargs console=ttyS0,115200 root=/dev/mtdblock1 rw rootfstype=jffs2