[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[fol] Re: Incorrectly built binary which accesses errno or h_errno directly. Needs to be fixed. を消すに は?


kono@xxxxxxxxxxxxxxxxx (Shinji KONO) writes:

> > > 普通は、thread local な領域にerrnoに相当するものを作る
> > > と思う。
> > だから、その通りになったのでは?
> 
> binary 互換をやぶるような実装になったのは、納得できないです〜

binary 互換は不可能では。API変えちゃったらソース互換でさえなくなります
よね。

# つーか、もともとANSI/ISO Cでは「errnoはマクロかもしれんから、errno.h
# を必ずインクルードしろよ」となってるわけで。
# glibc開発者がどっかに書いてましたが、「バグのあるアプリを永久にサポー
# トし続けるなんてできない」ということでしょう。

> つうか検出できるんだったら、対応しろよ...

グローバル変数を参照する機械語でthread specific dataを参照するようにす
るのは、ライブラリレベルじゃ無理じゃないですかねー。

> で、結局、どうしようかな.... glibc を元に戻せっていう意見が
> 結構あって、ターゲットプログラムだけ、そうするっていう手も
> あるんですが...

んー、まあそれが安全かもしれませんね。他の手段だと、ライブラリは「本物」
のerrnoを参照してるのに、アプリ側は全く別のものを読み書きしちゃってる
わけだから。
				前田敦司

$B$3$N>pJs$,$"$J$?$NC5$7$F$$?$b$N$+$I$&$+A*Br$7$F$/$@$5$!#(B
yes/$B$^$5$K$3$l$@!*(B   no/$B0c$&$J$!(B   part/$B0lIt8+$D$+$C$?(B   try/$B$3$l$G;n$7$F$_$k(B

$B$"$J$?$,C5$7$F$$?>pJs$O$I$N$h$&$J$3$H$+!"$4<+M3$K5-F~2<$5$!#FC$K!V$^$5$K$3$l$@!*!W$H8@$&>l9g$O5-F~$r$*4j$$7$^$9!#(B
$BNc(B:$B!VJ#?t$N%^%7%s$+$i(BCATV$B7PM3$G(Bipmasquerade$B$rMxMQ$7$F(BWeb$B$r;2>H$7$?$>l9g$N@_Dj$K$D$$F!W(B
References: