Home | History | Annotate | Line # | Download | only in i2o
iopio.h revision 1.5.10.1
      1  1.5.10.1    yamt /*	$NetBSD: iopio.h,v 1.5.10.1 2008/05/16 02:24:01 yamt Exp $	*/
      2       1.1      ad 
      3       1.1      ad /*-
      4       1.1      ad  * Copyright (c) 2000, 2001 The NetBSD Foundation, Inc.
      5       1.1      ad  * All rights reserved.
      6       1.1      ad  *
      7       1.1      ad  * This code is derived from software contributed to The NetBSD Foundation
      8       1.1      ad  * by Andrew Doran.
      9       1.1      ad  *
     10       1.1      ad  * Redistribution and use in source and binary forms, with or without
     11       1.1      ad  * modification, are permitted provided that the following conditions
     12       1.1      ad  * are met:
     13       1.1      ad  * 1. Redistributions of source code must retain the above copyright
     14       1.1      ad  *    notice, this list of conditions and the following disclaimer.
     15       1.1      ad  * 2. Redistributions in binary form must reproduce the above copyright
     16       1.1      ad  *    notice, this list of conditions and the following disclaimer in the
     17       1.1      ad  *    documentation and/or other materials provided with the distribution.
     18       1.1      ad  *
     19       1.1      ad  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20       1.1      ad  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21       1.1      ad  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22       1.1      ad  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23       1.1      ad  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24       1.1      ad  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25       1.1      ad  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26       1.1      ad  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27       1.1      ad  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28       1.1      ad  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29       1.1      ad  * POSSIBILITY OF SUCH DAMAGE.
     30       1.1      ad  */
     31       1.1      ad 
     32       1.1      ad #ifndef _I2O_IOPIO_H_
     33       1.1      ad #define	_I2O_IOPIO_H_
     34       1.1      ad 
     35       1.1      ad #define	IOP_MAX_MSG_XFERS	3	/* Maximum transfer count per msg */
     36       1.1      ad #define	IOP_MAX_OUTBOUND	256	/* Maximum outbound queue depth */
     37       1.1      ad #define	IOP_MAX_INBOUND		256	/* Maximum inbound queue depth */
     38       1.1      ad #define	IOP_MF_RESERVE		4	/* Frames to reserve for ctl ops */
     39       1.1      ad #define	IOP_MAX_XFER		64*1024	/* Maximum transfer size */
     40       1.2      ad #define	IOP_MAX_MSG_SIZE	160	/* Maximum message frame size */
     41       1.2      ad #define	IOP_MIN_MSG_SIZE	128	/* Minumum size supported by IOP */
     42       1.1      ad 
     43       1.1      ad struct iop_tidmap {
     44       1.1      ad 	u_short	it_tid;
     45       1.1      ad 	u_short	it_flags;
     46       1.5  dyoung 	char	it_dvname[16];
     47       1.1      ad };
     48       1.1      ad #define	IT_CONFIGURED	0x02	/* target configured */
     49       1.1      ad 
     50       1.1      ad struct ioppt_buf {
     51       1.1      ad 	void	*ptb_data;	/* pointer to buffer */
     52       1.1      ad 	size_t	ptb_datalen;	/* buffer size in bytes */
     53       1.1      ad 	int	ptb_out;	/* non-zero if transfer is to IOP */
     54       1.1      ad };
     55       1.1      ad 
     56       1.1      ad struct ioppt {
     57       1.1      ad 	void	*pt_msg;	/* pointer to message buffer */
     58       1.1      ad 	size_t	pt_msglen;	/* message buffer size in bytes */
     59       1.1      ad 	void	*pt_reply;	/* pointer to reply buffer */
     60       1.1      ad 	size_t	pt_replylen;	/* reply buffer size in bytes */
     61       1.1      ad 	int	pt_timo;	/* completion timeout in ms */
     62       1.1      ad 	int	pt_nbufs;	/* number of transfers */
     63       1.1      ad 	struct	ioppt_buf pt_bufs[IOP_MAX_MSG_XFERS]; /* transfers */
     64       1.1      ad };
     65       1.1      ad 
     66       1.1      ad #define	IOPIOCPT	_IOWR('u', 0, struct ioppt)
     67       1.1      ad #define	IOPIOCGLCT	_IOWR('u', 1, struct iovec)
     68       1.1      ad #define	IOPIOCGSTATUS	_IOWR('u', 2, struct iovec)
     69       1.1      ad #define	IOPIOCRECONFIG	_IO('u', 3)
     70       1.1      ad #define	IOPIOCGTIDMAP	_IOWR('u', 4, struct iovec)
     71       1.1      ad 
     72       1.1      ad #endif	/* !_I2O_IOPIO_H_ */
     73