On Tue, 2014-06-17 at 11:56 +0300, Dmitry Kasatkin wrote: 
> Key id matching will also be used in the following patch.
> To avoid code duplication this patch moves functionality
> to a separate function.
> 
> Signed-off-by: Dmitry Kasatkin <d.kasat...@samsung.com>

In refactoring asymmetric_key_match(), its changed.  The reason for this
change should be included in the patch description.  (Bug fixes should
be documented.)

thanks,

Mimi

> ---
>  crypto/asymmetric_keys/asymmetric_keys.h |  2 ++
>  crypto/asymmetric_keys/asymmetric_type.c | 50 
> ++++++++++++++++++++------------
>  2 files changed, 33 insertions(+), 19 deletions(-)
> 
> diff --git a/crypto/asymmetric_keys/asymmetric_keys.h 
> b/crypto/asymmetric_keys/asymmetric_keys.h
> index 515b634..a63c551 100644
> --- a/crypto/asymmetric_keys/asymmetric_keys.h
> +++ b/crypto/asymmetric_keys/asymmetric_keys.h
> @@ -9,6 +9,8 @@
>   * 2 of the Licence, or (at your option) any later version.
>   */
> 
> +int asymmetric_keyid_match(const char *kid, const char *id);
> +
>  static inline const char *asymmetric_key_id(const struct key *key)
>  {
>       return key->type_data.p[1];
> diff --git a/crypto/asymmetric_keys/asymmetric_type.c 
> b/crypto/asymmetric_keys/asymmetric_type.c
> index b77eb53..1fd1d30 100644
> --- a/crypto/asymmetric_keys/asymmetric_type.c
> +++ b/crypto/asymmetric_keys/asymmetric_type.c
> @@ -23,6 +23,34 @@ static LIST_HEAD(asymmetric_key_parsers);
>  static DECLARE_RWSEM(asymmetric_key_parsers_sem);
> 
>  /*
> + * Match asymmetric key id with partial match
> + * @id:              key id to match in a form "id:<id>"
> + */
> +int asymmetric_keyid_match(const char *kid, const char *id)
> +{
> +     size_t idlen, kidlen;
> +
> +     if (!kid || !id)
> +             return 0;
> +
> +     /* make it possible to use id as in the request: "id:<id>" */
> +     if (strncmp(id, "id:", 3) == 0)
> +             id += 3;
> +
> +     /* Anything after here requires a partial match on the ID string */
> +     idlen = strlen(id);
> +     kidlen = strlen(kid);
> +     if (idlen > kidlen)
> +             return 0;
> +
> +     kid += kidlen - idlen;
> +     if (strcasecmp(id, kid) != 0)
> +             return 0;
> +
> +     return 1;
> +}
> +
> +/*
>   * Match asymmetric keys on (part of) their name
>   * We have some shorthand methods for matching keys.  We allow:
>   *
> @@ -34,9 +62,8 @@ static int asymmetric_key_match(const struct key *key, 
> const void *description)
>  {
>       const struct asymmetric_key_subtype *subtype = 
> asymmetric_key_subtype(key);
>       const char *spec = description;
> -     const char *id, *kid;
> +     const char *id;
>       ptrdiff_t speclen;
> -     size_t idlen, kidlen;
> 
>       if (!subtype || !spec || !*spec)
>               return 0;
> @@ -55,23 +82,8 @@ static int asymmetric_key_match(const struct key *key, 
> const void *description)
>       speclen = id - spec;
>       id++;
> 
> -     /* Anything after here requires a partial match on the ID string */
> -     kid = asymmetric_key_id(key);
> -     if (!kid)
> -             return 0;
> -
> -     idlen = strlen(id);
> -     kidlen = strlen(kid);
> -     if (idlen > kidlen)
> -             return 0;
> -
> -     kid += kidlen - idlen;
> -     if (strcasecmp(id, kid) != 0)
> -             return 0;
> -
> -     if (speclen == 2 &&
> -         memcmp(spec, "id", 2) == 0)
> -             return 1;
> +     if (speclen == 2 && memcmp(spec, "id", 2) == 0)
> +             return asymmetric_keyid_match(asymmetric_key_id(key), id);
> 
>       if (speclen == subtype->name_len &&
>           memcmp(spec, subtype->name, speclen) == 0)


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to