コグノスケ


link 未来から過去へ表示  link 過去から未来へ表示(*)

link もっと前
2019年5月17日 >>> 2019年5月26日
link もっと後

2019年5月17日

GCCを調べる - その2 - デバッグ環境

目次: GCC

GCCをデバッグする入り口まで辿り着くのも案外大変だったので、方法を書き残しておこうと思います。

GCCはコンパイラ?

C言語(じゃなくても良いですが)をコンパイルする際に、gcc a.cのようにコマンドを起動します。一般的にgccコマンドをコンパイラと呼びますが、正確にいえばgccはコンパイラドライバ(コンパイラ、アセンブラ、リンカを順に呼び出すプログラム)です。

GCCの場合、コンパイラはcc1という名前で、コンパイラドライバgccとは別のプログラムとして存在します。コンパイラの役目は高級言語(Cなら *.cファイル)からアセンブリ言語(*.sファイル)に変換することです。

DebianのGCC 8.0だと /usr/lib/gcc/x86_64-linux-gnu/8/cc1に置かれています。クロスコンパイラの場合は様々ですが、crostool-NGでRISC-V 64bit Linux向けにビルドした場合(ビルド方法は 2019年2月26日の日記参照)は、~/x-tools/riscv64-unknown-linux-gnu/libexec/gcc/riscv64-unknown-linux-gnu/8.2.0/cc1に置かれます。ローカルビルドしないときは、~/x-toolsをクロスコンパイラをインストールしたディレクトリで読み替えてください。

コンパイラだけ起動したい

デバッガでコンパイラを追うとき、コンパイラドライバ → コンパイラだと余計な処理がたくさん挟まって邪魔なので、コンパイラ単体で起動したくなりますよね?私はなりました。特に気にならない人は読み飛ばしてください。

コンパイラcc1のオプションは、コンパイラドライバgccに渡したオプション以外にも、cc1用のオプションが渡されます。そのためcc1をシェルなどから手打ちで起動するのはちょっと難しいです。

しかし無理してコンパイラcc1のオプションを調べずとも、コンパイラドライバgccが渡すオプションをそのままパクれば良いです。gcc/gcc.cのexecute() 関数を下記のように書き換えると、cc1の起動オプションが表示されます。

コンパイラドライバgccがコンパイラcc1に渡す引数を表示

diff --git a/gcc/gcc.c b/gcc/gcc.c
index a716f708259..e48e5cca79b 100644
--- a/gcc/gcc.c
+++ b/gcc/gcc.c
@@ -3084,6 +3084,12 @@ execute (void)
       const char *errmsg;
       int err;
       const char *string = commands[i].argv[0];
+      int kkk;
+
+      printf("\n------------------------------\n");
+      for (kkk = 0; commands[i].argv[kkk]; kkk++)
+            printf("%s ", commands[i].argv[kkk]);
+      printf("\n------------------------------\n");
 
       errmsg = pex_run (pex,
 			((i + 1 == n_commands ? PEX_LAST : 0)

出力は下記のようになります。この例では、コンパイラはRISC-V 32bitベアメタル向けを使っています。

コンパイラのオプション例
------------------------------
/home/katsuhiro/share/projects/oss/crosstool-builder-new/buildroot/libexec/gcc/riscv32-unknown-elf/8.3.0/cc1 -quiet a.c -quiet -dumpbase a.c -march=rv32gc -mabi=ilp32d -auxbase a -o /tmp/ccdd2F4Z.s
------------------------------

この情報があれば、コマンドラインから単独で起動できますし、GDBで追うこともできます。

GDBでcc1をデバッグ
$ gdb /home/katsuhiro/share/projects/oss/crosstool-builder-new/buildroot/libexec/gcc/riscv32-unknown-elf/8.3.0/cc1

(gdb) b main
Breakpoint 1 at 0x4308a0: main. (2 locations)

(gdb) r a.c -dumpbase a.c -march=rv32gc -mabi=ilp32d -auxbase a -g -O0 -Wall -fdump-tree-all-raw -fdump-rtl-all -o a.s
Starting program: /home/katsuhiro/share/projects/oss/crosstool-builder-new/buildroot/libexec/gcc/riscv32-unknown-elf/8.3.0/cc1 a.c -dumpbase a.c -march=rv32gc -mabi=ilp32d -auxbase a -g -O0 -Wall -fdump-tree-all-raw -fdump-rtl-all -o a.s

Breakpoint 1, main (argc=15, argv=0x7fffffffd3c8)
    at /home/katsuhiro/share/projects/oss/crosstool-builder-new/./gcc/gcc/main.c:36
36        toplev toplev (NULL, /* external_timer */

ブレークポイントなども仕掛けられますし、変数の値を表示することもできます。解析がかなり楽になるはずです……たぶん。

編集者:すずき(2023/09/24 11:46)

コメント一覧

  • hdkさん(2019/05/23 21:07)
    実際に試したわけではないので素朴な疑問なのですが、cc1の引数はgcc -vで出る内容から-vと-versionあたりを外したものとは違うんでしょうか?
  • すずきさん(2019/05/25 10:35)
    試してみたら、同じみたいです。
    わざわざ改造しなくても、-v の方が簡単ですね。
open/close この記事にコメントする



2019年5月26日

RISC-V 64 CPUが我が家に来た

目次: RISC-V

SiFiveのHiFive Unleashedを購入しました。現状、世界唯一かつ最速のLinuxが動作するRISC-V 64bit SoC です。

ボードにはSDカードが付属しておりbuildrootがインストールされています。電源を入れればLinuxが起動し、ユーザroot、パスワードsifiveでログインできるようになっていました。

インストールされているカーネルは、
Linux buildroot 4.15.0-00044-g2b0aa1d #1 SMP Tue Mar 20 12:18:35 PDT 2018 riscv64 GNU/Linux
でした。うーん、4.19かと思ったら、意外と古い?

Linuxとbuildrootだけでは面白くないのでDebian portsからriscv64向けのパッケージを引っ張ってきてDebianの環境を構築しました。

Debianのriscv64向けポーティングは絶賛作業中らしく、ffmpegなど用意されていないパッケージもチラホラありますが、自分で用意する手間を考えれば、使えるだけでどれだけありがたいかわかるというものです。

元のSDカードを書き潰すのは若干ためらわれた(後で元に戻せなくなった時に面倒)ので、今はchrootで使っています。

購入時の罠

Crowd Supplyから購入しました。本体 $999, 送料 $40, 消費税が5,000円くらい、合計で11万円くらいです。SBCにしてはかなり良いお値段です。

送料を払うのですが、家には着払いで届く点にも注意しなければなりません。

UPSが米国→日本まで持ってきて、国内はクロネコヤマトが運びます。受け取りの際に、消費税を着払いでクロネコに払う必要があります。私は消費税のことを知らなくて、何で送料を2回払うんだ??と混乱しました。

メモ: 技術系の話はFacebookから転記しておくことにした。かなり追記。

編集者:すずき(2021/06/28 15:29)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



link もっと前
2019年5月17日 >>> 2019年5月26日
link もっと後

管理用メニュー

link 記事を新規作成

<2019>
<<<05>>>
---1234
567891011
12131415161718
19202122232425
262728293031-

最近のコメント5件

  • link 21年3月13日
    すずきさん (03/05 15:13)
    「あー、このプログラムがまずいんですね。ご...」
  • link 21年3月13日
    emkさん (03/05 12:44)
    「キャストでvolatileを外してアクセ...」
  • link 24年1月24日
    すずきさん (02/19 18:37)
    「簡単にできる方法はPowerShellの...」
  • link 24年1月24日
    KKKさん (02/19 02:30)
    「追伸です。\nネットで調べたらマイクロソ...」
  • link 24年1月24日
    KKKさん (02/19 02:25)
    「私もエラーで困ってます\n手動での回復パ...」

最近の記事3件

  • link 24年3月19日
    すずき (03/20 02:52)
    「[モジュラージャックの規格] 古くは電話線で、今だとEthernetで良く見かけるモジュラージャックというコネクタとレセプタク...」
  • link 23年4月10日
    すずき (03/19 11:48)
    「[Linux - まとめリンク] 目次: Linuxカーネル、ドライバ関連。Linuxのstruct pageって何?Linu...」
  • link 24年3月18日
    すずき (03/19 11:47)
    「[画面のブランクを無効にする] 目次: LinuxROCK 3 model CのDebian bullseyeイメージは10分...」
link もっとみる

こんてんつ

open/close wiki
open/close Linux JM
open/close Java API

過去の日記

open/close 2002年
open/close 2003年
open/close 2004年
open/close 2005年
open/close 2006年
open/close 2007年
open/close 2008年
open/close 2009年
open/close 2010年
open/close 2011年
open/close 2012年
open/close 2013年
open/close 2014年
open/close 2015年
open/close 2016年
open/close 2017年
open/close 2018年
open/close 2019年
open/close 2020年
open/close 2021年
open/close 2022年
open/close 2023年
open/close 2024年
open/close 過去日記について

その他の情報

open/close アクセス統計
open/close サーバ一覧
open/close サイトの情報

合計:  counter total
本日:  counter today

link About www2.katsuster.net
RDFファイル RSS 1.0

最終更新: 03/20 02:52