X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=ndk%2Fandroid-ndk-r4%2Flinux%2Fplatforms%2Fandroid-8%2Farch-x86%2Fusr%2Finclude%2Flinux%2Fsunrpc%2Fsvc.h;fp=ndk%2Fandroid-ndk-r4%2Flinux%2Fplatforms%2Fandroid-8%2Farch-x86%2Fusr%2Finclude%2Flinux%2Fsunrpc%2Fsvc.h;h=7a0cc2d07cad96ca56f06a1d53a3e4034f6d72c5;hb=72eddb87bfc38a2f6fae40566ec6380eb838489a;hp=0000000000000000000000000000000000000000;hpb=e19e12d257815bef7bfe4f3d81056a5b2464c464;p=android-x86%2Fprebuilt.git diff --git a/ndk/android-ndk-r4/linux/platforms/android-8/arch-x86/usr/include/linux/sunrpc/svc.h b/ndk/android-ndk-r4/linux/platforms/android-8/arch-x86/usr/include/linux/sunrpc/svc.h new file mode 100644 index 0000000..7a0cc2d --- /dev/null +++ b/ndk/android-ndk-r4/linux/platforms/android-8/arch-x86/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 +#include +#include +#include +#include +#include + +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