!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache. PHP/5.6.40 

uname -a: Linux cpanel06wh.bkk1.cloud.z.com 2.6.32-954.3.5.lve1.4.80.el6.x86_64 #1 SMP Thu Sep 24
01:42:00 EDT 2020 x86_64
 

uid=851(cp949260) gid=853(cp949260) groups=853(cp949260) 

Safe-mode: OFF (not secure)

/opt/alt/php83/usr/include/php/Zend/   drwxr-xr-x
Free 231.79 GB of 981.82 GB (23.61%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     zend_arena.h (5.92 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*
   +----------------------------------------------------------------------+
   | Zend Engine                                                          |
   +----------------------------------------------------------------------+
   | Copyright (c) Zend Technologies Ltd. (http://www.zend.com)           |
   +----------------------------------------------------------------------+
   | This source file is subject to version 2.00 of the Zend license,     |
   | that is bundled with this package in the file LICENSE, and is        |
   | available through the world-wide-web at the following url:           |
   | http://www.zend.com/license/2_00.txt.                                |
   | If you did not receive a copy of the Zend license and are unable to  |
   | obtain it through the world-wide-web, please send a note to          |
   | license@zend.com so we can mail you a copy immediately.              |
   +----------------------------------------------------------------------+
   | Authors: Dmitry Stogov <dmitry@php.net>                              |
   +----------------------------------------------------------------------+
*/

#ifndef _ZEND_ARENA_H_
#define _ZEND_ARENA_H_

#include "zend.h"

#ifndef ZEND_TRACK_ARENA_ALLOC

typedef struct _zend_arena zend_arena;

struct _zend_arena {
    char        *ptr;
    char        *end;
    zend_arena  *prev;
};

static zend_always_inline zend_arena* zend_arena_create(size_t size)
{
    zend_arena *arena = (zend_arena*)emalloc(size);

    arena->ptr = (char*) arena + ZEND_MM_ALIGNED_SIZE(sizeof(zend_arena));
    arena->end = (char*) arena + size;
    arena->prev = NULL;
    return arena;
}

static zend_always_inline void zend_arena_destroy(zend_arena *arena)
{
    do {
        zend_arena *prev = arena->prev;
        efree(arena);
        arena = prev;
    } while (arena);
}

static zend_always_inline void* zend_arena_alloc(zend_arena **arena_ptr, size_t size)
{
    zend_arena *arena = *arena_ptr;
    char *ptr = arena->ptr;

    size = ZEND_MM_ALIGNED_SIZE(size);

    if (EXPECTED(size <= (size_t)(arena->end - ptr))) {
        arena->ptr = ptr + size;
    } else {
        size_t arena_size =
            UNEXPECTED((size + ZEND_MM_ALIGNED_SIZE(sizeof(zend_arena))) > (size_t)(arena->end - (char*) arena)) ?
                (size + ZEND_MM_ALIGNED_SIZE(sizeof(zend_arena))) :
                (size_t)(arena->end - (char*) arena);
        zend_arena *new_arena = (zend_arena*)emalloc(arena_size);

        ptr = (char*) new_arena + ZEND_MM_ALIGNED_SIZE(sizeof(zend_arena));
        new_arena->ptr = (char*) new_arena + ZEND_MM_ALIGNED_SIZE(sizeof(zend_arena)) + size;
        new_arena->end = (char*) new_arena + arena_size;
        new_arena->prev = arena;
        *arena_ptr = new_arena;
    }

    return (void*) ptr;
}

static zend_always_inline void* zend_arena_calloc(zend_arena **arena_ptr, size_t count, size_t unit_size)
{
    bool overflow;
    size_t size;
    void *ret;

    size = zend_safe_address(unit_size, count, 0, &overflow);
    if (UNEXPECTED(overflow)) {
        zend_error(E_ERROR, "Possible integer overflow in zend_arena_calloc() (%zu * %zu)", unit_size, count);
    }
    ret = zend_arena_alloc(arena_ptr, size);
    memset(ret, 0, size);
    return ret;
}

static zend_always_inline void* zend_arena_checkpoint(zend_arena *arena)
{
    return arena->ptr;
}

static zend_always_inline void zend_arena_release(zend_arena **arena_ptr, void *checkpoint)
{
    zend_arena *arena = *arena_ptr;

    while (UNEXPECTED((char*)checkpoint > arena->end) ||
           UNEXPECTED((char*)checkpoint <= (char*)arena)) {
        zend_arena *prev = arena->prev;
        efree(arena);
        *arena_ptr = arena = prev;
    }
    ZEND_ASSERT((char*)checkpoint > (char*)arena && (char*)checkpoint <= arena->end);
    arena->ptr = (char*)checkpoint;
}

static zend_always_inline bool zend_arena_contains(zend_arena *arena, void *ptr)
{
    while (arena) {
        if ((char*)ptr > (char*)arena && (char*)ptr <= arena->ptr) {
            return 1;
        }
        arena = arena->prev;
    }
    return 0;
}

#else

/* Use normal allocations and keep track of them for mass-freeing.
 * This is intended for use with asan/valgrind. */

typedef struct _zend_arena zend_arena;

struct _zend_arena {
    void **ptr;
    void **end;
    struct _zend_arena *prev;
    void *ptrs[0];
};

#define ZEND_TRACKED_ARENA_SIZE 1000

static zend_always_inline zend_arena *zend_arena_create(size_t _size)
{
    zend_arena *arena = (zend_arena*) emalloc(
        sizeof(zend_arena) + sizeof(void *) * ZEND_TRACKED_ARENA_SIZE);
    arena->ptr = &arena->ptrs[0];
    arena->end = &arena->ptrs[ZEND_TRACKED_ARENA_SIZE];
    arena->prev = NULL;
    return arena;
}

static zend_always_inline void zend_arena_destroy(zend_arena *arena)
{
    do {
        zend_arena *prev = arena->prev;
        void **ptr;
        for (ptr = arena->ptrs; ptr < arena->ptr; ptr++) {
            efree(*ptr);
        }
        efree(arena);
        arena = prev;
    } while (arena);
}

static zend_always_inline void *zend_arena_alloc(zend_arena **arena_ptr, size_t size)
{
    zend_arena *arena = *arena_ptr;
    if (arena->ptr == arena->end) {
        *arena_ptr = zend_arena_create(0);
        (*arena_ptr)->prev = arena;
        arena = *arena_ptr;
    }

    return *arena->ptr++ = emalloc(size);
}

static zend_always_inline void* zend_arena_calloc(zend_arena **arena_ptr, size_t count, size_t unit_size)
{
    bool overflow;
    size_t size;
    void *ret;

    size = zend_safe_address(unit_size, count, 0, &overflow);
    if (UNEXPECTED(overflow)) {
        zend_error(E_ERROR, "Possible integer overflow in zend_arena_calloc() (%zu * %zu)", unit_size, count);
    }
    ret = zend_arena_alloc(arena_ptr, size);
    memset(ret, 0, size);
    return ret;
}

static zend_always_inline void* zend_arena_checkpoint(zend_arena *arena)
{
    return arena->ptr;
}

static zend_always_inline void zend_arena_release(zend_arena **arena_ptr, void *checkpoint)
{
    while (1) {
        zend_arena *arena = *arena_ptr;
        zend_arena *prev = arena->prev;
        while (1) {
            if (arena->ptr == (void **) checkpoint) {
                return;
            }
            if (arena->ptr == arena->ptrs) {
                break;
            }
            arena->ptr--;
            efree(*arena->ptr);
        }
        efree(arena);
        *arena_ptr = prev;
        ZEND_ASSERT(*arena_ptr);
    }
}

static zend_always_inline bool zend_arena_contains(zend_arena *arena, void *ptr)
{
    /* TODO: Dummy */
    return 1;
}

#endif

#endif /* _ZEND_ARENA_H_ */

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by KaizenLouie | C99Shell Github | Generation time: 0.1067 ]--