Commit 5821c769 authored by Herbert Xu's avatar Herbert Xu

sctp: Use shash

This patch replaces uses of the long obsolete hash interface with
shash.
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
Acked-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1edb82d2
...@@ -31,12 +31,12 @@ ...@@ -31,12 +31,12 @@
#define __sctp_auth_h__ #define __sctp_auth_h__
#include <linux/list.h> #include <linux/list.h>
#include <linux/crypto.h>
struct sctp_endpoint; struct sctp_endpoint;
struct sctp_association; struct sctp_association;
struct sctp_authkey; struct sctp_authkey;
struct sctp_hmacalgo; struct sctp_hmacalgo;
struct crypto_shash;
/* /*
* Define a generic struct that will hold all the info * Define a generic struct that will hold all the info
...@@ -90,7 +90,7 @@ int sctp_auth_asoc_copy_shkeys(const struct sctp_endpoint *ep, ...@@ -90,7 +90,7 @@ int sctp_auth_asoc_copy_shkeys(const struct sctp_endpoint *ep,
struct sctp_association *asoc, struct sctp_association *asoc,
gfp_t gfp); gfp_t gfp);
int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp); int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp);
void sctp_auth_destroy_hmacs(struct crypto_hash *auth_hmacs[]); void sctp_auth_destroy_hmacs(struct crypto_shash *auth_hmacs[]);
struct sctp_hmac *sctp_auth_get_hmac(__u16 hmac_id); struct sctp_hmac *sctp_auth_get_hmac(__u16 hmac_id);
struct sctp_hmac *sctp_auth_asoc_get_hmac(const struct sctp_association *asoc); struct sctp_hmac *sctp_auth_asoc_get_hmac(const struct sctp_association *asoc);
void sctp_auth_asoc_set_default_hmac(struct sctp_association *asoc, void sctp_auth_asoc_set_default_hmac(struct sctp_association *asoc,
......
...@@ -82,7 +82,7 @@ struct sctp_bind_addr; ...@@ -82,7 +82,7 @@ struct sctp_bind_addr;
struct sctp_ulpq; struct sctp_ulpq;
struct sctp_ep_common; struct sctp_ep_common;
struct sctp_ssnmap; struct sctp_ssnmap;
struct crypto_hash; struct crypto_shash;
#include <net/sctp/tsnmap.h> #include <net/sctp/tsnmap.h>
...@@ -166,7 +166,7 @@ struct sctp_sock { ...@@ -166,7 +166,7 @@ struct sctp_sock {
struct sctp_pf *pf; struct sctp_pf *pf;
/* Access to HMAC transform. */ /* Access to HMAC transform. */
struct crypto_hash *hmac; struct crypto_shash *hmac;
char *sctp_hmac_alg; char *sctp_hmac_alg;
/* What is our base endpointer? */ /* What is our base endpointer? */
...@@ -1235,7 +1235,7 @@ struct sctp_endpoint { ...@@ -1235,7 +1235,7 @@ struct sctp_endpoint {
/* SCTP AUTH: array of the HMACs that will be allocated /* SCTP AUTH: array of the HMACs that will be allocated
* we need this per association so that we don't serialize * we need this per association so that we don't serialize
*/ */
struct crypto_hash **auth_hmacs; struct crypto_shash **auth_hmacs;
/* SCTP-AUTH: hmacs for the endpoint encoded into parameter */ /* SCTP-AUTH: hmacs for the endpoint encoded into parameter */
struct sctp_hmac_algo_param *auth_hmacs_list; struct sctp_hmac_algo_param *auth_hmacs_list;
......
...@@ -27,9 +27,9 @@ ...@@ -27,9 +27,9 @@
* Vlad Yasevich <vladislav.yasevich@hp.com> * Vlad Yasevich <vladislav.yasevich@hp.com>
*/ */
#include <crypto/hash.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/crypto.h>
#include <linux/scatterlist.h> #include <linux/scatterlist.h>
#include <net/sctp/sctp.h> #include <net/sctp/sctp.h>
#include <net/sctp/auth.h> #include <net/sctp/auth.h>
...@@ -448,7 +448,7 @@ struct sctp_shared_key *sctp_auth_get_shkey( ...@@ -448,7 +448,7 @@ struct sctp_shared_key *sctp_auth_get_shkey(
*/ */
int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp) int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp)
{ {
struct crypto_hash *tfm = NULL; struct crypto_shash *tfm = NULL;
__u16 id; __u16 id;
/* If AUTH extension is disabled, we are done */ /* If AUTH extension is disabled, we are done */
...@@ -462,9 +462,8 @@ int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp) ...@@ -462,9 +462,8 @@ int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp)
return 0; return 0;
/* Allocated the array of pointers to transorms */ /* Allocated the array of pointers to transorms */
ep->auth_hmacs = kzalloc( ep->auth_hmacs = kzalloc(sizeof(struct crypto_shash *) *
sizeof(struct crypto_hash *) * SCTP_AUTH_NUM_HMACS, SCTP_AUTH_NUM_HMACS, gfp);
gfp);
if (!ep->auth_hmacs) if (!ep->auth_hmacs)
return -ENOMEM; return -ENOMEM;
...@@ -483,8 +482,7 @@ int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp) ...@@ -483,8 +482,7 @@ int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp)
continue; continue;
/* Allocate the ID */ /* Allocate the ID */
tfm = crypto_alloc_hash(sctp_hmac_list[id].hmac_name, 0, tfm = crypto_alloc_shash(sctp_hmac_list[id].hmac_name, 0, 0);
CRYPTO_ALG_ASYNC);
if (IS_ERR(tfm)) if (IS_ERR(tfm))
goto out_err; goto out_err;
...@@ -500,7 +498,7 @@ int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp) ...@@ -500,7 +498,7 @@ int sctp_auth_init_hmacs(struct sctp_endpoint *ep, gfp_t gfp)
} }
/* Destroy the hmac tfm array */ /* Destroy the hmac tfm array */
void sctp_auth_destroy_hmacs(struct crypto_hash *auth_hmacs[]) void sctp_auth_destroy_hmacs(struct crypto_shash *auth_hmacs[])
{ {
int i; int i;
...@@ -508,8 +506,7 @@ void sctp_auth_destroy_hmacs(struct crypto_hash *auth_hmacs[]) ...@@ -508,8 +506,7 @@ void sctp_auth_destroy_hmacs(struct crypto_hash *auth_hmacs[])
return; return;
for (i = 0; i < SCTP_AUTH_NUM_HMACS; i++) { for (i = 0; i < SCTP_AUTH_NUM_HMACS; i++) {
if (auth_hmacs[i]) crypto_free_shash(auth_hmacs[i]);
crypto_free_hash(auth_hmacs[i]);
} }
kfree(auth_hmacs); kfree(auth_hmacs);
} }
...@@ -709,8 +706,7 @@ void sctp_auth_calculate_hmac(const struct sctp_association *asoc, ...@@ -709,8 +706,7 @@ void sctp_auth_calculate_hmac(const struct sctp_association *asoc,
struct sctp_auth_chunk *auth, struct sctp_auth_chunk *auth,
gfp_t gfp) gfp_t gfp)
{ {
struct scatterlist sg; struct crypto_shash *tfm;
struct hash_desc desc;
struct sctp_auth_bytes *asoc_key; struct sctp_auth_bytes *asoc_key;
__u16 key_id, hmac_id; __u16 key_id, hmac_id;
__u8 *digest; __u8 *digest;
...@@ -742,16 +738,22 @@ void sctp_auth_calculate_hmac(const struct sctp_association *asoc, ...@@ -742,16 +738,22 @@ void sctp_auth_calculate_hmac(const struct sctp_association *asoc,
/* set up scatter list */ /* set up scatter list */
end = skb_tail_pointer(skb); end = skb_tail_pointer(skb);
sg_init_one(&sg, auth, end - (unsigned char *)auth);
desc.tfm = asoc->ep->auth_hmacs[hmac_id]; tfm = asoc->ep->auth_hmacs[hmac_id];
desc.flags = 0;
digest = auth->auth_hdr.hmac; digest = auth->auth_hdr.hmac;
if (crypto_hash_setkey(desc.tfm, &asoc_key->data[0], asoc_key->len)) if (crypto_shash_setkey(tfm, &asoc_key->data[0], asoc_key->len))
goto free; goto free;
crypto_hash_digest(&desc, &sg, sg.length, digest); {
SHASH_DESC_ON_STACK(desc, tfm);
desc->tfm = tfm;
desc->flags = 0;
crypto_shash_digest(desc, (u8 *)auth,
end - (unsigned char *)auth, digest);
shash_desc_zero(desc);
}
free: free:
if (free_key) if (free_key)
......
...@@ -42,7 +42,6 @@ ...@@ -42,7 +42,6 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/in.h> #include <linux/in.h>
#include <linux/random.h> /* get_random_bytes() */ #include <linux/random.h> /* get_random_bytes() */
#include <linux/crypto.h>
#include <net/sock.h> #include <net/sock.h>
#include <net/ipv6.h> #include <net/ipv6.h>
#include <net/sctp/sctp.h> #include <net/sctp/sctp.h>
......
...@@ -45,6 +45,7 @@ ...@@ -45,6 +45,7 @@
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
#include <crypto/hash.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/ip.h> #include <linux/ip.h>
...@@ -52,7 +53,6 @@ ...@@ -52,7 +53,6 @@
#include <linux/net.h> #include <linux/net.h>
#include <linux/inet.h> #include <linux/inet.h>
#include <linux/scatterlist.h> #include <linux/scatterlist.h>
#include <linux/crypto.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <net/sock.h> #include <net/sock.h>
...@@ -1606,7 +1606,6 @@ static sctp_cookie_param_t *sctp_pack_cookie(const struct sctp_endpoint *ep, ...@@ -1606,7 +1606,6 @@ static sctp_cookie_param_t *sctp_pack_cookie(const struct sctp_endpoint *ep,
{ {
sctp_cookie_param_t *retval; sctp_cookie_param_t *retval;
struct sctp_signed_cookie *cookie; struct sctp_signed_cookie *cookie;
struct scatterlist sg;
int headersize, bodysize; int headersize, bodysize;
/* Header size is static data prior to the actual cookie, including /* Header size is static data prior to the actual cookie, including
...@@ -1663,16 +1662,19 @@ static sctp_cookie_param_t *sctp_pack_cookie(const struct sctp_endpoint *ep, ...@@ -1663,16 +1662,19 @@ static sctp_cookie_param_t *sctp_pack_cookie(const struct sctp_endpoint *ep,
ntohs(init_chunk->chunk_hdr->length), raw_addrs, addrs_len); ntohs(init_chunk->chunk_hdr->length), raw_addrs, addrs_len);
if (sctp_sk(ep->base.sk)->hmac) { if (sctp_sk(ep->base.sk)->hmac) {
struct hash_desc desc; SHASH_DESC_ON_STACK(desc, sctp_sk(ep->base.sk)->hmac);
int err;
/* Sign the message. */ /* Sign the message. */
sg_init_one(&sg, &cookie->c, bodysize); desc->tfm = sctp_sk(ep->base.sk)->hmac;
desc.tfm = sctp_sk(ep->base.sk)->hmac; desc->flags = 0;
desc.flags = 0;
err = crypto_shash_setkey(desc->tfm, ep->secret_key,
if (crypto_hash_setkey(desc.tfm, ep->secret_key, sizeof(ep->secret_key)) ?:
sizeof(ep->secret_key)) || crypto_shash_digest(desc, (u8 *)&cookie->c, bodysize,
crypto_hash_digest(&desc, &sg, bodysize, cookie->signature)) cookie->signature);
shash_desc_zero(desc);
if (err)
goto free_cookie; goto free_cookie;
} }
...@@ -1697,12 +1699,10 @@ struct sctp_association *sctp_unpack_cookie( ...@@ -1697,12 +1699,10 @@ struct sctp_association *sctp_unpack_cookie(
struct sctp_cookie *bear_cookie; struct sctp_cookie *bear_cookie;
int headersize, bodysize, fixed_size; int headersize, bodysize, fixed_size;
__u8 *digest = ep->digest; __u8 *digest = ep->digest;
struct scatterlist sg;
unsigned int len; unsigned int len;
sctp_scope_t scope; sctp_scope_t scope;
struct sk_buff *skb = chunk->skb; struct sk_buff *skb = chunk->skb;
ktime_t kt; ktime_t kt;
struct hash_desc desc;
/* Header size is static data prior to the actual cookie, including /* Header size is static data prior to the actual cookie, including
* any padding. * any padding.
...@@ -1733,17 +1733,24 @@ struct sctp_association *sctp_unpack_cookie( ...@@ -1733,17 +1733,24 @@ struct sctp_association *sctp_unpack_cookie(
goto no_hmac; goto no_hmac;
/* Check the signature. */ /* Check the signature. */
sg_init_one(&sg, bear_cookie, bodysize); {
desc.tfm = sctp_sk(ep->base.sk)->hmac; SHASH_DESC_ON_STACK(desc, sctp_sk(ep->base.sk)->hmac);
desc.flags = 0; int err;
memset(digest, 0x00, SCTP_SIGNATURE_SIZE); desc->tfm = sctp_sk(ep->base.sk)->hmac;
if (crypto_hash_setkey(desc.tfm, ep->secret_key, desc->flags = 0;
sizeof(ep->secret_key)) ||
crypto_hash_digest(&desc, &sg, bodysize, digest)) { err = crypto_shash_setkey(desc->tfm, ep->secret_key,
sizeof(ep->secret_key)) ?:
crypto_shash_digest(desc, (u8 *)bear_cookie, bodysize,
digest);
shash_desc_zero(desc);
if (err) {
*error = -SCTP_IERROR_NOMEM; *error = -SCTP_IERROR_NOMEM;
goto fail; goto fail;
} }
}
if (memcmp(digest, cookie->signature, SCTP_SIGNATURE_SIZE)) { if (memcmp(digest, cookie->signature, SCTP_SIGNATURE_SIZE)) {
*error = -SCTP_IERROR_BAD_SIG; *error = -SCTP_IERROR_BAD_SIG;
......
...@@ -52,6 +52,7 @@ ...@@ -52,6 +52,7 @@
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
#include <crypto/hash.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/wait.h> #include <linux/wait.h>
...@@ -61,7 +62,6 @@ ...@@ -61,7 +62,6 @@
#include <linux/fcntl.h> #include <linux/fcntl.h>
#include <linux/poll.h> #include <linux/poll.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/crypto.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/file.h> #include <linux/file.h>
#include <linux/compat.h> #include <linux/compat.h>
...@@ -4160,7 +4160,7 @@ static void sctp_destruct_sock(struct sock *sk) ...@@ -4160,7 +4160,7 @@ static void sctp_destruct_sock(struct sock *sk)
struct sctp_sock *sp = sctp_sk(sk); struct sctp_sock *sp = sctp_sk(sk);
/* Free up the HMAC transform. */ /* Free up the HMAC transform. */
crypto_free_hash(sp->hmac); crypto_free_shash(sp->hmac);
inet_sock_destruct(sk); inet_sock_destruct(sk);
} }
...@@ -6299,13 +6299,13 @@ static int sctp_listen_start(struct sock *sk, int backlog) ...@@ -6299,13 +6299,13 @@ static int sctp_listen_start(struct sock *sk, int backlog)
{ {
struct sctp_sock *sp = sctp_sk(sk); struct sctp_sock *sp = sctp_sk(sk);
struct sctp_endpoint *ep = sp->ep; struct sctp_endpoint *ep = sp->ep;
struct crypto_hash *tfm = NULL; struct crypto_shash *tfm = NULL;
char alg[32]; char alg[32];
/* Allocate HMAC for generating cookie. */ /* Allocate HMAC for generating cookie. */
if (!sp->hmac && sp->sctp_hmac_alg) { if (!sp->hmac && sp->sctp_hmac_alg) {
sprintf(alg, "hmac(%s)", sp->sctp_hmac_alg); sprintf(alg, "hmac(%s)", sp->sctp_hmac_alg);
tfm = crypto_alloc_hash(alg, 0, CRYPTO_ALG_ASYNC); tfm = crypto_alloc_shash(alg, 0, 0);
if (IS_ERR(tfm)) { if (IS_ERR(tfm)) {
net_info_ratelimited("failed to load transform for %s: %ld\n", net_info_ratelimited("failed to load transform for %s: %ld\n",
sp->sctp_hmac_alg, PTR_ERR(tfm)); sp->sctp_hmac_alg, PTR_ERR(tfm));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment