android_kernel_sony_msm8994/init
Will Drewry 691cc182cb CHROMIUM: dm: boot time specification of dm=
This is a wrap-up of three patches pending upstream approval.
I'm bundling them because they are interdependent, and it'll be
easier to drop it on rebase later.

1. dm: allow a dm-fs-style device to be shared via dm-ioctl

Integrates feedback from Alisdair, Mike, and Kiyoshi.

Two main changes occur here:

- One function is added which allows for a programmatically created
mapped device to be inserted into the dm-ioctl hash table.  This binds
the device to a name and, optional, uuid which is needed by udev and
allows for userspace management of the mapped device.

- dm_table_complete() was extended to handle all of the final
functional changes required for the table to be operational once
called.

2. init: boot to device-mapper targets without an initr*

Add a dm= kernel parameter modeled after the md= parameter from
do_mounts_md.  It allows for device-mapper targets to be configured at
boot time for use early in the boot process (as the root device or
otherwise).  It also replaces /dev/XXX calls with major:minor opportunistically.

The format is dm="name uuid ro,table line 1,table line 2,...".  The
parser expects the comma to be safe to use as a newline substitute but,
otherwise, uses the normal separator of space.  Some attempt has been
made to make it forgiving of additional spaces (using skip_spaces()).

A mapped device created during boot will be assigned a minor of 0 and
may be access via /dev/dm-0.

An example dm-linear root with no uuid may look like:

root=/dev/dm-0  dm="lroot none ro, 0 4096 linear /dev/ubdb 0, 4096 4096 linear /dv/ubdc 0"

Once udev is started, /dev/dm-0 will become /dev/mapper/lroot.

Older upstream threads:
http://marc.info/?l=dm-devel&m=127429492521964&w=2
http://marc.info/?l=dm-devel&m=127429499422096&w=2
http://marc.info/?l=dm-devel&m=127429493922000&w=2

Latest upstream threads:
https://patchwork.kernel.org/patch/104859/
https://patchwork.kernel.org/patch/104860/
https://patchwork.kernel.org/patch/104861/

BUG: 27175947

Signed-off-by: Will Drewry <wad@chromium.org>
Review URL: http://codereview.chromium.org/2020011
Change-Id: I92bd53432a11241228d2e5ac89a3b20d19b05a31
2016-05-10 13:15:52 +05:30
..
calibrate.c
do_mounts_dm.c CHROMIUM: dm: boot time specification of dm= 2016-05-10 13:15:52 +05:30
do_mounts_initrd.c
do_mounts_md.c
do_mounts_rd.c
do_mounts.c CHROMIUM: dm: boot time specification of dm= 2016-05-10 13:15:52 +05:30
do_mounts.h CHROMIUM: dm: boot time specification of dm= 2016-05-10 13:15:52 +05:30
init_task.c
initramfs.c initramfs: Add skip_initramfs command line option 2015-08-12 18:31:39 -07:00
Kconfig UPSTREAM: KEYS: Separate the kernel signature checking keyring from module signing 2016-05-10 13:15:51 +05:30
main.c This is the 3.10.84 stable release 2015-08-13 14:38:09 -07:00
Makefile CHROMIUM: dm: boot time specification of dm= 2016-05-10 13:15:52 +05:30
noinitramfs.c initramfs: Add skip_initramfs command line option 2015-08-12 18:31:39 -07:00
version.c