2008-12-04 22:52:44 +03:00
|
|
|
/*
|
|
|
|
* Virtio Block Device
|
|
|
|
*
|
|
|
|
* Copyright IBM, Corp. 2007
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Anthony Liguori <aliguori@us.ibm.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2. See
|
|
|
|
* the COPYING file in the top-level directory.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2016-06-29 14:47:03 +03:00
|
|
|
#ifndef QEMU_VIRTIO_BLK_H
|
|
|
|
#define QEMU_VIRTIO_BLK_H
|
2008-12-04 22:52:44 +03:00
|
|
|
|
2015-02-17 00:36:03 +03:00
|
|
|
#include "standard-headers/linux/virtio_blk.h"
|
2013-02-05 20:06:20 +04:00
|
|
|
#include "hw/virtio/virtio.h"
|
|
|
|
#include "hw/block/block.h"
|
2014-03-03 14:30:08 +04:00
|
|
|
#include "sysemu/iothread.h"
|
2014-10-07 15:59:18 +04:00
|
|
|
#include "sysemu/block-backend.h"
|
2022-10-13 21:59:08 +03:00
|
|
|
#include "sysemu/block-ram-registrar.h"
|
2020-09-03 23:43:22 +03:00
|
|
|
#include "qom/object.h"
|
2023-12-20 16:47:55 +03:00
|
|
|
#include "qapi/qapi-types-virtio.h"
|
2008-12-04 22:52:44 +03:00
|
|
|
|
2013-04-09 14:04:48 +04:00
|
|
|
#define TYPE_VIRTIO_BLK "virtio-blk-device"
|
2020-09-16 21:25:19 +03:00
|
|
|
OBJECT_DECLARE_SIMPLE_TYPE(VirtIOBlock, VIRTIO_BLK)
|
2013-03-18 20:37:22 +04:00
|
|
|
|
2009-04-23 14:58:51 +04:00
|
|
|
/* This is the last element of the write scatter-gather list */
|
2008-12-04 22:52:44 +03:00
|
|
|
struct virtio_blk_inhdr
|
|
|
|
{
|
|
|
|
unsigned char status;
|
|
|
|
};
|
|
|
|
|
2020-08-18 17:33:47 +03:00
|
|
|
#define VIRTIO_BLK_AUTO_NUM_QUEUES UINT16_MAX
|
|
|
|
|
2012-05-16 14:54:05 +04:00
|
|
|
struct VirtIOBlkConf
|
|
|
|
{
|
|
|
|
BlockConf conf;
|
2014-03-03 14:30:08 +04:00
|
|
|
IOThread *iothread;
|
2023-12-20 16:47:55 +03:00
|
|
|
IOThreadVirtQueueMappingList *iothread_vq_mapping_list;
|
2012-05-16 14:54:05 +04:00
|
|
|
char *serial;
|
2015-02-02 16:52:22 +03:00
|
|
|
uint32_t request_merging;
|
2016-06-21 15:13:10 +03:00
|
|
|
uint16_t num_queues;
|
2017-12-11 18:16:24 +03:00
|
|
|
uint16_t queue_size;
|
2019-12-20 17:09:04 +03:00
|
|
|
bool seg_max_adjust;
|
2021-02-25 03:12:39 +03:00
|
|
|
bool report_discard_granularity;
|
2019-02-21 13:33:10 +03:00
|
|
|
uint32_t max_discard_sectors;
|
|
|
|
uint32_t max_write_zeroes_sectors;
|
2019-11-05 21:22:17 +03:00
|
|
|
bool x_enable_wce_if_config_wce;
|
2012-05-16 14:54:05 +04:00
|
|
|
};
|
|
|
|
|
2014-06-17 10:32:06 +04:00
|
|
|
struct VirtIOBlockReq;
|
2020-09-03 23:43:22 +03:00
|
|
|
struct VirtIOBlock {
|
2013-03-18 20:37:27 +04:00
|
|
|
VirtIODevice parent_obj;
|
2014-10-07 15:59:18 +04:00
|
|
|
BlockBackend *blk;
|
2023-09-14 17:00:59 +03:00
|
|
|
QemuMutex rq_lock;
|
2024-02-06 22:06:09 +03:00
|
|
|
struct VirtIOBlockReq *rq; /* protected by rq_lock */
|
2014-10-07 15:59:17 +04:00
|
|
|
VirtIOBlkConf conf;
|
2013-03-18 20:37:18 +04:00
|
|
|
unsigned short sector_mask;
|
virtio-blk: do not relay a previous driver's WCE configuration to the current
The following sequence happens:
- the SeaBIOS virtio-blk driver does not support the WCE feature, which
causes QEMU to disable writeback caching
- the Linux virtio-blk driver resets the device, finds WCE is available
but writeback caching is disabled; tells block layer to not send cache
flush commands
- the Linux virtio-blk driver sets the DRIVER_OK bit, which causes
writeback caching to be re-enabled, but the Linux virtio-blk driver does
not know of this side effect and cache flushes remain disabled
The bug is at the third step. If the guest does know about CONFIG_WCE,
QEMU should ignore the WCE feature's state. The guest will control the
cache mode solely using configuration space. This change makes Linux
do flushes correctly, but Linux will keep SeaBIOS's writethrough mode.
Hence, whenever the guest is reset, the cache mode of the disk should
be reset to whatever was specified in the "-drive" option. With this
change, the Linux virtio-blk driver finds that writeback caching is
enabled, and tells the block layer to send cache flush commands
appropriately.
Reported-by: Rusty Russell <rusty@au1.ibm.com
Cc: qemu-stable@nongnu.org
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
2013-09-20 19:31:55 +04:00
|
|
|
bool original_wce;
|
2013-03-18 20:37:18 +04:00
|
|
|
VMChangeStateEntry *change;
|
2024-01-19 16:57:45 +03:00
|
|
|
bool ioeventfd_disabled;
|
|
|
|
bool ioeventfd_started;
|
|
|
|
bool ioeventfd_starting;
|
|
|
|
bool ioeventfd_stopping;
|
2024-01-19 16:57:43 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The AioContext for each virtqueue. The BlockDriverState will use the
|
|
|
|
* first element as its AioContext.
|
|
|
|
*/
|
|
|
|
AioContext **vq_aio_context;
|
|
|
|
|
2019-02-21 13:33:06 +03:00
|
|
|
uint64_t host_features;
|
2019-02-21 13:33:09 +03:00
|
|
|
size_t config_size;
|
2022-10-13 21:59:08 +03:00
|
|
|
BlockRAMRegistrar blk_ram_registrar;
|
2020-09-03 23:43:22 +03:00
|
|
|
};
|
2013-03-18 20:37:18 +04:00
|
|
|
|
2014-06-11 08:11:42 +04:00
|
|
|
typedef struct VirtIOBlockReq {
|
2016-01-31 13:28:57 +03:00
|
|
|
VirtQueueElement elem;
|
2015-02-02 16:52:21 +03:00
|
|
|
int64_t sector_num;
|
2014-06-11 08:11:42 +04:00
|
|
|
VirtIOBlock *dev;
|
2016-06-21 15:13:13 +03:00
|
|
|
VirtQueue *vq;
|
2020-09-17 12:44:54 +03:00
|
|
|
IOVDiscardUndo inhdr_undo;
|
|
|
|
IOVDiscardUndo outhdr_undo;
|
2014-06-11 08:11:42 +04:00
|
|
|
struct virtio_blk_inhdr *in;
|
2014-06-11 08:11:48 +04:00
|
|
|
struct virtio_blk_outhdr out;
|
2014-06-11 08:11:42 +04:00
|
|
|
QEMUIOVector qiov;
|
2015-04-02 20:50:44 +03:00
|
|
|
size_t in_len;
|
2014-06-11 08:11:42 +04:00
|
|
|
struct VirtIOBlockReq *next;
|
2015-02-02 16:52:21 +03:00
|
|
|
struct VirtIOBlockReq *mr_next;
|
2014-06-11 08:11:42 +04:00
|
|
|
BlockAcctCookie acct;
|
|
|
|
} VirtIOBlockReq;
|
|
|
|
|
2015-02-02 16:52:21 +03:00
|
|
|
#define VIRTIO_BLK_MAX_MERGE_REQS 32
|
|
|
|
|
|
|
|
typedef struct MultiReqBuffer {
|
|
|
|
VirtIOBlockReq *reqs[VIRTIO_BLK_MAX_MERGE_REQS];
|
|
|
|
unsigned int num_reqs;
|
|
|
|
bool is_write;
|
|
|
|
} MultiReqBuffer;
|
|
|
|
|
2021-12-07 16:23:33 +03:00
|
|
|
void virtio_blk_handle_vq(VirtIOBlock *s, VirtQueue *vq);
|
2016-04-06 13:16:26 +03:00
|
|
|
|
2008-12-04 22:52:44 +03:00
|
|
|
#endif
|