root/usr/src/lib/udapl/udapl_tavor/common/dapl_cno_util.c
/*
 * 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
         */
}