OSDN Git Service

crypto/luks: Support creating LUKS image on Darwin
authorJungmin Park <pjm0616@gmail.com>
Wed, 24 Aug 2022 12:37:06 +0000 (21:37 +0900)
committerDaniel P. Berrangé <berrange@redhat.com>
Wed, 26 Oct 2022 12:32:08 +0000 (13:32 +0100)
commitbf98afc75efedf10965a3f2d98aa43c234cf69ed
treeadfbfbd27b58073102a0b00fc42adaf9070c88d8
parente750a7ace492f0b450653d4ad368a77d6f660fb8
crypto/luks: Support creating LUKS image on Darwin

When the user creates a LUKS-encrypted qcow2 image using the qemu-img
program, the passphrase is hashed using PBKDF2 with a dynamic
number of iterations. The number of iterations is determined by
measuring thread cpu time usage, such that it takes approximately
2 seconds to compute the hash.

Because Darwin doesn't implement getrusage(RUSAGE_THREAD), we get an
error message:
> qemu-img: test.qcow2: Unable to calculate thread CPU usage on this platform
for this command:
> qemu-img create --object secret,id=key,data=1234 -f qcow2 -o 'encrypt.format=luks,encrypt.key-secret=key' test.qcow2 100M

This patch implements qcrypto_pbkdf2_get_thread_cpu() for Darwin so that
the above command works.

Signed-off-by: Jungmin Park <pjm0616@gmail.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
crypto/pbkdf.c