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
* Software Foundation ; either version 2 of the License , or ( at your option )
* 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>
2005-04-16 15:20:36 -07:00
# include <asm/kmap_types.h>
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
extern enum km_type crypto_km_types [ ] ;
static inline enum km_type crypto_kmap_type ( int out )
{
return crypto_km_types [ ( in_softirq ( ) ? 2 : 0 ) + out ] ;
}
static inline void * crypto_kmap ( struct page * page , int out )
{
return kmap_atomic ( page , crypto_kmap_type ( out ) ) ;
}
static inline void crypto_kunmap ( void * vaddr , int out )
{
kunmap_atomic ( vaddr , crypto_kmap_type ( out ) ) ;
}
2006-07-30 11:53:45 +10:00
static inline void crypto_yield ( u32 flags )
2005-04-16 15:20:36 -07:00
{
2006-07-30 11:53:45 +10:00
if ( flags & CRYPTO_TFM_REQ_MAY_SLEEP )
2005-04-16 15:20:36 -07:00
cond_resched ( ) ;
}
# 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
2005-07-06 13:53:29 -07:00
static inline unsigned int crypto_digest_ctxsize ( struct crypto_alg * alg ,
int flags )
{
2006-07-09 14:49:42 +10:00
unsigned int len = alg - > cra_ctxsize ;
if ( alg - > cra_alignmask ) {
len = ALIGN ( len , ( unsigned long ) alg - > cra_alignmask + 1 ) ;
len + = alg - > cra_digest . dia_digestsize ;
}
return len ;
2005-07-06 13:53:29 -07:00
}
static inline unsigned int crypto_cipher_ctxsize ( struct crypto_alg * alg ,
int flags )
{
unsigned int len = alg - > cra_ctxsize ;
switch ( flags & CRYPTO_TFM_MODE_MASK ) {
case CRYPTO_TFM_MODE_CBC :
2005-07-15 07:41:31 -07:00
len = ALIGN ( len , ( unsigned long ) alg - > cra_alignmask + 1 ) ;
2005-07-06 13:53:29 -07:00
len + = alg - > cra_blocksize ;
break ;
}
return len ;
}
static inline unsigned int crypto_compress_ctxsize ( struct crypto_alg * alg ,
int flags )
{
return alg - > cra_ctxsize ;
}
2006-08-06 21:23:26 +10:00
struct crypto_alg * crypto_mod_get ( struct crypto_alg * alg ) ;
2006-09-21 11:35:17 +10:00
struct crypto_alg * __crypto_alg_lookup ( const char * name , u32 type , u32 mask ) ;
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_digest_flags ( struct crypto_tfm * tfm , u32 flags ) ;
int crypto_init_cipher_flags ( struct crypto_tfm * tfm , u32 flags ) ;
int crypto_init_compress_flags ( struct crypto_tfm * tfm , u32 flags ) ;
int crypto_init_digest_ops ( struct crypto_tfm * tfm ) ;
int crypto_init_cipher_ops ( struct crypto_tfm * tfm ) ;
int crypto_init_compress_ops ( struct crypto_tfm * tfm ) ;
void crypto_exit_digest_ops ( struct crypto_tfm * tfm ) ;
void crypto_exit_cipher_ops ( struct crypto_tfm * tfm ) ;
void crypto_exit_compress_ops ( struct crypto_tfm * tfm ) ;
2006-09-21 11:35:17 +10:00
void crypto_larval_error ( const char * name , u32 type , u32 mask ) ;
2006-08-06 21:23:26 +10:00
2006-09-21 11:39:29 +10:00
void crypto_shoot_alg ( struct crypto_alg * alg ) ;
struct crypto_tfm * __crypto_alloc_tfm ( struct crypto_alg * alg , u32 flags ) ;
2006-08-06 21:16:34 +10:00
int crypto_register_instance ( struct crypto_template * tmpl ,
struct crypto_instance * inst ) ;
2006-08-06 21:23:26 +10:00
int crypto_register_notifier ( struct notifier_block * nb ) ;
int crypto_unregister_notifier ( struct notifier_block * nb ) ;
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 ) ;
}
2006-08-06 21:23:26 +10:00
static inline int crypto_notify ( unsigned long val , void * v )
{
return blocking_notifier_call_chain ( & crypto_chain , val , v ) ;
}
2005-04-16 15:20:36 -07:00
# endif /* _CRYPTO_INTERNAL_H */