sprof [option]... shared-object-path [profile-data-path]
上記のオプションがどれも指定されなかった場合のデフォルトの動作は、 flat profile とコールグラフが表示される。
以下のコマンドラインオプションも使用できる。
$ cat prog.c #include <stdlib.h>
void x1(void); void x2(void);
int
main(int argc, char *argv[])
{
x1();
x2();
exit(EXIT_SUCCESS);
}
関数 x1() と x2() は以下のソースファイルで定義されており、 このファイルから共有オブジェクトが構成される。
$ cat libdemo.c #include <unistd.h>
void
consumeCpu1(int lim)
{
for (int j = 0; j < lim; j++)
getppid();
}
void
x1(void) {
for (int j = 0; j < 100; j++)
consumeCpu1(200000);
}
void
consumeCpu2(int lim)
{
for (int j = 0; j < lim; j++)
getppid();
}
void
x2(void)
{
for (int j = 0; j < 1000; j++)
consumeCpu2(10000);
}
ここで、 実際の名前は libdemo.so.1.0.1 で soname は libdemo.so.1 で共有オブジェクトを構成する。
$ cc -g -fPIC -shared -Wl,-soname,libdemo.so.1 \
-o libdemo.so.1.0.1 libdemo.c
次に、 ライブラリ soname とライブラリのリンカー名へのシンボリックリンクを作成する。
$ ln -sf libdemo.so.1.0.1 libdemo.so.1 $ ln -sf libdemo.so.1 libdemo.so
続けて、 共有オブジェクトとリンクしてメインプログラムをコンパイルし、 プログラムの動的な依存の一覧を表示する。
$ cc -g -o prog prog.c -L. -ldemo
$ ldd prog
linux-vdso.so.1 => (0x00007fff86d66000)
libdemo.so.1 => not found
libc.so.6 => /lib64/libc.so.6 (0x00007fd4dc138000)
/lib64/ld-linux-x86-64.so.2 (0x00007fd4dc51f000)
共有オブジェクトのプロファイル情報を取得するために、 環境変数 LD_PROFILE にこのライブラリの soname を設定する。
$ export LD_PROFILE=libdemo.so.1
環境変数 LD_PROFILE_OUTPUT にプロファイル情報を出力するディレクトリのパス名を設定し、 このディレクトリが存在しない場合は作成する。
$ export LD_PROFILE_OUTPUT=$(pwd)/prof_data $ mkdir -p $LD_PROFILE_OUTPUT
LD_PROFILE を設定すると、 プロファイルの出力は出力ファイルがすでに存在する場合は「追記」されるので、 既存のプロファイルデータが存在しないようにしておく。
$ rm -f $LD_PROFILE_OUTPUT/$LD_PROFILE.profile
次にプログラムを実行し、 プロファイリング出力を生成させる。 プロファイリング出力は LD_PROFILE_OUTPUT で指定されたディレクトリにファイルが書き込まれる。
$ LD_LIBRARY_PATH=. ./prog $ ls prof_data libdemo.so.1.profile
sprof -p オプションを使って、 呼び出し回数と tick 数が含まれる flat プロファイルを生成する。
$ sprof -p libdemo.so.1 $LD_PROFILE_OUTPUT/libdemo.so.1.profile Flat profile:
Each sample counts as 0.01 seconds.
% cumulative self self total
time seconds seconds calls us/call us/call name
60.00 0.06 0.06 100 600.00 consumeCpu1
40.00 0.10 0.04 1000 40.00 consumeCpu2
0.00 0.10 0.00 1 0.00 x1
0.00 0.10 0.00 1 0.00 x2
sprof -q オプションを使うと、 コールグラフが生成される。
$ sprof -q libdemo.so.1 $LD_PROFILE_OUTPUT/libdemo.so.1.profile
index % time self children called name
0.00 0.00 100/100 x1 [1]
[0] 100.0 0.00 0.00 100 consumeCpu1 [0]
-----------------------------------------------
0.00 0.00 1/1 <UNKNOWN>
[1] 0.0 0.00 0.00 1 x1 [1]
0.00 0.00 100/100 consumeCpu1 [0]
-----------------------------------------------
0.00 0.00 1000/1000 x2 [3]
[2] 0.0 0.00 0.00 1000 consumeCpu2 [2]
-----------------------------------------------
0.00 0.00 1/1 <UNKNOWN>
[3] 0.0 0.00 0.00 1 x2 [3]
0.00 0.00 1000/1000 consumeCpu2 [2]
-----------------------------------------------
上記や以下の例で、 "<UNKNOWN>" の文字列は、 識別子がプロファイルされたオブジェクトの外部にあることを表している (この例では "<UNKNOWN>" になっているのは main() 内のオブジェクトである)。
sprof -c オプションを使うと、 呼び出しの組とその発生回数のリストが生成される。
$ sprof -c libdemo.so.1 $LD_PROFILE_OUTPUT/libdemo.so.1.profile <UNKNOWN> x1 1 x1 consumeCpu1 100 <UNKNOWN> x2 1 x2 consumeCpu2 1000