Skip to content
This repository has been archived by the owner on May 3, 2021. It is now read-only.

Latest commit

 

History

History
109 lines (96 loc) · 4.35 KB

README.md

File metadata and controls

109 lines (96 loc) · 4.35 KB

XM_ipcam_crypto_generator

Generator of crypto data for XM ip cameras

Sometimes crypto data is stored in additional 1024k i2c eeprom chip (called FM chip), sometimes in main spi memory chip with offset 0x1fc00.

Crypto data contains MAC address and device info

Struct

000 * * * * * * * * * * * * * * * *
010 * * * * * * * * [d d d d M M M M
020 M M d d d d d d d d d d d d d d
030 d d d d d d d d d d d d d d d d
040 d d d d d d d d d d d d d d d d
050 d d d d d d d d] * * * * * * * * MD5 hash block1
060 * * * * * * * * * * * * * * * *
070 * * * * * * * * * * * * * * * *
080 * * * * * * * * * * * * * * * *
090 * * * * * * * * X X X X X X X X
0a0 X X X X X X X X X X X X X X X X
0b0 X X X X X X X X X X X X X X X X
0c0 X X X X X X X X X X X X X X X X
0d0 X X X X X X X X * * * * * * * *
0e0 * * * * * * * * * * * * * * * *
0f0 * * * * * * * * * * * * * * * *
100 * * * * * * * * * * * * * * * *
110 * * * * * * * * * * * * * * * *
120 * * * * * * * * * * * * * * * *
130 * * * * * * * * [d d d d d d d d
140 d d d d d d d d d d d d d d d d
150 d d d d d d d d d d d d d d d d
160 d d d d d d d d d d d d d d d d
170 d d d d d d d d] * * * * * * * * CRC T16
180 * * * * * * * * * * * * * * * *
190 * * * * * * * * * * * * * * * *
1a0 * * * * * * * * * * * * * * * *
1b0 * * * * * * * * X X X X X X X X
1c0 X X X X X X X X X X X X X X X X
1d0 X X X X X X X X X X X X X X X X
1e0 X X X X X X X X X X X X X X X X
1f0 X X X X X X X X * * * * * * * *
200 * * * * * * * * * * * * * * * *
210 * * * * * * * * * * * * * * * *
220 * * * * * * * * * * * * * * * *
230 * * * * * * * * * * * * * * * *
240 * * * * * * * * * * * * * * * *
250 * * * * * * * * [d d d d d d d d
260 d d d d d d d d d d d d d d d d
270 d d d d d d d d d d d d d d d d
280 d d d d d d d d d d d d d d d d
290 d d d d d d d d] * * * * * * * * CRC T16
2a0 * * * * * * * * * * * * * * * *
2b0 * * * * * * * * * * * * * * * *
2c0 * * * * * * * * * * * * * * * *
2d0 * * * * * * * * X X X X X X X X
2e0 X X X X X X X X X X X X X X X X
2f0 X X X X X X X X X X X X X X X X
300 X X X X X X X X X X X X X X X X
310 X X X X X X X X * * * * * * * *
320 * * * * * * * * * * * * * * * *
330 * * * * * * * * * * * * * * * *
340 * * * * * * * * * * * * * * * *
350 * * * * * * * * * * * * * * * *
360 * * * * * * * * * * * * * * * *
370 * * * * * * * * [d m d m d m d m
380 d m d m d d d d d d d d d d d d
390 d d d d d d d d d d d d d d d d
3a0 d d d d d d d d d d d d d d d d
3b0 d d d d d d d d] * * * * * * * * MD5 hash block4
3c0 * * * * * * * * * * * * * * * *
3d0 * * * * * * * * * * * * * * * *
3e0 * * * * * * * * * * * * * * * *
3f0 * * * * * * * * * * * * * * * * CRC T16

  • * any data
  • X data that taked into account for CRC/MD5 calculation
  • M,m MAC data
  • Device info seems to be in first bytes, check encrypt.c to compare different versions of devices

Tests were done on hi3516cv100(hi3518cv100) based cameras, but same method supposed to work on all XM devices. arm-hisiv100-linux toolchain from original HiSilicon SDK was used for cross compilation.

  • software/decrypt.c util for check 1024 bytes crypto data
  • software/encrypt.c crypto generator
  • software/bin/encrypt_* precompiled binaries
  • rootfs_toburn rootfs for hi3516cv100/hi3518cv100 (all crypto related software is in /opt dir)

Example usage: encrypt_imx122 XX:XX:XX:XX:XX:XX (util will generate .enc file in current dir)

How to generate crypto with new MAC

Supposed you have hi3516cv100/hi3518cv100 device with burned uImage/rootfs.romfs from this repo

Prepare FAT32 USB FLASH

  1. Put file generate_task.sh
  2. Edit generate_task.sh: choose which encryption tool to use edit first 4 bytes for MAC

Start camera module and connect via USB-Serial adapter (115200 speed)

  1. run /opt/mount_usb.sh
  2. run cd /mnt
  3. run ./generate_task.sh > ./do.sh
  4. run sh ./do.sh
  5. Wait...
  6. run cd /
  7. run /opt/umount_usb.sh

Unplug power, take off usb flash