2005-04-16 15:20:36 -07:00
/*
* Cryptographic API .
*
* Copyright ( c ) 2002 James Morris < jmorris @ intercode . com . au >
2005-11-05 16:58:14 +11:00
* Copyright ( c ) 2005 Herbert Xu < herbert @ gondor . apana . org . au >
2005-04-16 15:20:36 -07:00
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License as published by the Free
2010-03-10 18:24:46 +08:00
* Software Foundation ; either version 2 of the License , or ( at your option )
2005-04-16 15:20:36 -07:00
* any later version .
*
*/
# ifndef _CRYPTO_INTERNAL_H
# define _CRYPTO_INTERNAL_H
2006-08-21 21:08:13 +10:00
# include <crypto/algapi.h>
2006-08-06 21:23:26 +10:00
# include <linux/completion.h>
2005-04-16 15:20:36 -07:00
# include <linux/mm.h>
# include <linux/highmem.h>
# include <linux/interrupt.h>
# include <linux/init.h>
2005-11-05 16:58:14 +11:00
# include <linux/list.h>
2006-08-06 21:16:34 +10:00
# include <linux/module.h>
2005-07-06 13:53:29 -07:00
# include <linux/kernel.h>
2006-08-06 21:23:26 +10:00
# include <linux/notifier.h>
2005-11-05 16:58:14 +11:00
# include <linux/rwsem.h>
2005-09-01 17:43:05 -07:00
# include <linux/slab.h>
2009-06-18 19:50:21 +08:00
# include <linux/fips.h>
2008-08-05 14:13:08 +08:00
2006-08-06 21:23:26 +10:00
/* Crypto notification events. */
enum {
CRYPTO_MSG_ALG_REQUEST ,
CRYPTO_MSG_ALG_REGISTER ,
CRYPTO_MSG_ALG_UNREGISTER ,
CRYPTO_MSG_TMPL_REGISTER ,
CRYPTO_MSG_TMPL_UNREGISTER ,
} ;
2006-08-06 21:16:34 +10:00
struct crypto_instance ;
struct crypto_template ;
2006-08-06 21:23:26 +10:00
struct crypto_larval {
struct crypto_alg alg ;
struct crypto_alg * adult ;
struct completion completion ;
2006-09-21 11:35:17 +10:00
u32 mask ;
2006-08-06 21:23:26 +10:00
} ;
2005-11-05 16:58:14 +11:00
extern struct list_head crypto_alg_list ;
extern struct rw_semaphore crypto_alg_sem ;
2006-08-06 21:23:26 +10:00
extern struct blocking_notifier_head crypto_chain ;
2005-11-05 16:58:14 +11:00
2005-04-16 15:20:36 -07:00
# ifdef CONFIG_PROC_FS
void __init crypto_init_proc ( void ) ;
2006-08-21 21:08:13 +10:00
void __exit crypto_exit_proc ( void ) ;
2005-04-16 15:20:36 -07:00
# else
static inline void crypto_init_proc ( void )
{ }
2006-08-21 21:08:13 +10:00
static inline void crypto_exit_proc ( void )
{ }
2005-04-16 15:20:36 -07:00
# endif
2007-01-27 10:05:15 +11:00
static inline unsigned int crypto_cipher_ctxsize ( struct crypto_alg * alg )
2005-07-06 13:53:29 -07:00
{
2007-01-27 10:05:15 +11:00
return alg - > cra_ctxsize ;
2005-07-06 13:53:29 -07:00
}
2007-01-27 10:05:15 +11:00
static inline unsigned int crypto_compress_ctxsize ( struct crypto_alg * alg )
2005-07-06 13:53:29 -07:00
{
return alg - > cra_ctxsize ;
}
2006-08-06 21:23:26 +10:00
struct crypto_alg * crypto_mod_get ( struct crypto_alg * alg ) ;
2008-08-04 11:44:59 +08:00
struct crypto_alg * crypto_alg_lookup ( const char * name , u32 type , u32 mask ) ;
2006-09-21 11:35:17 +10:00
struct crypto_alg * crypto_alg_mod_lookup ( const char * name , u32 type , u32 mask ) ;
2006-08-06 21:23:26 +10:00
2005-04-16 15:20:36 -07:00
int crypto_init_cipher_ops ( struct crypto_tfm * tfm ) ;
int crypto_init_compress_ops ( struct crypto_tfm * tfm ) ;
void crypto_exit_cipher_ops ( struct crypto_tfm * tfm ) ;
void crypto_exit_compress_ops ( struct crypto_tfm * tfm ) ;
2008-08-03 21:15:23 +08:00
struct crypto_larval * crypto_larval_alloc ( const char * name , u32 type , u32 mask ) ;
2007-12-04 12:46:48 +11:00
void crypto_larval_kill ( struct crypto_alg * alg ) ;
struct crypto_alg * crypto_larval_lookup ( const char * name , u32 type , u32 mask ) ;
2006-09-21 11:35:17 +10:00
void crypto_larval_error ( const char * name , u32 type , u32 mask ) ;
2008-08-03 21:15:23 +08:00
void crypto_alg_tested ( const char * name , int err ) ;
2006-08-06 21:23:26 +10:00
2011-09-27 07:22:08 +02:00
void crypto_remove_spawns ( struct crypto_alg * alg , struct list_head * list ,
struct crypto_alg * nalg ) ;
2011-09-27 07:23:07 +02:00
void crypto_remove_final ( struct list_head * list ) ;
2006-09-21 11:39:29 +10:00
void crypto_shoot_alg ( struct crypto_alg * alg ) ;
2007-01-24 20:50:26 +11:00
struct crypto_tfm * __crypto_alloc_tfm ( struct crypto_alg * alg , u32 type ,
u32 mask ) ;
2009-02-18 16:56:59 +08:00
void * crypto_create_tfm ( struct crypto_alg * alg ,
const struct crypto_type * frontend ) ;
2009-07-08 17:53:16 +08:00
struct crypto_alg * crypto_find_alg ( const char * alg_name ,
const struct crypto_type * frontend ,
u32 type , u32 mask ) ;
2009-02-18 16:56:59 +08:00
void * crypto_alloc_tfm ( const char * alg_name ,
const struct crypto_type * frontend , u32 type , u32 mask ) ;
2006-08-06 21:16:34 +10:00
2006-08-06 21:23:26 +10:00
int crypto_register_notifier ( struct notifier_block * nb ) ;
int crypto_unregister_notifier ( struct notifier_block * nb ) ;
2008-08-03 21:15:23 +08:00
int crypto_probing_notify ( unsigned long val , void * v ) ;
2006-08-06 21:23:26 +10:00
2006-09-21 11:39:29 +10:00
static inline void crypto_alg_put ( struct crypto_alg * alg )
{
if ( atomic_dec_and_test ( & alg - > cra_refcnt ) & & alg - > cra_destroy )
alg - > cra_destroy ( alg ) ;
}
2006-08-06 21:16:34 +10:00
static inline int crypto_tmpl_get ( struct crypto_template * tmpl )
{
return try_module_get ( tmpl - > module ) ;
}
static inline void crypto_tmpl_put ( struct crypto_template * tmpl )
{
module_put ( tmpl - > module ) ;
}
2006-08-06 21:23:26 +10:00
static inline int crypto_is_larval ( struct crypto_alg * alg )
{
return alg - > cra_flags & CRYPTO_ALG_LARVAL ;
}
2006-09-21 11:39:29 +10:00
static inline int crypto_is_dead ( struct crypto_alg * alg )
{
return alg - > cra_flags & CRYPTO_ALG_DEAD ;
}
static inline int crypto_is_moribund ( struct crypto_alg * alg )
{
return alg - > cra_flags & ( CRYPTO_ALG_DEAD | CRYPTO_ALG_DYING ) ;
}
2008-08-03 21:15:23 +08:00
static inline void crypto_notify ( unsigned long val , void * v )
2006-08-06 21:23:26 +10:00
{
2008-08-03 21:15:23 +08:00
blocking_notifier_call_chain ( & crypto_chain , val , v ) ;
2006-08-06 21:23:26 +10:00
}
2005-04-16 15:20:36 -07:00
# endif /* _CRYPTO_INTERNAL_H */