From 2c6e16eb51bccb98c2d4cfb7b35f6e6500d5d028 Mon Sep 17 00:00:00 2001 From: Peter Zhu Date: Thu, 15 Aug 2024 14:33:13 -0400 Subject: [PATCH] Don't assume st_data_t and VALUE are the same in rb_gc_impl_object_id --- gc/default.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/gc/default.c b/gc/default.c index 87f570c2c6..28923a79c7 100644 --- a/gc/default.c +++ b/gc/default.c @@ -1683,8 +1683,10 @@ rb_gc_impl_object_id(void *objspace_ptr, VALUE obj) rb_objspace_t *objspace = objspace_ptr; unsigned int lev = rb_gc_vm_lock(); - if (st_lookup(objspace->obj_to_id_tbl, (st_data_t)obj, &id)) { + st_data_t val; + if (st_lookup(objspace->obj_to_id_tbl, (st_data_t)obj, &val)) { GC_ASSERT(FL_TEST(obj, FL_SEEN_OBJ_ID)); + id = (VALUE)val; } else { GC_ASSERT(!FL_TEST(obj, FL_SEEN_OBJ_ID));