Espressif ESP32 এ OTA পরীক্ষা করুন

নিম্নলিখিত নির্দেশাবলীতে M5Stack ESP32 ডেভেলপমেন্ট বোর্ডের সাথে Matter SDK থেকে লাইটিং অ্যাপের উদাহরণ ব্যবহার করা হয়েছে।

পরিবেশ সেটআপ তৈরি করুন

প্রথমে, Matter SDK ক্লোন করুন।

এই উদাহরণে, আমরা গুগল হোমের Matter রিলিজ ৫ এর জন্য ন্যূনতম সমর্থিত কমিট পরীক্ষা করে দেখি:

mkdir otaprep
cd otaprep
git clone https://github.com/project-chip/connectedhomeip.git
cd connectedhomeip
git fetch origin v1.0-branch
git checkout FETCH_HEAD
git submodule update --init --recursive
source ./scripts/activate.sh

এরপর, আমরা ESP32 GitHub Workflow-এ ব্যবহৃত সংস্করণটি পরীক্ষা করে দেখি কোন ডকার ইমেজটি আমাদের বিল্ডের জন্য সবচেয়ে উপযুক্ত:

cat .github/workflows/examples-esp32.yaml | grep chip-build | head -n 1
image: connectedhomeip/chip-build-esp32:0.5.99

আমরা ডকার ইমেজ থেকে একটি কন্টেইনার চালাই, কন্টেইনারে Matter SDK মাউন্ট করার জন্য এবং ESP32 ডিভাইসে অ্যাক্সেস প্রদানের জন্য ফ্ল্যাগগুলি পাস করি।

docker run --name container_name -it --user $(id -u):$(id -g)--mount source=$(pwd),target=/workspace,type=bind --device=/dev/ttyUSB0 connectedhomeip/chip-build-esp32:0.5.99 /bin/bash

ম্যাটার ডকার কন্টেইনারটি থামান এবং শুরু করুন।

যখনই আপনি একটি docker run কমান্ড চালাবেন, তখন আপনি নির্দিষ্ট চিত্র সহ একটি নতুন কন্টেইনার তৈরি করবেন। যখন আপনি এটি করবেন, তখন আপনার পুরানো ডেটা, যা পূর্ববর্তী কন্টেইনার ইনস্ট্যান্সে সংরক্ষিত ছিল, হারিয়ে যাবে। কখনও কখনও আপনি এটিই করতে চান, কারণ এটি আপনাকে একটি নতুন ইনস্টলেশন দিয়ে শুরু করতে দেয়। কিন্তু এই উদাহরণে আপনি সম্ভবত সেশনের মধ্যে আপনার কাজ এবং পরিবেশ কনফিগারেশন সংরক্ষণ করতে চান।

user@host> docker stop container_name

যখন আপনি আবার চালানোর জন্য প্রস্তুত হবেন, তখন কন্টেইনারটি শুরু করুন এবং একটি টার্মিনাল উইন্ডো খুলুন:

user@host> docker start container_name
user@host> docker exec -it container_name /bin/bash

আপনি আপনার কন্টেইনারে অতিরিক্ত টার্মিনাল সেশন খুলতে পারেন:

user@host> docker exec -it container_name /bin/bash

অথবা নিম্নলিখিতটি ব্যবহার করে একটি রুট সেশন শুরু করুন:

user@host> docker exec -u 0 -it container_name /bin/bash

SDK আরম্ভ করুন

কন্টেইনারে, আমরা Matter SDK এবং ESP IDF আরম্ভ করি:

cd /workspace
git submodule update --init --recursive
source ./scripts/activate.sh
source /opt/espressif/esp-idf/export.sh

তৈরি করুন এবং ফ্ল্যাশ করুন

পরবর্তী কাজ হল Matter ওটিএ ফার্মওয়্যার আপডেট পাওয়ার জন্য ছবিটি তৈরি করা এবং ডেভেলপমেন্ট কিট ফ্ল্যাশ করা।

এটি করার জন্য, আপনাকে একটি ছবি তৈরি করতে হবে।

প্রথমে ESP IDF থেকে menuconfig ইউটিলিটি ব্যবহার করে বিল্ডটি কনফিগার করুন।

cd examples/lighting-app/esp32
idf.py menuconfig

ইন্টারেক্টিভ মেনুতে, নিম্নলিখিত সেটিংস কনফিগার করুন:

  1. Component config --->

  2. CHIP Device Layer --->

  3. Device Identification Options --->

  4. আপনার Connectivity Standards Alliance (Alliance) -নির্ধারিত ভিআইডিতে Vendor ID সেট করুন।

  5. Google Home Developer Console Matter ইন্টিগ্রেশনে আপনি যে PID সেট করেছেন তাতে Product ID সেট করুন।

OTA রিকোয়েস্টর ফ্ল্যাগ সক্রিয় করুন:

  1. Component config -->

  2. CHIP Core -->

  3. System options --->

  4. OTA রিকোয়েস্টর ফ্ল্যাগ সক্ষম করুন [*] Enable OTA Requestor

  5. শীর্ষ স্তরের মেনুতে ফিরে যেতে দুবার ESC টিপুন।

Matter ওটিএ ইমেজ তৈরির পতাকা সক্ষম করুন:

  1. Component config -->

  2. CHIP Device Layer --->

  3. Matter OTA Image --->

  4. [*] Generate OTA IMAGE

সংস্করণ নম্বর সেট করুন:

  1. Application manager --->

  2. [*] Get the project version from Kconfig

  3. Project version (NEW) 1.0 তে সেট করুন

  4. কনফিগারেশন সংরক্ষণ করতে s টিপুন, দুবার Enter টিপুন, তারপর menuconfig বেরিয়ে আসতে q টিপুন।

পরীক্ষার সার্টিফিকেট সেট আপ করুন

CD, DAC, এবং PAI সার্টিফিকেট তৈরি করতে Create Matter ডিভাইস টেস্ট সার্টিফিকেটের ধাপগুলি অনুসরণ করুন।

আপনার ডিভাইস তৈরি করুন

এখন বিল্ডটি চালান এবং ডিভাইসটি ফ্ল্যাশ করুন:

idf.py build
idf.py -p /dev/ttyUSB0 erase_flash
idf.py -p /dev/ttyUSB0 flash

OTA ছবি তৈরি করুন এবং আপলোড করুন

এবার আবার বিল্ড সেটিংস পরিবর্তন করে একটি OTA ইমেজ তৈরি করুন। একই ইমেজ ব্যবহার করুন, কিন্তু বর্ধিত ভার্সন নম্বর সহ।

menuconfig চালান।

idf.py menuconfig

ইন্টারেক্টিভ মেনুতে, নিম্নলিখিতগুলি আপডেট করুন:

  1. Application manager --->
  2. [*] Get the project version from Kconfig
  3. Project version (NEW) 2.0 তে সেট করুন
  4. কনফিগারেশন সংরক্ষণ করতে s টিপুন, দুবার Enter টিপুন, তারপর menuconfig বেরিয়ে আসতে q টিপুন।

ছবিটি তৈরি করুন এবং পুনরুদ্ধার করুন। উদাহরণটি OTA-এর জন্য ছবির অবস্থান এবং ota_image_tool.py দিয়ে পার্স করার সময় আউটপুট উভয়ই প্রদর্শন করে।

cd build && /workspace/src/app/ota_image_tool.py show ./chip-lighting-app-ota.bin

আউটপুটটি নিম্নরূপ:

Magic: 1beef11e
Total Size: 1243360
Header Size: 64
Header TLV:
  [0] Vendor Id: XXXXX (0x000)
  [1] Product Id: XXXXX (0x000)
  [2] Version: 2 (0x2)
  [3] Version String: v2.0
  [4] Payload Size: 1243280 (0x12f890)
  [8] Digest Type: 1 (0x1)
  [9] Digest: e367f4d71e2ccd554b9a399c864abbf2c039382ef1def1b986fb2f59a99923a8

যেহেতু Matter SDK আপনার কন্টেইনার হোস্ট থেকে মাউন্ট করা হয়েছে, তাই OTA ইমেজটি আপনার কন্টেইনার হোস্টে উপলব্ধ।

OTA আপলোড নির্দেশাবলী অনুসরণ করে Developer Console OTA ছবি আপলোড করুন।

গুগল হোমে কমিশন করুন এবং OTA পর্যবেক্ষণ করুন

আপনার ডিভাইসটি USB এর মাধ্যমে হোস্ট লিনাক্স মেশিনের সাথে সংযুক্ত আছে কিনা তা নিশ্চিত করুন। নিম্নলিখিত উদাহরণে ডিভাইস লগ পড়ার জন্য GNU screen ব্যবহার দেখানো হয়েছে:

screen -L /dev/ttyUSB0 115200

এটি ডিভাইস থেকে আপনার টার্মিনালে আউটপুট প্রদর্শন করে এবং screenlog.0 নামক ডিফল্ট স্ক্রিন লগ ফাইলে একই আউটপুট লিখে।

আপনি screenlog.0 ফাইলটি অন্য টেক্সট এডিটরে খুলতে পারেন অথবা cat , tail , more , অথবা grep সহ অন্য শেলে প্রদর্শন করতে পারেন।

বুট থেকে লগ দেখতে ডিভাইসের পাশে লাল রিসেট বোতাম টিপুন।

ডিভাইসের আউটপুটে, আপনি আগে সেট করা VID এবং PID দেখতে পাবেন, সেইসাথে ডিভাইসটি চালু করার জন্য আপনি যে QR কোড চিত্রটি ব্যবহার করবেন তার একটি URLও দেখতে পাবেন।

[0;32mI (2388) chip[DIS]: Advertise commission parameter vendorID=XXXXX productID=XXXX discriminator=3840/15 cm=1[0m

[0;32mI (1928) chip[SVR]: SetupQRCode: [MT:E59-000000000000000][0m

https://project-chip.github.io/connectedhomeip/qrcode.html?data=MT%3AE59-000000000000000

আপনার বাড়িতে আপনার হাব অনলাইনে আছে কিনা তা নিশ্চিত করুন।

লগ ফাইলে প্রদর্শিত লিঙ্ক থেকে QR কোড ব্যবহার করে Google Home app (GHA) দিয়ে ডিভাইসটি চালু করুন।

চালু করার পর ডিভাইসটিকে কয়েক মিনিটের জন্য নিরবচ্ছিন্নভাবে চলতে দিন। আপনার OTA Requestor, OTA ইমেজ ডাউনলোড এবং OTAImageProcessor সম্পর্কিত লগ আউটপুট পর্যবেক্ষণ করা উচিত।

ছবিটি ইনস্টল করার পর, লক্ষ্য করুন যে ছবিটির কম্পাইল সময় কনসোলে আপলোড করা সময়ের সাথে মিলে যাচ্ছে এবং প্রথম বুটে রিপোর্ট করা কম্পাইল সময়ের চেয়ে পরে। screenlog.0 এ রেগুলার এক্সপ্রেশন মোডে নিম্নলিখিত প্যাটার্ন সহ grep চালানো OTA প্রক্রিয়াটি চিত্রিত করতে পারে:

grep -E "(Compile time|OTA)" screenlog.0

আউটপুটটি নিম্নরূপ:

I (76) boot:  1 otadata          OTA data         01 00 0000f000 00002000
I (91) boot:  3 ota_0            OTA app          00 10 00020000 00177000
I (99) boot:  4 ota_1            OTA app          00 11 001a0000 00177000
I (645) cpu_start: Compile time:     Oct 15 2022 06:21:59
I (135558) chip[SWU]: OTA Requestor received AnnounceOTAProvider
I (540658) chip[SWU]: OTA image downloaded to offset 0x1a0000
I (541348) OTAImageProcessor: Applying, Boot partition set offset:0x1a0000
I (76) boot:  1 otadata          OTA data         01 00 0000f000 00002000
I (91) boot:  3 ota_0            OTA app          00 10 00020000 00177000
I (99) boot:  4 ota_1            OTA app          00 11 001a0000 00177000
I (645) cpu_start: Compile time:     Oct 15 2022 07:35:31
I (76) boot:  1 otadata          OTA data         01 00 0000f000 00002000
I (91) boot:  3 ota_0            OTA app          00 10 00020000 00177000
I (99) boot:  4 ota_1            OTA app          00 11 001a0000 00177000
I (645) cpu_start: Compile time:     Oct 15 2022 07:35:31

প্রাথমিক সম্পাদনের পরে, আপনি "নতুন ছবি আপলোড না করে OTA ছবি তৈরি করুন এবং আপলোড করুন" বিভাগের ধাপগুলি পুনরাবৃত্তি করতে পারেন। এবার, সংস্করণগুলি 1 এ সেট করুন।

menuconfig চালান, এবং ইন্টারেক্টিভ মেনু বিকল্পগুলিতে:

  1. Component config -->

  2. CHIP Device Layer --->

  3. Device Identification Options

  4. Version String v1.0 তে সেট করুন।

  5. Device Software Version Number 1 এ সেট করুন।

  6. কনফিগারেশন সংরক্ষণ করতে s টিপুন, তারপর menuconfig বেরিয়ে আসতে q টিপুন।

GHA তে আপনার বাড়ি থেকে ডিভাইসটি সরিয়ে ফেলুন।

যদি ছবিটি ইতিমধ্যে তৈরি না হয়ে থাকে, তাহলে এটি তৈরি করুন:

idf.py build

ফ্ল্যাশ করুন:

idf.py -p /dev/ttyUSB0 erase_flash
idf.py -p /dev/ttyUSB0 flash

কমিশন টু গুগল হোমের ধাপগুলি পুনরাবৃত্তি করুন এবং প্রয়োজনে OTA পর্যবেক্ষণ করুন

OTA সফ্টওয়্যার আপডেট যাচাই করুন

ডিভাইসের সফ্টওয়্যার সংস্করণটি গুগল হোম অ্যাপ (GHA) ব্যবহার করে পরীক্ষা করা যেতে পারে। একবার একটি ডিভাইস চালু হয়ে গেলে, এই পদ্ধতিগুলি অনুসরণ করুন:

  1. GHA প্রধান স্ক্রিনে ডিভাইস টাইলটি দীর্ঘক্ষণ টিপুন।
  2. উপরের ডানদিকে আইকনে ট্যাপ করুন
  3. প্রযুক্তিগত তথ্য ট্যাপ করুন
  4. সফ্টওয়্যার সংস্করণ ক্ষেত্রটি পরীক্ষা করুন।

গুগল হোম অ্যাপ স্ক্রিনে সফ্টওয়্যার ভার্সন ফিল্ড দেখাচ্ছে