[PATCH 1/8] nvme-auth: modify nvme_auth_transform_key() to return status
Hannes Reinecke
hare at suse.de
Tue Mar 17 07:55:11 PDT 2026
On 3/17/26 14:09, Maurizio Lombardi wrote:
> On Tue Mar 17, 2026 at 2:00 PM CET, Hannes Reinecke wrote:
>> In preparation for converting the DH-HMAC-CHAP code to use the
>> kernel keyring modify nvme_auth_transform_key() to return a status
>> and provide the transformed data as argument on the command line as
>> raw data.
>>
>> Signed-off-by: Hannes Reinecke <hare at kernel.org>
>> ---
>> drivers/nvme/common/auth.c | 38 ++++++++++++++++----------------
>> drivers/nvme/host/auth.c | 44 ++++++++++++++++++++------------------
>> drivers/nvme/target/auth.c | 37 ++++++++++++++++++--------------
>> include/linux/nvme-auth.h | 4 ++--
>> 4 files changed, 65 insertions(+), 58 deletions(-)
>>
>> diff --git a/drivers/nvme/common/auth.c b/drivers/nvme/common/auth.c
>> index 2d325fb93083..772af9b6dccd 100644
>> --- a/drivers/nvme/common/auth.c
>> +++ b/drivers/nvme/common/auth.c
>> @@ -317,37 +317,37 @@ static int nvme_auth_hash(u8 hmac_id, const u8 *data, size_t data_len, u8 *out)
>> return -EINVAL;
>> }
>>
>> -struct nvme_dhchap_key *nvme_auth_transform_key(
>> - const struct nvme_dhchap_key *key, const char *nqn)
>> +int nvme_auth_transform_key(const struct nvme_dhchap_key *key, const char *nqn,
>> + u8 **transformed_secret)
>> {
>> struct nvme_auth_hmac_ctx hmac;
>> - struct nvme_dhchap_key *transformed_key;
>> - int ret, key_len;
>> + u8 *transformed_data;
>> + u8 *key_data;
>> + size_t transformed_len;
>> + int ret;
>>
>> if (!key) {
>> pr_warn("No key specified\n");
>> - return ERR_PTR(-ENOKEY);
>> + return -ENOKEY;
>> }
>> if (key->hash == 0) {
>> - key_len = nvme_auth_key_struct_size(key->len);
>> - transformed_key = kmemdup(key, key_len, GFP_KERNEL);
>> - if (!transformed_key)
>> - return ERR_PTR(-ENOMEM);
>> - return transformed_key;
>> + key_data = kzalloc(key->len, GFP_KERNEL);
>> + memcpy(key_data, key->key, key->len);
>
> Nit: unchecked kzalloc() return value
>
Will be removed in patch 3 anyway. No point trying to fix it up.
Cheers,
Hannes
--
Dr. Hannes Reinecke Kernel Storage Architect
hare at suse.de +49 911 74053 688
SUSE Software Solutions GmbH, Frankenstr. 146, 90461 Nürnberg
HRB 36809 (AG Nürnberg), GF: I. Totev, A. McDonald, W. Knoblich
More information about the Linux-nvme
mailing list