diff options
author | Quincey Koziol <koziol@hdfgroup.org> | 2005-07-22 14:37:37 (GMT) |
---|---|---|
committer | Quincey Koziol <koziol@hdfgroup.org> | 2005-07-22 14:37:37 (GMT) |
commit | 6c6e31039194de99a866b0477879065673860347 (patch) | |
tree | 94eb85bfc3d5532ad9bdf56675c8efaffbdfabda | |
parent | 52415d4a9a44c64b5030e0e588943e444b98ae40 (diff) | |
download | hdf5-6c6e31039194de99a866b0477879065673860347.zip hdf5-6c6e31039194de99a866b0477879065673860347.tar.gz hdf5-6c6e31039194de99a866b0477879065673860347.tar.bz2 |
[svn-r11107] Purpose:
Optimization
Description:
Switch some internal error API data structures over to using H5FL* routines
for memory management (instead of malloc/free), in order to reduce abuse of
operating system's memory allocation code.
Platforms tested:
FreeBSD 4.11 (sleipnir)
Too minor to require h5committest
-rw-r--r-- | src/H5E.c | 26 |
1 files changed, 18 insertions, 8 deletions
@@ -47,6 +47,7 @@ #include "H5private.h" /* Generic Functions */ #include "H5Iprivate.h" /* IDs */ #include "H5Eprivate.h" /* Private error routines */ +#include "H5FLprivate.h" /* Free lists */ #include "H5MMprivate.h" /* Memory management */ /* HDF5 error class ID */ @@ -113,6 +114,15 @@ static herr_t H5E_walk_cb(unsigned n, const H5E_error_t *err_desc, void *client static herr_t H5E_get_auto_stack(const H5E_t *estack, hbool_t new_api, void **func, void **client_data); static herr_t H5E_set_auto_stack(H5E_t *estack, hbool_t new_api, void *func, void *client_data); +/* Declare a free list to manage the H5E_t struct */ +H5FL_DEFINE_STATIC(H5E_t); + +/* Declare a free list to manage the H5E_cls_t struct */ +H5FL_DEFINE_STATIC(H5E_cls_t); + +/* Declare a free list to manage the H5E_msg_t struct */ +H5FL_DEFINE_STATIC(H5E_msg_t); + /*------------------------------------------------------------------------- * Function: H5E_init @@ -306,7 +316,7 @@ H5E_get_stack(void) if (!estack) { /* no associated value with current thread - create one */ - estack = (H5E_t *)H5MM_malloc(sizeof(H5E_t)); + estack = (H5E_t *)H5FL_MALLOC(H5E_t); estack->nused = 0; estack->new_api = TRUE; estack->u.func_stack = (H5E_auto_stack_t)H5Eprint_stack; @@ -388,7 +398,7 @@ H5E_register_class(const char *cls_name, const char *lib_name, const char *versi assert(version); /* Allocate space for new error class */ - if((cls = H5MM_malloc(sizeof(H5E_cls_t)))==NULL) + if((cls = H5FL_MALLOC(H5E_cls_t))==NULL) HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, NULL, "memory allocation failed") /* Duplicate string information */ @@ -478,7 +488,7 @@ H5E_unregister_class(H5E_cls_t *cls) H5MM_xfree((void*)cls->lib_name); if(cls->lib_vers) H5MM_xfree((void*)cls->lib_vers); - H5MM_xfree((void*)cls); + H5FL_FREE(H5E_cls_t, cls); FUNC_LEAVE_NOAPI(SUCCEED) } @@ -658,7 +668,7 @@ H5E_close_msg(H5E_msg_t *err) H5MM_xfree((void*)err->msg); /* Don't free err->cls here */ - H5MM_xfree((void*)err); + H5FL_FREE(H5E_msg_t, err); FUNC_LEAVE_NOAPI(SUCCEED) } @@ -737,7 +747,7 @@ H5E_create_msg(H5E_cls_t *cls, H5E_type_t msg_type, const char *msg_str) assert(msg_str); /* Allocate new message object */ - if((msg = H5MM_malloc(sizeof(H5E_msg_t)))==NULL) + if((msg = H5FL_MALLOC(H5E_msg_t))==NULL) HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, NULL, "memory allocation failed") /* Fill new message object */ @@ -1002,7 +1012,7 @@ H5E_get_current_stack(void) HGOTO_ERROR(H5E_ERROR, H5E_CANTGET, NULL, "can't get current error stack") /* Allocate a new error stack */ - if((estack_copy = H5MM_malloc(sizeof(H5E_t)))==NULL) + if((estack_copy = H5FL_MALLOC(H5E_t))==NULL) HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, NULL, "memory allocation failed") /* Make a copy of current error stack */ @@ -1042,7 +1052,7 @@ H5E_get_current_stack(void) done: if(ret_value==NULL) { if(estack_copy!=NULL) - H5MM_xfree((void*)estack_copy); + H5FL_FREE(H5E_t, estack_copy); } /* end if */ FUNC_LEAVE_NOAPI(ret_value) @@ -1214,7 +1224,7 @@ H5E_close_stack(H5E_t *estack) H5E_clear_stack(estack); /* Free the stack structure */ - H5MM_xfree((void*)estack); + H5FL_FREE(H5E_t, estack); FUNC_LEAVE_NOAPI(SUCCEED) } |