16.05.2018 PetaLinux
Lipa (обсуждение | вклад) (→Single On-board eth) |
Lipa (обсуждение | вклад) (→Single On-board eth) |
||
Строка 682: | Строка 682: | ||
В Vivado включен eth0(с mdio) и выключен eth1. | В Vivado включен eth0(с mdio) и выключен eth1. | ||
+ | <source lang="bash"> | ||
+ | &gem0{ | ||
+ | status = "okay"; | ||
+ | phy-handle = <&phy0>; | ||
+ | phy-mode = "rgmii-id"; | ||
+ | |||
+ | xlnx,eth-mode = <0x1>; | ||
+ | |||
+ | mdio { | ||
+ | status = "okay"; | ||
+ | #address-cells = <1>; | ||
+ | #size-cells = <0>; | ||
+ | phy0: phy@0 { | ||
+ | compatible = "ethernet-phy-ieee802.3-c22"; | ||
+ | device_type = "ethernet-phy"; | ||
+ | |||
+ | reg = <0>; | ||
+ | ti,rx-internal-delay = <0x8>; | ||
+ | ti,tx-internal-delay = <0xa>; | ||
+ | ti,fifo-depth = <0x01>; | ||
+ | ti,min-output-impedance; | ||
+ | ti,dp83867-rxctrl-strap-quirk; | ||
+ | status = "okay"; | ||
+ | }; | ||
+ | }; | ||
+ | }; | ||
+ | </source> | ||
=== Dual eth === | === Dual eth === |
Версия 11:12, 5 июня 2018
Содержание |
Требования
Vivado 2018.1 (для single-gigabit ethernet можно более ранние версии)
Необходима Ubuntu-16.04
Требуется поставить ряд пакетов, полный список приведен в документе UG1144
Устанавливаем PetaLinux в систему. Дистрибутив есть на Xilinx, либо у меня на компьютере. Ставить PetaLinux необходимо БЕЗ прав суперюзера!
Подготовка завершена
Правка Vivado
Для поддержки MDIO в Vivado 17.1-17.4 нужен патч. Ставим!
Не помогло. Ставим 2018.1
Сборка
Пошаговое руководство по сборке содержится в документе UG1156
В консоли пишем source/[путь к петалинух]/settings.sh
Выполняем шаги из UG1156 по главе 5:
- экспортируем из Vivado .hdf (в блок дизайн File->Export->Export Hardware)
- создаем проект PetaLinux
- переходим в папку с текущим проектом
- подключаем файл .hdf
- перед сборкой системы необходимо выполнить все команды конфигурации в данной последовательности:
$ petalinux-config -c kernel
$ petalinux-config -c rootfs
petalinux-config
Если хотим спользовать внешний файл device-tree включаем:
Advances bootable images storage settings->
dtb image settings->
image storage media
primary sd
Необходимо править netboot offset если оперативной памяти менее ~256МБ
netboot offset
Выставляем точку начала распаковки образа системы
petalinux-config -c kernel
- Подключаем в ядре поддержку физика и его дров.
[*]Network device support ->
[*]Ethernet driver support ->
[*] Micrel devices
[*] PHY Device support and infastructure -->
[*] Drivers for Micrel PHYs
- далее (сборка идет 30-60 минут)
- делаем boot.bin
- записываем в загрузочную область флешки файлы boot.bin и image.ub
Всякое
Если мало памяти как у нас - возможна ошибка image is not a fdt ссылка
Необходимо править netboot offset
netboot offset
Можно вручную загрузиться из u-boot'а.
$ bootm 0x8000000
либо
$ fatload mmc 0 0x7000000 system.dtb
$ bootm 0x8000000 0x8000000 0x7000000
Можно поварьировать адрес
Проверка статуса прошитости FPGA
device tree
Для внесения изменений в device tree добавляем нужные строки в файл
project-spec/meta-user/recipes-bsp/device-tree/files/system-user.dtsi
Для разборки device-tree ссылка
Для сборки device-tree
Модификация device-tree
После долгих мучений получилось поднять DP83867 только после добавления модификатора в файл волшебная статья
project-spec/meta-user/recipes-bsp/device-tree/files/system-user.dtsi
Single Kit-board eth
В Vivado включен eth1(с mdio) и выключен eth0.
status = "okay";
phy-handle = <&phy0>;
phy-mode = "rgmii-id";
xlnx,eth-mode = <0x1>;
mdio {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;
phy0: phy@12 {
compatible = "ethernet-phy-ieee802.3-c22";
device_type = "ethernet-phy";
reg = <12>;
ti,rx-internal-delay = <0x8>;
ti,tx-internal-delay = <0xa>;
ti,fifo-depth = <0x01>;
ti,min-output-impedance;
ti,dp83867-rxctrl-strap-quirk;
status = "okay";
};
};
};
Single On-board eth
В Vivado включен eth0(с mdio) и выключен eth1.
status = "okay";
phy-handle = <&phy0>;
phy-mode = "rgmii-id";
xlnx,eth-mode = <0x1>;
mdio {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;
phy0: phy@0 {
compatible = "ethernet-phy-ieee802.3-c22";
device_type = "ethernet-phy";
reg = <0>;
ti,rx-internal-delay = <0x8>;
ti,tx-internal-delay = <0xa>;
ti,fifo-depth = <0x01>;
ti,min-output-impedance;
ti,dp83867-rxctrl-strap-quirk;
status = "okay";
};
};
};
Dual eth
Попытка поднять два физика. Пока не работает
local-mac-address = [00 0a 35 00 00 00];
enet-reset = <&gpio0 47 0>;
status = "okay";
phy-handle = <&phy0>;
phy-mode = "rgmii-id";
xlnx,eth-mode = <0x1>;
mdio {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;
phy0: phy@0 {
compatible = "ethernet-phy-ieee802.3-c22";
device_type = "ethernet-phy";
reg = <0>;
ti,rx-internal-delay = <0x8>;
ti,tx-internal-delay = <0xa>;
ti,fifo-depth = <0x01>;
ti,min-output-impedance;
ti,dp83867-rxctrl-strap-quirk;
status = "okay";
};
phy1: phy@12 {
compatible = "ethernet-phy-ieee802.3-c22";
device_type = "ethernet-phy";
reg = <12>;
ti,rx-internal-delay = <0x8>;
ti,tx-internal-delay = <0xa>;
ti,fifo-depth = <0x01>;
ti,min-output-impedance;
ti,dp83867-rxctrl-strap-quirk;
status = "okay";
};
};
};
&gem1{
local-mac-address = [00 0a 35 00 00 01];
enet-reset = <&gpio0 47 0>;
status = "okay";
phy-handle = <&phy1>;
phy-mode = "rgmii-id";
xlnx,eth-mode = <0x1>;
};
[ Хронологический вид ]Комментарии
Войдите, чтобы комментировать.