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見・ご感[
麼嫋岌幃学庁医 利嫋壓濆杰環禧議| 忽恢91娼瞳消消| 消消消消消冉巖娼瞳| 娼瞳繁繁曇繁繁壽繁繁訪繁繁| 忽恢撹繁娼瞳窒継消消消消| 99RE6壓瀛啼犠瞳窒継| 冉巖窒継鉱心壓瀛啼| 消9消9娼瞳窒継鉱心| 天胆匯雫消消消消消消寄| 冉巖忝栽娼瞳卅繁消消| 膨拶壓炯醫帯西鍛盞| 匚匚彼彼晩晩繁繁楳楳| 消消娼瞳忽恢999寄穗濬| 天胆晩昆低峡議| 繁繁曇繁繁壽繁繁訪繁繁娼瞳惜咳 | 眉雫怜匚眉雫眉泣壓心| 晩云天胆篇撞壓濆杰| 冉巖av撹繁匯曝屈曝眉曝| 天胆決髄來鞭xxxxx島邦| 低峡議篇撞壓濂シ| 娼瞳涙鷹AV涙鷹窒継廨曝| 忽恢岱尖戴頭壓濆杰| 99RE66壓濆杰款瞳窒継| 溺繁18谷頭匯雫谷頭壓| 和中匯序匯竃挫訪篇撞| 天胆晩昆忽恢娼瞳忝栽| 卅繁弼忝栽消消爺爺| 娼瞳涙繁岱鷹匯曝屈曝眉曝| 忽恢眉雫壓瀉盞儿杰| 互賠涙鷹篇撞岷俊心| 忽恢天胆総窃消消消娼瞳窒継| 2020忽恢娼瞳徭田| 壓炒侘鍔崢参賛| 嶄猟忖鳥涙鷹音触壓| 天胆晩昆忽恢娼瞳徭壓徭 | 冥雑篇撞壓濘簡啼| 消消消宸戦嗤娼瞳| 晩昆牽旋窮唹壓濆杰| 繁繁際際忝栽消消冉巖| 娼瞳消消消消秉桐| 嗽啣嗽間序肇挫訪窒継|