mirror of
https://github.com/torvalds/linux.git
synced 2024-11-22 20:22:09 +00:00
86c639ce08
Make 'struct mmc_request' contain a pointer to the request's 'struct bio_crypt_ctx' directly, instead of extracting a 32-bit DUN from it which is a cqhci-crypto specific detail. This keeps the cqhci crypto specific details in the cqhci module, and it makes mmc_core and mmc_block ready for MMC crypto hardware that accepts the DUN and/or key in a way that is more flexible than that which will be specified by the eMMC v5.2 standard. Exynos SoCs are an example of such hardware, as their inline encryption hardware takes keys directly (it has no concept of keyslots) and supports 128-bit DUNs. Note that the 32-bit DUN length specified by the standard is very restrictive, so it is likely that more hardware will support longer DUNs despite it not following the standard. Thus, limiting the scope of the 32-bit DUN assumption to the place that actually needs it is warranted. Signed-off-by: Eric Biggers <ebiggers@google.com> Link: https://lore.kernel.org/r/20210721154738.3966463-1-ebiggers@kernel.org Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
51 lines
1.0 KiB
C
51 lines
1.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* CQHCI crypto engine (inline encryption) support
|
|
*
|
|
* Copyright 2020 Google LLC
|
|
*/
|
|
|
|
#ifndef LINUX_MMC_CQHCI_CRYPTO_H
|
|
#define LINUX_MMC_CQHCI_CRYPTO_H
|
|
|
|
#include <linux/mmc/host.h>
|
|
|
|
#include "cqhci.h"
|
|
|
|
#ifdef CONFIG_MMC_CRYPTO
|
|
|
|
int cqhci_crypto_init(struct cqhci_host *host);
|
|
|
|
/*
|
|
* Returns the crypto bits that should be set in bits 64-127 of the
|
|
* task descriptor.
|
|
*/
|
|
static inline u64 cqhci_crypto_prep_task_desc(struct mmc_request *mrq)
|
|
{
|
|
if (!mrq->crypto_ctx)
|
|
return 0;
|
|
|
|
/* We set max_dun_bytes_supported=4, so all DUNs should be 32-bit. */
|
|
WARN_ON_ONCE(mrq->crypto_ctx->bc_dun[0] > U32_MAX);
|
|
|
|
return CQHCI_CRYPTO_ENABLE_BIT |
|
|
CQHCI_CRYPTO_KEYSLOT(mrq->crypto_key_slot) |
|
|
mrq->crypto_ctx->bc_dun[0];
|
|
}
|
|
|
|
#else /* CONFIG_MMC_CRYPTO */
|
|
|
|
static inline int cqhci_crypto_init(struct cqhci_host *host)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline u64 cqhci_crypto_prep_task_desc(struct mmc_request *mrq)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
#endif /* !CONFIG_MMC_CRYPTO */
|
|
|
|
#endif /* LINUX_MMC_CQHCI_CRYPTO_H */
|