Railsアプリを書いてる場合はあまり関係ないですが、
セグメンテーションエラー(SEGV)などに遭遇した場合に、
原因を調査する方法を紹介します。

まずは、coreを吐かせるためにulimitの設定をします。

sh>>
% ulimit -c
0
% ulimit -c unlimited
% ulimit -c
unlimited
<<--

ulimit -cが0になっている場合は、coreを吐かないので、
適当な値を設定するか、unlimitedにします。

あとは、プログラムを実行してランタイムエラーを引き起こし、
coreファイルを出力させます。

sh>>
% ./command
zsh: segmentation fault (core dumped) ./command
<<--

さて、今度はgdbの出番です。
gdbは対話型のデバッガです。
以下のように、gdbにオプションを指定して起動します。

pre>>
% gdb ./command --core=./core

.. snip ..

Core was generated by `./command'.
Program terminated with signal 11, Segmentation fault.
#0 0x08048a43 in vec_sub (a=0x804e248, b=0xbfa9e720) at vec.c:124
124 const __m128 t_vec5 = (*a) ;
(gdb)
<<--

すると、上記のように対話セッションが開始されます。
あとは、表示された内容や、gdbのコマンドを使って原因を解析すればOKです。
例えば上記の出力の例では、aのアドレスが16バイト境界に乗っていないのが
原因であることが推察できます。

ソースコードが手元にある場合は、gccに-gオプションをつけてコンパイル
することで、lコマンドによって以下のようにエラーが発生した場所の周辺の
ソースコードを見たりすることができるようになります。

pre>>
(gdb) l
119 return t_vec3 ;
120 }
121
122 __m128 vec_sub (const __m128 * a, const __m128 * b)
123 {
124 const __m128 t_vec5 = (*a) ;
125 const __m128 t_vec4 = (*b) ;
126 const __m128 t_vec6 = _mm_sub_ps( t_vec5 , t_vec4 ) ;
127 return t_vec6 ;
128 }
<<--

gdbを終了する場合は、qコマンドを実行します。

posted by genki genki on Sat 15 Mar 2008 at 00:31 with 0 comments
Contents rssrss
光ファイバーを二次元振動させて走査するAR用ディスプレイ
因果の取り違え
Swift2's defer for CoffeeScript
mongodb-3.0からcreateIndexのdropDupsが無くなったらしい
mongodb-3.0以降のWiredTigerの設定を動的に変更する方法
一般楕円の高速生成アルゴリズムへの道標
farro mantecatoのレシピ
Droonga関連の記事のまとめ
RuntimeErrorの特定のメッセージに限定してrescueする方法
jQueryでscriptタグを実行せずにappendする
Tags
coffeescriptdefergroongajsmemonodenodejs
Comments rssrss
http://asia999-asia.pages.dev http://asia999-asia.pages.dev: โพสต์นี้ มีประโยชน์มาก ครับ ผม เพิ่งเจอข้อมูลเกี่... 05/24 10:29
https://chicagocherryloans.com https://chicagocherryloans.com: Hello! I simply wish to give you a big thumbs up f... 05/24 10:10
https://www.arabellareeve.co.uk/ https://www.arabellareeve.co.uk/: Смотрите видео для взрослых на безопасных и надежн... 05/24 08:52
https://www.ivrakurser.se/blogg/lonkero-sports-betting-bet-big-win-more-now/ https://www.ivrakurser.se/blogg/lonkero-sports-betting-bet-big-win-more-now/: Very informative read. 05/24 08:27
http://.qs.j.y@forum.annecy-outdoor.com/suivi_forum/?a[]=%3Ca%20href=https://maxi-furniture-singapore.y0h0.c19.e2-5.dev/furniture-deals/double-bed/index.html%3Eblack%20dining%20room%20table%20and%20chairs%3C/a%3E%3Cmeta%20http-equiv=refresh%20content=0;url=https://maxi-furniture-singapore.y0h0.c19.e2-5.dev/furniture-deals/double-bed/index.html%20/%3E http://.qs.j.y@forum.annecy-outdoor.com/suivi_forum/?a[]=%3Ca%20href=https://maxi-furniture-singapore.y0h0.c19.e2-5.dev/furniture-deals/double-bed/index.html%3Eblack%20dining%20room%20table%20and%20chairs%3C/a%3E%3Cmeta%20http-equiv=refresh%20content=0;url=https://maxi-furniture-singapore.y0h0.c19.e2-5.dev/furniture-deals/double-bed/index.html%20/%3E: As the top-rated furniture store аnd lɑrge-scale f... 05/24 08:05
http://ia.n.3@haedongacademy.org/phpinfo.php?a[]=%3Ca%20href=https://maxi-furniture-singapore.sgp1.vultrobjects.com/furniture-blog/sliding-wardrobe-doors/index.html%3Etable%20mirror%3C/a%3E%3Cmeta%20http-equiv=refresh%20content=0;url=https://maxi-furniture-singapore.sgp1.vultrobjects.com/furniture-blog/sliding-wardrobe-doors/index.html%20/%3E http://ia.n.3@haedongacademy.org/phpinfo.php?a[]=%3Ca%20href=https://maxi-furniture-singapore.sgp1.vultrobjects.com/furniture-blog/sliding-wardrobe-doors/index.html%3Etable%20mirror%3C/a%3E%3Cmeta%20http-equiv=refresh%20content=0;url=https://maxi-furniture-singapore.sgp1.vultrobjects.com/furniture-blog/sliding-wardrobe-doors/index.html%20/%3E: We aгe Singapore’s leading furniture store аnd lar... 05/24 07:46
https://remont-62.ru https://remont-62.ru: Ущерб от наркотиков — этто комплексная хоботня, об... 05/24 07:31
https://librabahchisaray.ru https://librabahchisaray.ru: Ущерб от наркотиков — это единая проблема, охват... 05/24 06:57
Services from s21g
YOMU Web小説リーダー
小説投稿サイトの公式ページを開き、WebView表示と読み上げ向け表示を切り替えて、移動中や作業中にもWeb小説の続きを聴きやすくするiPhoneアプリです。
補助探
公開されている補助金・助成金情報を集約し、条件に合う制度を探しやすくするサービスです。
jotter.me
個人開発者のためのホスティング一体型ノートサービス
ハンドミラー
iPhone向けの手鏡アプリ
ツイプロ(twpro)
Twitterプロフィールの高速検索エンジン