You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Ondrej Kozina 83934bdcf3 Clarify LUKS2 error message related to reencryption. 2 weeks ago
docs Version 2.2.2. 1 month ago
lib Clarify LUKS2 error message related to reencryption. 2 weeks ago
man Fix luksHeaderRestore occuring twice 1 month ago
misc Update copyright year. 10 months ago
po po: update cs.po (from 1 month ago
scripts Do not rename tmpfile config but use it directly. 2 years ago
src Add backward compatibility flags API. 2 weeks ago
tests Remove AEAD tests dor MORUS and AEGIS ciphers. 2 weeks ago
.gitignore Update gitignore (remove pot file). 3 months ago Add kernel crypt backend option to Travis build. 11 months ago
.travis.yml Test Bionic distro in Travis. 1 month ago
AUTHORS Add Ondra to authors. 1 month ago
COPYING Fix FSF address in license text according to 8 years ago
COPYING.LGPL Change License for sub-libraries from GPLv2 only to LGPLv2.1+ ("or any later") 7 years ago
ChangeLog Update version control history url 4 years ago
FAQ Fix misspellings 10 months ago
INSTALL Fix typos. 2 years ago Properly support LTLIBINTL setting in Makefiles. 2 months ago
NEWS Specify copyright holders in source files. 8 years ago
README Move README back. 3 years ago Update for 2.2.2. 1 month ago
TODO Update copyright year. 1 year ago Do not run configure automatically after running 2 years ago Set devel version. 1 month ago

LUKS logo

What the …?

Cryptsetup is a utility used to conveniently set up disk encryption based on the DMCrypt kernel module.

These include plain dm-crypt volumes, LUKS volumes, loop-AES and TrueCrypt (including VeraCrypt extension) formats.

The project also includes a veritysetup utility used to conveniently setup DMVerity block integrity checking kernel module and, since version 2.0, integritysetup to setup DMIntegrity block integrity kernel module.

LUKS Design

LUKS is the standard for Linux hard disk encryption. By providing a standard on-disk-format, it does not
only facilitate compatibility among distributions, but also provides secure management of multiple user passwords.
LUKS stores all necessary setup information in the partition header, enabling to transport or migrate data seamlessly.

Last version of the LUKS2 format specification is available here.

Last version of the LUKS1 format specification is available here.


  • compatibility via standardization,
  • secure against low entropy attacks,
  • support for multiple keys,
  • effective passphrase revocation,
  • free.

Project home page.

Frequently asked questions (FAQ)


All release tarballs and release notes are hosted on

The latest cryptsetup version is 2.2.2

Previous versions

Source and API docs

For development version code, please refer to source page, mirror on or GitHub.

For libcryptsetup documentation see libcryptsetup API page.

The libcryptsetup API/ABI changes are tracked in compatibility report.

NLS PO files are maintained by TranslationProject.


Please always read FAQ first. For cryptsetup and LUKS related questions, please use the dm-crypt mailing list,

If you want to subscribe just send an empty mail to

You can also browse list archive or read it through web interface.