xref: /freebsd/lib/geom/eli/geli.8 (revision 6132212808e8dccedc9e5d85fea4390c2f38059a)
1.\" Copyright (c) 2005-2019 Pawel Jakub Dawidek <pawel@dawidek.net>
2.\" All rights reserved.
3.\"
4.\" Redistribution and use in source and binary forms, with or without
5.\" modification, are permitted provided that the following conditions
6.\" are met:
7.\" 1. Redistributions of source code must retain the above copyright
8.\"    notice, this list of conditions and the following disclaimer.
9.\" 2. Redistributions in binary form must reproduce the above copyright
10.\"    notice, this list of conditions and the following disclaimer in the
11.\"    documentation and/or other materials provided with the distribution.
12.\"
13.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
14.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
17.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23.\" SUCH DAMAGE.
24.\"
25.\" $FreeBSD$
26.\"
27.Dd July 22, 2020
28.Dt GELI 8
29.Os
30.Sh NAME
31.Nm geli
32.Nd "control utility for the cryptographic GEOM class"
33.Sh SYNOPSIS
34To compile GEOM_ELI into your kernel, add the following lines to your kernel
35configuration file:
36.Bd -ragged -offset indent
37.Cd "device crypto"
38.Cd "options GEOM_ELI"
39.Ed
40.Pp
41Alternatively, to load the GEOM_ELI module at boot time, add the following line
42to your
43.Xr loader.conf 5 :
44.Bd -literal -offset indent
45geom_eli_load="YES"
46.Ed
47.Pp
48Usage of the
49.Nm
50utility:
51.Pp
52.Nm
53.Cm init
54.Op Fl bdgPRTv
55.Op Fl a Ar aalgo
56.Op Fl B Ar backupfile
57.Op Fl e Ar ealgo
58.Op Fl i Ar iterations
59.Op Fl J Ar newpassfile
60.Op Fl K Ar newkeyfile
61.Op Fl l Ar keylen
62.Op Fl s Ar sectorsize
63.Op Fl V Ar version
64.Ar prov ...
65.Nm
66.Cm label - an alias for
67.Cm init
68.Nm
69.Cm attach
70.Op Fl Cdprv
71.Op Fl n Ar keyno
72.Op Fl j Ar passfile
73.Op Fl k Ar keyfile
74.Ar prov ...
75.Nm
76.Cm detach
77.Op Fl fl
78.Ar prov ...
79.Nm
80.Cm stop - an alias for
81.Cm detach
82.Nm
83.Cm onetime
84.Op Fl dRT
85.Op Fl a Ar aalgo
86.Op Fl e Ar ealgo
87.Op Fl l Ar keylen
88.Op Fl s Ar sectorsize
89.Ar prov
90.Nm
91.Cm configure
92.Op Fl bBdDgGrRtT
93.Ar prov ...
94.Nm
95.Cm setkey
96.Op Fl pPv
97.Op Fl i Ar iterations
98.Op Fl j Ar passfile
99.Op Fl J Ar newpassfile
100.Op Fl k Ar keyfile
101.Op Fl K Ar newkeyfile
102.Op Fl n Ar keyno
103.Ar prov
104.Nm
105.Cm delkey
106.Op Fl afv
107.Op Fl n Ar keyno
108.Ar prov
109.Nm
110.Cm kill
111.Op Fl av
112.Op Ar prov ...
113.Nm
114.Cm backup
115.Op Fl v
116.Ar prov
117.Ar file
118.Nm
119.Cm restore
120.Op Fl fv
121.Ar file
122.Ar prov
123.Nm
124.Cm suspend
125.Op Fl v
126.Fl a | Ar prov ...
127.Nm
128.Cm resume
129.Op Fl pv
130.Op Fl j Ar passfile
131.Op Fl k Ar keyfile
132.Ar prov
133.Nm
134.Cm resize
135.Op Fl v
136.Fl s Ar oldsize
137.Ar prov
138.Nm
139.Cm version
140.Op Ar prov ...
141.Nm
142.Cm clear
143.Op Fl v
144.Ar prov ...
145.Nm
146.Cm dump
147.Op Fl v
148.Ar prov ...
149.Nm
150.Cm list
151.Nm
152.Cm status
153.Nm
154.Cm load
155.Nm
156.Cm unload
157.Sh DESCRIPTION
158The
159.Nm
160utility is used to configure encryption on GEOM providers.
161.Pp
162The following is a list of the most important features:
163.Pp
164.Bl -bullet -offset indent -compact
165.It
166Utilizes the
167.Xr crypto 9
168framework, so when there is crypto hardware available,
169.Nm
170will make use of it automatically.
171.It
172Supports many cryptographic algorithms (currently
173.Nm AES-XTS ,
174.Nm AES-CBC ,
175and
176.Nm Camellia-CBC ) .
177.It
178Can optionally perform data authentication (integrity verification) utilizing
179one of the following algorithms:
180.Nm HMAC/SHA1 ,
181.Nm HMAC/RIPEMD160 ,
182.Nm HMAC/SHA256 ,
183.Nm HMAC/SHA384
184or
185.Nm HMAC/SHA512 .
186.It
187Can create a User Key from up to two, piecewise components: a passphrase
188entered via prompt or read from one or more passfiles; a keyfile read from
189one or more files.
190.It
191Allows encryption of the root partition.
192The user is asked for the passphrase before the root filesystem is mounted.
193.It
194Strengthens the passphrase component of the User Key with:
195.Rs
196.%A B. Kaliski
197.%T "PKCS #5: Password-Based Cryptography Specification, Version 2.0."
198.%R RFC
199.%N 2898
200.Re
201.It
202Allows the use of two independent User Keys (e.g., a
203.Qq "user key"
204and a
205.Qq "company key" ) .
206.It
207It is fast -
208.Nm
209performs simple sector-to-sector encryption.
210.It
211Allows the encrypted Master Key to be backed up and restored,
212so that if a user has to quickly destroy key material,
213it is possible to get the data back by restoring keys from
214backup.
215.It
216Providers can be configured to automatically detach on last close,
217so users do not have to remember to detach providers after unmounting
218the filesystems.
219.It
220Allows attaching a provider with a random, one-time Master Key,
221which is useful for swap partitions and temporary filesystems.
222.It
223Allows verification of data integrity (data authentication).
224.It
225Allows suspending and resuming encrypted devices.
226.El
227.Pp
228The first argument to
229.Nm
230indicates an action to be performed:
231.Bl -tag -width ".Cm configure"
232.It Cm init
233Initialize providers which need to be encrypted.
234If multiple providers are listed as arguments, they will all be initialized
235with the same passphrase and/or User Key.
236A unique salt will be randomly generated for each provider to ensure the
237Master Key for each is unique.
238Here you can set up the cryptographic algorithm to use, Data Key length,
239etc.
240The last sector of the providers is used to store metadata.
241The
242.Cm init
243subcommand also automatically writes metadata backups to
244.Pa /var/backups/<prov>.eli
245file.
246The metadata can be recovered with the
247.Cm restore
248subcommand described below.
249.Pp
250Additional options include:
251.Bl -tag -width ".Fl J Ar newpassfile"
252.It Fl a Ar aalgo
253Enable data integrity verification (authentication) using the given algorithm.
254This will reduce the size of storage available and also reduce speed.
255For example, when using 4096 bytes sector and
256.Nm HMAC/SHA256
257algorithm, 89% of the original provider storage will be available for use.
258Currently supported algorithms are:
259.Nm HMAC/SHA1 ,
260.Nm HMAC/RIPEMD160 ,
261.Nm HMAC/SHA256 ,
262.Nm HMAC/SHA384
263and
264.Nm HMAC/SHA512 .
265If the option is not given, there will be no authentication, only encryption.
266The recommended algorithm is
267.Nm HMAC/SHA256 .
268.It Fl b
269Try to decrypt this partition during boot, before the root partition is mounted.
270This makes it possible to use an encrypted root partition.
271One will still need bootable unencrypted storage with a
272.Pa /boot/
273directory, which can be a CD-ROM disc or USB pen-drive, that can be removed
274after boot.
275.It Fl B Ar backupfile
276File name to use for metadata backup instead of the default
277.Pa /var/backups/<prov>.eli .
278To inhibit backups, you can use
279.Pa none
280as the
281.Ar backupfile .
282If multiple providers were initialized in the one command, you can use
283.Pa PROV
284(all upper-case) in the file name, and it will be replaced with the provider
285name.
286If
287.Pa PROV
288is not found in the file name and multiple providers were initialized in the
289one command,
290.Pa -<prov>
291will be appended to the end of the file name specified.
292.It Fl d
293When entering the passphrase to boot from this encrypted root filesystem, echo
294.Ql *
295characters.
296This makes the length of the passphrase visible.
297.It Fl e Ar ealgo
298Encryption algorithm to use.
299Currently supported algorithms are:
300.Nm AES-XTS ,
301.Nm AES-CBC ,
302.Nm Camellia-CBC ,
303and
304.Nm NULL .
305The default and recommended algorithm is
306.Nm AES-XTS .
307.Nm NULL
308is unencrypted.
309.It Fl g
310Enable booting from this encrypted root filesystem.
311The boot loader prompts for the passphrase and loads
312.Xr loader 8
313from the encrypted partition.
314.It Fl i Ar iterations
315Number of iterations to use with PKCS#5v2 when processing User Key
316passphrase component.
317If this option is not specified,
318.Nm
319will find the number of iterations which is equal to 2 seconds of crypto work.
320If 0 is given, PKCS#5v2 will not be used.
321PKCS#5v2 processing is performed once, after all parts of the passphrase
322component have been read.
323.It Fl J Ar newpassfile
324Specifies a file which contains the passphrase component of the User Key
325(or part of it).
326If
327.Ar newpassfile
328is given as -, standard input will be used.
329Only the first line (excluding new-line character) is taken from the given file.
330This argument can be specified multiple times, which has the effect of
331reassembling a single passphrase split across multiple files.
332Cannot be combined with the
333.Fl P
334option.
335.It Fl K Ar newkeyfile
336Specifies a file which contains the keyfile component of the User Key
337(or part of it).
338If
339.Ar newkeyfile
340is given as -, standard input will be used.
341This argument can be specified multiple times, which has the effect of
342reassembling a single keyfile split across multiple keyfile parts.
343.It Fl l Ar keylen
344Data Key length to use with the given cryptographic algorithm.
345If the length is not specified, the selected algorithm uses its
346.Em default
347key length.
348.Bl -ohang -offset indent
349.It Nm AES-XTS
350.Em 128 ,
351256
352.It Nm AES-CBC , Nm Camellia-CBC
353.Em 128 ,
354192,
355256
356.El
357.It Fl P
358Do not use a passphrase as a component of the User Key.
359Cannot be combined with the
360.Fl J
361option.
362.It Fl s Ar sectorsize
363Change decrypted provider's sector size.
364Increasing the sector size allows increased performance,
365because encryption/decryption which requires an initialization vector
366is done per sector; fewer sectors means less computational work.
367.It Fl R
368Turn off automatic expansion.
369By default, if the underlying provider grows, the encrypted provider will
370grow automatically too.
371The metadata will be moved to the new location.
372If automatic expansion if turned off and the underlying provider changes
373size, attaching encrypted provider will no longer be possible as the metadata
374will no longer be located in the last sector.
375In this case
376.Nm GELI
377will only log the previous size of the underlying provider, so metadata can
378be found easier, if resize was done by mistake.
379.It Fl T
380Don't pass through
381.Dv BIO_DELETE
382calls (i.e., TRIM/UNMAP).
383This can prevent an attacker from knowing how much space you're actually
384using and which sectors contain live data, but will also prevent the
385backing store (SSD, etc) from reclaiming space you're not using, which
386may degrade its performance and lifespan.
387The underlying provider may or may not actually obliterate the deleted
388sectors when TRIM is enabled, so it should not be considered to add any
389security.
390.It Fl V Ar version
391Metadata version to use.
392This option is helpful when creating a provider that may be used by older
393.Nm FreeBSD/GELI
394versions.
395Consult the
396.Sx HISTORY
397section to find which metadata version is supported by which
398.Fx
399version.
400Note that using an older version of metadata may limit the number of
401features available.
402.El
403.It Cm attach
404Attach the given providers.
405The encrypted Master Keys are loaded from the metadata and decrypted
406using the given passphrase/keyfile and new GEOM providers are created
407using the specified provider names.
408A
409.Qq .eli
410suffix is added to the user specified provider names.
411Multiple providers can only be attached with a single
412.Cm attach
413command if they all have the same passphrase and keyfiles.
414.Pp
415Additional options include:
416.Bl -tag -width ".Fl j Ar passfile"
417.It Fl C
418Do a dry-run decryption.
419This is useful to verify passphrase and keyfile without decrypting the device.
420.It Fl d
421If specified, the decrypted providers are detached automatically on last close,
422so the user does not have to remember to detach
423providers after unmounting the filesystems.
424This only works when providers were opened for writing, and will not work if
425the filesystems on the providers were mounted read-only.
426Probably a better choice is the
427.Fl l
428option for the
429.Cm detach
430subcommand.
431.It Fl n Ar keyno
432Specifies the index number of the Master Key copy to use (could be 0 or 1).
433If the index number is not provided all keys will be tested.
434.It Fl j Ar passfile
435Specifies a file which contains the passphrase component of the User Key
436(or part of it).
437For more information see the description of the
438.Fl J
439option for the
440.Cm init
441subcommand.
442The same passfiles are used for all listed providers.
443.It Fl k Ar keyfile
444Specifies a file which contains the keyfile component of the User Key
445(or part of it).
446For more information see the description of the
447.Fl K
448option for the
449.Cm init
450subcommand.
451The same keyfiles are used for all listed providers.
452.It Fl p
453Do not use a passphrase as a component of the User Keys.
454Cannot be combined with the
455.Fl j
456option.
457.It Fl r
458Attach read-only providers.
459They are not opened for writing.
460.El
461.It Cm detach
462Detach the given providers, which means remove the devfs entry
463and clear the Master Key and Data Keys from memory.
464.Pp
465Additional options include:
466.Bl -tag -width ".Fl f"
467.It Fl f
468Force detach - detach even if the provider is open.
469.It Fl l
470Mark provider to detach on last close, after the last filesystem has been
471unmounted.
472If this option is specified, the provider will not be detached
473while it is open, but will be automatically detached when it is closed for the
474last time even if it was only opened for reading.
475.El
476.It Cm onetime
477Attach the given providers with a random, one-time (ephemeral) Master Key.
478The command can be used to encrypt swap partitions or temporary filesystems.
479.Pp
480Additional options include:
481.Bl -tag -width ".Fl a Ar sectorsize"
482.It Fl a Ar aalgo
483Enable data integrity verification (authentication).
484For more information, see the description of the
485.Cm init
486subcommand.
487.It Fl e Ar ealgo
488Encryption algorithm to use.
489For more information, see the description of the
490.Cm init
491subcommand.
492.It Fl d
493Detach on last close, after the last filesystem has been unmounted.
494Note: this option is not usable for temporary filesystems as the provider is
495detached after the filesystem has been created.
496It still can, and should, be used for swap partitions.
497For more information, see the description of the
498.Cm attach
499subcommand.
500.It Fl l Ar keylen
501Data Key length to use with the given cryptographic algorithm.
502For more information, see the description of the
503.Cm init
504subcommand.
505.It Fl s Ar sectorsize
506Change decrypted provider's sector size.
507For more information, see the description of the
508.Cm init
509subcommand.
510.It Fl R
511Turn off automatic expansion.
512For more information, see the description of the
513.Cm init
514subcommand.
515.It Fl T
516Disable TRIM/UNMAP passthru.
517For more information, see the description of the
518.Cm init
519subcommand.
520.El
521.It Cm configure
522Change configuration of the given providers.
523.Pp
524Additional options include:
525.Bl -tag -width ".Fl b"
526.It Fl b
527Set the BOOT flag on the given providers.
528For more information, see the description of the
529.Cm init
530subcommand.
531.It Fl B
532Remove the BOOT flag from the given providers.
533.It Fl d
534When entering the passphrase to boot from this encrypted root filesystem, echo
535.Ql *
536characters.
537This makes the length of the passphrase visible.
538.It Fl D
539Disable echoing of any characters when a passphrase is entered to boot from this
540encrypted root filesystem.
541This hides the passphrase length.
542.It Fl g
543Enable booting from this encrypted root filesystem.
544The boot loader prompts for the passphrase and loads
545.Xr loader 8
546from the encrypted partition.
547.It Fl G
548Deactivate booting from this encrypted root partition.
549.It Fl r
550Turn on automatic expansion.
551For more information, see the description of the
552.Cm init
553subcommand.
554.It Fl R
555Turn off automatic expansion.
556.It Fl t
557Enable TRIM/UNMAP passthru.
558For more information, see the description of the
559.Cm init
560subcommand.
561.It Fl T
562Disable TRIM/UNMAP passthru.
563.El
564.It Cm setkey
565Install a copy of the Master Key into the selected slot, encrypted with
566a new User Key.
567If the selected slot is populated, replace the existing copy.
568A provider has one Master Key, which can be stored in one or both slots,
569each encrypted with an independent User Key.
570With the
571.Cm init
572subcommand, only key number 0 is initialized.
573The User Key can be changed at any time: for an attached provider,
574for a detached provider, or on the backup file.
575When a provider is attached, the user does not have to provide
576an existing passphrase/keyfile.
577.Pp
578Additional options include:
579.Bl -tag -width ".Fl J Ar newpassfile"
580.It Fl i Ar iterations
581Number of iterations to use with PKCS#5v2.
582If 0 is given, PKCS#5v2 will not be used.
583To be able to use this option with the
584.Cm setkey
585subcommand, only one key has to be defined and this key must be changed.
586.It Fl j Ar passfile
587Specifies a file which contains the passphrase component of a current User Key
588(or part of it).
589.It Fl J Ar newpassfile
590Specifies a file which contains the passphrase component of the new User Key
591(or part of it).
592.It Fl k Ar keyfile
593Specifies a file which contains the keyfile component of a current User Key
594(or part of it).
595.It Fl K Ar newkeyfile
596Specifies a file which contains the keyfile component of the new User Key
597(or part of it).
598.It Fl n Ar keyno
599Specifies the index number of the Master Key copy to change (could be 0 or 1).
600If the provider is attached and no key number is given, the key
601used for attaching the provider will be changed.
602If the provider is detached (or we are operating on a backup file)
603and no key number is given, the first Master Key copy to be successfully
604decrypted with the provided User Key passphrase/keyfile will be changed.
605.It Fl p
606Do not use a passphrase as a component of the current User Key.
607Cannot be combined with the
608.Fl j
609option.
610.It Fl P
611Do not use a passphrase as a component of the new User Key.
612Cannot be combined with the
613.Fl J
614option.
615.El
616.It Cm delkey
617Destroy (overwrite with random data) the selected Master Key copy.
618If one is destroying keys for an attached provider, the provider
619will not be detached even if all copies of the Master Key are destroyed.
620It can even be rescued with the
621.Cm setkey
622subcommand because the Master Key is still in memory.
623.Pp
624Additional options include:
625.Bl -tag -width ".Fl a Ar keyno"
626.It Fl a
627Destroy all copies of the Master Key (does not need
628.Fl f
629option).
630.It Fl f
631Force key destruction.
632This option is needed to destroy the last copy of the Master Key.
633.It Fl n Ar keyno
634Specifies the index number of the Master Key copy.
635If the provider is attached and no key number is given, the key
636used for attaching the provider will be destroyed.
637If provider is detached (or we are operating on a backup file) the key number
638has to be given.
639.El
640.It Cm kill
641This command should be used only in emergency situations.
642It will destroy all copies of the Master Key on a given provider and will
643detach it forcibly (if it is attached).
644This is absolutely a one-way command - if you do not have a metadata
645backup, your data is gone for good.
646In case the provider was attached with the
647.Fl r
648flag, the keys will not be destroyed, only the provider will be detached.
649.Pp
650Additional options include:
651.Bl -tag -width ".Fl a"
652.It Fl a
653If specified, all currently attached providers will be killed.
654.El
655.It Cm backup
656Backup metadata from the given provider to the given file.
657.It Cm restore
658Restore metadata from the given file to the given provider.
659.Pp
660Additional options include:
661.Bl -tag -width ".Fl f"
662.It Fl f
663Metadata contains the size of the provider to ensure that the correct
664partition or slice is attached.
665If an attempt is made to restore metadata to a provider that has a different
666size,
667.Nm
668will refuse to restore the data unless the
669.Fl f
670switch is used.
671If the partition or slice has been grown, the
672.Cm resize
673subcommand should be used rather than attempting to relocate the metadata
674through
675.Cm backup
676and
677.Cm restore .
678.El
679.It Cm suspend
680Suspend device by waiting for all inflight requests to finish, clearing all
681sensitive information such as the Master Key and Data Keys from kernel memory,
682and blocking all further I/O requests until the
683.Cm resume
684subcommand is executed.
685This functionality is useful for laptops.
686Suspending a laptop should not leave an encrypted device attached.
687The
688.Cm suspend
689subcommand can be used rather than closing all files and directories from
690filesystems on the encrypted device, unmounting the filesystem, and
691detaching the device.
692Any access to the encrypted device will be blocked until the Master Key is
693reloaded through the
694.Cm resume
695subcommand.
696Thus there is no need to close nor unmount anything.
697The
698.Cm suspend
699subcommand does not work with devices created with the
700.Cm onetime
701subcommand.
702Please note that sensitive data might still be present in memory locations
703such as the filesystem cache after suspending an encrypted device.
704.Pp
705Additional options include:
706.Bl -tag -width ".Fl a"
707.It Fl a
708Suspend all
709.Nm
710devices.
711.El
712.It Cm resume
713Resume previously suspended device.
714The caller must ensure that executing this subcommand does not access the
715suspended device, leading to a deadlock.
716For example, suspending a device which contains the filesystem where the
717.Nm
718utility is stored is a bad idea.
719.Pp
720Additional options include:
721.Bl -tag -width ".Fl j Ar passfile"
722.It Fl j Ar passfile
723Specifies a file which contains the passphrase component of the User Key,
724or part of it.
725For more information see the description of the
726.Fl J
727option for the
728.Cm init
729subcommand.
730.It Fl k Ar keyfile
731Specifies a file which contains the keyfile component of the User Key,
732or part of it.
733For more information see the description of the
734.Fl K
735option for the
736.Cm init
737subcommand.
738.It Fl p
739Do not use a passphrase as a component of the User Key.
740Cannot be combined with the
741.Fl j
742option.
743.El
744.It Cm resize
745Inform
746.Nm
747that the provider has been resized.
748The old metadata block is relocated to the correct position at the end of the
749provider and the provider size is updated.
750.Pp
751Additional options include:
752.Bl -tag -width ".Fl s Ar oldsize"
753.It Fl s Ar oldsize
754The size of the provider before it was resized.
755.El
756.It Cm version
757If no arguments are given, the
758.Cm version
759subcommand will print the version of
760.Nm
761userland utility as well as the version of the
762.Nm ELI
763GEOM class.
764.Pp
765If GEOM providers are specified, the
766.Cm version
767subcommand will print metadata version used by each of them.
768.It Cm clear
769Clear metadata from the given providers.
770.Em WARNING :
771This will erase with zeros the encrypted Master Key copies stored in the
772metadata.
773.It Cm dump
774Dump metadata stored on the given providers.
775.It Cm list
776See
777.Xr geom 8 .
778.It Cm status
779See
780.Xr geom 8 .
781.It Cm load
782See
783.Xr geom 8 .
784.It Cm unload
785See
786.Xr geom 8 .
787.El
788.Pp
789Additional options include:
790.Bl -tag -width ".Fl v"
791.It Fl v
792Be more verbose.
793.El
794.Sh KEY SUMMARY
795.Ss Master Key
796Upon
797.Cm init ,
798the
799.Nm
800utility generates a random Master Key for the provider.
801The Master Key never changes during the lifetime of the provider.
802Each copy of the provider metadata, active or backed up to a file, can store
803up to two, independently-encrypted copies of the Master Key.
804.Ss User Key
805Each stored copy of the Master Key is encrypted with a User Key, which
806is generated by the
807.Nm
808utility from a passphrase and/or a keyfile.
809The
810.Nm
811utility first reads all parts of the keyfile in the order specified on the
812command line, then reads all parts of the stored passphrase in the order
813specified on the command line.
814If no passphrase parts are specified, the system prompts the user to enter
815the passphrase.
816The passphrase is optionally strengthened by PKCS#5v2.
817The User Key is a digest computed over the concatenated keyfile and passphrase.
818.Ss Data Key
819During operation, one or more Data Keys are deterministically derived by
820the kernel from the Master Key and cached in memory.
821The number of Data Keys used by a given provider, and the way they are
822derived, depend on the GELI version and whether the provider is configured to
823use data authentication.
824.Sh SYSCTL VARIABLES
825The following
826.Xr sysctl 8
827variables can be used to control the behavior of the
828.Nm ELI
829GEOM class.
830The default value is shown next to each variable.
831Some variables can also be set in
832.Pa /boot/loader.conf .
833.Bl -tag -width indent
834.It Va kern.geom.eli.version
835Version number of the
836.Nm ELI
837GEOM class.
838.It Va kern.geom.eli.debug : No 0
839Debug level of the
840.Nm ELI
841GEOM class.
842This can be set to a number between 0 and 3 inclusive.
843If set to 0, minimal debug information is printed.
844If set to 3, the
845maximum amount of debug information is printed.
846.It Va kern.geom.eli.tries : No 3
847Number of times a user is asked for the passphrase.
848This is only used for providers which are attached on boot,
849before the root filesystem is mounted.
850If set to 0, attaching providers on boot will be disabled.
851This variable should be set in
852.Pa /boot/loader.conf .
853.It Va kern.geom.eli.overwrites : No 5
854Specifies how many times the Master Key is overwritten
855with random values when it is destroyed.
856After this operation it is filled with zeros.
857.It Va kern.geom.eli.visible_passphrase : No 0
858If set to 1, the passphrase entered on boot will be visible.
859This alternative should be used with caution as the entered
860passphrase can be logged and exposed via
861.Xr dmesg 8 .
862This variable should be set in
863.Pa /boot/loader.conf .
864.It Va kern.geom.eli.threads : No 0
865Specifies how many kernel threads should be used for doing software
866cryptography.
867Its purpose is to increase performance on SMP systems.
868If set to 0, a CPU-pinned thread will be started for every active CPU.
869.It Va kern.geom.eli.batch : No 0
870When set to 1, can speed-up crypto operations by using batching.
871Batching reduces the number of interrupts by responding to a group of
872crypto requests with one interrupt.
873The crypto card and the driver has to support this feature.
874.It Va kern.geom.eli.key_cache_limit : No 8192
875Specifies how many Data Keys to cache.
876The default limit
877(8192 keys) will allow caching of all keys for a 4TB provider with 512 byte
878sectors and will take around 1MB of memory.
879.It Va kern.geom.eli.key_cache_hits
880Reports how many times we were looking up a Data Key and it was already in
881cache.
882This sysctl is not updated for providers that need fewer Data Keys than
883the limit specified in
884.Va kern.geom.eli.key_cache_limit .
885.It Va kern.geom.eli.key_cache_misses
886Reports how many times we were looking up a Data Key and it was not in cache.
887This sysctl is not updated for providers that need fewer Data Keys than the limit
888specified in
889.Va kern.geom.eli.key_cache_limit .
890.El
891.Sh EXIT STATUS
892Exit status is 0 on success, and 1 if the command fails.
893.Sh EXAMPLES
894Initialize a provider which is going to be encrypted with a
895passphrase and random data from a file on the user's pen drive.
896Use 4kB sector size.
897Attach the provider, create a filesystem, and mount it.
898Do the work.
899Unmount the provider and detach it:
900.Bd -literal -offset indent
901# dd if=/dev/random of=/mnt/pendrive/da2.key bs=64 count=1
902# geli init -s 4096 -K /mnt/pendrive/da2.key /dev/da2
903Enter new passphrase:
904Reenter new passphrase:
905# geli attach -k /mnt/pendrive/da2.key /dev/da2
906Enter passphrase:
907# dd if=/dev/random of=/dev/da2.eli bs=1m
908# newfs /dev/da2.eli
909# mount /dev/da2.eli /mnt/secret
910\&...
911# umount /mnt/secret
912# geli detach da2.eli
913.Ed
914.Pp
915Create an encrypted provider, but use two User Keys:
916one for your employee and one for you as the company's security officer
917(so it is not a tragedy if the employee
918.Qq accidentally
919forgets his passphrase):
920.Bd -literal -offset indent
921# geli init /dev/da2
922Enter new passphrase:	(enter security officer's passphrase)
923Reenter new passphrase:
924# geli setkey -n 1 /dev/da2
925Enter passphrase:	(enter security officer's passphrase)
926Enter new passphrase:	(let your employee enter his passphrase ...)
927Reenter new passphrase:	(... twice)
928.Ed
929.Pp
930You are the security officer in your company.
931Create an encrypted provider for use by the user, but remember that users
932forget their passphrases, so backup the Master Key with your own random key:
933.Bd -literal -offset indent
934# dd if=/dev/random of=/mnt/pendrive/keys/`hostname` bs=64 count=1
935# geli init -P -K /mnt/pendrive/keys/`hostname` /dev/ada0s1e
936# geli backup /dev/ada0s1e /mnt/pendrive/backups/`hostname`
937(use key number 0, so the encrypted Master Key will be re-encrypted by this)
938# geli setkey -n 0 -k /mnt/pendrive/keys/`hostname` /dev/ada0s1e
939(allow the user to enter his passphrase)
940Enter new passphrase:
941Reenter new passphrase:
942.Ed
943.Pp
944Encrypted swap partition setup:
945.Bd -literal -offset indent
946# dd if=/dev/random of=/dev/ada0s1b bs=1m
947# geli onetime -d ada0s1b
948# swapon /dev/ada0s1b.eli
949.Ed
950.Pp
951The example below shows how to configure two providers which will be attached
952on boot, before the root filesystem is mounted.
953One of them is using passphrase and three keyfile parts and the other is
954using only a keyfile in one part:
955.Bd -literal -offset indent
956# dd if=/dev/random of=/dev/da0 bs=1m
957# dd if=/dev/random of=/boot/keys/da0.key0 bs=32k count=1
958# dd if=/dev/random of=/boot/keys/da0.key1 bs=32k count=1
959# dd if=/dev/random of=/boot/keys/da0.key2 bs=32k count=1
960# geli init -b -K /boot/keys/da0.key0 -K /boot/keys/da0.key1 -K /boot/keys/da0.key2 da0
961Enter new passphrase:
962Reenter new passphrase:
963# dd if=/dev/random of=/dev/da1s3a bs=1m
964# dd if=/dev/random of=/boot/keys/da1s3a.key bs=128k count=1
965# geli init -b -P -K /boot/keys/da1s3a.key da1s3a
966.Ed
967.Pp
968The providers are initialized, now we have to add these lines to
969.Pa /boot/loader.conf :
970.Bd -literal -offset indent
971geli_da0_keyfile0_load="YES"
972geli_da0_keyfile0_type="da0:geli_keyfile0"
973geli_da0_keyfile0_name="/boot/keys/da0.key0"
974geli_da0_keyfile1_load="YES"
975geli_da0_keyfile1_type="da0:geli_keyfile1"
976geli_da0_keyfile1_name="/boot/keys/da0.key1"
977geli_da0_keyfile2_load="YES"
978geli_da0_keyfile2_type="da0:geli_keyfile2"
979geli_da0_keyfile2_name="/boot/keys/da0.key2"
980
981geli_da1s3a_keyfile0_load="YES"
982geli_da1s3a_keyfile0_type="da1s3a:geli_keyfile0"
983geli_da1s3a_keyfile0_name="/boot/keys/da1s3a.key"
984.Ed
985.Pp
986If there is only one keyfile, the index might be omitted:
987.Bd -literal -offset indent
988geli_da1s3a_keyfile_load="YES"
989geli_da1s3a_keyfile_type="da1s3a:geli_keyfile"
990geli_da1s3a_keyfile_name="/boot/keys/da1s3a.key"
991.Ed
992.Pp
993By convention, these loader variables are called
994.Sm off
995.Va geli_ No < Ar device No > Va _load .
996.Sm on
997However, the actual name prefix before
998.Va _load , _type ,
999or
1000.Va _name
1001does not matter.
1002At boot time, the
1003.Nm
1004module searches through all
1005.Sm off
1006.No < Va prefix No > Va _type No -like
1007.Sm on
1008variables that have a value of
1009.Sm off
1010.Dq < Ar device No > :geli_keyfile .
1011.Sm on
1012The paths to keyfiles are then extracted from
1013.Sm off
1014.No < Ar prefix No > Va _name
1015.Sm on
1016variables.
1017In the example above,
1018.Ar prefix
1019is
1020.Dq Li geli_da1s3a_keyfile .
1021.Pp
1022Not only configure encryption, but also data integrity verification using
1023.Nm HMAC/SHA256 .
1024.Bd -literal -offset indent
1025# geli init -a hmac/sha256 -s 4096 /dev/da0
1026Enter new passphrase:
1027Reenter new passphrase:
1028# geli attach /dev/da0
1029Enter passphrase:
1030# dd if=/dev/random of=/dev/da0.eli bs=1m
1031# newfs /dev/da0.eli
1032# mount /dev/da0.eli /mnt/secret
1033.Ed
1034.Pp
1035.Cm geli
1036writes the metadata backup by default to the
1037.Pa /var/backups/<prov>.eli
1038file.
1039If the metadata is lost in any way (e.g., by accidental overwrite), it can be restored.
1040Consider the following situation:
1041.Bd -literal -offset indent
1042# geli init /dev/da0
1043Enter new passphrase:
1044Reenter new passphrase:
1045
1046Metadata backup can be found in /var/backups/da0.eli and
1047can be restored with the following command:
1048
1049	# geli restore /var/backups/da0.eli /dev/da0
1050
1051# geli clear /dev/da0
1052# geli attach /dev/da0
1053geli: Cannot read metadata from /dev/da0: Invalid argument.
1054# geli restore /var/backups/da0.eli /dev/da0
1055# geli attach /dev/da0
1056Enter passphrase:
1057.Ed
1058.Pp
1059If an encrypted filesystem is extended, it is necessary to relocate and
1060update the metadata:
1061.Bd -literal -offset indent
1062# gpart create -s GPT ada0
1063# gpart add -s 1g -t freebsd-ufs -i 1 ada0
1064# geli init -K keyfile -P ada0p1
1065# gpart resize -s 2g -i 1 ada0
1066# geli resize -s 1g ada0p1
1067# geli attach -k keyfile -p ada0p1
1068.Ed
1069.Pp
1070Initialize provider with the passphrase split into two files.
1071The provider can be attached using those two files or by entering
1072.Dq foobar
1073as the passphrase at the
1074.Nm
1075prompt:
1076.Bd -literal -offset indent
1077# echo foo > da0.pass0
1078# echo bar > da0.pass1
1079# geli init -J da0.pass0 -J da0.pass1 da0
1080# geli attach -j da0.pass0 -j da0.pass1 da0
1081# geli detach da0
1082# geli attach da0
1083Enter passphrase: foobar
1084.Ed
1085.Pp
1086Suspend all
1087.Nm
1088devices on a laptop, suspend the laptop, then resume devices one by one after
1089resuming the laptop:
1090.Bd -literal -offset indent
1091# geli suspend -a
1092# zzz
1093<resume your laptop>
1094# geli resume -p -k keyfile gpt/secret
1095# geli resume gpt/private
1096Enter passphrase:
1097.Ed
1098.Pp
1099To create a
1100.Nm
1101encrypted filesystem with a file as storage device follow this example.
1102First a file named private0 is created in
1103.Pa /usr
1104and attached as a memory disk like
1105.Pa /dev/md0
1106for example.
1107.Bd -literal -offset indent
1108# dd if=/dev/zero of=/usr/private0 bs=1m count=256
1109# chmod 0600 /usr/private0
1110# mdconfig -t vnode -f /usr/private0
1111.Ed
1112.Pp
1113It is recommended to place the following line in
1114.Xr rc.conf 5
1115to have the memory disk automatically created during boot.
1116.Bd -literal -offset indent
1117mdconfig_md0="-t vnode -f /usr/private0"
1118.Ed
1119.Pp
1120After
1121.Pa /dev/md0
1122is created a random key has to be generated and stored in a secure location,
1123like
1124.Pa /root
1125for example.
1126This key should be protected by a passphrase, which
1127is requested when geli init is called.
1128.Bd -literal -offset indent
1129# dd if=/dev/random of=/root/private0.key bs=64 count=1
1130# geli init -K /root/private0.key -s 4096 /dev/md0
1131Enter new passphrase:
1132Reenter new passphrase:
1133# geli attach -k /root/private0.key /dev/md0
1134Enter passphrase:
1135# dd if=/dev/random of=/dev/md0.eli bs=1m
1136.Ed
1137.Pp
1138Once the initialization of the
1139.Pa /dev/md0.eli
1140device is ready create a UFS filesystem and mount it for example in
1141.Pa /private .
1142.Bd -literal -offset indent
1143# newfs /dev/md0.eli
1144# mount /dev/md0.eli /private
1145.Ed
1146.Pp
1147After a system reboot the
1148.Nm
1149device can be mounted again with the following commands.
1150The call of geli attach will ask for the passphrase.
1151It is recommended to do this procedure after the boot, because otherwise
1152the boot process would be waiting for the passphrase input.
1153.Bd -literal -offset indent
1154# geli attach -k /root/private0.key /dev/md0
1155Enter passphrase:
1156# mount /dev/md0.eli /private
1157.Ed
1158.Sh ENCRYPTION MODES
1159.Nm
1160supports two encryption modes:
1161.Nm XTS ,
1162which was standardized as
1163.Nm IEEE P1619
1164and
1165.Nm CBC
1166with unpredictable IV.
1167The
1168.Nm CBC
1169mode used by
1170.Nm
1171is very similar to the mode
1172.Nm ESSIV .
1173.Sh DATA AUTHENTICATION
1174.Nm
1175can verify data integrity when an authentication algorithm is specified.
1176When data corruption/modification is detected,
1177.Nm
1178will not return any data, but instead will return an error
1179.Pq Er EINVAL .
1180The offset and size of the corrupted data will be printed on the console.
1181It is important to know against which attacks
1182.Nm
1183provides protection for your data.
1184If data is modified in-place or copied from one place on the disk
1185to another even without modification,
1186.Nm
1187should be able to detect such a change.
1188If an attacker can remember the encrypted data, he can overwrite any future
1189changes with the data he owns without it being noticed.
1190In other words
1191.Nm
1192will not protect your data against replay attacks.
1193.Pp
1194It is recommended to write to the whole provider before first use,
1195in order to make sure that all sectors and their corresponding
1196checksums are properly initialized into a consistent state.
1197One can safely ignore data authentication errors that occur immediately
1198after the first time a provider is attached and before it is
1199initialized in this way.
1200.Sh SEE ALSO
1201.Xr crypto 4 ,
1202.Xr gbde 4 ,
1203.Xr geom 4 ,
1204.Xr loader.conf 5 ,
1205.Xr gbde 8 ,
1206.Xr geom 8 ,
1207.Xr crypto 9
1208.Sh HISTORY
1209The
1210.Nm
1211utility appeared in
1212.Fx 6.0 .
1213Support for the
1214.Nm Camellia
1215block cipher was implemented by Yoshisato Yanagisawa in
1216.Fx 7.0 .
1217.Pp
1218Highest
1219.Nm GELI
1220metadata version supported by the given
1221.Fx
1222version:
1223.Bl -column -offset indent ".Sy FreeBSD" ".Sy version"
1224.It Sy FreeBSD Ta Sy GELI
1225.It Sy version Ta Sy version
1226.Pp
1227.It Li 6.0 Ta 0
1228.It Li 6.1 Ta 0
1229.It Li 6.2 Ta 3
1230.It Li 6.3 Ta 3
1231.It Li 6.4 Ta 3
1232.Pp
1233.It Li 7.0 Ta 3
1234.It Li 7.1 Ta 3
1235.It Li 7.2 Ta 3
1236.It Li 7.3 Ta 3
1237.It Li 7.4 Ta 3
1238.Pp
1239.It Li 8.0 Ta 3
1240.It Li 8.1 Ta 3
1241.It Li 8.2 Ta 5
1242.Pp
1243.It Li 9.0 Ta 6
1244.Pp
1245.It Li 10.0 Ta 7
1246.El
1247.Sh AUTHORS
1248.An Pawel Jakub Dawidek Aq Mt pjd@FreeBSD.org
1249