diff options
| author | Alexandra Ellwood <lxs@mit.edu> | 2007-06-12 21:07:16 +0000 |
|---|---|---|
| committer | Alexandra Ellwood <lxs@mit.edu> | 2007-06-12 21:07:16 +0000 |
| commit | 05b0fe74bb6eb10a49333d42f9f1677235863f85 (patch) | |
| tree | bbf3ca5514c49c0ac7d4f70073cb3208607cc05d /src/ccapi/server/ccs_lockref.c | |
| parent | fd7e3b884d0fa19a4d9b1f1965e656b62beb7351 (diff) | |
Add advisory locking to CCAPI
Added code to trash client crashes. Reorganized server launch to make
it easier to implement platform specific code.
ticket: new
status: open
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@19573 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/ccapi/server/ccs_lockref.c')
| -rw-r--r-- | src/ccapi/server/ccs_lockref.c | 121 |
1 files changed, 121 insertions, 0 deletions
diff --git a/src/ccapi/server/ccs_lockref.c b/src/ccapi/server/ccs_lockref.c new file mode 100644 index 0000000000..78f80ae5d1 --- /dev/null +++ b/src/ccapi/server/ccs_lockref.c @@ -0,0 +1,121 @@ +/* + * $Header$ + * + * Copyright 2006 Massachusetts Institute of Technology. + * All Rights Reserved. + * + * Export of this software from the United States of America may + * require a specific license from the United States Government. + * It is the responsibility of any person or organization contemplating + * export to obtain such a license before exporting. + * + * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and + * distribute this software and its documentation for any purpose and + * without fee is hereby granted, provided that the above copyright + * notice appear in all copies and that both that copyright notice and + * this permission notice appear in supporting documentation, and that + * the name of M.I.T. not be used in advertising or publicity pertaining + * to distribution of the software without specific, written prior + * permission. Furthermore if you modify this software you must label + * your software as modified software and not distribute it in such a + * fashion that it might be confused with the original M.I.T. software. + * M.I.T. makes no representations about the suitability of + * this software for any purpose. It is provided "as is" without express + * or implied warranty. + */ + +#include "ccs_common.h" + +struct ccs_lockref_d { + ccs_client_t client_owner; + ccs_lock_t lock; +}; + +struct ccs_lockref_d ccs_lockref_initializer = { NULL, NULL }; + +/* ------------------------------------------------------------------------ */ + +cc_int32 ccs_lockref_new (ccs_lockref_t *out_lockref, + ccs_client_t in_client_owner, + ccs_lock_t in_lock) +{ + cc_int32 err = ccNoError; + ccs_lockref_t lockref = NULL; + + if (!out_lockref ) { err = cci_check_error (ccErrBadParam); } + if (!in_client_owner) { err = cci_check_error (ccErrBadParam); } + if (!in_lock ) { err = cci_check_error (ccErrBadParam); } + + if (!err) { + lockref = malloc (sizeof (*lockref)); + if (lockref) { + *lockref = ccs_lockref_initializer; + } else { + err = cci_check_error (ccErrNoMem); + } + } + + if (!err) { + lockref->client_owner = in_client_owner; + lockref->lock = in_lock; + + *out_lockref = lockref; + lockref = NULL; + } + + ccs_lockref_release (lockref); + + return cci_check_error (err); +} + +/* ------------------------------------------------------------------------ */ + +cc_int32 ccs_lockref_release (ccs_lockref_t io_lockref) +{ + cc_int32 err = ccNoError; + + if (!io_lockref) { err = cci_check_error (ccErrBadParam); } + + if (!err) { + if (io_lockref->lock) { + ccs_lock_invalidate (io_lockref->lock); + } + free (io_lockref); + } + + return cci_check_error (err); +} + +/* ------------------------------------------------------------------------ */ + +cc_int32 ccs_lockref_invalidate (ccs_lockref_t io_lockref) +{ + cc_int32 err = ccNoError; + + if (!io_lockref) { err = cci_check_error (ccErrBadParam); } + + if (!err) { + io_lockref->lock = NULL; /* so we don't loop */ + } + + return cci_check_error (err); +} + +/* ------------------------------------------------------------------------ */ + +cc_int32 ccs_lockref_is_for_lock (ccs_lockref_t in_lockref, + ccs_lock_t in_lock, + cc_uint32 *out_is_for_lock) +{ + cc_int32 err = ccNoError; + + if (!in_lockref ) { err = cci_check_error (ccErrBadParam); } + if (!in_lock ) { err = cci_check_error (ccErrBadParam); } + if (!out_is_for_lock) { err = cci_check_error (ccErrBadParam); } + + if (!err) { + *out_is_for_lock = (in_lockref->lock == in_lock); + } + + return cci_check_error (err); +} |
