mmc: core: Add basic support for inline encryption
authorEric Biggers <ebiggers@google.com>
Tue, 26 Jan 2021 00:14:48 +0000 (16:14 -0800)
committerUlf Hansson <ulf.hansson@linaro.org>
Mon, 1 Feb 2021 11:02:33 +0000 (12:02 +0100)
commit93f1c150cb0d043e1e8985db7824b4e2e1ac653f
tree5c999fb86e72da2a2a12b871c122588ff5907598
parentd76d9d7d1009968dd3a0fc30e5f5ee9fbffc1350
mmc: core: Add basic support for inline encryption

In preparation for adding CQHCI crypto engine (inline encryption)
support, add the code required to make mmc_core and mmc_block aware of
inline encryption.  Specifically:

- Add a capability flag MMC_CAP2_CRYPTO to struct mmc_host.  Drivers
  will set this if the host and driver support inline encryption.

- Embed a blk_keyslot_manager in struct mmc_host.  Drivers will
  initialize this (as a device-managed resource) if the host and driver
  support inline encryption.  mmc_block registers this keyslot manager
  with the request_queue of any MMC card attached to the host.

- Make mmc_block copy the crypto keyslot and crypto data unit number
  from struct request to struct mmc_request, so that drivers will have
  access to them.

- If the MMC host is reset, reprogram all the keyslots to ensure that
  the software state stays in sync with the hardware state.

Co-developed-by: Satya Tangirala <satyat@google.com>
Signed-off-by: Satya Tangirala <satyat@google.com>
Acked-by: Adrian Hunter <adrian.hunter@intel.com>
Reviewed-by: Satya Tangirala <satyat@google.com>
Reviewed-and-tested-by: Peng Zhou <peng.zhou@mediatek.com>
Signed-off-by: Eric Biggers <ebiggers@google.com>
Link: https://lore.kernel.org/r/20210126001456.382989-2-ebiggers@kernel.org
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/core/Kconfig
drivers/mmc/core/Makefile
drivers/mmc/core/block.c
drivers/mmc/core/core.c
drivers/mmc/core/crypto.c [new file with mode: 0644]
drivers/mmc/core/crypto.h [new file with mode: 0644]
drivers/mmc/core/host.c
drivers/mmc/core/queue.c
include/linux/mmc/core.h
include/linux/mmc/host.h