Pull request
-----BEGIN PGP SIGNATURE----- iQEzBAABCAAdFiEEhpWov9P5fNqsNXdanKSrs4Grc8gFAmBPLgIACgkQnKSrs4Gr c8iFYAf9GFU9eKBUidV17cEA9PjudUNgUVCCox04JG1dorw61ZgaQ2Aw9KEsJB8a kr9p2JXBSbwMtpnl2ZnJMVtVsQzcOoUdiux9uq8RlsVHpYJTp2aKHe9Bfi/kXvfC 0eOjKH6+bbQFSEz6zn6lnnvNQ2ZqJOdIoM98nnDBgsaozOvGC0hB8/jjDU39dOck Xt1cCUf5PNpJj4/1HsUdna8MDY7wscxVvXZfj3Cf0Muv7ScS5X0NDMWid3C8dzTe Q+hEVS5/yrLjETTJnKDEFF7OyGwMTXh75uhveM/Q9yHG4riCzLVhT3nUTaiaknXT YII+Mno9x4HwWzlNScvd0G9pbx7YDw== =ZEoP -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/stefanha-gitlab/tags/block-pull-request' into staging Pull request # gpg: Signature made Mon 15 Mar 2021 09:50:58 GMT # gpg: using RSA key 8695A8BFD3F97CDAAC35775A9CA4ABB381AB73C8 # gpg: Good signature from "Stefan Hajnoczi <stefanha@redhat.com>" [full] # gpg: aka "Stefan Hajnoczi <stefanha@gmail.com>" [full] # Primary key fingerprint: 8695 A8BF D3F9 7CDA AC35 775A 9CA4 ABB3 81AB 73C8 * remotes/stefanha-gitlab/tags/block-pull-request: virtio-blk: Respect discard granularity Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
2615a5e433
@ -962,10 +962,14 @@ static void virtio_blk_update_config(VirtIODevice *vdev, uint8_t *config)
|
||||
blkcfg.wce = blk_enable_write_cache(s->blk);
|
||||
virtio_stw_p(vdev, &blkcfg.num_queues, s->conf.num_queues);
|
||||
if (virtio_has_feature(s->host_features, VIRTIO_BLK_F_DISCARD)) {
|
||||
uint32_t discard_granularity = conf->discard_granularity;
|
||||
if (discard_granularity == -1 || !s->conf.report_discard_granularity) {
|
||||
discard_granularity = blk_size;
|
||||
}
|
||||
virtio_stl_p(vdev, &blkcfg.max_discard_sectors,
|
||||
s->conf.max_discard_sectors);
|
||||
virtio_stl_p(vdev, &blkcfg.discard_sector_alignment,
|
||||
blk_size >> BDRV_SECTOR_BITS);
|
||||
discard_granularity >> BDRV_SECTOR_BITS);
|
||||
/*
|
||||
* We support only one segment per request since multiple segments
|
||||
* are not widely used and there are no userspace APIs that allow
|
||||
@ -1299,6 +1303,8 @@ static Property virtio_blk_properties[] = {
|
||||
IOThread *),
|
||||
DEFINE_PROP_BIT64("discard", VirtIOBlock, host_features,
|
||||
VIRTIO_BLK_F_DISCARD, true),
|
||||
DEFINE_PROP_BOOL("report-discard-granularity", VirtIOBlock,
|
||||
conf.report_discard_granularity, true),
|
||||
DEFINE_PROP_BIT64("write-zeroes", VirtIOBlock, host_features,
|
||||
VIRTIO_BLK_F_WRITE_ZEROES, true),
|
||||
DEFINE_PROP_UINT32("max-discard-sectors", VirtIOBlock,
|
||||
|
@ -39,6 +39,7 @@
|
||||
GlobalProperty hw_compat_5_2[] = {
|
||||
{ "ICH9-LPC", "smm-compat", "on"},
|
||||
{ "PIIX4_PM", "smm-compat", "on"},
|
||||
{ "virtio-blk-device", "report-discard-granularity", "off" },
|
||||
};
|
||||
const size_t hw_compat_5_2_len = G_N_ELEMENTS(hw_compat_5_2);
|
||||
|
||||
|
@ -41,6 +41,7 @@ struct VirtIOBlkConf
|
||||
uint16_t num_queues;
|
||||
uint16_t queue_size;
|
||||
bool seg_max_adjust;
|
||||
bool report_discard_granularity;
|
||||
uint32_t max_discard_sectors;
|
||||
uint32_t max_write_zeroes_sectors;
|
||||
bool x_enable_wce_if_config_wce;
|
||||
|
Loading…
x
Reference in New Issue
Block a user