1  /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2  #ifndef _UAPIBSG_H
3  #define _UAPIBSG_H
4  
5  #include <linux/types.h>
6  
7  #define BSG_PROTOCOL_SCSI		0
8  
9  #define BSG_SUB_PROTOCOL_SCSI_CMD	0
10  #define BSG_SUB_PROTOCOL_SCSI_TMF	1
11  #define BSG_SUB_PROTOCOL_SCSI_TRANSPORT	2
12  
13  /*
14   * For flag constants below:
15   * sg.h sg_io_hdr also has bits defined for it's flags member. These
16   * two flag values (0x10 and 0x20) have the same meaning in sg.h . For
17   * bsg the BSG_FLAG_Q_AT_HEAD flag is ignored since it is the deafult.
18   */
19  #define BSG_FLAG_Q_AT_TAIL 0x10 /* default is Q_AT_HEAD */
20  #define BSG_FLAG_Q_AT_HEAD 0x20
21  
22  struct sg_io_v4 {
23  	__s32 guard;		/* [i] 'Q' to differentiate from v3 */
24  	__u32 protocol;		/* [i] 0 -> SCSI , .... */
25  	__u32 subprotocol;	/* [i] 0 -> SCSI command, 1 -> SCSI task
26  				   management function, .... */
27  
28  	__u32 request_len;	/* [i] in bytes */
29  	__u64 request;		/* [i], [*i] {SCSI: cdb} */
30  	__u64 request_tag;	/* [i] {SCSI: task tag (only if flagged)} */
31  	__u32 request_attr;	/* [i] {SCSI: task attribute} */
32  	__u32 request_priority;	/* [i] {SCSI: task priority} */
33  	__u32 request_extra;	/* [i] {spare, for padding} */
34  	__u32 max_response_len;	/* [i] in bytes */
35  	__u64 response;		/* [i], [*o] {SCSI: (auto)sense data} */
36  
37          /* "dout_": data out (to device); "din_": data in (from device) */
38  	__u32 dout_iovec_count;	/* [i] 0 -> "flat" dout transfer else
39  				   dout_xfer points to array of iovec */
40  	__u32 dout_xfer_len;	/* [i] bytes to be transferred to device */
41  	__u32 din_iovec_count;	/* [i] 0 -> "flat" din transfer */
42  	__u32 din_xfer_len;	/* [i] bytes to be transferred from device */
43  	__u64 dout_xferp;	/* [i], [*i] */
44  	__u64 din_xferp;	/* [i], [*o] */
45  
46  	__u32 timeout;		/* [i] units: millisecond */
47  	__u32 flags;		/* [i] bit mask */
48  	__u64 usr_ptr;		/* [i->o] unused internally */
49  	__u32 spare_in;		/* [i] */
50  
51  	__u32 driver_status;	/* [o] 0 -> ok */
52  	__u32 transport_status;	/* [o] 0 -> ok */
53  	__u32 device_status;	/* [o] {SCSI: command completion status} */
54  	__u32 retry_delay;	/* [o] {SCSI: status auxiliary information} */
55  	__u32 info;		/* [o] additional information */
56  	__u32 duration;		/* [o] time to complete, in milliseconds */
57  	__u32 response_len;	/* [o] bytes of response actually written */
58  	__s32 din_resid;	/* [o] din_xfer_len - actual_din_xfer_len */
59  	__s32 dout_resid;	/* [o] dout_xfer_len - actual_dout_xfer_len */
60  	__u64 generated_tag;	/* [o] {SCSI: transport generated task tag} */
61  	__u32 spare_out;	/* [o] */
62  
63  	__u32 padding;
64  };
65  
66  
67  #endif /* _UAPIBSG_H */
68