aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-11-09 13:04:22 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-11-09 13:04:22 +0000
commit6e572060eba0d526125bf3044104747062f6f79a (patch)
tree6833f827b72e7dfae01a2afb6030b538c286e6cc
parent28c0aec1d889cfb3447c708a790b0acb95607e2f (diff)
downloadruby-6e572060eba0d526125bf3044104747062f6f79a.tar.gz
* vm.h (FRAME_MAGIC_MASK_BITS): bits of FRAME_MAGIC_MASK.
* insnhelper.ci (vm_call_cfunc, vm_cfunc_flags): use shift operations. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13857 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog6
-rw-r--r--insnhelper.ci4
-rw-r--r--vm.h3
3 files changed, 10 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 0390141dd4..a687cd7f87 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Fri Nov 9 22:04:21 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * vm.h (FRAME_MAGIC_MASK_BITS): bits of FRAME_MAGIC_MASK.
+
+ * insnhelper.ci (vm_call_cfunc, vm_cfunc_flags): use shift operations.
+
Fri Nov 9 21:46:28 2007 Koichi Sasada <ko1@atdot.net>
* eval.c (eval): should be volatile value for GC.
diff --git a/insnhelper.ci b/insnhelper.ci
index bfbbe6f418..82731829c6 100644
--- a/insnhelper.ci
+++ b/insnhelper.ci
@@ -355,7 +355,7 @@ vm_call_cfunc(rb_thread_t *th, rb_control_frame_t *reg_cfp, int num,
EXEC_EVENT_HOOK(th, RUBY_EVENT_C_CALL, recv, id, klass);
{
rb_control_frame_t *cfp =
- vm_push_frame(th, 0, FRAME_MAGIC_CFUNC | flag * (FRAME_MAGIC_MASK + 1),
+ vm_push_frame(th, 0, FRAME_MAGIC_CFUNC | (flag << FRAME_MAGIC_MASK_BITS),
recv, (VALUE) blockptr, 0, reg_cfp->sp, 0, 1);
cfp->method_id = id;
@@ -379,7 +379,7 @@ static int
vm_cfunc_flags(rb_control_frame_t *cfp)
{
if (RUBYVM_CFUNC_FRAME_P(cfp))
- return cfp->flag / (FRAME_MAGIC_MASK + 1);
+ return cfp->flag >> FRAME_MAGIC_MASK_BITS;
return 0;
}
diff --git a/vm.h b/vm.h
index fa131d96e7..5a6e47c1c8 100644
--- a/vm.h
+++ b/vm.h
@@ -236,7 +236,8 @@ default: \
#define FRAME_MAGIC_IFUNC 0x81
#define FRAME_MAGIC_EVAL 0x91
#define FRAME_MAGIC_LAMBDA 0xa1
-#define FRAME_MAGIC_MASK 0xff
+#define FRAME_MAGIC_MASK_BITS 8
+#define FRAME_MAGIC_MASK (~(~0<<FRAME_MAGIC_MASK_BITS))
#define VM_FRAME_FLAG(type) ((VALUE)((type) & FRAME_MAGIC_MASK))