вторник, 15 октября 2013 г.

RK3066 TV box. Тонкости прошивки update.img

Во время работ по "подпиливанию" прошивок для устройства столкнулся с небольшой проблемой: после каких-то определеннйх изменений очередной подготовленный update.img воспринимался девайсом "в штыки", со словами
 
Invalid firmware image!
Found a invalid firmware image file '/sdcard/update.img'.
Would you like to delete it?

Yes/No
 
В тоже время тот же образ легко прошивался в recovery-mode, т.е. образ был вполне пригоден. Начал вспоминать, что менял. А менял довольно многое. Подумалось, что здесь играют роль какие-то свойства самой прошивки, а не того, что у нее внутри. Поискал в интернете. Русскоязычный - порадовал богатством ответов типа "а вас предупреждали, что шится на кастом можно только через USB" или что-то типа того, вплоть до перехода на личности (а что делать мне, если нету у меня в девайсе USB OTG!?), но ни одного толкового, в котором бы упоминалось почему это происходит. Впрочем, это не удивительно - основная масса отечественных "клепателей прошивок" не любят читать мануалы, а те немногие, которые их читают - не спешат раскрывать свои знания. Что вполне логично.
Вцелом, было стойкое подозрение, что данная проблема как-то связана с несоответствием пропертей загруженного андроида и прошивки. В прошивку вкладывается файл parameter, в котором, среди прочего есть параметры

MACHINE_MODEL
MANUFACTURER

Был предпринят "grep -i model system/build.prop" и "grep -i manufacturer system/build.prop", первый выдал результат. Для пущести, гуглу был дан новый запрос, с указанием MACHINE_MODEL, который подтвердил мои подозрения:

rockchip's recovery program compares model name in update.img(machine_model in HWDEF) and running system(ro.product.model). if they are different, you'll get error.
отсюда.

Проверил - всё именно так: если параметр "ro.product.model" совпадает с MACHINE_MODEL из parameter, указанных при сборке имиджа - прошивка не считается инвалидной.

Комментариев нет:

Отправить комментарий