mirror of https://github.com/xqemu/xqemu.git
qcow2: Use QCryptoBlockCreateOptions in qcow2_co_create()
Instead of passing the encryption format name and the QemuOpts down, use the QCryptoBlockCreateOptions contained in BlockdevCreateOptions. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Max Reitz <mreitz@redhat.com>
This commit is contained in:
parent
e1d74bc6c6
commit
60900b7bd9
|
@ -2449,13 +2449,10 @@ static int qcow2_crypt_method_from_format(const char *encryptfmt)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcow2_set_up_encryption(BlockDriverState *bs, const char *encryptfmt,
|
static QCryptoBlockCreateOptions *
|
||||||
QemuOpts *opts, Error **errp)
|
qcow2_parse_encryption(const char *encryptfmt, QemuOpts *opts, Error **errp)
|
||||||
{
|
{
|
||||||
BDRVQcow2State *s = bs->opaque;
|
|
||||||
QCryptoBlockCreateOptions *cryptoopts = NULL;
|
QCryptoBlockCreateOptions *cryptoopts = NULL;
|
||||||
QCryptoBlock *crypto = NULL;
|
|
||||||
int ret = -EINVAL;
|
|
||||||
QDict *options, *encryptopts;
|
QDict *options, *encryptopts;
|
||||||
int fmt;
|
int fmt;
|
||||||
|
|
||||||
|
@ -2478,10 +2475,31 @@ static int qcow2_set_up_encryption(BlockDriverState *bs, const char *encryptfmt,
|
||||||
error_setg(errp, "Unknown encryption format '%s'", encryptfmt);
|
error_setg(errp, "Unknown encryption format '%s'", encryptfmt);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!cryptoopts) {
|
|
||||||
ret = -EINVAL;
|
QDECREF(encryptopts);
|
||||||
goto out;
|
return cryptoopts;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int qcow2_set_up_encryption(BlockDriverState *bs,
|
||||||
|
QCryptoBlockCreateOptions *cryptoopts,
|
||||||
|
Error **errp)
|
||||||
|
{
|
||||||
|
BDRVQcow2State *s = bs->opaque;
|
||||||
|
QCryptoBlock *crypto = NULL;
|
||||||
|
int fmt, ret;
|
||||||
|
|
||||||
|
switch (cryptoopts->format) {
|
||||||
|
case Q_CRYPTO_BLOCK_FORMAT_LUKS:
|
||||||
|
fmt = QCOW_CRYPT_LUKS;
|
||||||
|
break;
|
||||||
|
case Q_CRYPTO_BLOCK_FORMAT_QCOW:
|
||||||
|
fmt = QCOW_CRYPT_AES;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
error_setg(errp, "Crypto format not supported in qcow2");
|
||||||
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
s->crypt_method_header = fmt;
|
s->crypt_method_header = fmt;
|
||||||
|
|
||||||
crypto = qcrypto_block_create(cryptoopts, "encrypt.",
|
crypto = qcrypto_block_create(cryptoopts, "encrypt.",
|
||||||
|
@ -2489,8 +2507,7 @@ static int qcow2_set_up_encryption(BlockDriverState *bs, const char *encryptfmt,
|
||||||
qcow2_crypto_hdr_write_func,
|
qcow2_crypto_hdr_write_func,
|
||||||
bs, errp);
|
bs, errp);
|
||||||
if (!crypto) {
|
if (!crypto) {
|
||||||
ret = -EINVAL;
|
return -EINVAL;
|
||||||
goto out;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = qcow2_update_header(bs);
|
ret = qcow2_update_header(bs);
|
||||||
|
@ -2499,10 +2516,9 @@ static int qcow2_set_up_encryption(BlockDriverState *bs, const char *encryptfmt,
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ret = 0;
|
||||||
out:
|
out:
|
||||||
QDECREF(encryptopts);
|
|
||||||
qcrypto_block_free(crypto);
|
qcrypto_block_free(crypto);
|
||||||
qapi_free_QCryptoBlockCreateOptions(cryptoopts);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2768,8 +2784,7 @@ static uint64_t qcow2_opt_get_refcount_bits_del(QemuOpts *opts, int version,
|
||||||
}
|
}
|
||||||
|
|
||||||
static int coroutine_fn
|
static int coroutine_fn
|
||||||
qcow2_co_create(BlockdevCreateOptions *create_options, QemuOpts *opts,
|
qcow2_co_create(BlockdevCreateOptions *create_options, Error **errp)
|
||||||
const char *encryptfmt, Error **errp)
|
|
||||||
{
|
{
|
||||||
BlockdevCreateOptionsQcow2 *qcow2_opts;
|
BlockdevCreateOptionsQcow2 *qcow2_opts;
|
||||||
QDict *options;
|
QDict *options;
|
||||||
|
@ -2999,8 +3014,8 @@ qcow2_co_create(BlockdevCreateOptions *create_options, QemuOpts *opts,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Want encryption? There you go. */
|
/* Want encryption? There you go. */
|
||||||
if (encryptfmt) {
|
if (qcow2_opts->has_encrypt) {
|
||||||
ret = qcow2_set_up_encryption(blk_bs(blk), encryptfmt, opts, errp);
|
ret = qcow2_set_up_encryption(blk_bs(blk), qcow2_opts->encrypt, errp);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -3058,6 +3073,7 @@ static int coroutine_fn qcow2_co_create_opts(const char *filename, QemuOpts *opt
|
||||||
int version;
|
int version;
|
||||||
uint64_t refcount_bits;
|
uint64_t refcount_bits;
|
||||||
char *encryptfmt = NULL;
|
char *encryptfmt = NULL;
|
||||||
|
QCryptoBlockCreateOptions *cryptoopts = NULL;
|
||||||
BlockDriverState *bs = NULL;
|
BlockDriverState *bs = NULL;
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
int ret;
|
int ret;
|
||||||
|
@ -3074,6 +3090,7 @@ static int coroutine_fn qcow2_co_create_opts(const char *filename, QemuOpts *opt
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
encryptfmt = qemu_opt_get_del(opts, BLOCK_OPT_ENCRYPT_FORMAT);
|
encryptfmt = qemu_opt_get_del(opts, BLOCK_OPT_ENCRYPT_FORMAT);
|
||||||
if (encryptfmt) {
|
if (encryptfmt) {
|
||||||
if (qemu_opt_get(opts, BLOCK_OPT_ENCRYPT)) {
|
if (qemu_opt_get(opts, BLOCK_OPT_ENCRYPT)) {
|
||||||
|
@ -3085,6 +3102,14 @@ static int coroutine_fn qcow2_co_create_opts(const char *filename, QemuOpts *opt
|
||||||
} else if (qemu_opt_get_bool_del(opts, BLOCK_OPT_ENCRYPT, false)) {
|
} else if (qemu_opt_get_bool_del(opts, BLOCK_OPT_ENCRYPT, false)) {
|
||||||
encryptfmt = g_strdup("aes");
|
encryptfmt = g_strdup("aes");
|
||||||
}
|
}
|
||||||
|
if (encryptfmt) {
|
||||||
|
cryptoopts = qcow2_parse_encryption(encryptfmt, opts, errp);
|
||||||
|
if (cryptoopts == NULL) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto finish;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
cluster_size = qcow2_opt_get_cluster_size_del(opts, &local_err);
|
cluster_size = qcow2_opt_get_cluster_size_del(opts, &local_err);
|
||||||
if (local_err) {
|
if (local_err) {
|
||||||
error_propagate(errp, local_err);
|
error_propagate(errp, local_err);
|
||||||
|
@ -3158,6 +3183,8 @@ static int coroutine_fn qcow2_co_create_opts(const char *filename, QemuOpts *opt
|
||||||
.backing_file = backing_file,
|
.backing_file = backing_file,
|
||||||
.has_backing_fmt = (backing_fmt != NULL),
|
.has_backing_fmt = (backing_fmt != NULL),
|
||||||
.backing_fmt = backing_drv,
|
.backing_fmt = backing_drv,
|
||||||
|
.has_encrypt = (encryptfmt != NULL),
|
||||||
|
.encrypt = cryptoopts,
|
||||||
.has_cluster_size = true,
|
.has_cluster_size = true,
|
||||||
.cluster_size = cluster_size,
|
.cluster_size = cluster_size,
|
||||||
.has_preallocation = true,
|
.has_preallocation = true,
|
||||||
|
@ -3168,7 +3195,7 @@ static int coroutine_fn qcow2_co_create_opts(const char *filename, QemuOpts *opt
|
||||||
.refcount_bits = refcount_bits,
|
.refcount_bits = refcount_bits,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
ret = qcow2_co_create(&create_options, opts, encryptfmt, errp);
|
ret = qcow2_co_create(&create_options, errp);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
@ -3176,6 +3203,7 @@ static int coroutine_fn qcow2_co_create_opts(const char *filename, QemuOpts *opt
|
||||||
finish:
|
finish:
|
||||||
bdrv_unref(bs);
|
bdrv_unref(bs);
|
||||||
|
|
||||||
|
qapi_free_QCryptoBlockCreateOptions(cryptoopts);
|
||||||
g_free(backing_file);
|
g_free(backing_file);
|
||||||
g_free(backing_fmt);
|
g_free(backing_fmt);
|
||||||
g_free(encryptfmt);
|
g_free(encryptfmt);
|
||||||
|
|
Loading…
Reference in New Issue