| Herbert Xu | 03c8efc | 2010-10-19 21:12:39 +0800 | [diff] [blame] | 1 | /* | 
|  | 2 | * if_alg: User-space algorithm interface | 
|  | 3 | * | 
|  | 4 | * Copyright (c) 2010 Herbert Xu <herbert@gondor.apana.org.au> | 
|  | 5 | * | 
|  | 6 | * This program is free software; you can redistribute it and/or modify it | 
|  | 7 | * under the terms of the GNU General Public License as published by the Free | 
|  | 8 | * Software Foundation; either version 2 of the License, or (at your option) | 
|  | 9 | * any later version. | 
|  | 10 | * | 
|  | 11 | */ | 
|  | 12 |  | 
|  | 13 | #ifndef _CRYPTO_IF_ALG_H | 
|  | 14 | #define _CRYPTO_IF_ALG_H | 
|  | 15 |  | 
|  | 16 | #include <linux/compiler.h> | 
|  | 17 | #include <linux/completion.h> | 
|  | 18 | #include <linux/if_alg.h> | 
| Alexey Dobriyan | b7f080c | 2011-06-16 11:01:34 +0000 | [diff] [blame] | 19 | #include <linux/scatterlist.h> | 
| Herbert Xu | 03c8efc | 2010-10-19 21:12:39 +0800 | [diff] [blame] | 20 | #include <linux/types.h> | 
|  | 21 | #include <net/sock.h> | 
|  | 22 |  | 
|  | 23 | #define ALG_MAX_PAGES			16 | 
|  | 24 |  | 
|  | 25 | struct crypto_async_request; | 
|  | 26 |  | 
|  | 27 | struct alg_sock { | 
|  | 28 | /* struct sock must be the first member of struct alg_sock */ | 
|  | 29 | struct sock sk; | 
|  | 30 |  | 
|  | 31 | struct sock *parent; | 
|  | 32 |  | 
|  | 33 | const struct af_alg_type *type; | 
|  | 34 | void *private; | 
|  | 35 | }; | 
|  | 36 |  | 
|  | 37 | struct af_alg_completion { | 
|  | 38 | struct completion completion; | 
|  | 39 | int err; | 
|  | 40 | }; | 
|  | 41 |  | 
|  | 42 | struct af_alg_control { | 
|  | 43 | struct af_alg_iv *iv; | 
|  | 44 | int op; | 
|  | 45 | }; | 
|  | 46 |  | 
|  | 47 | struct af_alg_type { | 
|  | 48 | void *(*bind)(const char *name, u32 type, u32 mask); | 
|  | 49 | void (*release)(void *private); | 
|  | 50 | int (*setkey)(void *private, const u8 *key, unsigned int keylen); | 
|  | 51 | int (*accept)(void *private, struct sock *sk); | 
|  | 52 |  | 
|  | 53 | struct proto_ops *ops; | 
|  | 54 | struct module *owner; | 
|  | 55 | char name[14]; | 
|  | 56 | }; | 
|  | 57 |  | 
|  | 58 | struct af_alg_sgl { | 
|  | 59 | struct scatterlist sg[ALG_MAX_PAGES]; | 
|  | 60 | struct page *pages[ALG_MAX_PAGES]; | 
|  | 61 | }; | 
|  | 62 |  | 
|  | 63 | int af_alg_register_type(const struct af_alg_type *type); | 
|  | 64 | int af_alg_unregister_type(const struct af_alg_type *type); | 
|  | 65 |  | 
|  | 66 | int af_alg_release(struct socket *sock); | 
|  | 67 | int af_alg_accept(struct sock *sk, struct socket *newsock); | 
|  | 68 |  | 
|  | 69 | int af_alg_make_sg(struct af_alg_sgl *sgl, void __user *addr, int len, | 
|  | 70 | int write); | 
|  | 71 | void af_alg_free_sg(struct af_alg_sgl *sgl); | 
|  | 72 |  | 
|  | 73 | int af_alg_cmsg_send(struct msghdr *msg, struct af_alg_control *con); | 
|  | 74 |  | 
|  | 75 | int af_alg_wait_for_completion(int err, struct af_alg_completion *completion); | 
|  | 76 | void af_alg_complete(struct crypto_async_request *req, int err); | 
|  | 77 |  | 
|  | 78 | static inline struct alg_sock *alg_sk(struct sock *sk) | 
|  | 79 | { | 
|  | 80 | return (struct alg_sock *)sk; | 
|  | 81 | } | 
|  | 82 |  | 
|  | 83 | static inline void af_alg_release_parent(struct sock *sk) | 
|  | 84 | { | 
|  | 85 | sock_put(alg_sk(sk)->parent); | 
|  | 86 | } | 
|  | 87 |  | 
|  | 88 | static inline void af_alg_init_completion(struct af_alg_completion *completion) | 
|  | 89 | { | 
|  | 90 | init_completion(&completion->completion); | 
|  | 91 | } | 
|  | 92 |  | 
|  | 93 | #endif	/* _CRYPTO_IF_ALG_H */ |