/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License (the "License"). * You may not use this file except in compliance with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright (c) 2002-2003, Network Appliance, Inc. All rights reserved. */ /* * Copyright 2004 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ /* * * MODULE: dapl_cno_util.c * * PURPOSE: Manage CNO Info structure * * $Id: dapl_cno_util.c,v 1.6 2003/06/13 12:21:02 sjs2 Exp $ */ #include "dapl_ia_util.h" #include "dapl_cno_util.h" #include "dapl_adapter_util.h" /* * dapl_cno_alloc * * alloc and initialize an EVD struct * * Input: * ia * * Returns: * cno_ptr, or null on failure. */ DAPL_CNO * dapl_cno_alloc( IN DAPL_IA *ia_ptr, IN DAT_OS_WAIT_PROXY_AGENT wait_agent) { DAPL_CNO *cno_ptr; cno_ptr = (DAPL_CNO *) dapl_os_alloc(sizeof (DAPL_CNO)); if (!cno_ptr) { return (NULL); } /* zero the structure */ (void) dapl_os_memzero(cno_ptr, sizeof (DAPL_CNO)); /* * Initialize the header. */ cno_ptr->header.provider = ia_ptr->header.provider; cno_ptr->header.magic = DAPL_MAGIC_CNO; cno_ptr->header.handle_type = DAT_HANDLE_TYPE_CNO; cno_ptr->header.owner_ia = ia_ptr; cno_ptr->header.user_context.as_64 = 0; cno_ptr->header.user_context.as_ptr = NULL; dapl_llist_init_entry(&cno_ptr->header.ia_list_entry); dapl_llist_init_head(&cno_ptr->evd_list_head); dapl_os_lock_init(&cno_ptr->header.lock); /* * Initialize the body */ cno_ptr->cno_waiters = 0; cno_ptr->cno_ref_count = 0; cno_ptr->cno_state = DAPL_CNO_STATE_UNTRIGGERED; cno_ptr->cno_evd_triggered = NULL; cno_ptr->cno_wait_agent = wait_agent; (void) dapl_os_wait_object_init(&cno_ptr->cno_wait_object); return (cno_ptr); } /* * dapl_cno_dealloc * * Free the passed in CNO structure. * * Input: * cno_ptr * * Output: * none * * Returns: * none * */ void dapl_cno_dealloc( IN DAPL_CNO *cno_ptr) { dapl_os_assert(cno_ptr->header.magic == DAPL_MAGIC_CNO); dapl_os_assert(cno_ptr->cno_ref_count == 0); /* * deinitialize the header */ /* reset magic to prevent reuse */ cno_ptr->header.magic = DAPL_MAGIC_INVALID; (void) dapl_os_wait_object_destroy(&cno_ptr->cno_wait_object); dapl_os_free(cno_ptr, sizeof (DAPL_CNO)); } /* * dapl_cno_trigger * * DAPL Internal routine to trigger the specified CNO. * Called by the callback of some EVD associated with the CNO. * * Input: * cno_ptr * evd_ptr EVD triggering * * Output: * None * * Returns: * None */ void dapl_cno_trigger( IN DAPL_CNO *cno_ptr, IN DAPL_EVD *evd_ptr) /* ARGSUSED */ { /* * In Solaris uDAPL the CNO is triggered in the kernel */ }