block/file-posix: Fix laio_init() error handling crash bug
raw_aio_attach_aio_context() passes uninitialized Error *local_err by
reference to laio_init() via aio_setup_linux_aio(). When laio_init()
fails, it passes it on to error_setg_errno(), tripping error_setv()'s
assertion unless @local_err is null by dumb luck.
Fix by initializing @local_err properly.
Fixes: ed6e216171
Cc: Nishanth Aravamudan <naravamudan@digitalocean.com>
Cc: Stefan Hajnoczi <stefanha@redhat.com>
Cc: Kevin Wolf <kwolf@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Message-Id: <20191130194240.10517-4-armbru@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Reviewed-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
5a0948d36c
commit
cb09104ea8
@ -1973,7 +1973,7 @@ static void raw_aio_attach_aio_context(BlockDriverState *bs,
|
|||||||
#ifdef CONFIG_LINUX_AIO
|
#ifdef CONFIG_LINUX_AIO
|
||||||
BDRVRawState *s = bs->opaque;
|
BDRVRawState *s = bs->opaque;
|
||||||
if (s->use_linux_aio) {
|
if (s->use_linux_aio) {
|
||||||
Error *local_err;
|
Error *local_err = NULL;
|
||||||
if (!aio_setup_linux_aio(new_context, &local_err)) {
|
if (!aio_setup_linux_aio(new_context, &local_err)) {
|
||||||
error_reportf_err(local_err, "Unable to use native AIO, "
|
error_reportf_err(local_err, "Unable to use native AIO, "
|
||||||
"falling back to thread pool: ");
|
"falling back to thread pool: ");
|
||||||
|
Loading…
Reference in New Issue
Block a user