diff options
author | Koichi Sasada <[email protected]> | 2020-11-28 04:39:09 +0900 |
---|---|---|
committer | Koichi Sasada <[email protected]> | 2020-12-01 09:39:30 +0900 |
commit | 67693d8d806e67d6e50b303dd0be6ec06b81c853 () | |
tree | b0947049393400f046ac554b7f3573cd73b80af0 /random.c | |
parent | e79f1941b29738d95b42f8cb5bdb159e7138cf49 (diff) |
ractor local storage C-API
To manage ractor-local data for C extension, the following APIs are defined. * rb_ractor_local_storage_value_newkey * rb_ractor_local_storage_value * rb_ractor_local_storage_value_set * rb_ractor_local_storage_ptr_newkey * rb_ractor_local_storage_ptr * rb_ractor_local_storage_ptr_set At first, you need to create a key of storage by rb_ractor_local_(value|ptr)_newkey(). For ptr storage, it accepts the type of storage, how to mark and how to free with ractor's lifetime. rb_ractor_local_storage_value/set are used to access a VALUE and rb_ractor_local_storage_ptr/set are used to access a pointer. random.c uses this API.
Notes: Merged: https://.com/ruby/ruby/pull/3822
-rw-r--r-- | random.c | 33 |
1 files changed, 22 insertions, 11 deletions
@@ -63,6 +63,7 @@ #include "internal/sanitizers.h" #include "ruby_atomic.h" #include "ruby/random.h" typedef int int_must_be_32bit_at_least[sizeof(int) * CHAR_BIT < 32 ? -1 : 1]; @@ -146,23 +147,31 @@ rand_start(rb_random_mt_t *r) return &rand_mt_start(r)->base; } static rb_random_mt_t * default_rand(void) { - rb_random_t *rb_ractor_default_rand(rb_random_t *); // ractor.c - rb_random_mt_t *rnd = (rb_random_mt_t *)rb_ractor_default_rand(NULL); - if (rnd == NULL) { rnd = ZALLOC(rb_random_mt_t); - rb_ractor_default_rand(&rnd->base); } - return rnd; -} -void -rb_default_rand_mark(void *ptr) -{ - rb_random_mt_t *rnd = (rb_random_mt_t *)ptr; - rb_gc_mark(rnd->base.seed); } static rb_random_mt_t * @@ -1727,6 +1736,8 @@ InitVM_Random(void) rb_define_method(m, "random_number", rand_random_number, -1); rb_define_method(m, "rand", rand_random_number, -1); } } #undef rb_intern |