史上最強かもしれなかったツール、GCC(GNU Compiler Collection)について語るスレ。
GNU本家のGCCページ
http://gcc.gnu.org/
Binutils - Collection of binary utilities ←これも必要だぞ。
http://www.gnu.org/directory/GNU/binutils.html
GNU Binutils
http://sources.redhat.com/binutils/
GCC online documentation
http://gcc.gnu.org/onlinedocs/
Installing GCC
http://gcc.gnu.org/install/
GCC Timeline
http://gcc.gnu.org/releases.html#timeline
Calendar
http://gcc.gnu.org/develop.html#timeline
前スレ
GCCについて part9
http://hibari.2ch.net/test/read.cgi/tech/1246059290/
関連スレ
【最速へ】LowLevelVirtualMachine【LLVM】
http://hibari.2ch.net/test/read.cgi/tech/1211547655/
探検
GCCについて part10
■ このスレッドは過去ログ倉庫に格納されています
2011/09/03(土) 14:13:04.14
264デフォルトの名無しさん
2013/03/11(月) 09:38:08.17 俺も俺も
265デフォルトの名無しさん
2013/03/17(日) 14:29:39.93 すいません、これでできました
su
mkdir /w; mkdir /w/gcc; cd /w/gcc
wget http://ftp.tsukuba.wide.ad.jp/software/gcc/releases/gcc-4.7.2/gcc-4.7.2.tar.bz2
wget ftp://ftp.gmplib.org/pub/gmp/gmp-5.1.1.tar.bz2
wget http://www.mpfr.org/mpfr-current/mpfr-3.1.2.tar.bz2
wget http://core.ring.gr.jp/pub/GNU/mpc/mpc-1.0.1.tar.gz
tar xvfj gcc-4.7.2.tar.bz2
tar xvfj gmp-5.1.1.tar.bz2
tar xvfj mpfr-3.1.2.tar.bz2
tar xvfz mpc-1.0.1.tar.gz
mkdir gcc-4.7.2/build
mkdir gmp-5.1.1/build
mkdir mpfr-3.1.2/build
mkdir mpc-1.0.1/build
cd gmp-5.1.1/build
../configure --enable-cxx
make
#make install
cd ../../mpfr-3.1.2/build
../configure
make
#make install
cd ../../mpc-1.0.1/build
../configure
make
#make install
cd ../../gcc-4.7.2/build
../configure --enable-languages=c,c++ --enable-cxx --with-newlib --disable-multilib --enable-threads=posix --with-tune=amdfam10
export LD_LIBRARY_PATH=/usr/local/lib64
make
#make install
su
mkdir /w; mkdir /w/gcc; cd /w/gcc
wget http://ftp.tsukuba.wide.ad.jp/software/gcc/releases/gcc-4.7.2/gcc-4.7.2.tar.bz2
wget ftp://ftp.gmplib.org/pub/gmp/gmp-5.1.1.tar.bz2
wget http://www.mpfr.org/mpfr-current/mpfr-3.1.2.tar.bz2
wget http://core.ring.gr.jp/pub/GNU/mpc/mpc-1.0.1.tar.gz
tar xvfj gcc-4.7.2.tar.bz2
tar xvfj gmp-5.1.1.tar.bz2
tar xvfj mpfr-3.1.2.tar.bz2
tar xvfz mpc-1.0.1.tar.gz
mkdir gcc-4.7.2/build
mkdir gmp-5.1.1/build
mkdir mpfr-3.1.2/build
mkdir mpc-1.0.1/build
cd gmp-5.1.1/build
../configure --enable-cxx
make
#make install
cd ../../mpfr-3.1.2/build
../configure
make
#make install
cd ../../mpc-1.0.1/build
../configure
make
#make install
cd ../../gcc-4.7.2/build
../configure --enable-languages=c,c++ --enable-cxx --with-newlib --disable-multilib --enable-threads=posix --with-tune=amdfam10
export LD_LIBRARY_PATH=/usr/local/lib64
make
#make install
266デフォルトの名無しさん
2013/03/17(日) 15:08:52.01 あ、↑の #make install は make install でございますれば
で、
../configure --enable-languages=java --with-newlib --disable-multilib --enable-threads=posix --disable-bootstrap
とするとコケて、どうしても Java コンパイラが作れないです
libtool: compile: /w/gcc/gcc-4.7.2/build_java/./gcc/xgcc -shared-libgcc
---snip---
java/net/.deps/natVMInetAddress.Tpo -c java/net/natVMInetAddress.cc -fPIC -DPIC -o java/net/.libs/natVMInetAddress.o
java/net/natVMInetAddress.cc:42:52: error: declaration of C function ‘int gethostname(char*, int)’ conflicts with
In file included from java/net/natVMInetAddress.cc:12:0:
/usr/include/unistd.h:845:12: error: previous declaration ‘int gethostname(char*, size_t)’ here
make[3]: *** [java/net/natVMInetAddress.lo] Error 1
Web 検索しても、なぜかコケて回避できないみたいな記述があったような無かったような
で、
../configure --enable-languages=java --with-newlib --disable-multilib --enable-threads=posix --disable-bootstrap
とするとコケて、どうしても Java コンパイラが作れないです
libtool: compile: /w/gcc/gcc-4.7.2/build_java/./gcc/xgcc -shared-libgcc
---snip---
java/net/.deps/natVMInetAddress.Tpo -c java/net/natVMInetAddress.cc -fPIC -DPIC -o java/net/.libs/natVMInetAddress.o
java/net/natVMInetAddress.cc:42:52: error: declaration of C function ‘int gethostname(char*, int)’ conflicts with
In file included from java/net/natVMInetAddress.cc:12:0:
/usr/include/unistd.h:845:12: error: previous declaration ‘int gethostname(char*, size_t)’ here
make[3]: *** [java/net/natVMInetAddress.lo] Error 1
Web 検索しても、なぜかコケて回避できないみたいな記述があったような無かったような
267デフォルトの名無しさん
2013/03/17(日) 15:44:56.69 あー、
../configure --enable-languages=java --disable-multilib --disable-bootstrap
にしたらコンパイルできますた
が、実際に .java ファイルをコンパイルしようとすると
gcc: error trying to exec 'ecj1': execvp: No such file or directory
とか怒られる
ググったらこんな感じ
http://barutan.s296.xrea.com/cgi-bin/tdiary/?date=20100220#p04
お手上げでしょか?
../configure --enable-languages=java --disable-multilib --disable-bootstrap
にしたらコンパイルできますた
が、実際に .java ファイルをコンパイルしようとすると
gcc: error trying to exec 'ecj1': execvp: No such file or directory
とか怒られる
ググったらこんな感じ
http://barutan.s296.xrea.com/cgi-bin/tdiary/?date=20100220#p04
お手上げでしょか?
268デフォルトの名無しさん
2013/03/17(日) 16:31:58.39 ecj1って、eclipse関連のパッケージみたいだね。
https://launchpad.net/ubuntu/+source/ecj/3.5.1-6
https://launchpad.net/ubuntu/+source/ecj/3.5.1-6
269デフォルトの名無しさん
2013/03/17(日) 16:41:06.65 GCJ使うのが目標だったのね。
ディストリビューションのspecファイル参考にするといいんじゃないかな。
ディストリビューションのspecファイル参考にするといいんじゃないかな。
270デフォルトの名無しさん
2013/03/20(水) 09:53:14.28 4.8.0リリース?
271デフォルトの名無しさん
2013/03/20(水) 19:02:05.70 リリースアナウンス出てないからまだだろう
272デフォルトの名無しさん
2013/03/21(木) 12:32:55.08 gcc 4.8.0をmakeしようとしたらこんなの出ました。
この前にmakeをビルドしたのですが、makeのビルドに失敗したって意味でしょうか?
http://www.07ch.net/up2/src/lena8828.png
この前にmakeをビルドしたのですが、makeのビルドに失敗したって意味でしょうか?
http://www.07ch.net/up2/src/lena8828.png
273デフォルトの名無しさん
2013/03/21(木) 16:35:57.64 makefileの1〜6行目を晒すとか
274デフォルトの名無しさん
2013/03/21(木) 16:42:10.00 makeで始める行はmakeコマンドが出力してる。[n]はネストの深さ。
エラーが起きているのはシェルにコマンド行で渡して実行させているコード。
EOFが出てるのは、Win32上で有名な
> [Please ignore a syntax error on the next line - it is intentional]
じゃないんだな。この部分は出てないので。
エラーが起きているのはシェルにコマンド行で渡して実行させているコード。
EOFが出てるのは、Win32上で有名な
> [Please ignore a syntax error on the next line - it is intentional]
じゃないんだな。この部分は出てないので。
275デフォルトの名無しさん
2013/03/21(木) 19:49:40.74 http://www.07ch.net/up2/src/lena8830.png
すみません。今見たらbuild/libiberty/config.logにNo such file or directoryと書いてありました。
ぐぐってみます。
ありがとうございました。
すみません。今見たらbuild/libiberty/config.logにNo such file or directoryと書いてありました。
ぐぐってみます。
ありがとうございました。
276275
2013/03/22(金) 11:21:05.10 しつこくてすみません
MinGWにpthreadsをインストールしてgcc 4.8.0をコンパイルしようとしたのですが、sys/systemcfg.hが無いといわれて
ググったのですが、見当たらないのでwinpthreadsをコンパイルしようとしたのですが、makeでエラーになります。
http://www.07ch.net/up2/src/lena8836.png
configureもmakeも改変せずにビルドしているのですが、makeが存在していないファイルを作ろうとしていてmakefileに問題があるのでしょうか?
MinGWにpthreadsをインストールしてgcc 4.8.0をコンパイルしようとしたのですが、sys/systemcfg.hが無いといわれて
ググったのですが、見当たらないのでwinpthreadsをコンパイルしようとしたのですが、makeでエラーになります。
http://www.07ch.net/up2/src/lena8836.png
configureもmakeも改変せずにビルドしているのですが、makeが存在していないファイルを作ろうとしていてmakefileに問題があるのでしょうか?
277デフォルトの名無しさん
2013/03/22(金) 13:45:00.07 windowsでは無理
278デフォルトの名無しさん
2013/03/23(土) 01:57:39.27 GCC 4.8.0 released [2013-03-22]
279275
2013/03/23(土) 10:20:20.80 しつこくてすみません
make[1]: *** `src/libwinpthread_la-barrier.lo' に必要なターゲット `src/.dirstamp' を make するルールがありません. 中止.
make: *** [all] エラー 2
となるんですがmakefileの該当部分は
libdummy.la: $(libdummy_la_OBJECTS) $(libdummy_la_DEPENDENCIES)
$(LINK) $(libdummy_la_OBJECTS) $(libdummy_la_LIBADD) $(LIBS)
src/$(am__dirstamp):
@$(MKDIR_P) src
@: > src/$(am__dirstamp)
src/$(DEPDIR)/$(am__dirstamp):
@$(MKDIR_P) src/$(DEPDIR)
@: > src/$(DEPDIR)/$(am__dirstamp)
src/libwinpthread_la-barrier.lo: src/$(am__dirstamp) \
src/$(DEPDIR)/$(am__dirstamp)
これでは.dirstampは作れていないのでしょうか?
make[1]: *** `src/libwinpthread_la-barrier.lo' に必要なターゲット `src/.dirstamp' を make するルールがありません. 中止.
make: *** [all] エラー 2
となるんですがmakefileの該当部分は
libdummy.la: $(libdummy_la_OBJECTS) $(libdummy_la_DEPENDENCIES)
$(LINK) $(libdummy_la_OBJECTS) $(libdummy_la_LIBADD) $(LIBS)
src/$(am__dirstamp):
@$(MKDIR_P) src
@: > src/$(am__dirstamp)
src/$(DEPDIR)/$(am__dirstamp):
@$(MKDIR_P) src/$(DEPDIR)
@: > src/$(DEPDIR)/$(am__dirstamp)
src/libwinpthread_la-barrier.lo: src/$(am__dirstamp) \
src/$(DEPDIR)/$(am__dirstamp)
これでは.dirstampは作れていないのでしょうか?
280275
2013/03/23(土) 10:27:04.93 くっつけるerr.logを間違えました上の部分のエラーログは
process_begin: CreateProcess(NULL, /bin/mkdir -p src, ...) failed.
make (e=2): 指定されたファイルが見つかりません。
make[1]: *** [src/.dirstamp] エラー 2
make: *** [all] エラー 2
こちらです
process_begin: CreateProcess(NULL, /bin/mkdir -p src, ...) failed.
make (e=2): 指定されたファイルが見つかりません。
make[1]: *** [src/.dirstamp] エラー 2
make: *** [all] エラー 2
こちらです
281275
2013/03/23(土) 10:57:48.87 cd src
touch .dirstamp
cd .deps
touch .dirstamp
したらmakeできました
お騒がせしました
touch .dirstamp
cd .deps
touch .dirstamp
したらmakeできました
お騒がせしました
282デフォルトの名無しさん
2013/03/25(月) 12:34:35.28 4.8で動かなくなる奴たくさんありそうだな
普通の実行順序で考えると動きそうだし
たまたまローカル変数ですべて収まってたから、
過度に最適化されたのかな?
普通の実行順序で考えると動きそうだし
たまたまローカル変数ですべて収まってたから、
過度に最適化されたのかな?
283デフォルトの名無しさん
2013/03/25(月) 12:48:29.38 SPECのコードが壊れた話?
C言語は高級アセンブラで、思った通りの機械語コードを吐いてくれる、
なんてのが昔話だと、いい加減みんな認識すべきなんだな。
現代のC言語は、最適化オプション付けていて、未定義を踏んでたら
悪魔と契約してでも最適化を掛けてくるもんだ、と思うべき。
C言語は高級アセンブラで、思った通りの機械語コードを吐いてくれる、
なんてのが昔話だと、いい加減みんな認識すべきなんだな。
現代のC言語は、最適化オプション付けていて、未定義を踏んでたら
悪魔と契約してでも最適化を掛けてくるもんだ、と思うべき。
284デフォルトの名無しさん
2013/03/25(月) 12:53:58.03 日本語でどうぞ
285デフォルトの名無しさん
2013/03/25(月) 13:01:18.08 壊れるようなコードを書いているやつが悪い
286デフォルトの名無しさん
2013/03/25(月) 13:26:59.99 >>284
このスレでこの程度のジャーゴンもわからないとか。
このスレでこの程度のジャーゴンもわからないとか。
287デフォルトの名無しさん
2013/03/25(月) 13:55:39.89 >>286
単語の問題ではなく文法の問題では?
単語の問題ではなく文法の問題では?
288デフォルトの名無しさん
2013/03/25(月) 14:46:33.36 brokenな日本語でも日本語の話者ならば補って理解できる。
289デフォルトの名無しさん
2013/03/25(月) 21:04:51.78 実行される可能性がある未定義動作のコードが一行でも混じっていれば
そのプログラムは起動直後からソースコードを一切無視してどういうふるまいをしても構わない。
過度の最適化ではない。
そのプログラムは起動直後からソースコードを一切無視してどういうふるまいをしても構わない。
過度の最適化ではない。
290デフォルトの名無しさん
2013/03/25(月) 22:16:03.70291デフォルトの名無しさん
2013/03/25(月) 23:31:42.31 罵倒遊びも飽きた
292デフォルトの名無しさん
2013/03/28(木) 12:01:59.57 4.8、動かない以前にビルド通らんのが出てきたぞ
バージョン上がる度に型チェック厳しくなる一方だぜ
バージョン上がる度に型チェック厳しくなる一方だぜ
293デフォルトの名無しさん
2013/04/02(火) 05:44:55.99 http://gcc.gnu.org/projects/cxx0x.html
Rvalue references for *this : GCC 4.8.1
Rvalue references for *this : GCC 4.8.1
294デフォルトの名無しさん
2013/04/06(土) 15:49:25.58 fast-mathオプションをつけるとisnanが機能しなくなるのだけど、何かいい手はない?
295デフォルトの名無しさん
2013/04/06(土) 16:06:06.33 そのファイルだけfast-mathを外してコンパイルする。
と、どうなるか試してほしい。
と、どうなるか試してほしい。
296デフォルトの名無しさん
2013/04/06(土) 16:45:32.27 fast-mathつけなければ大丈夫。
fast-mathをつけると、isnan以外にも、a != aで判定する方法もダメ。
何かいい方法ないかな
fast-mathをつけると、isnan以外にも、a != aで判定する方法もダメ。
何かいい方法ないかな
297デフォルトの名無しさん
2013/04/06(土) 16:57:51.17 -ffast-math をばらして必要なオプションだけを指定してみたら?
-ffast-math
Sets -fno-math-errno, -funsafe-math-optimizations,
-fno-trapping-math, -ffinite-math-only, -fno-rounding-math, -fno-signaling-nans and fcx-limited-range.
-ffast-math
Sets -fno-math-errno, -funsafe-math-optimizations,
-fno-trapping-math, -ffinite-math-only, -fno-rounding-math, -fno-signaling-nans and fcx-limited-range.
298デフォルトの名無しさん
2013/04/06(土) 22:18:43.85 -ffast-math -fno-finite-math-only の併用でok
299デフォルトの名無しさん
2013/04/08(月) 21:00:04.38 4.8ビルドしようとするとgccでintl-printと__printf__が不明と怒られる
仕方ないのでconfig.hに#include <libintl.h>を書き足すと>>255と同じ事
言われて怒られる、しかしgmp等はインスト済み
これってx64のライブラリ以外にx86のライブラリも必要って事なのかな?
仕方ないのでconfig.hに#include <libintl.h>を書き足すと>>255と同じ事
言われて怒られる、しかしgmp等はインスト済み
これってx64のライブラリ以外にx86のライブラリも必要って事なのかな?
300デフォルトの名無しさん
2013/04/08(月) 22:29:24.61301デフォルトの名無しさん
2013/04/08(月) 23:18:38.75 レスありがとう!
んでも
64ビットのWindowsおよびgccだけSJLJ例外の32ビットベースのmultilibの
バージョンについては#エラーがサポートされています。
って怒られた。。。ウチの環境はWin7x64、gccはTDM64です
configureはこれ
LIBS="-lintl -liconv " ../gcc-4.8-20130404/configure --prefix=/usr/gcc \
--build=x86_64-w64-mingw32 --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 \
--with-tune=generic --enable-threads=posix --disable-multilib --enable-static \
--enable-languages=c,c++,objc,obj-c++ --enable-libgomp --disable-sjlj-exceptions \
--with-dwarf2 --enable-version-specific-runtime-libs --disable-win32-registry \
--disable-werror --disable-nls --enable-lto --with-system-zlib \
--enable-libstdcxx-debug --enable-cxx-flags='-fno-function-sections -fno-data-sections' \
--enable-fully-dynamic-string --disable-libstdcxx-pch --disable-bootstrap \
--with-mpc-lib=/usr/tool/lib --with-mpc-include=/usr/tool/include \
--with-mpfr-include=/usr/tool/include --with-mpfr-lib=/usr/tool/lib \
--with-gmp-include=/usr/tool/include --with-gmp-lib=/usr/tool/lib \
--with-cloog-include=/usr/tool/include --with-cloog-lib=/usr/tool/lib \
--with-isl-include=/usr/tool/include --with-isl-lib=/usr/tool/lib
--disable-multilibを消しても、やっぱりx64云々で蹴られますた
ってかconfigureのログ見てると、intl=ok, iconv=okって言ってるのになんで
intlの関数が不明って言われるのかなあ。
んでも
64ビットのWindowsおよびgccだけSJLJ例外の32ビットベースのmultilibの
バージョンについては#エラーがサポートされています。
って怒られた。。。ウチの環境はWin7x64、gccはTDM64です
configureはこれ
LIBS="-lintl -liconv " ../gcc-4.8-20130404/configure --prefix=/usr/gcc \
--build=x86_64-w64-mingw32 --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 \
--with-tune=generic --enable-threads=posix --disable-multilib --enable-static \
--enable-languages=c,c++,objc,obj-c++ --enable-libgomp --disable-sjlj-exceptions \
--with-dwarf2 --enable-version-specific-runtime-libs --disable-win32-registry \
--disable-werror --disable-nls --enable-lto --with-system-zlib \
--enable-libstdcxx-debug --enable-cxx-flags='-fno-function-sections -fno-data-sections' \
--enable-fully-dynamic-string --disable-libstdcxx-pch --disable-bootstrap \
--with-mpc-lib=/usr/tool/lib --with-mpc-include=/usr/tool/include \
--with-mpfr-include=/usr/tool/include --with-mpfr-lib=/usr/tool/lib \
--with-gmp-include=/usr/tool/include --with-gmp-lib=/usr/tool/lib \
--with-cloog-include=/usr/tool/include --with-cloog-lib=/usr/tool/lib \
--with-isl-include=/usr/tool/include --with-isl-lib=/usr/tool/lib
--disable-multilibを消しても、やっぱりx64云々で蹴られますた
ってかconfigureのログ見てると、intl=ok, iconv=okって言ってるのになんで
intlの関数が不明って言われるのかなあ。
302デフォルトの名無しさん
2013/04/08(月) 23:45:08.36 消すなら --disable-multilib ではなくて --disable-sjlj-exceptions だろjk
あと、もし binutils を一緒にビルドしようとして、
gcc のフォルダ内に binutils/{なんやらかんやら} へのリンクを張ってるなら、
両者に共通のライブラリが、バージョン違って失敗するかも
あと、もし binutils を一緒にビルドしようとして、
gcc のフォルダ内に binutils/{なんやらかんやら} へのリンクを張ってるなら、
両者に共通のライブラリが、バージョン違って失敗するかも
303デフォルトの名無しさん
2013/04/09(火) 00:07:40.47 消したけどダメ。。
ターゲット・ホスト・ビルドのx86_64-w64を消さないとどうしても
「はぁ?x64?」みたいな事言われるので消して、それでもintlで文句言われて
config.hに<linintl.h>書き加えてビルド進めるとlibgccで
Assembler messages:
Error: invalid instruction suffix for `push'
アセンブラ関連のエラーだと思うんだけど、ターゲットをx86_64-w64にすると怒
られ、libintlで怒られ…gccサイトのQ&A見ても「我々は悪くない、文句言われる
テメーが悪い」みたいな事書いてあるし。。。。
もうネルソン!
ターゲット・ホスト・ビルドのx86_64-w64を消さないとどうしても
「はぁ?x64?」みたいな事言われるので消して、それでもintlで文句言われて
config.hに<linintl.h>書き加えてビルド進めるとlibgccで
Assembler messages:
Error: invalid instruction suffix for `push'
アセンブラ関連のエラーだと思うんだけど、ターゲットをx86_64-w64にすると怒
られ、libintlで怒られ…gccサイトのQ&A見ても「我々は悪くない、文句言われる
テメーが悪い」みたいな事書いてあるし。。。。
もうネルソン!
304デフォルトの名無しさん
2013/04/09(火) 22:43:32.74 やっとでけたあああ
七誌さんそして>>300ありがとう!
一応手順
gcc用のディレクトリを作成、binutilsをビルド→インストール
gccをコンパイラのみビルドしてinstall-gcc
ここでmsys上のmingwを今作ったgccに切り替え
mingw-w64ランタイムをヘッダのみビルド→インストール
ランタイムをビルド→インストール
gccの残りをビルド→インストール
今まで通常使ってるmingwだけでビルドしようとしてたのが間違ってた?っぽい
七誌さんそして>>300ありがとう!
一応手順
gcc用のディレクトリを作成、binutilsをビルド→インストール
gccをコンパイラのみビルドしてinstall-gcc
ここでmsys上のmingwを今作ったgccに切り替え
mingw-w64ランタイムをヘッダのみビルド→インストール
ランタイムをビルド→インストール
gccの残りをビルド→インストール
今まで通常使ってるmingwだけでビルドしようとしてたのが間違ってた?っぽい
305デフォルトの名無しさん
2013/04/09(火) 22:49:25.32 なんだかよく分からなかったけど強引に潰したエラー、3件
1.↓って言われる
i386/cygming.h:358:2: error: #error For 64-bit windows and 32-bit based multilib version of gcc just SJLJ exceptions are supported.
i386/mingw32.h:101:2: error: #error DW2 unwind is not available for 64-bit.
i386/cygming.h:358:2: error: #error For 64-bit windows and 32-bit based multilib version of gcc just SJLJ exceptions are supported.
i386/mingw32.h:101:2: error: #error DW2 unwind is not available for 64-bit.
i386/cygming.h:358:2: error: #error For 64-bit windows and 32-bit based multilib version of gcc just SJLJ exceptions are supported.
i386/mingw32.h:101:2: error: #error DW2 unwind is not available for 64-bit.
コメントアウト
2.
intl_printが不明
config.hに<libintl.h>を書き足す
3.
libstdc++-v3/include/bits/basic_string.hでエラー
call googleで外人さんのパッチをクローン
+++ ./libstdc++-v3/config/os/mingw32-w64/os_defines.h
+#include <_mingw_mac.h>
+#if !defined (__MINGW64_VERSION_MAJOR) || (__MINGW64_VERSION_MAJOR < 3)
#define _GLIBCXX_HAVE_BROKEN_VSWPRINTF 1
+#endif
3は、なんだか公式のmingw32使えみたいな事言ってた気がするけど1.2が分からんち
特に2番、なんでヘッダを要求されるのか。公式になんか書いても怖い人しかいないよう
な雰囲気なので聞けない。。。
グダグダ書いたけど結局は>>302のbinutils云々がヒントになってビルド出来た、ありがとね
1.↓って言われる
i386/cygming.h:358:2: error: #error For 64-bit windows and 32-bit based multilib version of gcc just SJLJ exceptions are supported.
i386/mingw32.h:101:2: error: #error DW2 unwind is not available for 64-bit.
i386/cygming.h:358:2: error: #error For 64-bit windows and 32-bit based multilib version of gcc just SJLJ exceptions are supported.
i386/mingw32.h:101:2: error: #error DW2 unwind is not available for 64-bit.
i386/cygming.h:358:2: error: #error For 64-bit windows and 32-bit based multilib version of gcc just SJLJ exceptions are supported.
i386/mingw32.h:101:2: error: #error DW2 unwind is not available for 64-bit.
コメントアウト
2.
intl_printが不明
config.hに<libintl.h>を書き足す
3.
libstdc++-v3/include/bits/basic_string.hでエラー
call googleで外人さんのパッチをクローン
+++ ./libstdc++-v3/config/os/mingw32-w64/os_defines.h
+#include <_mingw_mac.h>
+#if !defined (__MINGW64_VERSION_MAJOR) || (__MINGW64_VERSION_MAJOR < 3)
#define _GLIBCXX_HAVE_BROKEN_VSWPRINTF 1
+#endif
3は、なんだか公式のmingw32使えみたいな事言ってた気がするけど1.2が分からんち
特に2番、なんでヘッダを要求されるのか。公式になんか書いても怖い人しかいないよう
な雰囲気なので聞けない。。。
グダグダ書いたけど結局は>>302のbinutils云々がヒントになってビルド出来た、ありがとね
306デフォルトの名無しさん
2013/04/09(火) 23:22:10.38 追記:libintlがぶっこわれてた
今までどうやってビルド通ってたんだろ・・・・・・・・・
今までどうやってビルド通ってたんだろ・・・・・・・・・
307デフォルトの名無しさん
2013/04/10(水) 12:19:18.40 馬鹿には無理
308デフォルトの名無しさん
2013/04/13(土) 12:00:07.40 ネタじゃないので聞いてください。
一番最初のgccはどのようにコンパイルされたのですか?
一番最初のgccはどのようにコンパイルされたのですか?
309デフォルトの名無しさん
2013/04/13(土) 13:04:09.04 別のコンパイラを使う。UNIXのccとか。
歴史の話じゃなくて実用的な意味でどうするかといえば、
オフィシャルでバイナリのgccが配布されているのでそれを使う。
歴史の話じゃなくて実用的な意味でどうするかといえば、
オフィシャルでバイナリのgccが配布されているのでそれを使う。
310デフォルトの名無しさん
2013/04/13(土) 13:12:18.33 最初のGCCはCで書かれていたわけでは無いらしい
311デフォルトの名無しさん
2013/04/13(土) 13:13:20.52 ネタじゃないので聞いてください。
一番最初のccはどのようにコンパイルされたのですか?
一番最初のccはどのようにコンパイルされたのですか?
312デフォルトの名無しさん
2013/04/13(土) 13:25:22.63 最初のコンパイラは機械語で書いた
313デフォルトの名無しさん
2013/04/13(土) 14:56:44.41 最初のコンパイラはA-0 Systemらしい。
314デフォルトの名無しさん
2013/04/13(土) 18:04:08.51 gccをどうやってコンパイルするかを勉強してると
そのあたりまで平然と遡らされるよな
そのあたりまで平然と遡らされるよな
315デフォルトの名無しさん
2013/04/13(土) 18:20:46.26 Z80アセンブラをN88-BASICで実装しようとしたのは良い思い出…
316デフォルトの名無しさん
2013/04/13(土) 23:18:45.40317デフォルトの名無しさん
2013/04/14(日) 00:00:12.33 >>316
どこまで遡れるか大会だろ空気嫁よ
どこまで遡れるか大会だろ空気嫁よ
318デフォルトの名無しさん
2013/04/14(日) 05:34:33.84 ネタじゃないので聞いてください。
一番最初のアセンブラはどのようにアセンブルされたのですか?
一番最初のアセンブラはどのようにアセンブルされたのですか?
319デフォルトの名無しさん
2013/04/14(日) 05:50:10.27 ネタじゃないならアセンブラスレで訊きましょう
320デフォルトの名無しさん
2013/04/14(日) 10:08:15.61 2chは優秀な技術者が議論する場所
321デフォルトの名無しさん
2013/04/14(日) 10:54:15.95 >>318
ハンドアセンブル
ハンドアセンブル
322デフォルトの名無しさん
2013/04/14(日) 11:37:22.44 multilib有効にしてGCCビルドしたら、ライブラリビルドでldちゃんが
32ライブラリに64libを合体させてしまいまする
export -m32 -L/lib32 とかにしても言う事を聞いてくれませぬ
ググっても、バカには無理みたいな風潮
TDMとか、どうやってmultilibなGCCビルドしてるんだろ?
32ライブラリに64libを合体させてしまいまする
export -m32 -L/lib32 とかにしても言う事を聞いてくれませぬ
ググっても、バカには無理みたいな風潮
TDMとか、どうやってmultilibなGCCビルドしてるんだろ?
323デフォルトの名無しさん
2013/05/08(水) 21:32:17.28 gccの2.95.3なんですが、
gccがコンパイルされたときの./configureに渡された設定など
調べる方法は無いでしょうか?
gccがコンパイルされたときの./configureに渡された設定など
調べる方法は無いでしょうか?
324デフォルトの名無しさん
2013/05/09(木) 02:22:37.84 gcc -vは?
どうでもいいことだが、なぜそんな化石を使うのか聞いてみたい
どうでもいいことだが、なぜそんな化石を使うのか聞いてみたい
325デフォルトの名無しさん
2013/05/22(水) 15:12:42.53 gccで、以下のような情報を得るためのコマンドラインオプション、あるいは
ツール・手段はありませんでしょうか?
知りたいのは、どういう過程でライブラリがリンクされているかです。
例えば、main.cでprintf()が使われている時、
(1) main.o には未解決のシンボル'printf'がある
(2) 未解決シンボル'printf'を解決するため、libc.a 内の lib_a-printf.o をリンクした
(3) さらに lib_a-printf.o には未解決のシンボル'vfprintf'がある
(4) 未解決シンボル'vfprintf'を解決するため、libc.a 内の lib_a-vfprintf.o をリンクした
(5) さらに lib_a-vfprintf.o には未解決のシンボル・・・・
:
のような情報が得たいのです。
目的は、組み込み用でコードサイズ小さくしたい場合に、想定外のライブラリがリンク
されているような場合、何が起点になっているかを調べるためです。
(例えば、標準入出力は使ってないのに標準入出力関係のライブラリがごっそりリンクさ
れてしまう場合に、sprintf()→vfprintf()→・・・と、sprintf()を使っているのが原因
であることを知りたい)
-Wl,--verbose は試してみましたが、ダメでした。
ツール・手段はありませんでしょうか?
知りたいのは、どういう過程でライブラリがリンクされているかです。
例えば、main.cでprintf()が使われている時、
(1) main.o には未解決のシンボル'printf'がある
(2) 未解決シンボル'printf'を解決するため、libc.a 内の lib_a-printf.o をリンクした
(3) さらに lib_a-printf.o には未解決のシンボル'vfprintf'がある
(4) 未解決シンボル'vfprintf'を解決するため、libc.a 内の lib_a-vfprintf.o をリンクした
(5) さらに lib_a-vfprintf.o には未解決のシンボル・・・・
:
のような情報が得たいのです。
目的は、組み込み用でコードサイズ小さくしたい場合に、想定外のライブラリがリンク
されているような場合、何が起点になっているかを調べるためです。
(例えば、標準入出力は使ってないのに標準入出力関係のライブラリがごっそりリンクさ
れてしまう場合に、sprintf()→vfprintf()→・・・と、sprintf()を使っているのが原因
であることを知りたい)
-Wl,--verbose は試してみましたが、ダメでした。
326デフォルトの名無しさん
2013/05/22(水) 15:23:31.68 man(2)
327デフォルトの名無しさん
2013/05/22(水) 15:25:10.67 lint
329325
2013/05/22(水) 19:12:38.41 >>328
レス、ありがとうございます。
スマートリンクもコードサイズ削減に効果が無くはありませんが、(newlibは結構細かく
ソースが分けてあるので)効果は小さいと思われます。
例えば、newlibの場合newlib内で使用する静的変数を(マルチスレッド対応等が容易なよ
うに)_reent構造体にまとめてありますが、これをリンクするような関数を一つでも使用
してしまうと_reent構造体に関連する関数が多数リンクされ、コードサイズが肥大します。
これは(実行時に呼ばれることは無くても)未定義シンボル解決には必要であり、
-Wl,--gc-sectionsでは防止できません。
コードサイズの肥大の起因となるライブラリ関数が(質問に記述のように)特定でき、これ
がごく少数なら、この関数を使用しないようにプログラムを書き換えてしまえ、という
わけです。
レス、ありがとうございます。
スマートリンクもコードサイズ削減に効果が無くはありませんが、(newlibは結構細かく
ソースが分けてあるので)効果は小さいと思われます。
例えば、newlibの場合newlib内で使用する静的変数を(マルチスレッド対応等が容易なよ
うに)_reent構造体にまとめてありますが、これをリンクするような関数を一つでも使用
してしまうと_reent構造体に関連する関数が多数リンクされ、コードサイズが肥大します。
これは(実行時に呼ばれることは無くても)未定義シンボル解決には必要であり、
-Wl,--gc-sectionsでは防止できません。
コードサイズの肥大の起因となるライブラリ関数が(質問に記述のように)特定でき、これ
がごく少数なら、この関数を使用しないようにプログラムを書き換えてしまえ、という
わけです。
330デフォルトの名無しさん
2013/05/22(水) 19:16:10.03 gccじゃなくてリンカの仕事
例えばAppleのldなら-why_liveとかあるから、とりあえずman ld
例えばAppleのldなら-why_liveとかあるから、とりあえずman ld
331デフォルトの名無しさん
2013/05/22(水) 19:58:13.29 使ってる*.oをnmして未定義シンボルをリストして、
シンボルがどの*.aで定義されてるかnmして調べて、
*.aをar xして*.oにしてnmして、
以下収束するまで繰り返し。
多分機械的に出来るんじゃないか?
Cの場合、使われる*.aは引数で与える必要があって、
最初から全リストが分かってるわけだし。
シンボルがどの*.aで定義されてるかnmして調べて、
*.aをar xして*.oにしてnmして、
以下収束するまで繰り返し。
多分機械的に出来るんじゃないか?
Cの場合、使われる*.aは引数で与える必要があって、
最初から全リストが分かってるわけだし。
332325
2013/05/22(水) 20:31:03.39 >>330
誤解を招く文章ですいません、ld(binutils)を含めてgccと書いていました。
-why_live(https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/ld.1.html)
はまさに欲しているものでしたが、使用しているld(GNU ld version2.15 arm-elf/cygwin
のクロス環境)には実装されていないようでした。
* ld.info(manがなかったので)
* arm-elf-ld --help
* http://sourceware.org/binutils/docs-2.15/ld/Options.html#Options
で、why/live/chain/refferenceなどのキーワードで探してみましたが、同等のものは
見つけられませんでした。
>>331
はい、その方法(それを行うツールの作成)は最後の手段として考えています・・・
誤解を招く文章ですいません、ld(binutils)を含めてgccと書いていました。
-why_live(https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/ld.1.html)
はまさに欲しているものでしたが、使用しているld(GNU ld version2.15 arm-elf/cygwin
のクロス環境)には実装されていないようでした。
* ld.info(manがなかったので)
* arm-elf-ld --help
* http://sourceware.org/binutils/docs-2.15/ld/Options.html#Options
で、why/live/chain/refferenceなどのキーワードで探してみましたが、同等のものは
見つけられませんでした。
>>331
はい、その方法(それを行うツールの作成)は最後の手段として考えています・・・
333デフォルトの名無しさん
2013/05/22(水) 21:59:40.34 ld --help
--cref 相互参照表を出力する
-Wl,--cref
--cref 相互参照表を出力する
-Wl,--cref
335デフォルトの名無しさん
2013/06/01(土) 20:00:59.98 cygwinで gcc 4.8.1 コンパイルしたけど、エラーが2つでてインスコできんわ・・orz
336デフォルトの名無しさん
2013/06/02(日) 11:49:35.35 gcc -S -g で出力されるアセンブルコード中の.locの情報を
該当するCソースに置換するフィルタはどこかで公開してませんか?
該当するCソースに置換するフィルタはどこかで公開してませんか?
337デフォルトの名無しさん
2013/06/02(日) 23:36:32.81 as --help
-a[sub-option...] turn on listings
Sub-options [default hls]:
c omit false conditionals
d omit debugging directives
g include general info
h include high-level source
l include assembly
m include macro expansions
n omit forms processing
s include symbols
=FILE list to FILE (must be last sub-option)
gcc -c -O2 hoge.c -Wa,-ahls=hoge.lst
-a[sub-option...] turn on listings
Sub-options [default hls]:
c omit false conditionals
d omit debugging directives
g include general info
h include high-level source
l include assembly
m include macro expansions
n omit forms processing
s include symbols
=FILE list to FILE (must be last sub-option)
gcc -c -O2 hoge.c -Wa,-ahls=hoge.lst
339デフォルトの名無しさん
2013/06/13(木) 05:42:57.74 gcovの使い方の質問ここでしたらスレチですか?
340デフォルトの名無しさん
2013/06/13(木) 11:06:32.53 profとかcovはいいんじゃない?
341デフォルトの名無しさん
2013/06/14(金) 00:47:14.15 ではお言葉に甘えて。
カバレッジを調べるためgcovすると自分のソース以外の
iostream.gcovとかも大量にできてしまいます。
これを指定のディレクトリ以外は生成しないようにできないものでしょうか?
今のところ-pをつけてファイルを生成し必要のないフォルダのものをrmで消してます。
カバレッジを調べるためgcovすると自分のソース以外の
iostream.gcovとかも大量にできてしまいます。
これを指定のディレクトリ以外は生成しないようにできないものでしょうか?
今のところ-pをつけてファイルを生成し必要のないフォルダのものをrmで消してます。
342デフォルトの名無しさん
2013/06/14(金) 01:08:14.99 gcov --help
-o, --object-directory DIR|FILE オブジェクトファイルを DIR 内または呼び出し用 FILE 内で検索する
-o, --object-directory DIR|FILE オブジェクトファイルを DIR 内または呼び出し用 FILE 内で検索する
343341
2013/06/15(土) 01:10:38.28 >>342
使い方が間違っているのか期待した結果になりませんでした。
srcディレクトリに.h / .ccがあるので -o src と指定しましたがiostream.gcovは生成されました。
objディレクトリに .o があるので -o obj と指定すると
obj/test.gcno:cannot open graph file
といったエラーが表示されます。そこでobjにtest.gcnoをmvすると処理は通りますが
相変わらずiostream.gcovは生成されます。
ただlcovすると.gcovは消えるので気にしなければ済む問題かもしれません。
使い方が間違っているのか期待した結果になりませんでした。
srcディレクトリに.h / .ccがあるので -o src と指定しましたがiostream.gcovは生成されました。
objディレクトリに .o があるので -o obj と指定すると
obj/test.gcno:cannot open graph file
といったエラーが表示されます。そこでobjにtest.gcnoをmvすると処理は通りますが
相変わらずiostream.gcovは生成されます。
ただlcovすると.gcovは消えるので気にしなければ済む問題かもしれません。
344デフォルトの名無しさん
2013/08/06(火) NY:AN:NY.AN345デフォルトの名無しさん
2013/09/13(金) 23:40:52.15 プリプロセッサの話ってここで大丈夫?スレチだったら流して
gccの-EオプションでCライクな言語のプリプロセスかけてるんだけど、そのマクロの記述で
#define get_pi(data) (6'(data)<<3)って感じの記述してて、
これの ' の部分が文字データ記述の開始として扱われてdataが置き換わらないんだけど、対策ないですかね?
gccの-EオプションでCライクな言語のプリプロセスかけてるんだけど、そのマクロの記述で
#define get_pi(data) (6'(data)<<3)って感じの記述してて、
これの ' の部分が文字データ記述の開始として扱われてdataが置き換わらないんだけど、対策ないですかね?
346デフォルトの名無しさん
2013/09/14(土) 00:07:31.67 SystemVerilogかね?
#define s '
#define get_pi(data) (6 s (data)<<3)
空白が入るけど動くよ。警告も出るけど。
規格上問題ないか、どのGCCバージョンでも動くかは分からん。
#define s '
#define get_pi(data) (6 s (data)<<3)
空白が入るけど動くよ。警告も出るけど。
規格上問題ないか、どのGCCバージョンでも動くかは分からん。
347デフォルトの名無しさん
2013/09/14(土) 00:25:12.48348デフォルトの名無しさん
2013/09/14(土) 00:39:13.04349デフォルトの名無しさん
2013/09/14(土) 00:48:05.09 >>348
プリプロセッサってプロトタイプ宣言みたいに上から順に〜ってわけではないのか。一緒だと思ってました
プリプロセッサってプロトタイプ宣言みたいに上から順に〜ってわけではないのか。一緒だと思ってました
350デフォルトの名無しさん
2013/09/14(土) 04:44:31.37 gcc4.9のtrunk版、3ヶ月くらいプラグマバグでビルド出来なかったんだけどようやく修正された
351デフォルトの名無しさん
2013/09/14(土) 10:36:33.97 >>349
いやいや、上から順で正しい。再走査はマクロ展開時の話だよ。
マクロ引数dataが展開された後に、その結果に対して再走査されて
普通の地の文と同じようにsがマクロ展開される。
最初のやつがうまく動かないのは、Cプリプロセッサは文字置き換えでなくて
トークンを置きえるから。
(6'(data)<<3) は (, 6, '(data)<<3) という3つのトークンになってしまう。
いやいや、上から順で正しい。再走査はマクロ展開時の話だよ。
マクロ引数dataが展開された後に、その結果に対して再走査されて
普通の地の文と同じようにsがマクロ展開される。
最初のやつがうまく動かないのは、Cプリプロセッサは文字置き換えでなくて
トークンを置きえるから。
(6'(data)<<3) は (, 6, '(data)<<3) という3つのトークンになってしまう。
352デフォルトの名無しさん
2013/09/14(土) 13:34:26.01 プリプロセッサなんて自作しちゃいなよ
353デフォルトの名無しさん
2013/09/17(火) 16:30:56.00 正確に標準に従ったcppを作るのは案外大変だぞ?
354デフォルトの名無しさん
2013/09/24(火) 00:04:00.29355デフォルトの名無しさん
2013/11/04(月) 10:16:18.31 dev/nullを出力先に指定するとscanfなどで入力した内容が表示されなくなるという噂を聞きました
どのように指定すると良いか教えてください
どのように指定すると良いか教えてください
356デフォルトの名無しさん
2013/11/04(月) 10:35:57.62 >>355
入力した内容なら、必要に応じて"/dev/stderr"(stderr)にでも出力すればいいじゃん。
入力した内容なら、必要に応じて"/dev/stderr"(stderr)にでも出力すればいいじゃん。
357デフォルトの名無しさん
2013/11/04(月) 19:25:05.12 >>355
scanf を実行する前に標準出力を /dev/null につけかえるのでは、pipe(), pipe2() とかで?
scanf を実行する前に標準出力を /dev/null につけかえるのでは、pipe(), pipe2() とかで?
358デフォルトの名無しさん
2013/11/04(月) 19:39:51.62 >>357
意味不明
意味不明
359デフォルトの名無しさん
2013/11/04(月) 21:46:42.94 >>357
はい、そのとおりです。
はい、そのとおりです。
360デフォルトの名無しさん
2013/11/05(火) 14:08:37.22 >>357
pipe2はlinux専用関数だがな
pipe2はlinux専用関数だがな
361デフォルトの名無しさん
2013/11/05(火) 17:17:29.77 >>360
ウイーンドーズにも/dev/nullがあるんですか?
ウイーンドーズにも/dev/nullがあるんですか?
362デフォルトの名無しさん
2013/11/05(火) 17:20:56.19 Windows だと NUL だろ。
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 高市首相の答弁書に「台湾有事答えない」と明記 存立危機発言当時 ★12 [蚤の市★]
- 女性天皇「賛成」69%、将来の皇位継承「不安」68%…読売世論調査 [蚤の市★]
- 不倫疑惑の永野芽郁さん、CM削除ドミノの違約金“やはり発生は免れない”可能性 約10億円になる見込み、本人は全額支払う覚悟 [牛丼★]
- 旧姓使用拡大に連合会長が反発 「何の説明もない。選択的夫婦別氏制度導入を」 男女共同参画会議 ★2 [ぐれ★]
- 開業4ヵ月でこれは…“国民の税金”投入の『ジャングリア沖縄』で見た衝撃的な光景と、モチベーションが低い一部スタッフの現状 ★2 [ぐれ★]
- 【芸能】『女芸人No.1決定戦THE W』 粗品が最後にバッサリ「優勝賞金1000万円にしてはレベル低い大会」 [冬月記者★]
- 【悲報】中学受験、意味がなかった…「中学受験をやっても大部分の子供は無勉で入れるMARCH地方国立大に行くのが精一杯です [483447288]
- ジムでインターバルの時にウロウロ歩くやつなんなの?
- レイプはとっても気持ちがいい
- 【悲報】ドイツ人「なんで日本人って自炊するの?出来合の惣菜や冷食食った方が楽でコスパいいやん。そんなんだから低生産性なんだよ [786648259]
- 大阪行くわよーーーッ!!!
- 近所の騒音おじさんが俺にだけ優しくしてくる
