mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
itself seems a step back, but the primary aim is opening future optimization opportunities. The list of changes follows: - Property is changed to be an abstract type, which has type, flags, and a value. It does not have a name anymore and property pointers cannot be compressed. - Full (32 bit) ecma values can be property values. This allows using non-compressed pointers for ecma values in the future. - The property chain is not restricted to the same item anymore, it can contain hash maps, arrays in the future. JerryScript-DCO-1.0-Signed-off-by: Zoltan Herczeg zherczeg.u-szeged@partner.samsung.com
123 lines
4.1 KiB
C
123 lines
4.1 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 "mem-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_property_pair_t) == sizeof (uint64_t) * 2,
|
|
size_of_ecma_property_pair_t_must_be_equal_to_16_bytes);
|
|
|
|
JERRY_STATIC_ASSERT (sizeof (ecma_object_t) <= sizeof (uint64_t),
|
|
size_of_ecma_object_t_must_be_less_than_or_equal_to_8_bytes);
|
|
|
|
JERRY_STATIC_ASSERT (sizeof (ecma_collection_header_t) == sizeof (uint64_t),
|
|
size_of_ecma_collection_header_t_must_be_less_than_or_equal_to_8_bytes);
|
|
JERRY_STATIC_ASSERT (sizeof (ecma_collection_chunk_t) == sizeof (uint64_t),
|
|
size_of_ecma_collection_chunk_t_must_be_less_than_or_equal_to_8_bytes);
|
|
JERRY_STATIC_ASSERT (sizeof (ecma_string_t) == sizeof (uint64_t),
|
|
size_of_ecma_string_t_must_be_less_than_or_equal_to_8_bytes);
|
|
JERRY_STATIC_ASSERT (sizeof (ecma_getter_setter_pointers_t) <= sizeof (uint64_t),
|
|
size_of_ecma_getter_setter_pointers_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 *p ## ecma_type = (ecma_ ## ecma_type ## _t *) mem_pools_alloc (); \
|
|
\
|
|
JERRY_ASSERT (p ## ecma_type != NULL); \
|
|
\
|
|
return p ## ecma_type; \
|
|
}
|
|
|
|
/**
|
|
* Deallocation routine template
|
|
*/
|
|
#define DEALLOC(ecma_type) void \
|
|
ecma_dealloc_ ## ecma_type (ecma_ ## ecma_type ## _t *p ## ecma_type) \
|
|
{ \
|
|
mem_pools_free ((uint8_t *) p ## ecma_type); \
|
|
}
|
|
|
|
/**
|
|
* 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 ecma-property pair
|
|
*
|
|
* @return pointer to allocated memory
|
|
*/
|
|
ecma_property_pair_t *
|
|
ecma_alloc_property_pair (void)
|
|
{
|
|
return mem_heap_alloc_block (sizeof (ecma_property_pair_t));
|
|
} /* ecma_alloc_property_pair */
|
|
|
|
/**
|
|
* Dealloc memory from an ecma-property
|
|
*/
|
|
extern void
|
|
ecma_dealloc_property_pair (ecma_property_pair_t *property_pair_p) /**< property pair to be freed */
|
|
{
|
|
mem_heap_free_block (property_pair_p, sizeof (ecma_property_pair_t));
|
|
} /* ecma_dealloc_property_pair */
|
|
|
|
/**
|
|
* @}
|
|
* @}
|
|
*/
|