mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* thread_pthread.c (reserve_stack): fix reserving position where
the stack growing bottom to top. [Bug #12118] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@54256 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
22f1db4b8e
commit
88291c190a
2 changed files with 25 additions and 6 deletions
|
@ -1,3 +1,8 @@
|
|||
Fri Mar 25 01:50:58 2016 NARUSE, Yui <naruse@ruby-lang.org>
|
||||
|
||||
* thread_pthread.c (reserve_stack): fix reserving position where
|
||||
the stack growing bottom to top. [Bug #12118]
|
||||
|
||||
Fri Mar 25 01:10:42 2016 Sebastian Schuberth <sschuberth@gmail.com>
|
||||
|
||||
* lib/mkmf.rb (find_executable0): On Windows, it is actually valid
|
||||
|
|
|
@ -693,17 +693,31 @@ reserve_stack(volatile char *limit, size_t size)
|
|||
const volatile char *end = buf + sizeof(buf);
|
||||
limit += size;
|
||||
if (limit > end) {
|
||||
size = limit - end;
|
||||
limit = alloca(size);
|
||||
limit[stack_check_margin+size-1] = 0;
|
||||
/* |<-bottom (=limit(a)) top->|
|
||||
* | .. |<-buf 256B |<-end | stack check |
|
||||
* | 256B | =size= | margin (4KB)|
|
||||
* | =size= limit(b)->| 256B | |
|
||||
* | | alloca(sz) | | |
|
||||
* | .. |<-buf |<-limit(c) [sz-1]->0> | |
|
||||
*/
|
||||
size_t sz = limit - end;
|
||||
limit = alloca(sz);
|
||||
limit[sz-1] = 0;
|
||||
}
|
||||
}
|
||||
else {
|
||||
limit -= size;
|
||||
if (buf > limit) {
|
||||
limit = alloca(buf - limit);
|
||||
limit[0] = 0; /* ensure alloca is called */
|
||||
limit -= stack_check_margin;
|
||||
/* |<-top (=limit(a)) bottom->|
|
||||
* | .. | 256B buf->| | stack check |
|
||||
* | 256B | =size= | margin (4KB)|
|
||||
* | =size= limit(b)->| 256B | |
|
||||
* | | alloca(sz) | | |
|
||||
* | .. | buf->| limit(c)-><0> | |
|
||||
*/
|
||||
size_t sz = buf - limit;
|
||||
limit = alloca(sz);
|
||||
limit[0] = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue