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
激安Linuxボード G-cluster改造のすべて
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
gpioblink
July 18, 2020
Technology
2
8.7k
激安Linuxボード G-cluster改造のすべて
gpioblink
July 18, 2020
Tweet
Share
Other Decks in Technology
See All in Technology
[続・営業向け 誰でも話せるOCI セールストーク] AWSよりOCIの優位性が分からない編(2026年2月20日開催)
oracle4engineer
PRO
0
120
「静的解析」だけで終わらせない。 SonarQube の最新機能 × AIで エンジニアの開発生産性を本気で上げる方法
xibuka
2
310
AI が Approve する開発フロー / How AI Reviewers Accelerate Our Development
zaimy
1
210
Lookerの最新バージョンv26.2がやばい話
waiwai2111
1
130
AIエンジニア Devin と歩む、自律型運用プロセスの構築
a2ito
0
150
Introduction to Sansan Meishi Maker Development Engineer
sansan33
PRO
0
360
器用貧乏が強みになるまで ~「なんでもやる」が導いたエンジニアとしての現在地~
kakehashi
PRO
5
590
Secure Boot 2026 - Aggiornamento dei certificati UEFI e piano di adozione in azienda
memiug
0
120
三菱UFJ銀行におけるエンタープライズAI駆動開発のリアル / Enterprise AI_Driven Development at MUFG Bank: The Real Story
muit
10
19k
Interop Tokyo 2025 ShowNet Team Memberで学んだSRv6を基礎から丁寧に
miyukichi_ospf
0
210
なぜAIは組織を速くしないのか 令和の腑分け
sugino
75
47k
Agent Ready になるためにデータ基盤チームが今年やること / How We're Making Our Data Platform Agent-Ready
zaimy
0
180
Featured
See All Featured
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
130
brightonSEO & MeasureFest 2025 - Christian Goodrich - Winning strategies for Black Friday CRO & PPC
cargoodrich
3
110
The Art of Programming - Codeland 2020
erikaheidi
57
14k
BBQ
matthewcrist
89
10k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
62
50k
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
117
110k
New Earth Scene 8
popppiees
1
1.6k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.3k
GraphQLとの向き合い方2022年版
quramy
50
14k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
1
310
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
170
Transcript
激安Linuxボード G-cluster改造のすべて @gpioblink じぶりん
About me じぶりん @gpioblink 会津大学 学部3年 山田 快 ❖ 英語吹き替え版アニメは神
❖ ゲームは遊ぶより改造する ❖ 進捗出すために自己管理中 [好きなもの] 地球
使えなくなったハードを再利用するの大好き❤
趣味で電子機器の修理をしたりもします
今回の話の目標 ハードウェアハッキングの 楽しさを知ってほしい!!
G-clusterで学ぶ組み込みLinux入門 - 目次 講義編 • Gclusterって何? • GPLソースコードは読んでて楽しい 実演編 •
G-Cluster用のシェルを作る • Gclusterをリバースエンジニアリングして任意コード実行してみた
G-clusterで学ぶ組み込みLinux入門 - 目次 講義編 • Gclusterって何? • GPLソースコードは読んでて楽しい 実演編 •
G-Cluster用のシェルを作る • Gclusterをリバースエンジニアリングして任意コード実行してみた
Gclusterって何?
G-clusterは、次世代のクラウドゲーム機!!
G-clusterは、次世代のクラウドゲーム機!!
G-clusterは、次世代のクラウドゲーム機!!
G-clusterは、次世代のクラウドゲーム機!!
G-clusterは、次世代のクラウドゲーム機!! 終わってます。。
でも、ハード的にはそこそこのスペックで Cavium CNW6611L SoC 256MB NANDストレージ (1Gbit/SLC) 512MB メモリ(2Gbit/16bit DDR3
SDRAM) WiFi / USBポート / HDMI出力 UART(要分解)
でも、ハード的にはそこそこのスペックで Cavium CNW6611L SoC 256MB NANDストレージ (1Gbit/SLC) 512MB メモリ(2Gbit/16bit DDR3
SDRAM) WiFi / USBポート / HDMI出力 UART(要分解) 激安
でも、ハード的にはそこそこのスペックで Cavium CNW6611L SoC 256MB NANDストレージ (1Gbit/SLC) 512MB メモリ(2Gbit/16bit DDR3
SDRAM) WiFi / USBポート / HDMI出力 UART(要分解) 激安
つまり、gcluster = 格安Linuxボード Cavium CNW6611L SoC 256MB NANDストレージ (1Gbit/SLC) 512MB
メモリ(2Gbit/16bit DDR3 SDRAM) WiFi / USBポート / HDMI出力 UART(要分解)
つまり、gcluster = 格安Linuxボード UART(シリアル通信)して始めましょう
つまり、gcluster = 格安Linuxボード
つまり、gcluster = 格安Linuxボード 実演編では、任意コード実行できるように改造して G-clusterにセカンドライフをおくって貰います!!
G-clusterで学ぶ組み込みLinux入門 - 目次 講義編 • Gclusterって何? • GPLソースコードは読んでて楽しい 実演編 •
G-Cluster用のシェルを作る • Gclusterをリバースエンジニアリングして任意コード実行してみた
GPLソースコードは読んでて楽しい
LinuxのGPLソースコードの面白い点3つ 製品のコードを知れちゃう マルヒ情報もあったり 楽しいコード流用の世界
GPLは楽しい: 製品のコードを知れちゃう そもそもGPLライセンスとは
GPLは楽しい: 製品のコードを知れちゃう そもそもGPLライセンスとは ソー ス コー ドを 公 開 す
る 義 務 の あ る ライセ ン ス
GPLは楽しい: 製品のコードを知れちゃう そもそもGPLライセンスとは ソー ス コー ドを 公 開 す
る 義 務 の あ る ライセ ン ス
GPLは楽しい: 製品のコードを知れちゃう そもそもGPLライセンスとは ソー ス コー ドを 公 開 す
る 義 務 の あ る ライセ ン ス
GPLは楽しい: 製品のコードを知れちゃう 特に製品にLinuxを使ってると • LinuxカーネルはGPLライセンス • ブートローダーのU-BootもGPLライセンス • その他の低レイヤーレベルのOSSのコードもほとんどGPLライセンス
GPLは楽しい: 製品のコードを知れちゃう 特に製品にLinuxを使ってると • LinuxカーネルはGPLライセンス • ブートローダーのU-BootもGPLライセンス • その他の低レイヤーレベルのOSSのコードもほとんどGPLライセンス → 製品のほぼすべての
ソースコードを見ることができる!!
GPLは楽しい: 製品のコードを知れちゃう しかも、定義的にはこんな感じだから (Wikipedia)
GPLは楽しい: 製品のコードを知れちゃう しかも、定義的にはこんな感じだから (Wikipedia)
GPLは楽しい: 製品のコードを知れちゃう しかも、定義的にはこんな感じだから (Wikipedia) 心理的安全性を保ちながら解析もできる!!
GPLは楽しい: マルヒ情報を知れるかも GPLコードを漁ってると、 いろんなドキュメントが出て くることが
あとは適当にGPL漁ってると
あとは適当にGPL漁ってると
あとは適当にGPL漁ってると なんかConfidentialって書いてる
この他にも商用アプリ側のソースコードもざくざく
この他にも商用アプリ側のソースコードもざくざく
楽しいコード流用の世界 実はハードは同じ会社が作ってるらしく
楽しいコード流用の世界 実はハードは同じ会社が作ってるらしく メガドライブミニのコードの中に、 ファミコンミニのコントローラのkeymap用のコードの残骸が入っていたり。。。
楽しいコード流用の世界 実はハードは同じ会社が作ってるらしく メガドライブミニのコードの中に、 ファミコンミニのコントローラのkeymap用のコードの残骸が入っていたり。。。 残骸まみれの結構泥臭い世界 読んでて飽きない!!
楽しいコード流用の世界 実はハードは同じ会社が作ってるらしく メガドライブミニのコードの中に、 ファミコンミニのコントローラのkeymap用のコードの残骸が入っていたり。。。 残骸まみれの結構泥臭い世界 読んでて飽きない!! コード流用について詳しく知りたい方は HoneyLabさんの本よむのがおすすめです!
講義編のまとめ • G-clusterは、ゲーム機としては終わってるけど激安Linuxと して使える • 企業のプロダクトがのぞき見できるGPLソースコードは面白 い
G-clusterで学ぶ組み込みLinux入門 - 目次 講義編 • Gclusterって何? • GPLソースコードは読んでて楽しい 実演編 •
G-Cluster用のシェルを作る • Gclusterをリバースエンジニアリングして任意コード実行してみた
では、GPLコードをありがた〜く使いながら、 どんどん改造を進めていきましょう!!!
G-Cluster用のシェルを作る
シェルなんて簡単????? そんなことないわw
Gclusterのテレビ画面出力はremotectl_pipe経由
Gclusterのテレビ画面出力はremotectl_pipe経由 GUIを直接自由にいじれない。。。
でGPLコード読み漁ってみると。。。。 echo gc_warning Firmware found > /cavium/remotectl_pipe
でGPLコード読み漁ってみると。。。。 echo gc_warning Firmware found > /cavium/remotectl_pipe ここいじったら反映された!!
とはいえUSBキーボード取得できないので /dev/event1 からとれるキーボードのデータを見て
とはいえUSBキーボード取得できないので LinuxのカーネルとStackOverFlowを 参考にコードを書いて
とはいえUSBキーボード取得できないので
あとは頑張ってキーボード処理するコード書いて
できたもの
G-clusterで学ぶ組み込みLinux入門 - 目次 講義編 • Gclusterって何? • GPLソースコードは読んでて楽しい 実演編 •
G-Cluster用のシェルを作る • Gclusterをリバースエンジニアリングして任意コード実行してみた
無改造で任意コード実行までの道のり
ここまでいろいろ話してきましたが、、、 作成したプログラムの実行には、
ここまでいろいろ話してきましたが、、、 作成したプログラムの実行には、 殻割り&UART取り出しが 必須でした
ここまでいろいろ話してきましたが、、、 作成したプログラムの実行には、 殻割り&UART取り出しが 必須でした
ここまでいろいろ話してきましたが、、、 作成したプログラムの実行には、 殻割り&UART取り出しが 必須でした 100個も殻割りするの めんどくせ〜〜
そこで、かんがえた
本体を改造せずに、簡単にハックする方法があれば。。 そこで、かんがえた
とりあえず、安定のGPLコード読み返してみると
とりあえず、安定のGPLコード読み返してみると なんか USBでUpgradeできそうな 機能あるじゃん
とりあえず、安定のGPLコード読み返してみると なんか USBでUpgradeできそうな 機能あるじゃん
とりあえず、安定のGPLコード読み返してみると なんか USBでUpgradeできそうな 機能あるじゃん
とりあえず、安定のGPLコード読み返してみると なんか USBでUpgradeできそうな 機能あるじゃん
とりあえず、安定のGPLコード読み返してみると なんか USBでUpgradeできそうな 機能あるじゃん USBのルートに「cameo_factory」なるフォルダ作ってそこにイメージぶちこむと どうやらfwimgに投げてくれるらしい
とりあえず、安定のGPLコード読み返してみると なんか USBでUpgradeできそうな 機能あるじゃん USBのルートに「cameo_factory」なるフォルダ作ってそこにイメージぶちこむと どうやらfwimgに投げてくれるらしい USBメモリを挿して起動するだ けで、 任意コード注入できそう!!
しかし、そんな単純ではなかった。。
試しにGPLソースビルドして入れてみたら
試しにGPLソースビルドして入れてみたら アップグレード自体はできたけど
試しにGPLソースビルドして入れてみたら アップグレード自体はできたけど 署名がないせいでブートできなかった。。
試しにGPLソースビルドして入れてみたら アップグレード自体はできたけど 署名がないせいでブートできなかった。。 ここからは、この署名チェックの回避方法に 焦点をあてて説明していきます!!!
どうやって回避しよう • 頑張って本体から認証キーを取り出す(失敗) • fwimgまわりに別の脆弱性がないか探す(成功)
頑張って本体から認証キーを取り出す(失敗)
頑張って本体から認証キーを取り出す(失敗) ブート時にU-bootから呼ばれているソースコード静的解析して頑張ってみます
頑張って本体から認証キーを取り出す(失敗) ファームウェアのダンプ機能なんてないので、
頑張って本体から認証キーを取り出す(失敗) ファームウェアのダンプ機能なんてないので U-Bootの「md - memory display」機能で ダンプしてBinaryBlobに書き戻すw
頑張って本体から認証キーを取り出す(失敗) そして、それっぽいデータが取れました
頑張って本体から認証キーを取り出す(失敗) とりあえずGPLコードに入れてREADMEとか調べてみると
頑張って本体から認証キーを取り出す(失敗) とりあえずGPLコードに入れてREADMEとか調べてみると やっぱりご丁寧にGPLにDVUについての解説が!!
頑張って本体から認証キーを取り出す(失敗) とりあえずGPLコードに入れてREADMEとか調べてみると やっぱりご丁寧にGPLにDVUについての解説が!!
頑張って本体から認証キーを取り出す(失敗) とりあえずGPLコードに入れてREADMEとか調べてみると やっぱりご丁寧にGPLにDVUについての解説が!!
頑張って本体から認証キーを取り出す(失敗) とりあえずGPLコードに入れてREADMEとか調べてみると やっぱりご丁寧にGPLにDVUについての解説が!! dvu.binの中に鍵が入ってそう!!
頑張って本体から認証キーを取り出す(失敗) とりあえずGPLコードに入れてREADMEとか調べてみると やっぱりご丁寧にGPLにDVUについての解説が!! あ、これはリークではないんですね dvu.binの中に鍵が入ってそう!!
頑張って本体から認証キーを取り出す(失敗) それで、このdvu.binをghidraで静的解析してみたけど どこにも鍵っぽいのは見つからなかった。。。
頑張って本体から認証キーを取り出す(失敗) もう一度README見返したら
頑張って本体から認証キーを取り出す(失敗) もう一度README見返したら
頑張って本体から認証キーを取り出す(失敗) もう一度README見返したら
頑張って本体から認証キーを取り出す(失敗) もう一度README見返したら 解析は不可能じゃないけど、ちょっと大変そう。。 (CTFの問題が本当に使えるんだなと思った瞬間)
頑張って本体から認証キーを取り出す(失敗) というわけで、こちらは最後の手段として、 別の方法を考えていきます!
fwimgまわりに別の脆弱性がないか探す(成功)
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析 関数名とか自分でつけ直して、関数を推測していきました!!
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析 関数名とか自分でつけ直して、関数を推測していきました!! ① まずは「factory.img」ヘッダ部分からDSM232の文字列を確認して
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析 関数名とか自分でつけ直して、関数を推測していきました!! ②暗号化の有無によって条件分岐
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析 関数名とか自分でつけ直して、関数を推測していきました!! ③ 次はアプリケーションのインストール。ん、なんか実行してね?
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析 関数名とか自分でつけ直して、関数を推測していきました!! ③ 次はアプリケーションのインストール。ん、なんか実行してね?
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析 関数名とか自分でつけ直して、関数を推測していきました!! ③ 次はアプリケーションのインストール。ん、なんか実行してね? どうやらfactory.imgの最初のgunzipのblobをファイルにして、
fwimgまわりに別の脆弱性がないか探す(成功) こちらもソースコード非公開だったので、ghidraで静的解析 関数名とか自分でつけ直して、関数を推測していきました!! ③ 次はアプリケーションのインストール。ん、なんか実行してね? どうやらfactory.imgの最初のgunzipのblobをファイルにして、 その中のapp.shを実行している!!!!
わかったこと factory.img内にAppImageがあると、その場でその中のshが実行される (しかもfwimgはrootで動いてるので、普通にroot権限w)
わかったこと factory.img内にAppImageがあると、その場でその中のshが実行される (しかもfwimgはrootで動いてるので、普通にroot権限w) ⇓ それなら、シェルスクリプト内からsetenv叩いて、 U-Boot側に非署名ブートする設定を永続化できるのでは?
というわけで、署名チェック回避するブート書いて
というわけで、署名チェック回避するブート書いて セキュアブートの前に、署名チェックせずにブートを試す設定へ
署名チェック回避ブートを入れたイメージにしたら あとはこのfactory.imgをUSBメモリに書き込んで試してみると、、、、 元のイメージの前に、このバイパス用イメージを結合!
永続的な非署名コードの注入(CFW)に成功!! 起動時にこの画面の表示と共に、 Telnetを有効化する カスタムファームウェアを作りまし た!!
まとめ GPLソースコードよく読めばなんでもできる ハードウェアハッキングは楽しい!
おわり: みなさんもgclusterで解析に入門しよう!! https://github.com/gpioblink/build-dsm232-docker 大量にgcluster買って、 ネットラジオチューナー、 ネットワークプリンター、 Amazon dash 中継など みなさんも低コストを活かし
いろんなことに使ってみてください!!! ←dockerで簡単にGPLソースやCFW用ビルド できる環境作りました!ぜひご利用ください じぶりん @gpioblink