フィードバック最適化コンパイルで、アウトライン関数が作成されることがあります。これらは、「ソース」ビューと「逆アセンブリ」ビューに特殊なインデックス行として表示されます。「ソース」ビューでは、アウトライン関数に変換されたコードのブロックに注釈が表示されます。
Function binsearchmod inlined from source file ptralias2.c into the
0. 0 . 58. if( binsearchmod( asize, &element ) ) {
0.240 0.240 59. if( key != (element << 1) ) {
0. 0. 60. error |= BINSEARCHMODPOSTESTFAILED;
<Function: main -- outline code from line 60 [_$o1B60.main]>
0.040 0.040 [ 61] break;
0. 0. 62. }
0. 0. 63. }
「逆アセンブリ」ビューでは、アウトライン関数は通常、ファイルの末尾に表示されます。
<Function: main -- outline code from line 85 [_$o1D85.main]>
0. 0. [ 85] 100001034: sethi %hi(0x100000), %i5
0. 0. [ 86] 100001038: bset 4, %i3
0. 0. [ 85] 10000103c: or %i5, 1, %l7
0. 0. [ 85] 100001040: sllx %l7, 12, %l5
0. 0. [ 85] 100001044: call printf ! 0x100101300
0. 0. [ 85] 100001048: add %l5, 336, %o0
0. 0. [ 90] 10000104c: cmp %i3, 0
0. 0. [ 20] 100001050: ba,a 0x1000010b4
<Function: main -- outline code from line 46 [_$o1A46.main]>
0. 0. [ 46] 100001054: mov 1, %i3
0. 0. [ 47] 100001058: ba 0x100001090
0. 0. [ 56] 10000105c: clr [%i2]
<Function: main -- outline code from line 60 [_$o1B60.main]>
0. 0. [ 60] 100001060: bset 2, %i3
0. 0. [ 61] 100001064: ba 0x10000109c
0. 0. [ 74] 100001068: mov 1, %o3
アウトライン関数の名前は角括弧内に表示され、コードの取り出し元関数の名前や、ソースコード内のセクションの先頭の行番号を含む、アウトライン化したコードのセクションに関する情報をエンコードします。これらの符号化された名前は、リリースごとに異なります。パフォーマンスアナライザは、読みやすいバージョンの関数名を表示します。詳細は、アウトライン関数を参照してください。
アプリケーションのパフォーマンスデータの収集時にアウトライン関数が呼び出されると、パフォーマンスアナライザは、注釈付き逆アセンブリに特殊な行を表示して、その関数の包括的メトリックを示します。詳細は、包括的メトリックを参照してください。