Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 1 | /**************************************************************************** |
| 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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 23 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 27 | #ifndef VIRTIO_SCSI_SENSE_SIZE |
| 28 | #define VIRTIO_SCSI_SENSE_SIZE VIRTIO_SCSI_SENSE_DEFAULT_SIZE |
| 29 | #endif |
| 30 | struct virtio_scsi_cmd_req { |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 31 | __u8 lun[8]; |
| 32 | __virtio64 tag; |
| 33 | __u8 task_attr; |
| 34 | __u8 prio; |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 35 | __u8 crn; |
| 36 | __u8 cdb[VIRTIO_SCSI_CDB_SIZE]; |
| 37 | } __attribute__((packed)); |
| 38 | struct virtio_scsi_cmd_req_pi { |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 39 | __u8 lun[8]; |
| 40 | __virtio64 tag; |
| 41 | __u8 task_attr; |
| 42 | __u8 prio; |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 43 | __u8 crn; |
| 44 | __virtio32 pi_bytesout; |
| 45 | __virtio32 pi_bytesin; |
| 46 | __u8 cdb[VIRTIO_SCSI_CDB_SIZE]; |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 47 | } __attribute__((packed)); |
| 48 | struct virtio_scsi_cmd_resp { |
| 49 | __virtio32 sense_len; |
| 50 | __virtio32 resid; |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 51 | __virtio16 status_qualifier; |
| 52 | __u8 status; |
| 53 | __u8 response; |
| 54 | __u8 sense[VIRTIO_SCSI_SENSE_SIZE]; |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 55 | } __attribute__((packed)); |
| 56 | struct virtio_scsi_ctrl_tmf_req { |
| 57 | __virtio32 type; |
| 58 | __virtio32 subtype; |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 59 | __u8 lun[8]; |
| 60 | __virtio64 tag; |
| 61 | } __attribute__((packed)); |
| 62 | struct virtio_scsi_ctrl_tmf_resp { |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 63 | __u8 response; |
| 64 | } __attribute__((packed)); |
| 65 | struct virtio_scsi_ctrl_an_req { |
| 66 | __virtio32 type; |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 67 | __u8 lun[8]; |
| 68 | __virtio32 event_requested; |
| 69 | } __attribute__((packed)); |
| 70 | struct virtio_scsi_ctrl_an_resp { |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 71 | __virtio32 event_actual; |
| 72 | __u8 response; |
| 73 | } __attribute__((packed)); |
| 74 | struct virtio_scsi_event { |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 75 | __virtio32 event; |
| 76 | __u8 lun[8]; |
| 77 | __virtio32 reason; |
| 78 | } __attribute__((packed)); |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 79 | struct virtio_scsi_config { |
Christopher Ferris | 25c18d4 | 2020-10-14 17:42:58 -0700 | [diff] [blame] | 80 | __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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 90 | } __attribute__((packed)); |
Christopher Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 91 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 95 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 99 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 103 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 107 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 111 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 115 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 119 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 123 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 127 | #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 Ferris | 05d08e9 | 2016-02-04 13:16:38 -0800 | [diff] [blame] | 131 | #endif |