blob: 74e6ac8487583b5c5be2e952224f18cd4ba55e5e [file] [log] [blame]
Christopher Ferris05d08e92016-02-04 13:16:38 -08001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _LINUX_VIRTIO_SCSI_H
20#define _LINUX_VIRTIO_SCSI_H
21#include <linux/virtio_types.h>
22#define VIRTIO_SCSI_CDB_DEFAULT_SIZE 32
Christopher Ferris05d08e92016-02-04 13:16:38 -080023#define VIRTIO_SCSI_SENSE_DEFAULT_SIZE 96
24#ifndef VIRTIO_SCSI_CDB_SIZE
25#define VIRTIO_SCSI_CDB_SIZE VIRTIO_SCSI_CDB_DEFAULT_SIZE
26#endif
Christopher Ferris05d08e92016-02-04 13:16:38 -080027#ifndef VIRTIO_SCSI_SENSE_SIZE
28#define VIRTIO_SCSI_SENSE_SIZE VIRTIO_SCSI_SENSE_DEFAULT_SIZE
29#endif
30struct virtio_scsi_cmd_req {
Christopher Ferris05d08e92016-02-04 13:16:38 -080031 __u8 lun[8];
32 __virtio64 tag;
33 __u8 task_attr;
34 __u8 prio;
Christopher Ferris05d08e92016-02-04 13:16:38 -080035 __u8 crn;
36 __u8 cdb[VIRTIO_SCSI_CDB_SIZE];
37} __attribute__((packed));
38struct virtio_scsi_cmd_req_pi {
Christopher Ferris05d08e92016-02-04 13:16:38 -080039 __u8 lun[8];
40 __virtio64 tag;
41 __u8 task_attr;
42 __u8 prio;
Christopher Ferris05d08e92016-02-04 13:16:38 -080043 __u8 crn;
44 __virtio32 pi_bytesout;
45 __virtio32 pi_bytesin;
46 __u8 cdb[VIRTIO_SCSI_CDB_SIZE];
Christopher Ferris05d08e92016-02-04 13:16:38 -080047} __attribute__((packed));
48struct virtio_scsi_cmd_resp {
49 __virtio32 sense_len;
50 __virtio32 resid;
Christopher Ferris05d08e92016-02-04 13:16:38 -080051 __virtio16 status_qualifier;
52 __u8 status;
53 __u8 response;
54 __u8 sense[VIRTIO_SCSI_SENSE_SIZE];
Christopher Ferris05d08e92016-02-04 13:16:38 -080055} __attribute__((packed));
56struct virtio_scsi_ctrl_tmf_req {
57 __virtio32 type;
58 __virtio32 subtype;
Christopher Ferris05d08e92016-02-04 13:16:38 -080059 __u8 lun[8];
60 __virtio64 tag;
61} __attribute__((packed));
62struct virtio_scsi_ctrl_tmf_resp {
Christopher Ferris05d08e92016-02-04 13:16:38 -080063 __u8 response;
64} __attribute__((packed));
65struct virtio_scsi_ctrl_an_req {
66 __virtio32 type;
Christopher Ferris05d08e92016-02-04 13:16:38 -080067 __u8 lun[8];
68 __virtio32 event_requested;
69} __attribute__((packed));
70struct virtio_scsi_ctrl_an_resp {
Christopher Ferris05d08e92016-02-04 13:16:38 -080071 __virtio32 event_actual;
72 __u8 response;
73} __attribute__((packed));
74struct virtio_scsi_event {
Christopher Ferris05d08e92016-02-04 13:16:38 -080075 __virtio32 event;
76 __u8 lun[8];
77 __virtio32 reason;
78} __attribute__((packed));
Christopher Ferris05d08e92016-02-04 13:16:38 -080079struct virtio_scsi_config {
Christopher Ferris25c18d42020-10-14 17:42:58 -070080 __virtio32 num_queues;
81 __virtio32 seg_max;
82 __virtio32 max_sectors;
83 __virtio32 cmd_per_lun;
84 __virtio32 event_info_size;
85 __virtio32 sense_size;
86 __virtio32 cdb_size;
87 __virtio16 max_channel;
88 __virtio16 max_target;
89 __virtio32 max_lun;
Christopher Ferris05d08e92016-02-04 13:16:38 -080090} __attribute__((packed));
Christopher Ferris05d08e92016-02-04 13:16:38 -080091#define VIRTIO_SCSI_F_INOUT 0
92#define VIRTIO_SCSI_F_HOTPLUG 1
93#define VIRTIO_SCSI_F_CHANGE 2
94#define VIRTIO_SCSI_F_T10_PI 3
Christopher Ferris05d08e92016-02-04 13:16:38 -080095#define VIRTIO_SCSI_S_OK 0
96#define VIRTIO_SCSI_S_OVERRUN 1
97#define VIRTIO_SCSI_S_ABORTED 2
98#define VIRTIO_SCSI_S_BAD_TARGET 3
Christopher Ferris05d08e92016-02-04 13:16:38 -080099#define VIRTIO_SCSI_S_RESET 4
100#define VIRTIO_SCSI_S_BUSY 5
101#define VIRTIO_SCSI_S_TRANSPORT_FAILURE 6
102#define VIRTIO_SCSI_S_TARGET_FAILURE 7
Christopher Ferris05d08e92016-02-04 13:16:38 -0800103#define VIRTIO_SCSI_S_NEXUS_FAILURE 8
104#define VIRTIO_SCSI_S_FAILURE 9
105#define VIRTIO_SCSI_S_FUNCTION_SUCCEEDED 10
106#define VIRTIO_SCSI_S_FUNCTION_REJECTED 11
Christopher Ferris05d08e92016-02-04 13:16:38 -0800107#define VIRTIO_SCSI_S_INCORRECT_LUN 12
108#define VIRTIO_SCSI_T_TMF 0
109#define VIRTIO_SCSI_T_AN_QUERY 1
110#define VIRTIO_SCSI_T_AN_SUBSCRIBE 2
Christopher Ferris05d08e92016-02-04 13:16:38 -0800111#define VIRTIO_SCSI_T_TMF_ABORT_TASK 0
112#define VIRTIO_SCSI_T_TMF_ABORT_TASK_SET 1
113#define VIRTIO_SCSI_T_TMF_CLEAR_ACA 2
114#define VIRTIO_SCSI_T_TMF_CLEAR_TASK_SET 3
Christopher Ferris05d08e92016-02-04 13:16:38 -0800115#define VIRTIO_SCSI_T_TMF_I_T_NEXUS_RESET 4
116#define VIRTIO_SCSI_T_TMF_LOGICAL_UNIT_RESET 5
117#define VIRTIO_SCSI_T_TMF_QUERY_TASK 6
118#define VIRTIO_SCSI_T_TMF_QUERY_TASK_SET 7
Christopher Ferris05d08e92016-02-04 13:16:38 -0800119#define VIRTIO_SCSI_T_EVENTS_MISSED 0x80000000
120#define VIRTIO_SCSI_T_NO_EVENT 0
121#define VIRTIO_SCSI_T_TRANSPORT_RESET 1
122#define VIRTIO_SCSI_T_ASYNC_NOTIFY 2
Christopher Ferris05d08e92016-02-04 13:16:38 -0800123#define VIRTIO_SCSI_T_PARAM_CHANGE 3
124#define VIRTIO_SCSI_EVT_RESET_HARD 0
125#define VIRTIO_SCSI_EVT_RESET_RESCAN 1
126#define VIRTIO_SCSI_EVT_RESET_REMOVED 2
Christopher Ferris05d08e92016-02-04 13:16:38 -0800127#define VIRTIO_SCSI_S_SIMPLE 0
128#define VIRTIO_SCSI_S_ORDERED 1
129#define VIRTIO_SCSI_S_HEAD 2
130#define VIRTIO_SCSI_S_ACA 3
Christopher Ferris05d08e92016-02-04 13:16:38 -0800131#endif