virtio_sys/
virtio_scsi.rs

1/* automatically generated by tools/bindgen-all-the-things */
2
3#![allow(clippy::missing_safety_doc)]
4#![allow(clippy::undocumented_unsafe_blocks)]
5#![allow(clippy::upper_case_acronyms)]
6#![allow(non_upper_case_globals)]
7#![allow(non_camel_case_types)]
8#![allow(non_snake_case)]
9#![allow(dead_code)]
10
11// Added by virtio_sys/bindgen.sh
12use zerocopy::FromBytes;
13use zerocopy::Immutable;
14use zerocopy::IntoBytes;
15use zerocopy::KnownLayout;
16
17pub const VIRTIO_SCSI_CDB_DEFAULT_SIZE: u32 = 32;
18pub const VIRTIO_SCSI_SENSE_DEFAULT_SIZE: u32 = 96;
19pub const VIRTIO_SCSI_CDB_SIZE: u32 = 32;
20pub const VIRTIO_SCSI_SENSE_SIZE: u32 = 96;
21pub const VIRTIO_SCSI_F_INOUT: u32 = 0;
22pub const VIRTIO_SCSI_F_HOTPLUG: u32 = 1;
23pub const VIRTIO_SCSI_F_CHANGE: u32 = 2;
24pub const VIRTIO_SCSI_F_T10_PI: u32 = 3;
25pub const VIRTIO_SCSI_S_OK: u32 = 0;
26pub const VIRTIO_SCSI_S_OVERRUN: u32 = 1;
27pub const VIRTIO_SCSI_S_ABORTED: u32 = 2;
28pub const VIRTIO_SCSI_S_BAD_TARGET: u32 = 3;
29pub const VIRTIO_SCSI_S_RESET: u32 = 4;
30pub const VIRTIO_SCSI_S_BUSY: u32 = 5;
31pub const VIRTIO_SCSI_S_TRANSPORT_FAILURE: u32 = 6;
32pub const VIRTIO_SCSI_S_TARGET_FAILURE: u32 = 7;
33pub const VIRTIO_SCSI_S_NEXUS_FAILURE: u32 = 8;
34pub const VIRTIO_SCSI_S_FAILURE: u32 = 9;
35pub const VIRTIO_SCSI_S_FUNCTION_SUCCEEDED: u32 = 10;
36pub const VIRTIO_SCSI_S_FUNCTION_REJECTED: u32 = 11;
37pub const VIRTIO_SCSI_S_INCORRECT_LUN: u32 = 12;
38pub const VIRTIO_SCSI_T_TMF: u32 = 0;
39pub const VIRTIO_SCSI_T_AN_QUERY: u32 = 1;
40pub const VIRTIO_SCSI_T_AN_SUBSCRIBE: u32 = 2;
41pub const VIRTIO_SCSI_T_TMF_ABORT_TASK: u32 = 0;
42pub const VIRTIO_SCSI_T_TMF_ABORT_TASK_SET: u32 = 1;
43pub const VIRTIO_SCSI_T_TMF_CLEAR_ACA: u32 = 2;
44pub const VIRTIO_SCSI_T_TMF_CLEAR_TASK_SET: u32 = 3;
45pub const VIRTIO_SCSI_T_TMF_I_T_NEXUS_RESET: u32 = 4;
46pub const VIRTIO_SCSI_T_TMF_LOGICAL_UNIT_RESET: u32 = 5;
47pub const VIRTIO_SCSI_T_TMF_QUERY_TASK: u32 = 6;
48pub const VIRTIO_SCSI_T_TMF_QUERY_TASK_SET: u32 = 7;
49pub const VIRTIO_SCSI_T_EVENTS_MISSED: u32 = 2147483648;
50pub const VIRTIO_SCSI_T_NO_EVENT: u32 = 0;
51pub const VIRTIO_SCSI_T_TRANSPORT_RESET: u32 = 1;
52pub const VIRTIO_SCSI_T_ASYNC_NOTIFY: u32 = 2;
53pub const VIRTIO_SCSI_T_PARAM_CHANGE: u32 = 3;
54pub const VIRTIO_SCSI_EVT_RESET_HARD: u32 = 0;
55pub const VIRTIO_SCSI_EVT_RESET_RESCAN: u32 = 1;
56pub const VIRTIO_SCSI_EVT_RESET_REMOVED: u32 = 2;
57pub const VIRTIO_SCSI_S_SIMPLE: u32 = 0;
58pub const VIRTIO_SCSI_S_ORDERED: u32 = 1;
59pub const VIRTIO_SCSI_S_HEAD: u32 = 2;
60pub const VIRTIO_SCSI_S_ACA: u32 = 3;
61pub type __virtio16 = u16;
62pub type __virtio32 = u32;
63pub type __virtio64 = u64;
64#[repr(C, packed)]
65#[derive(Debug, Default, Copy, Clone, FromBytes, Immutable, IntoBytes, KnownLayout)]
66pub struct virtio_scsi_cmd_req {
67    pub lun: [u8; 8usize],
68    pub tag: __virtio64,
69    pub task_attr: u8,
70    pub prio: u8,
71    pub crn: u8,
72    pub cdb: [u8; 32usize],
73}
74#[repr(C, packed)]
75#[derive(Debug, Copy, Clone, FromBytes, Immutable, IntoBytes, KnownLayout)]
76pub struct virtio_scsi_cmd_resp {
77    pub sense_len: __virtio32,
78    pub resid: __virtio32,
79    pub status_qualifier: __virtio16,
80    pub status: u8,
81    pub response: u8,
82    pub sense: [u8; 96usize],
83}
84impl Default for virtio_scsi_cmd_resp {
85    fn default() -> Self {
86        let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
87        unsafe {
88            ::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
89            s.assume_init()
90        }
91    }
92}
93#[repr(C, packed)]
94#[derive(Debug, Default, Copy, Clone, FromBytes, Immutable, IntoBytes, KnownLayout)]
95pub struct virtio_scsi_ctrl_tmf_req {
96    pub type_: __virtio32,
97    pub subtype: __virtio32,
98    pub lun: [u8; 8usize],
99    pub tag: __virtio64,
100}
101#[repr(C, packed)]
102#[derive(Debug, Default, Copy, Clone, FromBytes, Immutable, IntoBytes, KnownLayout)]
103pub struct virtio_scsi_ctrl_tmf_resp {
104    pub response: u8,
105}
106#[repr(C, packed)]
107#[derive(Debug, Default, Copy, Clone, FromBytes, Immutable, IntoBytes, KnownLayout)]
108pub struct virtio_scsi_ctrl_an_req {
109    pub type_: __virtio32,
110    pub lun: [u8; 8usize],
111    pub event_requested: __virtio32,
112}
113#[repr(C, packed)]
114#[derive(Debug, Default, Copy, Clone, FromBytes, Immutable, IntoBytes, KnownLayout)]
115pub struct virtio_scsi_ctrl_an_resp {
116    pub event_actual: __virtio32,
117    pub response: u8,
118}
119#[repr(C, packed)]
120#[derive(Debug, Default, Copy, Clone)]
121pub struct virtio_scsi_event {
122    pub event: __virtio32,
123    pub lun: [u8; 8usize],
124    pub reason: __virtio32,
125}
126#[repr(C, packed)]
127#[derive(Debug, Default, Copy, Clone, FromBytes, Immutable, IntoBytes, KnownLayout)]
128pub struct virtio_scsi_config {
129    pub num_queues: __virtio32,
130    pub seg_max: __virtio32,
131    pub max_sectors: __virtio32,
132    pub cmd_per_lun: __virtio32,
133    pub event_info_size: __virtio32,
134    pub sense_size: __virtio32,
135    pub cdb_size: __virtio32,
136    pub max_channel: __virtio16,
137    pub max_target: __virtio16,
138    pub max_lun: __virtio32,
139}