blob: 1cec1a82569bbe87e9758ce16437f73038fcc17e [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*
*************************************************************/
#ifndef INCLUDED_RTL_ALLOC_CACHE_H
#define INCLUDED_RTL_ALLOC_CACHE_H
#include "sal/types.h"
#include "rtl/alloc.h"
#include "alloc_impl.h"
#ifdef __cplusplus
extern "C" {
#endif
/** rtl_cache_stat_type
* @internal
*/
typedef struct rtl_cache_stat_st rtl_cache_stat_type;
struct rtl_cache_stat_st
{
sal_uInt64 m_alloc;
sal_uInt64 m_free;
sal_Size m_mem_total;
sal_Size m_mem_alloc;
};
/** rtl_cache_bufctl_type
* @internal
*/
typedef struct rtl_cache_bufctl_st rtl_cache_bufctl_type;
struct rtl_cache_bufctl_st
{
rtl_cache_bufctl_type * m_next; /* linkage */
sal_uIntPtr m_addr; /* buffer address */
sal_uIntPtr m_slab; /* parent slab address */
};
/** rtl_cache_slab_type
* @internal
*/
typedef struct rtl_cache_slab_st rtl_cache_slab_type;
struct rtl_cache_slab_st
{
rtl_cache_slab_type * m_slab_next; /* slab linkage */
rtl_cache_slab_type * m_slab_prev; /* slab linkage */
sal_Size m_ntypes; /* number of buffers used */
sal_uIntPtr m_data; /* buffer start addr */
sal_uIntPtr m_bp; /* free buffer linkage 'base pointer' */
rtl_cache_bufctl_type * m_sp; /* free buffer linkage 'stack pointer' */
};
/** rtl_cache_magazine_type
* @internal
*/
#define RTL_CACHE_MAGAZINE_SIZE 61
typedef struct rtl_cache_magazine_st rtl_cache_magazine_type;
struct rtl_cache_magazine_st
{
rtl_cache_magazine_type * m_mag_next; /* depot linkage */
sal_Size m_mag_size;
sal_Size m_mag_used;
void * m_objects[RTL_CACHE_MAGAZINE_SIZE];
};
/** rtl_cache_depot_type
* @internal
*/
typedef struct rtl_cache_depot_st rtl_cache_depot_type;
struct rtl_cache_depot_st
{
/* magazine list */
rtl_cache_magazine_type * m_mag_next; /* linkage */
sal_Size m_mag_count; /* count */
/* working set parameters */
sal_Size m_curr_min;
sal_Size m_prev_min;
};
/** rtl_cache_type
* @internal
*/
#define RTL_CACHE_HASH_SIZE 8
#define RTL_CACHE_FEATURE_HASH 1
#define RTL_CACHE_FEATURE_BULKDESTROY 2
#define RTL_CACHE_FEATURE_RESCALE 4 /* within hash rescale operation */
struct rtl_cache_st
{
/* linkage */
rtl_cache_type * m_cache_next;
rtl_cache_type * m_cache_prev;
/* properties */
char m_name[RTL_CACHE_NAME_LENGTH + 1];
long m_features;
sal_Size m_type_size; /* const */
sal_Size m_type_align; /* const */
sal_Size m_type_shift; /* log2(m_type_size); const */
int (SAL_CALL * m_constructor)(void * obj, void * userarg); /* const */
void (SAL_CALL * m_destructor) (void * obj, void * userarg); /* const */
void (SAL_CALL * m_reclaim) (void * userarg); /* const */
void * m_userarg;
/* slab layer */
rtl_memory_lock_type m_slab_lock;
rtl_cache_stat_type m_slab_stats;
rtl_arena_type * m_source; /* slab supplier; const */
sal_Size m_slab_size; /* const */
sal_Size m_ntypes; /* number of buffers per slab; const */
sal_Size m_ncolor; /* next slab color */
sal_Size m_ncolor_max; /* max. slab color */
rtl_cache_slab_type m_free_head;
rtl_cache_slab_type m_used_head;
rtl_cache_bufctl_type ** m_hash_table;
rtl_cache_bufctl_type * m_hash_table_0[RTL_CACHE_HASH_SIZE];
sal_Size m_hash_size; /* m_hash_mask + 1 */
sal_Size m_hash_shift; /* log2(m_hash_size) */
/* depot layer */
rtl_memory_lock_type m_depot_lock;
rtl_cache_depot_type m_depot_empty;
rtl_cache_depot_type m_depot_full;
rtl_cache_type * m_magazine_cache; /* magazine supplier; const */
/* cpu layer */
rtl_cache_magazine_type * m_cpu_curr;
rtl_cache_magazine_type * m_cpu_prev;
rtl_cache_stat_type m_cpu_stats;
};
#ifdef __cplusplus
}
#endif
#endif /* INCLUDED_RTL_ALLOC_CACHE_H */