| CRYPTSETUP-CONVERT(8) | Maintenance Commands | CRYPTSETUP-CONVERT(8) | 
NAME
cryptsetup-convert - converts the device between LUKS1 and LUKS2 format
SYNOPSIS
cryptsetup convert --type <format> [<options>] <device>
DESCRIPTION
Converts the device between LUKS1 and LUKS2 format (if possible). The conversion will not be performed if there is an additional LUKS2 feature or LUKS1 has an unsupported header size.
For conversion from LUKS2 to LUKS1, all active keyslots must use the PBKDF2 key-derivation function. The PBKDF2 and anti-forensic filter (AF) hash must be the same as the hash used in the digest. All keyslot numbers must be lower than 8 (LUKS1 maximum slot number). There must be at least one active keyslot and no unbound or reencryption keyslots.
Conversion (both directions) must be performed on an inactive device. There must not be an active dm-crypt mapping established for the LUKS header requested for conversion.
The --type option is mandatory with the following accepted values: luks1 or luks2.
WARNING: The convert action can destroy the LUKS header in the case of a crash during conversion or if a media error occurs. Always create a header backup before performing this operation!
<options> can be [--header, --type, --disable-locks].
OPTIONS
--batch-mode, -q
If the --verify-passphrase option is not specified, this option also switches off the passphrase verification.
--debug or --debug-json
If --debug-json is used, additional LUKS2 JSON data structures are printed.
--disable-locks
WARNING: Do not use this option unless you run cryptsetup in a restricted environment where locking is impossible to perform (where /run directory cannot be used).
--header <device or file storing the LUKS header>
For commands that change the LUKS header (e.g., luksAddKey), specify the device or file with the LUKS header directly as the LUKS device.
--help, -?
--type type
--usage
--version, -V
REPORTING BUGS
Report bugs at cryptsetup mailing list <cryptsetup@lists.linux.dev> or in Issues project section https://gitlab.com/cryptsetup/cryptsetup/-/issues/new.
Please attach the output of the failed command with --debug option added.
SEE ALSO
Cryptsetup FAQ https://gitlab.com/cryptsetup/cryptsetup/wikis/FrequentlyAskedQuestions
CRYPTSETUP
Part of cryptsetup project https://gitlab.com/cryptsetup/cryptsetup/.
| 2025-08-13 | cryptsetup 2.8.1 |