Кто-нибудь знает способ установить версию U-boot из пользовательского пространства? Существует команда fw_printenv, которая обеспечивает доступ к переменным среды U-boot, но не та версия.
Получение версии U-boot из пользовательского пространства
Ответы (8)
Нет определенного способа сделать это. После загрузки Linux u-boot больше не работает, и его оперативная память освобождается для использования Linux. Linux даже не знает о u-boot. И при этом он не должен быть загружен u-boot.
Если вы действительно хотите это сделать, единственный способ сделать это — добавить версию u-boot в командную строку ядра, написать код для сканирования образа u-boot во флэш-памяти на предмет его версии или что-то еще более неприятное.
Если U-boot находится в mtd0, вы можете получить информацию о версии следующим образом:
root@SUPERWIFI:/proc# strings /dev/mtd0 | grep U-Boot
U-Boot 1.1.4-g1c8343c8-dirty (Feb 28 2014 - 13:56:54)
U-Boot
Now running in RAM - U-Boot at: %08lx
альтернативное решение — прочитать версию непосредственно из u-boot. двоичный файл (может быть даже встроен в файл изображения, содержащий другие двоичные файлы, а также, например, загрузчик первого этапа) с, например. mmcblk0boot0 как раздел (устройства mmcblk0), в котором находится загрузчик:
sudo grep -a --null-data U-Boot /dev/mmcblk0boot0
Примечание к сайту: работает не только для Arch Linux, но, например. Убунту тоже.
Как раз обновление для этого. В нашей версии U-Boot мы изменили код main_loop() в main.c на этот:
#ifdef CONFIG_VERSION_VARIABLE
char *oldver=getenv("ver");
if(oldver==0 ||strcmp(oldver,version_string))
{
setenv("ver", version_string); /* set version variable */
saveenv();
}
#endif /* CONFIG_VERSION_VARIABLE */
Таким образом, setenv/saveenv вызывается только при необходимости обновления. В нашей прошивке мы добавили
/sbin/fw_printenv -n ver > /var/config/u-boot.ver
чтобы сделать общедоступной версию u-boot.
В моих устройствах UBoot автоматически создает переменную среды "ver", содержащую его версию:
U-Boot > printenv
baudrate=115200
ethact=FEC ETHERNET
ethaddr=24-db-ad-00-00-08
bootdelay=3
bootcmd=bootm fc080000 - fc060000
bootargs=console=ttyCPM0,115200n8 rdinit=/sbin/init
stdin=serial
stdout=serial
stderr=serial
ver=U-Boot 2009.03-svn9684 (Mar 08 2010 - 17:08:32)
Environment size: 253/131068 bytes
U-Boot >
Я не использую fw_printenv, но могу предположить, что эта переменная тоже передается. Может быть, у вас уже есть что-то подобное в вашей системе?
ОБНОВЛЕНИЕ (23.05.2012): я добавил fw_printenv в свой образ Linux и могу подтвердить, что вижу переменную «ver»:
[root@ST600 /]# fw_printenv
baudrate=115200
ethact=FEC ETHERNET
ethaddr=24-db-ad-00-00-08
stdin=serial
stdout=serial
stderr=serial
ver=U-Boot 2009.03-svn9684 (Mar 11 2010 - 09:43:08)
bootcmd=bootm fc080000 - fc060000
bootdelay=3
bootargs=console=ttyCPM0,115200n8 rdinit=/sbin/init panic=10 mem=32m
[root@ST600 /]#
CONFIG_VERSION_VARIABLE=y, чтобы ver отображалось в среде.
- person remcycles; 07.07.2018
Попробуйте прочитать версию uboot следующим образом:
Найдите раздел uboot, например. для устройства МПД:
кот /прок/мтд
Для /dev/mtd5:
кот /dev/mtd5 | шестнадцатеричный дамп -C -n 64
Вы не можете полагаться на fw_printenv, если хотите узнать версию u-boot.
fw_printenv просто ищет раздел printenv и выгружает его данные. Таким образом, это нормально для обычных переменных, но не подходит для переменной «ver», которая является динамической и значение которой инициализируется u-boot при загрузке. Значение этой переменной не сохраняется после выхода из u-boot, кроме случаев, когда вы вручную сохраняете его в среду.
Например, на моей плате, если я напечатаю переменную «ver» из приглашения u-boot:
U-Boot > printenv ver
ver=U-Boot 2009.11-00393-g5ca9497-dirty (Nov 26 2012 - 11:08:44)
Это настоящая версия u-boot, исходящая от самого u-boot.
Теперь, если я загружу свою плату и использую fw_printenv:
el@board # fw_printenv | grep ver=
ver=U-Boot 2009.11-00323-gbcc6e0e (Sep 21 2012 - 11:07:19)
Как видите, это другое. Потому что у меня есть переменная "ver", определенная в моей среде. И это не соответствует реальной версии u-boot.
Конечно, я мог бы вернуться к u-boot, использовать «saveenv», чтобы обновить значение «ver» в среде. Тогда эти два значения совпадут. Но тогда я всегда должен обновлять среду после изменения u-boot.
Итак, я пришел к выводу, что использование fw_printenv для получения версии u-boot определенно не очень хорошая идея.
Если u-boot находится в разделе MTD, это будет работать:
U_BOOT_VER=$(for part in `grep u-boot-[01] /proc/mtd | cut -f 1 -d ':'`; do strings /dev/${part} | grep "^U-Boot.*("; break; done)