diff options
author | Andrew Hsieh <andrewhsieh@google.com> | 2012-04-16 04:56:33 -0700 |
---|---|---|
committer | android code review <noreply-gerritcodereview@google.com> | 2012-04-16 04:56:33 -0700 |
commit | 9841d729919cd19016525e2b6b1670ab52ad0b16 (patch) | |
tree | 704b7df8fc7ff9d59a15737e9932a0cd46a0848a /sysroot/usr/include/linux/sunrpc/svc.h | |
parent | b832c77812d4735e04acf368e0f2b7628fc4b242 (diff) | |
parent | 373d8e9f24e73a7a5507f2cb668b2b50ab8f27a3 (diff) | |
download | mipsel-linux-android-4.4.3-tools_r20.tar.gz |
Merge "Adding mipsel-linux-android- cross toolchain"android-sdk-adt_r20android-cts-4.1_r4android-cts-4.1_r2android-cts-4.1_r1android-4.1.2_r2.1android-4.1.2_r2android-4.1.2_r1android-4.1.1_r6.1android-4.1.1_r6android-4.1.1_r5android-4.1.1_r4android-4.1.1_r3android-4.1.1_r2android-4.1.1_r1.1android-4.1.1_r1tools_r20jb-releasejb-mr0-releasejb-devics-plus-aosp
Diffstat (limited to 'sysroot/usr/include/linux/sunrpc/svc.h')
-rw-r--r-- | sysroot/usr/include/linux/sunrpc/svc.h | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/sysroot/usr/include/linux/sunrpc/svc.h b/sysroot/usr/include/linux/sunrpc/svc.h new file mode 100644 index 0000000..7a0cc2d --- /dev/null +++ b/sysroot/usr/include/linux/sunrpc/svc.h @@ -0,0 +1,82 @@ +/**************************************************************************** + **************************************************************************** + *** + *** This header was automatically generated from a Linux kernel header + *** of the same name, to make information necessary for userspace to + *** call into the kernel available to libc. It contains only constants, + *** structures, and macros generated from the original header, and thus, + *** contains no copyrightable information. + *** + **************************************************************************** + ****************************************************************************/ +#ifndef SUNRPC_SVC_H +#define SUNRPC_SVC_H + +#include <linux/in.h> +#include <linux/sunrpc/types.h> +#include <linux/sunrpc/xdr.h> +#include <linux/sunrpc/svcauth.h> +#include <linux/wait.h> +#include <linux/mm.h> + +struct svc_serv { + struct list_head sv_threads; + struct list_head sv_sockets; + struct svc_program * sv_program; + struct svc_stat * sv_stats; + spinlock_t sv_lock; + unsigned int sv_nrthreads; + unsigned int sv_bufsz; + unsigned int sv_xdrsize; + + struct list_head sv_permsocks; + struct list_head sv_tempsocks; + int sv_tmpcnt; + + char * sv_name; +}; + +#define RPCSVC_MAXPAYLOAD (64*1024u) + +#define RPCSVC_MAXPAGES ((RPCSVC_MAXPAYLOAD+PAGE_SIZE-1)/PAGE_SIZE + 2) + +struct svc_program { + struct svc_program * pg_next; + u32 pg_prog; + unsigned int pg_lovers; + unsigned int pg_hivers; + unsigned int pg_nvers; + struct svc_version ** pg_vers; + char * pg_name; + char * pg_class; + struct svc_stat * pg_stats; + int (*pg_authenticate)(struct svc_rqst *); +}; + +struct svc_version { + u32 vs_vers; + u32 vs_nproc; + struct svc_procedure * vs_proc; + u32 vs_xdrsize; + + int (*vs_dispatch)(struct svc_rqst *, u32 *); +}; + +typedef int (*svc_procfunc)(struct svc_rqst *, void *argp, void *resp); +struct svc_procedure { + svc_procfunc pc_func; + kxdrproc_t pc_decode; + kxdrproc_t pc_encode; + kxdrproc_t pc_release; + unsigned int pc_argsize; + unsigned int pc_ressize; + unsigned int pc_count; + unsigned int pc_cachetype; + unsigned int pc_xdrressize; +}; + +typedef void (*svc_thread_fn)(struct svc_rqst *); + +struct svc_serv * svc_create(struct svc_program *, unsigned int); + +#endif |