Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

wsfalloc.h

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  *
00059  * wsfalloc.h
00060  *
00061  * Author: Markku Rossi <mtr@iki.fi>
00062  *
00063  * Copyright (c) 1999-2000 WAPIT OY LTD.
00064  *       All rights reserved.
00065  *
00066  * Fast memory allocation routines with easy cleanup.
00067  *
00068  */
00069 
00070 #ifndef WSFALLOC_H
00071 #define WSFALLOC_H
00072 
00073 /********************* Types and definitions ****************************/
00074 
00075 struct WsFastMallocBlockRec
00076 {
00077     struct WsFastMallocBlockRec *next;
00078     /* The data follows immediately here. */
00079 };
00080 
00081 typedef struct WsFastMallocBlockRec WsFastMallocBlock;
00082 
00083 struct WsFastMallocRec
00084 {
00085     WsFastMallocBlock *blocks;
00086 
00087     /* The default block size of this pool. */
00088     size_t block_size;
00089 
00090     /* The number of bytes allocates for user blocks. */
00091     size_t user_bytes_allocated;
00092 
00093     /* The next allocation can be done from this position. */
00094     unsigned char *ptr;
00095 
00096     /* And it has this much space. */
00097     size_t size;
00098 };
00099 
00100 typedef struct WsFastMallocRec WsFastMalloc;
00101 
00102 /********************* Prototypes for global functions ******************/
00103 
00104 /* Create a new fast memory allocator with internal block size of
00105    `block_size' bytes.  The function returns NULL if the creation
00106    failed. */
00107 WsFastMalloc *ws_f_create(size_t block_size);
00108 
00109 /* Destroy the fast allocator `pool' and free all resources it has
00110    allocated.  All memory chunks, allocated from this pool will be
00111    invalidated with this call. */
00112 void ws_f_destroy(WsFastMalloc *pool);
00113 
00114 /* Allocate `size' bytes of memory from the pool `pool'.  The function
00115    returns NULL if the allocation fails. */
00116 void *ws_f_malloc(WsFastMalloc *pool, size_t size);
00117 
00118 /* Allocate `num' items of size `size' from the pool `pool'.  The
00119    returned memory block is initialized with zero.  The function
00120    returns NULL if the allocation fails. */
00121 void *ws_f_calloc(WsFastMalloc *pool, size_t num, size_t size);
00122 
00123 /* Take a copy of the memory buffer `ptr' which has `size' bytes of
00124    data.  The copy is allocated from the pool `pool'.  The function
00125    returns NULL if the allocation fails. */
00126 void *ws_f_memdup(WsFastMalloc *pool, const void *ptr, size_t size);
00127 
00128 /* Take a copy of the C-string `str'.  The copy is allocated from the
00129    pool `pool'.  The function returns NULL if the allocation fails. */
00130 void *ws_f_strdup(WsFastMalloc *pool, const char *str);
00131 
00132 #endif /* not WSFALLOC_H */
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.