mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
Class and value internal properties are always exists for primitive types (e.g. Boolean, Regex) so they can be stored right after the object. This improve property access (since internal properties are searched by a slow linear algorithm) and reduces memory consumption, since only 8 byte is allocated for these two properties instead of 16 which is the size of a property pair. JerryScript-DCO-1.0-Signed-off-by: Zoltan Herczeg zherczeg.u-szeged@partner.samsung.com
134 lines
4.0 KiB
C
134 lines
4.0 KiB
C
/* Copyright 2014-2016 Samsung Electronics Co., Ltd.
|
|
* Copyright 2016 University of Szeged.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include "ecma-alloc.h"
|
|
#include "ecma-globals.h"
|
|
#include "ecma-gc.h"
|
|
#include "ecma-lcache.h"
|
|
#include "jrt.h"
|
|
#include "jmem-poolman.h"
|
|
|
|
JERRY_STATIC_ASSERT (sizeof (ecma_property_value_t) == sizeof (ecma_value_t),
|
|
size_of_ecma_property_value_t_must_be_equal_to_size_of_ecma_value_t);
|
|
JERRY_STATIC_ASSERT (((sizeof (ecma_property_value_t) - 1) & sizeof (ecma_property_value_t)) == 0,
|
|
size_of_ecma_property_value_t_must_be_power_of_2);
|
|
|
|
JERRY_STATIC_ASSERT (sizeof (ecma_string_t) == sizeof (uint64_t),
|
|
size_of_ecma_string_t_must_be_less_than_or_equal_to_8_bytes);
|
|
|
|
/** \addtogroup ecma ECMA
|
|
* @{
|
|
*
|
|
* \addtogroup ecmaalloc Routines for allocation/freeing memory for ECMA data types
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* Implementation of routines for allocation/freeing memory for ECMA data types.
|
|
*
|
|
* All allocation routines from this module have the same structure:
|
|
* 1. Try to allocate memory.
|
|
* 2. If allocation was successful, return pointer to the allocated block.
|
|
* 3. Run garbage collection.
|
|
* 4. Try to allocate memory.
|
|
* 5. If allocation was successful, return pointer to the allocated block;
|
|
* else - shutdown engine.
|
|
*/
|
|
|
|
/**
|
|
* Template of an allocation routine.
|
|
*/
|
|
#define ALLOC(ecma_type) ecma_ ## ecma_type ## _t * \
|
|
ecma_alloc_ ## ecma_type (void) \
|
|
{ \
|
|
ecma_ ## ecma_type ## _t *ecma_type ## _p; \
|
|
ecma_type ## _p = (ecma_ ## ecma_type ## _t *) jmem_pools_alloc (sizeof (ecma_ ## ecma_type ## _t)); \
|
|
\
|
|
JERRY_ASSERT (ecma_type ## _p != NULL); \
|
|
\
|
|
return ecma_type ## _p; \
|
|
}
|
|
|
|
/**
|
|
* Deallocation routine template
|
|
*/
|
|
#define DEALLOC(ecma_type) void \
|
|
ecma_dealloc_ ## ecma_type (ecma_ ## ecma_type ## _t *ecma_type ## _p) \
|
|
{ \
|
|
jmem_pools_free ((uint8_t *) ecma_type ## _p, sizeof (ecma_ ## ecma_type ## _t)); \
|
|
}
|
|
|
|
/**
|
|
* Declaration of alloc/free routine for specified ecma-type.
|
|
*/
|
|
#define DECLARE_ROUTINES_FOR(ecma_type) \
|
|
ALLOC (ecma_type) \
|
|
DEALLOC (ecma_type)
|
|
|
|
DECLARE_ROUTINES_FOR (object)
|
|
DECLARE_ROUTINES_FOR (number)
|
|
DECLARE_ROUTINES_FOR (collection_header)
|
|
DECLARE_ROUTINES_FOR (collection_chunk)
|
|
DECLARE_ROUTINES_FOR (string)
|
|
DECLARE_ROUTINES_FOR (getter_setter_pointers)
|
|
DECLARE_ROUTINES_FOR (external_pointer)
|
|
|
|
/**
|
|
* Allocate memory for extended object
|
|
*
|
|
* @return pointer to allocated memory
|
|
*/
|
|
inline ecma_extended_object_t * __attr_always_inline___
|
|
ecma_alloc_extended_object (size_t size) /**< size of object */
|
|
{
|
|
return jmem_heap_alloc_block (size);
|
|
} /* ecma_alloc_extended_object */
|
|
|
|
/**
|
|
* Dealloc memory of an extended object
|
|
*/
|
|
inline void __attr_always_inline___
|
|
ecma_dealloc_extended_object (ecma_extended_object_t *ext_object_p, /**< property pair to be freed */
|
|
size_t size) /**< size of object */
|
|
{
|
|
jmem_heap_free_block (ext_object_p, size);
|
|
} /* ecma_dealloc_extended_object */
|
|
|
|
/**
|
|
* Allocate memory for ecma-property pair
|
|
*
|
|
* @return pointer to allocated memory
|
|
*/
|
|
inline ecma_property_pair_t * __attr_always_inline___
|
|
ecma_alloc_property_pair (void)
|
|
{
|
|
return jmem_heap_alloc_block (sizeof (ecma_property_pair_t));
|
|
} /* ecma_alloc_property_pair */
|
|
|
|
/**
|
|
* Dealloc memory of an ecma-property
|
|
*/
|
|
inline void __attr_always_inline___
|
|
ecma_dealloc_property_pair (ecma_property_pair_t *property_pair_p) /**< property pair to be freed */
|
|
{
|
|
jmem_heap_free_block (property_pair_p, sizeof (ecma_property_pair_t));
|
|
} /* ecma_dealloc_property_pair */
|
|
|
|
/**
|
|
* @}
|
|
* @}
|
|
*/
|