File tree Expand file tree Collapse file tree 3 files changed +17
-2
lines changed Expand file tree Collapse file tree 3 files changed +17
-2
lines changed Original file line number Diff line number Diff line change @@ -49,6 +49,10 @@ PHP NEWS
49
49
. Fixed bug GH-19098 (libxml<2.13 segmentation fault caused by
50
50
php_libxml_node_free). (nielsdos)
51
51
52
+ - MbString:
53
+ . Fixed bug GH-19397 (mb_list_encodings() can cause crashes on shutdown).
54
+ (nielsdos)
55
+
52
56
- Opcache:
53
57
. Reset global pointers to prevent use-after-free in zend_jit_status().
54
58
(Florian Engelhardt)
Original file line number Diff line number Diff line change @@ -1166,8 +1166,8 @@ PHP_RSHUTDOWN_FUNCTION(mbstring)
1166
1166
MBSTRG (outconv_state ) = 0 ;
1167
1167
1168
1168
if (MBSTRG (all_encodings_list )) {
1169
- GC_DELREF ( MBSTRG ( all_encodings_list ));
1170
- zend_array_destroy (MBSTRG (all_encodings_list ));
1169
+ /* must be *array* release to remove from GC root buffer and free the hashtable itself */
1170
+ zend_array_release (MBSTRG (all_encodings_list ));
1171
1171
MBSTRG (all_encodings_list ) = NULL ;
1172
1172
}
1173
1173
Original file line number Diff line number Diff line change
1
+ --TEST--
2
+ GH-19397 (mb_list_encodings() can cause crashes on shutdown)
3
+ --EXTENSIONS--
4
+ mbstring
5
+ --FILE--
6
+ <?php
7
+ $ doNotDeleteThisVariableAssignment = mb_list_encodings ();
8
+ var_dump (count ($ doNotDeleteThisVariableAssignment ) > 0 );
9
+ ?>
10
+ --EXPECT--
11
+ bool(true)
You can’t perform that action at this time.
0 commit comments