<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Telink Python腳本生成工廠數據的步驟介紹

泰凌微電子 ? 來源:泰凌微電子 ? 2024-03-27 10:13 ? 次閱讀

工廠數據是在制造過程中寫入非易失性存儲器的一組設備參數。

所有的工廠數據參數都受保護,以避免被軟件修改。在設備使用周期內,固件的數據參數集必須保持不變。在生成固件時,除了某些廠商定義的情況,必須確保在設備固件更新或恢復出廠設置期間,工廠數據不會被重寫或覆蓋。

在生成固件的時候,可以用多種方式實現Matter工廠數據,只要保證最終的 HEX/BIN 文件包含工廠數據組件表中定義的所有強制要求的組件。

在本次分享中,我們描述了一種由我們的平臺維護者創建的工廠數據集的實現方式。在完成后,將得到一個包含 `CBOR` 格式的工廠數據分區的十六進制和二進制文件。

1

工廠數據組件表和數據格式

工廠數據參數集包括不同類型的信息,例如設備證書、加密密鑰、設備標識符,以及硬件等等。所有的這些參數都是特定于廠商的,并且在制造過程中,必須保存到設備的持久性存儲器中。工廠數據參數將會在設備啟動時被讀取,然后可以被用在 Matter 協議棧和用戶應用程序中(例如在配網過程中)。下表列出了工廠數據集中包含的參數:

4f82a684-ebdb-11ee-a297-92fbcf53809c.png

工廠數據集需要被寫入到Matter設備的閃存中,所以在我們的示例中,工廠數據集以 `CBOR` 格式表示,并存儲在十六進制或二進制文件中。然后,該文件將被燒錄到設備上。

工廠數據集的參數包括強制參數和可選參數:

必須始終提供強制性參數,因為設備在進行配網進入Matter網絡時需要它們。

可選參數可用于開發和測試目的。例如,用戶數據參數包含了特定制造商所需要的且不包含在強制性參數中的所有數據。

在工廠數據集中,使用了以下格式:

`uint16` 和 `uint32` -- 這些是分別表示兩字節長度無符號整數,和四字節長度無符號整數的數字格式。此值以大端順序存儲在十六進制文件中`Byte string` -- 該參數表示在0到255之間(包括255)的整數序列,沒有任何編碼。由于JSON格式不允許使用字節字符串,因此將 `hex:` 前綴添加到參數中,并將其轉換為十六進制字符串。

`ASCII string` 是ASCII編碼中的字符串表示形式,沒有空終止。

`ISO 8601` 格式是一種日期格式,表示以`YYYY-MM-DD`或`YYYYMMDD`格式提供的日期。

存儲在工廠數據中的所有證書都以X.509格式提供。

2

啟用工廠數據支持

在所有的 Telink 示例中,要開始使用存儲在閃存和 Telink 平臺中的工廠數據和 Telink 平臺的 Factory Data Provider,請使用以下編譯選項構建一個示例:

1、westbuild---DCONFIG_CHIP_FACTORY_DATA=y

3

生成工廠數據

本節介紹使用以下 Telink Python 腳本生成工廠數據的步驟。

檢查和安裝Matter依賴項

在使用生成器工具之前,請確保已具備以下工具。

CHIP Certificate Tool

SPAKE2P Parameters Tool

chip-tool

安裝的詳細描述:

使用以下命令在 `path/to/connectedhomeip/build/out/host` 生成 chip-tool, spake2p 和chip-cert

cdpath/to/connectedhomeip

sourcescripts/activate.sh

gngenbuild/out/host

ninja-Cbuild/out/host

在$PATH 中加入工具路徑

exportPATH="$PATH:path/to/connectedhomeip/build/out/host"

在設備固件上準備工廠數據分區

工廠數據分區是設備持久存儲中存儲工廠數據集的區域。這個區域在 DeviceTrees 文件里進行配置。

對于 Matter v1.0-branch 分支,配置文件在Zephyr工程中,路徑為:`zephyrproject/zephyr/boards/riscv/tlsr9518adk80d/tlsr9518adk80d.dts`。

對于 Matter v1.1-branch 分支,配置文件在Matter工程中,路徑為:`connectedhomeip/src/platform/telink/tlsr9518adk80d.overlay`。

對于 Matter master 分支,配置文件在Matter工程中。不過,將對分區的聲明從 `tlsr9518adk80d.overlay` 中提取出來,分別寫作 `1m_flash.overlay`,`2m_flash.overlay`,和 `4m_flash.overlay`。那么,可以根據所選的芯片的 Flash 尺寸,去選擇合適的配置文件。

若要準備一個客制化的支持工廠數據的示例,請在 `tlsr9518adk80d.dts`,`tlsr9518adk80d.overlay` 或 `Xm_flash.overlay` 文件中添加或修改一個名為 `factory-data` 的分區。分區大小應該是一個 flash page 的倍數(單個 page 大小等于 4kB)。

腳本使用

若要使用此腳本,請完成以下步驟:

1、進入 `connectedhomeip` 根目錄。

2、使用 `-h` 選項運行腳本,以查看所有可能的選項:

pythonscripts/tools/telink/mfg_tool.py-h

3、準備一個參數列表:

填寫所有強制性參數:

--serial-num--vendor-id,--product-id,--vendor-name,--product-name,--mfg-date,--hw-ver,--hw-ver-str,--enable-rotating-device-id,--spake2-path,--chip-tool-path,--chip-cert-path,--offset,--size

添加輸出文件路徑:

--output

添加證書聲明路徑(必選):

-cd

指定使用哪個證書:

用戶:

--dac-cert

--dac-key

--cert

--key

--pai

生成DAC和PAI:

--cert

--key

--paa

使用以下選項之一為輪換設備 ID 添加新的唯一 ID:

提供一個已存在的 ID:

--rdid--uid

生成一個新的 ID 并提供:

--enable-rotating-device-id

(可選)指定自己的密碼:

--passcode

(可選)指定自己的鑒別碼:

--discriminator

(可選)添加覆蓋現有輸出文件的請求:

--overwrite

指定分區偏移量和大?。?/p>

--offset

--size

這個命令中:

是設備的持久存儲區域中的地址,分區數據集將存儲在其中。

是設備持久存儲區域中分區的大小。根據這個值檢查新數據,看它的大小是否適合。

重要提示:

對 Matter v1.0-branch 分支使用:

--offset0xf4000--size0x1000

對 Matter ***v1.1-branch*** 分支使用:

--offset0x104000--size0x1000

最新的 Matter ***master*** 分支(2MB flash)使用:

--offset0x107000--size0x1000

使用已準備好的參數列表運行該腳本

1、python3mfg_tool.py

例如,對Python腳本的最終調用看起來類似于下面的用法:

python3scripts/tools/telink/mfg_tool.py

--vendor-id0xFFF2--product-id0x8001

--serial-numAABBCCDDEEFF11223344556677889900

--vendor-name"TelinkSemiconductor"

--product-name"not-specified"

--mfg-date2022-12-12

--hw-ver1

--hw-ver-str"prerelase"

--enable-rotating-device-id

--pai

--keycredentials/test/attestation/Chip-Test-PAI-FFF2-8001-Key.pem

--certcredentials/test/attestation/Chip-Test-PAI-FFF2-8001-Cert.pem

-cdcredentials/test/certification-declaration/Chip-Test-CD-FFF2-8001.der

--spake2-pathbuild/out/host/spake2p

--chip-tool-pathbuild/out/host/chip-tool

--chip-cert-pathbuild/out/host/chip-cert

--offset0x107000--size0x1000

--out./factory_data_for_2mb_flash

作為上述示例的結果,將會生成以下文件:

4f9896c4-ebdb-11ee-a297-92fbcf53809c.png

可選示例/

生成多個工廠分區數據

[可選參數 :--count]

python3scripts/tools/telink/mfg_tool.py--count2-v0xFFF2-p0x8001

--serial-numAABBCCDDEEFF11223344556677889900

--vendor-name"TelinkSemiconductor"

--product-name"not-specified"

--mfg-date2022-12-02

--hw-ver1

--hw-ver-str"prerelase"

--enable-rotating-device-id

--pai

--keycredentials/test/attestation/Chip-Test-PAI-FFF2-8001-Key.pem

--certcredentials/test/attestation/Chip-Test-PAI-FFF2-8001-Cert.pem

-cdcredentials/test/certification-declaration/Chip-Test-CD-FFF2-8001.der

--spake2-pathbuild/out/host/spake2p

--chip-tool-pathbuild/out/host/chip-tool

--chip-cert-pathbuild/out/host/chip-cert

--offset0x107000--size0x1000

--out./factory_data_for_2mb_flash

作為上述示例的結果,將會生成以下文件:

4fb07956-ebdb-11ee-a297-92fbcf53809c.png

*注意:默認情況下,生成的文件不能覆蓋現有輸出目錄。如果想要允許覆蓋,請將 `--overwrite` 選項添加到 Python 腳本的參數列表中。



審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 二進制
    +關注

    關注

    2

    文章

    717

    瀏覽量

    41310
  • python
    +關注

    關注

    52

    文章

    4697

    瀏覽量

    83591
  • 非易失性存儲器

    關注

    0

    文章

    106

    瀏覽量

    23289

原文標題:【技術專欄】Matter工廠數據使用介紹(一)

文章出處:【微信號:telink-semi,微信公眾號:泰凌微電子】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    基于Python腳本的R語言的函數

    本文介紹了采用創建一個Python腳本,用該腳本模仿R風格的函數的方法來方便地進行統計。 是用R語言還是用Python語言?這是一個曠日持久
    的頭像 發表于 10-12 09:33 ?1894次閱讀
    基于<b class='flag-5'>Python</b><b class='flag-5'>腳本</b>的R語言的函數

    我用labview調用matlab腳本如何保存生成數據向量?

    我用labview調用matlab腳本,想保存matlab腳本生成數據向量,怎么實現?
    發表于 11-12 15:14

    我用labview調用matlab腳本,想保存matlab腳本生成數據向量,怎么實現?

    我用labview調用matlab腳本,想保存matlab腳本生成數據向量,怎么實現?
    發表于 02-20 10:07

    Ultra Libraian生成Altium Designer元件庫的步驟介紹

    一、步驟介紹首先下載和安裝Ultra Libraian軟件,這個在Ti或者ADI或者Ultra Libraian官網都可以下載到。下載和安裝過程和普通軟件差不多,根據操作系統不同需要安裝對應
    發表于 07-10 07:49

    Python操作Mysql實現數據腳本的方法概述

    Python操作Mysql數據腳本(cmd)
    發表于 10-08 10:44

    vision的腳本生成vi,vi里面是空白的

    我用vision2016的腳本生成labview2013的vi,生成的vi里面是空白的,什么都沒有,哪位大神可以幫忙解釋一下,十分感謝
    發表于 08-03 16:30

    如何將RK 3128腳本生成固件?

    如何將RK 3128腳本生成固件?
    發表于 03-04 07:03

    Telink的TLSR9系列芯片OpenHarmony開發環境配置

    bash中輸入下列命令,查看python版本:python3 --version如果不低于3.8,可以忽略第二步的重新安裝,從第三步的設置開始。如果Python版本低于3.8,不建議直接升級,請按照如下
    發表于 07-05 14:31

    如何為PyInstaller命令行添加OpenVINO依賴性,從OpenVINO python腳本生成功能 .exe文件?

    執行此命令行以從 OpenVINO python 腳本創建 build.exe 文件: pyinstaller --onefile --add-data \"D
    發表于 08-15 07:16

    如何在 IIS 中執行 Python 腳本

    如何在 IIS 中執行 Python 腳本 Python 是一種解釋腳本語言,概念類似 Microsoft Visual Basic Scripting Edition (VBSc
    發表于 02-23 15:13 ?1150次閱讀

    受控文本生成模型的一般架構及故事生成任務等方面的具體應用

    來自:哈工大訊飛聯合實驗室 本期導讀:本文是對受控文本生成任務的一個簡單的介紹。首先,本文介紹了受控文本生成模型的一般架構,點明了受控文本生成
    的頭像 發表于 10-13 09:46 ?3145次閱讀
    受控文<b class='flag-5'>本生成</b>模型的一般架構及故事<b class='flag-5'>生成</b>任務等方面的具體應用

    基于GPT-2進行文本生成

    系統投入使用。這些系統根據格式化數據或自然語言文本生成新聞、財報或者其他解釋性文本。例如,Automated Insights的WordSmith技術已經被美聯社等機構使用,幫助美聯社報道大學橄欖球賽
    的頭像 發表于 04-13 08:35 ?4310次閱讀

    分享Perl和Python腳本輕量實用的調試工具

    Perl和Python作為目前芯片開發流程中最為流行的腳本語言,本文將分別介紹它們輕量且實用的調試工具(Debugger),讓你在調試腳本的時候不再抓瞎。
    的頭像 發表于 01-21 17:25 ?1366次閱讀
    分享Perl和<b class='flag-5'>Python</b><b class='flag-5'>腳本</b>輕量實用的調試工具

    如何在Linux命令行中運行Python腳本

    Python 腳本。 在本文中,我們將詳細介紹如何在 Linux 命令行中運行 Python 腳本。我們將討論以下主題:
    的頭像 發表于 05-12 14:49 ?1412次閱讀

    如何使用Python腳本調試賽靈思PCIe設計?

    現在,您不僅可以使用 Python 腳本執行調試分析,更重要的是,借由 Vivado ILA 所生成的 ILA 文件可以進一步簡化此操作。通過將 *.ila 擴展名重命名為 *.zip 然后將
    的頭像 發表于 06-26 09:20 ?774次閱讀
    如何使用<b class='flag-5'>Python</b><b class='flag-5'>腳本</b>調試賽靈思PCIe設計?
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>