/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (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 1996-2003 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #include "mt.h" #include #include #include #include #include "tx.h" /* * Prefix: _xti_ * * The _xti_ prefix is the default prefix for these functions. A function * having the _xti_ prefix means one of the following. * a. This interface remains unchanged in all versions of XTI, starting * with the version of XTI in which it was first introduced. * Consequently there is no other entry point, with a different * prefix for this interface. * b. This interface has changed subsequent to when it was first. This * function is meant for compatibility and provides the semantics of * the XTI version when it was first introduced. * * The _xti_xns5_ prefix is used for functions that provide XNS Issue 5 * (UNIX98) semantics. It means the following. * The UNIX98 version of this interface has different semantics * as compared to UNIX95, and this function provides UNIX98 semantics * */ int _xti_accept(int fd, int resfd, const struct t_call *call) { return (_tx_accept(fd, resfd, call, TX_XTI_API)); } int _xti_xns5_accept(int fd, int resfd, const struct t_call *call) { return (_tx_accept(fd, resfd, call, TX_XTI_XNS5_API)); } void * _xti_alloc(int fd, int struct_type, int fields) { return (_tx_alloc(fd, struct_type, fields, TX_XTI_API)); } int _xti_bind(int fd, const struct t_bind *req, struct t_bind *ret) { return (_tx_bind(fd, req, ret, TX_XTI_API)); } int _xti_close(int fd) { return (_tx_close(fd, TX_XTI_API)); } int _xti_connect(int fd, const struct t_call *sndcall, struct t_call *rcvcall) { return (_tx_connect(fd, sndcall, rcvcall, TX_XTI_API)); } /* * Note: The TLI version of t_error has return type void. XTI has "int". * The spec probably needs to change to void * */ int _xti_error(const char *errmsg) { return (_tx_error(errmsg, TX_XTI_API)); } int _xti_free(void *ptr, int struct_type) { return (_tx_free(ptr, struct_type, TX_XTI_API)); } int _xti_getinfo(int fd, struct t_info *info) { return (_tx_getinfo(fd, info, TX_XTI_API)); } int _xti_getprotaddr(int fd, struct t_bind *boundaddr, struct t_bind *peeraddr) { return (_tx_getprotaddr(fd, boundaddr, peeraddr, TX_XTI_API)); } int _xti_getstate(int fd) { return (_tx_getstate(fd, TX_XTI_API)); } int _xti_listen(int fd, struct t_call *call) { return (_tx_listen(fd, call, TX_XTI_API)); } int _xti_look(int fd) { return (_tx_look(fd, TX_XTI_API)); } int _xti_open(const char *path, int flags, struct t_info *info) { return (_tx_open(path, flags, info, TX_XTI_API)); } int _xti_optmgmt(int fd, const struct t_optmgmt *req, struct t_optmgmt *ret) { return (_tx_optmgmt(fd, req, ret, TX_XTI_API)); } int _xti_rcv(int fd, void *buf, unsigned int nbytes, int *flags) { return (_tx_rcv(fd, buf, nbytes, flags, TX_XTI_API)); } int _xti_rcvconnect(int fd, struct t_call *call) { return (_tx_rcvconnect(fd, call, TX_XTI_API)); } int _xti_rcvdis(int fd, struct t_discon *discon) { return (_tx_rcvdis(fd, discon, TX_XTI_API)); } int _xti_rcvrel(int fd) { return (_tx_rcvrel(fd, TX_XTI_API)); } int _xti_rcvreldata(int fd, struct t_discon *discon) { return (_tx_rcvreldata(fd, discon, TX_XTI_XNS5_API)); } int _xti_rcvudata(int fd, struct t_unitdata *unitdata, int *flags) { return (_tx_rcvudata(fd, unitdata, flags, TX_XTI_API)); } int _xti_rcvuderr(int fd, struct t_uderr *uderr) { return (_tx_rcvuderr(fd, uderr, TX_XTI_API)); } int _xti_rcvv(int fd, struct t_iovec *tiov, unsigned int tiovcount, int *flags) { return (_tx_rcvv(fd, tiov, tiovcount, flags, TX_XTI_XNS5_API)); } int _xti_rcvvudata(int fd, struct t_unitdata *unitdata, struct t_iovec *tiov, unsigned int tiovcount, int *flags) { return (_tx_rcvvudata(fd, unitdata, tiov, tiovcount, flags, TX_XTI_XNS5_API)); } int _xti_snd(int fd, void *buf, unsigned int nbytes, int flags) { return (_tx_snd(fd, buf, nbytes, flags, TX_XTI_API)); } int _xti_xns5_snd(int fd, void *buf, unsigned int nbytes, int flags) { return (_tx_snd(fd, buf, nbytes, flags, TX_XTI_XNS5_API)); } int _xti_snddis(int fd, const struct t_call *call) { return (_tx_snddis(fd, call, TX_XTI_API)); } int _xti_sndrel(int fd) { return (_tx_sndrel(fd, TX_XTI_API)); } int _xti_sndreldata(int fd, struct t_discon *discon) { return (_tx_sndreldata(fd, discon, TX_XTI_XNS5_API)); } int _xti_sndudata(int fd, const struct t_unitdata *unitdata) { return (_tx_sndudata(fd, unitdata, TX_XTI_API)); } int _xti_sndv(int fd, const struct t_iovec *tiov, unsigned int tiovcount, int flags) { return (_tx_sndv(fd, tiov, tiovcount, flags, TX_XTI_XNS5_API)); } int _xti_sndvudata(int fd, struct t_unitdata *unitdata, struct t_iovec *tiov, unsigned int tiovcount) { return (_tx_sndvudata(fd, unitdata, tiov, tiovcount, TX_XTI_XNS5_API)); } const char * _xti_strerror(int errnum) { return (_tx_strerror(errnum, TX_XTI_API)); } int _xti_sync(int fd) { return (_tx_sync(fd, TX_XTI_API)); } int _xti_sysconf(int name) { return (_tx_sysconf(name, TX_XTI_XNS5_API)); } int _xti_unbind(int fd) { return (_tx_unbind(fd, TX_XTI_API)); }