summaryrefslogtreecommitdiff
path: root/sal
diff options
context:
space:
mode:
authorRüdiger Timm <rt@openoffice.org>2006-05-02 11:12:09 +0000
committerRüdiger Timm <rt@openoffice.org>2006-05-02 11:12:09 +0000
commit63957e3084af9344d6e0efbde06ae5444f252726 (patch)
tree5fd5da525768648eae5911c8f03fe20129a30d2e /sal
parent8a7040c94b83cbf0df51df616beb1c01350eb4b2 (diff)
INTEGRATION: CWS mhu12 (1.1.2); FILE ADDED
2006/04/20 11:00:11 mhu 1.1.2.2: #i23172# #i57764# #125511# Cleaned up, added documentation. 2006/04/11 16:56:49 mhu 1.1.2.1: #125511# #i23172# #i57754# rtl_cache implementation.
Diffstat (limited to 'sal')
-rw-r--r--sal/rtl/source/alloc_cache.h198
1 files changed, 198 insertions, 0 deletions
diff --git a/sal/rtl/source/alloc_cache.h b/sal/rtl/source/alloc_cache.h
new file mode 100644
index 000000000000..b7b203fc058b
--- /dev/null
+++ b/sal/rtl/source/alloc_cache.h
@@ -0,0 +1,198 @@
+/*************************************************************************
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * $RCSfile: alloc_cache.h,v $
+ *
+ * $Revision: 1.2 $
+ *
+ * last change: $Author: rt $ $Date: 2006-05-02 12:12:09 $
+ *
+ * The Contents of this file are made available subject to
+ * the terms of GNU Lesser General Public License Version 2.1.
+ *
+ *
+ * GNU Lesser General Public License Version 2.1
+ * =============================================
+ * Copyright 2005 by Sun Microsystems, Inc.
+ * 901 San Antonio Road, Palo Alto, CA 94303, USA
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License version 2.1, as published by the Free Software Foundation.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ *
+ ************************************************************************/
+
+#ifndef INCLUDED_RTL_ALLOC_CACHE_H
+#define INCLUDED_RTL_ALLOC_CACHE_H
+
+#ifndef _SAL_TYPES_H_
+#include "sal/types.h"
+#endif
+
+#ifndef _RTL_ALLOC_H_
+#include "rtl/alloc.h"
+#endif
+
+#ifndef INCLUDED_RTL_ALLOC_IMPL_H
+#include "alloc_impl.h"
+#endif
+
+#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 64
+
+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 */