summaryrefslogtreecommitdiffstats
path: root/gc.c
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-12-01 08:03:31 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-12-01 08:03:31 +0000
commit6e7e48942d842168eb0ea00f42146c53e192082b (patch)
tree1d386417cec5c8e31c4a2025b4ee69d4edd4e4c4 /gc.c
parent0cb26db1d7cd12075ac12507ec5a7ecf0d3471ed (diff)
downloadruby-6e7e48942d842168eb0ea00f42146c53e192082b.tar.gz
ruby-6e7e48942d842168eb0ea00f42146c53e192082b.tar.xz
ruby-6e7e48942d842168eb0ea00f42146c53e192082b.zip
* gc.c (ruby_init_stack): decrease "stack level too deep" in Windows.
merge from trunk. git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@11318 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r--gc.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/gc.c b/gc.c
index ccfa68b23..e3b088efd 100644
--- a/gc.c
+++ b/gc.c
@@ -424,7 +424,7 @@ static unsigned int STACK_LEVEL_MAX = 65535;
unsigned int _stacksize = 262144;
# define STACK_LEVEL_MAX (_stacksize - 4096)
# undef HAVE_GETRLIMIT
-#elif defined(HAVE_GETRLIMIT)
+#elif defined(HAVE_GETRLIMIT) || defined(_WIN32)
static unsigned int STACK_LEVEL_MAX = 655300;
#else
# define STACK_LEVEL_MAX 655300
@@ -1542,6 +1542,19 @@ void ruby_init_stack(VALUE *addr
STACK_LEVEL_MAX = (rlim.rlim_cur - space) / sizeof(VALUE);
}
}
+#elif defined _WIN32
+ {
+ MEMORY_BASIC_INFORMATION mi;
+ DWORD size;
+ DWORD space;
+
+ if (VirtualQuery(&mi, &mi, sizeof(mi))) {
+ size = (char *)mi.BaseAddress - (char *)mi.AllocationBase;
+ space = size / 5;
+ if (space > 1024*1024) space = 1024*1024;
+ STACK_LEVEL_MAX = (size - space) / sizeof(VALUE);
+ }
+ }
#endif
}