Merge pull request #11 from themactep/master

How to dump flash via SD card.
pull/12/head
Paul Philippov 2022-02-12 21:01:46 -05:00 committed by GitHub
commit 0fe68c5e3f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 79 additions and 9 deletions

View File

@ -21,13 +21,21 @@ root@openipc-hi3518ev100:~#
### Сохранение заводской прошивки без tftp.
В программе-терминале, используемой для подключения к порту UART, установите
сохранение лога сессии. После чего в консоли загрузчика запустите команду чтения
данных из памяти длиной в объем флэш-памяти начиная с нулевого адреса.
сохранение лога сессии. В качестве примера мы используем программу-терминал
`screen`. В этом случае команда подлючения к UART-адаптеру с сохранением лога
сессии в файл _fulldump.log_ будет выглядеть примерно так:
Используйте шестнадцатеричное представление для адресов памяти. Так 0 в
шестнадцатеричной записи выглядит как 0x0, 8 мегабайтов (8 * 1024 * 1024 =
8,388,608 байтов) выглядят как 0x800000, 16 мегабайтов (16 * 1024 * 1024 =
или 16,777,216 байтов) - как 0x1000000.
```
$ screen -L -Logfile fulldump.log /dev/ttyUSB0 115200
```
После чего в консоли загрузчика запустите команду чтения данных из памяти длиной
в объем флэш-памяти начиная с нулевого адреса.
Используйте шестнадцатеричную запись для адресов памяти.
Так 0 в шестнадцатеричном представлении выглядит как 0x0,
8 мегабайтов (8 * 1024 * 1024 = 8,388,608 байтов) -- как 0x800000,
16 мегабайтов (16 * 1024 * 1024 = или 16,777,216 байтов) -- как 0x1000000.
Чтение 8МБ флэш-памяти:
@ -41,16 +49,78 @@ md.b 0x0 0x800000
md.b 0x0 0x1000000
```
После запуска команды чтения содержимого памяти вы можете отсоедить сессию,
чтобы случайное нажатие клавиш не замусорило лог. В `screen` это делается
последовательным нажатием комбинации клавиш `Ctrl-a` и клавиши `d` (detach).
Для последующего присоединения к запущенной сессии используйте команду
```
screen -r
```
Будьте готовы к тому, что процесс передачи данных через серийное подключение
займет несколько часов. Зато в результате у вас будет полная копия оригинальной
прошивки, которую можно конвертировать в бинарный файл с помощью программы
[binwalk](https://github.com/ReFirmLabs/binwalk) и использовать для дальнейшего
изучения или для восстановления камеры в её оригинальный вид.
#### Сохранение прошивки через SD карту.
Бывает, что у камеры есть только беспроводной доступ, который не работает
напрямую из загрузчика. Очень часто такие камеры имеют разъём для внешней карты
памяти формата microSD. В таком случае можно попробовать получить копию
оригинальной прошивки используя карту как носитель-посредник. Объем данных,
которые вам потребуется сохранить -- не более 16 МБ, поэтому подойдет любая
доступная карта, даже самого маленького объема.
Вставьте карту в соответствующий разъем на камере, подключите серийный адаптер
к порту UART, подайте питание на камеру и остановите процесс загрузки так,
чтобы оказаться в консоли загрузчика.
Инициализируйте доступ к карте, и очистите место для сохранения копии прошивки.
Запись на карту производится блоками по 512 байтов. Для очистки 8 МБ вам
потребуется стереть 16384 таких блоков, а для 16 МБ - 32768, что в
шестнадцатеричном представлении будет 0x4000 и 0x8000, соответственно.
Обратите внимание, что мы используем прямой доступ к регистрам карты, минуя
таблицу разделов. Чтобы избежать конфликтов при обращении к данным карты, мы
будем записывать данные пропустив 8 килобайтов от начала (8 * 1024 = 8192 байтов
или 16 блоков по 512 байтов, или 0x10 блоков в шестнадцатеричном представлении)
```
mmc dev 0
mmc erase 0x10 0x8000
```
Теперь вам надо скопировать содержимое прошивки из микросхемы флэш-памяти в
оперативную память камеры. Для этого очистите участок оперативной памяти
(0x800000 байтов для микросхем объемом 8 МБ или 0x1000000 байтов для микросхем
объемом 16 МБ), получите доступ к микросхеме флэш-памяти и скопируйте весь объем
флэш-памяти в очищенное пространство оперативной памяти. После чего сохраните
скопированные данные из оперативной памяти на карту.
NB! В примере мы используем стартовый адрес 0x2000000, но этот параметр может
отличаться у разных моделей камер.
```
mw.b 0x2000000 ff 0x1000000
sf probe 0
sf read 0x2000000 0x0 0x1000000
mmc write 0x2000000 0x10 0x8000
```
Выньте карту из камеры и вставьте в компьютер с операционной системой Linux.
Используя команду `dd` скопируйте данные с карты в бинарный файл на диске
компьютера.
```
dd bs=512 skip=16 count=32768 if=/dev/sdc of=./fulldump.bin
```
### Обход запароленного загрузчика.
Смена загрузчика -- рискованная операция. Уж слишком высоки шансы превратить
Смена загрузчика -- рискованная операция. Уж слишком высоки шансы превратить
камеру в пресс-папье, если что-то пойдёт не так. Поэтому прежде чем прошивать
новый загрузчик надо взвесить все риски и бенефиты.
@ -62,7 +132,7 @@ md.b 0x0 0x1000000
загрузки -- это приглашение ввести пароль. В таком случае относительно
безопасным решением будет даунгрейд родной прошивки до версии, где ещё не
требовался пароль. Например, у камер Xiongmai пароль в загрузчике появился
где-то в районе июля 2021 года, следовательно вам понадобится файл с фирменной
где-то в районе июля 2021 года, следовательно, вам понадобится файл с фирменной
прошивкой от вашей камеры с более ранней датой. После успешного даунгрейда на
беспарольный загрузчик вы сможете установить прошивку OpenIPC уже стандартными
средствами.

View File

@ -160,7 +160,7 @@ tftp 0x82000000 firmware-full.bin 0x1000000
присущих той или иной камере. Но и казалось бы менее значимые детали могут
устанавливать ограничения на возможности камеры и её прошивки. Например, у
разных камер могут отличаться установленные микросхемы флэш-памяти. Одни камеры
могут иметь флэш-память объемом 8 МБ, в то время как другие - 16 МБ, то и
могут иметь флэш-память объемом 8 МБ, в то время как другие - 16 МБ, а то и
больше. В больший объем флэш-памяти можно поместить большее количество
программного кода, позволить камере запускать дополнительные сервисы, которые
недоступны на камерах с меньшим объёмом флэш-памяти. Поэтому мы решили