| // SPDX-License-Identifier: GPL-2.0-only |
| /* |
| * MMC crypto engine (inline encryption) support |
| * |
| * Copyright 2020 Google LLC |
| */ |
| |
| #include <linux/blk-crypto.h> |
| #include <linux/mmc/host.h> |
| |
| #include "core.h" |
| #include "crypto.h" |
| #include "queue.h" |
| |
| void mmc_crypto_set_initial_state(struct mmc_host *host) |
| { |
| /* Reset might clear all keys, so reprogram all the keys. */ |
| if (host->caps2 & MMC_CAP2_CRYPTO) |
| blk_crypto_reprogram_all_keys(&host->crypto_profile); |
| } |
| |
| void mmc_crypto_setup_queue(struct request_queue *q, struct mmc_host *host) |
| { |
| if (host->caps2 & MMC_CAP2_CRYPTO) |
| blk_crypto_register(&host->crypto_profile, q); |
| } |
| EXPORT_SYMBOL_GPL(mmc_crypto_setup_queue); |
| |
| void mmc_crypto_prepare_req(struct mmc_queue_req *mqrq) |
| { |
| struct request *req = mmc_queue_req_to_req(mqrq); |
| struct mmc_request *mrq = &mqrq->brq.mrq; |
| struct blk_crypto_keyslot *keyslot; |
| |
| if (!req->crypt_ctx) |
| return; |
| |
| mrq->crypto_ctx = req->crypt_ctx; |
| |
| keyslot = req->crypt_keyslot; |
| if (keyslot) |
| mrq->crypto_key_slot = blk_crypto_keyslot_index(keyslot); |
| } |
| EXPORT_SYMBOL_GPL(mmc_crypto_prepare_req); |