忍者ブログ
物理学者(ポスドク)による日々の研究生活のメモ書きです ( python/emacs/html/Japascript/シェルスクリプト/TeX/Mac/C言語/Linux/git/tmux/R/ポケモンGO)
ブログを書き始めて苦節8年
ついにタイトル回収しましたw





■ やること

1.コンパイル時にgオプションを付ける
 g++ -g
2. ulimitの設定を変更してcore dumpを出力するようにする
% ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 386124
max locked memory (kbytes, -l) unlimited
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 4096
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
設定を変えるには、
% ulimit -c unlimited
% ulimit -a
core file size (blocks, -c) unlimited
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 386124
max locked memory (kbytes, -l) unlimited
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 4096
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
2'. ただ、自分の環境では↑の設定はしなくてもうまくいった。condor経由で実行したので、そっちの設定が上書きされたとか?
3. プログラム実行時にsegmentation faultなどのエラーで終了すると core.5045.5 のようなファイルが作成される
4. このファイルを解析する

(追記)
coreファイルがクッソファイル容量が大きいので注意
自分の環境だと64GBもあって思わず吹いてしまった
どーしてもこのバグを取らないと死ぬって状況以外では使わないほうがいいかもしれん





コアファイルについての情報を表示するときは
% file core.5045.5
これでどの環境でどのプログラムのcoreファイルかわかる


gdbコマンドでこのcoreファイルを解析するときのフォーマットはこんな感じ
gdb [実行プログラムの名前] ./[コアファイルの名前]

% gbd hoge core.5045.5
これでいろいろと画面出力が出てくるはず(自分の結果をここに貼ることはできないので、↓の方にある他の人の記事参照)
ちなみにコアファイルと実行プログラムは1対1対応しているので、実行プログラムを修正してコンパイルし直すときちんとgdbが動かなくなるので注意な(すでに体験済)



このあとプログラムがどこまで進んだかをBackTraceで調べる
(gbd) の後に今のカーソルがあるので、btと入力する

左端に#0, #1, #2...と通し番号がある、これをframeというらしい

もっと詳しく見たい場合は
frame 25
と打つと、そのframeでの詳細が見れる


変数について詳しくみたいときはpを使う
p [変数名、配列名、構造体名]
と入力する
(gdb) p npoint_total
$2 = 1415577600
(gdb) p dataParameters[iChannel].sampleRate
value has been optimized out
(gdb) p dataParameters[iChannel]
value has been optimized out
「value has been optimized out」と表示されるのはなんでだろう?
=> コンパイル時に最適化してしまって見れなくなっている値らしい
ということは -O2 オプションを外せば見えるのかな? 今回は見てもしゃあないけど

最適化関連の話題については次の記事がわかりやすかった
■ 参考 : デバッガ


他にもxというコマンドもあるらしい、配列の中身を見るとかだった気がするけど
今回は使ってないので省略


gdbを終了するときは quit または q と入力する



■ 参考 : [GDB] 別環境で採取した Core ファイルを解析する方法

■ 参考 : コアダンプを解析しよう









PR
この記事にコメントする
Name
Title
Color
E-Mail
URL
Comment
Password   Vodafone絵文字 i-mode絵文字 Ezweb絵文字
プロフィール
HN:coffee
職業:物理屋(自称)
趣味:映画鑑賞、登山
出身:大阪府の南の田舎
自己紹介:
import MyProfile
import coffee_pote from TWITTER
import amazonのほしい物リスト from WISH_LIST

print "先月子供が産まれました!"

# 最終更新 2022/10/25
カウンター
カウンター カウンター
ブログ内検索
ツイートするボタン
リンク
相互リンク募集中です (Twitterにてお知らせください)

Demo scripts for gnuplot version 5
(gnuplotのさまざまなデモ画像と作り方がまとめられている、眺めているだけでできるようになった気分になれる)

gnuplotスクリプトの解説
(米澤進吾さんの個人ページ、gnuplotと言えばこのかた)

gnuplot のページ
(Takeno Lab、うちのブログがリンクされていたのでリンク返し)

Twitterから映画の評価が分かる & 映画の鑑賞記録が残せる coco
(映画の感想をまとめられるサイト、いつもお世話になっています)

Astronomy Picture of the Day Archive
(天文や宇宙関連の最新の話題について画像とともにNASAが説明しているページ)

今日のほしぞら
(任意の時刻の空で見える星を表示してくれる、国立天文台が管理している)

GNUPLOTとアニメーション
(応用の項目の「見せてあげよう!ラピュタの雷を!!」あたりからすごすぎる)

読書メーター
(読んだ本をリストできる便利なサイト)

flickr難民の写真置き場
(20XX年、flickrは有料化の炎に包まれた。あらゆるflickr無料ユーザーは絶滅したかに見えた。 しかし、tumblr移住民は死に絶えてはいなかった。)

教授でもできるMac OS X へのLaTeX, X11, gccのインストレーションと環境設定
(阪大の山中卓さんのwebページ、タイトルにセンスが溢れている、内容は超充実してる、特にTeX関連、学振DCとかPDの申請書類作成時にはお世話になっております)

英語論文執筆用の例文検索サービス
(とんでもないものを見つけてしまった・・・・ arXivに収録されている 811,761報の 英語論文から,例文を検索するための検索エンジン)


Template "simple02" by Emile*Emilie
忍者ブログ [PR]