diff --git a/ext/fiddle/function.c b/ext/fiddle/function.c index b6a105abe1..73dfb129a5 100644 --- a/ext/fiddle/function.c +++ b/ext/fiddle/function.c @@ -371,7 +371,7 @@ function_call(int argc, VALUE argv[], VALUE self) args.values[i_call] = (void *)&generic_args[i_call]; } args.values[i_call] = NULL; - args.fn = (void(*)(void))NUM2PTR(cfunc); + args.fn = (void(*)(void))(VALUE)NUM2PTR(cfunc); if (RTEST(need_gvl)) { ffi_call(args.cif, args.fn, &(args.retval), args.values); diff --git a/ext/fiddle/pointer.c b/ext/fiddle/pointer.c index 1b7d7a69f6..5c375fe9d2 100644 --- a/ext/fiddle/pointer.c +++ b/ext/fiddle/pointer.c @@ -570,7 +570,7 @@ rb_fiddle_ptr_inspect(VALUE self) TypedData_Get_Struct(self, struct ptr_data, &fiddle_ptr_data_type, data); return rb_sprintf("#<%"PRIsVALUE":%p ptr=%p size=%ld free=%p>", - RB_OBJ_CLASSNAME(self), (void *)data, data->ptr, data->size, (void *)data->free); + RB_OBJ_CLASSNAME(self), (void *)data, data->ptr, data->size, (void *)(VALUE)data->free); } /*