Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Nature Remo SDKアップデートの軌跡
Search
tomoyuki-nakabayashi
September 29, 2022
Programming
1
1k
Nature Remo SDKアップデートの軌跡
tomoyuki-nakabayashi
September 29, 2022
Tweet
Share
More Decks by tomoyuki-nakabayashi
See All by tomoyuki-nakabayashi
How to learn Embedded Rust Edition 2021
tomoyuki
0
1.4k
Embedded-Rust
tomoyuki
1
2.9k
hello-world-on-RTOS
tomoyuki
0
810
Baremetal Rust for RISC-V
tomoyuki
5
1.1k
Other Decks in Programming
See All in Programming
ecspresso, ecschedule, lambroll を PipeCDプラグインとして動かしてみた (プロトタイプ) / Running ecspresso, ecschedule, and lambroll as PipeCD Plugins (prototype)
tkikuc
2
1.9k
PHPで学ぶプログラミングの教訓 / Lessons in Programming Learned through PHP
nrslib
4
1.1k
「とりあえず動く」コードはよい、「読みやすい」コードはもっとよい / Code that 'just works' is good, but code that is 'readable' is even better.
mkmk884
6
1.4k
.NETでOBS Studio操作してみたけど…… / Operating OBS Studio by .NET
skasweb
0
120
asdf-ecspresso作って 友達が増えた話 / Fujiwara Tech Conference 2025
koluku
0
1.4k
知られざるDMMデータエンジニアの生態 〜かつてツチノコと呼ばれし者〜
takaha4k
1
450
Итераторы в Go 1.23: зачем они нужны, как использовать, и насколько они быстрые?
lamodatech
0
1.4k
生成AIでGitHubソースコード取得して仕様書を作成
shukob
0
630
Simple組み合わせ村から大都会Railsにやってきた俺は / Coming to Rails from the Simple
moznion
3
2.2k
[JAWS-UG横浜 #80] うわっ…今年のServerless アップデート、少なすぎ…?
maroon1st
0
100
Amazon Nova Reelの可能性
hideg
0
200
毎日13時間もかかるバッチ処理をたった3日で60%短縮するためにやったこと
sho_ssk_
1
550
Featured
See All Featured
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
160
15k
How to train your dragon (web standard)
notwaldorf
89
5.8k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
173
51k
BBQ
matthewcrist
85
9.4k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
232
17k
Reflections from 52 weeks, 52 projects
jeffersonlam
348
20k
Bootstrapping a Software Product
garrettdimon
PRO
305
110k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
98
18k
Build The Right Thing And Hit Your Dates
maggiecrowley
33
2.5k
Designing on Purpose - Digital PM Summit 2013
jponch
116
7.1k
The Invisible Side of Design
smashingmag
299
50k
Fireside Chat
paigeccino
34
3.1k
Transcript
Nature Remo SDKアップデートの軌跡 2022年9月28日 IoTぶっちゃけNight Vol. 1 Nature 中林智之
- 中林智之 @tnakabayashi - Nature Firmware Engineer ちょっと咳は出ちゃうかも ><
自己紹介
PRODUCT 製品について
Nature Remo / Nature Remo mini
How It Works スマートデバイス Nature Remo 家電 赤外線 インターネット 例:
Alexa、書斎照明消して
How It Works スマートデバイス Nature Remo 家電 赤外線 インターネット !?
※登壇者の居室が真っ暗になるデモ中です
Firmwareエンジニア視点のRemo3
BLE Central BLE Peripheral HTTP Server (mDNS) HTTP / WebSocket
Client 赤外線 センサ 温度、湿度 人感、輝度 Nature Remo3の機能 BLE連携 setup Local API server
Nature Remo3の中身 ※分解は自己責任でお願いします! ぱかっと開けると… ESP32 - Espressif - xtensa デュアルコア@240MHz
- SRAM: 520KiB - Bluetooth & Wireless LAN
Nature RemoのSDK - ESP-IDF (Espressif IoT Development Framework) - 大部分がOSS
- GitHubでissueやパッチの受け入れも - 無線通信部分などはバイナリ配布
ぶっちゃけESP32 (ESP-IDF) ってどうなの? - (カタログスペック比で) 破格の安さ - ソフトウェア開発環境は使いやすい - ログシステム
/ デバッグ環境 / テスト環境 - ビルド用のDocker image完備 - menuconfig / kconfig - ソフトウェアに力入れているのは感じる - SDKの変更量 - LLVMのxtensa対応 - Rust - ただし… - 続きは発表の最後で! - チャンネルはそのまま! Ferrous Systemsがやっている Rustチュートリアル用ボードとかも製造
Firmware Updateについての考え方
なぜFirmware Updateをするのか? > ソフトウェアには…簡単に変更できることが求められる。 > 簡単に変更したくないなら、ハードウェアと呼ぶべきだ。 > (中略) > ソフトウェアが簡単に変更できないなら、
> ソフトウェアの存在意義を妨害している。 Nature Remoをハードウェアと呼ばせないため
- ESP-IDF v3.3.4を2年ほど使用 - メンテナンス期限切れ - security issueとか発生したら…? - 機能追加
/ バグフィックス / 開発環境改善 - WPA3対応 - gcc 5.4 -> 8.4 なぜSDKをアップデートするのか?
SDK Updateの軌跡
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
楽しい冒険の始まり - 直前にリリースされた ESP-IDF v4.3.2を移行対象に決定 - 機能開発は凍結 (ぼっちファームなので問題なし ! -
短期決戦を目指して最優先でやる (3ヶ月でケリをつける! 残された希望に満ちたメモ … 100日後に折れるフラグ
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
- v3.3.4で困っていたバグがいくつか直ってそう - WPA3対応してる! - メモリアロケータが変わった…だと…?(v4.3から - TLSF (Two-Level Segregate
Fit) アロケータに - 教科書通りのフリーリストアロケータから O(1) アロケータに - これは重要な変更だ!じっくり調査するしかあるまい? - アロケータの論文 / コード読んだり楽しい時間を過ごす 夢の広がるリリースノート
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
ヒープ残量が・・・ - v4.3.2に上げるとヒープ残量ががっつり減った… - 60KB -> 50KB - 何もしてないのにヒープ残量が減った! -
SDKのコンフィギュレーションが何か変わったか?と調査を開始 - TLSFアロケータのテーブルが10KB使っている
しかも実際のヒープ残量は・・・ - なんかヒープ残量計算がバグってない・・・? - 確保したバッファの管理領域分が計算されていない - 最新バージョンでは直ってます - https://github.com/espressif/esp-idf/issues/8270
ま、いっか 減った分はコード見直せばなんとか…、ということで立ち直る 詳しくは ESP-IDF v4.3でESP32のヒープ残量が10KB減る問題の調査 を参照
None
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
Releaseできちゃうのでは・・・? - 社内リリースして2週間、順調に動いている - サーバー側で段階リリースの仕組みを作ってもらった - 大量の文鎮化を一番恐れている - 本番前に何度かお試し -
全ては順調に見えた・・・
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
v4.3.2の評価結果は・・・? - ダメでした! - 2週間くらい動かすと WiFi 止まる現象がちらほら… - ここから長く苦しいバグ調査の日々が始まる -
真相はバイナリの中 - なので、現象をファームのアプリ層でキャッチする条件調査 - 死活監視入れたり
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
嬉しい悲報の時間です - 4月からファームウェアエンジニアが入社!めでたい! - ファームウェア開発、しちゃうよね…? - v4.3.2にしてしまったから、v3.3.4で開発できるように戻さにゃ - リポジトリをmonorepo化して開発しやすいように -
各種CIやリリースワークフロー再整備 remo3 remo-e products-common network-manager sensor echonet-lite app remo3 remo-e components sensor products-common echonet-lite network-manager
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
新たなる希望v4.4.1 > Fixed failing to transmit data or getting stuck
in WiFi sleep if running WiFi and BT with modem-sleep together これは…まさか…?
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
またヒープ減ってるやんけ・・・ - 4KBくらい ESP-IDF v4.4でまたもやヒープ残量が4KBも減った問題の調査
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
こいつ、止まらないぞ・・・! - 1ヶ月の安定稼働を確認してからリリース準備 - メトリクスを仕込んだり - Remo <-> server 間の通信は
s3 に保存されており、Athenaでクエリできる
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7
ナーバス期 - アップデート対象は数十万台…! - CSチームと連携しながら (直接話しながら - prime dayと重なっていたのでちょっとリリース時期調節したり -
自分で毎朝サポートチケット見たり
中林のテンション 2022/1 SDK Updateの軌跡 2022/4 2022/2 2022/3 2022/5 2022/8 2022/6
2022/7 祝!100%リリース!!!
ぶっちゃけESP32 (ESP-IDF) ってどうなの? - 破格の安さ - なぜか割と入手できる - 開発環境は使いやすい -
ログシステム / デバッグ環境 / テスト環境 - ビルド用のDocker image完備 - menuconfig / kconfig - ソフトウェアに力入れているのは感じる - SDKの変更量 - LLVMのxtensa対応 - Rust - ただし…安定性は慎重な評価が必要 - 場合によっては死活監視も・・・ Ferrous Systemsがやっている Rustチュートリアル用ボードとかも製造
まとめ - Nature RemoのESP-IDFをv3.3.4からv4.4.1にアップデートできた! - ESP32 & ESP-IDFは… - 使いやすいが安定性は慎重に評価が必要
- バイナリ配布の通信部分はどうしようもない… - 見ての通りOSの自作は人生の役に立つんだ!
ご清聴ありがとうございました