mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 15:10:38 +00:00
6bbc923dfc
Add a "create" module parameter, which allows device-mapper targets to be configured at boot time. This enables early use of DM targets in the boot process (as the root device or otherwise) without the need of an initramfs. The syntax used in the boot param is based on the concise format from the dmsetup tool to follow the rule of least surprise: dmsetup table --concise /dev/mapper/lroot Which is: dm-mod.create=<name>,<uuid>,<minor>,<flags>,<table>[,<table>+][;<name>,<uuid>,<minor>,<flags>,<table>[,<table>+]+] Where, <name> ::= The device name. <uuid> ::= xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx | "" <minor> ::= The device minor number | "" <flags> ::= "ro" | "rw" <table> ::= <start_sector> <num_sectors> <target_type> <target_args> <target_type> ::= "verity" | "linear" | ... For example, the following could be added in the boot parameters: dm-mod.create="lroot,,,rw, 0 4096 linear 98:16 0, 4096 4096 linear 98:32 0" root=/dev/dm-0 Only the targets that were tested are allowed and the ones that don't change any block device when the device is create as read-only. For example, mirror and cache targets are not allowed. The rationale behind this is that if the user makes a mistake, choosing the wrong device to be the mirror or the cache can corrupt data. The only targets initially allowed are: * crypt * delay * linear * snapshot-origin * striped * verity Co-developed-by: Will Drewry <wad@chromium.org> Co-developed-by: Kees Cook <keescook@chromium.org> Co-developed-by: Enric Balletbo i Serra <enric.balletbo@collabora.com> Signed-off-by: Helen Koike <helen.koike@collabora.com> Reviewed-by: Kees Cook <keescook@chromium.org> Signed-off-by: Mike Snitzer <snitzer@redhat.com>
115 lines
4.0 KiB
Plaintext
115 lines
4.0 KiB
Plaintext
Early creation of mapped devices
|
|
====================================
|
|
|
|
It is possible to configure a device-mapper device to act as the root device for
|
|
your system in two ways.
|
|
|
|
The first is to build an initial ramdisk which boots to a minimal userspace
|
|
which configures the device, then pivot_root(8) in to it.
|
|
|
|
The second is to create one or more device-mappers using the module parameter
|
|
"dm-mod.create=" through the kernel boot command line argument.
|
|
|
|
The format is specified as a string of data separated by commas and optionally
|
|
semi-colons, where:
|
|
- a comma is used to separate fields like name, uuid, flags and table
|
|
(specifies one device)
|
|
- a semi-colon is used to separate devices.
|
|
|
|
So the format will look like this:
|
|
|
|
dm-mod.create=<name>,<uuid>,<minor>,<flags>,<table>[,<table>+][;<name>,<uuid>,<minor>,<flags>,<table>[,<table>+]+]
|
|
|
|
Where,
|
|
<name> ::= The device name.
|
|
<uuid> ::= xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx | ""
|
|
<minor> ::= The device minor number | ""
|
|
<flags> ::= "ro" | "rw"
|
|
<table> ::= <start_sector> <num_sectors> <target_type> <target_args>
|
|
<target_type> ::= "verity" | "linear" | ... (see list below)
|
|
|
|
The dm line should be equivalent to the one used by the dmsetup tool with the
|
|
--concise argument.
|
|
|
|
Target types
|
|
============
|
|
|
|
Not all target types are available as there are serious risks in allowing
|
|
activation of certain DM targets without first using userspace tools to check
|
|
the validity of associated metadata.
|
|
|
|
"cache": constrained, userspace should verify cache device
|
|
"crypt": allowed
|
|
"delay": allowed
|
|
"era": constrained, userspace should verify metadata device
|
|
"flakey": constrained, meant for test
|
|
"linear": allowed
|
|
"log-writes": constrained, userspace should verify metadata device
|
|
"mirror": constrained, userspace should verify main/mirror device
|
|
"raid": constrained, userspace should verify metadata device
|
|
"snapshot": constrained, userspace should verify src/dst device
|
|
"snapshot-origin": allowed
|
|
"snapshot-merge": constrained, userspace should verify src/dst device
|
|
"striped": allowed
|
|
"switch": constrained, userspace should verify dev path
|
|
"thin": constrained, requires dm target message from userspace
|
|
"thin-pool": constrained, requires dm target message from userspace
|
|
"verity": allowed
|
|
"writecache": constrained, userspace should verify cache device
|
|
"zero": constrained, not meant for rootfs
|
|
|
|
If the target is not listed above, it is constrained by default (not tested).
|
|
|
|
Examples
|
|
========
|
|
An example of booting to a linear array made up of user-mode linux block
|
|
devices:
|
|
|
|
dm-mod.create="lroot,,,rw, 0 4096 linear 98:16 0, 4096 4096 linear 98:32 0" root=/dev/dm-0
|
|
|
|
This will boot to a rw dm-linear target of 8192 sectors split across two block
|
|
devices identified by their major:minor numbers. After boot, udev will rename
|
|
this target to /dev/mapper/lroot (depending on the rules). No uuid was assigned.
|
|
|
|
An example of multiple device-mappers, with the dm-mod.create="..." contents is shown here
|
|
split on multiple lines for readability:
|
|
|
|
vroot,,,ro,
|
|
0 1740800 verity 254:0 254:0 1740800 sha1
|
|
76e9be054b15884a9fa85973e9cb274c93afadb6
|
|
5b3549d54d6c7a3837b9b81ed72e49463a64c03680c47835bef94d768e5646fe;
|
|
vram,,,rw,
|
|
0 32768 linear 1:0 0,
|
|
32768 32768 linear 1:1 0
|
|
|
|
Other examples (per target):
|
|
|
|
"crypt":
|
|
dm-crypt,,8,ro,
|
|
0 1048576 crypt aes-xts-plain64
|
|
babebabebabebabebabebabebabebabebabebabebabebabebabebabebabebabe 0
|
|
/dev/sda 0 1 allow_discards
|
|
|
|
"delay":
|
|
dm-delay,,4,ro,0 409600 delay /dev/sda1 0 500
|
|
|
|
"linear":
|
|
dm-linear,,,rw,
|
|
0 32768 linear /dev/sda1 0,
|
|
32768 1024000 linear /dev/sda2 0,
|
|
1056768 204800 linear /dev/sda3 0,
|
|
1261568 512000 linear /dev/sda4 0
|
|
|
|
"snapshot-origin":
|
|
dm-snap-orig,,4,ro,0 409600 snapshot-origin 8:2
|
|
|
|
"striped":
|
|
dm-striped,,4,ro,0 1638400 striped 4 4096
|
|
/dev/sda1 0 /dev/sda2 0 /dev/sda3 0 /dev/sda4 0
|
|
|
|
"verity":
|
|
dm-verity,,4,ro,
|
|
0 1638400 verity 1 8:1 8:2 4096 4096 204800 1 sha256
|
|
fb1a5a0f00deb908d8b53cb270858975e76cf64105d412ce764225d53b8f3cfd
|
|
51934789604d1b92399c52e7cb149d1b3a1b74bbbcb103b2a0aaacbed5c08584
|