Добрый день!
Собственно проблема:
Есть DE0-Nano-SoC, есть задача собрать свое ядро под нее. При этом нужно чтоб там были SPI, I2C, FPGA-manager, Ethernet.
Если взять собранное 3.13 ядро от терасика - то все отлично работает, интерфейсы есть, fpga-mngr позволяет перезаливать прошивку FPGA, сеть есть, все хорошо.
Но, как только начинаю собирать собственное ядро происходит магия. Под одной версией ядра (4.1_15.09.01) работает fpga_mngr, но не работает spi и сеть, под 4.4 работает сеть, но нет ни менеджера, ни spi, под более высокими версиями примерно то же самое.
При этом под нерабочим spi я подразумеваю что он создается как устройство spidev31765.1, но принимать данные упорно не хочет. Да и номер "31765" очень смущает.
(spidev31765.1 появляется если использовать драйвер "snps,dw-spi-mmio", если указывать "snps,dw-apb-ssi", как это делают в socfpga.dtsi, в исходниках ядра - то вообще устройство исчезает, нет ни в /sys/class, ни в /sys/devices)
FPGA_mngr под версиями старше 4.1 попросту исчезает из /dev. Хотя /sys/class есть директория fpga0.
Если собирать вручную ядро 3.13, как у терасика, то все что нужно появляется, но ядро стартует только с прелоадером терасика. Если генерить через bsp-editor или bsp-create-settings - то ядро попросту не стартует после загрузки u-boot.
Ядра из ветки linux-socfpga, для сборки брал конфиги из "socfpga_defconfog" + добавлял поддержку блочных устройств +2Tb для работы ext4.
прелоадер и бутлоадер собирал как описано на rocketboards:
https://rocketboards.org/foswiki/view/Docum...xBeginnerSGuide
https://rocketboards.org/foswiki/view/Docum...CWorkshopSeries
Ни у кого не возникало таких проблем?
на хабре как-то была статья про исчезновения fpga-mngr https://habrahabr.ru/post/267273/, но лично у меня он в исходниках присутствует