hc
2024-08-12 0517ab8c70e05fc5877c0c6dae1a5f42a16dcf88
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __USB_UAS_H__
#define __USB_UAS_H__
 
#include <scsi/scsi.h>
#include <scsi/scsi_cmnd.h>
 
/* Common header for all IUs */
struct iu {
   __u8 iu_id;
   __u8 rsvd1;
   __be16 tag;
} __attribute__((__packed__));
 
enum {
   IU_ID_COMMAND        = 0x01,
   IU_ID_STATUS        = 0x03,
   IU_ID_RESPONSE        = 0x04,
   IU_ID_TASK_MGMT        = 0x05,
   IU_ID_READ_READY    = 0x06,
   IU_ID_WRITE_READY    = 0x07,
};
 
enum {
   TMF_ABORT_TASK          = 0x01,
   TMF_ABORT_TASK_SET      = 0x02,
   TMF_CLEAR_TASK_SET      = 0x04,
   TMF_LOGICAL_UNIT_RESET  = 0x08,
   TMF_I_T_NEXUS_RESET     = 0x10,
   TMF_CLEAR_ACA           = 0x40,
   TMF_QUERY_TASK          = 0x80,
   TMF_QUERY_TASK_SET      = 0x81,
   TMF_QUERY_ASYNC_EVENT   = 0x82,
};
 
enum {
   RC_TMF_COMPLETE         = 0x00,
   RC_INVALID_INFO_UNIT    = 0x02,
   RC_TMF_NOT_SUPPORTED    = 0x04,
   RC_TMF_FAILED           = 0x05,
   RC_TMF_SUCCEEDED        = 0x08,
   RC_INCORRECT_LUN        = 0x09,
   RC_OVERLAPPED_TAG       = 0x0a,
};
 
struct command_iu {
   __u8 iu_id;
   __u8 rsvd1;
   __be16 tag;
   __u8 prio_attr;
   __u8 rsvd5;
   __u8 len;
   __u8 rsvd7;
   struct scsi_lun lun;
   __u8 cdb[16];    /* XXX: Overflow-checking tools may misunderstand */
} __attribute__((__packed__));
 
struct task_mgmt_iu {
   __u8 iu_id;
   __u8 rsvd1;
   __be16 tag;
   __u8 function;
   __u8 rsvd2;
   __be16 task_tag;
   struct scsi_lun lun;
} __attribute__((__packed__));
 
/*
 * Also used for the Read Ready and Write Ready IUs since they have the
 * same first four bytes
 */
struct sense_iu {
   __u8 iu_id;
   __u8 rsvd1;
   __be16 tag;
   __be16 status_qual;
   __u8 status;
   __u8 rsvd7[7];
   __be16 len;
   __u8 sense[SCSI_SENSE_BUFFERSIZE];
} __attribute__((__packed__));
 
struct response_iu {
   __u8 iu_id;
   __u8 rsvd1;
   __be16 tag;
   __u8 add_response_info[3];
   __u8 response_code;
} __attribute__((__packed__));
 
struct usb_pipe_usage_descriptor {
   __u8  bLength;
   __u8  bDescriptorType;
 
   __u8  bPipeID;
   __u8  Reserved;
} __attribute__((__packed__));
 
enum {
   CMD_PIPE_ID        = 1,
   STATUS_PIPE_ID        = 2,
   DATA_IN_PIPE_ID        = 3,
   DATA_OUT_PIPE_ID    = 4,
 
   UAS_SIMPLE_TAG        = 0,
   UAS_HEAD_TAG        = 1,
   UAS_ORDERED_TAG        = 2,
   UAS_ACA            = 4,
};
#endif