aboutsummaryrefslogtreecommitdiffstats
path: root/variable.c
diff options
context:
space:
mode:
authorPeter Zhu <peter@peterzhu.ca>2023-11-21 09:19:15 -0500
committerPeter Zhu <peter@peterzhu.ca>2023-11-21 10:27:02 -0500
commit7e7e2dde2403ad6d5b265ca541d15a51402e6bae (patch)
treeff20b7b819d2be13abb166976e1955c8d0539e3d /variable.c
parentb4f551686b973b03665bcaa3ecf128c0a87ff58b (diff)
downloadruby-7e7e2dde2403ad6d5b265ca541d15a51402e6bae.tar.gz
Fix memory leak when evacuating generic ivars
The lookup in the table is using the wrong key when converting generic instance variables to too complex, which means that it never looks up the entry which leaks memory when the entry is overwritten.
Diffstat (limited to 'variable.c')
-rw-r--r--variable.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/variable.c b/variable.c
index b6c9cc3e0d..f155f7e712 100644
--- a/variable.c
+++ b/variable.c
@@ -1379,7 +1379,7 @@ rb_obj_convert_to_too_complex(VALUE obj, st_table *table)
RB_VM_LOCK_ENTER();
{
struct st_table *gen_ivs = generic_ivtbl_no_ractor_check(obj);
- st_lookup(gen_ivs, (st_data_t)&obj, (st_data_t *)&old_ivptr);
+ st_lookup(gen_ivs, (st_data_t)obj, (st_data_t *)&old_ivptr);
struct gen_ivtbl *ivtbl = xmalloc(sizeof(struct gen_ivtbl));
ivtbl->as.complex.table = table;