2 * Common code for block device models
4 * Copyright (C) 2012 Red Hat, Inc.
6 * This work is licensed under the terms of the GNU GPL, version 2 or
7 * later. See the COPYING file in the top-level directory.
10 #include "qemu/osdep.h"
11 #include "sysemu/blockdev.h"
12 #include "sysemu/block-backend.h"
13 #include "hw/block/block.h"
14 #include "qapi/error.h"
15 #include "qapi/qapi-types-block.h"
18 * Read the entire contents of @blk into @buf.
19 * @blk's contents must be @size bytes, and @size must be at most
20 * BDRV_REQUEST_MAX_BYTES.
21 * On success, return true.
22 * On failure, store an error through @errp and return false.
23 * Note that the error messages do not identify the block backend.
24 * TODO Since callers don't either, this can result in confusing
26 * This function not intended for actual block devices, which read on
27 * demand. It's for things like memory devices that (ab)use a block
28 * backend to provide persistence.
30 bool blk_check_size_and_read_all(BlockBackend
*blk
, void *buf
, hwaddr size
,
36 blk_len
= blk_getlength(blk
);
38 error_setg_errno(errp
, -blk_len
,
39 "can't get size of block backend");
42 if (blk_len
!= size
) {
43 error_setg(errp
, "device requires %" HWADDR_PRIu
" bytes, "
44 "block backend provides %" PRIu64
" bytes",
50 * We could loop for @size > BDRV_REQUEST_MAX_BYTES, but if we
51 * ever get to the point we want to read *gigabytes* here, we
52 * should probably rework the device to be more like an actual
53 * block device and read only on demand.
55 assert(size
<= BDRV_REQUEST_MAX_BYTES
);
56 ret
= blk_pread(blk
, 0, buf
, size
);
58 error_setg_errno(errp
, -ret
, "can't read block backend");
64 bool blkconf_blocksizes(BlockConf
*conf
, Error
**errp
)
66 BlockBackend
*blk
= conf
->blk
;
67 BlockSizes blocksizes
;
70 backend_ret
= blk_probe_blocksizes(blk
, &blocksizes
);
71 /* fill in detected values if they are not defined via qemu command line */
72 if (!conf
->physical_block_size
) {
74 conf
->physical_block_size
= blocksizes
.phys
;
76 conf
->physical_block_size
= BDRV_SECTOR_SIZE
;
79 if (!conf
->logical_block_size
) {
81 conf
->logical_block_size
= blocksizes
.log
;
83 conf
->logical_block_size
= BDRV_SECTOR_SIZE
;
87 if (conf
->logical_block_size
> conf
->physical_block_size
) {
89 "logical_block_size > physical_block_size not supported");
93 if (!QEMU_IS_ALIGNED(conf
->min_io_size
, conf
->logical_block_size
)) {
95 "min_io_size must be a multiple of logical_block_size");
100 * all devices which support min_io_size (scsi and virtio-blk) expose it to
101 * the guest as a uint16_t in units of logical blocks
103 if (conf
->min_io_size
/ conf
->logical_block_size
> UINT16_MAX
) {
104 error_setg(errp
, "min_io_size must not exceed %u logical blocks",
109 if (!QEMU_IS_ALIGNED(conf
->opt_io_size
, conf
->logical_block_size
)) {
111 "opt_io_size must be a multiple of logical_block_size");
115 if (conf
->discard_granularity
!= -1 &&
116 !QEMU_IS_ALIGNED(conf
->discard_granularity
,
117 conf
->logical_block_size
)) {
118 error_setg(errp
, "discard_granularity must be "
119 "a multiple of logical_block_size");
126 bool blkconf_apply_backend_options(BlockConf
*conf
, bool readonly
,
127 bool resizable
, Error
**errp
)
129 BlockBackend
*blk
= conf
->blk
;
130 BlockdevOnError rerror
, werror
;
131 uint64_t perm
, shared_perm
;
135 perm
= BLK_PERM_CONSISTENT_READ
;
137 perm
|= BLK_PERM_WRITE
;
140 shared_perm
= BLK_PERM_CONSISTENT_READ
| BLK_PERM_WRITE_UNCHANGED
|
143 shared_perm
|= BLK_PERM_RESIZE
;
145 if (conf
->share_rw
) {
146 shared_perm
|= BLK_PERM_WRITE
;
149 ret
= blk_set_perm(blk
, perm
, shared_perm
, errp
);
155 case ON_OFF_AUTO_ON
: wce
= true; break;
156 case ON_OFF_AUTO_OFF
: wce
= false; break;
157 case ON_OFF_AUTO_AUTO
: wce
= blk_enable_write_cache(blk
); break;
162 rerror
= conf
->rerror
;
163 if (rerror
== BLOCKDEV_ON_ERROR_AUTO
) {
164 rerror
= blk_get_on_error(blk
, true);
167 werror
= conf
->werror
;
168 if (werror
== BLOCKDEV_ON_ERROR_AUTO
) {
169 werror
= blk_get_on_error(blk
, false);
172 blk_set_enable_write_cache(blk
, wce
);
173 blk_set_on_error(blk
, rerror
, werror
);
178 bool blkconf_geometry(BlockConf
*conf
, int *ptrans
,
179 unsigned cyls_max
, unsigned heads_max
, unsigned secs_max
,
182 if (!conf
->cyls
&& !conf
->heads
&& !conf
->secs
) {
183 hd_geometry_guess(conf
->blk
,
184 &conf
->cyls
, &conf
->heads
, &conf
->secs
,
186 } else if (ptrans
&& *ptrans
== BIOS_ATA_TRANSLATION_AUTO
) {
187 *ptrans
= hd_bios_chs_auto_trans(conf
->cyls
, conf
->heads
, conf
->secs
);
189 if (conf
->cyls
|| conf
->heads
|| conf
->secs
) {
190 if (conf
->cyls
< 1 || conf
->cyls
> cyls_max
) {
191 error_setg(errp
, "cyls must be between 1 and %u", cyls_max
);
194 if (conf
->heads
< 1 || conf
->heads
> heads_max
) {
195 error_setg(errp
, "heads must be between 1 and %u", heads_max
);
198 if (conf
->secs
< 1 || conf
->secs
> secs_max
) {
199 error_setg(errp
, "secs must be between 1 and %u", secs_max
);