2019-05-23 11:14:41 +02:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2008-01-11 09:57:09 -05:00
/* SCTP kernel implementation
2007-10-09 01:15:59 -07:00
* ( C ) Copyright 2007 Hewlett - Packard Development Company , L . P .
*
2008-01-11 09:57:09 -05:00
* This file is part of the SCTP kernel implementation
2007-10-09 01:15:59 -07:00
*
* Please send any bug reports or fixes you make to the
* email address ( es ) :
2013-07-23 14:51:47 +02:00
* lksctp developers < linux - sctp @ vger . kernel . org >
2007-10-09 01:15:59 -07:00
*
* Written or modified by :
* Vlad Yasevich < vladislav . yasevich @ hp . com >
*/
# ifndef __sctp_auth_h__
# define __sctp_auth_h__
# include <linux/list.h>
2017-07-04 15:53:24 +03:00
# include <linux/refcount.h>
2007-10-09 01:15:59 -07:00
struct sctp_endpoint ;
struct sctp_association ;
struct sctp_authkey ;
2007-09-16 19:34:00 -07:00
struct sctp_hmacalgo ;
2016-01-24 21:20:12 +08:00
struct crypto_shash ;
2007-10-09 01:15:59 -07:00
/*
* Define a generic struct that will hold all the info
* necessary for an HMAC transform
*/
struct sctp_hmac {
__u16 hmac_id ; /* one of the above ids */
char * hmac_name ; /* name for loading */
__u16 hmac_len ; /* length of the signature */
} ;
/* This is generic structure that containst authentication bytes used
* as keying material . It ' s a what is referred to as byte - vector all
* over SCTP - AUTH
*/
struct sctp_auth_bytes {
2017-07-04 15:53:24 +03:00
refcount_t refcnt ;
2007-10-09 01:15:59 -07:00
__u32 len ;
__u8 data [ ] ;
} ;
/* Definition for a shared key, weather endpoint or association */
struct sctp_shared_key {
struct list_head key_list ;
struct sctp_auth_bytes * key ;
2018-03-14 19:05:30 +08:00
refcount_t refcnt ;
__u16 key_id ;
2018-03-14 19:05:32 +08:00
__u8 deactivated ;
2007-10-09 01:15:59 -07:00
} ;
# define key_for_each(__key, __list_head) \
list_for_each_entry ( __key , __list_head , key_list )
# define key_for_each_safe(__key, __tmp, __list_head) \
list_for_each_entry_safe ( __key , __tmp , __list_head , key_list )
static inline void sctp_auth_key_hold ( struct sctp_auth_bytes * key )
{
if ( ! key )
return ;
2017-07-04 15:53:24 +03:00
refcount_inc ( & key - > refcnt ) ;
2007-10-09 01:15:59 -07:00
}
void sctp_auth_key_put ( struct sctp_auth_bytes * key ) ;
struct sctp_shared_key * sctp_auth_shkey_create ( __u16 key_id , gfp_t gfp ) ;
void sctp_auth_destroy_keys ( struct list_head * keys ) ;
int sctp_auth_asoc_init_active_key ( struct sctp_association * asoc , gfp_t gfp ) ;
struct sctp_shared_key * sctp_auth_get_shkey (
const struct sctp_association * asoc ,
__u16 key_id ) ;
int sctp_auth_asoc_copy_shkeys ( const struct sctp_endpoint * ep ,
struct sctp_association * asoc ,
gfp_t gfp ) ;
int sctp_auth_init_hmacs ( struct sctp_endpoint * ep , gfp_t gfp ) ;
2016-01-24 21:20:12 +08:00
void sctp_auth_destroy_hmacs ( struct crypto_shash * auth_hmacs [ ] ) ;
2007-10-09 01:15:59 -07:00
struct sctp_hmac * sctp_auth_get_hmac ( __u16 hmac_id ) ;
struct sctp_hmac * sctp_auth_asoc_get_hmac ( const struct sctp_association * asoc ) ;
void sctp_auth_asoc_set_default_hmac ( struct sctp_association * asoc ,
struct sctp_hmac_algo_param * hmacs ) ;
int sctp_auth_asoc_verify_hmac_id ( const struct sctp_association * asoc ,
2007-10-29 05:03:23 +00:00
__be16 hmac_id ) ;
2017-06-30 11:52:14 +08:00
int sctp_auth_send_cid ( enum sctp_cid chunk ,
const struct sctp_association * asoc ) ;
int sctp_auth_recv_cid ( enum sctp_cid chunk ,
const struct sctp_association * asoc ) ;
2007-10-09 01:15:59 -07:00
void sctp_auth_calculate_hmac ( const struct sctp_association * asoc ,
2018-03-14 19:05:30 +08:00
struct sk_buff * skb , struct sctp_auth_chunk * auth ,
struct sctp_shared_key * ep_key , gfp_t gfp ) ;
void sctp_auth_shkey_release ( struct sctp_shared_key * sh_key ) ;
void sctp_auth_shkey_hold ( struct sctp_shared_key * sh_key ) ;
2007-09-16 19:34:00 -07:00
/* API Helpers */
int sctp_auth_ep_add_chunkid ( struct sctp_endpoint * ep , __u8 chunk_id ) ;
int sctp_auth_ep_set_hmacs ( struct sctp_endpoint * ep ,
struct sctp_hmacalgo * hmacs ) ;
2018-03-14 19:05:32 +08:00
int sctp_auth_set_key ( struct sctp_endpoint * ep , struct sctp_association * asoc ,
2007-09-16 19:34:00 -07:00
struct sctp_authkey * auth_key ) ;
int sctp_auth_set_active_key ( struct sctp_endpoint * ep ,
2018-03-14 19:05:32 +08:00
struct sctp_association * asoc , __u16 key_id ) ;
2007-09-16 19:34:00 -07:00
int sctp_auth_del_key_id ( struct sctp_endpoint * ep ,
2018-03-14 19:05:32 +08:00
struct sctp_association * asoc , __u16 key_id ) ;
int sctp_auth_deact_key_id ( struct sctp_endpoint * ep ,
struct sctp_association * asoc , __u16 key_id ) ;
2019-08-19 22:02:48 +08:00
int sctp_auth_init ( struct sctp_endpoint * ep , gfp_t gfp ) ;
void sctp_auth_free ( struct sctp_endpoint * ep ) ;
2007-09-16 19:34:00 -07:00
2007-10-09 01:15:59 -07:00
# endif