#include <crypto/algapi.h>
#include <crypto/internal/simd.h>
#include <linux/err.h>
#include <linux/errno.h>
#include <linux/fips.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/list.h>
#include <linux/module.h>
#include <linux/rtnetlink.h>
#include <linux/slab.h>
#include <linux/string.h>
#include <linux/workqueue.h>
#include "internal.h"
static LIST_HEAD(crypto_template_list);
#ifdef CONFIG_CRYPTO_MANAGER_EXTRA_TESTS
DEFINE_PER_CPU(bool, crypto_simd_disabled_for_test);
EXPORT_PER_CPU_SYMBOL_GPL(crypto_simd_disabled_for_test);
#endif
static inline void crypto_check_module_sig(struct module *mod)
{ … }
static int crypto_check_alg(struct crypto_alg *alg)
{ … }
static void crypto_free_instance(struct crypto_instance *inst)
{ … }
static void crypto_destroy_instance_workfn(struct work_struct *w)
{ … }
static void crypto_destroy_instance(struct crypto_alg *alg)
{ … }
static struct list_head *crypto_more_spawns(struct crypto_alg *alg,
struct list_head *stack,
struct list_head *top,
struct list_head *secondary_spawns)
{ … }
static void crypto_remove_instance(struct crypto_instance *inst,
struct list_head *list)
{ … }
void crypto_remove_spawns(struct crypto_alg *alg, struct list_head *list,
struct crypto_alg *nalg)
{ … }
EXPORT_SYMBOL_GPL(…);
static void crypto_alg_finish_registration(struct crypto_alg *alg,
struct list_head *algs_to_put)
{ … }
static struct crypto_larval *crypto_alloc_test_larval(struct crypto_alg *alg)
{ … }
static struct crypto_larval *
__crypto_register_alg(struct crypto_alg *alg, struct list_head *algs_to_put)
{ … }
void crypto_alg_tested(const char *name, int err)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_remove_final(struct list_head *list)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_register_alg(struct crypto_alg *alg)
{ … }
EXPORT_SYMBOL_GPL(…);
static int crypto_remove_alg(struct crypto_alg *alg, struct list_head *list)
{ … }
void crypto_unregister_alg(struct crypto_alg *alg)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_register_algs(struct crypto_alg *algs, int count)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_unregister_algs(struct crypto_alg *algs, int count)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_register_template(struct crypto_template *tmpl)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_register_templates(struct crypto_template *tmpls, int count)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_unregister_template(struct crypto_template *tmpl)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_unregister_templates(struct crypto_template *tmpls, int count)
{ … }
EXPORT_SYMBOL_GPL(…);
static struct crypto_template *__crypto_lookup_template(const char *name)
{ … }
struct crypto_template *crypto_lookup_template(const char *name)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_register_instance(struct crypto_template *tmpl,
struct crypto_instance *inst)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_unregister_instance(struct crypto_instance *inst)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_grab_spawn(struct crypto_spawn *spawn, struct crypto_instance *inst,
const char *name, u32 type, u32 mask)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_drop_spawn(struct crypto_spawn *spawn)
{ … }
EXPORT_SYMBOL_GPL(…);
static struct crypto_alg *crypto_spawn_alg(struct crypto_spawn *spawn)
{ … }
struct crypto_tfm *crypto_spawn_tfm(struct crypto_spawn *spawn, u32 type,
u32 mask)
{ … }
EXPORT_SYMBOL_GPL(…);
void *crypto_spawn_tfm2(struct crypto_spawn *spawn)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_register_notifier(struct notifier_block *nb)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_unregister_notifier(struct notifier_block *nb)
{ … }
EXPORT_SYMBOL_GPL(…);
struct crypto_attr_type *crypto_get_attr_type(struct rtattr **tb)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_check_attr_type(struct rtattr **tb, u32 type, u32 *mask_ret)
{ … }
EXPORT_SYMBOL_GPL(…);
const char *crypto_attr_alg_name(struct rtattr *rta)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_inst_setname(struct crypto_instance *inst, const char *name,
struct crypto_alg *alg)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_init_queue(struct crypto_queue *queue, unsigned int max_qlen)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_enqueue_request(struct crypto_queue *queue,
struct crypto_async_request *request)
{ … }
EXPORT_SYMBOL_GPL(…);
void crypto_enqueue_request_head(struct crypto_queue *queue,
struct crypto_async_request *request)
{ … }
EXPORT_SYMBOL_GPL(…);
struct crypto_async_request *crypto_dequeue_request(struct crypto_queue *queue)
{ … }
EXPORT_SYMBOL_GPL(…);
static inline void crypto_inc_byte(u8 *a, unsigned int size)
{ … }
void crypto_inc(u8 *a, unsigned int size)
{ … }
EXPORT_SYMBOL_GPL(…);
unsigned int crypto_alg_extsize(struct crypto_alg *alg)
{ … }
EXPORT_SYMBOL_GPL(…);
int crypto_type_has_alg(const char *name, const struct crypto_type *frontend,
u32 type, u32 mask)
{ … }
EXPORT_SYMBOL_GPL(…);
static void __init crypto_start_tests(void)
{ … }
static int __init crypto_algapi_init(void)
{ … }
static void __exit crypto_algapi_exit(void)
{ … }
late_initcall(crypto_algapi_init);
module_exit(crypto_algapi_exit);
MODULE_LICENSE(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_SOFTDEP(…) …;