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
Long-term testing on accelerated Linux kernel
Search
Yoshitake Kobayashi
May 05, 2010
Technology
0
9
Long-term testing on accelerated Linux kernel
CELF Japan Technical Jamboree 32
Yoshitake Kobayashi
May 05, 2010
Tweet
Share
More Decks by Yoshitake Kobayashi
See All by Yoshitake Kobayashi
InnerSource Learning Path - インナーソースで始める組織内オープンソース開発入門&実践 -
ystk
1
210
Civil Infrastructure Platform : Industrial-Grade Linux
ystk
0
29
Boosting Software Development with Generative AI
ystk
0
36
Enhancing Cyber Resilience and Sustainability in Critical Infrastructure with CIP and IEC-62443-4
ystk
0
22
Introducing CIP in 10 minutes
ystk
0
39
Civil Infrastructure Platform-Empowering Sustainable Living with Industrial Grade Linux
ystk
0
43
Enhancing Cyber Resilience with CIP
ystk
0
8
共に創る未来:ソフトウェア開発における共創・協働のアプローチと戦略
ystk
0
110
Civil Infrastructure Platform : Industrial-Grade Linux
ystk
0
570
Other Decks in Technology
See All in Technology
Contract One Engineering Unit 紹介資料
sansan33
PRO
0
6.9k
AWS Well-Architected から考えるオブザーバビリティの勘所 / Considering the Essentials of Observability from AWS Well-Architected
sms_tech
1
110
Figma Dev Mode MCP Serverを用いたUI開発
zoothezoo
0
230
衛星運用をソフトウェアエンジニアに依頼したときにできあがるもの
sankichi92
1
1.1k
P2P通信の標準化 WebRTCを知ろう
faithandbrave
1
140
「現場で活躍するAIエージェント」を実現するチームと開発プロセス
tkikuchi1002
3
410
Data Engineering Study#30 LT資料
tetsuroito
1
200
安定した基盤システムのためのライブラリ選定
kakehashi
PRO
3
130
助けて! XからWaylandに移行しないと新しいGNOMEが使えなくなっちゃう 2025-07-12
nobutomurata
2
200
【あのMCPって、どんな処理してるの?】 AWS CDKでの開発で便利なAWS MCP Servers特集
yoshimi0227
6
960
LIXIL基幹システム刷新に立ち向かう技術的アプローチについて
tsukuha
1
390
All About Sansan – for New Global Engineers
sansan33
PRO
1
1.2k
Featured
See All Featured
Being A Developer After 40
akosma
90
590k
How to Ace a Technical Interview
jacobian
278
23k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
30
2.2k
GraphQLとの向き合い方2022年版
quramy
49
14k
Rebuilding a faster, lazier Slack
samanthasiow
83
9.1k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
108
19k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
48
2.9k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
32
2.4k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
161
15k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
126
53k
Transcript
Mar. 5, 2010 Long-term testing on accelerated Linux kernel Yoshitake
Kobayashi Advanced Software Technology Group Corporate Software Engineering Center TOSHIBA CORPORATION Copyright 2010, Toshiba Corporation.
2 本日の発表のアウトライン 問題 Linuxカーネルの加速方法 実装と問題点 実験 まとめ
3 はじめに 今回 今回 今回 今回の の の の話 話
話 話は は は は・・・ ・・・ ・・・ ・・・ • 「こんなことをやってみた」という内容です 何 何 何 何をしたか をしたか をしたか をしたか • Linux カーネルの動作を加速してみました • ....というのは,少し(かなり?)”怪しい”部分を含みます
4 問題と解決案 問題 • 長期稼動を対象としたテストには時間がかかる → 手っ取り早く長期間分のテストをしてみたい START GOAL 加速
加速 加速 加速! ! ! !
5 制限事項 加速 加速 加速 加速できないものは できないものは できないものは できないものは多 多
多 多い い い い • CPUの最大動作周波数 • ディスクアクセススピード • ネットワーク通信速度 • ..... 加速 加速 加速 加速できそうなもの できそうなもの できそうなもの できそうなもの • 時間の進み方 ハード ハード ハード ハードそのものは そのものは そのものは そのものは 加速不可 加速不可 加速不可 加速不可
6 時間の加速にあたって Linuxにおける における における における時間管理 時間管理 時間管理 時間管理 •
jiffies - システム起動時から経過したtick数 • xtime - 現在時刻と日付を保持 加速 加速 加速 加速の の の の定義 定義 定義 定義 • 加速 = jiffies × 加速係数 jiffies jiffies jiffies jiffiesが が が が基本 基本 基本 基本
7 実装 1. Kconfigにパラメータを追加 • Config SPEEDUP_RATIO (範囲:1~1000) 2. do_timer()関数でごにょごにょ
• 単に加速係数を掛けているだけ 3.操作は procfs経由で行う 例: echo 100 > /proc/sys/kern/accel など 実装環境: kernel-2.6.18 (Debian/GNU Linux 4.0) void do_timer(….) { jiffies_64 = jiffies_64 + (1 * speedup_ratio); ….. } 1000倍速 倍速 倍速 倍速で で で で起動 起動 起動 起動! まともに まともに まともに まともに 動 動 動 動かない かない かない かない!
8 動作不具合現象と原因 1. 現象 • ファイルシステムがマウントできない • デバイスがまともに動作しない 2. 原因
• カーネル内部のタイムアウト処理 - デバイスドライバ - ファイルシステム • ユーザレベルプログラムのタイムアウト 例: udev
9 具体例 マウスが動かない • 以下のカーネルメッセージが表示される - Mar 4 00:18:13 accel
kernel: psmouse.c: Wheel Mouse at isa0060/serio1/input0 lost synchronization, throwing 1 bytes away. - 赤で書いたファイル名は実際には”psmouse-base.c” (コメントのバグ?) キーボード • キーボード入力: 一瞬で数十文字入力が可能に! • シリアルコンソールは大丈夫 スクリーンセーバー • 一瞬でブラックアウト
10 タイムアウトへの対策 1. 方針 • 対象カーネルのタイムアウト依存部を整理 • jiffiesを利用している部分を中心にgrepで 2. 方法
• 加速係数に合わせてタイムアウトを調整 • ( timeout * speedup_ratio ) でタイムアウトを長く gnomeデスクトップ デスクトップ デスクトップ デスクトップ環境 環境 環境 環境までそれなりに までそれなりに までそれなりに までそれなりに動 動 動 動いた いた いた いた
11 実験 ★ 簡単なテストプログラムをいくつか用意 • gettimeofday()利用による時間進行確認プログラム • times()利用による時間進行確認プログラム • syslog,
message, vmstatログ監視プログラム • とりあえず10年程度走らせてみる(1000倍速で約4日) ★ 結果 • gettimeofday()利用では特に問題なし • times()利用ではclock_tオーバーフローを確認 (マニュアルに書かれている通りの動作) • syslog, message, vmstatログ監視では特に異常は見当たらない • ACPIによる電源断も10年経過後も行えるようだ
12 スクリーンショット xdaliclockはそれなりの はそれなりの はそれなりの はそれなりの速度 速度 速度 速度で で
で で動作 動作 動作 動作 xclockは は は は針 針 針 針がまともに がまともに がまともに がまともに動作 動作 動作 動作せず せず せず せず( ( ( (スキップ スキップ スキップ スキップ動作 動作 動作 動作) ) ) ) 40倍速程度 倍速程度 倍速程度 倍速程度で で で で CPU使用率 使用率 使用率 使用率100% % % %に に に に 450日弱 日弱 日弱 日弱で で で で不正 不正 不正 不正な な な な値 値 値 値が が が が 出力 出力 出力 出力されている されている されている されている
13 まとめ Linuxカーネル カーネル カーネル カーネルを を を を加速 加速
加速 加速してみた してみた してみた してみた • 本当に(ハードウェアが)速くなるわけではない - 物理的に加速したのではないので限界あり - 加速したのは時刻のみ • ソフトウェアの実行は”見た目”で早く感じることもある • clock_tのオーバーフロー問題は,1日程度で再現可能 • カーネル自体は10年動作させても大丈夫そう • 長期稼動向けの試験に応用することを期待 • 他の有効利用方法についてはアイデア アイデア アイデア アイデア募集中 募集中 募集中 募集中です
14 2008 / 7 / 24 TOSHIBA Confidential