[PATCH 02/18] nvme-keyring: define a 'psk' keytype
Sagi Grimberg
sagi at grimberg.me
Wed Mar 22 01:29:34 PDT 2023
On 3/21/23 14:43, Hannes Reinecke wrote:
> Define a 'psk' keytype to hold the NVMe TLS PSKs.
>
> Signed-off-by: Hannes Reinecke <hare at suse.de>
> ---
> drivers/nvme/common/keyring.c | 96 +++++++++++++++++++++++++++++++++++
> include/linux/nvme-keyring.h | 8 +++
> 2 files changed, 104 insertions(+)
>
> diff --git a/drivers/nvme/common/keyring.c b/drivers/nvme/common/keyring.c
> index 3a6e8a0b38e2..6cbb9d66e0f6 100644
> --- a/drivers/nvme/common/keyring.c
> +++ b/drivers/nvme/common/keyring.c
> @@ -11,6 +11,96 @@
>
> static struct key *nvme_keyring;
>
> +key_serial_t nvme_keyring_id(void)
> +{
> + return nvme_keyring->serial;
> +}
> +EXPORT_SYMBOL_GPL(nvme_keyring_id);
> +
> +static void nvme_tls_psk_describe(const struct key *key, struct seq_file *m)
> +{
> + seq_puts(m, key->description);
> + seq_printf(m, ": %u", key->datalen);
> +}
> +
> +static bool nvme_tls_psk_match(const struct key *key,
> + const struct key_match_data *match_data)
> +{
> + const char *match_id;
> + size_t match_len;
> +
> + if (!key->description) {
> + pr_debug("%s: no key description\n", __func__);
> + return false;
> + }
> + match_len = strlen(key->description);
> + pr_debug("%s: id %s len %zd\n", __func__, key->description, match_len);
> +
> + if (!match_data->raw_data) {
> + pr_debug("%s: no match data\n", __func__);
> + return false;
> + }
> + match_id = match_data->raw_data;
> + pr_debug("%s: match '%s' '%s' len %lu\n",
> + __func__, match_id, key->description, match_len);
> + return !memcmp(key->description, match_id, match_len);
> +}
> +
> +static int nvme_tls_psk_match_preparse(struct key_match_data *match_data)
> +{
> + match_data->lookup_type = KEYRING_SEARCH_LOOKUP_ITERATE;
> + match_data->cmp = nvme_tls_psk_match;
> + return 0;
> +}
> +
> +static struct key_type nvme_tls_psk_key_type = {
> + .name = "psk",
> + .flags = KEY_TYPE_NET_DOMAIN,
> + .preparse = user_preparse,
> + .free_preparse = user_free_preparse,
> + .match_preparse = nvme_tls_psk_match_preparse,
> + .instantiate = generic_key_instantiate,
> + .revoke = user_revoke,
> + .destroy = user_destroy,
> + .describe = nvme_tls_psk_describe,
> + .read = user_read,
> +};
> +
Hannes, can you please provide a documentation section
to this function? most importantly 'generated' argument.
> +struct key *nvme_tls_psk_lookup(key_ref_t keyring,
> + const char *hostnqn, const char *subnqn,
> + int hmac, bool generated)
> +{
> + char *identity;
> + size_t identity_len = (NVMF_NQN_SIZE) * 2 + 11;
> + key_ref_t keyref;
> + key_serial_t keyring_id;
> +
> + identity = kzalloc(identity_len, GFP_KERNEL);
> + if (!identity)
> + return ERR_PTR(-ENOMEM);
> +
> + snprintf(identity, identity_len, "NVMe0%c%02d %s %s",
> + generated ? 'G' : 'R', hmac, hostnqn, subnqn);
Is that a format that is expected from userspace to produce?
> +
> + if (!keyring)
> + keyring = make_key_ref(nvme_keyring, true);
> + keyring_id = key_serial(key_ref_to_ptr(keyring));
> + pr_debug("keyring %x lookup tls psk '%s'\n",
> + keyring_id, identity);
> + keyref = keyring_search(keyring, &nvme_tls_psk_key_type,
> + identity, false);
> + if (IS_ERR(keyref)) {
> + pr_debug("lookup tls psk '%s' failed, error %ld\n",
> + identity, PTR_ERR(keyref));
> + kfree(identity);
> + return ERR_PTR(-ENOKEY);
> + }
> + kfree(identity);
> +
> + return key_ref_to_ptr(keyref);
> +}
> +EXPORT_SYMBOL_GPL(nvme_tls_psk_lookup);
> +
> int nvme_keyring_init(void)
> {
> int err;
> @@ -24,12 +114,18 @@ int nvme_keyring_init(void)
> if (IS_ERR(nvme_keyring))
> return PTR_ERR(nvme_keyring);
>
> + err = register_key_type(&nvme_tls_psk_key_type);
> + if (err) {
> + key_put(nvme_keyring);
> + return err;
> + }
> return 0;
> }
> EXPORT_SYMBOL_GPL(nvme_keyring_init);
>
> void nvme_keyring_exit(void)
> {
> + unregister_key_type(&nvme_tls_psk_key_type);
> key_revoke(nvme_keyring);
> key_put(nvme_keyring);
> }
> diff --git a/include/linux/nvme-keyring.h b/include/linux/nvme-keyring.h
> index a875c06cc922..c0c3d934f474 100644
> --- a/include/linux/nvme-keyring.h
> +++ b/include/linux/nvme-keyring.h
> @@ -6,6 +6,14 @@
> #ifndef _NVME_KEYRING_H
> #define _NVME_KEYRING_H
>
> +#include <linux/key.h>
> +
> +struct key *nvme_tls_psk_lookup(key_ref_t keyring,
> + const char *hostnqn, const char *subnqn,
> + int hmac, bool generated);
> +
> +key_serial_t nvme_keyring_id(void);
> +
> int nvme_keyring_init(void);
> void nvme_keyring_exit(void);
>
More information about the Linux-nvme
mailing list