2 * The UCW Library -- Resource Pools
4 * (c) 2008 Martin Mares <mj@ucw.cz>
6 * This software may be freely distributed and used according to the terms
7 * of the GNU Lesser General Public License.
12 * - check other candidates for resourcification
13 * - respool as a resource in another respool?
15 * - automatic freeing of trans pool on thread exit
18 #ifndef _UCW_RESPOOL_H
19 #define _UCW_RESPOOL_H
21 #include "ucw/clists.h"
22 #include "ucw/threads.h"
27 struct mempool *mpool; // If set, resources are allocated from the mempool, otherwise by xmalloc()
32 struct respool *rpool;
33 const struct res_class *rclass;
34 void *priv; // Private to the class
39 void (*detach)(struct resource *r);
40 void (*free)(struct resource *r);
41 void (*dump)(struct resource *r);
42 uns res_size; // Size of the resource structure (0=default)
45 struct respool *rp_new(const char *name, struct mempool *mp);
46 void rp_delete(struct respool *rp);
47 void rp_detach(struct respool *rp);
48 void rp_dump(struct respool *rp);
50 static inline struct respool *
53 return ucwlib_thread_context()->current_respool; // May be NULL
56 static inline struct respool *
57 rp_switch(struct respool *rp)
59 struct ucwlib_context *ctx = ucwlib_thread_context();
60 struct respool *orp = ctx->current_respool;
61 ctx->current_respool = rp;
65 struct resource *res_alloc(const struct res_class *rc); // Returns NULL if there is no pool active
66 void res_drop(struct resource *r);
67 void res_detach(struct resource *r);
68 void res_free(struct resource *r);
69 void res_dump(struct resource *r);
71 static inline struct resource * // Returns NULL if there is no pool active
72 res_new(const struct res_class *rc, void *priv)
74 struct resource *r = res_alloc(rc);
83 /* Various special types of resources */
85 struct resource *res_for_fd(int fd); // Creates a resource that closes a given file descriptor
87 void *res_malloc(size_t size, struct resource **ptr); // Allocates memory and creates a resource for it
88 void *res_malloc_zero(size_t size, struct resource **ptr); // Allocates zero-initialized memory and creates a resource for it
89 void *res_realloc(struct resource *res, size_t size);