block/gluster: limit the transfer size to 512 MiB
Several versions of GlusterFS (3.12? -> 6.0.1) fail when the transfer size is greater or equal to 1024 MiB, so we are limiting the transfer size to 512 MiB to avoid this rare issue. Buglink: https://bugzilla.redhat.com/show_bug.cgi?id=1691320 Signed-off-by: Stefano Garzarella <sgarzare@redhat.com> Reviewed-by: Niels de Vos <ndevos@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
a3d6ae2299
commit
de23e72bb7
@ -9,6 +9,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
|
#include "qemu/units.h"
|
||||||
#include <glusterfs/api/glfs.h>
|
#include <glusterfs/api/glfs.h>
|
||||||
#include "block/block_int.h"
|
#include "block/block_int.h"
|
||||||
#include "block/qdict.h"
|
#include "block/qdict.h"
|
||||||
@ -41,6 +42,12 @@
|
|||||||
#define GLUSTER_DEBUG_MAX 9
|
#define GLUSTER_DEBUG_MAX 9
|
||||||
#define GLUSTER_OPT_LOGFILE "logfile"
|
#define GLUSTER_OPT_LOGFILE "logfile"
|
||||||
#define GLUSTER_LOGFILE_DEFAULT "-" /* handled in libgfapi as /dev/stderr */
|
#define GLUSTER_LOGFILE_DEFAULT "-" /* handled in libgfapi as /dev/stderr */
|
||||||
|
/*
|
||||||
|
* Several versions of GlusterFS (3.12? -> 6.0.1) fail when the transfer size
|
||||||
|
* is greater or equal to 1024 MiB, so we are limiting the transfer size to 512
|
||||||
|
* MiB to avoid this rare issue.
|
||||||
|
*/
|
||||||
|
#define GLUSTER_MAX_TRANSFER (512 * MiB)
|
||||||
|
|
||||||
#define GERR_INDEX_HINT "hint: check in 'server' array index '%d'\n"
|
#define GERR_INDEX_HINT "hint: check in 'server' array index '%d'\n"
|
||||||
|
|
||||||
@ -887,6 +894,11 @@ out:
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void qemu_gluster_refresh_limits(BlockDriverState *bs, Error **errp)
|
||||||
|
{
|
||||||
|
bs->bl.max_transfer = GLUSTER_MAX_TRANSFER;
|
||||||
|
}
|
||||||
|
|
||||||
static int qemu_gluster_reopen_prepare(BDRVReopenState *state,
|
static int qemu_gluster_reopen_prepare(BDRVReopenState *state,
|
||||||
BlockReopenQueue *queue, Error **errp)
|
BlockReopenQueue *queue, Error **errp)
|
||||||
{
|
{
|
||||||
@ -1544,6 +1556,7 @@ static BlockDriver bdrv_gluster = {
|
|||||||
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
||||||
#endif
|
#endif
|
||||||
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
||||||
|
.bdrv_refresh_limits = qemu_gluster_refresh_limits,
|
||||||
.create_opts = &qemu_gluster_create_opts,
|
.create_opts = &qemu_gluster_create_opts,
|
||||||
.strong_runtime_opts = gluster_strong_open_opts,
|
.strong_runtime_opts = gluster_strong_open_opts,
|
||||||
};
|
};
|
||||||
@ -1574,6 +1587,7 @@ static BlockDriver bdrv_gluster_tcp = {
|
|||||||
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
||||||
#endif
|
#endif
|
||||||
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
||||||
|
.bdrv_refresh_limits = qemu_gluster_refresh_limits,
|
||||||
.create_opts = &qemu_gluster_create_opts,
|
.create_opts = &qemu_gluster_create_opts,
|
||||||
.strong_runtime_opts = gluster_strong_open_opts,
|
.strong_runtime_opts = gluster_strong_open_opts,
|
||||||
};
|
};
|
||||||
@ -1604,6 +1618,7 @@ static BlockDriver bdrv_gluster_unix = {
|
|||||||
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
||||||
#endif
|
#endif
|
||||||
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
||||||
|
.bdrv_refresh_limits = qemu_gluster_refresh_limits,
|
||||||
.create_opts = &qemu_gluster_create_opts,
|
.create_opts = &qemu_gluster_create_opts,
|
||||||
.strong_runtime_opts = gluster_strong_open_opts,
|
.strong_runtime_opts = gluster_strong_open_opts,
|
||||||
};
|
};
|
||||||
@ -1640,6 +1655,7 @@ static BlockDriver bdrv_gluster_rdma = {
|
|||||||
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
.bdrv_co_pwrite_zeroes = qemu_gluster_co_pwrite_zeroes,
|
||||||
#endif
|
#endif
|
||||||
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
.bdrv_co_block_status = qemu_gluster_co_block_status,
|
||||||
|
.bdrv_refresh_limits = qemu_gluster_refresh_limits,
|
||||||
.create_opts = &qemu_gluster_create_opts,
|
.create_opts = &qemu_gluster_create_opts,
|
||||||
.strong_runtime_opts = gluster_strong_open_opts,
|
.strong_runtime_opts = gluster_strong_open_opts,
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user