2N/A/*
2N/A * CDDL HEADER START
2N/A *
2N/A * The contents of this file are subject to the terms of the
2N/A * Common Development and Distribution License (the "License").
2N/A * You may not use this file except in compliance with the License.
2N/A *
2N/A * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
2N/A * or http://www.opensolaris.org/os/licensing.
2N/A * See the License for the specific language governing permissions
2N/A * and limitations under the License.
2N/A *
2N/A * When distributing Covered Code, include this CDDL HEADER in each
2N/A * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
2N/A * If applicable, add the following below this CDDL HEADER, with the
2N/A * fields enclosed by brackets "[]" replaced with your own identifying
2N/A * information: Portions Copyright [yyyy] [name of copyright owner]
2N/A *
2N/A * CDDL HEADER END
2N/A */
2N/A
2N/A/*
2N/A * Copyright (c) 2002-2003, Network Appliance, Inc. All rights reserved.
2N/A */
2N/A
2N/A/*
2N/A * Copyright 2003 Sun Microsystems, Inc. All rights reserved.
2N/A * Use is subject to license terms.
2N/A */
2N/A
2N/A/*
2N/A *
2N/A * MODULE: dapl_ep_dup_connect.c
2N/A *
2N/A * PURPOSE: Endpoint management
2N/A * Description: Interfaces in this file are completely described in
2N/A * the DAPL 1.1 API, Chapter 6, section 5
2N/A *
2N/A * $Id: dapl_ep_dup_connect.c,v 1.8 2003/06/16 17:53:32 sjs2 Exp $
2N/A */
2N/A
2N/A#include "dapl.h"
2N/A#include "dapl_ep_util.h"
2N/A#include "dapl_adapter_util.h"
2N/A
2N/A/*
2N/A * dapl_ep_dup_connect
2N/A *
2N/A * DAPL Requirements Version xxx, 6.5.8
2N/A *
2N/A * Requst that a connection be established between the local Endpoint
2N/A * and a remote Endpoint. The remote Endpoint is identified by the
2N/A * dup_ep.
2N/A *
2N/A * Input:
2N/A * ep_handle
2N/A * ep_dup_handle
2N/A * conn_qual
2N/A * timeout
2N/A * private_data_size
2N/A * private_data
2N/A * qos
2N/A *
2N/A * Output:
2N/A * none
2N/A *
2N/A * Returns:
2N/A * DAT_SUCCESS
2N/A * DAT_INSUFFICIENT_RESOURCES
2N/A * DAT_INVALID_PARAMETER
2N/A * DAT_INVALID_STATE
2N/A * DAT_MODEL_NOT_SUPPORTED
2N/A */
2N/A
2N/ADAT_RETURN
2N/Adapl_ep_dup_connect(
2N/A IN DAT_EP_HANDLE ep_handle,
2N/A IN DAT_EP_HANDLE ep_dup_handle,
2N/A IN DAT_TIMEOUT timeout,
2N/A IN DAT_COUNT private_data_size,
2N/A IN const DAT_PVOID private_data,
2N/A IN DAT_QOS qos)
2N/A{
2N/A DAPL_EP *ep_dup_ptr;
2N/A DAT_RETURN dat_status;
2N/A DAT_IA_ADDRESS_PTR remote_ia_address_ptr;
2N/A DAT_CONN_QUAL remote_conn_qual;
2N/A
2N/A ep_dup_ptr = (DAPL_EP *)ep_dup_handle;
2N/A
2N/A /*
2N/A * Verify the dup handle, which must be connected. All other
2N/A * parameters will be verified by dapl_ep_connect
2N/A */
2N/A if (DAPL_BAD_HANDLE(ep_dup_handle, DAPL_MAGIC_EP)) {
2N/A dat_status = DAT_ERROR(DAT_INVALID_HANDLE,
2N/A DAT_INVALID_HANDLE_EP);
2N/A goto bail;
2N/A }
2N/A /*
2N/A * Check both the EP state and the QP state: if we don't have a QP
2N/A * there is a problem. Do this under a lock and pull out
2N/A * the connection parameters for atomicity.
2N/A */
2N/A dapl_os_lock(&ep_dup_ptr->header.lock);
2N/A if (ep_dup_ptr->param.ep_state != DAT_EP_STATE_CONNECTED) {
2N/A dapl_os_unlock(&ep_dup_ptr->header.lock);
2N/A dat_status = DAT_ERROR(DAT_INVALID_STATE,
2N/A dapls_ep_state_subtype(ep_dup_ptr));
2N/A goto bail;
2N/A }
2N/A remote_ia_address_ptr = ep_dup_ptr->param.remote_ia_address_ptr;
2N/A remote_conn_qual = ep_dup_ptr->param.remote_port_qual;
2N/A dapl_os_unlock(&ep_dup_ptr->header.lock);
2N/A
2N/A dat_status = dapl_ep_connect(ep_handle,
2N/A remote_ia_address_ptr, remote_conn_qual, timeout,
2N/A private_data_size, private_data, qos,
2N/A DAT_CONNECT_DEFAULT_FLAG);
2N/A
2N/Abail:
2N/A return (dat_status);
2N/A}