blob: 1ee492c2ffc6953d277d00e2e0cfe01fc3152608 [file] [log] [blame] [view]
# Manufacturing Partition Generator Utility
This tool is designed to generate factory partitions for mass production.
## Dependencies
Please make sure you have had the following tools before using the generator
tool.
- [CHIP Certificate Tool](https://github.com/project-chip/connectedhomeip/tree/master/src/tools/chip-cert)
- [SPAKE2P Parameters Tool](https://github.com/project-chip/connectedhomeip/tree/master/src/tools/spake2p)
- [chip-tool](https://github.com/project-chip/connectedhomeip/tree/master/examples/chip-tool)
### [Build Matter tools](https://github.com/project-chip/connectedhomeip/blob/master/docs/guides/BUILDING.md#build-for-the-host-os-linux-or-macos)
1. Using the following commands to generate chip-tool, spake2p and chip-cert at
`path/to/connectedhomeip/build/out/host`.
```shell
cd path/to/connectedhomeip
source scripts/activate.sh
gn gen build/out/host
ninja -C build/out/host
```
2. Add the tools path to \$PATH
```shell
export PATH="$PATH:path/to/connectedhomeip/build/out/host"
```
### Install python dependencies
```shell
cd path/to/connectedhomeip/scripts/tools/telink/
python3 -m pip install -r requirements.build.txt
python3 -m pip install -r requirements.telink.txt
```
## Usage
The following commands generate factory partitions using the default testing PAI
keys, certificates, and CD in Matter project. You can make it using yours
instead in real production.
### Generate a factory partition
```shell
python3 mfg_tool.py -v 0xFFF2 -p 0x8001 \
--serial-num AABBCCDDEEFF11223344556677889900 \
--vendor-name "Telink Semiconductor" \
--product-name "not-specified" \
--mfg-date 2022-12-12 \
--hw-ver 1 \
--hw-ver-str "prerelase" \
--pai \
--key /path/to/connectedhomeip/credentials/test/attestation/Chip-Test-PAI-FFF2-8001-Key.pem \
--cert /path/to/connectedhomeip/credentials/test/attestation/Chip-Test-PAI-FFF2-8001-Cert.pem \
-cd /path/to/connectedhomeip/credentials/test/certification-declaration/Chip-Test-CD-FFF2-8001.der \
--spake2-path /path/to/spake2p \
--chip-tool-path /path/to/chip-tool \
--chip-cert-path /path/to/chip-cert
```
### Generate 5 factory partitions [Optional argument : --count]
```shell
python3 mfg_tool.py --count 5 -v 0xFFF2 -p 0x8001 \
--serial-num AABBCCDDEEFF11223344556677889900 \
--vendor-name "Telink Semiconductor" \
--product-name "not-specified" \
--mfg-date 2022-02-02 \
--hw-ver 1 \
--hw-ver-str "prerelase" \
--pai \
--key /path/to/connectedhomeip/credentials/test/attestation/Chip-Test-PAI-FFF2-8001-Key.pem \
--cert /path/to/connectedhomeip/credentials/test/attestation/Chip-Test-PAI-FFF2-8001-Cert.pem \
-cd /path/to/connectedhomeip/credentials/test/certification-declaration/Chip-Test-CD-FFF2-8001.der \
--spake2-path /path/to/spake2p \
--chip-tool-path /path/to/chip-tool \
--chip-cert-path /path/to/chip-cert
```
## Output files and directory structure
```
out
├── device_sn.csv
└── fff2_8001
├── aabbccddeeff11223344556677889900
│   ├── factory_data.bin
│   ├── factory_data.hex
│   ├── internal
│   │   ├── DAC_cert.der
│   │   ├── DAC_cert.pem
│   │   ├── DAC_key.pem
│   │   ├── DAC_private_key.bin
│   │   ├── DAC_public_key.bin
│   │   └── pai_cert.der
│   ├── onb_codes.csv
│   ├── pin_disc.csv
│   ├── qrcode.png
│   └── summary.json
├── aabbccddeeff11223344556677889901
│   ├── factory_data.bin
│   ├── factory_data.hex
│   ├── internal
│   │   ├── DAC_cert.der
│   │   ├── DAC_cert.pem
│   │   ├── DAC_key.pem
│   │   ├── DAC_private_key.bin
│   │   ├── DAC_public_key.bin
│   │   └── pai_cert.der
│   ├── onb_codes.csv
│   ├── pin_disc.csv
│   ├── qrcode.png
│   └── summary.json
├── aabbccddeeff11223344556677889902
│   ├── factory_data.bin
│   ├── factory_data.hex
│   ├── internal
│   │   ├── DAC_cert.der
│   │   ├── DAC_cert.pem
│   │   ├── DAC_key.pem
│   │   ├── DAC_private_key.bin
│   │   ├── DAC_public_key.bin
│   │   └── pai_cert.der
│   ├── onb_codes.csv
│   ├── pin_disc.csv
│   ├── qrcode.png
│   └── summary.json
└── aabbccddeeff11223344556677889903
├── factory_data.bin
├── factory_data.hex
├── internal
│   ├── DAC_cert.der
│   ├── DAC_cert.pem
│   ├── DAC_key.pem
│   ├── DAC_private_key.bin
│   ├── DAC_public_key.bin
│   └── pai_cert.der
├── onb_codes.csv
├── pin_disc.csv
├── qrcode.png
└── summary.json
```
Tool generates following output files:
- Partition Binary : `factory_data.bin` and `factory_data.hex`
- Partition JSON : `summary.json`
- Onboarding codes : `onb_codes.csv`
- QR Code image : `qrcode.png`
Other intermediate files are stored in `internal/` directory:
- PAI Certificate : `pai_cert.der`
- DAC Certificates : `DAC_cert.der` and `DAC_cert.pem`
- DAC Private Key : `DAC_private_key.bin`
- DAC Public Key : `DAC_public_key.bin`
Above files are stored at `out/<vid_pid>/<SN>`. Each device is identified with
an unique SN.
## Flashing the factory partition FW into Matter App
You can try one of these factory partition FW on developing stage.
1. Prepare a Matter App FW with empty factory data partition.
For example, `lighting-app`. Please generate the FW as below:
```shell
cd path/to/connectedhomeip/example/ligting-app/telink/
west build -- -DCONFIG_CHIP_FACTORY_DATA=y
```
The output FW is stored at `./build/zephyr/zephyr.bin`.
2. Then flash Matter App FW onto B91 board.
3. Then flash the `factory_data.bin` generated from the generator tool at
specific address:
> Note: The offset for Matter
> [v1.0-branch](https://github.com/telink-semi/zephyr/blob/telink_matter_v1.0-branch/boards/riscv/tlsr9518adk80d/tlsr9518adk80d.dts)
> is `0xF4000` and for
> [master branch](https://github.com/telink-semi/zephyr/blob/telink_matter/boards/riscv/tlsr9518adk80d/tlsr9518adk80d.dts)
> is `0x104000`. You can check the `factory_partition` reg at
> `tlsr9518adk80d.dts` for details.
For example, the `factory_data_bin` with serial number
`aabbccddeeff11223344556677889900`. Here is the expected output in logging:
```shell
...
I: 947 [DL]Device Configuration:
I: 951 [DL] Serial Number: aabbccddeeff11223344556677889900
I: 957 [DL] Vendor Id: 65522 (0xFFF2)
I: 961 [DL] Product Id: 32769 (0x8001)
I: 965 [DL] Hardware Version: 1
I: 969 [DL] Setup Pin Code (0 for UNKNOWN/ERROR): 93320241
I: 975 [DL] Setup Discriminator (0xFFFF for UNKNOWN/ERROR): 3008 (0xBC0)
I: 983 [DL] Manufacturing Date: 2022-02-02
I: 988 [DL] Device Type: 65535 (0xFFFF)
I: 993 [SVR]SetupQRCode: [MT:634J042C00O-KB7Z-10]
I: 999 [SVR]Copy/paste the below URL in a browser to see the QR Code:
I: 1006 [SVR]https://project-chip.github.io/connectedhomeip/qrcode.html?data=MT%3A634J042C00O-KB7Z-10
I: 1017 [SVR]Manual pairing code: [26251356956]
...
```