Semiconductor Portal

» セミコンポータルによる分析 » \術分析 » \術分析(デバイス設& FPD)

ソフトウエアのバグがないことを証してくれるツールをMonoidicsが拡販へ

半導ビジネスにソフトウエアの比率が高まってくるにつれ、ソフトウエアプログラムにつきもののバグが頭痛の|になる。これまでバグをEするツールは見つけて除去するだけで、他にも遒鵑任い覯性はあった。もし、バグがないことを証してくれたら、SoCの設時間がぐんと]くなる。この夢を実現してくれるソフトウエアツールが普及の兆しを見せている。

英国ロンドンを拠点として日櫃砲皀フィスをく、モノイディクス(Monoidics)社は、2Qiにロンドンj学のピーター・オーハン教bと櫂ーネギーメロンj学のジョン・C・レイノルズ教bが]ち立てたプログラムのしさを証する理bをWして、それを化し商@「Infer」と@けた。二人の教bは今でもモノイディクス社の顧問でもある。

同社日本Ъ劵妊レクタであるRichard Rettigによると、このツール「Infer」は世の中にあるC/C++で書いたプログラムならどれでも適できるが、同社の狙うx場は組み込みソフトの分野だという。組み込みUのj模なSoCやFPGAのプログラム開発ではC言語を使う例が\えているからだ。

「Infer」のメリットは、コストを抑えたままバグのないソフトウエアプログラムを証できる点である。これまでバグを除去する場合は、ソフトウエアのプログラムをつぶさに調べると時間(コスト)がかかってしまうが、調hのプログラム霾をらすと時間は]くなるが、カバレージ(垣)が下がってしまいプログラムのが落ちてしまう。できるだけ]時間でバグのないことが証できればありがたい。「Infer」は]時間でバグを調べバグがなくなったことを証するソフトウエアである。ただし、プロシージャ(プログラムの中で、繰り返し登場する処理を行うためにk連の命令をkつの}順(procedure)としてまとめたもの)レベルでのコードがWであることを証するlであり、プロシージャレベルではないコードに関してはずしもWというlではない。

「Infer」は3つのソフトウエアからなる。発見しにくいバグを捉えるBug Catchingと、L陥のないことを証するFormal Verification、ソフトウエアのをビジュアルに表するInferクオリティチャート、である。Bug Catchはソースコードの画C屬縫┘蕁爾あるとそれをハイライトで表し、Formal Verificationはプロシージャごとに証ダイアグラムを発行する。Inferクオリティチャートでは、Tの優先順位と、カバー率を表しプログラムのをビジュアル化する。

この中で、Formal Verificationツールと}ばれるものは来もあった。しかし、これまでのツールではプログラムコードをチェックし、バグのある所に優先度をけそれぞれ直していくという作業が中心だったという。「Infer」のFormal Verificationツールは、バグがないことを数学的に証するものであり、プログラムのをチェックする時間を]縮、すなわち検hコストを下げることができる。


図1 プログラムのを図で表 出Z:Monoidics
図1 プログラムのを図で表 出Z:Monoidics


Inferクオリティチャートは、ソフトウエアのをCall Rankという指Yと、証の(プルーフ)カバレージという指Yを使って表すもの(図1)。横軸のプルーフカバレージは0%から100%まであるが、e軸のCall Rankはプロシージャが}ばれる割合で、高い気曚匹茲}ばれていることをす。L陥のある霾を掘∠堯黄でそれぞれHい、中くらい、少ない、を表している。L陥がないコードはuで表す。図1の笋曚Wであり、左笋柾L陥を含む可性がHいことを表している。

「Infer」はコードとメモリとの関係をきっちり保証することが実現のカギだという。見つけにくいバグの中でもメモリリークと}ばれる、メモリ覦茲徐々にってしまう現に咾ぁメモリリークはOSのメモリ管理桔,北筱があったり、アプリケーションにバグが残っていたりするときやすい、と言われている。

「Infer」の~Wな点は、サードパーティのコードに瓦靴討をチェックできることだ(図2)。経済噞省の組込みソフトウエア噞実調h報告書2010によると、世の中にあるてのソフトウエアの平均的なプログラム行数は99.8万行であり、そのうちくゼロから開発するコードは45.4万行である。残りの54.4万行はソフトの再Wということになる。となるとサードパーティのソフトを流することがごくk般的になってきていることになる。ただし、「サードパーティのコードには基がない。その基は他のコードとの互換性もない」とRichard Rettigは言う。また、サードパーティのコードがたとえしくても、組み合わせるとL陥となるケースもあるという。


図2 サードパーティのソフトのチェックにも~効 出Z:Monoidics

図2 サードパーティのソフトのチェックにも~効 出Z:Monoidics


そこで、サードパーティも含めたソフトウエアのをチェックするために、ドライバからライブラリ、ミドルウエア、アプリケーションのてに渡ってチェックすることが要になってくる。それもできるだけ開発の嵶工で行い、バグをZい工までeっていかないことが_要になる。に、Androidデバイスに使われるソフトウエアはサードパーティだらけなので再Wのチェックは不可Lである。

このソフトの入}桔,箸靴董PCやサーバーにインストールするパッケージソフトの他に、クラウドをWする桔,眤靴┐討い襦「Infer」はC/C++をサポートしているが、2012QにはJavaプログラムにも官する予定だ。

(2011/08/31)
ごT見・ご感[
麼嫋岌幃学庁医 忽恢娼瞳謹p斤易住算駄単| 涙呱鱗畠科武平岑辛徨涙孳飢| 窒継h仔扉強只壓濆杰 | 晩云互賠www| 冉巖卅繁消消寄穗濬彊| 際際夊匚匚夊繁繁訪階当97秉| 晴晴晴恷仟壓濆杰潅盞儻瀁緤啼| 醍狭勧炭秘笥醍狭巷望勧箪 | 消消娼瞳嶄猟忖鳥及匯匈| 天胆來値住xxxx菜繁| 冉巖娼瞳篇撞壓濆杰簡啼| 娼瞳岱鷹匯曝坪符繁曇涙鷹| 忽恢匯曝屈曝眉曝胆溺| 仔弼利峽窒継鉱心| 忽恢娼瞳冉巖頭匚弼壓| 99消消忽囂其然娼瞳忽恢| 劑娼篇撞匯曝屈曝眉曝| 嶄猟忖鳥唹頭窒継壓濆杰| 晩昆音触壓濂シ| 冉巖AV弼虚某涙鷹| 天胆忽恢戴消消消消| 冉巖天胆晩昆嶄猟涙濛| 際際弼供竊中綻綻致杠 | 99re99.nat| 溺繁18匯雫谷頭邦寔謹| 匯雫戴尖窮灣2019| 撹定胆溺仔利嫋弼寄窒継篇撞| 消消怜匚涙鷹続某頭怜匚娼瞳| 恷除2018窒継嶄猟忖鳥篇撞| 冉巖総窃涙鷹匯曝屈曝眉曝| 天胆娼瞳窒継鉱心屈曝| 冉巖忝栽弼7777秤利嫋777| 槻溺住來喟消窒継篇撞殴慧| 強只繁麗涌強只繁麗窒継鉱心 | 忽恢天胆晩昆匯曝屈曝紗責曳| 69撹繁窒継篇撞涙鷹廨曝| 忽恢互賠篇撞壓| 98消消繁曇涙鷹娼瞳狼双築孟| 爺銘〔壓濆挈| a弼谷頭窒継篇撞| 溺繁褒揚衣蝕斑槻繁涌|