File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / libpdel / util / tinfo.h
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Tue Feb 21 23:25:53 2012 UTC (12 years, 8 months ago) by misho
Branches: libpdel, MAIN
CVS tags: v0_5_3, HEAD
libpdel


/*
 * Copyright (c) 2001-2002 Packet Design, LLC.
 * All rights reserved.
 * 
 * Subject to the following obligations and disclaimer of warranty,
 * use and redistribution of this software, in source or object code
 * forms, with or without modifications are expressly permitted by
 * Packet Design; provided, however, that:
 * 
 *    (i)  Any and all reproductions of the source or object code
 *         must include the copyright notice above and the following
 *         disclaimer of warranties; and
 *    (ii) No rights are granted, in any manner or form, to use
 *         Packet Design trademarks, including the mark "PACKET DESIGN"
 *         on advertising, endorsements, or otherwise except as such
 *         appears in the above copyright notice or in the software.
 * 
 * THIS SOFTWARE IS BEING PROVIDED BY PACKET DESIGN "AS IS", AND
 * TO THE MAXIMUM EXTENT PERMITTED BY LAW, PACKET DESIGN MAKES NO
 * REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING
 * THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY AND ALL IMPLIED
 * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
 * OR NON-INFRINGEMENT.  PACKET DESIGN DOES NOT WARRANT, GUARANTEE,
 * OR MAKE ANY REPRESENTATIONS REGARDING THE USE OF, OR THE RESULTS
 * OF THE USE OF THIS SOFTWARE IN TERMS OF ITS CORRECTNESS, ACCURACY,
 * RELIABILITY OR OTHERWISE.  IN NO EVENT SHALL PACKET DESIGN BE
 * LIABLE FOR ANY DAMAGES RESULTING FROM OR ARISING OUT OF ANY USE
 * OF THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY DIRECT,
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, PUNITIVE, OR CONSEQUENTIAL
 * DAMAGES, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, LOSS OF
 * USE, DATA OR PROFITS, HOWEVER CAUSED AND UNDER ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
 * THE USE OF THIS SOFTWARE, EVEN IF PACKET DESIGN IS ADVISED OF
 * THE POSSIBILITY OF SUCH DAMAGE.
 *
 * Author: Archie Cobbs <archie@freebsd.org>
 */

#ifndef _PDEL_UTIL_TINFO_H_
#define _PDEL_UTIL_TINFO_H_

/*
 * Support for generic per-thread data described by a structs type.
 */

struct tinfo;

/*
 * Optional user-supplied initialization routine. The routine should
 * initialize the memory pointed to by "data" as an instance of the
 * structs type for this tinfo data (i.e., t->type). If this method
 * is not supplied (i.e., NULL), then structs_init() is invoked instead.
 */
typedef int	tinfo_init_t(struct tinfo *t, void *data);

/* User-supplied data structure for a tinfo variable */
struct tinfo {
	const struct structs_type	*const type;	/* type for data */
	const char			*const mtype;	/* typed mem string */
	pthread_key_t			pkey;		/* per-thread var */
	tinfo_init_t			*init;		/* initialize data */
};

/* Invalid key value */
#define TINFO_KEY_INIT		(-1)			/* XXX not portable */

/* Always use this macro to initialize a struct tinfo */
#define TINFO_INIT(type, mtype, init)	{ type, mtype, TINFO_KEY_INIT, init }

__BEGIN_DECLS

/*
 * Get thread-local variable.
 *
 * If the variable has not been initialized, a new one is instantiated
 * using the t->type's init method, and t->init is called (if not NULL).
 *
 * The caller should NOT free the returned value, but may modify it
 * in a way consistent with its structs type (i.e., t->type).
 */
extern void	*tinfo_get(struct tinfo *t);

/*
 * Set thread-local variable by copying "data".
 *
 * The "data" pointer must point to an object having structs type t->type.
 * The data is copied using structs_get(). Any previous thread-local
 * value is free'd and replaced.
 *
 * If "data" is NULL, then any existing information is free'd, so that
 * the next call to tinfo_get() will cause the init routine to be called
 * again.
 */
extern int	tinfo_set(struct tinfo *t, const void *data);

/*
 * Set thread-local variable to "data".
 *
 * This sets the thread-local variable to "data" without copying it.
 * "data" must point to memory allocated with type t->mtype.
 * Any previous thread-local value is free'd and replaced.
 *
 * The caller should not reference "data" if this function returns
 * successfully.
 */
extern int	tinfo_set_nocopy(struct tinfo *t, void *data);

__END_DECLS

#endif	/* _PDEL_UTIL_TINFO_H_ */


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>