Я использую uboot и добавляю в него команду tftpboot. Но это не работает, хотя может передавать данные, всегда есть тайм-аут во время всей передачи. Консоль показывает так
Моя топология Ethernet: плата с uboot подключается к моему маршрутизатору, а мой компьютер подключается к маршрутизатору. И мой tftp-сервер находится на моей виртуальной машине Linux на моем ПК, и виртуальная машина использует режим моста для подключения к Ethernet
Конечно, я пытался подключить плату напрямую к ПК, но проблема осталась.
Я изменил строку 433 dm9000x.c, измените
tmo = get_timer(0) + 5 * CONFIG_SYS_HZ; //
в
tmo = get_timer(0) + 200; //timeout 200 miliiseconds
Время перевода теперь терпимо. Но это все еще много времени ожидания передачи, журналы показывают ниже
dm9000 i/o: 0x88000000, id: 0x90000a46
DM9000: running in 16 bit mode
MAC: 1a:2a:3a:4a:5a:6a
operating at 100M full duplex mode
Using dm9000 device
TFTP from server 192.168.0.15; our IP address is 192.168.0.12
Filename '/linux-3.14.24/fs/yaffs2/ubifs.img'.
Load address: 0x20000000
Loading: ################################################################transmission timeout
#
####transmission timeout
#############################################################
####################transmission timeout
##########transmission timeout
################transmission timeout
##################transmission timeout
#
#################################################################
#################################################################
#############################################################transmission timeout
####
#####################transmission timeout
######################transmission timeout
######################
#################################################################
###############################################################transmission timeout
##
##################################transmission timeout
#######transmission timeout
########################
#################################################################
#################################################################
#################################################################
###################transmission timeout
###################
61.5 KiB/s
done
Bytes transferred = 4515840 (44e800 hex)
4515840 bytes written to volume rootfs
Я до сих пор не знаю, почему, потому что он действительно может передавать данные. Так есть какие-нибудь идеи по этому поводу?