]>
Commit | Line | Data |
---|---|---|
6e02c38d AL |
1 | /* |
2 | * Virtio Block Device | |
3 | * | |
4 | * Copyright IBM, Corp. 2007 | |
5 | * | |
6 | * Authors: | |
7 | * Anthony Liguori <[email protected]> | |
8 | * | |
9 | * This work is licensed under the terms of the GNU GPL, version 2. See | |
10 | * the COPYING file in the top-level directory. | |
11 | * | |
12 | */ | |
13 | ||
14 | #ifndef _QEMU_VIRTIO_BLK_H | |
15 | #define _QEMU_VIRTIO_BLK_H | |
16 | ||
17 | #include "virtio.h" | |
18 | #include "block.h" | |
6e02c38d AL |
19 | |
20 | /* from Linux's linux/virtio_blk.h */ | |
21 | ||
22 | /* The ID for virtio_block */ | |
23 | #define VIRTIO_ID_BLOCK 2 | |
24 | ||
25 | /* Feature bits */ | |
26 | #define VIRTIO_BLK_F_BARRIER 0 /* Does host support barriers? */ | |
27 | #define VIRTIO_BLK_F_SIZE_MAX 1 /* Indicates maximum segment size */ | |
28 | #define VIRTIO_BLK_F_SEG_MAX 2 /* Indicates maximum # of segments */ | |
29 | #define VIRTIO_BLK_F_GEOMETRY 4 /* Indicates support of legacy geometry */ | |
1063b8b1 CH |
30 | #define VIRTIO_BLK_F_RO 5 /* Disk is read-only */ |
31 | #define VIRTIO_BLK_F_BLK_SIZE 6 /* Block size of disk is available*/ | |
32 | #define VIRTIO_BLK_F_SCSI 7 /* Supports scsi command passthru */ | |
bf011293 | 33 | #define VIRTIO_BLK_F_IDENTIFY 8 /* ATA IDENTIFY supported */ |
aa659be3 | 34 | #define VIRTIO_BLK_F_WCACHE 9 /* write cache enabled */ |
bf011293 | 35 | |
36 | #define VIRTIO_BLK_ID_LEN 256 /* length of identify u16 array */ | |
37 | #define VIRTIO_BLK_ID_SN 10 /* start of char * serial# */ | |
38 | #define VIRTIO_BLK_ID_SN_BYTES 20 /* length in bytes of serial# */ | |
6e02c38d AL |
39 | |
40 | struct virtio_blk_config | |
41 | { | |
42 | uint64_t capacity; | |
43 | uint32_t size_max; | |
44 | uint32_t seg_max; | |
45 | uint16_t cylinders; | |
46 | uint8_t heads; | |
47 | uint8_t sectors; | |
bf011293 | 48 | uint32_t _blk_size; /* structure pad, currently unused */ |
49 | uint16_t identify[VIRTIO_BLK_ID_LEN]; | |
6e02c38d AL |
50 | } __attribute__((packed)); |
51 | ||
52 | /* These two define direction. */ | |
53 | #define VIRTIO_BLK_T_IN 0 | |
54 | #define VIRTIO_BLK_T_OUT 1 | |
55 | ||
56 | /* This bit says it's a scsi command, not an actual read or write. */ | |
57 | #define VIRTIO_BLK_T_SCSI_CMD 2 | |
58 | ||
aa659be3 CH |
59 | /* Flush the volatile write cache */ |
60 | #define VIRTIO_BLK_T_FLUSH 4 | |
61 | ||
6e02c38d AL |
62 | /* Barrier before this op. */ |
63 | #define VIRTIO_BLK_T_BARRIER 0x80000000 | |
64 | ||
65 | /* This is the first element of the read scatter-gather list. */ | |
66 | struct virtio_blk_outhdr | |
67 | { | |
68 | /* VIRTIO_BLK_T* */ | |
69 | uint32_t type; | |
70 | /* io priority. */ | |
71 | uint32_t ioprio; | |
72 | /* Sector (ie. 512 byte offset) */ | |
73 | uint64_t sector; | |
74 | }; | |
75 | ||
76 | #define VIRTIO_BLK_S_OK 0 | |
77 | #define VIRTIO_BLK_S_IOERR 1 | |
78 | #define VIRTIO_BLK_S_UNSUPP 2 | |
79 | ||
8b91408b | 80 | /* This is the last element of the write scatter-gather list */ |
6e02c38d AL |
81 | struct virtio_blk_inhdr |
82 | { | |
83 | unsigned char status; | |
84 | }; | |
85 | ||
1063b8b1 CH |
86 | /* SCSI pass-through header */ |
87 | struct virtio_scsi_inhdr | |
88 | { | |
89 | uint32_t errors; | |
90 | uint32_t data_len; | |
91 | uint32_t sense_len; | |
92 | uint32_t residual; | |
93 | }; | |
94 | ||
6e02c38d | 95 | #endif |