summaryrefslogtreecommitdiff
path: root/Zend/zend_alloc.c
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@php.net>2008-10-30 08:55:20 +0000
committerDmitry Stogov <dmitry@php.net>2008-10-30 08:55:20 +0000
commit8107a8f121398f8c6e43593e4c7c152b0a84ce45 (patch)
tree45691b8a1ae6eba6a25d8b3cfed7369cb616bced /Zend/zend_alloc.c
parentbdda0cff3f5f6e18c7beb7f2aaa45610fb30ef2d (diff)
downloadphp-git-8107a8f121398f8c6e43593e4c7c152b0a84ce45.tar.gz
Fixed ability to use "internal" heaps in extensions.
Diffstat (limited to 'Zend/zend_alloc.c')
-rw-r--r--Zend/zend_alloc.c16
1 files changed, 13 insertions, 3 deletions
diff --git a/Zend/zend_alloc.c b/Zend/zend_alloc.c
index 1e11cf86ce..3c6a17067b 100644
--- a/Zend/zend_alloc.c
+++ b/Zend/zend_alloc.c
@@ -1068,16 +1068,26 @@ ZEND_API zend_mm_heap *zend_mm_startup_ex(const zend_mm_mem_handlers *handlers,
}
if (internal) {
int i;
- zend_mm_free_block *p;
+ zend_mm_free_block *p, *q, *orig;
zend_mm_heap *mm_heap = _zend_mm_alloc_int(heap, sizeof(zend_mm_heap) ZEND_FILE_LINE_CC ZEND_FILE_LINE_EMPTY_CC);
*mm_heap = *heap;
p = ZEND_MM_SMALL_FREE_BUCKET(mm_heap, 0);
+ orig = ZEND_MM_SMALL_FREE_BUCKET(heap, 0);
for (i = 0; i < ZEND_MM_NUM_BUCKETS; i++) {
- p->prev_free_block->next_free_block = p;
- p->next_free_block->prev_free_block = p;
+ q = p;
+ while (q->prev_free_block != orig) {
+ q = q->prev_free_block;
+ }
+ q->prev_free_block = p;
+ q = p;
+ while (q->next_free_block != orig) {
+ q = q->next_free_block;
+ }
+ q->next_free_block = p;
p = (zend_mm_free_block*)((char*)p + sizeof(zend_mm_free_block*) * 2);
+ orig = (zend_mm_free_block*)((char*)orig + sizeof(zend_mm_free_block*) * 2);
if (mm_heap->large_free_buckets[i]) {
mm_heap->large_free_buckets[i]->parent = &mm_heap->large_free_buckets[i];
}