質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.57%

LINUX上のアプリの戻り値(終了コード)の定義

解決済

回答 4

投稿

  • 評価
  • クリップ 0
  • VIEW 1,926

dotkind

score 14

組み込みLinux上でのアプリケーションを作成しています。

意図せぬエラーでアプリが落ちた時の挙動について質問です。

例えば、以下の様なアプリを実行すると、メモリ二重開放でエラーになります。
* Error in `/tmp/app': double free or corruption (top): 0x003b5008 * Aborted

そのとき、アプリの戻り値(終了コード)を確認すると0x86になっておりました。 この値はどこに定義されているのでしょうか?

終了コードを数種類利用し、 終了の状態を外部に伝えたいと考えており、通常の成功の0以外で使える数値(エラーに割り当てられていない数値)が何かを知りたいと思っております。

int main()
{
    FILE* fp = fopen("/tmp/app", "r");
    fclose(fp);
    fclose(fp);    //←ここでメモリ二重開放のエラーが出る

    return 0;
}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 4

+3

プログラムがabort(異常終了)した場合には、_exitシステムコールが呼ばれないため、通常の終了コードはセットされません。

何となくでいうと、0x86は、SIGABRTのシグナル番号である0x06に、下から4ビット目が立った値ではないでしょうか。

 追記:

そう思って調べてみると、これは終了コードを受け取るシェルの側の動作のようですね。ash・bash・zshあたりは128+シグナル番号、ksh93あたりは256+シグナル番号、という説明がありました。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/30 13:43

    情報ありがとうございます。
    大変参考になりました。

    キャンセル

checkベストアンサー

+1

終了コードが128を超える場合は、シグナルによる割り込み終了です。
終了コード=128+シグナル番号です。
今回は、終了コード=0x86=134とのことですが
0x8B=139ではないでしょうか。(こちらで確認すると139で終了しています)
134なら134-128=6(SIGABRT 6 Coreabort(3) からの中断 (Abort) シグナル)
139なら139-128=11(SIGSEGV    11    Core    不正なメモリー参照)
となります。
下記URLを参照ください。
https://www.pistolfly.com/weblog/2014/04/%E3%82%B3%E3%83%9E%E3%83%B3%E3%83%89%E3%81%AE%E7%B5%82%E4%BA%86%E3%82%B3%E3%83%BC%E3%83%89%E3%81%8C128%E3%82%92%E8%B6%85%E3%81%88%E3%82%8B%E5%A0%B4%E5%90%88%E3%81%AF%E3%82%B7%E3%82%B0%E3%83%8A.html

https://linuxjm.osdn.jp/html/LDP_man-pages/man7/signal.7.html

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/30 13:42

    ご回答ありがとうございます。
    追加の質問がございます。
    128以下の場合は、どの様な意味合いになるのでしょうか?

    キャンセル

  • 2018/11/30 14:19

    can110さんが提示されている一覧があるかと思いますが、紳士協定かと思いますので。
    あなたが作成するアプリケーションで自由に決めてよいかと。
    0は正常にし、以外は数値が大きくなるほど重度のエラーになるように、きめれば良いとおもます。
    アプリケーション間で齟齬がなく、統一的に決めれば、問題ないと思います。

    キャンセル

+1

sysexits.hには、プログラムがexit()で外部に返す値が定義されています。
但し、これに準拠しないプログラムも多く存在するので確認が必要です。

sysexits.hより抜粋

#define EX_OK   0 /* successful termination */

#define EX__BASE  64  /* base value for error messages */

#define EX_USAGE  64  /* command line usage error */
#define EX_DATAERR  65  /* data format error */
#define EX_NOINPUT  66  /* cannot open input */
#define EX_NOUSER 67  /* addressee unknown */
#define EX_NOHOST 68  /* host name unknown */
#define EX_UNAVAILABLE  69  /* service unavailable */
#define EX_SOFTWARE 70  /* internal software error */
#define EX_OSERR  71  /* system error (e.g., can't fork) */
#define EX_OSFILE 72  /* critical OS file missing */
#define EX_CANTCREAT  73  /* can't create (user) output file */
#define EX_IOERR  74  /* input/output error */
#define EX_TEMPFAIL 75  /* temp failure; user is invited to retry */
#define EX_PROTOCOL 76  /* remote error in protocol */
#define EX_NOPERM 77  /* permission denied */
#define EX_CONFIG 78  /* configuration error */

#define EX__MAX 78  /* maximum listed value */

ちなみにerrno.hは、システムコールがエラーで返ってきた時にerrnoにセットされる値なので、終了コードとは別物です。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/30 13:44

    ご回答ありがとうございます。
    今後はsysexits.hも参考にするよういたします。

    キャンセル

0

UNIX系のエラー一覧を参照ください。
実際には各プログラムで決めているので、上記の一覧とは異なる意味を表している可能性は十分にあります。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/30 13:42

    情報ありがとうございます。
    大変参考になりました。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.57%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る