[#27919] 1.8.4 Preview2 検証 — "URABE Shyouhei aka. mput" <root@...>
卜部です。
まつもと ゆきひろです
[#27944] Ruby 1.8.3 on FreeBSD — Masayoshi Takahashi <maki@...>
高橋征義です。
[#27991] GC.always — Tanaka Akira <akr@...17n.org>
というように、GC を常に動かすというのは GC 関連の問題を発見
まつもと ゆきひろです
In article <1134314081.457781.8573.nullmailer@x31.priv.netlab.jp>,
[#27997] 1.8.4 documents? — "URABE Shyouhei aka. mput" <root@...>
卜部です。
新井です。
新井です。
[#28010] IA64 BSPSTORE — Tanaka Akira <akr@...17n.org>
そういえば、IA64 で gc.c や eval.c に BSPSTORE レジスタの値
まつもと ゆきひろです
In article <1134478762.181062.2779.nullmailer@x31.priv.netlab.jp>,
[#28045] 1.8.4 what remains? — "URABE Shyouhei aka. mput" <root@...>
卜部です。
[#28082] ruby_1_8 Segmentation fault on Cygwin — yanagi@...
柳田です。
山本です。
こんにちは、なかむら(う)です。
山本です。
こんにちは、なかむら(う)です。
柳田です。
山本です。
[#28087] test(?-, file1, file2) — Tanaka Akira <akr@...17n.org>
マニュアルの test(?-, file1, file2) の説明に、
[#28109] Kernel#fail — "URABE Shyouhei aka. mput" <root@...>
さすがにもう誰も使ってないのではないかと思います。Kernel#failは廃止にし
[#28121] post_connection_check with javacc.dev.java.net — Tanaka Akira <akr@...17n.org>
ふと、https://javacc.dev.java.net/ を open-uri でアクセスすると、
[#28127] Intel C++ Compiler and HP aC++/ANSI C on IA64 — Tanaka Akira <akr@...17n.org>
TestDrive で IA64 上の Intel C++ Compiler and HP aC++/ANSI C
渡辺哲也です。
[#28140] ia64-hpux11.23/socket.sl: this executable file can't load extension libraries (LoadError) — Tanaka Akira <akr@...17n.org>
HP-UX で HP aC++/ANSI C を使って作った ruby で、openssl や drb のテストをすると、
渡辺哲也です。
In article <200512280307.jBS37nnj005909@pbsg500.nifty.com>,
In message "[ruby-dev:28142] Re: ia64-hpux11.23/socket.sl: this executable file can't load extension libraries (LoadError)"
山本です。
In article <20051228210640.13C71A10.ocean@m2.ccsnet.ne.jp>,
渡辺哲也です。
山本です。
山本です。
In article <20051229114438.44D19F00.ocean@m2.ccsnet.ne.jp>,
なかだです。
In article <ypvtr77wv7q9.wl%nobuyoshi.nakada@ge.com>,
なかだです。
In article <ypvtoe30v1zk.wl%nobuyoshi.nakada@ge.com>,
なかだです。
In article <ypvtmzikv11x.wl%nobuyoshi.nakada@ge.com>,
なかだです。
In article <ypvtwthol15x.wl%nobuyoshi.nakada@ge.com>,
[#28177] Generator dumps core — "H.Yamamoto" <ocean@...2.ccsnet.ne.jp>
山本です。
[#28178] accessing ruby_cbase (nil) dumps core — SASADA Koichi <ko1@...>
ささだです。
[#28181] zsuper (with define_method) dumps core — SASADA Koichi <ko1@...>
ささだです。
[#28182] generator.rb deadlocks — Tanaka Akira <akr@...17n.org>
RUBY_ALWAYS_GC= つきで test_generator.rb を動かすと deadlock が起きます。
[#28184] test_each(TC_SyncEnumerator) fails. — Tanaka Akira <akr@...17n.org>
deadlock は解決しましたが次のようにテストが失敗します。
[ruby-dev:28110] Re: ruby_1_8 Segmentation fault on Cygwin
山本です。
>>● 例
>>test_parse_headers(TestWEBrickHTTPRequest): /var/tmp/ruby_1_8-src/lib/timeout.rb:52: [BUG] Segmentation fault
>>ruby 1.8.4 (2005-12-21) [i386-cygwin]
>>
>>*** starting debugger for pid 648, tid 1636
>>*** continuing pid 648 from debugger call (1)
>>make: *** [test-all] Aborted (core dumped)
>>% gdb -c test/ruby.exe.core
>>GNU gdb 6.3.50_2004-12-28-cvs (cygwin-special)
>>Copyright 2004 Free Software Foundation, Inc.
>>GDB is free software, covered by the GNU General Public License, and you are
>>welcome to change it and/or distribute copies of it under certain conditions.
>>Type "show copying" to see the conditions.
>>There is absolutely no warranty for GDB. Type "show warranty" for details.
>>This GDB was configured as "i686-pc-cygwin".
>>
>>#0 0x77f88f13 in ntdll!ZwWaitForSingleObject ()
>>(gdb) bt
>>#0 0x77f88f13 in ntdll!ZwWaitForSingleObject ()
>>#1 0x77e7a030 in WaitForSingleObjectEx ()
>>#2 0x77e5b3db in WaitForSingleObject ()
>>#3 0x0000000c in ?? ()
>
>webrick は yaml の前に来るはずなので、yaml の問題ではないようですね。すみません、だとすると
>私にはわかりません。cygwin 特有の問題でしょうか。
[ruby-dev:28003] が関連しそうだったので、cygwin をインストールして試して
みたところ、[ruby-dev:26187] IO.select dumps core と同じ原因のようでした。
cygwin の FD_SEtSIZE は 64 と小さく、私の手元では fd == 128 のときに SEGV しました。
# gdb を使う関係で configure --disable-shared --static-linked-ext した
#
# Breakpoint 1, ruby_connect (fd=128, sockaddr=0x1008a1d8, len=16, socks=0)
# at ../../../ruby_1_8/ext/socket/socket.c:997
# 997 status = wait_connectable(fd);
#
# の wait_connectable から返ったあとに SEGV
[ruby-dev:26369] のとみたさんのアイデアに倣って、とりあえずこうすると
落ちなくなりました。
Index: ext/socket/socket.c
===================================================================
RCS file: /src/ruby/ext/socket/socket.c,v
retrieving revision 1.108.2.37
diff -u -p -r1.108.2.37 socket.c
--- ext/socket/socket.c 28 Nov 2005 09:56:45 -0000 1.108.2.37
+++ ext/socket/socket.c 24 Dec 2005 04:12:27 -0000
@@ -872,6 +872,16 @@ ruby_socket(domain, type, proto)
fd = socket(domain, type, proto);
}
}
+ if (fd > FD_SETSIZE) {
+ close(fd);
+ rb_gc();
+ fd = socket(domain, type, proto);
+ if (fd > FD_SETSIZE) {
+ close(fd);
+ errno = EMFILE;
+ return -1;
+ }
+ }
return fd;
}
これで test-all も通るでしょうか?(自分で試そうとしたのですが、なぜか dbm などの
make に失敗するので。。。どうも私は cygwin との相性が悪いようです)