зеркало из https://github.com/github/ruby.git
* eval.c (FUNCTION_CALL_MAY_RETURN_TWICE): don't clobber %l7 of SPARC
if enable-shared. (ruby_setjmp): call FUNCTION_CALL_MAY_RETURN_TWICE after getcontext too. reported by Pav Lucistnik and Marius Strobl. http://lists.freebsd.org/pipermail/freebsd-sparc64/2006-January/003739.html git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@9844 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
f2367ae395
Коммит
77a71cf160
|
@ -1,3 +1,12 @@
|
|||
Wed Jan 18 23:37:06 2006 Tanaka Akira <akr@m17n.org>
|
||||
|
||||
* eval.c (FUNCTION_CALL_MAY_RETURN_TWICE): don't clobber %l7 of SPARC
|
||||
if enable-shared.
|
||||
(ruby_setjmp): call FUNCTION_CALL_MAY_RETURN_TWICE after getcontext
|
||||
too.
|
||||
reported by Pav Lucistnik and Marius Strobl.
|
||||
http://lists.freebsd.org/pipermail/freebsd-sparc64/2006-January/003739.html
|
||||
|
||||
Tue Jan 17 23:59:56 2006 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* object.c (rb_mod_const_get, rb_mod_const_defined): added optional
|
||||
|
|
16
eval.c
16
eval.c
|
@ -119,7 +119,8 @@ rb_jump_context(env, val)
|
|||
* But it has not the problem because gcc knows setjmp may return twice.
|
||||
* gcc detects setjmp and generates setjmp safe code.
|
||||
*
|
||||
* So setjmp call before getcontext call makes the code somewhat safe.
|
||||
* So setjmp calls before and after getcontext call makes the code
|
||||
* somewhat safe.
|
||||
* It fix the problem on IA64.
|
||||
* It is not required that setjmp is called at run time, since the problem is
|
||||
* register usage.
|
||||
|
@ -139,11 +140,23 @@ rb_jump_context(env, val)
|
|||
(__GNUC__ == (major) && __GNUC_MINOR__ == (minor) && __GNUC_PATCHLEVEL__ < (patchlevel))))
|
||||
#if GCC_VERSION_BEFORE(4,0,3)
|
||||
#if defined(sparc) || defined(__sparc__)
|
||||
#ifdef __pic__
|
||||
/*
|
||||
* %l7 is excluded for PIC because it is PIC register.
|
||||
* http://lists.freebsd.org/pipermail/freebsd-sparc64/2006-January/003739.html
|
||||
*/
|
||||
#define FUNCTION_CALL_MAY_RETURN_TWICE \
|
||||
({ __asm__ volatile ("" : : : \
|
||||
"%o0", "%o1", "%o2", "%o3", "%o4", "%o5", "%o7", \
|
||||
"%l0", "%l1", "%l2", "%l3", "%l4", "%l5", "%l6", \
|
||||
"%i0", "%i1", "%i2", "%i3", "%i4", "%i5", "%i7"); })
|
||||
#else
|
||||
#define FUNCTION_CALL_MAY_RETURN_TWICE \
|
||||
({ __asm__ volatile ("" : : : \
|
||||
"%o0", "%o1", "%o2", "%o3", "%o4", "%o5", "%o7", \
|
||||
"%l0", "%l1", "%l2", "%l3", "%l4", "%l5", "%l6", "%l7", \
|
||||
"%i0", "%i1", "%i2", "%i3", "%i4", "%i5", "%i7"); })
|
||||
#endif
|
||||
#elif defined(IA64)
|
||||
static jmp_buf function_call_may_return_twice_jmp_buf;
|
||||
int function_call_may_return_twice_false = 0;
|
||||
|
@ -162,6 +175,7 @@ int function_call_may_return_twice_false = 0;
|
|||
(just_before_setjmp), \
|
||||
FUNCTION_CALL_MAY_RETURN_TWICE, \
|
||||
getcontext(&(j)->context), \
|
||||
FUNCTION_CALL_MAY_RETURN_TWICE, \
|
||||
(j)->status)
|
||||
#else
|
||||
typedef jmp_buf rb_jmpbuf_t;
|
||||
|
|
Загрузка…
Ссылка в новой задаче