xref: /onnv-gate/usr/src/lib/scsi/libscsi/common/libscsi.h (revision 6316:40d5384cc8b2)
1*6316Seschrock /*
2*6316Seschrock  * CDDL HEADER START
3*6316Seschrock  *
4*6316Seschrock  * The contents of this file are subject to the terms of the
5*6316Seschrock  * Common Development and Distribution License (the "License").
6*6316Seschrock  * You may not use this file except in compliance with the License.
7*6316Seschrock  *
8*6316Seschrock  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*6316Seschrock  * or http://www.opensolaris.org/os/licensing.
10*6316Seschrock  * See the License for the specific language governing permissions
11*6316Seschrock  * and limitations under the License.
12*6316Seschrock  *
13*6316Seschrock  * When distributing Covered Code, include this CDDL HEADER in each
14*6316Seschrock  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*6316Seschrock  * If applicable, add the following below this CDDL HEADER, with the
16*6316Seschrock  * fields enclosed by brackets "[]" replaced with your own identifying
17*6316Seschrock  * information: Portions Copyright [yyyy] [name of copyright owner]
18*6316Seschrock  *
19*6316Seschrock  * CDDL HEADER END
20*6316Seschrock  */
21*6316Seschrock 
22*6316Seschrock /*
23*6316Seschrock  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
24*6316Seschrock  * Use is subject to license terms.
25*6316Seschrock  */
26*6316Seschrock 
27*6316Seschrock #ifndef	_LIBSCSI_H
28*6316Seschrock #define	_LIBSCSI_H
29*6316Seschrock 
30*6316Seschrock #pragma ident	"%Z%%M%	%I%	%E% SMI"
31*6316Seschrock 
32*6316Seschrock #ifdef	__cplusplus
33*6316Seschrock extern "C" {
34*6316Seschrock #endif
35*6316Seschrock 
36*6316Seschrock #include <sys/types.h>
37*6316Seschrock #include <sys/sysmacros.h>
38*6316Seschrock #include <sys/scsi/impl/spc3_types.h>
39*6316Seschrock #include <stdarg.h>
40*6316Seschrock 
41*6316Seschrock #define	LIBSCSI_VERSION		1
42*6316Seschrock #define	LIBSCSI_STATUS_INVALID	((sam4_status_t)-1)
43*6316Seschrock #define	LIBSCSI_DEFAULT_ENGINE_PATH	"/usr/lib/scsi/plugins/scsi/engines"
44*6316Seschrock #define	LIBSCSI_DEFAULT_ENGINE	"uscsi"
45*6316Seschrock 
46*6316Seschrock /*
47*6316Seschrock  * Flags for action creation.  Selected to avoid overlap with the uscsi
48*6316Seschrock  * flags with similar or identical meaning.
49*6316Seschrock  */
50*6316Seschrock #define	LIBSCSI_AF_READ		0x80000000
51*6316Seschrock #define	LIBSCSI_AF_WRITE	0x40000000
52*6316Seschrock #define	LIBSCSI_AF_SILENT	0x20000000
53*6316Seschrock #define	LIBSCSI_AF_DIAGNOSE	0x10000000
54*6316Seschrock #define	LIBSCSI_AF_ISOLATE	0x08000000
55*6316Seschrock #define	LIBSCSI_AF_RQSENSE	0x04000000
56*6316Seschrock 
57*6316Seschrock typedef enum libscsi_errno {
58*6316Seschrock 	ESCSI_NONE,		/* no error */
59*6316Seschrock 	ESCSI_NOMEM,		/* no memory */
60*6316Seschrock 	ESCSI_ZERO_LENGTH,	/* zero-length allocation requested */
61*6316Seschrock 	ESCSI_VERSION,		/* library version mismatch */
62*6316Seschrock 	ESCSI_BADTARGET,	/* invalid target specification */
63*6316Seschrock 	ESCSI_BADCMD,		/* invalid SCSI command */
64*6316Seschrock 	ESCSI_BADENGINE,	/* engine library corrupt */
65*6316Seschrock 	ESCSI_NOENGINE,		/* engine library not found */
66*6316Seschrock 	ESCSI_ENGINE_INIT,	/* engine initialization failed */
67*6316Seschrock 	ESCSI_ENGINE_VER,	/* engine version mismatch */
68*6316Seschrock 	ESCSI_ENGINE_BADPATH,	/* engine path contains no usable components */
69*6316Seschrock 	ESCSI_BADFLAGS,		/* incorrect action flags */
70*6316Seschrock 	ESCSI_BOGUSFLAGS,	/* unknown flag value */
71*6316Seschrock 	ESCSI_BADLENGTH,	/* buffer length overflow */
72*6316Seschrock 	ESCSI_NEEDBUF,		/* missing required buffer */
73*6316Seschrock 	ESCSI_IO,		/* I/O operation failed */
74*6316Seschrock 	ESCSI_SYS,		/* system call failed */
75*6316Seschrock 	ESCSI_PERM,		/* insufficient permissions */
76*6316Seschrock 	ESCSI_RANGE,		/* parameter outside valid range */
77*6316Seschrock 	ESCSI_NOTSUP,		/* operation not supported */
78*6316Seschrock 	ESCSI_UNKNOWN,		/* error of unknown type */
79*6316Seschrock 	ESCSI_INQUIRY_FAILED,	/* initial inquiry command failed */
80*6316Seschrock 	ESCSI_MAX		/* maximum libscsi errno value */
81*6316Seschrock } libscsi_errno_t;
82*6316Seschrock 
83*6316Seschrock struct libscsi_hdl;
84*6316Seschrock typedef struct libscsi_hdl libscsi_hdl_t;
85*6316Seschrock 
86*6316Seschrock struct libscsi_target;
87*6316Seschrock typedef struct libscsi_target libscsi_target_t;
88*6316Seschrock 
89*6316Seschrock typedef struct libscsi_status {
90*6316Seschrock 	uint64_t lss_status;		/* SCSI status of this command */
91*6316Seschrock 	size_t lss_sense_len;		/* Length in bytes of sense data */
92*6316Seschrock 	uint8_t *lss_sense_data;	/* Pointer to sense data */
93*6316Seschrock } libscsi_status_t;
94*6316Seschrock 
95*6316Seschrock struct libscsi_action;
96*6316Seschrock typedef struct libscsi_action libscsi_action_t;
97*6316Seschrock 
98*6316Seschrock struct libscsi_result;
99*6316Seschrock typedef struct libscsi_result libscsi_result_t;
100*6316Seschrock 
101*6316Seschrock typedef struct libscsi_engine_ops {
102*6316Seschrock 	void *(*lseo_open)(libscsi_hdl_t *, const void *);
103*6316Seschrock 	void (*lseo_close)(libscsi_hdl_t *, void *);
104*6316Seschrock 	int (*lseo_exec)(libscsi_hdl_t *, void *, libscsi_action_t *);
105*6316Seschrock 	void (*lseo_target_name)(libscsi_hdl_t *, void *, char *, size_t);
106*6316Seschrock } libscsi_engine_ops_t;
107*6316Seschrock 
108*6316Seschrock typedef struct libscsi_engine {
109*6316Seschrock 	const char *lse_name;
110*6316Seschrock 	uint_t lse_libversion;
111*6316Seschrock 	const libscsi_engine_ops_t *lse_ops;
112*6316Seschrock } libscsi_engine_t;
113*6316Seschrock 
114*6316Seschrock extern libscsi_hdl_t *libscsi_init(uint_t, libscsi_errno_t *);
115*6316Seschrock extern void libscsi_fini(libscsi_hdl_t *);
116*6316Seschrock 
117*6316Seschrock extern libscsi_target_t *libscsi_open(libscsi_hdl_t *, const char *,
118*6316Seschrock     const void *);
119*6316Seschrock extern void libscsi_close(libscsi_hdl_t *, libscsi_target_t *);
120*6316Seschrock extern libscsi_hdl_t *libscsi_get_handle(libscsi_target_t *);
121*6316Seschrock 
122*6316Seschrock extern const char *libscsi_vendor(libscsi_target_t *);
123*6316Seschrock extern const char *libscsi_product(libscsi_target_t *);
124*6316Seschrock extern const char *libscsi_revision(libscsi_target_t *);
125*6316Seschrock 
126*6316Seschrock extern libscsi_errno_t libscsi_errno(libscsi_hdl_t *);
127*6316Seschrock extern const char *libscsi_errmsg(libscsi_hdl_t *);
128*6316Seschrock extern const char *libscsi_strerror(libscsi_errno_t);
129*6316Seschrock extern const char *libscsi_errname(libscsi_errno_t);
130*6316Seschrock extern libscsi_errno_t libscsi_errcode(const char *);
131*6316Seschrock 
132*6316Seschrock extern libscsi_action_t *libscsi_action_alloc(libscsi_hdl_t *, spc3_cmd_t,
133*6316Seschrock     uint_t, void *, size_t);
134*6316Seschrock extern sam4_status_t libscsi_action_get_status(const libscsi_action_t *);
135*6316Seschrock extern void libscsi_action_set_timeout(libscsi_action_t *, uint32_t);
136*6316Seschrock extern uint32_t libscsi_action_get_timeout(const libscsi_action_t *);
137*6316Seschrock extern uint_t libscsi_action_get_flags(const libscsi_action_t *);
138*6316Seschrock extern uint8_t *libscsi_action_get_cdb(const libscsi_action_t *);
139*6316Seschrock extern int libscsi_action_get_buffer(const libscsi_action_t *,
140*6316Seschrock     uint8_t **, size_t *, size_t *);
141*6316Seschrock extern int libscsi_action_get_sense(const libscsi_action_t *,
142*6316Seschrock     uint8_t **, size_t *, size_t *);
143*6316Seschrock extern int libscsi_action_parse_sense(const libscsi_action_t *, uint64_t *,
144*6316Seschrock     uint64_t *, uint64_t *, diskaddr_t *);
145*6316Seschrock extern void libscsi_action_set_status(libscsi_action_t *, sam4_status_t);
146*6316Seschrock extern int libscsi_action_set_datalen(libscsi_action_t *, size_t);
147*6316Seschrock extern int libscsi_action_set_senselen(libscsi_action_t *, size_t);
148*6316Seschrock extern int libscsi_exec(libscsi_action_t *, libscsi_target_t *);
149*6316Seschrock extern void libscsi_action_free(libscsi_action_t *);
150*6316Seschrock 
151*6316Seschrock extern const char *libscsi_sense_key_name(uint64_t);
152*6316Seschrock extern const char *libscsi_sense_code_name(uint64_t, uint64_t);
153*6316Seschrock 
154*6316Seschrock /*
155*6316Seschrock  * Interfaces for engine providers
156*6316Seschrock  */
157*6316Seschrock extern void *libscsi_alloc(libscsi_hdl_t *, size_t);
158*6316Seschrock extern void *libscsi_zalloc(libscsi_hdl_t *, size_t);
159*6316Seschrock extern char *libscsi_strdup(libscsi_hdl_t *, const char *);
160*6316Seschrock extern void libscsi_free(libscsi_hdl_t *, void *);
161*6316Seschrock extern libscsi_status_t *libscsi_status_alloc(libscsi_hdl_t *, size_t);
162*6316Seschrock extern int libscsi_status_fill(libscsi_hdl_t *, libscsi_status_t *,
163*6316Seschrock     uint16_t, size_t);
164*6316Seschrock extern void libscsi_status_free(libscsi_hdl_t *, libscsi_status_t *);
165*6316Seschrock 
166*6316Seschrock extern int libscsi_set_errno(libscsi_hdl_t *, libscsi_errno_t);
167*6316Seschrock extern int libscsi_verror(libscsi_hdl_t *, libscsi_errno_t, const char *,
168*6316Seschrock     va_list);
169*6316Seschrock extern int libscsi_error(libscsi_hdl_t *, libscsi_errno_t, const char *, ...);
170*6316Seschrock 
171*6316Seschrock typedef const libscsi_engine_t *(*libscsi_engine_init_f)(libscsi_hdl_t *);
172*6316Seschrock 
173*6316Seschrock /*
174*6316Seschrock  * Generic SCSI utility functions.
175*6316Seschrock  */
176*6316Seschrock extern size_t libscsi_cmd_cdblen(libscsi_hdl_t *, uint8_t);
177*6316Seschrock 
178*6316Seschrock #ifdef	__cplusplus
179*6316Seschrock }
180*6316Seschrock #endif
181*6316Seschrock 
182*6316Seschrock #endif	/* _LIBSCSI_H */
183