[PATCH 1/2] Commit generated prototype headers.

James Peach jpeach at samba.org
Tue Jun 5 19:32:05 GMT 2007


commit a snapshot of the generated prototype headers
---
source/client/client_proto.h     |  366 ++
source/include/proto.h           |10128 ++++++++++++++++++++++++++++++ 
++++++++
source/nsswitch/winbindd_proto.h |  516 ++
source/utils/net_proto.h         |  382 ++
source/utils/ntlm_auth_proto.h   |   28 +
source/utils/passwd_proto.h      |   12 +
source/web/swat_proto.h          |   49 +
7 files changed, 11481 insertions(+), 0 deletions(-)
create mode 100644 source/client/client_proto.h
create mode 100644 source/include/proto.h
create mode 100644 source/nsswitch/winbindd_proto.h
create mode 100644 source/utils/net_proto.h
create mode 100644 source/utils/ntlm_auth_proto.h
create mode 100644 source/utils/passwd_proto.h
create mode 100644 source/web/swat_proto.h

diff --git a/source/client/client_proto.h b/source/client/client_proto.h
new file mode 100644
index 0000000..f5027e8
--- /dev/null
+++ b/source/client/client_proto.h
@@ -0,0 +1,366 @@
+#ifndef _CLIENT_PROTO_H_
+#define _CLIENT_PROTO_H_
+
+/* This file is automatically generated with "make proto". DO NOT  
EDIT */
+
+
+/* The following definitions come from client/client.c  */
+
+void do_list(const char *mask,uint16 attribute,void (*fn)(file_info  
*),BOOL rec, BOOL dirs);
+
+/* The following definitions come from client/clitar.c  */
+
+int cmd_block(void);
+int cmd_tarmode(void);
+int cmd_setmode(void);
+int cmd_tar(void);
+int process_tar(void);
+int tar_parseargs(int argc, char *argv[], const char *Optarg, int  
Optind);
+
+/* The following definitions come from rpc_client/cli_netlogon.c  */
+
+NTSTATUS rpccli_netlogon_setup_creds(struct rpc_pipe_client *cli,
+				const char *server_name,
+				const char *domain,
+				const char *clnt_name,
+				const char *machine_account,
+				const unsigned char machine_pwd[16],
+				uint32 sec_chan_type,
+				uint32 *neg_flags_inout);
+NTSTATUS rpccli_netlogon_logon_ctrl2(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                  uint32 query_level);
+WERROR rpccli_netlogon_getanydcname(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx, const char *mydcname,
+				    const char *domainname, fstring newdcname);
+NTSTATUS rpccli_netlogon_getdcname(struct rpc_pipe_client *cli,
+				   TALLOC_CTX *mem_ctx, const char *mydcname,
+				   const char *domainname, fstring newdcname);
+WERROR rpccli_netlogon_dsr_getdcname(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     const char *server_name,
+				     const char *domain_name,
+				     struct GUID *domain_guid,
+				     struct GUID *site_guid,
+				     uint32_t flags,
+				     struct DS_DOMAIN_CONTROLLER_INFO **info_out);
+WERROR rpccli_netlogon_dsr_getdcnameex(struct rpc_pipe_client *cli,
+				       TALLOC_CTX *mem_ctx,
+				       const char *server_name,
+				       const char *domain_name,
+				       struct GUID *domain_guid,
+				       const char *site_name,
+				       uint32_t flags,
+				       struct DS_DOMAIN_CONTROLLER_INFO **info_out);
+WERROR rpccli_netlogon_dsr_getdcnameex2(struct rpc_pipe_client *cli,
+					TALLOC_CTX *mem_ctx,
+					const char *server_name,
+					const char *client_account,
+					uint32 mask,
+					const char *domain_name,
+					struct GUID *domain_guid,
+					const char *site_name,
+					uint32_t flags,
+					struct DS_DOMAIN_CONTROLLER_INFO **info_out);
+WERROR rpccli_netlogon_dsr_getsitename(struct rpc_pipe_client *cli,
+				       TALLOC_CTX *mem_ctx,
+				       const char *computer_name,
+				       char **site_name);
+NTSTATUS rpccli_netlogon_sam_sync(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                               uint32 database_id, uint32 next_rid,  
uint32 *num_deltas,
+                               SAM_DELTA_HDR **hdr_deltas,
+                               SAM_DELTA_CTR **deltas);
+NTSTATUS rpccli_netlogon_sam_deltas(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                 uint32 database_id, uint64 seqnum,
+                                 uint32 *num_deltas,
+                                 SAM_DELTA_HDR **hdr_deltas,
+                                 SAM_DELTA_CTR **deltas);
+NTSTATUS rpccli_netlogon_sam_logon(struct rpc_pipe_client *cli,
+				   TALLOC_CTX *mem_ctx,
+				   uint32 logon_parameters,
+				   const char *domain,
+				   const char *username,
+				   const char *password,
+				   const char *workstation,
+				   int logon_type);
+NTSTATUS rpccli_netlogon_sam_network_logon(struct rpc_pipe_client *cli,
+					   TALLOC_CTX *mem_ctx,
+					   uint32 logon_parameters,
+					   const char *server,
+					   const char *username,
+					   const char *domain,
+					   const char *workstation,
+					   const uint8 chal[8],
+					   DATA_BLOB lm_response,
+					   DATA_BLOB nt_response,
+					   NET_USER_INFO_3 *info3);
+NTSTATUS rpccli_netlogon_sam_network_logon_ex(struct rpc_pipe_client  
*cli,
+					      TALLOC_CTX *mem_ctx,
+					      uint32 logon_parameters,
+					      const char *server,
+					      const char *username,
+					      const char *domain,
+					      const char *workstation,
+					      const uint8 chal[8],
+					      DATA_BLOB lm_response,
+					      DATA_BLOB nt_response,
+					      NET_USER_INFO_3 *info3);
+NTSTATUS rpccli_net_srv_pwset(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			   const char *machine_name, const uint8 hashed_mach_pwd[16]);
+
+/* The following definitions come from rpc_client/cli_pipe.c  */
+
+NTSTATUS rpc_api_pipe_req(struct rpc_pipe_client *cli,
+			uint8 op_num,
+			prs_struct *in_data,
+			prs_struct *out_data);
+struct rpc_pipe_client *cli_rpc_pipe_open_noauth(struct cli_state  
*cli, int pipe_idx, NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_ntlmssp(struct cli_state  
*cli,
+						int pipe_idx,
+						enum pipe_auth_level auth_level,
+						const char *domain,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_spnego_ntlmssp(struct  
cli_state *cli,
+						int pipe_idx,
+						enum pipe_auth_level auth_level,
+						const char *domain,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+struct rpc_pipe_client *get_schannel_session_key(struct cli_state *cli,
+							const char *domain,
+							uint32 *pneg_flags,
+							NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_schannel_with_key(struct  
cli_state *cli,
+					int pipe_idx,
+					enum pipe_auth_level auth_level,
+					const char *domain,
+					const struct dcinfo *pdc,
+					NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_ntlmssp_auth_schannel 
(struct cli_state *cli,
+                                                int pipe_idx,
+						enum pipe_auth_level auth_level,
+                                                const char *domain,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_schannel(struct cli_state  
*cli,
+                                                int pipe_idx,
+						enum pipe_auth_level auth_level,
+                                                const char *domain,
+						NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_krb5(struct cli_state *cli,
+						int pipe_idx,
+						enum pipe_auth_level auth_level,
+						const char *service_princ,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+
+/* The following definitions come from rpc_parse/parse_net.c  */
+
+BOOL net_io_q_logon_ctrl2(const char *desc, NET_Q_LOGON_CTRL2 *q_l,  
prs_struct *ps, int depth);
+void init_net_q_logon_ctrl2(NET_Q_LOGON_CTRL2 *q_l, const char  
*srv_name,
+			    uint32 query_level);
+void init_net_r_logon_ctrl2(NET_R_LOGON_CTRL2 *r_l, uint32 query_level,
+			    uint32 flags, uint32 pdc_status,
+			    uint32 logon_attempts, uint32 tc_status,
+			    const char *trusted_domain_name);
+BOOL net_io_r_logon_ctrl2(const char *desc, NET_R_LOGON_CTRL2 *r_l,  
prs_struct *ps, int depth);
+BOOL net_io_q_logon_ctrl(const char *desc, NET_Q_LOGON_CTRL *q_l,  
prs_struct *ps,
+			 int depth);
+void init_net_q_logon_ctrl(NET_Q_LOGON_CTRL *q_l, const char *srv_name,
+			   uint32 query_level);
+void init_net_r_logon_ctrl(NET_R_LOGON_CTRL *r_l, uint32 query_level,
+			   uint32 flags, uint32 pdc_status);
+BOOL net_io_r_logon_ctrl(const char *desc, NET_R_LOGON_CTRL *r_l,  
prs_struct *ps,
+			 int depth);
+void init_net_q_getanydcname(NET_Q_GETANYDCNAME *r_t, const char  
*logon_server,
+			     const char *domainname);
+BOOL net_io_q_getanydcname(const char *desc, NET_Q_GETANYDCNAME  
*r_t, prs_struct *ps,
+			   int depth);
+void init_net_r_getanydcname(NET_R_GETANYDCNAME *r_t, const char  
*dcname);
+BOOL net_io_r_getanydcname(const char *desc, NET_R_GETANYDCNAME  
*r_t, prs_struct *ps,
+			   int depth);
+void init_net_q_getdcname(NET_Q_GETDCNAME *r_t, const char  
*logon_server,
+			  const char *domainname);
+BOOL net_io_q_getdcname(const char *desc, NET_Q_GETDCNAME *r_t,  
prs_struct *ps,
+			int depth);
+void init_net_r_getdcname(NET_R_GETDCNAME *r_t, const char *dcname);
+BOOL net_io_r_getdcname(const char *desc, NET_R_GETDCNAME *r_t,  
prs_struct *ps,
+			int depth);
+void init_r_trust_dom(NET_R_TRUST_DOM_LIST *r_t,
+			uint32 num_doms, const char *dom_name);
+BOOL net_io_r_trust_dom(const char *desc, NET_R_TRUST_DOM_LIST *r_t,  
prs_struct *ps, int depth);
+BOOL net_io_q_trust_dom(const char *desc, NET_Q_TRUST_DOM_LIST *q_l,  
prs_struct *ps, int depth);
+void init_q_req_chal(NET_Q_REQ_CHAL *q_c,
+		     const char *logon_srv, const char *logon_clnt,
+		     const DOM_CHAL *clnt_chal);
+BOOL net_io_q_req_chal(const char *desc,  NET_Q_REQ_CHAL *q_c,  
prs_struct *ps, int depth);
+BOOL net_io_r_req_chal(const char *desc, NET_R_REQ_CHAL *r_c,  
prs_struct *ps, int depth);
+BOOL net_io_q_auth(const char *desc, NET_Q_AUTH *q_a, prs_struct  
*ps, int depth);
+BOOL net_io_r_auth(const char *desc, NET_R_AUTH *r_a, prs_struct  
*ps, int depth);
+void init_q_auth_2(NET_Q_AUTH_2 *q_a,
+		const char *logon_srv, const char *acct_name, uint16 sec_chan,  
const char *comp_name,
+		const DOM_CHAL *clnt_chal, uint32 clnt_flgs);
+BOOL net_io_q_auth_2(const char *desc, NET_Q_AUTH_2 *q_a, prs_struct  
*ps, int depth);
+BOOL net_io_r_auth_2(const char *desc, NET_R_AUTH_2 *r_a, prs_struct  
*ps, int depth);
+void init_q_auth_3(NET_Q_AUTH_3 *q_a,
+		const char *logon_srv, const char *acct_name, uint16 sec_chan,  
const char *comp_name,
+		const DOM_CHAL *clnt_chal, uint32 clnt_flgs);
+BOOL net_io_q_auth_3(const char *desc, NET_Q_AUTH_3 *q_a, prs_struct  
*ps, int depth);
+BOOL net_io_r_auth_3(const char *desc, NET_R_AUTH_3 *r_a, prs_struct  
*ps, int depth);
+void init_q_srv_pwset(NET_Q_SRV_PWSET *q_s,
+		const char *logon_srv, const char *sess_key, const char *acct_name,
+                uint16 sec_chan, const char *comp_name,
+		DOM_CRED *cred, const uchar hashed_mach_pwd[16]);
+BOOL net_io_q_srv_pwset(const char *desc, NET_Q_SRV_PWSET *q_s,  
prs_struct *ps, int depth);
+BOOL net_io_r_srv_pwset(const char *desc, NET_R_SRV_PWSET *r_s,  
prs_struct *ps, int depth);
+void init_id_info1(NET_ID_INFO_1 *id, const char *domain_name,
+				uint32 param_ctrl, uint32 log_id_low, uint32 log_id_high,
+				const char *user_name, const char *wksta_name,
+				const char *sess_key,
+				unsigned char lm_cypher[16], unsigned char nt_cypher[16]);
+void init_id_info2(NET_ID_INFO_2 * id, const char *domain_name,
+		   uint32 param_ctrl,
+		   uint32 log_id_low, uint32 log_id_high,
+		   const char *user_name, const char *wksta_name,
+		   const uchar lm_challenge[8],
+		   const uchar * lm_chal_resp, size_t lm_chal_resp_len,
+		   const uchar * nt_chal_resp, size_t nt_chal_resp_len);
+void init_sam_info(DOM_SAM_INFO *sam,
+				const char *logon_srv, const char *comp_name,
+				DOM_CRED *clnt_cred,
+				DOM_CRED *rtn_cred, uint16 logon_level,
+				NET_ID_INFO_CTR *ctr);
+void init_sam_info_ex(DOM_SAM_INFO_EX *sam,
+		      const char *logon_srv, const char *comp_name,
+		      uint16 logon_level, NET_ID_INFO_CTR *ctr);
+void init_net_user_info3(TALLOC_CTX *ctx, NET_USER_INFO_3 *usr,
+			 uint32                user_rid,
+			 uint32                group_rid,
+
+			 const char*		user_name,
+			 const char*		full_name,
+			 const char*		home_dir,
+			 const char*		dir_drive,
+			 const char*		logon_script,
+			 const char*		profile_path,
+
+			 time_t unix_logon_time,
+			 time_t unix_logoff_time,
+			 time_t unix_kickoff_time,
+			 time_t unix_pass_last_set_time,
+			 time_t unix_pass_can_change_time,
+			 time_t unix_pass_must_change_time,
+			
+			 uint16 logon_count, uint16 bad_pw_count,
+ 		 	 uint32 num_groups, const DOM_GID *gids,
+			 uint32 user_flgs, uint32 acct_flags,
+			 uchar user_session_key[16],
+			 uchar lm_session_key[16],
+ 			 const char *logon_srv, const char *logon_dom,
+			 const DOM_SID *dom_sid);
+BOOL net_io_user_info3(const char *desc, NET_USER_INFO_3 *usr,  
prs_struct *ps,
+		       int depth, uint16 validation_level, BOOL  
kerb_validation_level);
+BOOL net_io_q_sam_logon(const char *desc, NET_Q_SAM_LOGON *q_l,  
prs_struct *ps, int depth);
+BOOL net_io_r_sam_logon(const char *desc, NET_R_SAM_LOGON *r_l,  
prs_struct *ps, int depth);
+BOOL net_io_q_sam_logon_ex(const char *desc, NET_Q_SAM_LOGON_EX  
*q_l, prs_struct *ps, int depth);
+BOOL net_io_r_sam_logon_ex(const char *desc, NET_R_SAM_LOGON_EX  
*r_l, prs_struct *ps, int depth);
+BOOL net_io_q_sam_logoff(const char *desc,  NET_Q_SAM_LOGOFF *q_l,  
prs_struct *ps, int depth);
+BOOL net_io_r_sam_logoff(const char *desc, NET_R_SAM_LOGOFF *r_l,  
prs_struct *ps, int depth);
+BOOL init_net_q_sam_sync(NET_Q_SAM_SYNC * q_s, const char *srv_name,
+                         const char *cli_name, DOM_CRED *cli_creds,
+                         DOM_CRED *ret_creds, uint32 database_id,
+			 uint32 next_rid);
+BOOL net_io_q_sam_sync(const char *desc, NET_Q_SAM_SYNC * q_s,  
prs_struct *ps,
+		       int depth);
+BOOL net_io_r_sam_sync(const char *desc,
+		       NET_R_SAM_SYNC * r_s, prs_struct *ps, int depth);
+BOOL init_net_q_sam_deltas(NET_Q_SAM_DELTAS *q_s, const char *srv_name,
+                           const char *cli_name, DOM_CRED *cli_creds,
+                           uint32 database_id, uint64 dom_mod_count);
+BOOL net_io_q_sam_deltas(const char *desc, NET_Q_SAM_DELTAS *q_s,  
prs_struct *ps,
+                         int depth);
+BOOL net_io_r_sam_deltas(const char *desc,
+                         NET_R_SAM_DELTAS *r_s, prs_struct *ps, int  
depth);
+void init_net_q_dsr_getdcname(NET_Q_DSR_GETDCNAME *r_t, const char  
*server_unc,
+			      const char *domain_name,
+			      struct GUID *domain_guid,
+			      struct GUID *site_guid,
+			      uint32_t flags);
+void init_net_q_dsr_getdcnameex(NET_Q_DSR_GETDCNAMEEX *r_t, const  
char *server_unc,
+				const char *domain_name,
+				struct GUID *domain_guid,
+				const char *site_name,
+				uint32_t flags);
+void init_net_q_dsr_getdcnameex2(NET_Q_DSR_GETDCNAMEEX2 *r_t, const  
char *server_unc,
+				 const char *domain_name,
+				 const char *client_account,
+				 uint32 mask,
+				 struct GUID *domain_guid,
+				 const char *site_name,
+				 uint32_t flags);
+BOOL net_io_q_dsr_getdcname(const char *desc, NET_Q_DSR_GETDCNAME *r_t,
+			    prs_struct *ps, int depth);
+BOOL net_io_q_dsr_getdcnameex(const char *desc,  
NET_Q_DSR_GETDCNAMEEX *r_t,
+			      prs_struct *ps, int depth);
+BOOL net_io_q_dsr_getdcnameex2(const char *desc,  
NET_Q_DSR_GETDCNAMEEX2 *r_t,
+			       prs_struct *ps, int depth);
+void init_net_r_dsr_getdcname(NET_R_DSR_GETDCNAME *r_t, const char  
*dc_unc,
+			      const char *dc_address, int32 dc_address_type,
+			      struct GUID domain_guid, const char *domain_name,
+			      const char *forest_name, uint32 dc_flags,
+			      const char *dc_site_name,
+			      const char *client_site_name);
+BOOL net_io_r_dsr_getdcname(const char *desc, NET_R_DSR_GETDCNAME *r_t,
+			    prs_struct *ps, int depth);
+void init_net_q_dsr_getsitename(NET_Q_DSR_GETSITENAME *r_t, const  
char *computer_name);
+BOOL net_io_q_dsr_getsitename(const char *desc,  
NET_Q_DSR_GETSITENAME *r_t,
+			      prs_struct *ps, int depth);
+BOOL net_io_r_dsr_getsitename(const char *desc,  
NET_R_DSR_GETSITENAME *r_t,
+			      prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_rpc.c  */
+
+const char *cli_get_pipe_name(int pipe_idx);
+void init_rpc_hdr(RPC_HDR *hdr, enum RPC_PKT_TYPE pkt_type, uint8  
flags,
+				uint32 call_id, int data_len, int auth_len);
+BOOL smb_io_rpc_hdr(const char *desc,  RPC_HDR *rpc, prs_struct *ps,  
int depth);
+void init_rpc_context(RPC_CONTEXT *rpc_ctx, uint16 context_id,  
RPC_IFACE *abstract, RPC_IFACE *transfer);
+void init_rpc_hdr_rb(RPC_HDR_RB *rpc,
+				uint16 max_tsize, uint16 max_rsize, uint32 assoc_gid,
+				RPC_CONTEXT *context);
+BOOL smb_io_rpc_context(const char *desc, RPC_CONTEXT *rpc_ctx,  
prs_struct *ps, int depth);
+BOOL smb_io_rpc_hdr_rb(const char *desc, RPC_HDR_RB *rpc, prs_struct  
*ps, int depth);
+void init_rpc_hdr_ba(RPC_HDR_BA *rpc,
+				uint16 max_tsize, uint16 max_rsize, uint32 assoc_gid,
+				const char *pipe_addr,
+				uint8 num_results, uint16 result, uint16 reason,
+				RPC_IFACE *transfer);
+BOOL smb_io_rpc_hdr_ba(const char *desc, RPC_HDR_BA *rpc, prs_struct  
*ps, int depth);
+void init_rpc_hdr_req(RPC_HDR_REQ *hdr, uint32 alloc_hint, uint16  
opnum);
+BOOL smb_io_rpc_hdr_req(const char *desc, RPC_HDR_REQ *rpc,  
prs_struct *ps, int depth);
+BOOL smb_io_rpc_hdr_resp(const char *desc, RPC_HDR_RESP *rpc,  
prs_struct *ps, int depth);
+BOOL smb_io_rpc_hdr_fault(const char *desc, RPC_HDR_FAULT *rpc,  
prs_struct *ps, int depth);
+void init_rpc_hdr_auth(RPC_HDR_AUTH *rai,
+				uint8 auth_type, uint8 auth_level,
+				uint8 auth_pad_len,
+				uint32 auth_context_id);
+BOOL smb_io_rpc_hdr_auth(const char *desc, RPC_HDR_AUTH *rai,  
prs_struct *ps, int depth);
+BOOL rpc_auth_verifier_chk(RPC_AUTH_VERIFIER *rav,
+				const char *signature, uint32 msg_type);
+void init_rpc_auth_verifier(RPC_AUTH_VERIFIER *rav,
+				const char *signature, uint32 msg_type);
+BOOL smb_io_rpc_auth_verifier(const char *desc, RPC_AUTH_VERIFIER  
*rav, prs_struct *ps, int depth);
+BOOL smb_io_rpc_schannel_verifier(const char *desc,  
RPC_AUTH_VERIFIER *rav, prs_struct *ps, int depth);
+void init_rpc_auth_schannel_neg(RPC_AUTH_SCHANNEL_NEG *neg,
+			      const char *domain, const char *myname);
+BOOL smb_io_rpc_auth_schannel_neg(const char *desc,  
RPC_AUTH_SCHANNEL_NEG *neg,
+				prs_struct *ps, int depth);
+BOOL smb_io_rpc_auth_schannel_chk(const char *desc, int auth_len,
+                                RPC_AUTH_SCHANNEL_CHK * chk,
+				prs_struct *ps, int depth);
+
+#endif /*  _CLIENT_PROTO_H_  */
diff --git a/source/include/proto.h b/source/include/proto.h
new file mode 100644
index 0000000..b836503
--- /dev/null
+++ b/source/include/proto.h
@@ -0,0 +1,10128 @@
+#ifndef _PROTO_H_
+#define _PROTO_H_
+
+/* This file is automatically generated with "make proto". DO NOT  
EDIT */
+
+
+/* The following definitions come from auth/auth.c  */
+
+NTSTATUS smb_register_auth(int version, const char *name,  
auth_init_function init);
+BOOL load_auth_module(struct auth_context *auth_context,
+		      const char *module, auth_methods **ret) ;
+NTSTATUS make_auth_context_subsystem(struct auth_context  
**auth_context) ;
+NTSTATUS make_auth_context_fixed(struct auth_context **auth_context,  
uchar chal[8]) ;
+
+/* The following definitions come from auth/auth_builtin.c  */
+
+NTSTATUS auth_builtin_init(void);
+
+/* The following definitions come from auth/auth_compat.c  */
+
+NTSTATUS check_plaintext_password(const char *smb_name, DATA_BLOB  
plaintext_password, auth_serversupplied_info **server_info);
+BOOL password_ok(char *smb_name, DATA_BLOB password_blob);
+
+/* The following definitions come from auth/auth_domain.c  */
+
+NTSTATUS auth_domain_init(void) ;
+
+/* The following definitions come from auth/auth_ntlmssp.c  */
+
+NTSTATUS auth_ntlmssp_start(AUTH_NTLMSSP_STATE **auth_ntlmssp_state);
+void auth_ntlmssp_end(AUTH_NTLMSSP_STATE **auth_ntlmssp_state);
+NTSTATUS auth_ntlmssp_update(AUTH_NTLMSSP_STATE *auth_ntlmssp_state,
+			     const DATA_BLOB request, DATA_BLOB *reply) ;
+
+/* The following definitions come from auth/auth_sam.c  */
+
+NTSTATUS auth_sam_init(void);
+
+/* The following definitions come from auth/auth_server.c  */
+
+NTSTATUS auth_server_init(void);
+
+/* The following definitions come from auth/auth_unix.c  */
+
+NTSTATUS auth_unix_init(void);
+
+/* The following definitions come from auth/auth_util.c  */
+
+NTSTATUS make_user_info_map(auth_usersupplied_info **user_info,
+			    const char *smb_name,
+			    const char *client_domain,
+			    const char *wksta_name,
+ 			    DATA_BLOB *lm_pwd, DATA_BLOB *nt_pwd,
+ 			    DATA_BLOB *lm_interactive_pwd, DATA_BLOB *nt_interactive_pwd,
+			    DATA_BLOB *plaintext,
+			    BOOL encrypted);
+BOOL make_user_info_netlogon_network(auth_usersupplied_info  
**user_info,
+				     const char *smb_name,
+				     const char *client_domain,
+				     const char *wksta_name,
+				     uint32 logon_parameters,
+				     const uchar *lm_network_pwd,
+				     int lm_pwd_len,
+				     const uchar *nt_network_pwd,
+				     int nt_pwd_len);
+BOOL make_user_info_netlogon_interactive(auth_usersupplied_info  
**user_info,
+					 const char *smb_name,
+					 const char *client_domain,
+					 const char *wksta_name,
+					 uint32 logon_parameters,
+					 const uchar chal[8],
+					 const uchar lm_interactive_pwd[16],
+					 const uchar nt_interactive_pwd[16],
+					 const uchar *dc_sess_key);
+BOOL make_user_info_for_reply(auth_usersupplied_info **user_info,
+			      const char *smb_name,
+			      const char *client_domain,
+			      const uint8 chal[8],
+			      DATA_BLOB plaintext_password);
+NTSTATUS make_user_info_for_reply_enc(auth_usersupplied_info  
**user_info,
+                                      const char *smb_name,
+                                      const char *client_domain,
+                                      DATA_BLOB lm_resp, DATA_BLOB  
nt_resp);
+BOOL make_user_info_guest(auth_usersupplied_info **user_info) ;
+NTSTATUS make_server_info_sam(auth_serversupplied_info **server_info,
+			      struct samu *sampass);
+NTSTATUS create_local_token(auth_serversupplied_info *server_info);
+NTSTATUS create_token_from_username(TALLOC_CTX *mem_ctx, const char  
*username,
+				    BOOL is_guest,
+				    uid_t *uid, gid_t *gid,
+				    char **found_username,
+				    struct nt_user_token **token);
+BOOL user_in_group_sid(const char *username, const DOM_SID *group_sid);
+BOOL user_in_group(const char *username, const char *groupname);
+NTSTATUS make_server_info_pw(auth_serversupplied_info **server_info,
+                             char *unix_username,
+			     struct passwd *pwd);
+BOOL init_guest_info(void);
+NTSTATUS make_server_info_guest(auth_serversupplied_info  
**server_info);
+BOOL copy_current_user(struct current_user *dst, struct current_user  
*src);
+BOOL set_current_user_guest(struct current_user *dst);
+struct passwd *smb_getpwnam( TALLOC_CTX *mem_ctx, char *domuser,
+			     fstring save_username, BOOL create );
+NTSTATUS make_server_info_info3(TALLOC_CTX *mem_ctx,
+				const char *sent_nt_username,
+				const char *domain,
+				auth_serversupplied_info **server_info,
+				NET_USER_INFO_3 *info3) ;
+void free_user_info(auth_usersupplied_info **user_info);
+BOOL make_auth_methods(struct auth_context *auth_context,  
auth_methods **auth_method) ;
+BOOL is_trusted_domain(const char* dom_name);
+
+/* The following definitions come from auth/auth_winbind.c  */
+
+NTSTATUS auth_winbind_init(void);
+
+/* The following definitions come from auth/pampass.c  */
+
+BOOL smb_pam_claim_session(char *user, char *tty, char *rhost);
+BOOL smb_pam_close_session(char *user, char *tty, char *rhost);
+NTSTATUS smb_pam_accountcheck(const char * user);
+NTSTATUS smb_pam_passcheck(const char * user, const char * password);
+BOOL smb_pam_passchange(const char * user, const char * oldpassword,  
const char * newpassword);
+NTSTATUS smb_pam_accountcheck(const char * user);
+BOOL smb_pam_claim_session(char *user, char *tty, char *rhost);
+BOOL smb_pam_close_session(char *in_user, char *tty, char *rhost);
+
+/* The following definitions come from auth/pass_check.c  */
+
+void dfs_unlogin(void);
+NTSTATUS pass_check(const struct passwd *pass, const char *user,  
const char *password,
+		    int pwlen, BOOL (*fn) (const char *, const char *), BOOL  
run_cracker);
+
+/* The following definitions come from auth/token_util.c  */
+
+NT_USER_TOKEN *dup_nt_token(TALLOC_CTX *mem_ctx, const NT_USER_TOKEN  
*ptoken);
+BOOL nt_token_check_sid ( const DOM_SID *sid, const NT_USER_TOKEN  
*token );
+BOOL nt_token_check_domain_rid( NT_USER_TOKEN *token, uint32 rid ) ;
+NT_USER_TOKEN *get_root_nt_token( void );
+NTSTATUS add_aliases(const DOM_SID *domain_sid,
+		     struct nt_user_token *token);
+struct nt_user_token *create_local_nt_token(TALLOC_CTX *mem_ctx,
+					    const DOM_SID *user_sid,
+					    BOOL is_guest,
+					    int num_groupsids,
+					    const DOM_SID *groupsids);
+void debug_nt_user_token(int dbg_class, int dbg_lev, NT_USER_TOKEN  
*token);
+void debug_unix_user_token(int dbg_class, int dbg_lev, uid_t uid,  
gid_t gid,
+			   int n_groups, gid_t *groups);
+
+/* The following definitions come from dynconfig.c  */
+
+
+/* The following definitions come from groupdb/mapping.c  */
+
+NTSTATUS add_initial_entry(gid_t gid, const char *sid, enum  
lsa_SidType sid_name_use, const char *nt_name, const char *comment);
+BOOL get_domain_group_from_sid(DOM_SID sid, GROUP_MAP *map);
+int smb_create_group(const char *unix_group, gid_t *new_gid);
+int smb_delete_group(const char *unix_group);
+int smb_set_primary_group(const char *unix_group, const char*  
unix_user);
+int smb_add_user_group(const char *unix_group, const char *unix_user);
+int smb_delete_user_group(const char *unix_group, const char  
*unix_user);
+NTSTATUS pdb_default_getgrsid(struct pdb_methods *methods, GROUP_MAP  
*map,
+				 DOM_SID sid);
+NTSTATUS pdb_default_getgrgid(struct pdb_methods *methods, GROUP_MAP  
*map,
+				 gid_t gid);
+NTSTATUS pdb_default_getgrnam(struct pdb_methods *methods, GROUP_MAP  
*map,
+				 const char *name);
+NTSTATUS pdb_default_add_group_mapping_entry(struct pdb_methods  
*methods,
+						GROUP_MAP *map);
+NTSTATUS pdb_default_update_group_mapping_entry(struct pdb_methods  
*methods,
+						   GROUP_MAP *map);
+NTSTATUS pdb_default_delete_group_mapping_entry(struct pdb_methods  
*methods,
+						   DOM_SID sid);
+NTSTATUS pdb_default_enum_group_mapping(struct pdb_methods *methods,
+					   const DOM_SID *sid, enum lsa_SidType sid_name_use,
+					   GROUP_MAP **pp_rmap, size_t *p_num_entries,
+					   BOOL unix_only);
+NTSTATUS pdb_default_create_alias(struct pdb_methods *methods,
+				  const char *name, uint32 *rid);
+NTSTATUS pdb_default_delete_alias(struct pdb_methods *methods,
+				  const DOM_SID *sid);
+NTSTATUS pdb_default_get_aliasinfo(struct pdb_methods *methods,
+				   const DOM_SID *sid,
+				   struct acct_info *info);
+NTSTATUS pdb_default_set_aliasinfo(struct pdb_methods *methods,
+				   const DOM_SID *sid,
+				   struct acct_info *info);
+NTSTATUS pdb_default_add_aliasmem(struct pdb_methods *methods,
+				  const DOM_SID *alias, const DOM_SID *member);
+NTSTATUS pdb_default_del_aliasmem(struct pdb_methods *methods,
+				  const DOM_SID *alias, const DOM_SID *member);
+NTSTATUS pdb_default_enum_aliasmem(struct pdb_methods *methods,
+				   const DOM_SID *alias, DOM_SID **pp_members,
+				   size_t *p_num_members);
+NTSTATUS pdb_default_alias_memberships(struct pdb_methods *methods,
+				       TALLOC_CTX *mem_ctx,
+				       const DOM_SID *domain_sid,
+				       const DOM_SID *members,
+				       size_t num_members,
+				       uint32 **pp_alias_rids,
+				       size_t *p_num_alias_rids);
+NTSTATUS pdb_nop_getgrsid(struct pdb_methods *methods, GROUP_MAP *map,
+				 DOM_SID sid);
+NTSTATUS pdb_nop_getgrgid(struct pdb_methods *methods, GROUP_MAP *map,
+				 gid_t gid);
+NTSTATUS pdb_nop_getgrnam(struct pdb_methods *methods, GROUP_MAP *map,
+				 const char *name);
+NTSTATUS pdb_nop_add_group_mapping_entry(struct pdb_methods *methods,
+						GROUP_MAP *map);
+NTSTATUS pdb_nop_update_group_mapping_entry(struct pdb_methods  
*methods,
+						   GROUP_MAP *map);
+NTSTATUS pdb_nop_delete_group_mapping_entry(struct pdb_methods  
*methods,
+						   DOM_SID sid);
+NTSTATUS pdb_nop_enum_group_mapping(struct pdb_methods *methods,
+					   enum lsa_SidType sid_name_use,
+					   GROUP_MAP **rmap, size_t *num_entries,
+					   BOOL unix_only);
+BOOL pdb_get_dom_grp_info(const DOM_SID *sid, struct acct_info *info);
+BOOL pdb_set_dom_grp_info(const DOM_SID *sid, const struct acct_info  
*info);
+NTSTATUS pdb_create_builtin_alias(uint32 rid);
+
+/* The following definitions come from groupdb/mapping_ldb.c  */
+
+const struct mapping_backend *groupdb_ldb_init(void);
+
+/* The following definitions come from groupdb/mapping_tdb.c  */
+
+const struct mapping_backend *groupdb_tdb_init(void);
+
+/* The following definitions come from intl/lang_tdb.c  */
+
+BOOL lang_tdb_init(const char *lang);
+const char *lang_msg(const char *msgid);
+void lang_msg_free(const char *msgstr);
+const char *lang_msg_rotate(const char *msgid);
+char *lang_tdb_current(void);
+
+/* The following definitions come from lib/access.c  */
+
+BOOL allow_access(const char **deny_list, const char **allow_list,
+		  const char *cname, const char *caddr);
+BOOL check_access(int sock, const char **allow_list, const char  
**deny_list);
+
+/* The following definitions come from lib/account_pol.c  */
+
+void account_policy_names_list(const char ***names, int *num_names);
+const char *decode_account_policy_name(int field);
+const char *get_account_policy_attr(int field);
+const char *account_policy_get_desc(int field);
+int account_policy_name_to_fieldnum(const char *name);
+BOOL account_policy_get_default(int account_policy, uint32 *val);
+BOOL init_account_policy(void);
+BOOL account_policy_get(int field, uint32 *value);
+BOOL account_policy_set(int field, uint32 value);
+BOOL cache_account_policy_set(int field, uint32 value);
+BOOL cache_account_policy_get(int field, uint32 *value);
+TDB_CONTEXT *get_account_pol_tdb( void );
+
+/* The following definitions come from lib/adt_tree.c  */
+
+
+/* The following definitions come from lib/afs.c  */
+
+char *afs_createtoken_str(const char *username, const char *cell);
+BOOL afs_login(connection_struct *conn);
+BOOL afs_login(connection_struct *conn);
+char *afs_createtoken_str(const char *username, const char *cell);
+
+/* The following definitions come from lib/afs_settoken.c  */
+
+int afs_syscall( int subcall,
+	  char * path,
+	  int cmd,
+	  char * cmarg,
+	  int follow);
+BOOL afs_settoken_str(const char *token_string);
+BOOL afs_settoken_str(const char *token_string);
+
+/* The following definitions come from lib/arc4.c  */
+
+void smb_arc4_init(unsigned char arc4_state_out[258], const unsigned  
char *key, size_t keylen);
+void smb_arc4_crypt(unsigned char arc4_state_inout[258], unsigned  
char *data, size_t len);
+
+/* The following definitions come from lib/audit.c  */
+
+const char *audit_category_str(uint32 category);
+const char *audit_param_str(uint32 category);
+const char *audit_description_str(uint32 category);
+BOOL get_audit_category_from_param(const char *param, uint32  
*audit_category);
+const char *audit_policy_str(TALLOC_CTX *mem_ctx, uint32 policy);
+
+/* The following definitions come from lib/bitmap.c  */
+
+struct bitmap *bitmap_allocate(int n);
+void bitmap_free(struct bitmap *bm);
+struct bitmap *bitmap_talloc(TALLOC_CTX *mem_ctx, int n);
+int bitmap_copy(struct bitmap * const dst, const struct bitmap *  
const src);
+BOOL bitmap_set(struct bitmap *bm, unsigned i);
+BOOL bitmap_clear(struct bitmap *bm, unsigned i);
+BOOL bitmap_query(struct bitmap *bm, unsigned i);
+int bitmap_find(struct bitmap *bm, unsigned ofs);
+
+/* The following definitions come from lib/charcnv.c  */
+
+char lp_failed_convert_char(void);
+void lazy_initialize_conv(void);
+void gfree_charcnv(void);
+void init_iconv(void);
+size_t convert_string(charset_t from, charset_t to,
+		      void const *src, size_t srclen,
+		      void *dest, size_t destlen, BOOL allow_bad_conv);
+size_t convert_string_allocate(TALLOC_CTX *ctx, charset_t from,  
charset_t to,
+			       void const *src, size_t srclen, void *dst, BOOL  
allow_bad_conv);
+size_t convert_string_talloc(TALLOC_CTX *ctx, charset_t from,  
charset_t to,
+			     void const *src, size_t srclen, void *dst,
+			     BOOL allow_bad_conv);
+size_t unix_strupper(const char *src, size_t srclen, char *dest,  
size_t destlen);
+char *strdup_upper(const char *s);
+size_t unix_strlower(const char *src, size_t srclen, char *dest,  
size_t destlen);
+char *strdup_lower(const char *s);
+size_t push_ascii(void *dest, const char *src, size_t dest_len, int  
flags);
+size_t push_ascii_fstring(void *dest, const char *src);
+size_t push_ascii_pstring(void *dest, const char *src);
+size_t push_ascii_nstring(void *dest, const char *src);
+size_t pull_ascii(char *dest, const void *src, size_t dest_len,  
size_t src_len, int flags);
+size_t pull_ascii_pstring(char *dest, const void *src);
+size_t pull_ascii_fstring(char *dest, const void *src);
+size_t pull_ascii_nstring(char *dest, size_t dest_len, const void  
*src);
+size_t push_ucs2(const void *base_ptr, void *dest, const char *src,  
size_t dest_len, int flags);
+size_t push_ucs2_talloc(TALLOC_CTX *ctx, smb_ucs2_t **dest, const  
char *src);
+size_t push_ucs2_allocate(smb_ucs2_t **dest, const char *src);
+size_t push_utf8_fstring(void *dest, const char *src);
+size_t push_utf8_talloc(TALLOC_CTX *ctx, char **dest, const char *src);
+size_t push_utf8_allocate(char **dest, const char *src);
+size_t pull_ucs2(const void *base_ptr, char *dest, const void *src,  
size_t dest_len, size_t src_len, int flags);
+size_t pull_ucs2_pstring(char *dest, const void *src);
+size_t pull_ucs2_fstring(char *dest, const void *src);
+size_t pull_ucs2_talloc(TALLOC_CTX *ctx, char **dest, const  
smb_ucs2_t *src);
+size_t pull_ucs2_allocate(char **dest, const smb_ucs2_t *src);
+size_t pull_utf8_talloc(TALLOC_CTX *ctx, char **dest, const char *src);
+size_t pull_utf8_allocate(char **dest, const char *src);
+size_t pull_ascii_talloc(TALLOC_CTX *ctx, char **dest, const char  
*src);
+size_t push_string_fn(const char *function, unsigned int line, const  
void *base_ptr, void *dest, const char *src, size_t dest_len, int  
flags);
+size_t pull_string_fn(const char *function, unsigned int line, const  
void *base_ptr, char *dest, const void *src, size_t dest_len, size_t  
src_len, int flags);
+size_t align_string(const void *base_ptr, const char *p, int flags);
+codepoint_t next_codepoint(const char *str, size_t *size);
+
+/* The following definitions come from lib/clobber.c  */
+
+void clobber_region(const char *fn, unsigned int line, char *dest,  
size_t len);
+
+/* The following definitions come from lib/conn_tdb.c  */
+
+struct db_record *connections_fetch_record(TALLOC_CTX *mem_ctx,
+					   TDB_DATA key);
+struct db_record *connections_fetch_entry(TALLOC_CTX *mem_ctx,
+					  connection_struct *conn,
+					  const char *name);
+int connections_traverse(int (*fn)(struct db_record *rec,
+				   void *private_data),
+			 void *private_data);
+int connections_forall(int (*fn)(struct db_record *rec,
+				 const struct connections_key *key,
+				 const struct connections_data *data,
+				 void *private_data),
+		       void *private_data);
+BOOL connections_init(BOOL rw);
+
+/* The following definitions come from lib/crc32.c  */
+
+uint32 crc32_calc_buffer(const char *buf, size_t size);
+
+/* The following definitions come from lib/data_blob.c  */
+
+DATA_BLOB data_blob(const void *p, size_t length);
+DATA_BLOB data_blob_talloc(TALLOC_CTX *mem_ctx, const void *p,  
size_t length);
+void data_blob_free(DATA_BLOB *d);
+void data_blob_clear(DATA_BLOB *d);
+void data_blob_clear_free(DATA_BLOB *d);
+DATA_BLOB data_blob_string_const(const char *str);
+DATA_BLOB data_blob_const(const void *p, size_t length);
+
+/* The following definitions come from lib/dbwrap.c  */
+
+struct db_context *db_open(TALLOC_CTX *mem_ctx,
+			   const char *name,
+			   int hash_size, int tdb_flags,
+			   int open_flags, mode_t mode);
+
+/* The following definitions come from lib/dbwrap_tdb.c  */
+
+struct db_context *db_open_tdb(TALLOC_CTX *mem_ctx,
+			       const char *name,
+			       int hash_size, int tdb_flags,
+			       int open_flags, mode_t mode);
+
+/* The following definitions come from lib/debug.c  */
+
+void gfree_debugsyms(void);
+const char *debug_classname_from_index(int ndx);
+int debug_add_class(const char *classname);
+int debug_lookup_classname(const char *classname);
+BOOL debug_parse_levels(const char *params_str);
+void debug_init(void);
+void debug_register_msgs(struct messaging_context *msg_ctx);
+void setup_logging(const char *pname, BOOL interactive);
+BOOL reopen_logs( void );
+void force_check_log_size( void );
+BOOL need_to_check_log_size( void );
+void check_log_size( void );
+void dbgflush( void );
+BOOL dbghdr( int level, const char *file, const char *func, int line );
+
+/* The following definitions come from lib/display_sec.c  */
+
+char *get_sec_mask_str(uint32 type);
+void display_sec_access(SEC_ACCESS *info);
+void display_sec_ace(SEC_ACE *ace);
+void display_sec_acl(SEC_ACL *sec_acl);
+void display_acl_type(uint16 type);
+void display_sec_desc(SEC_DESC *sec);
+
+/* The following definitions come from lib/dmallocmsg.c  */
+
+void register_dmalloc_msgs(struct messaging_context *msg_ctx);
+
+/* The following definitions come from lib/dprintf.c  */
+
+void display_set_stderr(void);
+
+/* The following definitions come from lib/errmap_unix.c  */
+
+NTSTATUS map_nt_error_from_unix(int unix_error);
+
+/* The following definitions come from lib/events.c  */
+
+struct timed_event *event_add_timed(struct event_context *event_ctx,
+				TALLOC_CTX *mem_ctx,
+				struct timeval when,
+				const char *event_name,
+				void (*handler)(struct event_context *event_ctx,
+						struct timed_event *te,
+						const struct timeval *now,
+						void *private_data),
+				void *private_data);
+struct fd_event *event_add_fd(struct event_context *event_ctx,
+			      TALLOC_CTX *mem_ctx,
+			      int fd, uint16_t flags,
+			      void (*handler)(struct event_context *event_ctx,
+					      struct fd_event *event,
+					      uint16 flags,
+					      void *private_data),
+			      void *private_data);
+void event_fd_set_writeable(struct fd_event *fde);
+void event_fd_set_not_writeable(struct fd_event *fde);
+void event_fd_set_readable(struct fd_event *fde);
+void event_fd_set_not_readable(struct fd_event *fde);
+BOOL event_add_to_select_args(struct event_context *event_ctx,
+			      const struct timeval *now,
+			      fd_set *read_fds, fd_set *write_fds,
+			      struct timeval *timeout, int *maxfd);
+BOOL events_pending(struct event_context *event_ctx);
+BOOL run_events(struct event_context *event_ctx,
+		int selrtn, fd_set *read_fds, fd_set *write_fds);
+struct timeval *get_timed_events_timeout(struct event_context  
*event_ctx,
+					 struct timeval *to_ret);
+int event_loop_once(struct event_context *ev);
+struct event_context *event_context_init(TALLOC_CTX *mem_ctx);
+int set_event_dispatch_time(struct event_context *event_ctx,
+			    const char *event_name, struct timeval when);
+int cancel_named_event(struct event_context *event_ctx,
+		       const char *event_name);
+
+/* The following definitions come from lib/fault.c  */
+
+void fault_setup(void (*fn)(void *));
+void dump_core_setup(const char *progname);
+
+/* The following definitions come from lib/file_id.c  */
+
+struct file_id file_id_create(SMB_DEV_T dev, SMB_INO_T inode);
+struct file_id file_id_sbuf(const SMB_STRUCT_STAT *sbuf);
+BOOL file_id_equal(const struct file_id *id1, const struct file_id  
*id2);
+const char *file_id_static_string(const struct file_id *id);
+const char *file_id_static_string2(const struct file_id *id);
+void push_file_id_16(char *buf, const struct file_id *id);
+void pull_file_id_16(char *buf, struct file_id *id);
+
+/* The following definitions come from lib/fsusage.c  */
+
+int sys_fsusage(const char *path, SMB_BIG_UINT *dfree, SMB_BIG_UINT  
*dsize);
+
+/* The following definitions come from lib/gencache.c  */
+
+BOOL gencache_init(void);
+BOOL gencache_shutdown(void);
+BOOL gencache_set(const char *keystr, const char *value, time_t  
timeout);
+BOOL gencache_del(const char *keystr);
+BOOL gencache_get(const char *keystr, char **valstr, time_t *timeout);
+void gencache_iterate(void (*fn)(const char* key, const char *value,  
time_t timeout, void* dptr),
+                      void* data, const char* keystr_pattern);
+int gencache_lock_entry( const char *key );
+void gencache_unlock_entry( const char *key );
+
+/* The following definitions come from lib/genrand.c  */
+
+void set_rand_reseed_callback(void (*fn)(int *));
+void set_need_random_reseed(void);
+void generate_random_buffer( unsigned char *out, int len);
+char *generate_random_str(size_t len);
+
+/* The following definitions come from lib/hmacmd5.c  */
+
+void hmac_md5_init_rfc2104(const unsigned char *key, int key_len,  
HMACMD5Context *ctx);
+void hmac_md5_init_limK_to_64(const unsigned char* key, int key_len,
+			HMACMD5Context *ctx);
+void hmac_md5_update(const unsigned char *text, int text_len,  
HMACMD5Context *ctx);
+void hmac_md5_final(unsigned char *digest, HMACMD5Context *ctx);
+void hmac_md5( unsigned char key[16], unsigned char *data, int  
data_len, unsigned char *digest);
+
+/* The following definitions come from lib/iconv.c  */
+
+NTSTATUS smb_register_charset(struct charset_functions *funcs) ;
+size_t smb_iconv(smb_iconv_t cd,
+		 const char **inbuf, size_t *inbytesleft,
+		 char **outbuf, size_t *outbytesleft);
+smb_iconv_t smb_iconv_open(const char *tocode, const char *fromcode);
+int smb_iconv_close (smb_iconv_t cd);
+
+/* The following definitions come from lib/interface.c  */
+
+void load_interfaces(void);
+void gfree_interfaces(void);
+BOOL interfaces_changed(void);
+BOOL ismyip(struct in_addr ip);
+BOOL is_local_net(struct in_addr from);
+int iface_count(void);
+struct interface *get_interface(int n);
+struct in_addr *iface_n_ip(int n);
+struct in_addr *iface_n_bcast(int n);
+struct in_addr *iface_ip(struct in_addr ip);
+BOOL iface_local(struct in_addr ip);
+
+/* The following definitions come from lib/interfaces.c  */
+
+int get_interfaces(struct iface_struct *ifaces, int max_interfaces);
+
+/* The following definitions come from lib/launchd.c  */
+
+
+/* The following definitions come from lib/ldap_escape.c  */
+
+char *escape_ldap_string_alloc(const char *s);
+char *escape_rdn_val_string_alloc(const char *s);
+
+/* The following definitions come from lib/md4.c  */
+
+void mdfour(unsigned char *out, const unsigned char *in, int n);
+
+/* The following definitions come from lib/md5.c  */
+
+void MD5Init(struct MD5Context *ctx);
+void MD5Update(struct MD5Context *ctx, unsigned char const *buf,  
unsigned len);
+void MD5Final(unsigned char digest[16], struct MD5Context *ctx);
+
+/* The following definitions come from lib/module.c  */
+
+NTSTATUS smb_load_module(const char *module_name);
+int smb_load_modules(const char **modules);
+NTSTATUS smb_probe_module(const char *subsystem, const char *module);
+NTSTATUS smb_load_module(const char *module_name);
+int smb_load_modules(const char **modules);
+NTSTATUS smb_probe_module(const char *subsystem, const char *module);
+void init_modules(void);
+
+/* The following definitions come from lib/ms_fnmatch.c  */
+
+int ms_fnmatch(const char *pattern, const char *string, BOOL  
translate_pattern,
+	       BOOL is_case_sensitive);
+int gen_fnmatch(const char *pattern, const char *string);
+
+/* The following definitions come from lib/pam_errors.c  */
+
+NTSTATUS pam_to_nt_status(int pam_error);
+int nt_status_to_pam(NTSTATUS nt_status);
+NTSTATUS pam_to_nt_status(int pam_error);
+int nt_status_to_pam(NTSTATUS nt_status);
+
+/* The following definitions come from lib/pidfile.c  */
+
+pid_t pidfile_pid(const char *name);
+void pidfile_create(const char *program_name);
+
+/* The following definitions come from lib/popt_common.c  */
+
+
+/* The following definitions come from lib/privileges.c  */
+
+BOOL se_priv_copy( SE_PRIV *dst, const SE_PRIV *src );
+void se_priv_add( SE_PRIV *mask, const SE_PRIV *addpriv );
+void se_priv_remove( SE_PRIV *mask, const SE_PRIV *removepriv );
+BOOL se_priv_from_name( const char *name, SE_PRIV *mask );
+void dump_se_priv( int dbg_cl, int dbg_lvl, const SE_PRIV *mask );
+LUID_ATTR get_privilege_luid( SE_PRIV *mask );
+const char* get_privilege_dispname( const char *name );
+BOOL get_privileges_for_sids(SE_PRIV *privileges, DOM_SID *slist,  
int scount);
+NTSTATUS privilege_enumerate_accounts(DOM_SID **sids, int *num_sids);
+BOOL grant_privilege(const DOM_SID *sid, const SE_PRIV *priv_mask);
+BOOL grant_privilege_by_name(DOM_SID *sid, const char *name);
+BOOL revoke_privilege(const DOM_SID *sid, const SE_PRIV *priv_mask);
+BOOL revoke_all_privileges( DOM_SID *sid );
+BOOL revoke_privilege_by_name(DOM_SID *sid, const char *name);
+NTSTATUS privilege_create_account(const DOM_SID *sid );
+NTSTATUS privilege_set_init(PRIVILEGE_SET *priv_set);
+NTSTATUS privilege_set_init_by_ctx(TALLOC_CTX *mem_ctx,  
PRIVILEGE_SET *priv_set);
+void privilege_set_free(PRIVILEGE_SET *priv_set);
+NTSTATUS dup_luid_attr(TALLOC_CTX *mem_ctx, LUID_ATTR **new_la,  
LUID_ATTR *old_la, int count);
+BOOL user_has_privileges(const NT_USER_TOKEN *token, const SE_PRIV  
*privilege);
+BOOL user_has_any_privilege(NT_USER_TOKEN *token, const SE_PRIV  
*privilege);
+char* luid_to_privilege_name(const LUID *set);
+int count_all_privileges( void );
+BOOL se_priv_to_privilege_set( PRIVILEGE_SET *set, SE_PRIV *mask );
+BOOL privilege_set_to_se_priv( SE_PRIV *mask, PRIVILEGE_SET *privset );
+BOOL is_privileged_sid( const DOM_SID *sid );
+BOOL grant_all_privileges( const DOM_SID *sid );
+
+/* The following definitions come from lib/readline.c  */
+
+char *smb_readline(const char *prompt, void (*callback)(void),
+		   char **(completion_fn)(const char *text, int start, int end));
+const char *smb_readline_get_line_buffer(void);
+void smb_readline_ca_char(char c);
+int cmd_history(void);
+
+/* The following definitions come from lib/secace.c  */
+
+BOOL sec_ace_object(uint8 type);
+void sec_ace_copy(SEC_ACE *ace_dest, SEC_ACE *ace_src);
+void init_sec_ace(SEC_ACE *t, const DOM_SID *sid, uint8 type, uint32  
mask, uint8 flag);
+NTSTATUS sec_ace_add_sid(TALLOC_CTX *ctx, SEC_ACE **pp_new, SEC_ACE  
*old, unsigned *num, DOM_SID *sid, uint32 mask);
+NTSTATUS sec_ace_mod_sid(SEC_ACE *ace, size_t num, DOM_SID *sid,  
uint32 mask);
+NTSTATUS sec_ace_del_sid(TALLOC_CTX *ctx, SEC_ACE **pp_new, SEC_ACE  
*old, uint32 *num, DOM_SID *sid);
+BOOL sec_ace_equal(SEC_ACE *s1, SEC_ACE *s2);
+int nt_ace_inherit_comp( SEC_ACE *a1, SEC_ACE *a2);
+int nt_ace_canon_comp( SEC_ACE *a1, SEC_ACE *a2);
+void dacl_sort_into_canonical_order(SEC_ACE *srclist, unsigned int  
num_aces);
+BOOL token_sid_in_ace(const NT_USER_TOKEN *token, const SEC_ACE *ace);
+
+/* The following definitions come from lib/secacl.c  */
+
+SEC_ACL *make_sec_acl(TALLOC_CTX *ctx, uint16 revision, int  
num_aces, SEC_ACE *ace_list);
+SEC_ACL *dup_sec_acl(TALLOC_CTX *ctx, SEC_ACL *src);
+BOOL sec_acl_equal(SEC_ACL *s1, SEC_ACL *s2);
+
+/* The following definitions come from lib/secdesc.c  */
+
+size_t sec_desc_size(SEC_DESC *psd);
+BOOL sec_desc_equal(SEC_DESC *s1, SEC_DESC *s2);
+SEC_DESC_BUF *sec_desc_merge(TALLOC_CTX *ctx, SEC_DESC_BUF *new_sdb,  
SEC_DESC_BUF *old_sdb);
+SEC_DESC *make_sec_desc(TALLOC_CTX *ctx, uint16 revision, uint16 type,
+			const DOM_SID *owner_sid, const DOM_SID *grp_sid,
+			SEC_ACL *sacl, SEC_ACL *dacl, size_t *sd_size);
+SEC_DESC *dup_sec_desc(TALLOC_CTX *ctx, const SEC_DESC *src);
+NTSTATUS marshall_sec_desc(TALLOC_CTX *mem_ctx,
+			   struct security_descriptor *secdesc,
+			   uint8 **data, size_t *len);
+NTSTATUS unmarshall_sec_desc(TALLOC_CTX *mem_ctx, uint8 *data,  
size_t len,
+			     struct security_descriptor **psecdesc);
+SEC_DESC *make_standard_sec_desc(TALLOC_CTX *ctx, const DOM_SID  
*owner_sid, const DOM_SID *grp_sid,
+				 SEC_ACL *dacl, size_t *sd_size);
+SEC_DESC_BUF *make_sec_desc_buf(TALLOC_CTX *ctx, size_t len,  
SEC_DESC *sec_desc);
+SEC_DESC_BUF *dup_sec_desc_buf(TALLOC_CTX *ctx, SEC_DESC_BUF *src);
+NTSTATUS sec_desc_add_sid(TALLOC_CTX *ctx, SEC_DESC **psd, DOM_SID  
*sid, uint32 mask, size_t *sd_size);
+NTSTATUS sec_desc_mod_sid(SEC_DESC *sd, DOM_SID *sid, uint32 mask);
+NTSTATUS sec_desc_del_sid(TALLOC_CTX *ctx, SEC_DESC **psd, DOM_SID  
*sid, size_t *sd_size);
+SEC_DESC_BUF *se_create_child_secdesc(TALLOC_CTX *ctx, SEC_DESC  
*parent_ctr,
+				      BOOL child_container);
+void init_sec_access(uint32 *t, uint32 mask);
+
+/* The following definitions come from lib/select.c  */
+
+void sys_select_signal(char c);
+int sys_select(int maxfd, fd_set *readfds, fd_set *writefds, fd_set  
*errorfds, struct timeval *tval);
+int sys_select_intr(int maxfd, fd_set *readfds, fd_set *writefds,  
fd_set *errorfds, struct timeval *tval);
+
+/* The following definitions come from lib/sendfile.c  */
+
+ssize_t sys_sendfile(int tofd, int fromfd, const DATA_BLOB *header,  
SMB_OFF_T offset, size_t count);
+ssize_t sys_sendfile(int tofd, int fromfd, const DATA_BLOB *header,  
SMB_OFF_T offset, size_t count);
+ssize_t sys_sendfile(int tofd, int fromfd, const DATA_BLOB *header,  
SMB_OFF_T offset, size_t count);
+ssize_t sys_sendfile(int tofd, int fromfd, const DATA_BLOB *header,  
SMB_OFF_T offset, size_t count);
+ssize_t sys_sendfile(int tofd, int fromfd, const DATA_BLOB *header,  
SMB_OFF_T offset, size_t count);
+ssize_t sys_sendfile(int tofd, int fromfd, const DATA_BLOB *header,  
SMB_OFF_T offset, size_t count);
+ssize_t sys_sendfile(int tofd, int fromfd, const DATA_BLOB *header,  
SMB_OFF_T offset, size_t count);
+
+/* The following definitions come from lib/server_mutex.c  */
+
+BOOL grab_server_mutex(const char *name);
+void release_server_mutex(void);
+
+/* The following definitions come from lib/sharesec.c  */
+
+BOOL share_info_db_init(void);
+SEC_DESC *get_share_security_default( TALLOC_CTX *ctx, size_t  
*psize, uint32 def_access);
+SEC_DESC *get_share_security( TALLOC_CTX *ctx, const char *servicename,
+			      size_t *psize);
+BOOL set_share_security(const char *share_name, SEC_DESC *psd);
+BOOL delete_share_security(const struct share_params *params);
+BOOL share_access_check(const NT_USER_TOKEN *token, const char  
*sharename,
+			uint32 desired_access);
+BOOL parse_usershare_acl(TALLOC_CTX *ctx, const char *acl_str,  
SEC_DESC **ppsd);
+
+/* The following definitions come from lib/signal.c  */
+
+void BlockSignals(BOOL block,int signum);
+void (*CatchSignal(int signum,void (*handler)(int )))(int);
+void CatchChild(void);
+void CatchChildLeaveStatus(void);
+
+/* The following definitions come from lib/smbldap.c  */
+
+int smb_ldap_start_tls(LDAP *ldap_struct, int version);
+int smb_ldap_setup_conn(LDAP **ldap_struct, const char *uri);
+int smb_ldap_upgrade_conn(LDAP *ldap_struct, int *new_version) ;
+int smb_ldap_setup_full_conn(LDAP **ldap_struct, const char *uri);
+int smbldap_search(struct smbldap_state *ldap_state,
+		   const char *base, int scope, const char *filter,
+		   const char *attrs[], int attrsonly,
+		   LDAPMessage **res);
+int smbldap_search_paged(struct smbldap_state *ldap_state,
+			 const char *base, int scope, const char *filter,
+			 const char **attrs, int attrsonly, int pagesize,
+			 LDAPMessage **res, void **cookie);
+int smbldap_modify(struct smbldap_state *ldap_state, const char *dn,  
LDAPMod *attrs[]);
+int smbldap_add(struct smbldap_state *ldap_state, const char *dn,  
LDAPMod *attrs[]);
+int smbldap_delete(struct smbldap_state *ldap_state, const char *dn);
+int smbldap_extended_operation(struct smbldap_state *ldap_state,
+			       LDAP_CONST char *reqoid, struct berval *reqdata,
+			       LDAPControl **serverctrls, LDAPControl **clientctrls,
+			       char **retoidp, struct berval **retdatap);
+int smbldap_search_suffix (struct smbldap_state *ldap_state,
+			   const char *filter, const char **search_attr,
+			   LDAPMessage ** result);
+void smbldap_free_struct(struct smbldap_state **ldap_state) ;
+NTSTATUS smbldap_init(TALLOC_CTX *mem_ctx, struct event_context  
*event_ctx,
+		      const char *location,
+		      struct smbldap_state **smbldap_state);
+char *smbldap_get_dn(LDAP *ld, LDAPMessage *entry);
+BOOL smbldap_has_control(LDAP *ld, const char *control);
+BOOL smbldap_has_extension(LDAP *ld, const char *extension);
+BOOL smbldap_has_naming_context(LDAP *ld, const char *naming_context);
+BOOL smbldap_set_creds(struct smbldap_state *ldap_state, BOOL anon,  
const char *dn, const char *secret);
+
+/* The following definitions come from lib/smbldap_util.c  */
+
+NTSTATUS smbldap_search_domain_info(struct smbldap_state *ldap_state,
+                                    LDAPMessage ** result, const  
char *domain_name,
+                                    BOOL try_add);
+
+/* The following definitions come from lib/smbrun.c  */
+
+int smbrun_no_sanitize(const char *cmd, int *outfd);
+int smbrun(const char *cmd, int *outfd);
+int smbrunsecret(const char *cmd, const char *secret);
+
+/* The following definitions come from lib/sock_exec.c  */
+
+int sock_exec(const char *prog);
+
+/* The following definitions come from lib/substitute.c  */
+
+void set_local_machine_name(const char* local_name, BOOL perm);
+void set_remote_machine_name(const char* remote_name, BOOL perm);
+const char* get_remote_machine_name(void) ;
+const char* get_local_machine_name(void) ;
+void sub_set_smb_name(const char *name);
+char* sub_get_smb_name( void );
+void set_current_user_info(const userdom_struct *pcui);
+const char* get_current_username( void );
+void standard_sub_basic(const char *smb_name, const char *domain_name,
+			char *str, size_t len);
+char *talloc_sub_basic(TALLOC_CTX *mem_ctx, const char *smb_name,
+		       const char *domain_name, const char *str);
+char *alloc_sub_basic(const char *smb_name, const char *domain_name,
+		      const char *str);
+char *talloc_sub_specified(TALLOC_CTX *mem_ctx,
+			const char *input_string,
+			const char *username,
+			const char *domain,
+			uid_t uid,
+			gid_t gid);
+char *talloc_sub_advanced(TALLOC_CTX *mem_ctx,
+			  const char *servicename, const char *user,
+			  const char *connectpath, gid_t gid,
+			  const char *smb_name, const char *domain_name,
+			  const char *str);
+void standard_sub_advanced(const char *servicename, const char *user,
+			   const char *connectpath, gid_t gid,
+			   const char *smb_name, const char *domain_name,
+			   char *str, size_t len);
+
+/* The following definitions come from lib/sysacls.c  */
+
+int sys_acl_get_entry(SMB_ACL_T acl_d, int entry_id, SMB_ACL_ENTRY_T  
*entry_p);
+int sys_acl_get_tag_type(SMB_ACL_ENTRY_T entry_d, SMB_ACL_TAG_T  
*type_p);
+int sys_acl_get_permset(SMB_ACL_ENTRY_T entry_d, SMB_ACL_PERMSET_T  
*permset_p);
+void *sys_acl_get_qualifier(SMB_ACL_ENTRY_T entry_d);
+int sys_acl_clear_perms(SMB_ACL_PERMSET_T permset_d);
+int sys_acl_add_perm(SMB_ACL_PERMSET_T permset_d, SMB_ACL_PERM_T perm);
+int sys_acl_get_perm(SMB_ACL_PERMSET_T permset_d, SMB_ACL_PERM_T perm);
+char *sys_acl_to_text(SMB_ACL_T acl_d, ssize_t *len_p);
+SMB_ACL_T sys_acl_init(int count);
+int sys_acl_create_entry(SMB_ACL_T *acl_p, SMB_ACL_ENTRY_T *entry_p);
+int sys_acl_set_tag_type(SMB_ACL_ENTRY_T entry_d, SMB_ACL_TAG_T  
tag_type);
+int sys_acl_set_qualifier(SMB_ACL_ENTRY_T entry_d, void *qual_p);
+int sys_acl_set_permset(SMB_ACL_ENTRY_T entry_d, SMB_ACL_PERMSET_T  
permset_d);
+int sys_acl_free_text(char *text);
+int sys_acl_free_acl(SMB_ACL_T acl_d) ;
+int sys_acl_free_qualifier(void *qual, SMB_ACL_TAG_T tagtype);
+int sys_acl_valid(SMB_ACL_T acl_d);
+SMB_ACL_T sys_acl_get_file(vfs_handle_struct *handle,
+			   const char *path_p, SMB_ACL_TYPE_T type);
+SMB_ACL_T sys_acl_get_fd(vfs_handle_struct *handle, files_struct  
*fsp, int fd);
+int sys_acl_set_file(vfs_handle_struct *handle,
+		     const char *name, SMB_ACL_TYPE_T type, SMB_ACL_T acl_d);
+int sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp,
+		   int fd, SMB_ACL_T acl_d);
+int sys_acl_delete_def_file(vfs_handle_struct *handle,
+			    const char *path);
+SMB_ACL_T sys_acl_get_file(vfs_handle_struct *handle,
+			   const char *path_p, SMB_ACL_TYPE_T type);
+SMB_ACL_T sys_acl_get_fd(vfs_handle_struct *handle, files_struct  
*fsp, int fd);
+int sys_acl_set_file(vfs_handle_struct *handle,
+		     const char *name, SMB_ACL_TYPE_T type, SMB_ACL_T acl_d);
+int sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp,
+		   int fd, SMB_ACL_T acl_d);
+int sys_acl_delete_def_file(vfs_handle_struct *handle,
+			    const char *path);
+SMB_ACL_T sys_acl_get_file(vfs_handle_struct *handle,
+			   const char *path_p, SMB_ACL_TYPE_T type);
+SMB_ACL_T sys_acl_get_fd(vfs_handle_struct *handle, files_struct  
*fsp, int fd);
+int sys_acl_set_file(vfs_handle_struct *handle,
+		     const char *name, SMB_ACL_TYPE_T type, SMB_ACL_T acl_d);
+int sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp,
+		   int fd, SMB_ACL_T acl_d);
+int sys_acl_delete_def_file(vfs_handle_struct *handle,
+			    const char *path);
+SMB_ACL_T sys_acl_get_file(vfs_handle_struct *handle,
+			   const char *path_p, SMB_ACL_TYPE_T type);
+SMB_ACL_T sys_acl_get_fd(vfs_handle_struct *handle, files_struct  
*fsp, int fd);
+int sys_acl_set_file(vfs_handle_struct *handle,
+		     const char *name, SMB_ACL_TYPE_T type, SMB_ACL_T acl_d);
+int sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp,
+		   int fd, SMB_ACL_T acl_d);
+int sys_acl_delete_def_file(vfs_handle_struct *handle,
+			    const char *path);
+SMB_ACL_T sys_acl_get_file(vfs_handle_struct *handle,
+			   const char *path_p, SMB_ACL_TYPE_T type);
+SMB_ACL_T sys_acl_get_fd(vfs_handle_struct *handle, files_struct  
*fsp, int fd);
+int sys_acl_set_file(vfs_handle_struct *handle,
+		     const char *name, SMB_ACL_TYPE_T type, SMB_ACL_T acl_d);
+int sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp,
+		   int fd, SMB_ACL_T acl_d);
+int sys_acl_delete_def_file(vfs_handle_struct *handle,
+			    const char *path);
+SMB_ACL_T sys_acl_get_file(vfs_handle_struct *handle,
+			   const char *path_p, SMB_ACL_TYPE_T type);
+SMB_ACL_T sys_acl_get_fd(vfs_handle_struct *handle, files_struct  
*fsp, int fd);
+int sys_acl_set_file(vfs_handle_struct *handle,
+		     const char *name, SMB_ACL_TYPE_T type, SMB_ACL_T acl_d);
+int sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp,
+		   int fd, SMB_ACL_T acl_d);
+int sys_acl_delete_def_file(vfs_handle_struct *handle,
+			    const char *path);
+SMB_ACL_T sys_acl_get_file(vfs_handle_struct *handle,
+			   const char *path_p, SMB_ACL_TYPE_T type);
+SMB_ACL_T sys_acl_get_fd(vfs_handle_struct *handle, files_struct  
*fsp, int fd);
+int sys_acl_set_file(vfs_handle_struct *handle,
+		     const char *name, SMB_ACL_TYPE_T type, SMB_ACL_T acl_d);
+int sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp,
+		   int fd, SMB_ACL_T acl_d);
+int sys_acl_delete_def_file(vfs_handle_struct *handle,
+			    const char *path);
+int no_acl_syscall_error(int err);
+
+/* The following definitions come from lib/sysquotas.c  */
+
+int sys_get_quota(const char *path, enum SMB_QUOTA_TYPE qtype,  
unid_t id, SMB_DISK_QUOTA *dp);
+int sys_set_quota(const char *path, enum SMB_QUOTA_TYPE qtype,  
unid_t id, SMB_DISK_QUOTA *dp);
+
+/* The following definitions come from lib/sysquotas_4A.c  */
+
+int sys_get_vfs_quota(const char *path, const char *bdev, enum  
SMB_QUOTA_TYPE qtype, unid_t id, SMB_DISK_QUOTA *dp);
+int sys_set_vfs_quota(const char *path, const char *bdev, enum  
SMB_QUOTA_TYPE qtype, unid_t id, SMB_DISK_QUOTA *dp);
+
+/* The following definitions come from lib/sysquotas_linux.c  */
+
+int sys_get_vfs_quota(const char *path, const char *bdev, enum  
SMB_QUOTA_TYPE qtype, unid_t id, SMB_DISK_QUOTA *dp);
+int sys_set_vfs_quota(const char *path, const char *bdev, enum  
SMB_QUOTA_TYPE qtype, unid_t id, SMB_DISK_QUOTA *dp);
+
+/* The following definitions come from lib/sysquotas_xfs.c  */
+
+int sys_get_xfs_quota(const char *path, const char *bdev, enum  
SMB_QUOTA_TYPE qtype, unid_t id, SMB_DISK_QUOTA *dp);
+int sys_set_xfs_quota(const char *path, const char *bdev, enum  
SMB_QUOTA_TYPE qtype, unid_t id, SMB_DISK_QUOTA *dp);
+
+/* The following definitions come from lib/system.c  */
+
+void *sys_memalign( size_t align, size_t size );
+int sys_usleep(long usecs);
+ssize_t sys_read(int fd, void *buf, size_t count);
+ssize_t sys_write(int fd, const void *buf, size_t count);
+ssize_t sys_pread(int fd, void *buf, size_t count, SMB_OFF_T off);
+ssize_t sys_pwrite(int fd, const void *buf, size_t count, SMB_OFF_T  
off);
+ssize_t sys_send(int s, const void *msg, size_t len, int flags);
+ssize_t sys_sendto(int s,  const void *msg, size_t len, int flags,  
const struct sockaddr *to, socklen_t tolen);
+ssize_t sys_recv(int fd, void *buf, size_t count, int flags);
+ssize_t sys_recvfrom(int s, void *buf, size_t len, int flags, struct  
sockaddr *from, socklen_t *fromlen);
+int sys_fcntl_ptr(int fd, int cmd, void *arg);
+int sys_fcntl_long(int fd, int cmd, long arg);
+int sys_stat(const char *fname,SMB_STRUCT_STAT *sbuf);
+int sys_fstat(int fd,SMB_STRUCT_STAT *sbuf);
+int sys_lstat(const char *fname,SMB_STRUCT_STAT *sbuf);
+int sys_ftruncate(int fd, SMB_OFF_T offset);
+SMB_OFF_T sys_lseek(int fd, SMB_OFF_T offset, int whence);
+int sys_fseek(FILE *fp, SMB_OFF_T offset, int whence);
+SMB_OFF_T sys_ftell(FILE *fp);
+int sys_creat(const char *path, mode_t mode);
+int sys_open(const char *path, int oflag, mode_t mode);
+FILE *sys_fopen(const char *path, const char *type);
+void kernel_flock(int fd, uint32 share_mode);
+SMB_STRUCT_DIR *sys_opendir(const char *name);
+SMB_STRUCT_DIRENT *sys_readdir(SMB_STRUCT_DIR *dirp);
+void sys_seekdir(SMB_STRUCT_DIR *dirp, long offset);
+long sys_telldir(SMB_STRUCT_DIR *dirp);
+void sys_rewinddir(SMB_STRUCT_DIR *dirp);
+int sys_closedir(SMB_STRUCT_DIR *dirp);
+int sys_mknod(const char *path, mode_t mode, SMB_DEV_T dev);
+char *sys_realpath(const char *path, char *resolved_path);
+int sys_waitpid(pid_t pid,int *status,int options);
+char *sys_getwd(char *s);
+int sys_symlink(const char *oldpath, const char *newpath);
+int sys_readlink(const char *path, char *buf, size_t bufsiz);
+int sys_link(const char *oldpath, const char *newpath);
+int sys_chown(const char *fname,uid_t uid,gid_t gid);
+int sys_lchown(const char *fname,uid_t uid,gid_t gid);
+int sys_chroot(const char *dname);
+struct hostent *sys_gethostbyname(const char *name);
+void set_effective_capability(enum smbd_capability capability);
+void drop_effective_capability(enum smbd_capability capability);
+long sys_random(void);
+void sys_srandom(unsigned int seed);
+int groups_max(void);
+int sys_getgroups(int setlen, gid_t *gidset);
+int sys_setgroups(int setlen, gid_t *gidset);
+void sys_setpwent(void);
+struct passwd *sys_getpwent(void);
+void sys_endpwent(void);
+struct passwd *sys_getpwnam(const char *name);
+struct passwd *sys_getpwuid(uid_t uid);
+void faked_create_user(const char *name);
+struct passwd *sys_getpwnam(const char *name);
+struct passwd *sys_getpwuid(uid_t uid);
+struct group *sys_getgrnam(const char *name);
+struct group *sys_getgrgid(gid_t gid);
+int wsys_stat(const smb_ucs2_t *wfname,SMB_STRUCT_STAT *sbuf);
+int wsys_lstat(const smb_ucs2_t *wfname,SMB_STRUCT_STAT *sbuf);
+int wsys_creat(const smb_ucs2_t *wfname, mode_t mode);
+int wsys_open(const smb_ucs2_t *wfname, int oflag, mode_t mode);
+FILE *wsys_fopen(const smb_ucs2_t *wfname, const char *type);
+SMB_STRUCT_DIR *wsys_opendir(const smb_ucs2_t *wfname);
+SMB_STRUCT_WDIRENT *wsys_readdir(SMB_STRUCT_DIR *dirp);
+smb_ucs2_t *wsys_getwd(smb_ucs2_t *s);
+int wsys_chown(const smb_ucs2_t *wfname, uid_t uid, gid_t gid);
+int wsys_chroot(const smb_ucs2_t *wfname);
+pid_t sys_fork(void);
+pid_t sys_getpid(void);
+int sys_popen(const char *command);
+int sys_pclose(int fd);
+void *sys_dlopen(const char *name, int flags);
+void *sys_dlsym(void *handle, const char *symbol);
+int sys_dlclose (void *handle);
+const char *sys_dlerror(void);
+int sys_dup2(int oldfd, int newfd) ;
+ssize_t sys_getxattr (const char *path, const char *name, void  
*value, size_t size);
+ssize_t sys_lgetxattr (const char *path, const char *name, void  
*value, size_t size);
+ssize_t sys_fgetxattr (int filedes, const char *name, void *value,  
size_t size);
+ssize_t sys_listxattr (const char *path, char *list, size_t size);
+ssize_t sys_llistxattr (const char *path, char *list, size_t size);
+ssize_t sys_flistxattr (int filedes, char *list, size_t size);
+int sys_removexattr (const char *path, const char *name);
+int sys_lremovexattr (const char *path, const char *name);
+int sys_fremovexattr (int filedes, const char *name);
+int sys_setxattr (const char *path, const char *name, const void  
*value, size_t size, int flags);
+int sys_lsetxattr (const char *path, const char *name, const void  
*value, size_t size, int flags);
+int sys_fsetxattr (int filedes, const char *name, const void *value,  
size_t size, int flags);
+uint32 unix_dev_major(SMB_DEV_T dev);
+uint32 unix_dev_minor(SMB_DEV_T dev);
+int sys_aio_read(SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_write(SMB_STRUCT_AIOCB *aiocb);
+ssize_t sys_aio_return(SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_cancel(int fd, SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_error(const SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_fsync(int op, SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_suspend(const SMB_STRUCT_AIOCB * const cblist[], int n,  
const struct timespec *timeout);
+int sys_aio_read(SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_write(SMB_STRUCT_AIOCB *aiocb);
+ssize_t sys_aio_return(SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_cancel(int fd, SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_error(const SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_fsync(int op, SMB_STRUCT_AIOCB *aiocb);
+int sys_aio_suspend(const SMB_STRUCT_AIOCB * const cblist[], int n,  
const struct timespec *timeout);
+int sys_getpeereid( int s, uid_t *uid);
+
+/* The following definitions come from lib/system_smbd.c  */
+
+BOOL getgroups_unix_user(TALLOC_CTX *mem_ctx, const char *user,
+			 gid_t primary_gid,
+			 gid_t **ret_groups, size_t *p_ngroups);
+
+/* The following definitions come from lib/tallocmsg.c  */
+
+void register_msg_pool_usage(struct messaging_context *msg_ctx);
+
+/* The following definitions come from lib/time.c  */
+
+time_t get_time_t_max(void);
+void GetTimeOfDay(struct timeval *tval);
+time_t nt_time_to_unix(NTTIME nt);
+void unix_to_nt_time(NTTIME *nt, time_t t);
+BOOL null_time(time_t t);
+BOOL null_nttime(NTTIME t);
+BOOL null_timespec(struct timespec ts);
+void push_dos_date(uint8_t *buf, int offset, time_t unixdate, int  
zone_offset);
+void push_dos_date2(uint8_t *buf,int offset,time_t unixdate, int  
zone_offset);
+void push_dos_date3(uint8_t *buf,int offset,time_t unixdate, int  
zone_offset);
+time_t pull_dos_date(const uint8_t *date_ptr, int zone_offset);
+time_t pull_dos_date2(const uint8_t *date_ptr, int zone_offset);
+time_t pull_dos_date3(const uint8_t *date_ptr, int zone_offset);
+char *http_timestring(time_t t);
+char *timestring(TALLOC_CTX *mem_ctx, time_t t);
+const char *nt_time_string(TALLOC_CTX *mem_ctx, NTTIME nt);
+NTTIME nttime_from_string(const char *s);
+int64_t usec_time_diff(struct timeval *tv1, struct timeval *tv2);
+struct timeval timeval_zero(void);
+BOOL timeval_is_zero(const struct timeval *tv);
+struct timeval timeval_current(void);
+struct timeval timeval_set(uint32_t secs, uint32_t usecs);
+struct timeval timeval_add(const struct timeval *tv,
+			   uint32_t secs, uint32_t usecs);
+struct timeval timeval_sum(const struct timeval *tv1,
+			   const struct timeval *tv2);
+struct timeval timeval_current_ofs(uint32_t secs, uint32_t usecs);
+int timeval_compare(const struct timeval *tv1, const struct timeval  
*tv2);
+BOOL timeval_expired(const struct timeval *tv);
+double timeval_elapsed2(const struct timeval *tv1, const struct  
timeval *tv2);
+double timeval_elapsed(const struct timeval *tv);
+struct timeval timeval_min(const struct timeval *tv1,
+			   const struct timeval *tv2);
+struct timeval timeval_max(const struct timeval *tv1,
+			   const struct timeval *tv2);
+struct timeval timeval_until(const struct timeval *tv1,
+			     const struct timeval *tv2);
+NTTIME timeval_to_nttime(const struct timeval *tv);
+uint32 convert_time_t_to_uint32(time_t t);
+time_t convert_uint32_to_time_t(uint32 u);
+int get_time_zone(time_t t);
+BOOL nt_time_is_zero(const NTTIME *nt);
+time_t generalized_to_unix_time(const char *str);
+int get_server_zone_offset(void);
+int set_server_zone_offset(time_t t);
+char *current_timestring(BOOL hires);
+void srv_put_dos_date(char *buf,int offset,time_t unixdate);
+void srv_put_dos_date2(char *buf,int offset, time_t unixdate);
+void srv_put_dos_date3(char *buf,int offset,time_t unixdate);
+void put_long_date_timespec(char *p, struct timespec ts);
+void put_long_date(char *p, time_t t);
+time_t get_create_time(const SMB_STRUCT_STAT *st,BOOL fake_dirs);
+struct timespec get_create_timespec(const SMB_STRUCT_STAT *st,BOOL  
fake_dirs);
+struct timespec get_atimespec(const SMB_STRUCT_STAT *pst);
+void set_atimespec(SMB_STRUCT_STAT *pst, struct timespec ts);
+struct timespec get_mtimespec(const SMB_STRUCT_STAT *pst);
+void set_mtimespec(SMB_STRUCT_STAT *pst, struct timespec ts);
+struct timespec get_ctimespec(const SMB_STRUCT_STAT *pst);
+void set_ctimespec(SMB_STRUCT_STAT *pst, struct timespec ts);
+void dos_filetime_timespec(struct timespec *tsp);
+time_t srv_make_unix_date(const void *date_ptr);
+time_t srv_make_unix_date2(const void *date_ptr);
+time_t srv_make_unix_date3(const void *date_ptr);
+time_t convert_timespec_to_time_t(struct timespec ts);
+struct timespec convert_time_t_to_timespec(time_t t);
+struct timespec convert_timeval_to_timespec(const struct timeval tv);
+struct timeval convert_timespec_to_timeval(const struct timespec ts);
+struct timespec timespec_current(void);
+struct timespec timespec_min(const struct timespec *ts1,
+			   const struct timespec *ts2);
+int timespec_compare(const struct timespec *ts1, const struct  
timespec *ts2);
+struct timespec interpret_long_date(const char *p);
+void cli_put_dos_date(struct cli_state *cli, char *buf, int offset,  
time_t unixdate);
+void cli_put_dos_date2(struct cli_state *cli, char *buf, int offset,  
time_t unixdate);
+void cli_put_dos_date3(struct cli_state *cli, char *buf, int offset,  
time_t unixdate);
+time_t cli_make_unix_date(struct cli_state *cli, void *date_ptr);
+time_t cli_make_unix_date2(struct cli_state *cli, void *date_ptr);
+time_t cli_make_unix_date3(struct cli_state *cli, void *date_ptr);
+struct timespec nt_time_to_unix_timespec(NTTIME *nt);
+BOOL nt_time_equals(const NTTIME *nt1, const NTTIME *nt2);
+void TimeInit(void);
+void get_process_uptime(struct timeval *ret_time);
+time_t nt_time_to_unix_abs(const NTTIME *nt);
+void unix_timespec_to_nt_time(NTTIME *nt, struct timespec ts);
+void unix_to_nt_time_abs(NTTIME *nt, time_t t);
+BOOL null_mtime(time_t mtime);
+const char *time_to_asc(const time_t t);
+const char *display_time(NTTIME nttime);
+BOOL nt_time_is_set(const NTTIME *nt);
+
+/* The following definitions come from lib/ufc.c  */
+
+char *ufc_crypt(const char *key,const char *salt);
+
+/* The following definitions come from lib/username.c  */
+
+char *get_user_home_dir(const char *user);
+struct passwd *Get_Pwnam_alloc(TALLOC_CTX *mem_ctx, const char *user);
+struct passwd *Get_Pwnam(const char *user);
+
+/* The following definitions come from lib/util.c  */
+
+BOOL set_global_myname(const char *myname);
+const char *global_myname(void);
+BOOL set_global_myworkgroup(const char *myworkgroup);
+const char *lp_workgroup(void);
+BOOL set_global_scope(const char *scope);
+const char *global_scope(void);
+void gfree_names(void);
+void gfree_all( void );
+const char *my_netbios_names(int i);
+BOOL set_netbios_aliases(const char **str_array);
+BOOL init_names(void);
+const char *tmpdir(void);
+BOOL add_gid_to_array_unique(TALLOC_CTX *mem_ctx, gid_t gid,
+			     gid_t **gids, size_t *num_gids);
+const char *get_numlist(const char *p, uint32 **num, int *count);
+BOOL file_exist(const char *fname,SMB_STRUCT_STAT *sbuf);
+time_t file_modtime(const char *fname);
+BOOL directory_exist(char *dname,SMB_STRUCT_STAT *st);
+SMB_OFF_T get_file_size(char *file_name);
+char *attrib_string(uint16 mode);
+void show_msg(char *buf);
+void smb_set_enclen(char *buf,int len,uint16 enc_ctx_num);
+void smb_setlen(const char *frombuf, char *buf, int len);
+int set_message(const char *frombuf, char *buf,int num_words,int  
num_bytes,BOOL zero);
+int set_message_bcc(const char *frombuf, char *buf,int num_bytes);
+int set_message_end(const char *frombuf, void *outbuf,void *end_ptr);
+void dos_clean_name(char *s);
+void unix_clean_name(char *s);
+void clean_name(char *s);
+void close_low_fds(BOOL stderr_too);
+ssize_t write_data_at_offset(int fd, const char *buffer, size_t N,  
SMB_OFF_T pos);
+int set_blocking(int fd, BOOL set);
+ssize_t transfer_file_internal(int infd, int outfd, size_t n,  
ssize_t (*read_fn)(int, void *, size_t),
+						ssize_t (*write_fn)(int, const void *, size_t));
+SMB_OFF_T transfer_file(int infd,int outfd,SMB_OFF_T n);
+void smb_msleep(unsigned int t);
+void become_daemon(BOOL Fork, BOOL no_process_group);
+BOOL yesno(char *p);
+void *malloc_(size_t size);
+void *malloc_array(size_t el_size, unsigned int count);
+void *memalign_array(size_t el_size, size_t align, unsigned int count);
+void *calloc_array(size_t size, size_t nmemb);
+void *Realloc(void *p, size_t size, BOOL free_old_on_error);
+void *realloc_array(void *p, size_t el_size, unsigned int count,  
BOOL free_old_on_error);
+void add_to_large_array(TALLOC_CTX *mem_ctx, size_t element_size,
+			void *element, void *_array, uint32 *num_elements,
+			ssize_t *array_size);
+void safe_free(void *p);
+BOOL get_myname(char *my_name);
+BOOL get_mydnsfullname(fstring my_dnsname);
+BOOL get_mydnsdomname(fstring my_domname);
+int interpret_protocol(const char *str,int def);
+BOOL is_ipaddress(const char *str);
+uint32 interpret_addr(const char *str);
+struct in_addr *interpret_addr2(const char *str);
+BOOL is_zero_ip(struct in_addr ip);
+void zero_ip(struct in_addr *ip);
+char *automount_lookup(const char *user_name);
+char *automount_lookup(const char *user_name);
+BOOL same_net(struct in_addr ip1,struct in_addr ip2,struct in_addr  
mask);
+BOOL process_exists(const struct server_id pid);
+BOOL process_exists_by_pid(pid_t pid);
+const char *uidtoname(uid_t uid);
+char *gidtoname(gid_t gid);
+uid_t nametouid(const char *name);
+gid_t nametogid(const char *name);
+void smb_panic(const char *const why);
+void log_stack_trace(void);
+const char *readdirname(SMB_STRUCT_DIR *p);
+BOOL is_in_path(const char *name, name_compare_entry *namelist, BOOL  
case_sensitive);
+void set_namearray(name_compare_entry **ppname_array, char *namelist);
+void free_namearray(name_compare_entry *name_array);
+BOOL fcntl_lock(int fd, int op, SMB_OFF_T offset, SMB_OFF_T count,  
int type);
+BOOL fcntl_getlock(int fd, SMB_OFF_T *poffset, SMB_OFF_T *pcount,  
int *ptype, pid_t *ppid);
+BOOL is_myname(const char *s);
+BOOL is_myname_or_ipaddr(const char *s);
+BOOL is_myworkgroup(const char *s);
+void ra_lanman_string( const char *native_lanman );
+void set_remote_arch(enum remote_arch_types type);
+enum remote_arch_types get_remote_arch(void);
+void print_asc(int level, const unsigned char *buf,int len);
+void dump_data(int level, const unsigned char *buf,int len);
+void dump_data_pw(const char *msg, const uchar * data, size_t len);
+char *tab_depth(int depth);
+int str_checksum(const char *s);
+void zero_free(void *p, size_t size);
+int set_maxfiles(int requested_max);
+int smb_mkstemp(char *name_template);
+void *smb_xmalloc_array(size_t size, unsigned int count);
+void *smb_xmemdup(const void *p, size_t size);
+char *smb_xstrdup(const char *s);
+char *smb_xstrndup(const char *s, size_t n);
+void *memdup(const void *p, size_t size);
+char *myhostname(void);
+char *lock_path(const char *name);
+char *pid_path(const char *name);
+char *lib_path(const char *name);
+const char *shlib_ext(void);
+char *parent_dirname(const char *path);
+BOOL parent_dirname_talloc(TALLOC_CTX *mem_ctx, const char *dir,
+			   char **parent, const char **name);
+BOOL ms_has_wild(const char *s);
+BOOL ms_has_wild_w(const smb_ucs2_t *s);
+BOOL mask_match(const char *string, char *pattern, BOOL  
is_case_sensitive);
+BOOL mask_match_search(const char *string, char *pattern, BOOL  
is_case_sensitive);
+BOOL mask_match_list(const char *string, char **list, int listLen,  
BOOL is_case_sensitive);
+BOOL unix_wild_match(const char *pattern, const char *string);
+BOOL name_to_fqdn(fstring fqdn, const char *name);
+void *talloc_check_name_abort(const void *ptr, const char *name);
+int _Insure_trap_error(int a1, int a2, int a3, int a4, int a5, int a6);
+uint32 map_share_mode_to_deny_mode(uint32 share_access, uint32  
private_options);
+pid_t procid_to_pid(const struct server_id *proc);
+struct server_id pid_to_procid(pid_t pid);
+struct server_id procid_self(void);
+struct server_id server_id_self(void);
+BOOL procid_equal(const struct server_id *p1, const struct server_id  
*p2);
+BOOL cluster_id_equal(const struct server_id *id1,
+		      const struct server_id *id2);
+BOOL procid_is_me(const struct server_id *pid);
+struct server_id interpret_pid(const char *pid_string);
+char *procid_str_static(const struct server_id *pid);
+char *procid_str(TALLOC_CTX *mem_ctx, const struct server_id *pid);
+BOOL procid_valid(const struct server_id *pid);
+BOOL procid_is_local(const struct server_id *pid);
+int this_is_smp(void);
+BOOL is_offset_safe(const char *buf_base, size_t buf_len, char *ptr,  
size_t off);
+char *get_safe_ptr(const char *buf_base, size_t buf_len, char *ptr,  
size_t off);
+char *get_safe_str_ptr(const char *buf_base, size_t buf_len, char  
*ptr, size_t off);
+int get_safe_SVAL(const char *buf_base, size_t buf_len, char *ptr,  
size_t off, int failval);
+int get_safe_IVAL(const char *buf_base, size_t buf_len, char *ptr,  
size_t off, int failval);
+void *_talloc_zero_zeronull(const void *ctx, size_t size, const char  
*name);
+void *_talloc_memdup_zeronull(const void *t, const void *p, size_t  
size, const char *name);
+void *_talloc_array_zeronull(const void *ctx, size_t el_size,  
unsigned count, const char *name);
+void *_talloc_zero_array_zeronull(const void *ctx, size_t el_size,  
unsigned count, const char *name);
+void *talloc_zeronull(const void *context, size_t size, const char  
*name);
+
+/* The following definitions come from lib/util_file.c  */
+
+char *fgets_slash(char *s2,int maxlen,XFILE *f);
+char *file_pload(char *syscmd, size_t *size);
+char *fd_load(int fd, size_t *psize, size_t maxsize);
+char *file_load(const char *fname, size_t *size, size_t maxsize);
+BOOL unmap_file(void* start, size_t size);
+void *map_file(char *fname, size_t size);
+char **file_lines_load(const char *fname, int *numlines, size_t  
maxsize);
+char **fd_lines_load(int fd, int *numlines, size_t maxsize);
+char **file_lines_pload(char *syscmd, int *numlines);
+void file_lines_free(char **lines);
+void file_lines_slashcont(char **lines);
+BOOL file_save(const char *fname, void *packet, size_t length);
+
+/* The following definitions come from lib/util_nscd.c  */
+
+void smb_nscd_flush_user_cache(void);
+void smb_nscd_flush_group_cache(void);
+
+/* The following definitions come from lib/util_pw.c  */
+
+struct passwd *tcopy_passwd(TALLOC_CTX *mem_ctx, const struct passwd  
*from) ;
+void flush_pwnam_cache(void);
+struct passwd *getpwnam_alloc(TALLOC_CTX *mem_ctx, const char *name);
+struct passwd *getpwuid_alloc(TALLOC_CTX *mem_ctx, uid_t uid) ;
+
+/* The following definitions come from lib/util_reg.c  */
+
+const char *reg_type_lookup(enum winreg_Type type);
+WERROR reg_pull_multi_sz(TALLOC_CTX *mem_ctx, const void *buf,  
size_t len,
+			 uint32 *num_values, char ***values);
+WERROR registry_pull_value(TALLOC_CTX *mem_ctx,
+			   struct registry_value **pvalue,
+			   enum winreg_Type type, uint8 *data,
+			   uint32 size, uint32 length);
+WERROR registry_push_value(TALLOC_CTX *mem_ctx,
+			   const struct registry_value *value,
+			   DATA_BLOB *presult);
+
+/* The following definitions come from lib/util_seaccess.c  */
+
+void se_map_generic(uint32 *access_mask, struct generic_mapping  
*mapping);
+void se_map_standard(uint32 *access_mask, struct standard_mapping  
*mapping);
+BOOL se_access_check(const SEC_DESC *sd, const NT_USER_TOKEN *token,
+		     uint32 acc_desired, uint32 *acc_granted,
+		     NTSTATUS *status);
+NTSTATUS samr_make_sam_obj_sd(TALLOC_CTX *ctx, SEC_DESC **psd,  
size_t *sd_size);
+
+/* The following definitions come from lib/util_sec.c  */
+
+void sec_init(void);
+uid_t sec_initial_uid(void);
+gid_t sec_initial_gid(void);
+BOOL non_root_mode(void);
+void gain_root_privilege(void);
+void gain_root_group_privilege(void);
+void set_effective_uid(uid_t uid);
+void set_effective_gid(gid_t gid);
+void save_re_uid(void);
+void restore_re_uid_fromroot(void);
+void restore_re_uid(void);
+void save_re_gid(void);
+void restore_re_gid(void);
+int set_re_uid(void);
+void become_user_permanently(uid_t uid, gid_t gid);
+BOOL is_setuid_root(void) ;
+
+/* The following definitions come from lib/util_sid.c  */
+
+const char *sid_type_lookup(uint32 sid_type) ;
+NT_USER_TOKEN *get_system_token(void) ;
+const char *get_global_sam_name(void) ;
+char *sid_to_string(fstring sidstr_out, const DOM_SID *sid);
+const char *sid_string_static(const DOM_SID *sid);
+BOOL string_to_sid(DOM_SID *sidout, const char *sidstr);
+DOM_SID *string_sid_talloc(TALLOC_CTX *mem_ctx, const char *sidstr);
+BOOL sid_append_rid(DOM_SID *sid, uint32 rid);
+BOOL sid_compose(DOM_SID *dst, const DOM_SID *domain_sid, uint32 rid);
+BOOL sid_split_rid(DOM_SID *sid, uint32 *rid);
+BOOL sid_peek_rid(const DOM_SID *sid, uint32 *rid);
+BOOL sid_peek_check_rid(const DOM_SID *exp_dom_sid, const DOM_SID  
*sid, uint32 *rid);
+void sid_copy(DOM_SID *dst, const DOM_SID *src);
+BOOL sid_linearize(char *outbuf, size_t len, const DOM_SID *sid);
+BOOL sid_parse(const char *inbuf, size_t len, DOM_SID *sid);
+int sid_compare(const DOM_SID *sid1, const DOM_SID *sid2);
+int sid_compare_domain(const DOM_SID *sid1, const DOM_SID *sid2);
+BOOL sid_equal(const DOM_SID *sid1, const DOM_SID *sid2);
+size_t sid_size(const DOM_SID *sid);
+BOOL non_mappable_sid(DOM_SID *sid);
+char *sid_binstring(const DOM_SID *sid);
+char *sid_binstring_hex(const DOM_SID *sid);
+DOM_SID *sid_dup_talloc(TALLOC_CTX *ctx, const DOM_SID *src);
+BOOL add_sid_to_array(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+		      DOM_SID **sids, size_t *num);
+BOOL add_sid_to_array_unique(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+			     DOM_SID **sids, size_t *num_sids);
+void del_sid_from_array(const DOM_SID *sid, DOM_SID **sids, size_t  
*num);
+BOOL add_rid_to_array_unique(TALLOC_CTX *mem_ctx,
+				    uint32 rid, uint32 **pp_rids, size_t *p_num);
+BOOL is_null_sid(const DOM_SID *sid);
+
+/* The following definitions come from lib/util_sock.c  */
+
+void client_setfd(int fd);
+char *client_name(void);
+char *client_addr(void);
+char *client_socket_addr(void);
+int client_socket_port(void);
+struct in_addr *client_inaddr(struct sockaddr *sa);
+BOOL is_a_socket(int fd);
+void set_socket_options(int fd, const char *options);
+ssize_t read_udp_socket(int fd,char *buf,size_t len);
+ssize_t read_data_until(int fd,char *buffer,size_t N, const struct  
timeval *endtime);
+ssize_t read_socket_with_timeout(int fd,char *buf,size_t  
mincnt,size_t maxcnt,unsigned int time_out);
+ssize_t read_data(int fd,char *buffer,size_t N);
+ssize_t write_data(int fd, const char *buffer, size_t N);
+BOOL send_keepalive(int client);
+ssize_t read_smb_length(int fd, char *inbuf, unsigned int timeout);
+ssize_t receive_smb_raw(int fd, char *buffer, unsigned int timeout,  
size_t maxlen);
+BOOL receive_smb(int fd, char *buffer, unsigned int timeout);
+BOOL send_smb(int fd, char *buffer);
+int open_socket_in( int type, int port, int dlevel, uint32  
socket_addr, BOOL rebind );
+int open_socket_out(int type, struct in_addr *addr, int port ,int  
timeout);
+BOOL open_any_socket_out(struct sockaddr_in *addrs, int num_addrs,
+			 int timeout, int *fd_index, int *fd);
+int open_udp_socket(const char *host, int port);
+char *get_peer_name(int fd, BOOL force_lookup);
+char *get_peer_addr(int fd);
+int create_pipe_sock(const char *socket_dir,
+		     const char *socket_name,
+		     mode_t dir_perms);
+
+/* The following definitions come from lib/util_str.c  */
+
+BOOL next_token(const char **ptr, char *buff, const char *sep,  
size_t bufsize);
+BOOL next_token_no_ltrim(const char **ptr,
+                         char *buff,
+                         const char *sep,
+                         size_t bufsize);
+BOOL next_token_nr(const char **ptr,char *buff, const char *sep,  
size_t bufsize);
+void set_first_token(char *ptr);
+char **toktocliplist(int *ctok, const char *sep);
+int StrCaseCmp(const char *s, const char *t);
+int StrnCaseCmp(const char *s, const char *t, size_t n);
+BOOL strequal(const char *s1, const char *s2);
+BOOL strnequal(const char *s1,const char *s2,size_t n);
+BOOL strcsequal(const char *s1,const char *s2);
+int strwicmp(const char *psz1, const char *psz2);
+char *strupper_static(const char *s);
+void strnorm(char *s, int case_default);
+BOOL strisnormal(const char *s, int case_default);
+void string_replace( pstring s, char oldc, char newc );
+char *push_skip_string(char *buf);
+char *skip_string(const char *base, size_t len, char *buf);
+size_t str_charnum(const char *s);
+size_t str_ascii_charnum(const char *s);
+BOOL trim_char(char *s,char cfront,char cback);
+BOOL trim_string(char *s,const char *front,const char *back);
+BOOL strhasupper(const char *s);
+BOOL strhaslower(const char *s);
+size_t count_chars(const char *s,char c);
+char *safe_strcpy_fn(const char *fn, int line, char *dest,const char  
*src, size_t maxlength);
+char *safe_strcat_fn(const char *fn, int line, char *dest, const  
char *src, size_t maxlength);
+char *alpha_strcpy_fn(const char *fn, int line, char *dest, const  
char *src, const char *other_safe_chars, size_t maxlength);
+char *StrnCpy_fn(const char *fn, int line,char *dest,const char  
*src,size_t n);
+size_t strhex_to_str(char *p, size_t len, const char *strhex);
+DATA_BLOB strhex_to_data_blob(TALLOC_CTX *mem_ctx, const char  
*strhex) ;
+char *hex_encode(TALLOC_CTX *mem_ctx, const unsigned char *buff_in,  
size_t len);
+BOOL in_list(const char *s, const char *list, BOOL casesensitive);
+void string_free(char **s);
+BOOL string_set(char **dest,const char *src);
+void string_sub2(char *s,const char *pattern, const char *insert,  
size_t len,
+		 BOOL remove_unsafe_characters, BOOL replace_once, BOOL  
allow_trailing_dollar);
+void string_sub_once(char *s, const char *pattern, const char  
*insert, size_t len);
+void string_sub(char *s,const char *pattern, const char *insert,  
size_t len);
+void fstring_sub(char *s,const char *pattern,const char *insert);
+void pstring_sub(char *s,const char *pattern,const char *insert);
+char *realloc_string_sub(char *string, const char *pattern,
+			 const char *insert);
+char *talloc_string_sub(TALLOC_CTX *mem_ctx, const char *src,
+			const char *pattern, const char *insert);
+void all_string_sub(char *s,const char *pattern,const char *insert,  
size_t len);
+smb_ucs2_t *all_string_sub_wa(smb_ucs2_t *s, const char *pattern,
+					     const char *insert);
+const char *octal_string(int i);
+char *string_truncate(char *s, unsigned int length);
+char *strchr_m(const char *src, char c);
+char *strrchr_m(const char *s, char c);
+char *strnrchr_m(const char *s, char c, unsigned int n);
+char *strstr_m(const char *src, const char *findstr);
+void strlower_m(char *s);
+void strupper_m(char *s);
+size_t strlen_m(const char *s);
+size_t strlen_m_term(const char *s);
+size_t strlen_m_term_null(const char *s);
+char *binary_string_rfc2254(char *buf, int len);
+char *binary_string(char *buf, int len);
+int fstr_sprintf(fstring s, const char *fmt, ...);
+char **str_list_make_talloc(TALLOC_CTX *mem_ctx, const char *string,  
const char *sep);
+char **str_list_make(const char *string, const char *sep);
+BOOL str_list_copy(char ***dest, const char **src);
+BOOL str_list_compare(char **list1, char **list2);
+void str_list_free_talloc(TALLOC_CTX *mem_ctx, char ***list);
+void str_list_free(char ***list);
+int str_list_count( const char **list );
+BOOL str_list_sub_basic( char **list, const char *smb_name,
+			 const char *domain_name );
+BOOL str_list_substitute(char **list, const char *pattern, const  
char *insert);
+char* ipstr_list_add(char** ipstr_list, const struct ip_service  
*service);
+char* ipstr_list_make(char** ipstr_list, const struct ip_service*  
ip_list, int ip_count);
+int ipstr_list_parse(const char* ipstr_list, struct ip_service  
**ip_list);
+void ipstr_list_free(char* ipstr_list);
+void rfc1738_unescape(char *buf);
+DATA_BLOB base64_decode_data_blob(const char *s);
+void base64_decode_inplace(char *s);
+char * base64_encode_data_blob(DATA_BLOB data);
+SMB_BIG_UINT STR_TO_SMB_BIG_UINT(const char *nptr, const char  
**entptr);
+SMB_OFF_T conv_str_size(const char * str);
+void string_append(char **left, const char *right);
+BOOL add_string_to_array(TALLOC_CTX *mem_ctx,
+			 const char *str, const char ***strings,
+			 int *num);
+void sprintf_append(TALLOC_CTX *mem_ctx, char **string, ssize_t *len,
+		    size_t *bufsize, const char *fmt, ...);
+char *sstring_sub(const char *src, char front, char back);
+BOOL validate_net_name( const char *name, const char *invalid_chars,  
int max_len );
+size_t ascii_len_n(const char *src, size_t n);
+size_t utf16_len(const void *buf);
+size_t utf16_len_n(const void *src, size_t n);
+char *escape_shell_string(const char *src);
+
+/* The following definitions come from lib/util_tdb.c  */
+
+TDB_DATA make_tdb_data(const uint8 *dptr, size_t dsize);
+TDB_DATA string_tdb_data(const char *string);
+TDB_DATA string_term_tdb_data(const char *string);
+int tdb_chainlock_with_timeout( TDB_CONTEXT *tdb, TDB_DATA key,  
unsigned int timeout);
+int tdb_lock_bystring(TDB_CONTEXT *tdb, const char *keyval);
+int tdb_lock_bystring_with_timeout(TDB_CONTEXT *tdb, const char  
*keyval,
+				   int timeout);
+void tdb_unlock_bystring(TDB_CONTEXT *tdb, const char *keyval);
+int tdb_read_lock_bystring_with_timeout(TDB_CONTEXT *tdb, const char  
*keyval, unsigned int timeout);
+void tdb_read_unlock_bystring(TDB_CONTEXT *tdb, const char *keyval);
+int32 tdb_fetch_int32_byblob(TDB_CONTEXT *tdb, TDB_DATA key);
+int32 tdb_fetch_int32(TDB_CONTEXT *tdb, const char *keystr);
+int tdb_store_int32_byblob(TDB_CONTEXT *tdb, TDB_DATA key, int32 v);
+int tdb_store_int32(TDB_CONTEXT *tdb, const char *keystr, int32 v);
+BOOL tdb_fetch_uint32_byblob(TDB_CONTEXT *tdb, TDB_DATA key, uint32  
*value);
+BOOL tdb_fetch_uint32(TDB_CONTEXT *tdb, const char *keystr, uint32  
*value);
+BOOL tdb_store_uint32_byblob(TDB_CONTEXT *tdb, TDB_DATA key, uint32  
value);
+BOOL tdb_store_uint32(TDB_CONTEXT *tdb, const char *keystr, uint32  
value);
+int tdb_store_bystring(TDB_CONTEXT *tdb, const char *keystr,  
TDB_DATA data, int flags);
+int tdb_trans_store_bystring(TDB_CONTEXT *tdb, const char *keystr,
+			     TDB_DATA data, int flags);
+TDB_DATA tdb_fetch_bystring(TDB_CONTEXT *tdb, const char *keystr);
+int tdb_delete_bystring(TDB_CONTEXT *tdb, const char *keystr);
+int32 tdb_change_int32_atomic(TDB_CONTEXT *tdb, const char *keystr,  
int32 *oldval, int32 change_val);
+BOOL tdb_change_uint32_atomic(TDB_CONTEXT *tdb, const char *keystr,  
uint32 *oldval, uint32 change_val);
+size_t tdb_pack_va(uint8 *buf, int bufsize, const char *fmt, va_list  
ap);
+size_t tdb_pack(uint8 *buf, int bufsize, const char *fmt, ...);
+BOOL tdb_pack_append(TALLOC_CTX *mem_ctx, uint8 **buf, size_t *len,
+		     const char *fmt, ...);
+int tdb_unpack(const uint8 *buf, int bufsize, const char *fmt, ...);
+TDB_CONTEXT *tdb_open_log(const char *name, int hash_size, int  
tdb_flags,
+			  int open_flags, mode_t mode);
+int tdb_traverse_delete_fn(TDB_CONTEXT *the_tdb, TDB_DATA key,  
TDB_DATA dbuf,
+                     void *state);
+void tdb_search_list_free(TDB_LIST_NODE* node);
+int tdb_trans_store(struct tdb_context *tdb, TDB_DATA key, TDB_DATA  
dbuf,
+		    int flag);
+int tdb_trans_delete(struct tdb_context *tdb, TDB_DATA key);
+struct tdb_wrap *tdb_wrap_open(TALLOC_CTX *mem_ctx,
+			       const char *name, int hash_size, int tdb_flags,
+			       int open_flags, mode_t mode);
+NTSTATUS map_nt_error_from_tdb(enum TDB_ERROR err);
+
+/* The following definitions come from lib/util_unistr.c  */
+
+void gfree_case_tables(void);
+void load_case_tables(void);
+int check_dos_char(smb_ucs2_t c);
+void init_doschar_table(void);
+void init_valid_table(void);
+size_t dos_PutUniCode(char *dst,const char *src, size_t len, BOOL  
null_terminate);
+char *skip_unibuf(char *src, size_t len);
+int rpcstr_pull(char* dest, void *src, int dest_len, int src_len,  
int flags);
+int rpcstr_pull_unistr2_fstring(char *dest, UNISTR2 *src);
+char *rpcstr_pull_unistr2_talloc(TALLOC_CTX *mem_ctx, const UNISTR2  
*src);
+int rpcstr_push(void* dest, const char *src, size_t dest_len, int  
flags);
+void unistr2_to_ascii(char *dest, const UNISTR2 *str, size_t maxlen);
+void unistr3_to_ascii(char *dest, const UNISTR3 *str, size_t maxlen);
+const char *unistr2_static(const UNISTR2 *str);
+char *unistr2_tdup(TALLOC_CTX *ctx, const UNISTR2 *str);
+smb_ucs2_t toupper_w(smb_ucs2_t val);
+smb_ucs2_t tolower_w( smb_ucs2_t val );
+BOOL islower_w(smb_ucs2_t c);
+BOOL isupper_w(smb_ucs2_t c);
+BOOL isvalid83_w(smb_ucs2_t c);
+size_t strlen_w(const smb_ucs2_t *src);
+size_t strnlen_w(const smb_ucs2_t *src, size_t max);
+smb_ucs2_t *strchr_w(const smb_ucs2_t *s, smb_ucs2_t c);
+smb_ucs2_t *strchr_wa(const smb_ucs2_t *s, char c);
+smb_ucs2_t *strrchr_w(const smb_ucs2_t *s, smb_ucs2_t c);
+smb_ucs2_t *strnrchr_w(const smb_ucs2_t *s, smb_ucs2_t c, unsigned  
int n);
+smb_ucs2_t *strstr_w(const smb_ucs2_t *s, const smb_ucs2_t *ins);
+BOOL strlower_w(smb_ucs2_t *s);
+BOOL strupper_w(smb_ucs2_t *s);
+void strnorm_w(smb_ucs2_t *s, int case_default);
+int strcmp_w(const smb_ucs2_t *a, const smb_ucs2_t *b);
+int strncmp_w(const smb_ucs2_t *a, const smb_ucs2_t *b, size_t len);
+int strcasecmp_w(const smb_ucs2_t *a, const smb_ucs2_t *b);
+int strncasecmp_w(const smb_ucs2_t *a, const smb_ucs2_t *b, size_t  
len);
+BOOL strequal_w(const smb_ucs2_t *s1, const smb_ucs2_t *s2);
+BOOL strnequal_w(const smb_ucs2_t *s1,const smb_ucs2_t *s2,size_t n);
+smb_ucs2_t *strdup_w(const smb_ucs2_t *src);
+smb_ucs2_t *strndup_w(const smb_ucs2_t *src, size_t len);
+smb_ucs2_t *strncpy_w(smb_ucs2_t *dest, const smb_ucs2_t *src, const  
size_t max);
+smb_ucs2_t *strncat_w(smb_ucs2_t *dest, const smb_ucs2_t *src, const  
size_t max);
+smb_ucs2_t *strcat_w(smb_ucs2_t *dest, const smb_ucs2_t *src);
+void string_replace_w(smb_ucs2_t *s, smb_ucs2_t oldc, smb_ucs2_t newc);
+BOOL trim_string_w(smb_ucs2_t *s, const smb_ucs2_t *front,
+				  const smb_ucs2_t *back);
+int strcmp_wa(const smb_ucs2_t *a, const char *b);
+int strncmp_wa(const smb_ucs2_t *a, const char *b, size_t len);
+smb_ucs2_t *strpbrk_wa(const smb_ucs2_t *s, const char *p);
+smb_ucs2_t *strstr_wa(const smb_ucs2_t *s, const char *ins);
+BOOL trim_string_wa(smb_ucs2_t *s, const char *front,
+				  const char *back);
+int unistrlen(uint16 *s);
+int unistrcpy(uint16 *dst, uint16 *src);
+UNISTR2* ucs2_to_unistr2(TALLOC_CTX *ctx, UNISTR2* dst, smb_ucs2_t*  
src);
+int toupper_ascii(int c);
+int tolower_ascii(int c);
+int isupper_ascii(int c);
+int islower_ascii(int c);
+
+/* The following definitions come from lib/util_uuid.c  */
+
+void smb_uuid_pack(const struct GUID uu, UUID_FLAT *ptr);
+void smb_uuid_unpack(const UUID_FLAT in, struct GUID *uu);
+struct GUID smb_uuid_unpack_static(const UUID_FLAT in);
+void smb_uuid_generate_random(struct GUID *uu);
+char *smb_uuid_to_string(const struct GUID uu);
+const char *smb_uuid_string_static(const struct GUID uu);
+BOOL smb_string_to_uuid(const char *in, struct GUID* uu);
+
+/* The following definitions come from lib/version.c  */
+
+const char *samba_version_string(void);
+
+/* The following definitions come from lib/wins_srv.c  */
+
+BOOL wins_srv_is_dead(struct in_addr wins_ip, struct in_addr src_ip);
+void wins_srv_alive(struct in_addr wins_ip, struct in_addr src_ip);
+void wins_srv_died(struct in_addr wins_ip, struct in_addr src_ip);
+unsigned wins_srv_count(void);
+char **wins_srv_tags(void);
+void wins_srv_tags_free(char **list);
+struct in_addr wins_srv_ip_tag(const char *tag, struct in_addr src_ip);
+unsigned wins_srv_count_tag(const char *tag);
+
+/* The following definitions come from lib/xfile.c  */
+
+int x_setvbuf(XFILE *f, char *buf, int mode, size_t size);
+XFILE *x_fopen(const char *fname, int flags, mode_t mode);
+XFILE *x_fdup(const XFILE *f);
+int x_fclose(XFILE *f);
+size_t x_fwrite(const void *p, size_t size, size_t nmemb, XFILE *f);
+int x_fileno(const XFILE *f);
+int x_fflush(XFILE *f);
+void x_setbuffer(XFILE *f, char *buf, size_t size);
+void x_setbuf(XFILE *f, char *buf);
+void x_setlinebuf(XFILE *f);
+int x_feof(XFILE *f);
+int x_ferror(XFILE *f);
+int x_fgetc(XFILE *f);
+size_t x_fread(void *p, size_t size, size_t nmemb, XFILE *f);
+char *x_fgets(char *s, int size, XFILE *stream) ;
+off_t x_tseek(XFILE *f, off_t offset, int whence);
+
+/* The following definitions come from libads/ads_status.c  */
+
+ADS_STATUS ads_build_error(enum ads_error_type etype,
+			   int rc, int minor_status);
+ADS_STATUS ads_build_nt_error(enum ads_error_type etype,
+			   NTSTATUS nt_status);
+NTSTATUS ads_ntstatus(ADS_STATUS status);
+const char *ads_errstr(ADS_STATUS status);
+NTSTATUS gss_err_to_ntstatus(uint32 maj, uint32 min);
+
+/* The following definitions come from libads/ads_struct.c  */
+
+char *ads_build_path(const char *realm, const char *sep, const char  
*field, int reverse);
+char *ads_build_dn(const char *realm);
+char *ads_build_domain(const char *dn);
+ADS_STRUCT *ads_init(const char *realm,
+		     const char *workgroup,
+		     const char *ldap_server);
+void ads_destroy(ADS_STRUCT **ads);
+
+/* The following definitions come from libads/ads_utils.c  */
+
+uint32 ads_acb2uf(uint32 acb);
+uint32 ads_uf2acb(uint32 uf);
+uint32 ads_uf2atype(uint32 uf);
+uint32 ads_gtype2atype(uint32 gtype);
+enum lsa_SidType ads_atype_map(uint32 atype);
+
+/* The following definitions come from libads/authdata.c  */
+
+char *pac_group_attr_string(uint32 attr);
+
+/* The following definitions come from libads/cldap.c  */
+
+BOOL ads_cldap_netlogon(const char *server, const char *realm,   
struct cldap_netlogon_reply *reply);
+
+/* The following definitions come from libads/disp_sec.c  */
+
+void ads_disp_sd(SEC_DESC *sd);
+
+/* The following definitions come from libads/dns.c  */
+
+NTSTATUS ads_dns_lookup_ns( TALLOC_CTX *ctx, const char *dnsdomain,  
struct dns_rr_ns **nslist, int *numns );
+BOOL sitename_store(const char *realm, const char *sitename);
+char *sitename_fetch(const char *realm);
+BOOL stored_sitename_changed(const char *realm, const char *sitename);
+NTSTATUS ads_dns_query_internal(TALLOC_CTX *ctx,
+				const char *servicename,
+				const char *realm,
+				const char *sitename,
+				struct dns_rr_srv **dclist,
+				int *numdcs );
+NTSTATUS ads_dns_query_dcs(TALLOC_CTX *ctx,
+			const char *realm,
+			const char *sitename,
+			struct dns_rr_srv **dclist,
+			int *numdcs );
+NTSTATUS ads_dns_query_kdcs(TALLOC_CTX *ctx,
+			const char *realm,
+			const char *sitename,
+			struct dns_rr_srv **dclist,
+			int *numdcs );
+
+/* The following definitions come from libads/kerberos.c  */
+
+int kerberos_kinit_password_ext(const char *principal,
+				const char *password,
+				int time_offset,
+				time_t *expire_time,
+				time_t *renew_till_time,
+				const char *cache_name,
+				BOOL request_pac,
+				BOOL add_netbios_addr,
+				time_t renewable_time,
+				NTSTATUS *ntstatus);
+int ads_kinit_password(ADS_STRUCT *ads);
+int ads_kdestroy(const char *cc_name);
+char* kerberos_standard_des_salt( void );
+BOOL kerberos_secrets_store_des_salt( const char* salt );
+char* kerberos_secrets_fetch_des_salt( void );
+BOOL kerberos_secrets_store_salting_principal(const char *service,
+					      int enctype,
+					      const char *principal);
+int kerberos_kinit_password(const char *principal,
+			    const char *password,
+			    int time_offset,
+			    const char *cache_name);
+BOOL create_local_private_krb5_conf_for_domain(const char *realm,  
const char *domain,
+					const char *sitename, struct in_addr ip);
+
+/* The following definitions come from libads/kerberos_keytab.c  */
+
+int ads_keytab_add_entry(ADS_STRUCT *ads, const char *srvPrinc);
+int ads_keytab_flush(ADS_STRUCT *ads);
+int ads_keytab_create_default(ADS_STRUCT *ads);
+int ads_keytab_list(void);
+
+/* The following definitions come from libads/kerberos_verify.c  */
+
+NTSTATUS ads_verify_ticket(TALLOC_CTX *mem_ctx,
+			   const char *realm,
+			   time_t time_offset,
+			   const DATA_BLOB *ticket,
+			   char **principal,
+			   PAC_DATA **pac_data,
+			   DATA_BLOB *ap_rep,
+			   DATA_BLOB *session_key);
+
+/* The following definitions come from libads/krb5_errs.c  */
+
+
+/* The following definitions come from libads/krb5_setpw.c  */
+
+ADS_STATUS ads_krb5_set_password(const char *kdc_host, const char  
*princ,
+				 const char *newpw, int time_offset);
+ADS_STATUS kerberos_set_password(const char *kpasswd_server,
+				 const char *auth_principal, const char *auth_password,
+				 const char *target_principal, const char *new_password,
+				 int time_offset);
+ADS_STATUS ads_set_machine_password(ADS_STRUCT *ads,
+				    const char *machine_account,
+				    const char *password);
+
+/* The following definitions come from libads/ldap.c  */
+
+BOOL ads_sitename_match(ADS_STRUCT *ads);
+BOOL ads_closest_dc(ADS_STRUCT *ads);
+BOOL ads_try_connect(ADS_STRUCT *ads, const char *server );
+ADS_STATUS ads_connect(ADS_STRUCT *ads);
+ADS_STATUS ads_do_search_all_fn(ADS_STRUCT *ads, const char *bind_path,
+				int scope, const char *expr, const char **attrs,
+				BOOL(*fn)(char *, void **, void *),
+				void *data_area);
+void ads_memfree(ADS_STRUCT *ads, void *mem);
+char *ads_parent_dn(const char *dn);
+ADS_MODLIST ads_init_mods(TALLOC_CTX *ctx);
+ADS_STATUS ads_mod_str(TALLOC_CTX *ctx, ADS_MODLIST *mods,
+		       const char *name, const char *val);
+ADS_STATUS ads_mod_strlist(TALLOC_CTX *ctx, ADS_MODLIST *mods,
+			   const char *name, const char **vals);
+ADS_STATUS ads_gen_mod(ADS_STRUCT *ads, const char *mod_dn,  
ADS_MODLIST mods);
+ADS_STATUS ads_gen_add(ADS_STRUCT *ads, const char *new_dn,  
ADS_MODLIST mods);
+ADS_STATUS ads_del_dn(ADS_STRUCT *ads, char *del_dn);
+char *ads_ou_string(ADS_STRUCT *ads, const char *org_unit);
+char *ads_default_ou_string(ADS_STRUCT *ads, const char *wknguid);
+ADS_STATUS ads_add_strlist(TALLOC_CTX *ctx, ADS_MODLIST *mods,
+				const char *name, const char **vals);
+uint32 ads_get_kvno(ADS_STRUCT *ads, const char *machine_name);
+ADS_STATUS ads_clear_service_principal_names(ADS_STRUCT *ads, const  
char *machine_name);
+ADS_STATUS ads_add_service_principal_name(ADS_STRUCT *ads, const  
char *machine_name,
+                                          const char *my_fqdn, const  
char *spn);
+ADS_STATUS ads_create_machine_acct(ADS_STRUCT *ads, const char  
*machine_name,
+                                   const char *org_unit);
+ADS_STATUS ads_move_machine_acct(ADS_STRUCT *ads, const char  
*machine_name,
+                                 const char *org_unit, BOOL *moved);
+int ads_count_replies(ADS_STRUCT *ads, void *res);
+ADS_STATUS ads_USN(ADS_STRUCT *ads, uint32 *usn);
+ADS_STATUS ads_current_time(ADS_STRUCT *ads);
+ADS_STATUS ads_domain_func_level(ADS_STRUCT *ads, uint32 *val);
+ADS_STATUS ads_domain_sid(ADS_STRUCT *ads, DOM_SID *sid);
+ADS_STATUS ads_site_dn(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx, const  
char **site_name);
+ADS_STATUS ads_site_dn_for_machine(ADS_STRUCT *ads, TALLOC_CTX  
*mem_ctx, const char *computer_name, const char **site_dn);
+ADS_STATUS ads_upn_suffixes(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx,  
char ***suffixes, size_t *num_suffixes);
+BOOL ads_get_dn_from_extended_dn(TALLOC_CTX *mem_ctx,
+				 const char *extended_dn,
+				 char **dn);
+BOOL ads_get_sid_from_extended_dn(TALLOC_CTX *mem_ctx,
+				  const char *extended_dn,
+				  enum ads_extended_dn_flags flags,
+				  DOM_SID *sid);
+char* ads_get_dnshostname( ADS_STRUCT *ads, TALLOC_CTX *ctx, const  
char *machine_name );
+char* ads_get_upn( ADS_STRUCT *ads, TALLOC_CTX *ctx, const char  
*machine_name );
+char* ads_get_samaccountname( ADS_STRUCT *ads, TALLOC_CTX *ctx,  
const char *machine_name );
+ADS_STATUS ads_join_realm(ADS_STRUCT *ads, const char *machine_name,
+			uint32 account_type, const char *org_unit);
+ADS_STATUS ads_leave_realm(ADS_STRUCT *ads, const char *hostname);
+
+/* The following definitions come from libads/ldap_printer.c  */
+
+ADS_STATUS ads_mod_printer_entry(ADS_STRUCT *ads, char *prt_dn,
+				 TALLOC_CTX *ctx, const ADS_MODLIST *mods);
+ADS_STATUS ads_add_printer_entry(ADS_STRUCT *ads, char *prt_dn,
+					TALLOC_CTX *ctx, ADS_MODLIST *mods);
+WERROR get_remote_printer_publishing_data(struct rpc_pipe_client *cli,
+					  TALLOC_CTX *mem_ctx,
+					  ADS_MODLIST *mods,
+					  const char *printer);
+BOOL get_local_printer_publishing_data(TALLOC_CTX *mem_ctx,
+				       ADS_MODLIST *mods,
+				       NT_PRINTER_DATA *data);
+
+/* The following definitions come from libads/ldap_schema.c  */
+
+ADS_STATUS ads_get_attrnames_by_oids(ADS_STRUCT *ads, TALLOC_CTX  
*mem_ctx,
+				     const char *schema_path,
+				     const char **OIDs, size_t num_OIDs,
+				     char ***OIDs_out, char ***names, size_t *count);
+const char *ads_get_attrname_by_oid(ADS_STRUCT *ads, const char  
*schema_path, TALLOC_CTX *mem_ctx, const char * OID);
+ADS_STATUS ads_check_posix_schema_mapping(TALLOC_CTX *mem_ctx,
+					  ADS_STRUCT *ads,
+					  enum wb_posix_mapping map_type,
+					  struct posix_schema **s ) ;
+
+/* The following definitions come from libads/ldap_user.c  */
+
+ADS_STATUS ads_add_user_acct(ADS_STRUCT *ads, const char *user,
+			     const char *container, const char *fullname);
+ADS_STATUS ads_add_group_acct(ADS_STRUCT *ads, const char *group,
+			      const char *container, const char *comment);
+
+/* The following definitions come from libads/ldap_utils.c  */
+
+ADS_STATUS ads_ranged_search(ADS_STRUCT *ads,
+			     TALLOC_CTX *mem_ctx,
+			     int scope,
+			     const char *base,
+			     const char *filter,
+			     void *args,
+			     const char *range_attr,
+			     char ***strings,
+			     size_t *num_strings);
+ADS_STATUS ads_ranged_search_internal(ADS_STRUCT *ads,
+				      TALLOC_CTX *mem_ctx,
+				      int scope,
+				      const char *base,
+				      const char *filter,
+				      const char **attrs,
+				      void *args,
+				      const char *range_attr,
+				      char ***strings,
+				      size_t *num_strings,
+				      uint32 *first_usn,
+				      int *num_retries,
+				      BOOL *more_values);
+
+/* The following definitions come from libads/sasl.c  */
+
+ADS_STATUS ads_sasl_bind(ADS_STRUCT *ads);
+
+/* The following definitions come from libads/util.c  */
+
+ADS_STATUS ads_change_trust_account_password(ADS_STRUCT *ads, char  
*host_principal);
+
+/* The following definitions come from libgpo/gpo_fetch.c  */
+
+NTSTATUS ads_gpo_explode_filesyspath(ADS_STRUCT *ads,
+				     TALLOC_CTX *mem_ctx,
+				     const char *file_sys_path,
+				     char **server,
+				     char **service,
+				     char **nt_path,
+				     char **unix_path);
+NTSTATUS ads_gpo_prepare_local_store(ADS_STRUCT *ads,
+				     TALLOC_CTX *mem_ctx,
+				     const char *unix_path);
+NTSTATUS ads_fetch_gpo_files(ADS_STRUCT *ads,
+			    TALLOC_CTX *mem_ctx,
+			    struct cli_state *cli,
+			    struct GROUP_POLICY_OBJECT *gpo);
+NTSTATUS ads_gpo_get_sysvol_gpt_version(ADS_STRUCT *ads,
+					TALLOC_CTX *mem_ctx,
+					const char *unix_path,
+					uint32 *sysvol_version,
+					char **display_name);
+
+/* The following definitions come from libgpo/gpo_filesync.c  */
+
+NTSTATUS gpo_copy_file(TALLOC_CTX *mem_ctx,
+		       struct cli_state *cli,
+		       const char *nt_path,
+		       const char *unix_path);
+NTSTATUS gpo_sync_directories(TALLOC_CTX *mem_ctx,
+			      struct cli_state *cli,
+			      const char *nt_path,
+			      const char *local_path);
+
+/* The following definitions come from libgpo/gpo_ldap.c  */
+
+ADS_STATUS ads_parse_gp_ext(TALLOC_CTX *mem_ctx,
+			    const char *extension_raw,
+			    struct GP_EXT *gp_ext);
+ADS_STATUS ads_parse_gplink(TALLOC_CTX *mem_ctx,
+			    const char *gp_link_raw,
+			    uint32 options,
+			    struct GP_LINK *gp_link);
+ADS_STATUS ads_get_gpo_link(ADS_STRUCT *ads,
+			    TALLOC_CTX *mem_ctx,
+			    const char *link_dn,
+			    struct GP_LINK *gp_link_struct);
+ADS_STATUS ads_add_gpo_link(ADS_STRUCT *ads,
+			    TALLOC_CTX *mem_ctx,
+			    const char *link_dn,
+			    const char *gpo_dn,
+			    uint32 gpo_opt);
+ADS_STATUS ads_delete_gpo_link(ADS_STRUCT *ads,
+			       TALLOC_CTX *mem_ctx,
+			       const char *link_dn,
+			       const char *gpo_dn);
+ADS_STATUS ads_get_gpo(ADS_STRUCT *ads,
+		       TALLOC_CTX *mem_ctx,
+		       const char *gpo_dn,
+		       const char *display_name,
+		       const char *guid_name,
+		       struct GROUP_POLICY_OBJECT *gpo);
+ADS_STATUS add_gplink_to_gpo_list(ADS_STRUCT *ads,
+				  TALLOC_CTX *mem_ctx,
+				  struct GROUP_POLICY_OBJECT **gpo_list,
+				  const char *link_dn,
+				  struct GP_LINK *gp_link,
+				  enum GPO_LINK_TYPE link_type,
+				  BOOL only_add_forced_gpos,
+				  struct GPO_SID_TOKEN *token);
+ADS_STATUS ads_get_gpo_sid_token(ADS_STRUCT *ads,
+				TALLOC_CTX *mem_ctx,
+				const char *dn,
+				struct GPO_SID_TOKEN **token);
+ADS_STATUS ads_get_gpo_list(ADS_STRUCT *ads,
+			    TALLOC_CTX *mem_ctx,
+			    const char *dn,
+			    uint32 flags,
+			    struct GROUP_POLICY_OBJECT **gpo_list);
+
+/* The following definitions come from libgpo/gpo_parse.c  */
+
+NTSTATUS parse_gpt_ini(TALLOC_CTX *mem_ctx, const char *filename,  
uint32 *version, char **display_name);
+
+/* The following definitions come from libgpo/gpo_sec.c  */
+
+NTSTATUS gpo_apply_security_filtering(const struct  
GROUP_POLICY_OBJECT *gpo,
+				      const struct GPO_SID_TOKEN *token);
+
+/* The following definitions come from libgpo/gpo_util.c  */
+
+const char *cse_gpo_guid_string_to_name(const char *guid);
+const char *cse_snapin_gpo_guid_string_to_name(const char *guid);
+void dump_gp_ext(struct GP_EXT *gp_ext, int debuglevel);
+void dump_gpo(TALLOC_CTX *mem_ctx, struct GROUP_POLICY_OBJECT *gpo,  
int debuglevel) ;
+void dump_gplink(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx, struct  
GP_LINK *gp_link);
+ADS_STATUS process_extension_with_snapin(ADS_STRUCT *ads,
+					 TALLOC_CTX *mem_ctx,
+					 const char *extension_guid,
+					 const char *snapin_guid);
+ADS_STATUS gpo_process_a_gpo(ADS_STRUCT *ads,
+			     TALLOC_CTX *mem_ctx,
+			     struct GROUP_POLICY_OBJECT *gpo,
+			     const char *extension_guid,
+			     uint32 flags);
+ADS_STATUS gpo_process_gpo_list(ADS_STRUCT *ads,
+				TALLOC_CTX *mem_ctx,
+				struct GROUP_POLICY_OBJECT **gpo_list,
+				const char *extensions_guid,
+				uint32 flags);
+ADS_STATUS gpo_snapin_handler_none(ADS_STRUCT *ads,
+				   TALLOC_CTX *mem_ctx,
+				   const char *extension_guid,
+				   const char *snapin_guid);
+ADS_STATUS gpo_snapin_handler_security_settings(ADS_STRUCT *ads,
+						TALLOC_CTX *mem_ctx,
+						const char *extension_guid,
+						const char *snapin_guid);
+ADS_STATUS gpo_lockout_policy(ADS_STRUCT *ads,
+			      TALLOC_CTX *mem_ctx,
+			      const char *hostname,
+			      SAM_UNK_INFO_12 *lockout_policy);
+ADS_STATUS gpo_password_policy(ADS_STRUCT *ads,
+			       TALLOC_CTX *mem_ctx,
+			       const char *hostname,
+			       SAM_UNK_INFO_1 *password_policy);
+NTSTATUS check_refresh_gpo(ADS_STRUCT *ads,
+			   TALLOC_CTX *mem_ctx,
+			   struct GROUP_POLICY_OBJECT *gpo,
+			   struct cli_state **cli_out);
+NTSTATUS check_refresh_gpo_list(ADS_STRUCT *ads,
+				TALLOC_CTX *mem_ctx,
+				struct GROUP_POLICY_OBJECT *gpo_list);
+
+/* The following definitions come from librpc/gen_ndr/ndr_dfs.c  */
+
+NTSTATUS ndr_push_dfs_Info0(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info0 *r);
+NTSTATUS ndr_pull_dfs_Info0(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info0 *r);
+NTSTATUS ndr_push_dfs_Info1(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info1 *r);
+NTSTATUS ndr_pull_dfs_Info1(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info1 *r);
+NTSTATUS ndr_push_dfs_Info2(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info2 *r);
+NTSTATUS ndr_pull_dfs_Info2(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info2 *r);
+NTSTATUS ndr_push_dfs_StorageInfo(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_StorageInfo *r);
+NTSTATUS ndr_pull_dfs_StorageInfo(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_StorageInfo *r);
+NTSTATUS ndr_push_dfs_Info3(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info3 *r);
+NTSTATUS ndr_pull_dfs_Info3(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info3 *r);
+NTSTATUS ndr_push_dfs_Info4(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info4 *r);
+NTSTATUS ndr_pull_dfs_Info4(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info4 *r);
+NTSTATUS ndr_push_dfs_Info100(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info100 *r);
+NTSTATUS ndr_pull_dfs_Info100(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info100 *r);
+NTSTATUS ndr_push_dfs_Info101(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info101 *r);
+NTSTATUS ndr_pull_dfs_Info101(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info101 *r);
+NTSTATUS ndr_push_dfs_Info102(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info102 *r);
+NTSTATUS ndr_pull_dfs_Info102(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info102 *r);
+NTSTATUS ndr_push_dfs_Info200(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info200 *r);
+NTSTATUS ndr_pull_dfs_Info200(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info200 *r);
+NTSTATUS ndr_push_dfs_Info300(struct ndr_push *ndr, int ndr_flags,  
const struct dfs_Info300 *r);
+NTSTATUS ndr_pull_dfs_Info300(struct ndr_pull *ndr, int ndr_flags,  
struct dfs_Info300 *r);
+NTSTATUS ndr_push_dfs_Info(struct ndr_push *ndr, int ndr_flags,  
const union dfs_Info *r);
+NTSTATUS ndr_pull_dfs_Info(struct ndr_pull *ndr, int ndr_flags,  
union dfs_Info *r);
+NTSTATUS ndr_push_dfs_EnumArray1(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_EnumArray1 *r);
+NTSTATUS ndr_pull_dfs_EnumArray1(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_EnumArray1 *r);
+NTSTATUS ndr_push_dfs_EnumArray2(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_EnumArray2 *r);
+NTSTATUS ndr_pull_dfs_EnumArray2(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_EnumArray2 *r);
+NTSTATUS ndr_push_dfs_EnumArray3(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_EnumArray3 *r);
+NTSTATUS ndr_pull_dfs_EnumArray3(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_EnumArray3 *r);
+NTSTATUS ndr_push_dfs_EnumArray4(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_EnumArray4 *r);
+NTSTATUS ndr_pull_dfs_EnumArray4(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_EnumArray4 *r);
+NTSTATUS ndr_push_dfs_EnumArray200(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_EnumArray200 *r);
+NTSTATUS ndr_pull_dfs_EnumArray200(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_EnumArray200 *r);
+NTSTATUS ndr_push_dfs_EnumArray300(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_EnumArray300 *r);
+NTSTATUS ndr_pull_dfs_EnumArray300(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_EnumArray300 *r);
+NTSTATUS ndr_push_dfs_EnumInfo(struct ndr_push *ndr, int ndr_flags,  
const union dfs_EnumInfo *r);
+NTSTATUS ndr_pull_dfs_EnumInfo(struct ndr_pull *ndr, int ndr_flags,  
union dfs_EnumInfo *r);
+NTSTATUS ndr_push_dfs_EnumStruct(struct ndr_push *ndr, int  
ndr_flags, const struct dfs_EnumStruct *r);
+NTSTATUS ndr_pull_dfs_EnumStruct(struct ndr_pull *ndr, int  
ndr_flags, struct dfs_EnumStruct *r);
+NTSTATUS ndr_push_dfs_GetManagerVersion(struct ndr_push *ndr, int  
flags, const struct dfs_GetManagerVersion *r);
+NTSTATUS ndr_pull_dfs_GetManagerVersion(struct ndr_pull *ndr, int  
flags, struct dfs_GetManagerVersion *r);
+NTSTATUS ndr_push_dfs_Add(struct ndr_push *ndr, int flags, const  
struct dfs_Add *r);
+NTSTATUS ndr_pull_dfs_Add(struct ndr_pull *ndr, int flags, struct  
dfs_Add *r);
+NTSTATUS ndr_push_dfs_Remove(struct ndr_push *ndr, int flags, const  
struct dfs_Remove *r);
+NTSTATUS ndr_pull_dfs_Remove(struct ndr_pull *ndr, int flags, struct  
dfs_Remove *r);
+NTSTATUS ndr_push_dfs_SetInfo(struct ndr_push *ndr, int flags, const  
struct dfs_SetInfo *r);
+NTSTATUS ndr_pull_dfs_SetInfo(struct ndr_pull *ndr, int flags,  
struct dfs_SetInfo *r);
+NTSTATUS ndr_push_dfs_GetInfo(struct ndr_push *ndr, int flags, const  
struct dfs_GetInfo *r);
+NTSTATUS ndr_pull_dfs_GetInfo(struct ndr_pull *ndr, int flags,  
struct dfs_GetInfo *r);
+NTSTATUS ndr_push_dfs_Enum(struct ndr_push *ndr, int flags, const  
struct dfs_Enum *r);
+NTSTATUS ndr_pull_dfs_Enum(struct ndr_pull *ndr, int flags, struct  
dfs_Enum *r);
+NTSTATUS ndr_push_dfs_Rename(struct ndr_push *ndr, int flags, const  
struct dfs_Rename *r);
+NTSTATUS ndr_pull_dfs_Rename(struct ndr_pull *ndr, int flags, struct  
dfs_Rename *r);
+NTSTATUS ndr_push_dfs_Move(struct ndr_push *ndr, int flags, const  
struct dfs_Move *r);
+NTSTATUS ndr_pull_dfs_Move(struct ndr_pull *ndr, int flags, struct  
dfs_Move *r);
+NTSTATUS ndr_push_dfs_ManagerGetConfigInfo(struct ndr_push *ndr, int  
flags, const struct dfs_ManagerGetConfigInfo *r);
+NTSTATUS ndr_pull_dfs_ManagerGetConfigInfo(struct ndr_pull *ndr, int  
flags, struct dfs_ManagerGetConfigInfo *r);
+NTSTATUS ndr_push_dfs_ManagerSendSiteInfo(struct ndr_push *ndr, int  
flags, const struct dfs_ManagerSendSiteInfo *r);
+NTSTATUS ndr_pull_dfs_ManagerSendSiteInfo(struct ndr_pull *ndr, int  
flags, struct dfs_ManagerSendSiteInfo *r);
+NTSTATUS ndr_push_dfs_AddFtRoot(struct ndr_push *ndr, int flags,  
const struct dfs_AddFtRoot *r);
+NTSTATUS ndr_pull_dfs_AddFtRoot(struct ndr_pull *ndr, int flags,  
struct dfs_AddFtRoot *r);
+NTSTATUS ndr_push_dfs_RemoveFtRoot(struct ndr_push *ndr, int flags,  
const struct dfs_RemoveFtRoot *r);
+NTSTATUS ndr_pull_dfs_RemoveFtRoot(struct ndr_pull *ndr, int flags,  
struct dfs_RemoveFtRoot *r);
+NTSTATUS ndr_push_dfs_AddStdRoot(struct ndr_push *ndr, int flags,  
const struct dfs_AddStdRoot *r);
+NTSTATUS ndr_pull_dfs_AddStdRoot(struct ndr_pull *ndr, int flags,  
struct dfs_AddStdRoot *r);
+NTSTATUS ndr_push_dfs_RemoveStdRoot(struct ndr_push *ndr, int flags,  
const struct dfs_RemoveStdRoot *r);
+NTSTATUS ndr_pull_dfs_RemoveStdRoot(struct ndr_pull *ndr, int flags,  
struct dfs_RemoveStdRoot *r);
+NTSTATUS ndr_push_dfs_ManagerInitialize(struct ndr_push *ndr, int  
flags, const struct dfs_ManagerInitialize *r);
+NTSTATUS ndr_pull_dfs_ManagerInitialize(struct ndr_pull *ndr, int  
flags, struct dfs_ManagerInitialize *r);
+NTSTATUS ndr_push_dfs_AddStdRootForced(struct ndr_push *ndr, int  
flags, const struct dfs_AddStdRootForced *r);
+NTSTATUS ndr_pull_dfs_AddStdRootForced(struct ndr_pull *ndr, int  
flags, struct dfs_AddStdRootForced *r);
+NTSTATUS ndr_push_dfs_GetDcAddress(struct ndr_push *ndr, int flags,  
const struct dfs_GetDcAddress *r);
+NTSTATUS ndr_pull_dfs_GetDcAddress(struct ndr_pull *ndr, int flags,  
struct dfs_GetDcAddress *r);
+NTSTATUS ndr_push_dfs_SetDcAddress(struct ndr_push *ndr, int flags,  
const struct dfs_SetDcAddress *r);
+NTSTATUS ndr_pull_dfs_SetDcAddress(struct ndr_pull *ndr, int flags,  
struct dfs_SetDcAddress *r);
+NTSTATUS ndr_push_dfs_FlushFtTable(struct ndr_push *ndr, int flags,  
const struct dfs_FlushFtTable *r);
+NTSTATUS ndr_pull_dfs_FlushFtTable(struct ndr_pull *ndr, int flags,  
struct dfs_FlushFtTable *r);
+NTSTATUS ndr_push_dfs_Add2(struct ndr_push *ndr, int flags, const  
struct dfs_Add2 *r);
+NTSTATUS ndr_pull_dfs_Add2(struct ndr_pull *ndr, int flags, struct  
dfs_Add2 *r);
+NTSTATUS ndr_push_dfs_Remove2(struct ndr_push *ndr, int flags, const  
struct dfs_Remove2 *r);
+NTSTATUS ndr_pull_dfs_Remove2(struct ndr_pull *ndr, int flags,  
struct dfs_Remove2 *r);
+NTSTATUS ndr_push_dfs_EnumEx(struct ndr_push *ndr, int flags, const  
struct dfs_EnumEx *r);
+NTSTATUS ndr_pull_dfs_EnumEx(struct ndr_pull *ndr, int flags, struct  
dfs_EnumEx *r);
+NTSTATUS ndr_push_dfs_SetInfo2(struct ndr_push *ndr, int flags,  
const struct dfs_SetInfo2 *r);
+NTSTATUS ndr_pull_dfs_SetInfo2(struct ndr_pull *ndr, int flags,  
struct dfs_SetInfo2 *r);
+
+/* The following definitions come from librpc/gen_ndr/ndr_echo.c  */
+
+NTSTATUS ndr_push_echo_info1(struct ndr_push *ndr, int ndr_flags,  
const struct echo_info1 *r);
+NTSTATUS ndr_pull_echo_info1(struct ndr_pull *ndr, int ndr_flags,  
struct echo_info1 *r);
+NTSTATUS ndr_push_echo_info2(struct ndr_push *ndr, int ndr_flags,  
const struct echo_info2 *r);
+NTSTATUS ndr_pull_echo_info2(struct ndr_pull *ndr, int ndr_flags,  
struct echo_info2 *r);
+NTSTATUS ndr_push_echo_info3(struct ndr_push *ndr, int ndr_flags,  
const struct echo_info3 *r);
+NTSTATUS ndr_pull_echo_info3(struct ndr_pull *ndr, int ndr_flags,  
struct echo_info3 *r);
+NTSTATUS ndr_push_echo_info4(struct ndr_push *ndr, int ndr_flags,  
const struct echo_info4 *r);
+NTSTATUS ndr_pull_echo_info4(struct ndr_pull *ndr, int ndr_flags,  
struct echo_info4 *r);
+NTSTATUS ndr_push_echo_info5(struct ndr_push *ndr, int ndr_flags,  
const struct echo_info5 *r);
+NTSTATUS ndr_pull_echo_info5(struct ndr_pull *ndr, int ndr_flags,  
struct echo_info5 *r);
+NTSTATUS ndr_push_echo_info6(struct ndr_push *ndr, int ndr_flags,  
const struct echo_info6 *r);
+NTSTATUS ndr_pull_echo_info6(struct ndr_pull *ndr, int ndr_flags,  
struct echo_info6 *r);
+NTSTATUS ndr_push_echo_info7(struct ndr_push *ndr, int ndr_flags,  
const struct echo_info7 *r);
+NTSTATUS ndr_pull_echo_info7(struct ndr_pull *ndr, int ndr_flags,  
struct echo_info7 *r);
+NTSTATUS ndr_push_echo_Info(struct ndr_push *ndr, int ndr_flags,  
const union echo_Info *r);
+NTSTATUS ndr_pull_echo_Info(struct ndr_pull *ndr, int ndr_flags,  
union echo_Info *r);
+NTSTATUS ndr_push_echo_Enum1(struct ndr_push *ndr, int ndr_flags,  
enum echo_Enum1 r);
+NTSTATUS ndr_pull_echo_Enum1(struct ndr_pull *ndr, int ndr_flags,  
enum echo_Enum1 *r);
+NTSTATUS ndr_push_echo_Enum1_32(struct ndr_push *ndr, int ndr_flags,  
enum echo_Enum1_32 r);
+NTSTATUS ndr_pull_echo_Enum1_32(struct ndr_pull *ndr, int ndr_flags,  
enum echo_Enum1_32 *r);
+NTSTATUS ndr_push_echo_Enum2(struct ndr_push *ndr, int ndr_flags,  
const struct echo_Enum2 *r);
+NTSTATUS ndr_pull_echo_Enum2(struct ndr_pull *ndr, int ndr_flags,  
struct echo_Enum2 *r);
+NTSTATUS ndr_push_echo_Enum3(struct ndr_push *ndr, int ndr_flags,  
const union echo_Enum3 *r);
+NTSTATUS ndr_pull_echo_Enum3(struct ndr_pull *ndr, int ndr_flags,  
union echo_Enum3 *r);
+NTSTATUS ndr_push_echo_Surrounding(struct ndr_push *ndr, int  
ndr_flags, const struct echo_Surrounding *r);
+NTSTATUS ndr_pull_echo_Surrounding(struct ndr_pull *ndr, int  
ndr_flags, struct echo_Surrounding *r);
+NTSTATUS ndr_push_echo_AddOne(struct ndr_push *ndr, int flags, const  
struct echo_AddOne *r);
+NTSTATUS ndr_pull_echo_AddOne(struct ndr_pull *ndr, int flags,  
struct echo_AddOne *r);
+NTSTATUS ndr_push_echo_EchoData(struct ndr_push *ndr, int flags,  
const struct echo_EchoData *r);
+NTSTATUS ndr_pull_echo_EchoData(struct ndr_pull *ndr, int flags,  
struct echo_EchoData *r);
+NTSTATUS ndr_push_echo_SinkData(struct ndr_push *ndr, int flags,  
const struct echo_SinkData *r);
+NTSTATUS ndr_pull_echo_SinkData(struct ndr_pull *ndr, int flags,  
struct echo_SinkData *r);
+NTSTATUS ndr_push_echo_SourceData(struct ndr_push *ndr, int flags,  
const struct echo_SourceData *r);
+NTSTATUS ndr_pull_echo_SourceData(struct ndr_pull *ndr, int flags,  
struct echo_SourceData *r);
+NTSTATUS ndr_push_echo_TestCall(struct ndr_push *ndr, int flags,  
const struct echo_TestCall *r);
+NTSTATUS ndr_pull_echo_TestCall(struct ndr_pull *ndr, int flags,  
struct echo_TestCall *r);
+NTSTATUS ndr_push_echo_TestCall2(struct ndr_push *ndr, int flags,  
const struct echo_TestCall2 *r);
+NTSTATUS ndr_pull_echo_TestCall2(struct ndr_pull *ndr, int flags,  
struct echo_TestCall2 *r);
+NTSTATUS ndr_push_echo_TestSleep(struct ndr_push *ndr, int flags,  
const struct echo_TestSleep *r);
+NTSTATUS ndr_pull_echo_TestSleep(struct ndr_pull *ndr, int flags,  
struct echo_TestSleep *r);
+NTSTATUS ndr_push_echo_TestEnum(struct ndr_push *ndr, int flags,  
const struct echo_TestEnum *r);
+NTSTATUS ndr_pull_echo_TestEnum(struct ndr_pull *ndr, int flags,  
struct echo_TestEnum *r);
+NTSTATUS ndr_push_echo_TestSurrounding(struct ndr_push *ndr, int  
flags, const struct echo_TestSurrounding *r);
+NTSTATUS ndr_pull_echo_TestSurrounding(struct ndr_pull *ndr, int  
flags, struct echo_TestSurrounding *r);
+NTSTATUS ndr_push_echo_TestDoublePointer(struct ndr_push *ndr, int  
flags, const struct echo_TestDoublePointer *r);
+NTSTATUS ndr_pull_echo_TestDoublePointer(struct ndr_pull *ndr, int  
flags, struct echo_TestDoublePointer *r);
+
+/* The following definitions come from librpc/gen_ndr/ 
ndr_epmapper.c  */
+
+NTSTATUS ndr_push_epm_protocol(struct ndr_push *ndr, int ndr_flags,  
enum epm_protocol r);
+NTSTATUS ndr_pull_epm_protocol(struct ndr_pull *ndr, int ndr_flags,  
enum epm_protocol *r);
+NTSTATUS ndr_push_epm_rhs_dnet_nsp(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_dnet_nsp *r);
+NTSTATUS ndr_pull_epm_rhs_dnet_nsp(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_dnet_nsp *r);
+NTSTATUS ndr_push_epm_rhs_osi_tp4(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_osi_tp4 *r);
+NTSTATUS ndr_pull_epm_rhs_osi_tp4(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_osi_tp4 *r);
+NTSTATUS ndr_push_epm_rhs_osi_clns(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_osi_clns *r);
+NTSTATUS ndr_pull_epm_rhs_osi_clns(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_osi_clns *r);
+NTSTATUS ndr_push_epm_rhs_udp(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_udp *r);
+NTSTATUS ndr_pull_epm_rhs_udp(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_udp *r);
+NTSTATUS ndr_push_epm_rhs_tcp(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_tcp *r);
+NTSTATUS ndr_pull_epm_rhs_tcp(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_tcp *r);
+NTSTATUS ndr_push_epm_rhs_ip(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_ip *r);
+NTSTATUS ndr_pull_epm_rhs_ip(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_ip *r);
+NTSTATUS ndr_push_epm_rhs_ncadg(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_ncadg *r);
+NTSTATUS ndr_pull_epm_rhs_ncadg(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_ncadg *r);
+NTSTATUS ndr_push_epm_rhs_ncacn(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_ncacn *r);
+NTSTATUS ndr_pull_epm_rhs_ncacn(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_ncacn *r);
+NTSTATUS ndr_push_epm_rhs_uuid(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_uuid *r);
+NTSTATUS ndr_pull_epm_rhs_uuid(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_uuid *r);
+NTSTATUS ndr_push_epm_rhs_ipx(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_ipx *r);
+NTSTATUS ndr_pull_epm_rhs_ipx(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_ipx *r);
+NTSTATUS ndr_push_epm_rhs_smb(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_smb *r);
+NTSTATUS ndr_pull_epm_rhs_smb(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_smb *r);
+NTSTATUS ndr_push_epm_rhs_pipe(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_pipe *r);
+NTSTATUS ndr_pull_epm_rhs_pipe(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_pipe *r);
+NTSTATUS ndr_push_epm_rhs_netbios(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_netbios *r);
+NTSTATUS ndr_pull_epm_rhs_netbios(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_netbios *r);
+NTSTATUS ndr_push_epm_rhs_netbeui(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_netbeui *r);
+NTSTATUS ndr_pull_epm_rhs_netbeui(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_netbeui *r);
+NTSTATUS ndr_push_epm_rhs_spx(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_spx *r);
+NTSTATUS ndr_pull_epm_rhs_spx(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_spx *r);
+NTSTATUS ndr_push_epm_rhs_nb_ipx(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_nb_ipx *r);
+NTSTATUS ndr_pull_epm_rhs_nb_ipx(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_nb_ipx *r);
+NTSTATUS ndr_push_epm_rhs_http(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_http *r);
+NTSTATUS ndr_pull_epm_rhs_http(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_http *r);
+NTSTATUS ndr_push_epm_rhs_unix_ds(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_unix_ds *r);
+NTSTATUS ndr_pull_epm_rhs_unix_ds(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_unix_ds *r);
+NTSTATUS ndr_push_epm_rhs_null(struct ndr_push *ndr, int ndr_flags,  
const struct epm_rhs_null *r);
+NTSTATUS ndr_pull_epm_rhs_null(struct ndr_pull *ndr, int ndr_flags,  
struct epm_rhs_null *r);
+NTSTATUS ndr_push_epm_rhs_ncalrpc(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_ncalrpc *r);
+NTSTATUS ndr_pull_epm_rhs_ncalrpc(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_ncalrpc *r);
+NTSTATUS ndr_push_epm_rhs_appletalk(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_appletalk *r);
+NTSTATUS ndr_pull_epm_rhs_appletalk(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_appletalk *r);
+NTSTATUS ndr_push_epm_rhs_atalk_stream(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_atalk_stream *r);
+NTSTATUS ndr_pull_epm_rhs_atalk_stream(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_atalk_stream *r);
+NTSTATUS ndr_push_epm_rhs_atalk_datagram(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_atalk_datagram *r);
+NTSTATUS ndr_pull_epm_rhs_atalk_datagram(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_atalk_datagram *r);
+NTSTATUS ndr_push_epm_rhs_vines_spp(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_vines_spp *r);
+NTSTATUS ndr_pull_epm_rhs_vines_spp(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_vines_spp *r);
+NTSTATUS ndr_push_epm_rhs_vines_ipc(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_vines_ipc *r);
+NTSTATUS ndr_pull_epm_rhs_vines_ipc(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_vines_ipc *r);
+NTSTATUS ndr_push_epm_rhs_streettalk(struct ndr_push *ndr, int  
ndr_flags, const struct epm_rhs_streettalk *r);
+NTSTATUS ndr_pull_epm_rhs_streettalk(struct ndr_pull *ndr, int  
ndr_flags, struct epm_rhs_streettalk *r);
+NTSTATUS ndr_push_epm_rhs(struct ndr_push *ndr, int ndr_flags, const  
union epm_rhs *r);
+NTSTATUS ndr_pull_epm_rhs(struct ndr_pull *ndr, int ndr_flags, union  
epm_rhs *r);
+NTSTATUS ndr_push_epm_lhs(struct ndr_push *ndr, int ndr_flags, const  
struct epm_lhs *r);
+NTSTATUS ndr_pull_epm_lhs(struct ndr_pull *ndr, int ndr_flags,  
struct epm_lhs *r);
+NTSTATUS ndr_push_epm_floor(struct ndr_push *ndr, int ndr_flags,  
const struct epm_floor *r);
+NTSTATUS ndr_pull_epm_floor(struct ndr_pull *ndr, int ndr_flags,  
struct epm_floor *r);
+NTSTATUS ndr_push_epm_tower(struct ndr_push *ndr, int ndr_flags,  
const struct epm_tower *r);
+NTSTATUS ndr_pull_epm_tower(struct ndr_pull *ndr, int ndr_flags,  
struct epm_tower *r);
+size_t ndr_size_epm_tower(const struct epm_tower *r, int flags);
+NTSTATUS ndr_push_epm_twr_t(struct ndr_push *ndr, int ndr_flags,  
const struct epm_twr_t *r);
+NTSTATUS ndr_pull_epm_twr_t(struct ndr_pull *ndr, int ndr_flags,  
struct epm_twr_t *r);
+NTSTATUS ndr_push_epm_entry_t(struct ndr_push *ndr, int ndr_flags,  
const struct epm_entry_t *r);
+NTSTATUS ndr_pull_epm_entry_t(struct ndr_pull *ndr, int ndr_flags,  
struct epm_entry_t *r);
+NTSTATUS ndr_push_rpc_if_id_t(struct ndr_push *ndr, int ndr_flags,  
const struct rpc_if_id_t *r);
+NTSTATUS ndr_pull_rpc_if_id_t(struct ndr_pull *ndr, int ndr_flags,  
struct rpc_if_id_t *r);
+NTSTATUS ndr_push_epm_twr_p_t(struct ndr_push *ndr, int ndr_flags,  
const struct epm_twr_p_t *r);
+NTSTATUS ndr_pull_epm_twr_p_t(struct ndr_pull *ndr, int ndr_flags,  
struct epm_twr_p_t *r);
+NTSTATUS ndr_push_epm_Insert(struct ndr_push *ndr, int flags, const  
struct epm_Insert *r);
+NTSTATUS ndr_pull_epm_Insert(struct ndr_pull *ndr, int flags, struct  
epm_Insert *r);
+NTSTATUS ndr_push_epm_Delete(struct ndr_push *ndr, int flags, const  
struct epm_Delete *r);
+NTSTATUS ndr_pull_epm_Delete(struct ndr_pull *ndr, int flags, struct  
epm_Delete *r);
+NTSTATUS ndr_push_epm_Lookup(struct ndr_push *ndr, int flags, const  
struct epm_Lookup *r);
+NTSTATUS ndr_pull_epm_Lookup(struct ndr_pull *ndr, int flags, struct  
epm_Lookup *r);
+NTSTATUS ndr_push_epm_LookupHandleFree(struct ndr_push *ndr, int  
flags, const struct epm_LookupHandleFree *r);
+NTSTATUS ndr_pull_epm_LookupHandleFree(struct ndr_pull *ndr, int  
flags, struct epm_LookupHandleFree *r);
+NTSTATUS ndr_push_epm_InqObject(struct ndr_push *ndr, int flags,  
const struct epm_InqObject *r);
+NTSTATUS ndr_pull_epm_InqObject(struct ndr_pull *ndr, int flags,  
struct epm_InqObject *r);
+NTSTATUS ndr_push_epm_MgmtDelete(struct ndr_push *ndr, int flags,  
const struct epm_MgmtDelete *r);
+NTSTATUS ndr_pull_epm_MgmtDelete(struct ndr_pull *ndr, int flags,  
struct epm_MgmtDelete *r);
+NTSTATUS ndr_push_epm_MapAuth(struct ndr_push *ndr, int flags, const  
struct epm_MapAuth *r);
+NTSTATUS ndr_pull_epm_MapAuth(struct ndr_pull *ndr, int flags,  
struct epm_MapAuth *r);
+
+/* The following definitions come from librpc/gen_ndr/ 
ndr_eventlog.c  */
+
+NTSTATUS ndr_push_eventlog_OpenUnknown0(struct ndr_push *ndr, int  
ndr_flags, const struct eventlog_OpenUnknown0 *r);
+NTSTATUS ndr_pull_eventlog_OpenUnknown0(struct ndr_pull *ndr, int  
ndr_flags, struct eventlog_OpenUnknown0 *r);
+NTSTATUS ndr_push_eventlog_ClearEventLogW(struct ndr_push *ndr, int  
flags, const struct eventlog_ClearEventLogW *r);
+NTSTATUS ndr_pull_eventlog_ClearEventLogW(struct ndr_pull *ndr, int  
flags, struct eventlog_ClearEventLogW *r);
+NTSTATUS ndr_push_eventlog_BackupEventLogW(struct ndr_push *ndr, int  
flags, const struct eventlog_BackupEventLogW *r);
+NTSTATUS ndr_pull_eventlog_BackupEventLogW(struct ndr_pull *ndr, int  
flags, struct eventlog_BackupEventLogW *r);
+NTSTATUS ndr_push_eventlog_CloseEventLog(struct ndr_push *ndr, int  
flags, const struct eventlog_CloseEventLog *r);
+NTSTATUS ndr_pull_eventlog_CloseEventLog(struct ndr_pull *ndr, int  
flags, struct eventlog_CloseEventLog *r);
+NTSTATUS ndr_push_eventlog_DeregisterEventSource(struct ndr_push  
*ndr, int flags, const struct eventlog_DeregisterEventSource *r);
+NTSTATUS ndr_pull_eventlog_DeregisterEventSource(struct ndr_pull  
*ndr, int flags, struct eventlog_DeregisterEventSource *r);
+NTSTATUS ndr_push_eventlog_GetNumRecords(struct ndr_push *ndr, int  
flags, const struct eventlog_GetNumRecords *r);
+NTSTATUS ndr_pull_eventlog_GetNumRecords(struct ndr_pull *ndr, int  
flags, struct eventlog_GetNumRecords *r);
+NTSTATUS ndr_push_eventlog_GetOldestRecord(struct ndr_push *ndr, int  
flags, const struct eventlog_GetOldestRecord *r);
+NTSTATUS ndr_pull_eventlog_GetOldestRecord(struct ndr_pull *ndr, int  
flags, struct eventlog_GetOldestRecord *r);
+NTSTATUS ndr_push_eventlog_ChangeNotify(struct ndr_push *ndr, int  
flags, const struct eventlog_ChangeNotify *r);
+NTSTATUS ndr_pull_eventlog_ChangeNotify(struct ndr_pull *ndr, int  
flags, struct eventlog_ChangeNotify *r);
+NTSTATUS ndr_push_eventlog_OpenEventLogW(struct ndr_push *ndr, int  
flags, const struct eventlog_OpenEventLogW *r);
+NTSTATUS ndr_pull_eventlog_OpenEventLogW(struct ndr_pull *ndr, int  
flags, struct eventlog_OpenEventLogW *r);
+NTSTATUS ndr_push_eventlog_RegisterEventSourceW(struct ndr_push  
*ndr, int flags, const struct eventlog_RegisterEventSourceW *r);
+NTSTATUS ndr_pull_eventlog_RegisterEventSourceW(struct ndr_pull  
*ndr, int flags, struct eventlog_RegisterEventSourceW *r);
+NTSTATUS ndr_push_eventlog_OpenBackupEventLogW(struct ndr_push *ndr,  
int flags, const struct eventlog_OpenBackupEventLogW *r);
+NTSTATUS ndr_pull_eventlog_OpenBackupEventLogW(struct ndr_pull *ndr,  
int flags, struct eventlog_OpenBackupEventLogW *r);
+NTSTATUS ndr_push_eventlog_ReadEventLogW(struct ndr_push *ndr, int  
flags, const struct eventlog_ReadEventLogW *r);
+NTSTATUS ndr_pull_eventlog_ReadEventLogW(struct ndr_pull *ndr, int  
flags, struct eventlog_ReadEventLogW *r);
+NTSTATUS ndr_push_eventlog_ReportEventW(struct ndr_push *ndr, int  
flags, const struct eventlog_ReportEventW *r);
+NTSTATUS ndr_pull_eventlog_ReportEventW(struct ndr_pull *ndr, int  
flags, struct eventlog_ReportEventW *r);
+NTSTATUS ndr_push_eventlog_ClearEventLogA(struct ndr_push *ndr, int  
flags, const struct eventlog_ClearEventLogA *r);
+NTSTATUS ndr_pull_eventlog_ClearEventLogA(struct ndr_pull *ndr, int  
flags, struct eventlog_ClearEventLogA *r);
+NTSTATUS ndr_push_eventlog_BackupEventLogA(struct ndr_push *ndr, int  
flags, const struct eventlog_BackupEventLogA *r);
+NTSTATUS ndr_pull_eventlog_BackupEventLogA(struct ndr_pull *ndr, int  
flags, struct eventlog_BackupEventLogA *r);
+NTSTATUS ndr_push_eventlog_OpenEventLogA(struct ndr_push *ndr, int  
flags, const struct eventlog_OpenEventLogA *r);
+NTSTATUS ndr_pull_eventlog_OpenEventLogA(struct ndr_pull *ndr, int  
flags, struct eventlog_OpenEventLogA *r);
+NTSTATUS ndr_push_eventlog_RegisterEventSourceA(struct ndr_push  
*ndr, int flags, const struct eventlog_RegisterEventSourceA *r);
+NTSTATUS ndr_pull_eventlog_RegisterEventSourceA(struct ndr_pull  
*ndr, int flags, struct eventlog_RegisterEventSourceA *r);
+NTSTATUS ndr_push_eventlog_OpenBackupEventLogA(struct ndr_push *ndr,  
int flags, const struct eventlog_OpenBackupEventLogA *r);
+NTSTATUS ndr_pull_eventlog_OpenBackupEventLogA(struct ndr_pull *ndr,  
int flags, struct eventlog_OpenBackupEventLogA *r);
+NTSTATUS ndr_push_eventlog_ReadEventLogA(struct ndr_push *ndr, int  
flags, const struct eventlog_ReadEventLogA *r);
+NTSTATUS ndr_pull_eventlog_ReadEventLogA(struct ndr_pull *ndr, int  
flags, struct eventlog_ReadEventLogA *r);
+NTSTATUS ndr_push_eventlog_ReportEventA(struct ndr_push *ndr, int  
flags, const struct eventlog_ReportEventA *r);
+NTSTATUS ndr_pull_eventlog_ReportEventA(struct ndr_pull *ndr, int  
flags, struct eventlog_ReportEventA *r);
+NTSTATUS ndr_push_eventlog_RegisterClusterSvc(struct ndr_push *ndr,  
int flags, const struct eventlog_RegisterClusterSvc *r);
+NTSTATUS ndr_pull_eventlog_RegisterClusterSvc(struct ndr_pull *ndr,  
int flags, struct eventlog_RegisterClusterSvc *r);
+NTSTATUS ndr_push_eventlog_DeregisterClusterSvc(struct ndr_push  
*ndr, int flags, const struct eventlog_DeregisterClusterSvc *r);
+NTSTATUS ndr_pull_eventlog_DeregisterClusterSvc(struct ndr_pull  
*ndr, int flags, struct eventlog_DeregisterClusterSvc *r);
+NTSTATUS ndr_push_eventlog_WriteClusterEvents(struct ndr_push *ndr,  
int flags, const struct eventlog_WriteClusterEvents *r);
+NTSTATUS ndr_pull_eventlog_WriteClusterEvents(struct ndr_pull *ndr,  
int flags, struct eventlog_WriteClusterEvents *r);
+NTSTATUS ndr_push_eventlog_GetLogIntormation(struct ndr_push *ndr,  
int flags, const struct eventlog_GetLogIntormation *r);
+NTSTATUS ndr_pull_eventlog_GetLogIntormation(struct ndr_pull *ndr,  
int flags, struct eventlog_GetLogIntormation *r);
+NTSTATUS ndr_push_eventlog_FlushEventLog(struct ndr_push *ndr, int  
flags, const struct eventlog_FlushEventLog *r);
+NTSTATUS ndr_pull_eventlog_FlushEventLog(struct ndr_pull *ndr, int  
flags, struct eventlog_FlushEventLog *r);
+
+/* The following definitions come from librpc/gen_ndr/ 
ndr_initshutdown.c  */
+
+NTSTATUS ndr_push_initshutdown_String_sub(struct ndr_push *ndr, int  
ndr_flags, const struct initshutdown_String_sub *r);
+NTSTATUS ndr_pull_initshutdown_String_sub(struct ndr_pull *ndr, int  
ndr_flags, struct initshutdown_String_sub *r);
+NTSTATUS ndr_push_initshutdown_Init(struct ndr_push *ndr, int flags,  
const struct initshutdown_Init *r);
+NTSTATUS ndr_pull_initshutdown_Init(struct ndr_pull *ndr, int flags,  
struct initshutdown_Init *r);
+NTSTATUS ndr_push_initshutdown_Abort(struct ndr_push *ndr, int  
flags, const struct initshutdown_Abort *r);
+NTSTATUS ndr_pull_initshutdown_Abort(struct ndr_pull *ndr, int  
flags, struct initshutdown_Abort *r);
+NTSTATUS ndr_push_initshutdown_InitEx(struct ndr_push *ndr, int  
flags, const struct initshutdown_InitEx *r);
+NTSTATUS ndr_pull_initshutdown_InitEx(struct ndr_pull *ndr, int  
flags, struct initshutdown_InitEx *r);
+
+/* The following definitions come from librpc/gen_ndr/ndr_lsa.c  */
+
+NTSTATUS ndr_push_lsa_LUID(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_LUID *r);
+NTSTATUS ndr_pull_lsa_LUID(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_LUID *r);
+NTSTATUS ndr_push_lsa_PrivEntry(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_PrivEntry *r);
+NTSTATUS ndr_pull_lsa_PrivEntry(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_PrivEntry *r);
+NTSTATUS ndr_push_lsa_PrivArray(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_PrivArray *r);
+NTSTATUS ndr_pull_lsa_PrivArray(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_PrivArray *r);
+NTSTATUS ndr_push_lsa_QosInfo(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_QosInfo *r);
+NTSTATUS ndr_pull_lsa_QosInfo(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_QosInfo *r);
+NTSTATUS ndr_push_lsa_ObjectAttribute(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_ObjectAttribute *r);
+NTSTATUS ndr_pull_lsa_ObjectAttribute(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_ObjectAttribute *r);
+NTSTATUS ndr_push_lsa_AuditLogInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_AuditLogInfo *r);
+NTSTATUS ndr_pull_lsa_AuditLogInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_AuditLogInfo *r);
+NTSTATUS ndr_push_lsa_AuditEventsInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_AuditEventsInfo *r);
+NTSTATUS ndr_pull_lsa_AuditEventsInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_AuditEventsInfo *r);
+NTSTATUS ndr_push_lsa_DomainInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DomainInfo *r);
+NTSTATUS ndr_pull_lsa_DomainInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DomainInfo *r);
+NTSTATUS ndr_push_lsa_PDAccountInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_PDAccountInfo *r);
+NTSTATUS ndr_pull_lsa_PDAccountInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_PDAccountInfo *r);
+NTSTATUS ndr_push_lsa_ServerRole(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_ServerRole *r);
+NTSTATUS ndr_pull_lsa_ServerRole(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_ServerRole *r);
+NTSTATUS ndr_push_lsa_ReplicaSourceInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_ReplicaSourceInfo *r);
+NTSTATUS ndr_pull_lsa_ReplicaSourceInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_ReplicaSourceInfo *r);
+NTSTATUS ndr_push_lsa_DefaultQuotaInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DefaultQuotaInfo *r);
+NTSTATUS ndr_pull_lsa_DefaultQuotaInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DefaultQuotaInfo *r);
+NTSTATUS ndr_push_lsa_ModificationInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_ModificationInfo *r);
+NTSTATUS ndr_pull_lsa_ModificationInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_ModificationInfo *r);
+NTSTATUS ndr_push_lsa_AuditFullSetInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_AuditFullSetInfo *r);
+NTSTATUS ndr_pull_lsa_AuditFullSetInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_AuditFullSetInfo *r);
+NTSTATUS ndr_push_lsa_AuditFullQueryInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_AuditFullQueryInfo *r);
+NTSTATUS ndr_pull_lsa_AuditFullQueryInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_AuditFullQueryInfo *r);
+NTSTATUS ndr_push_lsa_DnsDomainInfo(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DnsDomainInfo *r);
+NTSTATUS ndr_pull_lsa_DnsDomainInfo(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DnsDomainInfo *r);
+NTSTATUS ndr_push_lsa_PolicyInformation(struct ndr_push *ndr, int  
ndr_flags, const union lsa_PolicyInformation *r);
+NTSTATUS ndr_pull_lsa_PolicyInformation(struct ndr_pull *ndr, int  
ndr_flags, union lsa_PolicyInformation *r);
+NTSTATUS ndr_push_lsa_SidPtr(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_SidPtr *r);
+NTSTATUS ndr_pull_lsa_SidPtr(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_SidPtr *r);
+NTSTATUS ndr_push_lsa_DomainList(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DomainList *r);
+NTSTATUS ndr_pull_lsa_DomainList(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DomainList *r);
+NTSTATUS ndr_push_lsa_SidType(struct ndr_push *ndr, int ndr_flags,  
enum lsa_SidType r);
+NTSTATUS ndr_pull_lsa_SidType(struct ndr_pull *ndr, int ndr_flags,  
enum lsa_SidType *r);
+NTSTATUS ndr_push_lsa_TranslatedSid(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TranslatedSid *r);
+NTSTATUS ndr_pull_lsa_TranslatedSid(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TranslatedSid *r);
+NTSTATUS ndr_push_lsa_TransSidArray(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TransSidArray *r);
+NTSTATUS ndr_pull_lsa_TransSidArray(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TransSidArray *r);
+NTSTATUS ndr_push_lsa_RefDomainList(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_RefDomainList *r);
+NTSTATUS ndr_pull_lsa_RefDomainList(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_RefDomainList *r);
+NTSTATUS ndr_push_lsa_TranslatedName(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TranslatedName *r);
+NTSTATUS ndr_pull_lsa_TranslatedName(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TranslatedName *r);
+NTSTATUS ndr_push_lsa_TransNameArray(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TransNameArray *r);
+NTSTATUS ndr_pull_lsa_TransNameArray(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TransNameArray *r);
+NTSTATUS ndr_push_lsa_LUIDAttribute(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_LUIDAttribute *r);
+NTSTATUS ndr_pull_lsa_LUIDAttribute(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_LUIDAttribute *r);
+NTSTATUS ndr_push_lsa_PrivilegeSet(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_PrivilegeSet *r);
+NTSTATUS ndr_pull_lsa_PrivilegeSet(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_PrivilegeSet *r);
+NTSTATUS ndr_push_lsa_DATA_BUF(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_DATA_BUF *r);
+NTSTATUS ndr_pull_lsa_DATA_BUF(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_DATA_BUF *r);
+NTSTATUS ndr_push_lsa_DATA_BUF2(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_DATA_BUF2 *r);
+NTSTATUS ndr_pull_lsa_DATA_BUF2(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_DATA_BUF2 *r);
+NTSTATUS ndr_push_lsa_TrustDomInfoEnum(struct ndr_push *ndr, int  
ndr_flags, enum lsa_TrustDomInfoEnum r);
+NTSTATUS ndr_pull_lsa_TrustDomInfoEnum(struct ndr_pull *ndr, int  
ndr_flags, enum lsa_TrustDomInfoEnum *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoName(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TrustDomainInfoName *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoName(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TrustDomainInfoName *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoPosixOffset(struct ndr_push  
*ndr, int ndr_flags, const struct lsa_TrustDomainInfoPosixOffset *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoPosixOffset(struct ndr_pull  
*ndr, int ndr_flags, struct lsa_TrustDomainInfoPosixOffset *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoPassword(struct ndr_push *ndr,  
int ndr_flags, const struct lsa_TrustDomainInfoPassword *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoPassword(struct ndr_pull *ndr,  
int ndr_flags, struct lsa_TrustDomainInfoPassword *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoBasic(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TrustDomainInfoBasic *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoBasic(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TrustDomainInfoBasic *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoInfoEx(struct ndr_push *ndr,  
int ndr_flags, const struct lsa_TrustDomainInfoInfoEx *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoInfoEx(struct ndr_pull *ndr,  
int ndr_flags, struct lsa_TrustDomainInfoInfoEx *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoBuffer(struct ndr_push *ndr,  
int ndr_flags, const struct lsa_TrustDomainInfoBuffer *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoBuffer(struct ndr_pull *ndr,  
int ndr_flags, struct lsa_TrustDomainInfoBuffer *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoAuthInfo(struct ndr_push *ndr,  
int ndr_flags, const struct lsa_TrustDomainInfoAuthInfo *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoAuthInfo(struct ndr_pull *ndr,  
int ndr_flags, struct lsa_TrustDomainInfoAuthInfo *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoFullInfo(struct ndr_push *ndr,  
int ndr_flags, const struct lsa_TrustDomainInfoFullInfo *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoFullInfo(struct ndr_pull *ndr,  
int ndr_flags, struct lsa_TrustDomainInfoFullInfo *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfo11(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TrustDomainInfo11 *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfo11(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TrustDomainInfo11 *r);
+NTSTATUS ndr_push_lsa_TrustDomainInfoInfoAll(struct ndr_push *ndr,  
int ndr_flags, const struct lsa_TrustDomainInfoInfoAll *r);
+NTSTATUS ndr_pull_lsa_TrustDomainInfoInfoAll(struct ndr_pull *ndr,  
int ndr_flags, struct lsa_TrustDomainInfoInfoAll *r);
+NTSTATUS ndr_push_lsa_TrustedDomainInfo(struct ndr_push *ndr, int  
ndr_flags, const union lsa_TrustedDomainInfo *r);
+NTSTATUS ndr_pull_lsa_TrustedDomainInfo(struct ndr_pull *ndr, int  
ndr_flags, union lsa_TrustedDomainInfo *r);
+NTSTATUS ndr_push_lsa_DATA_BUF_PTR(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DATA_BUF_PTR *r);
+NTSTATUS ndr_pull_lsa_DATA_BUF_PTR(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DATA_BUF_PTR *r);
+NTSTATUS ndr_push_lsa_RightSet(struct ndr_push *ndr, int ndr_flags,  
const struct lsa_RightSet *r);
+NTSTATUS ndr_pull_lsa_RightSet(struct ndr_pull *ndr, int ndr_flags,  
struct lsa_RightSet *r);
+NTSTATUS ndr_push_lsa_StringPointer(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_StringPointer *r);
+NTSTATUS ndr_pull_lsa_StringPointer(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_StringPointer *r);
+NTSTATUS ndr_push_lsa_DomainListEx(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DomainListEx *r);
+NTSTATUS ndr_pull_lsa_DomainListEx(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DomainListEx *r);
+NTSTATUS ndr_push_lsa_DomainInfoKerberos(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DomainInfoKerberos *r);
+NTSTATUS ndr_pull_lsa_DomainInfoKerberos(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DomainInfoKerberos *r);
+NTSTATUS ndr_push_lsa_DomainInfoEfs(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_DomainInfoEfs *r);
+NTSTATUS ndr_pull_lsa_DomainInfoEfs(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_DomainInfoEfs *r);
+NTSTATUS ndr_push_lsa_DomainInformationPolicy(struct ndr_push *ndr,  
int ndr_flags, const union lsa_DomainInformationPolicy *r);
+NTSTATUS ndr_pull_lsa_DomainInformationPolicy(struct ndr_pull *ndr,  
int ndr_flags, union lsa_DomainInformationPolicy *r);
+NTSTATUS ndr_push_lsa_TranslatedName2(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TranslatedName2 *r);
+NTSTATUS ndr_pull_lsa_TranslatedName2(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TranslatedName2 *r);
+NTSTATUS ndr_push_lsa_TransNameArray2(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TransNameArray2 *r);
+NTSTATUS ndr_pull_lsa_TransNameArray2(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TransNameArray2 *r);
+NTSTATUS ndr_push_lsa_TranslatedSid2(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TranslatedSid2 *r);
+NTSTATUS ndr_pull_lsa_TranslatedSid2(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TranslatedSid2 *r);
+NTSTATUS ndr_push_lsa_TransSidArray2(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TransSidArray2 *r);
+NTSTATUS ndr_pull_lsa_TransSidArray2(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TransSidArray2 *r);
+NTSTATUS ndr_push_lsa_TranslatedSid3(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TranslatedSid3 *r);
+NTSTATUS ndr_pull_lsa_TranslatedSid3(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TranslatedSid3 *r);
+NTSTATUS ndr_push_lsa_TransSidArray3(struct ndr_push *ndr, int  
ndr_flags, const struct lsa_TransSidArray3 *r);
+NTSTATUS ndr_pull_lsa_TransSidArray3(struct ndr_pull *ndr, int  
ndr_flags, struct lsa_TransSidArray3 *r);
+NTSTATUS ndr_push_lsa_Close(struct ndr_push *ndr, int flags, const  
struct lsa_Close *r);
+NTSTATUS ndr_pull_lsa_Close(struct ndr_pull *ndr, int flags, struct  
lsa_Close *r);
+NTSTATUS ndr_push_lsa_Delete(struct ndr_push *ndr, int flags, const  
struct lsa_Delete *r);
+NTSTATUS ndr_pull_lsa_Delete(struct ndr_pull *ndr, int flags, struct  
lsa_Delete *r);
+NTSTATUS ndr_push_lsa_EnumPrivs(struct ndr_push *ndr, int flags,  
const struct lsa_EnumPrivs *r);
+NTSTATUS ndr_pull_lsa_EnumPrivs(struct ndr_pull *ndr, int flags,  
struct lsa_EnumPrivs *r);
+NTSTATUS ndr_push_lsa_QuerySecurity(struct ndr_push *ndr, int flags,  
const struct lsa_QuerySecurity *r);
+NTSTATUS ndr_pull_lsa_QuerySecurity(struct ndr_pull *ndr, int flags,  
struct lsa_QuerySecurity *r);
+NTSTATUS ndr_push_lsa_SetSecObj(struct ndr_push *ndr, int flags,  
const struct lsa_SetSecObj *r);
+NTSTATUS ndr_pull_lsa_SetSecObj(struct ndr_pull *ndr, int flags,  
struct lsa_SetSecObj *r);
+NTSTATUS ndr_push_lsa_ChangePassword(struct ndr_push *ndr, int  
flags, const struct lsa_ChangePassword *r);
+NTSTATUS ndr_pull_lsa_ChangePassword(struct ndr_pull *ndr, int  
flags, struct lsa_ChangePassword *r);
+NTSTATUS ndr_push_lsa_OpenPolicy(struct ndr_push *ndr, int flags,  
const struct lsa_OpenPolicy *r);
+NTSTATUS ndr_pull_lsa_OpenPolicy(struct ndr_pull *ndr, int flags,  
struct lsa_OpenPolicy *r);
+NTSTATUS ndr_push_lsa_QueryInfoPolicy(struct ndr_push *ndr, int  
flags, const struct lsa_QueryInfoPolicy *r);
+NTSTATUS ndr_pull_lsa_QueryInfoPolicy(struct ndr_pull *ndr, int  
flags, struct lsa_QueryInfoPolicy *r);
+NTSTATUS ndr_push_lsa_SetInfoPolicy(struct ndr_push *ndr, int flags,  
const struct lsa_SetInfoPolicy *r);
+NTSTATUS ndr_pull_lsa_SetInfoPolicy(struct ndr_pull *ndr, int flags,  
struct lsa_SetInfoPolicy *r);
+NTSTATUS ndr_push_lsa_ClearAuditLog(struct ndr_push *ndr, int flags,  
const struct lsa_ClearAuditLog *r);
+NTSTATUS ndr_pull_lsa_ClearAuditLog(struct ndr_pull *ndr, int flags,  
struct lsa_ClearAuditLog *r);
+NTSTATUS ndr_push_lsa_CreateAccount(struct ndr_push *ndr, int flags,  
const struct lsa_CreateAccount *r);
+NTSTATUS ndr_pull_lsa_CreateAccount(struct ndr_pull *ndr, int flags,  
struct lsa_CreateAccount *r);
+NTSTATUS ndr_push_lsa_EnumAccounts(struct ndr_push *ndr, int flags,  
const struct lsa_EnumAccounts *r);
+NTSTATUS ndr_pull_lsa_EnumAccounts(struct ndr_pull *ndr, int flags,  
struct lsa_EnumAccounts *r);
+NTSTATUS ndr_push_lsa_CreateTrustedDomain(struct ndr_push *ndr, int  
flags, const struct lsa_CreateTrustedDomain *r);
+NTSTATUS ndr_pull_lsa_CreateTrustedDomain(struct ndr_pull *ndr, int  
flags, struct lsa_CreateTrustedDomain *r);
+NTSTATUS ndr_push_lsa_EnumTrustDom(struct ndr_push *ndr, int flags,  
const struct lsa_EnumTrustDom *r);
+NTSTATUS ndr_pull_lsa_EnumTrustDom(struct ndr_pull *ndr, int flags,  
struct lsa_EnumTrustDom *r);
+NTSTATUS ndr_push_lsa_LookupNames(struct ndr_push *ndr, int flags,  
const struct lsa_LookupNames *r);
+NTSTATUS ndr_pull_lsa_LookupNames(struct ndr_pull *ndr, int flags,  
struct lsa_LookupNames *r);
+NTSTATUS ndr_push_lsa_LookupSids(struct ndr_push *ndr, int flags,  
const struct lsa_LookupSids *r);
+NTSTATUS ndr_pull_lsa_LookupSids(struct ndr_pull *ndr, int flags,  
struct lsa_LookupSids *r);
+NTSTATUS ndr_push_lsa_CreateSecret(struct ndr_push *ndr, int flags,  
const struct lsa_CreateSecret *r);
+NTSTATUS ndr_pull_lsa_CreateSecret(struct ndr_pull *ndr, int flags,  
struct lsa_CreateSecret *r);
+NTSTATUS ndr_push_lsa_OpenAccount(struct ndr_push *ndr, int flags,  
const struct lsa_OpenAccount *r);
+NTSTATUS ndr_pull_lsa_OpenAccount(struct ndr_pull *ndr, int flags,  
struct lsa_OpenAccount *r);
+NTSTATUS ndr_push_lsa_EnumPrivsAccount(struct ndr_push *ndr, int  
flags, const struct lsa_EnumPrivsAccount *r);
+NTSTATUS ndr_pull_lsa_EnumPrivsAccount(struct ndr_pull *ndr, int  
flags, struct lsa_EnumPrivsAccount *r);
+NTSTATUS ndr_push_lsa_AddPrivilegesToAccount(struct ndr_push *ndr,  
int flags, const struct lsa_AddPrivilegesToAccount *r);
+NTSTATUS ndr_pull_lsa_AddPrivilegesToAccount(struct ndr_pull *ndr,  
int flags, struct lsa_AddPrivilegesToAccount *r);
+NTSTATUS ndr_push_lsa_RemovePrivilegesFromAccount(struct ndr_push  
*ndr, int flags, const struct lsa_RemovePrivilegesFromAccount *r);
+NTSTATUS ndr_pull_lsa_RemovePrivilegesFromAccount(struct ndr_pull  
*ndr, int flags, struct lsa_RemovePrivilegesFromAccount *r);
+NTSTATUS ndr_push_lsa_GetQuotasForAccount(struct ndr_push *ndr, int  
flags, const struct lsa_GetQuotasForAccount *r);
+NTSTATUS ndr_pull_lsa_GetQuotasForAccount(struct ndr_pull *ndr, int  
flags, struct lsa_GetQuotasForAccount *r);
+NTSTATUS ndr_push_lsa_SetQuotasForAccount(struct ndr_push *ndr, int  
flags, const struct lsa_SetQuotasForAccount *r);
+NTSTATUS ndr_pull_lsa_SetQuotasForAccount(struct ndr_pull *ndr, int  
flags, struct lsa_SetQuotasForAccount *r);
+NTSTATUS ndr_push_lsa_GetSystemAccessAccount(struct ndr_push *ndr,  
int flags, const struct lsa_GetSystemAccessAccount *r);
+NTSTATUS ndr_pull_lsa_GetSystemAccessAccount(struct ndr_pull *ndr,  
int flags, struct lsa_GetSystemAccessAccount *r);
+NTSTATUS ndr_push_lsa_SetSystemAccessAccount(struct ndr_push *ndr,  
int flags, const struct lsa_SetSystemAccessAccount *r);
+NTSTATUS ndr_pull_lsa_SetSystemAccessAccount(struct ndr_pull *ndr,  
int flags, struct lsa_SetSystemAccessAccount *r);
+NTSTATUS ndr_push_lsa_OpenTrustedDomain(struct ndr_push *ndr, int  
flags, const struct lsa_OpenTrustedDomain *r);
+NTSTATUS ndr_pull_lsa_OpenTrustedDomain(struct ndr_pull *ndr, int  
flags, struct lsa_OpenTrustedDomain *r);
+NTSTATUS ndr_push_lsa_QueryTrustedDomainInfo(struct ndr_push *ndr,  
int flags, const struct lsa_QueryTrustedDomainInfo *r);
+NTSTATUS ndr_pull_lsa_QueryTrustedDomainInfo(struct ndr_pull *ndr,  
int flags, struct lsa_QueryTrustedDomainInfo *r);
+NTSTATUS ndr_push_lsa_SetInformationTrustedDomain(struct ndr_push  
*ndr, int flags, const struct lsa_SetInformationTrustedDomain *r);
+NTSTATUS ndr_pull_lsa_SetInformationTrustedDomain(struct ndr_pull  
*ndr, int flags, struct lsa_SetInformationTrustedDomain *r);
+NTSTATUS ndr_push_lsa_OpenSecret(struct ndr_push *ndr, int flags,  
const struct lsa_OpenSecret *r);
+NTSTATUS ndr_pull_lsa_OpenSecret(struct ndr_pull *ndr, int flags,  
struct lsa_OpenSecret *r);
+NTSTATUS ndr_push_lsa_SetSecret(struct ndr_push *ndr, int flags,  
const struct lsa_SetSecret *r);
+NTSTATUS ndr_pull_lsa_SetSecret(struct ndr_pull *ndr, int flags,  
struct lsa_SetSecret *r);
+NTSTATUS ndr_push_lsa_QuerySecret(struct ndr_push *ndr, int flags,  
const struct lsa_QuerySecret *r);
+NTSTATUS ndr_pull_lsa_QuerySecret(struct ndr_pull *ndr, int flags,  
struct lsa_QuerySecret *r);
+NTSTATUS ndr_push_lsa_LookupPrivValue(struct ndr_push *ndr, int  
flags, const struct lsa_LookupPrivValue *r);
+NTSTATUS ndr_pull_lsa_LookupPrivValue(struct ndr_pull *ndr, int  
flags, struct lsa_LookupPrivValue *r);
+NTSTATUS ndr_push_lsa_LookupPrivName(struct ndr_push *ndr, int  
flags, const struct lsa_LookupPrivName *r);
+NTSTATUS ndr_pull_lsa_LookupPrivName(struct ndr_pull *ndr, int  
flags, struct lsa_LookupPrivName *r);
+NTSTATUS ndr_push_lsa_LookupPrivDisplayName(struct ndr_push *ndr,  
int flags, const struct lsa_LookupPrivDisplayName *r);
+NTSTATUS ndr_pull_lsa_LookupPrivDisplayName(struct ndr_pull *ndr,  
int flags, struct lsa_LookupPrivDisplayName *r);
+NTSTATUS ndr_push_lsa_DeleteObject(struct ndr_push *ndr, int flags,  
const struct lsa_DeleteObject *r);
+NTSTATUS ndr_pull_lsa_DeleteObject(struct ndr_pull *ndr, int flags,  
struct lsa_DeleteObject *r);
+NTSTATUS ndr_push_lsa_EnumAccountsWithUserRight(struct ndr_push  
*ndr, int flags, const struct lsa_EnumAccountsWithUserRight *r);
+NTSTATUS ndr_pull_lsa_EnumAccountsWithUserRight(struct ndr_pull  
*ndr, int flags, struct lsa_EnumAccountsWithUserRight *r);
+NTSTATUS ndr_push_lsa_EnumAccountRights(struct ndr_push *ndr, int  
flags, const struct lsa_EnumAccountRights *r);
+NTSTATUS ndr_pull_lsa_EnumAccountRights(struct ndr_pull *ndr, int  
flags, struct lsa_EnumAccountRights *r);
+NTSTATUS ndr_push_lsa_AddAccountRights(struct ndr_push *ndr, int  
flags, const struct lsa_AddAccountRights *r);
+NTSTATUS ndr_pull_lsa_AddAccountRights(struct ndr_pull *ndr, int  
flags, struct lsa_AddAccountRights *r);
+NTSTATUS ndr_push_lsa_RemoveAccountRights(struct ndr_push *ndr, int  
flags, const struct lsa_RemoveAccountRights *r);
+NTSTATUS ndr_pull_lsa_RemoveAccountRights(struct ndr_pull *ndr, int  
flags, struct lsa_RemoveAccountRights *r);
+NTSTATUS ndr_push_lsa_QueryTrustedDomainInfoBySid(struct ndr_push  
*ndr, int flags, const struct lsa_QueryTrustedDomainInfoBySid *r);
+NTSTATUS ndr_pull_lsa_QueryTrustedDomainInfoBySid(struct ndr_pull  
*ndr, int flags, struct lsa_QueryTrustedDomainInfoBySid *r);
+NTSTATUS ndr_push_lsa_SetTrustedDomainInfo(struct ndr_push *ndr, int  
flags, const struct lsa_SetTrustedDomainInfo *r);
+NTSTATUS ndr_pull_lsa_SetTrustedDomainInfo(struct ndr_pull *ndr, int  
flags, struct lsa_SetTrustedDomainInfo *r);
+NTSTATUS ndr_push_lsa_DeleteTrustedDomain(struct ndr_push *ndr, int  
flags, const struct lsa_DeleteTrustedDomain *r);
+NTSTATUS ndr_pull_lsa_DeleteTrustedDomain(struct ndr_pull *ndr, int  
flags, struct lsa_DeleteTrustedDomain *r);
+NTSTATUS ndr_push_lsa_StorePrivateData(struct ndr_push *ndr, int  
flags, const struct lsa_StorePrivateData *r);
+NTSTATUS ndr_pull_lsa_StorePrivateData(struct ndr_pull *ndr, int  
flags, struct lsa_StorePrivateData *r);
+NTSTATUS ndr_push_lsa_RetrievePrivateData(struct ndr_push *ndr, int  
flags, const struct lsa_RetrievePrivateData *r);
+NTSTATUS ndr_pull_lsa_RetrievePrivateData(struct ndr_pull *ndr, int  
flags, struct lsa_RetrievePrivateData *r);
+NTSTATUS ndr_push_lsa_OpenPolicy2(struct ndr_push *ndr, int flags,  
const struct lsa_OpenPolicy2 *r);
+NTSTATUS ndr_pull_lsa_OpenPolicy2(struct ndr_pull *ndr, int flags,  
struct lsa_OpenPolicy2 *r);
+NTSTATUS ndr_push_lsa_GetUserName(struct ndr_push *ndr, int flags,  
const struct lsa_GetUserName *r);
+NTSTATUS ndr_pull_lsa_GetUserName(struct ndr_pull *ndr, int flags,  
struct lsa_GetUserName *r);
+NTSTATUS ndr_push_lsa_QueryInfoPolicy2(struct ndr_push *ndr, int  
flags, const struct lsa_QueryInfoPolicy2 *r);
+NTSTATUS ndr_pull_lsa_QueryInfoPolicy2(struct ndr_pull *ndr, int  
flags, struct lsa_QueryInfoPolicy2 *r);
+NTSTATUS ndr_push_lsa_SetInfoPolicy2(struct ndr_push *ndr, int  
flags, const struct lsa_SetInfoPolicy2 *r);
+NTSTATUS ndr_pull_lsa_SetInfoPolicy2(struct ndr_pull *ndr, int  
flags, struct lsa_SetInfoPolicy2 *r);
+NTSTATUS ndr_push_lsa_QueryTrustedDomainInfoByName(struct ndr_push  
*ndr, int flags, const struct lsa_QueryTrustedDomainInfoByName *r);
+NTSTATUS ndr_pull_lsa_QueryTrustedDomainInfoByName(struct ndr_pull  
*ndr, int flags, struct lsa_QueryTrustedDomainInfoByName *r);
+NTSTATUS ndr_push_lsa_SetTrustedDomainInfoByName(struct ndr_push  
*ndr, int flags, const struct lsa_SetTrustedDomainInfoByName *r);
+NTSTATUS ndr_pull_lsa_SetTrustedDomainInfoByName(struct ndr_pull  
*ndr, int flags, struct lsa_SetTrustedDomainInfoByName *r);
+NTSTATUS ndr_push_lsa_EnumTrustedDomainsEx(struct ndr_push *ndr, int  
flags, const struct lsa_EnumTrustedDomainsEx *r);
+NTSTATUS ndr_pull_lsa_EnumTrustedDomainsEx(struct ndr_pull *ndr, int  
flags, struct lsa_EnumTrustedDomainsEx *r);
+NTSTATUS ndr_push_lsa_CreateTrustedDomainEx(struct ndr_push *ndr,  
int flags, const struct lsa_CreateTrustedDomainEx *r);
+NTSTATUS ndr_pull_lsa_CreateTrustedDomainEx(struct ndr_pull *ndr,  
int flags, struct lsa_CreateTrustedDomainEx *r);
+NTSTATUS ndr_push_lsa_CloseTrustedDomainEx(struct ndr_push *ndr, int  
flags, const struct lsa_CloseTrustedDomainEx *r);
+NTSTATUS ndr_pull_lsa_CloseTrustedDomainEx(struct ndr_pull *ndr, int  
flags, struct lsa_CloseTrustedDomainEx *r);
+NTSTATUS ndr_push_lsa_QueryDomainInformationPolicy(struct ndr_push  
*ndr, int flags, const struct lsa_QueryDomainInformationPolicy *r);
+NTSTATUS ndr_pull_lsa_QueryDomainInformationPolicy(struct ndr_pull  
*ndr, int flags, struct lsa_QueryDomainInformationPolicy *r);
+NTSTATUS ndr_push_lsa_SetDomainInformationPolicy(struct ndr_push  
*ndr, int flags, const struct lsa_SetDomainInformationPolicy *r);
+NTSTATUS ndr_pull_lsa_SetDomainInformationPolicy(struct ndr_pull  
*ndr, int flags, struct lsa_SetDomainInformationPolicy *r);
+NTSTATUS ndr_push_lsa_OpenTrustedDomainByName(struct ndr_push *ndr,  
int flags, const struct lsa_OpenTrustedDomainByName *r);
+NTSTATUS ndr_pull_lsa_OpenTrustedDomainByName(struct ndr_pull *ndr,  
int flags, struct lsa_OpenTrustedDomainByName *r);
+NTSTATUS ndr_push_lsa_TestCall(struct ndr_push *ndr, int flags,  
const struct lsa_TestCall *r);
+NTSTATUS ndr_pull_lsa_TestCall(struct ndr_pull *ndr, int flags,  
struct lsa_TestCall *r);
+NTSTATUS ndr_push_lsa_LookupSids2(struct ndr_push *ndr, int flags,  
const struct lsa_LookupSids2 *r);
+NTSTATUS ndr_pull_lsa_LookupSids2(struct ndr_pull *ndr, int flags,  
struct lsa_LookupSids2 *r);
+NTSTATUS ndr_push_lsa_LookupNames2(struct ndr_push *ndr, int flags,  
const struct lsa_LookupNames2 *r);
+NTSTATUS ndr_pull_lsa_LookupNames2(struct ndr_pull *ndr, int flags,  
struct lsa_LookupNames2 *r);
+NTSTATUS ndr_push_lsa_CreateTrustedDomainEx2(struct ndr_push *ndr,  
int flags, const struct lsa_CreateTrustedDomainEx2 *r);
+NTSTATUS ndr_pull_lsa_CreateTrustedDomainEx2(struct ndr_pull *ndr,  
int flags, struct lsa_CreateTrustedDomainEx2 *r);
+NTSTATUS ndr_push_lsa_CREDRWRITE(struct ndr_push *ndr, int flags,  
const struct lsa_CREDRWRITE *r);
+NTSTATUS ndr_pull_lsa_CREDRWRITE(struct ndr_pull *ndr, int flags,  
struct lsa_CREDRWRITE *r);
+NTSTATUS ndr_push_lsa_CREDRREAD(struct ndr_push *ndr, int flags,  
const struct lsa_CREDRREAD *r);
+NTSTATUS ndr_pull_lsa_CREDRREAD(struct ndr_pull *ndr, int flags,  
struct lsa_CREDRREAD *r);
+NTSTATUS ndr_push_lsa_CREDRENUMERATE(struct ndr_push *ndr, int  
flags, const struct lsa_CREDRENUMERATE *r);
+NTSTATUS ndr_pull_lsa_CREDRENUMERATE(struct ndr_pull *ndr, int  
flags, struct lsa_CREDRENUMERATE *r);
+NTSTATUS ndr_push_lsa_CREDRWRITEDOMAINCREDENTIALS(struct ndr_push  
*ndr, int flags, const struct lsa_CREDRWRITEDOMAINCREDENTIALS *r);
+NTSTATUS ndr_pull_lsa_CREDRWRITEDOMAINCREDENTIALS(struct ndr_pull  
*ndr, int flags, struct lsa_CREDRWRITEDOMAINCREDENTIALS *r);
+NTSTATUS ndr_push_lsa_CREDRREADDOMAINCREDENTIALS(struct ndr_push  
*ndr, int flags, const struct lsa_CREDRREADDOMAINCREDENTIALS *r);
+NTSTATUS ndr_pull_lsa_CREDRREADDOMAINCREDENTIALS(struct ndr_pull  
*ndr, int flags, struct lsa_CREDRREADDOMAINCREDENTIALS *r);
+NTSTATUS ndr_push_lsa_CREDRDELETE(struct ndr_push *ndr, int flags,  
const struct lsa_CREDRDELETE *r);
+NTSTATUS ndr_pull_lsa_CREDRDELETE(struct ndr_pull *ndr, int flags,  
struct lsa_CREDRDELETE *r);
+NTSTATUS ndr_push_lsa_CREDRGETTARGETINFO(struct ndr_push *ndr, int  
flags, const struct lsa_CREDRGETTARGETINFO *r);
+NTSTATUS ndr_pull_lsa_CREDRGETTARGETINFO(struct ndr_pull *ndr, int  
flags, struct lsa_CREDRGETTARGETINFO *r);
+NTSTATUS ndr_push_lsa_CREDRPROFILELOADED(struct ndr_push *ndr, int  
flags, const struct lsa_CREDRPROFILELOADED *r);
+NTSTATUS ndr_pull_lsa_CREDRPROFILELOADED(struct ndr_pull *ndr, int  
flags, struct lsa_CREDRPROFILELOADED *r);
+NTSTATUS ndr_push_lsa_LookupNames3(struct ndr_push *ndr, int flags,  
const struct lsa_LookupNames3 *r);
+NTSTATUS ndr_pull_lsa_LookupNames3(struct ndr_pull *ndr, int flags,  
struct lsa_LookupNames3 *r);
+NTSTATUS ndr_push_lsa_CREDRGETSESSIONTYPES(struct ndr_push *ndr, int  
flags, const struct lsa_CREDRGETSESSIONTYPES *r);
+NTSTATUS ndr_pull_lsa_CREDRGETSESSIONTYPES(struct ndr_pull *ndr, int  
flags, struct lsa_CREDRGETSESSIONTYPES *r);
+NTSTATUS ndr_push_lsa_LSARREGISTERAUDITEVENT(struct ndr_push *ndr,  
int flags, const struct lsa_LSARREGISTERAUDITEVENT *r);
+NTSTATUS ndr_pull_lsa_LSARREGISTERAUDITEVENT(struct ndr_pull *ndr,  
int flags, struct lsa_LSARREGISTERAUDITEVENT *r);
+NTSTATUS ndr_push_lsa_LSARGENAUDITEVENT(struct ndr_push *ndr, int  
flags, const struct lsa_LSARGENAUDITEVENT *r);
+NTSTATUS ndr_pull_lsa_LSARGENAUDITEVENT(struct ndr_pull *ndr, int  
flags, struct lsa_LSARGENAUDITEVENT *r);
+NTSTATUS ndr_push_lsa_LSARUNREGISTERAUDITEVENT(struct ndr_push *ndr,  
int flags, const struct lsa_LSARUNREGISTERAUDITEVENT *r);
+NTSTATUS ndr_pull_lsa_LSARUNREGISTERAUDITEVENT(struct ndr_pull *ndr,  
int flags, struct lsa_LSARUNREGISTERAUDITEVENT *r);
+NTSTATUS ndr_push_lsa_LSARQUERYFORESTTRUSTINFORMATION(struct  
ndr_push *ndr, int flags, const struct  
lsa_LSARQUERYFORESTTRUSTINFORMATION *r);
+NTSTATUS ndr_pull_lsa_LSARQUERYFORESTTRUSTINFORMATION(struct  
ndr_pull *ndr, int flags, struct lsa_LSARQUERYFORESTTRUSTINFORMATION  
*r);
+NTSTATUS ndr_push_lsa_LSARSETFORESTTRUSTINFORMATION(struct ndr_push  
*ndr, int flags, const struct lsa_LSARSETFORESTTRUSTINFORMATION *r);
+NTSTATUS ndr_pull_lsa_LSARSETFORESTTRUSTINFORMATION(struct ndr_pull  
*ndr, int flags, struct lsa_LSARSETFORESTTRUSTINFORMATION *r);
+NTSTATUS ndr_push_lsa_CREDRRENAME(struct ndr_push *ndr, int flags,  
const struct lsa_CREDRRENAME *r);
+NTSTATUS ndr_pull_lsa_CREDRRENAME(struct ndr_pull *ndr, int flags,  
struct lsa_CREDRRENAME *r);
+NTSTATUS ndr_push_lsa_LookupSids3(struct ndr_push *ndr, int flags,  
const struct lsa_LookupSids3 *r);
+NTSTATUS ndr_pull_lsa_LookupSids3(struct ndr_pull *ndr, int flags,  
struct lsa_LookupSids3 *r);
+NTSTATUS ndr_push_lsa_LookupNames4(struct ndr_push *ndr, int flags,  
const struct lsa_LookupNames4 *r);
+NTSTATUS ndr_pull_lsa_LookupNames4(struct ndr_pull *ndr, int flags,  
struct lsa_LookupNames4 *r);
+NTSTATUS ndr_push_lsa_LSAROPENPOLICYSCE(struct ndr_push *ndr, int  
flags, const struct lsa_LSAROPENPOLICYSCE *r);
+NTSTATUS ndr_pull_lsa_LSAROPENPOLICYSCE(struct ndr_pull *ndr, int  
flags, struct lsa_LSAROPENPOLICYSCE *r);
+NTSTATUS ndr_push_lsa_LSARADTREGISTERSECURITYEVENTSOURCE(struct  
ndr_push *ndr, int flags, const struct  
lsa_LSARADTREGISTERSECURITYEVENTSOURCE *r);
+NTSTATUS ndr_pull_lsa_LSARADTREGISTERSECURITYEVENTSOURCE(struct  
ndr_pull *ndr, int flags, struct  
lsa_LSARADTREGISTERSECURITYEVENTSOURCE *r);
+NTSTATUS ndr_push_lsa_LSARADTUNREGISTERSECURITYEVENTSOURCE(struct  
ndr_push *ndr, int flags, const struct  
lsa_LSARADTUNREGISTERSECURITYEVENTSOURCE *r);
+NTSTATUS ndr_pull_lsa_LSARADTUNREGISTERSECURITYEVENTSOURCE(struct  
ndr_pull *ndr, int flags, struct  
lsa_LSARADTUNREGISTERSECURITYEVENTSOURCE *r);
+NTSTATUS ndr_push_lsa_LSARADTREPORTSECURITYEVENT(struct ndr_push  
*ndr, int flags, const struct lsa_LSARADTREPORTSECURITYEVENT *r);
+NTSTATUS ndr_pull_lsa_LSARADTREPORTSECURITYEVENT(struct ndr_pull  
*ndr, int flags, struct lsa_LSARADTREPORTSECURITYEVENT *r);
+
+/* The following definitions come from librpc/gen_ndr/ndr_notify.c  */
+
+NTSTATUS ndr_push_notify_depth(struct ndr_push *ndr, int ndr_flags,  
const struct notify_depth *r);
+NTSTATUS ndr_pull_notify_depth(struct ndr_pull *ndr, int ndr_flags,  
struct notify_depth *r);
+
+/* The following definitions come from librpc/gen_ndr/ndr_srvsvc.c  */
+
+NTSTATUS ndr_push_srvsvc_NetCharDevInfo0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevInfo0 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevInfo0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevInfo0 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevCtr0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevCtr0 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevCtr0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevCtr0 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevInfo1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevInfo1 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevInfo1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevInfo1 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevCtr1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevCtr1 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevCtr1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevCtr1 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevInfo(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetCharDevInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevInfo(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetCharDevInfo *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevCtr(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetCharDevCtr *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevCtr(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetCharDevCtr *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQInfo0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevQInfo0 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQInfo0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevQInfo0 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQCtr0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevQCtr0 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQCtr0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevQCtr0 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQInfo1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevQInfo1 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQInfo1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevQInfo1 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQCtr1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetCharDevQCtr1 *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQCtr1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetCharDevQCtr1 *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQInfo(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetCharDevQInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQInfo(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetCharDevQInfo *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQCtr(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetCharDevQCtr *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQCtr(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetCharDevQCtr *r);
+NTSTATUS ndr_push_srvsvc_NetConnInfo0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetConnInfo0 *r);
+NTSTATUS ndr_pull_srvsvc_NetConnInfo0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetConnInfo0 *r);
+NTSTATUS ndr_push_srvsvc_NetConnCtr0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetConnCtr0 *r);
+NTSTATUS ndr_pull_srvsvc_NetConnCtr0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetConnCtr0 *r);
+NTSTATUS ndr_push_srvsvc_NetConnInfo1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetConnInfo1 *r);
+NTSTATUS ndr_pull_srvsvc_NetConnInfo1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetConnInfo1 *r);
+NTSTATUS ndr_push_srvsvc_NetConnCtr1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetConnCtr1 *r);
+NTSTATUS ndr_pull_srvsvc_NetConnCtr1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetConnCtr1 *r);
+NTSTATUS ndr_push_srvsvc_NetConnCtr(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetConnCtr *r);
+NTSTATUS ndr_pull_srvsvc_NetConnCtr(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetConnCtr *r);
+NTSTATUS ndr_push_srvsvc_NetFileInfo2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetFileInfo2 *r);
+NTSTATUS ndr_pull_srvsvc_NetFileInfo2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetFileInfo2 *r);
+NTSTATUS ndr_push_srvsvc_NetFileCtr2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetFileCtr2 *r);
+NTSTATUS ndr_pull_srvsvc_NetFileCtr2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetFileCtr2 *r);
+NTSTATUS ndr_push_srvsvc_NetFileInfo3(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetFileInfo3 *r);
+NTSTATUS ndr_pull_srvsvc_NetFileInfo3(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetFileInfo3 *r);
+NTSTATUS ndr_push_srvsvc_NetFileCtr3(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetFileCtr3 *r);
+NTSTATUS ndr_pull_srvsvc_NetFileCtr3(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetFileCtr3 *r);
+NTSTATUS ndr_push_srvsvc_NetFileInfo(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetFileInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetFileInfo(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetFileInfo *r);
+NTSTATUS ndr_push_srvsvc_NetFileCtr(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetFileCtr *r);
+NTSTATUS ndr_pull_srvsvc_NetFileCtr(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetFileCtr *r);
+NTSTATUS ndr_push_srvsvc_NetSessInfo0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessInfo0 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessInfo0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessInfo0 *r);
+NTSTATUS ndr_push_srvsvc_NetSessCtr0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessCtr0 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessCtr0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessCtr0 *r);
+NTSTATUS ndr_push_srvsvc_NetSessInfo1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessInfo1 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessInfo1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessInfo1 *r);
+NTSTATUS ndr_push_srvsvc_NetSessCtr1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessCtr1 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessCtr1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessCtr1 *r);
+NTSTATUS ndr_push_srvsvc_NetSessInfo2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessInfo2 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessInfo2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessInfo2 *r);
+NTSTATUS ndr_push_srvsvc_NetSessCtr2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessCtr2 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessCtr2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessCtr2 *r);
+NTSTATUS ndr_push_srvsvc_NetSessInfo10(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessInfo10 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessInfo10(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessInfo10 *r);
+NTSTATUS ndr_push_srvsvc_NetSessCtr10(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessCtr10 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessCtr10(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessCtr10 *r);
+NTSTATUS ndr_push_srvsvc_NetSessInfo502(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessInfo502 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessInfo502(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessInfo502 *r);
+NTSTATUS ndr_push_srvsvc_NetSessCtr502(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSessCtr502 *r);
+NTSTATUS ndr_pull_srvsvc_NetSessCtr502(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSessCtr502 *r);
+NTSTATUS ndr_push_srvsvc_NetSessCtr(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetSessCtr *r);
+NTSTATUS ndr_pull_srvsvc_NetSessCtr(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetSessCtr *r);
+NTSTATUS ndr_push_srvsvc_ShareType(struct ndr_push *ndr, int  
ndr_flags, enum srvsvc_ShareType r);
+NTSTATUS ndr_pull_srvsvc_ShareType(struct ndr_pull *ndr, int  
ndr_flags, enum srvsvc_ShareType *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo0 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo0 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr0 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr0 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo1 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo1 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr1 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr1 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo2 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo2 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr2 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr2 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo501(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo501 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo501(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo501 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr501(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr501 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr501(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr501 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo502(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo502 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo502(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo502 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr502(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr502 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr502(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr502 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo1004(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo1004 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo1004(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo1004 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr1004(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr1004 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr1004(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr1004 *r);
+NTSTATUS ndr_push_NetShareInfo1005Flags(struct ndr_push *ndr, int  
ndr_flags, uint32_t r);
+NTSTATUS ndr_pull_NetShareInfo1005Flags(struct ndr_pull *ndr, int  
ndr_flags, uint32_t *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo1005(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo1005 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo1005(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo1005 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr1005(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr1005 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr1005(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr1005 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo1006(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo1006 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo1006(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo1006 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr1006(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr1006 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr1006(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr1006 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo1007(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareInfo1007 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo1007(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareInfo1007 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr1007(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr1007 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr1007(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr1007 *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr1501(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetShareCtr1501 *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr1501(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetShareCtr1501 *r);
+NTSTATUS ndr_push_srvsvc_NetShareInfo(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetShareInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetShareInfo(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetShareInfo *r);
+NTSTATUS ndr_push_srvsvc_NetShareCtr(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetShareCtr *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCtr(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetShareCtr *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo100(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo100 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo100(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo100 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo101(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo101 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo101(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo101 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo102(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo102 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo102(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo102 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo402(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo402 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo402(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo402 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo403(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo403 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo403(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo403 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo502(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo502 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo502(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo502 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo503(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo503 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo503(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo503 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo599(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo599 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo599(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo599 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1005(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1005 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1005(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1005 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1010(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1010 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1010(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1010 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1016(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1016 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1016(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1016 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1017(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1017 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1017(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1017 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1018(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1018 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1018(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1018 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1107(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1107 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1107(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1107 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1501(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1501 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1501(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1501 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1502(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1502 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1502(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1502 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1503(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1503 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1503(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1503 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1506(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1506 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1506(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1506 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1509(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1509 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1509(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1509 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1510(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1510 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1510(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1510 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1511(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1511 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1511(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1511 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1512(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1512 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1512(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1512 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1513(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1513 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1513(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1513 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1514(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1514 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1514(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1514 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1515(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1515 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1515(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1515 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1516(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1516 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1516(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1516 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1518(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1518 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1518(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1518 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1520(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1520 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1520(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1520 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1521(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1521 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1521(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1521 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1522(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1522 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1522(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1522 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1523(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1523 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1523(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1523 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1524(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1524 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1524(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1524 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1525(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1525 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1525(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1525 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1528(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1528 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1528(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1528 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1529(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1529 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1529(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1529 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1530(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1530 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1530(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1530 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1533(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1533 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1533(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1533 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1534(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1534 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1534(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1534 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1535(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1535 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1535(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1535 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1536(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1536 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1536(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1536 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1537(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1537 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1537(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1537 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1538(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1538 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1538(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1538 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1539(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1539 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1539(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1539 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1540(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1540 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1540(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1540 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1541(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1541 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1541(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1541 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1542(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1542 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1542(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1542 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1543(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1543 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1543(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1543 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1544(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1544 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1544(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1544 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1545(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1545 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1545(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1545 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1546(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1546 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1546(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1546 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1547(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1547 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1547(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1547 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1548(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1548 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1548(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1548 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1549(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1549 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1549(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1549 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1550(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1550 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1550(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1550 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1552(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1552 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1552(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1552 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1553(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1553 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1553(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1553 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1554(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1554 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1554(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1554 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1555(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1555 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1555(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1555 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo1556(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetSrvInfo1556 *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo1556(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetSrvInfo1556 *r);
+NTSTATUS ndr_push_srvsvc_NetSrvInfo(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetSrvInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvInfo(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetSrvInfo *r);
+NTSTATUS ndr_push_srvsvc_NetDiskInfo0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetDiskInfo0 *r);
+NTSTATUS ndr_pull_srvsvc_NetDiskInfo0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetDiskInfo0 *r);
+NTSTATUS ndr_push_srvsvc_NetDiskInfo(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetDiskInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetDiskInfo(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetDiskInfo *r);
+NTSTATUS ndr_push_srvsvc_Statistics(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_Statistics *r);
+NTSTATUS ndr_pull_srvsvc_Statistics(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_Statistics *r);
+NTSTATUS ndr_push_srvsvc_NetTransportInfo0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportInfo0 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportInfo0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportInfo0 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportCtr0(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportCtr0 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportCtr0(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportCtr0 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportInfo1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportInfo1 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportInfo1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportInfo1 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportCtr1(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportCtr1 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportCtr1(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportCtr1 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportInfo2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportInfo2 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportInfo2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportInfo2 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportCtr2(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportCtr2 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportCtr2(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportCtr2 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportInfo3(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportInfo3 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportInfo3(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportInfo3 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportCtr3(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetTransportCtr3 *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportCtr3(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetTransportCtr3 *r);
+NTSTATUS ndr_push_srvsvc_NetTransportCtr(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetTransportCtr *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportCtr(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetTransportCtr *r);
+NTSTATUS ndr_push_srvsvc_NetRemoteTODInfo(struct ndr_push *ndr, int  
ndr_flags, const struct srvsvc_NetRemoteTODInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetRemoteTODInfo(struct ndr_pull *ndr, int  
ndr_flags, struct srvsvc_NetRemoteTODInfo *r);
+NTSTATUS ndr_push_srvsvc_NetTransportInfo(struct ndr_push *ndr, int  
ndr_flags, const union srvsvc_NetTransportInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportInfo(struct ndr_pull *ndr, int  
ndr_flags, union srvsvc_NetTransportInfo *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetCharDevEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetCharDevEnum *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevGetInfo(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetCharDevGetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevGetInfo(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetCharDevGetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevControl(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetCharDevControl *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevControl(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetCharDevControl *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetCharDevQEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetCharDevQEnum *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQGetInfo(struct ndr_push *ndr,  
int flags, const struct srvsvc_NetCharDevQGetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQGetInfo(struct ndr_pull *ndr,  
int flags, struct srvsvc_NetCharDevQGetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQSetInfo(struct ndr_push *ndr,  
int flags, const struct srvsvc_NetCharDevQSetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQSetInfo(struct ndr_pull *ndr,  
int flags, struct srvsvc_NetCharDevQSetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQPurge(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetCharDevQPurge *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQPurge(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetCharDevQPurge *r);
+NTSTATUS ndr_push_srvsvc_NetCharDevQPurgeSelf(struct ndr_push *ndr,  
int flags, const struct srvsvc_NetCharDevQPurgeSelf *r);
+NTSTATUS ndr_pull_srvsvc_NetCharDevQPurgeSelf(struct ndr_pull *ndr,  
int flags, struct srvsvc_NetCharDevQPurgeSelf *r);
+NTSTATUS ndr_push_srvsvc_NetConnEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetConnEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetConnEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetConnEnum *r);
+NTSTATUS ndr_push_srvsvc_NetFileEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetFileEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetFileEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetFileEnum *r);
+NTSTATUS ndr_push_srvsvc_NetFileGetInfo(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetFileGetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetFileGetInfo(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetFileGetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetFileClose(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetFileClose *r);
+NTSTATUS ndr_pull_srvsvc_NetFileClose(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetFileClose *r);
+NTSTATUS ndr_push_srvsvc_NetSessEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetSessEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetSessEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetSessEnum *r);
+NTSTATUS ndr_push_srvsvc_NetSessDel(struct ndr_push *ndr, int flags,  
const struct srvsvc_NetSessDel *r);
+NTSTATUS ndr_pull_srvsvc_NetSessDel(struct ndr_pull *ndr, int flags,  
struct srvsvc_NetSessDel *r);
+NTSTATUS ndr_push_srvsvc_NetShareAdd(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareAdd *r);
+NTSTATUS ndr_pull_srvsvc_NetShareAdd(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareAdd *r);
+NTSTATUS ndr_push_srvsvc_NetShareEnumAll(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareEnumAll *r);
+NTSTATUS ndr_pull_srvsvc_NetShareEnumAll(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareEnumAll *r);
+NTSTATUS ndr_push_srvsvc_NetShareGetInfo(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareGetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetShareGetInfo(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareGetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetShareSetInfo(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareSetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetShareSetInfo(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareSetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetShareDel(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareDel *r);
+NTSTATUS ndr_pull_srvsvc_NetShareDel(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareDel *r);
+NTSTATUS ndr_push_srvsvc_NetShareDelSticky(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareDelSticky *r);
+NTSTATUS ndr_pull_srvsvc_NetShareDelSticky(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareDelSticky *r);
+NTSTATUS ndr_push_srvsvc_NetShareCheck(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareCheck *r);
+NTSTATUS ndr_pull_srvsvc_NetShareCheck(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareCheck *r);
+NTSTATUS ndr_push_srvsvc_NetSrvGetInfo(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetSrvGetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvGetInfo(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetSrvGetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetSrvSetInfo(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetSrvSetInfo *r);
+NTSTATUS ndr_pull_srvsvc_NetSrvSetInfo(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetSrvSetInfo *r);
+NTSTATUS ndr_push_srvsvc_NetDiskEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetDiskEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetDiskEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetDiskEnum *r);
+NTSTATUS ndr_push_srvsvc_NetServerStatisticsGet(struct ndr_push  
*ndr, int flags, const struct srvsvc_NetServerStatisticsGet *r);
+NTSTATUS ndr_pull_srvsvc_NetServerStatisticsGet(struct ndr_pull  
*ndr, int flags, struct srvsvc_NetServerStatisticsGet *r);
+NTSTATUS ndr_push_srvsvc_NetTransportAdd(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetTransportAdd *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportAdd(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetTransportAdd *r);
+NTSTATUS ndr_push_srvsvc_NetTransportEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetTransportEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetTransportEnum *r);
+NTSTATUS ndr_push_srvsvc_NetTransportDel(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetTransportDel *r);
+NTSTATUS ndr_pull_srvsvc_NetTransportDel(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetTransportDel *r);
+NTSTATUS ndr_push_srvsvc_NetRemoteTOD(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetRemoteTOD *r);
+NTSTATUS ndr_pull_srvsvc_NetRemoteTOD(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetRemoteTOD *r);
+NTSTATUS ndr_push_srvsvc_NetSetServiceBits(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetSetServiceBits *r);
+NTSTATUS ndr_pull_srvsvc_NetSetServiceBits(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetSetServiceBits *r);
+NTSTATUS ndr_push_srvsvc_NetPathType(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetPathType *r);
+NTSTATUS ndr_pull_srvsvc_NetPathType(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetPathType *r);
+NTSTATUS ndr_push_srvsvc_NetPathCanonicalize(struct ndr_push *ndr,  
int flags, const struct srvsvc_NetPathCanonicalize *r);
+NTSTATUS ndr_pull_srvsvc_NetPathCanonicalize(struct ndr_pull *ndr,  
int flags, struct srvsvc_NetPathCanonicalize *r);
+NTSTATUS ndr_push_srvsvc_NetPathCompare(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetPathCompare *r);
+NTSTATUS ndr_pull_srvsvc_NetPathCompare(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetPathCompare *r);
+NTSTATUS ndr_push_srvsvc_NetNameValidate(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetNameValidate *r);
+NTSTATUS ndr_pull_srvsvc_NetNameValidate(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetNameValidate *r);
+NTSTATUS ndr_push_srvsvc_NETRPRNAMECANONICALIZE(struct ndr_push  
*ndr, int flags, const struct srvsvc_NETRPRNAMECANONICALIZE *r);
+NTSTATUS ndr_pull_srvsvc_NETRPRNAMECANONICALIZE(struct ndr_pull  
*ndr, int flags, struct srvsvc_NETRPRNAMECANONICALIZE *r);
+NTSTATUS ndr_push_srvsvc_NetPRNameCompare(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetPRNameCompare *r);
+NTSTATUS ndr_pull_srvsvc_NetPRNameCompare(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetPRNameCompare *r);
+NTSTATUS ndr_push_srvsvc_NetShareEnum(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareEnum *r);
+NTSTATUS ndr_pull_srvsvc_NetShareEnum(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareEnum *r);
+NTSTATUS ndr_push_srvsvc_NetShareDelStart(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareDelStart *r);
+NTSTATUS ndr_pull_srvsvc_NetShareDelStart(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareDelStart *r);
+NTSTATUS ndr_push_srvsvc_NetShareDelCommit(struct ndr_push *ndr, int  
flags, const struct srvsvc_NetShareDelCommit *r);
+NTSTATUS ndr_pull_srvsvc_NetShareDelCommit(struct ndr_pull *ndr, int  
flags, struct srvsvc_NetShareDelCommit *r);
+NTSTATUS ndr_push_srvsvc_NetGetFileSecurity(struct ndr_push *ndr,  
int flags, const struct srvsvc_NetGetFileSecurity *r);
+NTSTATUS ndr_pull_srvsvc_NetGetFileSecurity(struct ndr_pull *ndr,  
int flags, struct srvsvc_NetGetFileSecurity *r);
+NTSTATUS ndr_push_srvsvc_NetSetFileSecurity(struct ndr_push *ndr,  
int flags, const struct srvsvc_NetSetFileSecurity *r);
+NTSTATUS ndr_pull_srvsvc_NetSetFileSecurity(struct ndr_pull *ndr,  
int flags, struct srvsvc_NetSetFileSecurity *r);
+NTSTATUS ndr_push_srvsvc_NetServerTransportAddEx(struct ndr_push  
*ndr, int flags, const struct srvsvc_NetServerTransportAddEx *r);
+NTSTATUS ndr_pull_srvsvc_NetServerTransportAddEx(struct ndr_pull  
*ndr, int flags, struct srvsvc_NetServerTransportAddEx *r);
+NTSTATUS ndr_push_srvsvc_NetServerSetServiceBitsEx(struct ndr_push  
*ndr, int flags, const struct srvsvc_NetServerSetServiceBitsEx *r);
+NTSTATUS ndr_pull_srvsvc_NetServerSetServiceBitsEx(struct ndr_pull  
*ndr, int flags, struct srvsvc_NetServerSetServiceBitsEx *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSGETVERSION(struct ndr_push *ndr, int  
flags, const struct srvsvc_NETRDFSGETVERSION *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSGETVERSION(struct ndr_pull *ndr, int  
flags, struct srvsvc_NETRDFSGETVERSION *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSCREATELOCALPARTITION(struct ndr_push  
*ndr, int flags, const struct srvsvc_NETRDFSCREATELOCALPARTITION *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSCREATELOCALPARTITION(struct ndr_pull  
*ndr, int flags, struct srvsvc_NETRDFSCREATELOCALPARTITION *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSDELETELOCALPARTITION(struct ndr_push  
*ndr, int flags, const struct srvsvc_NETRDFSDELETELOCALPARTITION *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSDELETELOCALPARTITION(struct ndr_pull  
*ndr, int flags, struct srvsvc_NETRDFSDELETELOCALPARTITION *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSSETLOCALVOLUMESTATE(struct ndr_push  
*ndr, int flags, const struct srvsvc_NETRDFSSETLOCALVOLUMESTATE *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSSETLOCALVOLUMESTATE(struct ndr_pull  
*ndr, int flags, struct srvsvc_NETRDFSSETLOCALVOLUMESTATE *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSSETSERVERINFO(struct ndr_push *ndr,  
int flags, const struct srvsvc_NETRDFSSETSERVERINFO *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSSETSERVERINFO(struct ndr_pull *ndr,  
int flags, struct srvsvc_NETRDFSSETSERVERINFO *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSCREATEEXITPOINT(struct ndr_push  
*ndr, int flags, const struct srvsvc_NETRDFSCREATEEXITPOINT *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSCREATEEXITPOINT(struct ndr_pull  
*ndr, int flags, struct srvsvc_NETRDFSCREATEEXITPOINT *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSDELETEEXITPOINT(struct ndr_push  
*ndr, int flags, const struct srvsvc_NETRDFSDELETEEXITPOINT *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSDELETEEXITPOINT(struct ndr_pull  
*ndr, int flags, struct srvsvc_NETRDFSDELETEEXITPOINT *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSMODIFYPREFIX(struct ndr_push *ndr,  
int flags, const struct srvsvc_NETRDFSMODIFYPREFIX *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSMODIFYPREFIX(struct ndr_pull *ndr,  
int flags, struct srvsvc_NETRDFSMODIFYPREFIX *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSFIXLOCALVOLUME(struct ndr_push *ndr,  
int flags, const struct srvsvc_NETRDFSFIXLOCALVOLUME *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSFIXLOCALVOLUME(struct ndr_pull *ndr,  
int flags, struct srvsvc_NETRDFSFIXLOCALVOLUME *r);
+NTSTATUS ndr_push_srvsvc_NETRDFSMANAGERREPORTSITEINFO(struct  
ndr_push *ndr, int flags, const struct  
srvsvc_NETRDFSMANAGERREPORTSITEINFO *r);
+NTSTATUS ndr_pull_srvsvc_NETRDFSMANAGERREPORTSITEINFO(struct  
ndr_pull *ndr, int flags, struct srvsvc_NETRDFSMANAGERREPORTSITEINFO  
*r);
+NTSTATUS ndr_push_srvsvc_NETRSERVERTRANSPORTDELEX(struct ndr_push  
*ndr, int flags, const struct srvsvc_NETRSERVERTRANSPORTDELEX *r);
+NTSTATUS ndr_pull_srvsvc_NETRSERVERTRANSPORTDELEX(struct ndr_pull  
*ndr, int flags, struct srvsvc_NETRSERVERTRANSPORTDELEX *r);
+
+/* The following definitions come from librpc/gen_ndr/ndr_svcctl.c  */
+
+NTSTATUS ndr_push_SERVICE_LOCK_STATUS(struct ndr_push *ndr, int  
ndr_flags, const struct SERVICE_LOCK_STATUS *r);
+NTSTATUS ndr_pull_SERVICE_LOCK_STATUS(struct ndr_pull *ndr, int  
ndr_flags, struct SERVICE_LOCK_STATUS *r);
+NTSTATUS ndr_push_SERVICE_STATUS(struct ndr_push *ndr, int  
ndr_flags, const struct SERVICE_STATUS *r);
+NTSTATUS ndr_pull_SERVICE_STATUS(struct ndr_pull *ndr, int  
ndr_flags, struct SERVICE_STATUS *r);
+NTSTATUS ndr_push_ENUM_SERVICE_STATUS(struct ndr_push *ndr, int  
ndr_flags, const struct ENUM_SERVICE_STATUS *r);
+NTSTATUS ndr_pull_ENUM_SERVICE_STATUS(struct ndr_pull *ndr, int  
ndr_flags, struct ENUM_SERVICE_STATUS *r);
+NTSTATUS ndr_push_svcctl_CloseServiceHandle(struct ndr_push *ndr,  
int flags, const struct svcctl_CloseServiceHandle *r);
+NTSTATUS ndr_pull_svcctl_CloseServiceHandle(struct ndr_pull *ndr,  
int flags, struct svcctl_CloseServiceHandle *r);
+NTSTATUS ndr_push_svcctl_ControlService(struct ndr_push *ndr, int  
flags, const struct svcctl_ControlService *r);
+NTSTATUS ndr_pull_svcctl_ControlService(struct ndr_pull *ndr, int  
flags, struct svcctl_ControlService *r);
+NTSTATUS ndr_push_svcctl_DeleteService(struct ndr_push *ndr, int  
flags, const struct svcctl_DeleteService *r);
+NTSTATUS ndr_pull_svcctl_DeleteService(struct ndr_pull *ndr, int  
flags, struct svcctl_DeleteService *r);
+NTSTATUS ndr_push_svcctl_LockServiceDatabase(struct ndr_push *ndr,  
int flags, const struct svcctl_LockServiceDatabase *r);
+NTSTATUS ndr_pull_svcctl_LockServiceDatabase(struct ndr_pull *ndr,  
int flags, struct svcctl_LockServiceDatabase *r);
+NTSTATUS ndr_push_svcctl_QueryServiceObjectSecurity(struct ndr_push  
*ndr, int flags, const struct svcctl_QueryServiceObjectSecurity *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceObjectSecurity(struct ndr_pull  
*ndr, int flags, struct svcctl_QueryServiceObjectSecurity *r);
+NTSTATUS ndr_push_svcctl_SetServiceObjectSecurity(struct ndr_push  
*ndr, int flags, const struct svcctl_SetServiceObjectSecurity *r);
+NTSTATUS ndr_pull_svcctl_SetServiceObjectSecurity(struct ndr_pull  
*ndr, int flags, struct svcctl_SetServiceObjectSecurity *r);
+NTSTATUS ndr_push_svcctl_QueryServiceStatus(struct ndr_push *ndr,  
int flags, const struct svcctl_QueryServiceStatus *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceStatus(struct ndr_pull *ndr,  
int flags, struct svcctl_QueryServiceStatus *r);
+NTSTATUS ndr_push_svcctl_SetServiceStatus(struct ndr_push *ndr, int  
flags, const struct svcctl_SetServiceStatus *r);
+NTSTATUS ndr_pull_svcctl_SetServiceStatus(struct ndr_pull *ndr, int  
flags, struct svcctl_SetServiceStatus *r);
+NTSTATUS ndr_push_svcctl_UnlockServiceDatabase(struct ndr_push *ndr,  
int flags, const struct svcctl_UnlockServiceDatabase *r);
+NTSTATUS ndr_pull_svcctl_UnlockServiceDatabase(struct ndr_pull *ndr,  
int flags, struct svcctl_UnlockServiceDatabase *r);
+NTSTATUS ndr_push_svcctl_NotifyBootConfigStatus(struct ndr_push  
*ndr, int flags, const struct svcctl_NotifyBootConfigStatus *r);
+NTSTATUS ndr_pull_svcctl_NotifyBootConfigStatus(struct ndr_pull  
*ndr, int flags, struct svcctl_NotifyBootConfigStatus *r);
+NTSTATUS ndr_push_svcctl_SCSetServiceBitsW(struct ndr_push *ndr, int  
flags, const struct svcctl_SCSetServiceBitsW *r);
+NTSTATUS ndr_pull_svcctl_SCSetServiceBitsW(struct ndr_pull *ndr, int  
flags, struct svcctl_SCSetServiceBitsW *r);
+NTSTATUS ndr_push_svcctl_ChangeServiceConfigW(struct ndr_push *ndr,  
int flags, const struct svcctl_ChangeServiceConfigW *r);
+NTSTATUS ndr_pull_svcctl_ChangeServiceConfigW(struct ndr_pull *ndr,  
int flags, struct svcctl_ChangeServiceConfigW *r);
+NTSTATUS ndr_push_svcctl_CreateServiceW(struct ndr_push *ndr, int  
flags, const struct svcctl_CreateServiceW *r);
+NTSTATUS ndr_pull_svcctl_CreateServiceW(struct ndr_pull *ndr, int  
flags, struct svcctl_CreateServiceW *r);
+NTSTATUS ndr_push_svcctl_EnumDependentServicesW(struct ndr_push  
*ndr, int flags, const struct svcctl_EnumDependentServicesW *r);
+NTSTATUS ndr_pull_svcctl_EnumDependentServicesW(struct ndr_pull  
*ndr, int flags, struct svcctl_EnumDependentServicesW *r);
+NTSTATUS ndr_push_svcctl_EnumServicesStatusW(struct ndr_push *ndr,  
int flags, const struct svcctl_EnumServicesStatusW *r);
+NTSTATUS ndr_pull_svcctl_EnumServicesStatusW(struct ndr_pull *ndr,  
int flags, struct svcctl_EnumServicesStatusW *r);
+NTSTATUS ndr_push_svcctl_OpenSCManagerW(struct ndr_push *ndr, int  
flags, const struct svcctl_OpenSCManagerW *r);
+NTSTATUS ndr_pull_svcctl_OpenSCManagerW(struct ndr_pull *ndr, int  
flags, struct svcctl_OpenSCManagerW *r);
+NTSTATUS ndr_push_svcctl_OpenServiceW(struct ndr_push *ndr, int  
flags, const struct svcctl_OpenServiceW *r);
+NTSTATUS ndr_pull_svcctl_OpenServiceW(struct ndr_pull *ndr, int  
flags, struct svcctl_OpenServiceW *r);
+NTSTATUS ndr_push_svcctl_QueryServiceConfigW(struct ndr_push *ndr,  
int flags, const struct svcctl_QueryServiceConfigW *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceConfigW(struct ndr_pull *ndr,  
int flags, struct svcctl_QueryServiceConfigW *r);
+NTSTATUS ndr_push_svcctl_QueryServiceLockStatusW(struct ndr_push  
*ndr, int flags, const struct svcctl_QueryServiceLockStatusW *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceLockStatusW(struct ndr_pull  
*ndr, int flags, struct svcctl_QueryServiceLockStatusW *r);
+NTSTATUS ndr_push_svcctl_StartServiceW(struct ndr_push *ndr, int  
flags, const struct svcctl_StartServiceW *r);
+NTSTATUS ndr_pull_svcctl_StartServiceW(struct ndr_pull *ndr, int  
flags, struct svcctl_StartServiceW *r);
+NTSTATUS ndr_push_svcctl_GetServiceDisplayNameW(struct ndr_push  
*ndr, int flags, const struct svcctl_GetServiceDisplayNameW *r);
+NTSTATUS ndr_pull_svcctl_GetServiceDisplayNameW(struct ndr_pull  
*ndr, int flags, struct svcctl_GetServiceDisplayNameW *r);
+NTSTATUS ndr_push_svcctl_GetServiceKeyNameW(struct ndr_push *ndr,  
int flags, const struct svcctl_GetServiceKeyNameW *r);
+NTSTATUS ndr_pull_svcctl_GetServiceKeyNameW(struct ndr_pull *ndr,  
int flags, struct svcctl_GetServiceKeyNameW *r);
+NTSTATUS ndr_push_svcctl_SCSetServiceBitsA(struct ndr_push *ndr, int  
flags, const struct svcctl_SCSetServiceBitsA *r);
+NTSTATUS ndr_pull_svcctl_SCSetServiceBitsA(struct ndr_pull *ndr, int  
flags, struct svcctl_SCSetServiceBitsA *r);
+NTSTATUS ndr_push_svcctl_ChangeServiceConfigA(struct ndr_push *ndr,  
int flags, const struct svcctl_ChangeServiceConfigA *r);
+NTSTATUS ndr_pull_svcctl_ChangeServiceConfigA(struct ndr_pull *ndr,  
int flags, struct svcctl_ChangeServiceConfigA *r);
+NTSTATUS ndr_push_svcctl_CreateServiceA(struct ndr_push *ndr, int  
flags, const struct svcctl_CreateServiceA *r);
+NTSTATUS ndr_pull_svcctl_CreateServiceA(struct ndr_pull *ndr, int  
flags, struct svcctl_CreateServiceA *r);
+NTSTATUS ndr_push_svcctl_EnumDependentServicesA(struct ndr_push  
*ndr, int flags, const struct svcctl_EnumDependentServicesA *r);
+NTSTATUS ndr_pull_svcctl_EnumDependentServicesA(struct ndr_pull  
*ndr, int flags, struct svcctl_EnumDependentServicesA *r);
+NTSTATUS ndr_push_svcctl_EnumServicesStatusA(struct ndr_push *ndr,  
int flags, const struct svcctl_EnumServicesStatusA *r);
+NTSTATUS ndr_pull_svcctl_EnumServicesStatusA(struct ndr_pull *ndr,  
int flags, struct svcctl_EnumServicesStatusA *r);
+NTSTATUS ndr_push_svcctl_OpenSCManagerA(struct ndr_push *ndr, int  
flags, const struct svcctl_OpenSCManagerA *r);
+NTSTATUS ndr_pull_svcctl_OpenSCManagerA(struct ndr_pull *ndr, int  
flags, struct svcctl_OpenSCManagerA *r);
+NTSTATUS ndr_push_svcctl_OpenServiceA(struct ndr_push *ndr, int  
flags, const struct svcctl_OpenServiceA *r);
+NTSTATUS ndr_pull_svcctl_OpenServiceA(struct ndr_pull *ndr, int  
flags, struct svcctl_OpenServiceA *r);
+NTSTATUS ndr_push_svcctl_QueryServiceConfigA(struct ndr_push *ndr,  
int flags, const struct svcctl_QueryServiceConfigA *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceConfigA(struct ndr_pull *ndr,  
int flags, struct svcctl_QueryServiceConfigA *r);
+NTSTATUS ndr_push_svcctl_QueryServiceLockStatusA(struct ndr_push  
*ndr, int flags, const struct svcctl_QueryServiceLockStatusA *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceLockStatusA(struct ndr_pull  
*ndr, int flags, struct svcctl_QueryServiceLockStatusA *r);
+NTSTATUS ndr_push_svcctl_StartServiceA(struct ndr_push *ndr, int  
flags, const struct svcctl_StartServiceA *r);
+NTSTATUS ndr_pull_svcctl_StartServiceA(struct ndr_pull *ndr, int  
flags, struct svcctl_StartServiceA *r);
+NTSTATUS ndr_push_svcctl_GetServiceDisplayNameA(struct ndr_push  
*ndr, int flags, const struct svcctl_GetServiceDisplayNameA *r);
+NTSTATUS ndr_pull_svcctl_GetServiceDisplayNameA(struct ndr_pull  
*ndr, int flags, struct svcctl_GetServiceDisplayNameA *r);
+NTSTATUS ndr_push_svcctl_GetServiceKeyNameA(struct ndr_push *ndr,  
int flags, const struct svcctl_GetServiceKeyNameA *r);
+NTSTATUS ndr_pull_svcctl_GetServiceKeyNameA(struct ndr_pull *ndr,  
int flags, struct svcctl_GetServiceKeyNameA *r);
+NTSTATUS ndr_push_svcctl_GetCurrentGroupeStateW(struct ndr_push  
*ndr, int flags, const struct svcctl_GetCurrentGroupeStateW *r);
+NTSTATUS ndr_pull_svcctl_GetCurrentGroupeStateW(struct ndr_pull  
*ndr, int flags, struct svcctl_GetCurrentGroupeStateW *r);
+NTSTATUS ndr_push_svcctl_EnumServiceGroupW(struct ndr_push *ndr, int  
flags, const struct svcctl_EnumServiceGroupW *r);
+NTSTATUS ndr_pull_svcctl_EnumServiceGroupW(struct ndr_pull *ndr, int  
flags, struct svcctl_EnumServiceGroupW *r);
+NTSTATUS ndr_push_svcctl_ChangeServiceConfig2A(struct ndr_push *ndr,  
int flags, const struct svcctl_ChangeServiceConfig2A *r);
+NTSTATUS ndr_pull_svcctl_ChangeServiceConfig2A(struct ndr_pull *ndr,  
int flags, struct svcctl_ChangeServiceConfig2A *r);
+NTSTATUS ndr_push_svcctl_ChangeServiceConfig2W(struct ndr_push *ndr,  
int flags, const struct svcctl_ChangeServiceConfig2W *r);
+NTSTATUS ndr_pull_svcctl_ChangeServiceConfig2W(struct ndr_pull *ndr,  
int flags, struct svcctl_ChangeServiceConfig2W *r);
+NTSTATUS ndr_push_svcctl_QueryServiceConfig2A(struct ndr_push *ndr,  
int flags, const struct svcctl_QueryServiceConfig2A *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceConfig2A(struct ndr_pull *ndr,  
int flags, struct svcctl_QueryServiceConfig2A *r);
+NTSTATUS ndr_push_svcctl_QueryServiceConfig2W(struct ndr_push *ndr,  
int flags, const struct svcctl_QueryServiceConfig2W *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceConfig2W(struct ndr_pull *ndr,  
int flags, struct svcctl_QueryServiceConfig2W *r);
+NTSTATUS ndr_push_svcctl_QueryServiceStatusEx(struct ndr_push *ndr,  
int flags, const struct svcctl_QueryServiceStatusEx *r);
+NTSTATUS ndr_pull_svcctl_QueryServiceStatusEx(struct ndr_pull *ndr,  
int flags, struct svcctl_QueryServiceStatusEx *r);
+NTSTATUS ndr_push_EnumServicesStatusExA(struct ndr_push *ndr, int  
flags, const struct EnumServicesStatusExA *r);
+NTSTATUS ndr_pull_EnumServicesStatusExA(struct ndr_pull *ndr, int  
flags, struct EnumServicesStatusExA *r);
+NTSTATUS ndr_push_EnumServicesStatusExW(struct ndr_push *ndr, int  
flags, const struct EnumServicesStatusExW *r);
+NTSTATUS ndr_pull_EnumServicesStatusExW(struct ndr_pull *ndr, int  
flags, struct EnumServicesStatusExW *r);
+NTSTATUS ndr_push_svcctl_SCSendTSMessage(struct ndr_push *ndr, int  
flags, const struct svcctl_SCSendTSMessage *r);
+NTSTATUS ndr_pull_svcctl_SCSendTSMessage(struct ndr_pull *ndr, int  
flags, struct svcctl_SCSendTSMessage *r);
+
+/* The following definitions come from librpc/gen_ndr/ 
ndr_unixinfo.c  */
+
+NTSTATUS ndr_push_unixinfo_GetPWUidInfo(struct ndr_push *ndr, int  
ndr_flags, const struct unixinfo_GetPWUidInfo *r);
+NTSTATUS ndr_pull_unixinfo_GetPWUidInfo(struct ndr_pull *ndr, int  
ndr_flags, struct unixinfo_GetPWUidInfo *r);
+NTSTATUS ndr_push_unixinfo_SidToUid(struct ndr_push *ndr, int flags,  
const struct unixinfo_SidToUid *r);
+NTSTATUS ndr_pull_unixinfo_SidToUid(struct ndr_pull *ndr, int flags,  
struct unixinfo_SidToUid *r);
+NTSTATUS ndr_push_unixinfo_UidToSid(struct ndr_push *ndr, int flags,  
const struct unixinfo_UidToSid *r);
+NTSTATUS ndr_pull_unixinfo_UidToSid(struct ndr_pull *ndr, int flags,  
struct unixinfo_UidToSid *r);
+NTSTATUS ndr_push_unixinfo_SidToGid(struct ndr_push *ndr, int flags,  
const struct unixinfo_SidToGid *r);
+NTSTATUS ndr_pull_unixinfo_SidToGid(struct ndr_pull *ndr, int flags,  
struct unixinfo_SidToGid *r);
+NTSTATUS ndr_push_unixinfo_GidToSid(struct ndr_push *ndr, int flags,  
const struct unixinfo_GidToSid *r);
+NTSTATUS ndr_pull_unixinfo_GidToSid(struct ndr_pull *ndr, int flags,  
struct unixinfo_GidToSid *r);
+NTSTATUS ndr_push_unixinfo_GetPWUid(struct ndr_push *ndr, int flags,  
const struct unixinfo_GetPWUid *r);
+NTSTATUS ndr_pull_unixinfo_GetPWUid(struct ndr_pull *ndr, int flags,  
struct unixinfo_GetPWUid *r);
+
+/* The following definitions come from librpc/gen_ndr/ndr_winreg.c  */
+
+NTSTATUS ndr_push_winreg_AccessMask(struct ndr_push *ndr, int  
ndr_flags, uint32_t r);
+NTSTATUS ndr_pull_winreg_AccessMask(struct ndr_pull *ndr, int  
ndr_flags, uint32_t *r);
+NTSTATUS ndr_push_winreg_Type(struct ndr_push *ndr, int ndr_flags,  
enum winreg_Type r);
+NTSTATUS ndr_pull_winreg_Type(struct ndr_pull *ndr, int ndr_flags,  
enum winreg_Type *r);
+NTSTATUS ndr_push_KeySecurityData(struct ndr_push *ndr, int  
ndr_flags, const struct KeySecurityData *r);
+NTSTATUS ndr_pull_KeySecurityData(struct ndr_pull *ndr, int  
ndr_flags, struct KeySecurityData *r);
+NTSTATUS ndr_push_winreg_SecBuf(struct ndr_push *ndr, int ndr_flags,  
const struct winreg_SecBuf *r);
+NTSTATUS ndr_pull_winreg_SecBuf(struct ndr_pull *ndr, int ndr_flags,  
struct winreg_SecBuf *r);
+NTSTATUS ndr_push_winreg_CreateAction(struct ndr_push *ndr, int  
ndr_flags, enum winreg_CreateAction r);
+NTSTATUS ndr_pull_winreg_CreateAction(struct ndr_pull *ndr, int  
ndr_flags, enum winreg_CreateAction *r);
+NTSTATUS ndr_push_winreg_StringBuf(struct ndr_push *ndr, int  
ndr_flags, const struct winreg_StringBuf *r);
+NTSTATUS ndr_pull_winreg_StringBuf(struct ndr_pull *ndr, int  
ndr_flags, struct winreg_StringBuf *r);
+NTSTATUS ndr_push_winreg_ValNameBuf(struct ndr_push *ndr, int  
ndr_flags, const struct winreg_ValNameBuf *r);
+NTSTATUS ndr_pull_winreg_ValNameBuf(struct ndr_pull *ndr, int  
ndr_flags, struct winreg_ValNameBuf *r);
+NTSTATUS ndr_push_KeySecurityAttribute(struct ndr_push *ndr, int  
ndr_flags, const struct KeySecurityAttribute *r);
+NTSTATUS ndr_pull_KeySecurityAttribute(struct ndr_pull *ndr, int  
ndr_flags, struct KeySecurityAttribute *r);
+NTSTATUS ndr_push_QueryMultipleValue(struct ndr_push *ndr, int  
ndr_flags, const struct QueryMultipleValue *r);
+NTSTATUS ndr_pull_QueryMultipleValue(struct ndr_pull *ndr, int  
ndr_flags, struct QueryMultipleValue *r);
+NTSTATUS ndr_push_winreg_OpenHKCR(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKCR *r);
+NTSTATUS ndr_pull_winreg_OpenHKCR(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKCR *r);
+NTSTATUS ndr_push_winreg_OpenHKCU(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKCU *r);
+NTSTATUS ndr_pull_winreg_OpenHKCU(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKCU *r);
+NTSTATUS ndr_push_winreg_OpenHKLM(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKLM *r);
+NTSTATUS ndr_pull_winreg_OpenHKLM(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKLM *r);
+NTSTATUS ndr_push_winreg_OpenHKPD(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKPD *r);
+NTSTATUS ndr_pull_winreg_OpenHKPD(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKPD *r);
+NTSTATUS ndr_push_winreg_OpenHKU(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKU *r);
+NTSTATUS ndr_pull_winreg_OpenHKU(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKU *r);
+NTSTATUS ndr_push_winreg_CloseKey(struct ndr_push *ndr, int flags,  
const struct winreg_CloseKey *r);
+NTSTATUS ndr_pull_winreg_CloseKey(struct ndr_pull *ndr, int flags,  
struct winreg_CloseKey *r);
+NTSTATUS ndr_push_winreg_CreateKey(struct ndr_push *ndr, int flags,  
const struct winreg_CreateKey *r);
+NTSTATUS ndr_pull_winreg_CreateKey(struct ndr_pull *ndr, int flags,  
struct winreg_CreateKey *r);
+NTSTATUS ndr_push_winreg_DeleteKey(struct ndr_push *ndr, int flags,  
const struct winreg_DeleteKey *r);
+NTSTATUS ndr_pull_winreg_DeleteKey(struct ndr_pull *ndr, int flags,  
struct winreg_DeleteKey *r);
+NTSTATUS ndr_push_winreg_DeleteValue(struct ndr_push *ndr, int  
flags, const struct winreg_DeleteValue *r);
+NTSTATUS ndr_pull_winreg_DeleteValue(struct ndr_pull *ndr, int  
flags, struct winreg_DeleteValue *r);
+NTSTATUS ndr_push_winreg_EnumKey(struct ndr_push *ndr, int flags,  
const struct winreg_EnumKey *r);
+NTSTATUS ndr_pull_winreg_EnumKey(struct ndr_pull *ndr, int flags,  
struct winreg_EnumKey *r);
+NTSTATUS ndr_push_winreg_EnumValue(struct ndr_push *ndr, int flags,  
const struct winreg_EnumValue *r);
+NTSTATUS ndr_pull_winreg_EnumValue(struct ndr_pull *ndr, int flags,  
struct winreg_EnumValue *r);
+NTSTATUS ndr_push_winreg_FlushKey(struct ndr_push *ndr, int flags,  
const struct winreg_FlushKey *r);
+NTSTATUS ndr_pull_winreg_FlushKey(struct ndr_pull *ndr, int flags,  
struct winreg_FlushKey *r);
+NTSTATUS ndr_push_winreg_GetKeySecurity(struct ndr_push *ndr, int  
flags, const struct winreg_GetKeySecurity *r);
+NTSTATUS ndr_pull_winreg_GetKeySecurity(struct ndr_pull *ndr, int  
flags, struct winreg_GetKeySecurity *r);
+NTSTATUS ndr_push_winreg_LoadKey(struct ndr_push *ndr, int flags,  
const struct winreg_LoadKey *r);
+NTSTATUS ndr_pull_winreg_LoadKey(struct ndr_pull *ndr, int flags,  
struct winreg_LoadKey *r);
+NTSTATUS ndr_push_winreg_NotifyChangeKeyValue(struct ndr_push *ndr,  
int flags, const struct winreg_NotifyChangeKeyValue *r);
+NTSTATUS ndr_pull_winreg_NotifyChangeKeyValue(struct ndr_pull *ndr,  
int flags, struct winreg_NotifyChangeKeyValue *r);
+NTSTATUS ndr_push_winreg_OpenKey(struct ndr_push *ndr, int flags,  
const struct winreg_OpenKey *r);
+NTSTATUS ndr_pull_winreg_OpenKey(struct ndr_pull *ndr, int flags,  
struct winreg_OpenKey *r);
+NTSTATUS ndr_push_winreg_QueryInfoKey(struct ndr_push *ndr, int  
flags, const struct winreg_QueryInfoKey *r);
+NTSTATUS ndr_pull_winreg_QueryInfoKey(struct ndr_pull *ndr, int  
flags, struct winreg_QueryInfoKey *r);
+NTSTATUS ndr_push_winreg_QueryValue(struct ndr_push *ndr, int flags,  
const struct winreg_QueryValue *r);
+NTSTATUS ndr_pull_winreg_QueryValue(struct ndr_pull *ndr, int flags,  
struct winreg_QueryValue *r);
+NTSTATUS ndr_push_winreg_ReplaceKey(struct ndr_push *ndr, int flags,  
const struct winreg_ReplaceKey *r);
+NTSTATUS ndr_pull_winreg_ReplaceKey(struct ndr_pull *ndr, int flags,  
struct winreg_ReplaceKey *r);
+NTSTATUS ndr_push_winreg_RestoreKey(struct ndr_push *ndr, int flags,  
const struct winreg_RestoreKey *r);
+NTSTATUS ndr_pull_winreg_RestoreKey(struct ndr_pull *ndr, int flags,  
struct winreg_RestoreKey *r);
+NTSTATUS ndr_push_winreg_SaveKey(struct ndr_push *ndr, int flags,  
const struct winreg_SaveKey *r);
+NTSTATUS ndr_pull_winreg_SaveKey(struct ndr_pull *ndr, int flags,  
struct winreg_SaveKey *r);
+NTSTATUS ndr_push_winreg_SetKeySecurity(struct ndr_push *ndr, int  
flags, const struct winreg_SetKeySecurity *r);
+NTSTATUS ndr_pull_winreg_SetKeySecurity(struct ndr_pull *ndr, int  
flags, struct winreg_SetKeySecurity *r);
+NTSTATUS ndr_push_winreg_SetValue(struct ndr_push *ndr, int flags,  
const struct winreg_SetValue *r);
+NTSTATUS ndr_pull_winreg_SetValue(struct ndr_pull *ndr, int flags,  
struct winreg_SetValue *r);
+NTSTATUS ndr_push_winreg_UnLoadKey(struct ndr_push *ndr, int flags,  
const struct winreg_UnLoadKey *r);
+NTSTATUS ndr_pull_winreg_UnLoadKey(struct ndr_pull *ndr, int flags,  
struct winreg_UnLoadKey *r);
+NTSTATUS ndr_push_winreg_InitiateSystemShutdown(struct ndr_push  
*ndr, int flags, const struct winreg_InitiateSystemShutdown *r);
+NTSTATUS ndr_pull_winreg_InitiateSystemShutdown(struct ndr_pull  
*ndr, int flags, struct winreg_InitiateSystemShutdown *r);
+NTSTATUS ndr_push_winreg_AbortSystemShutdown(struct ndr_push *ndr,  
int flags, const struct winreg_AbortSystemShutdown *r);
+NTSTATUS ndr_pull_winreg_AbortSystemShutdown(struct ndr_pull *ndr,  
int flags, struct winreg_AbortSystemShutdown *r);
+NTSTATUS ndr_push_winreg_GetVersion(struct ndr_push *ndr, int flags,  
const struct winreg_GetVersion *r);
+NTSTATUS ndr_pull_winreg_GetVersion(struct ndr_pull *ndr, int flags,  
struct winreg_GetVersion *r);
+NTSTATUS ndr_push_winreg_OpenHKCC(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKCC *r);
+NTSTATUS ndr_pull_winreg_OpenHKCC(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKCC *r);
+NTSTATUS ndr_push_winreg_OpenHKDD(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKDD *r);
+NTSTATUS ndr_pull_winreg_OpenHKDD(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKDD *r);
+NTSTATUS ndr_push_winreg_QueryMultipleValues(struct ndr_push *ndr,  
int flags, const struct winreg_QueryMultipleValues *r);
+NTSTATUS ndr_pull_winreg_QueryMultipleValues(struct ndr_pull *ndr,  
int flags, struct winreg_QueryMultipleValues *r);
+NTSTATUS ndr_push_winreg_InitiateSystemShutdownEx(struct ndr_push  
*ndr, int flags, const struct winreg_InitiateSystemShutdownEx *r);
+NTSTATUS ndr_pull_winreg_InitiateSystemShutdownEx(struct ndr_pull  
*ndr, int flags, struct winreg_InitiateSystemShutdownEx *r);
+NTSTATUS ndr_push_winreg_SaveKeyEx(struct ndr_push *ndr, int flags,  
const struct winreg_SaveKeyEx *r);
+NTSTATUS ndr_pull_winreg_SaveKeyEx(struct ndr_pull *ndr, int flags,  
struct winreg_SaveKeyEx *r);
+NTSTATUS ndr_push_winreg_OpenHKPT(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKPT *r);
+NTSTATUS ndr_pull_winreg_OpenHKPT(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKPT *r);
+NTSTATUS ndr_push_winreg_OpenHKPN(struct ndr_push *ndr, int flags,  
const struct winreg_OpenHKPN *r);
+NTSTATUS ndr_pull_winreg_OpenHKPN(struct ndr_pull *ndr, int flags,  
struct winreg_OpenHKPN *r);
+NTSTATUS ndr_push_winreg_QueryMultipleValues2(struct ndr_push *ndr,  
int flags, const struct winreg_QueryMultipleValues2 *r);
+NTSTATUS ndr_pull_winreg_QueryMultipleValues2(struct ndr_pull *ndr,  
int flags, struct winreg_QueryMultipleValues2 *r);
+
+/* The following definitions come from librpc/gen_ndr/ndr_wkssvc.c  */
+
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo100(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo100 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo100(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo100 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo101(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo101 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo101(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo101 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo102(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo102 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo102(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo102 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo502(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo502 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo502(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo502 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1010(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1010 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1010(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1010 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1011(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1011 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1011(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1011 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1012(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1012 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1012(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1012 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1013(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1013 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1013(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1013 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1018(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1018 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1018(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1018 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1023(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1023 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1023(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1023 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1027(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1027 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1027(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1027 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo1033(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_NetWkstaInfo1033 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo1033(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_NetWkstaInfo1033 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaInfo(struct ndr_push *ndr, int  
ndr_flags, const union wkssvc_NetWkstaInfo *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaInfo(struct ndr_pull *ndr, int  
ndr_flags, union wkssvc_NetWkstaInfo *r);
+NTSTATUS ndr_push_USER_INFO_0(struct ndr_push *ndr, int ndr_flags,  
const struct USER_INFO_0 *r);
+NTSTATUS ndr_pull_USER_INFO_0(struct ndr_pull *ndr, int ndr_flags,  
struct USER_INFO_0 *r);
+NTSTATUS ndr_push_USER_INFO_0_CONTAINER(struct ndr_push *ndr, int  
ndr_flags, const struct USER_INFO_0_CONTAINER *r);
+NTSTATUS ndr_pull_USER_INFO_0_CONTAINER(struct ndr_pull *ndr, int  
ndr_flags, struct USER_INFO_0_CONTAINER *r);
+NTSTATUS ndr_push_USER_INFO_1(struct ndr_push *ndr, int ndr_flags,  
const struct USER_INFO_1 *r);
+NTSTATUS ndr_pull_USER_INFO_1(struct ndr_pull *ndr, int ndr_flags,  
struct USER_INFO_1 *r);
+NTSTATUS ndr_push_USER_INFO_1_CONTAINER(struct ndr_push *ndr, int  
ndr_flags, const struct USER_INFO_1_CONTAINER *r);
+NTSTATUS ndr_pull_USER_INFO_1_CONTAINER(struct ndr_pull *ndr, int  
ndr_flags, struct USER_INFO_1_CONTAINER *r);
+NTSTATUS ndr_push_WKS_USER_ENUM_UNION(struct ndr_push *ndr, int  
ndr_flags, const union WKS_USER_ENUM_UNION *r);
+NTSTATUS ndr_pull_WKS_USER_ENUM_UNION(struct ndr_pull *ndr, int  
ndr_flags, union WKS_USER_ENUM_UNION *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaTransportInfo0(struct ndr_push  
*ndr, int ndr_flags, const struct wkssvc_NetWkstaTransportInfo0 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaTransportInfo0(struct ndr_pull  
*ndr, int ndr_flags, struct wkssvc_NetWkstaTransportInfo0 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaTransportCtr0(struct ndr_push *ndr,  
int ndr_flags, const struct wkssvc_NetWkstaTransportCtr0 *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaTransportCtr0(struct ndr_pull *ndr,  
int ndr_flags, struct wkssvc_NetWkstaTransportCtr0 *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaTransportCtr(struct ndr_push *ndr,  
int ndr_flags, const union wkssvc_NetWkstaTransportCtr *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaTransportCtr(struct ndr_pull *ndr,  
int ndr_flags, union wkssvc_NetWkstaTransportCtr *r);
+NTSTATUS ndr_push_wkssvc_PasswordBuffer(struct ndr_push *ndr, int  
ndr_flags, const struct wkssvc_PasswordBuffer *r);
+NTSTATUS ndr_pull_wkssvc_PasswordBuffer(struct ndr_pull *ndr, int  
ndr_flags, struct wkssvc_PasswordBuffer *r);
+NTSTATUS ndr_push_wkssvc_joinflags(struct ndr_push *ndr, int  
ndr_flags, uint32_t r);
+NTSTATUS ndr_pull_wkssvc_joinflags(struct ndr_pull *ndr, int  
ndr_flags, uint32_t *r);
+NTSTATUS ndr_push_wkssvc_renameflags(struct ndr_push *ndr, int  
ndr_flags, uint32_t r);
+NTSTATUS ndr_pull_wkssvc_renameflags(struct ndr_pull *ndr, int  
ndr_flags, uint32_t *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaGetInfo(struct ndr_push *ndr, int  
flags, const struct wkssvc_NetWkstaGetInfo *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaGetInfo(struct ndr_pull *ndr, int  
flags, struct wkssvc_NetWkstaGetInfo *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaSetInfo(struct ndr_push *ndr, int  
flags, const struct wkssvc_NetWkstaSetInfo *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaSetInfo(struct ndr_pull *ndr, int  
flags, struct wkssvc_NetWkstaSetInfo *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaEnumUsers(struct ndr_push *ndr, int  
flags, const struct wkssvc_NetWkstaEnumUsers *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaEnumUsers(struct ndr_pull *ndr, int  
flags, struct wkssvc_NetWkstaEnumUsers *r);
+NTSTATUS ndr_push_WKSSVC_NETRWKSTAUSERGETINFO(struct ndr_push *ndr,  
int flags, const struct WKSSVC_NETRWKSTAUSERGETINFO *r);
+NTSTATUS ndr_pull_WKSSVC_NETRWKSTAUSERGETINFO(struct ndr_pull *ndr,  
int flags, struct WKSSVC_NETRWKSTAUSERGETINFO *r);
+NTSTATUS ndr_push_WKSSVC_NETRWKSTAUSERSETINFO(struct ndr_push *ndr,  
int flags, const struct WKSSVC_NETRWKSTAUSERSETINFO *r);
+NTSTATUS ndr_pull_WKSSVC_NETRWKSTAUSERSETINFO(struct ndr_pull *ndr,  
int flags, struct WKSSVC_NETRWKSTAUSERSETINFO *r);
+NTSTATUS ndr_push_wkssvc_NetWkstaTransportEnum(struct ndr_push *ndr,  
int flags, const struct wkssvc_NetWkstaTransportEnum *r);
+NTSTATUS ndr_pull_wkssvc_NetWkstaTransportEnum(struct ndr_pull *ndr,  
int flags, struct wkssvc_NetWkstaTransportEnum *r);
+NTSTATUS ndr_push_WKSSVC_NETRWKSTATRANSPORTADD(struct ndr_push *ndr,  
int flags, const struct WKSSVC_NETRWKSTATRANSPORTADD *r);
+NTSTATUS ndr_pull_WKSSVC_NETRWKSTATRANSPORTADD(struct ndr_pull *ndr,  
int flags, struct WKSSVC_NETRWKSTATRANSPORTADD *r);
+NTSTATUS ndr_push_WKSSVC_NETRWKSTATRANSPORTDEL(struct ndr_push *ndr,  
int flags, const struct WKSSVC_NETRWKSTATRANSPORTDEL *r);
+NTSTATUS ndr_pull_WKSSVC_NETRWKSTATRANSPORTDEL(struct ndr_pull *ndr,  
int flags, struct WKSSVC_NETRWKSTATRANSPORTDEL *r);
+NTSTATUS ndr_push_WKSSVC_NETRUSEADD(struct ndr_push *ndr, int flags,  
const struct WKSSVC_NETRUSEADD *r);
+NTSTATUS ndr_pull_WKSSVC_NETRUSEADD(struct ndr_pull *ndr, int flags,  
struct WKSSVC_NETRUSEADD *r);
+NTSTATUS ndr_push_WKSSVC_NETRUSEGETINFO(struct ndr_push *ndr, int  
flags, const struct WKSSVC_NETRUSEGETINFO *r);
+NTSTATUS ndr_pull_WKSSVC_NETRUSEGETINFO(struct ndr_pull *ndr, int  
flags, struct WKSSVC_NETRUSEGETINFO *r);
+NTSTATUS ndr_push_WKSSVC_NETRUSEDEL(struct ndr_push *ndr, int flags,  
const struct WKSSVC_NETRUSEDEL *r);
+NTSTATUS ndr_pull_WKSSVC_NETRUSEDEL(struct ndr_pull *ndr, int flags,  
struct WKSSVC_NETRUSEDEL *r);
+NTSTATUS ndr_push_WKSSVC_NETRUSEENUM(struct ndr_push *ndr, int  
flags, const struct WKSSVC_NETRUSEENUM *r);
+NTSTATUS ndr_pull_WKSSVC_NETRUSEENUM(struct ndr_pull *ndr, int  
flags, struct WKSSVC_NETRUSEENUM *r);
+NTSTATUS ndr_push_WKSSVC_NETRMESSAGEBUFFERSEND(struct ndr_push *ndr,  
int flags, const struct WKSSVC_NETRMESSAGEBUFFERSEND *r);
+NTSTATUS ndr_pull_WKSSVC_NETRMESSAGEBUFFERSEND(struct ndr_pull *ndr,  
int flags, struct WKSSVC_NETRMESSAGEBUFFERSEND *r);
+NTSTATUS ndr_push_WKSSVC_NETRWORKSTATIONSTATISTICSGET(struct  
ndr_push *ndr, int flags, const struct  
WKSSVC_NETRWORKSTATIONSTATISTICSGET *r);
+NTSTATUS ndr_pull_WKSSVC_NETRWORKSTATIONSTATISTICSGET(struct  
ndr_pull *ndr, int flags, struct WKSSVC_NETRWORKSTATIONSTATISTICSGET  
*r);
+NTSTATUS ndr_push_WKSSVC_NETRLOGONDOMAINNAMEADD(struct ndr_push  
*ndr, int flags, const struct WKSSVC_NETRLOGONDOMAINNAMEADD *r);
+NTSTATUS ndr_pull_WKSSVC_NETRLOGONDOMAINNAMEADD(struct ndr_pull  
*ndr, int flags, struct WKSSVC_NETRLOGONDOMAINNAMEADD *r);
+NTSTATUS ndr_push_WKSSVC_NETRLOGONDOMAINNAMEDEL(struct ndr_push  
*ndr, int flags, const struct WKSSVC_NETRLOGONDOMAINNAMEDEL *r);
+NTSTATUS ndr_pull_WKSSVC_NETRLOGONDOMAINNAMEDEL(struct ndr_pull  
*ndr, int flags, struct WKSSVC_NETRLOGONDOMAINNAMEDEL *r);
+NTSTATUS ndr_push_WKSSVC_NETRJOINDOMAIN(struct ndr_push *ndr, int  
flags, const struct WKSSVC_NETRJOINDOMAIN *r);
+NTSTATUS ndr_pull_WKSSVC_NETRJOINDOMAIN(struct ndr_pull *ndr, int  
flags, struct WKSSVC_NETRJOINDOMAIN *r);
+NTSTATUS ndr_push_WKSSVC_NETRUNJOINDOMAIN(struct ndr_push *ndr, int  
flags, const struct WKSSVC_NETRUNJOINDOMAIN *r);
+NTSTATUS ndr_pull_WKSSVC_NETRUNJOINDOMAIN(struct ndr_pull *ndr, int  
flags, struct WKSSVC_NETRUNJOINDOMAIN *r);
+NTSTATUS ndr_push_WKSSVC_NETRRENAMEMACHINEINDOMAIN(struct ndr_push  
*ndr, int flags, const struct WKSSVC_NETRRENAMEMACHINEINDOMAIN *r);
+NTSTATUS ndr_pull_WKSSVC_NETRRENAMEMACHINEINDOMAIN(struct ndr_pull  
*ndr, int flags, struct WKSSVC_NETRRENAMEMACHINEINDOMAIN *r);
+NTSTATUS ndr_push_WKSSVC_NETRVALIDATENAME(struct ndr_push *ndr, int  
flags, const struct WKSSVC_NETRVALIDATENAME *r);
+NTSTATUS ndr_pull_WKSSVC_NETRVALIDATENAME(struct ndr_pull *ndr, int  
flags, struct WKSSVC_NETRVALIDATENAME *r);
+NTSTATUS ndr_push_WKSSVC_NETRGETJOININFORMATION(struct ndr_push  
*ndr, int flags, const struct WKSSVC_NETRGETJOININFORMATION *r);
+NTSTATUS ndr_pull_WKSSVC_NETRGETJOININFORMATION(struct ndr_pull  
*ndr, int flags, struct WKSSVC_NETRGETJOININFORMATION *r);
+NTSTATUS ndr_push_WKSSVC_NETRGETJOINABLEOUS(struct ndr_push *ndr,  
int flags, const struct WKSSVC_NETRGETJOINABLEOUS *r);
+NTSTATUS ndr_pull_WKSSVC_NETRGETJOINABLEOUS(struct ndr_pull *ndr,  
int flags, struct WKSSVC_NETRGETJOINABLEOUS *r);
+NTSTATUS ndr_push_wkssvc_NetrJoinDomain2(struct ndr_push *ndr, int  
flags, const struct wkssvc_NetrJoinDomain2 *r);
+NTSTATUS ndr_pull_wkssvc_NetrJoinDomain2(struct ndr_pull *ndr, int  
flags, struct wkssvc_NetrJoinDomain2 *r);
+NTSTATUS ndr_push_wkssvc_NetrUnjoinDomain2(struct ndr_push *ndr, int  
flags, const struct wkssvc_NetrUnjoinDomain2 *r);
+NTSTATUS ndr_pull_wkssvc_NetrUnjoinDomain2(struct ndr_pull *ndr, int  
flags, struct wkssvc_NetrUnjoinDomain2 *r);
+NTSTATUS ndr_push_wkssvc_NetrRenameMachineInDomain2(struct ndr_push  
*ndr, int flags, const struct wkssvc_NetrRenameMachineInDomain2 *r);
+NTSTATUS ndr_pull_wkssvc_NetrRenameMachineInDomain2(struct ndr_pull  
*ndr, int flags, struct wkssvc_NetrRenameMachineInDomain2 *r);
+NTSTATUS ndr_push_WKSSVC_NETRVALIDATENAME2(struct ndr_push *ndr, int  
flags, const struct WKSSVC_NETRVALIDATENAME2 *r);
+NTSTATUS ndr_pull_WKSSVC_NETRVALIDATENAME2(struct ndr_pull *ndr, int  
flags, struct WKSSVC_NETRVALIDATENAME2 *r);
+NTSTATUS ndr_push_WKSSVC_NETRGETJOINABLEOUS2(struct ndr_push *ndr,  
int flags, const struct WKSSVC_NETRGETJOINABLEOUS2 *r);
+NTSTATUS ndr_pull_WKSSVC_NETRGETJOINABLEOUS2(struct ndr_pull *ndr,  
int flags, struct WKSSVC_NETRGETJOINABLEOUS2 *r);
+NTSTATUS ndr_push_wkssvc_NetrAddAlternateComputerName(struct  
ndr_push *ndr, int flags, const struct  
wkssvc_NetrAddAlternateComputerName *r);
+NTSTATUS ndr_pull_wkssvc_NetrAddAlternateComputerName(struct  
ndr_pull *ndr, int flags, struct wkssvc_NetrAddAlternateComputerName  
*r);
+NTSTATUS ndr_push_wkssvc_NetrRemoveAlternateComputerName(struct  
ndr_push *ndr, int flags, const struct  
wkssvc_NetrRemoveAlternateComputerName *r);
+NTSTATUS ndr_pull_wkssvc_NetrRemoveAlternateComputerName(struct  
ndr_pull *ndr, int flags, struct  
wkssvc_NetrRemoveAlternateComputerName *r);
+NTSTATUS ndr_push_WKSSVC_NETRSETPRIMARYCOMPUTERNAME(struct ndr_push  
*ndr, int flags, const struct WKSSVC_NETRSETPRIMARYCOMPUTERNAME *r);
+NTSTATUS ndr_pull_WKSSVC_NETRSETPRIMARYCOMPUTERNAME(struct ndr_pull  
*ndr, int flags, struct WKSSVC_NETRSETPRIMARYCOMPUTERNAME *r);
+NTSTATUS ndr_push_WKSSVC_NETRENUMERATECOMPUTERNAMES(struct ndr_push  
*ndr, int flags, const struct WKSSVC_NETRENUMERATECOMPUTERNAMES *r);
+NTSTATUS ndr_pull_WKSSVC_NETRENUMERATECOMPUTERNAMES(struct ndr_pull  
*ndr, int flags, struct WKSSVC_NETRENUMERATECOMPUTERNAMES *r);
+
+/* The following definitions come from librpc/gen_ndr/srv_dfs.c  */
+
+void netdfs_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_netdfs_init(void);
+
+/* The following definitions come from librpc/gen_ndr/srv_echo.c  */
+
+void rpcecho_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_rpcecho_init(void);
+
+/* The following definitions come from librpc/gen_ndr/ 
srv_epmapper.c  */
+
+void epmapper_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_epmapper_init(void);
+
+/* The following definitions come from librpc/gen_ndr/ 
srv_eventlog.c  */
+
+void eventlog_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_eventlog_init(void);
+
+/* The following definitions come from librpc/gen_ndr/ 
srv_initshutdown.c  */
+
+void initshutdown_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_initshutdown_init(void);
+
+/* The following definitions come from librpc/gen_ndr/srv_lsa.c  */
+
+void lsarpc_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_lsarpc_init(void);
+
+/* The following definitions come from librpc/gen_ndr/srv_srvsvc.c  */
+
+void srvsvc_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_srvsvc_init(void);
+
+/* The following definitions come from librpc/gen_ndr/srv_svcctl.c  */
+
+void svcctl_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_svcctl_init(void);
+
+/* The following definitions come from librpc/gen_ndr/ 
srv_unixinfo.c  */
+
+void unixinfo_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_unixinfo_init(void);
+
+/* The following definitions come from librpc/gen_ndr/srv_winreg.c  */
+
+void winreg_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_winreg_init(void);
+
+/* The following definitions come from librpc/gen_ndr/srv_wkssvc.c  */
+
+void wkssvc_get_pipe_fns(struct api_struct **fns, int *n_fns);
+NTSTATUS rpc_wkssvc_init(void);
+
+/* The following definitions come from librpc/ndr/ndr.c  */
+
+size_t ndr_align_size(uint32_t offset, size_t n);
+struct ndr_pull *ndr_pull_init_blob(const DATA_BLOB *blob,  
TALLOC_CTX *mem_ctx);
+NTSTATUS ndr_pull_advance(struct ndr_pull *ndr, uint32_t size);
+void ndr_pull_save(struct ndr_pull *ndr, struct ndr_pull_save *save);
+void ndr_pull_restore(struct ndr_pull *ndr, struct ndr_pull_save  
*save);
+struct ndr_push *ndr_push_init_ctx(TALLOC_CTX *mem_ctx);
+struct ndr_push *ndr_push_init(void);
+void ndr_push_free(struct ndr_push *ndr);
+DATA_BLOB ndr_push_blob(struct ndr_push *ndr);
+NTSTATUS ndr_push_expand(struct ndr_push *ndr, uint32_t extra_size);
+void ndr_print_debug_helper(struct ndr_print *ndr, const char  
*format, ...) _PRINTF_ATTRIBUTE(2,3);
+void ndr_print_debug(ndr_print_fn_t fn, const char *name, void *ptr);
+void ndr_print_union_debug(ndr_print_fn_t fn, const char *name,  
uint32_t level, void *ptr);
+void ndr_print_function_debug(ndr_print_function_t fn, const char  
*name, int flags, void *ptr);
+char *ndr_print_function_string(TALLOC_CTX *mem_ctx,
+				ndr_print_function_t fn, const char *name,
+				int flags, void *ptr);
+void ndr_set_flags(uint32_t *pflags, uint32_t new_flags);
+NTSTATUS ndr_pull_error(struct ndr_pull *ndr,
+				 enum ndr_err_code ndr_err,
+				 const char *format, ...) _PRINTF_ATTRIBUTE(3,4);
+NTSTATUS ndr_push_error(struct ndr_push *ndr,
+				 enum ndr_err_code ndr_err,
+				 const char *format, ...)  _PRINTF_ATTRIBUTE(3,4);
+NTSTATUS ndr_pull_subcontext_start(struct ndr_pull *ndr,
+				   struct ndr_pull **_subndr,
+				   size_t header_size,
+				   ssize_t size_is);
+NTSTATUS ndr_pull_subcontext_end(struct ndr_pull *ndr,
+				 struct ndr_pull *subndr,
+				 size_t header_size,
+				 ssize_t size_is);
+NTSTATUS ndr_push_subcontext_start(struct ndr_push *ndr,
+				   struct ndr_push **_subndr,
+				   size_t header_size,
+				   ssize_t size_is);
+NTSTATUS ndr_push_subcontext_end(struct ndr_push *ndr,
+				 struct ndr_push *subndr,
+				 size_t header_size,
+				 ssize_t size_is);
+NTSTATUS ndr_token_store(TALLOC_CTX *mem_ctx,
+			 struct ndr_token_list **list,
+			 const void *key,
+			 uint32_t value);
+NTSTATUS ndr_token_retrieve_cmp_fn(struct ndr_token_list **list,  
const void *key, uint32_t *v,
+				   comparison_fn_t _cmp_fn, BOOL _remove_tok);
+NTSTATUS ndr_token_retrieve(struct ndr_token_list **list, const void  
*key, uint32_t *v);
+uint32_t ndr_token_peek(struct ndr_token_list **list, const void *key);
+NTSTATUS ndr_pull_array_size(struct ndr_pull *ndr, const void *p);
+uint32_t ndr_get_array_size(struct ndr_pull *ndr, const void *p);
+NTSTATUS ndr_check_array_size(struct ndr_pull *ndr, void *p,  
uint32_t size);
+NTSTATUS ndr_pull_array_length(struct ndr_pull *ndr, const void *p);
+uint32_t ndr_get_array_length(struct ndr_pull *ndr, const void *p);
+NTSTATUS ndr_check_array_length(struct ndr_pull *ndr, void *p,  
uint32_t length);
+NTSTATUS ndr_push_set_switch_value(struct ndr_push *ndr, const void  
*p, uint32_t val);
+NTSTATUS ndr_pull_set_switch_value(struct ndr_pull *ndr, const void  
*p, uint32_t val);
+NTSTATUS ndr_print_set_switch_value(struct ndr_print *ndr, const  
void *p, uint32_t val);
+uint32_t ndr_push_get_switch_value(struct ndr_push *ndr, const void  
*p);
+uint32_t ndr_pull_get_switch_value(struct ndr_pull *ndr, const void  
*p);
+uint32_t ndr_print_get_switch_value(struct ndr_print *ndr, const  
void *p);
+NTSTATUS ndr_pull_struct_blob(const DATA_BLOB *blob, TALLOC_CTX  
*mem_ctx, void *p,
+			      ndr_pull_flags_fn_t fn);
+NTSTATUS ndr_pull_struct_blob_all(const DATA_BLOB *blob, TALLOC_CTX  
*mem_ctx, void *p,
+				  ndr_pull_flags_fn_t fn);
+NTSTATUS ndr_pull_union_blob(const DATA_BLOB *blob, TALLOC_CTX  
*mem_ctx, void *p,
+			     uint32_t level, ndr_pull_flags_fn_t fn);
+NTSTATUS ndr_push_struct_blob(DATA_BLOB *blob, TALLOC_CTX *mem_ctx,  
const void *p,
+			      ndr_push_flags_fn_t fn);
+NTSTATUS ndr_push_union_blob(DATA_BLOB *blob, TALLOC_CTX *mem_ctx,  
void *p,
+			     uint32_t level, ndr_push_flags_fn_t fn);
+size_t ndr_size_struct(const void *p, int flags, ndr_push_flags_fn_t  
push);
+size_t ndr_size_union(const void *p, int flags, uint32_t level,  
ndr_push_flags_fn_t push);
+uint32_t ndr_push_get_relative_base_offset(struct ndr_push *ndr);
+void ndr_push_restore_relative_base_offset(struct ndr_push *ndr,  
uint32_t offset);
+NTSTATUS ndr_push_setup_relative_base_offset1(struct ndr_push *ndr,  
const void *p, uint32_t offset);
+NTSTATUS ndr_push_setup_relative_base_offset2(struct ndr_push *ndr,  
const void *p);
+NTSTATUS ndr_push_relative_ptr1(struct ndr_push *ndr, const void *p);
+NTSTATUS ndr_push_relative_ptr2(struct ndr_push *ndr, const void *p);
+uint32_t ndr_pull_get_relative_base_offset(struct ndr_pull *ndr);
+void ndr_pull_restore_relative_base_offset(struct ndr_pull *ndr,  
uint32_t offset);
+NTSTATUS ndr_pull_setup_relative_base_offset1(struct ndr_pull *ndr,  
const void *p, uint32_t offset);
+NTSTATUS ndr_pull_setup_relative_base_offset2(struct ndr_pull *ndr,  
const void *p);
+NTSTATUS ndr_pull_relative_ptr1(struct ndr_pull *ndr, const void *p,  
uint32_t rel_offset);
+NTSTATUS ndr_pull_relative_ptr2(struct ndr_pull *ndr, const void *p);
+
+/* The following definitions come from librpc/ndr/ndr_basic.c  */
+
+void ndr_check_padding(struct ndr_pull *ndr, size_t n);
+NTSTATUS ndr_pull_int8(struct ndr_pull *ndr, int ndr_flags, int8_t *v);
+NTSTATUS ndr_pull_uint8(struct ndr_pull *ndr, int ndr_flags, uint8_t  
*v);
+NTSTATUS ndr_pull_int16(struct ndr_pull *ndr, int ndr_flags, int16_t  
*v);
+NTSTATUS ndr_pull_uint16(struct ndr_pull *ndr, int ndr_flags,  
uint16_t *v);
+NTSTATUS ndr_pull_int32(struct ndr_pull *ndr, int ndr_flags, int32_t  
*v);
+NTSTATUS ndr_pull_uint32(struct ndr_pull *ndr, int ndr_flags,  
uint32_t *v);
+NTSTATUS ndr_pull_generic_ptr(struct ndr_pull *ndr, uint32_t *v);
+NTSTATUS ndr_pull_ref_ptr(struct ndr_pull *ndr, uint32_t *v);
+NTSTATUS ndr_pull_udlong(struct ndr_pull *ndr, int ndr_flags,  
uint64_t *v);
+NTSTATUS ndr_pull_udlongr(struct ndr_pull *ndr, int ndr_flags,  
uint64_t *v);
+NTSTATUS ndr_pull_dlong(struct ndr_pull *ndr, int ndr_flags, int64_t  
*v);
+NTSTATUS ndr_pull_hyper(struct ndr_pull *ndr, int ndr_flags,  
uint64_t *v);
+NTSTATUS ndr_pull_pointer(struct ndr_pull *ndr, int ndr_flags, void*  
*v);
+NTSTATUS ndr_pull_NTSTATUS(struct ndr_pull *ndr, int ndr_flags,  
NTSTATUS *status);
+NTSTATUS ndr_push_NTSTATUS(struct ndr_push *ndr, int ndr_flags,  
NTSTATUS status);
+void ndr_print_NTSTATUS(struct ndr_print *ndr, const char *name,  
NTSTATUS r);
+NTSTATUS ndr_pull_WERROR(struct ndr_pull *ndr, int ndr_flags, WERROR  
*status);
+NTSTATUS ndr_push_WERROR(struct ndr_push *ndr, int ndr_flags, WERROR  
status);
+void ndr_print_WERROR(struct ndr_print *ndr, const char *name,  
WERROR r);
+NTSTATUS ndr_pull_bytes(struct ndr_pull *ndr, uint8_t *data,  
uint32_t n);
+NTSTATUS ndr_pull_array_uint8(struct ndr_pull *ndr, int ndr_flags,  
uint8_t *data, uint32_t n);
+NTSTATUS ndr_push_int8(struct ndr_push *ndr, int ndr_flags, int8_t v);
+NTSTATUS ndr_push_uint8(struct ndr_push *ndr, int ndr_flags, uint8_t  
v);
+NTSTATUS ndr_push_int16(struct ndr_push *ndr, int ndr_flags, int16_t  
v);
+NTSTATUS ndr_push_uint16(struct ndr_push *ndr, int ndr_flags,  
uint16_t v);
+NTSTATUS ndr_push_int32(struct ndr_push *ndr, int ndr_flags, int32_t  
v);
+NTSTATUS ndr_push_uint32(struct ndr_push *ndr, int ndr_flags,  
uint32_t v);
+NTSTATUS ndr_push_udlong(struct ndr_push *ndr, int ndr_flags,  
uint64_t v);
+NTSTATUS ndr_push_udlongr(struct ndr_push *ndr, int ndr_flags,  
uint64_t v);
+NTSTATUS ndr_push_dlong(struct ndr_push *ndr, int ndr_flags, int64_t  
v);
+NTSTATUS ndr_push_hyper(struct ndr_push *ndr, int ndr_flags,  
uint64_t v);
+NTSTATUS ndr_push_pointer(struct ndr_push *ndr, int ndr_flags, void*  
v);
+NTSTATUS ndr_push_align(struct ndr_push *ndr, size_t size);
+NTSTATUS ndr_pull_align(struct ndr_pull *ndr, size_t size);
+NTSTATUS ndr_push_bytes(struct ndr_push *ndr, const uint8_t *data,  
uint32_t n);
+NTSTATUS ndr_push_zero(struct ndr_push *ndr, uint32_t n);
+NTSTATUS ndr_push_array_uint8(struct ndr_push *ndr, int ndr_flags,  
const uint8_t *data, uint32_t n);
+void ndr_push_save(struct ndr_push *ndr, struct ndr_push_save *save);
+void ndr_push_restore(struct ndr_push *ndr, struct ndr_push_save  
*save);
+NTSTATUS ndr_push_unique_ptr(struct ndr_push *ndr, const void *p);
+NTSTATUS ndr_push_full_ptr(struct ndr_push *ndr, const void *p);
+NTSTATUS ndr_push_ref_ptr(struct ndr_push *ndr);
+NTSTATUS ndr_push_NTTIME(struct ndr_push *ndr, int ndr_flags, NTTIME  
t);
+NTSTATUS ndr_pull_NTTIME(struct ndr_pull *ndr, int ndr_flags, NTTIME  
*t);
+NTSTATUS ndr_push_NTTIME_1sec(struct ndr_push *ndr, int ndr_flags,  
NTTIME t);
+NTSTATUS ndr_pull_NTTIME_1sec(struct ndr_pull *ndr, int ndr_flags,  
NTTIME *t);
+NTSTATUS ndr_pull_NTTIME_hyper(struct ndr_pull *ndr, int ndr_flags,  
NTTIME *t);
+NTSTATUS ndr_push_NTTIME_hyper(struct ndr_push *ndr, int ndr_flags,  
NTTIME t);
+NTSTATUS ndr_push_time_t(struct ndr_push *ndr, int ndr_flags, time_t  
t);
+NTSTATUS ndr_pull_time_t(struct ndr_pull *ndr, int ndr_flags, time_t  
*t);
+NTSTATUS ndr_pull_ipv4address(struct ndr_pull *ndr, int ndr_flags,  
const char **address);
+NTSTATUS ndr_push_ipv4address(struct ndr_push *ndr, int ndr_flags,  
const char *address);
+void ndr_print_ipv4address(struct ndr_print *ndr, const char *name,
+			   const char *address);
+void ndr_print_struct(struct ndr_print *ndr, const char *name, const  
char *type);
+void ndr_print_enum(struct ndr_print *ndr, const char *name, const  
char *type,
+		    const char *val, uint32_t value);
+void ndr_print_bitmap_flag(struct ndr_print *ndr, size_t size, const  
char *flag_name, uint32_t flag, uint32_t value);
+void ndr_print_int8(struct ndr_print *ndr, const char *name, int8_t v);
+void ndr_print_uint8(struct ndr_print *ndr, const char *name,  
uint8_t v);
+void ndr_print_int16(struct ndr_print *ndr, const char *name,  
int16_t v);
+void ndr_print_uint16(struct ndr_print *ndr, const char *name,  
uint16_t v);
+void ndr_print_int32(struct ndr_print *ndr, const char *name,  
int32_t v);
+void ndr_print_uint32(struct ndr_print *ndr, const char *name,  
uint32_t v);
+void ndr_print_udlong(struct ndr_print *ndr, const char *name,  
uint64_t v);
+void ndr_print_udlongr(struct ndr_print *ndr, const char *name,  
uint64_t v);
+void ndr_print_dlong(struct ndr_print *ndr, const char *name,  
int64_t v);
+void ndr_print_hyper(struct ndr_print *ndr, const char *name,  
uint64_t v);
+void ndr_print_pointer(struct ndr_print *ndr, const char *name, void  
*v);
+void ndr_print_ptr(struct ndr_print *ndr, const char *name, const  
void *p);
+void ndr_print_NTTIME(struct ndr_print *ndr, const char *name,  
NTTIME t);
+void ndr_print_NTTIME_1sec(struct ndr_print *ndr, const char *name,  
NTTIME t);
+void ndr_print_NTTIME_hyper(struct ndr_print *ndr, const char *name,  
NTTIME t);
+void ndr_print_time_t(struct ndr_print *ndr, const char *name,  
time_t t);
+void ndr_print_union(struct ndr_print *ndr, const char *name, int  
level, const char *type);
+void ndr_print_bad_level(struct ndr_print *ndr, const char *name,  
uint16_t level);
+void ndr_print_array_uint8(struct ndr_print *ndr, const char *name,
+			   const uint8_t *data, uint32_t count);
+void ndr_print_DATA_BLOB(struct ndr_print *ndr, const char *name,  
DATA_BLOB r);
+NTSTATUS ndr_push_DATA_BLOB(struct ndr_push *ndr, int ndr_flags,  
DATA_BLOB blob);
+NTSTATUS ndr_pull_DATA_BLOB(struct ndr_pull *ndr, int ndr_flags,  
DATA_BLOB *blob);
+uint32_t ndr_size_DATA_BLOB(int ret, const DATA_BLOB *data, int flags);
+
+/* The following definitions come from librpc/ndr/ndr_misc.c  */
+
+NTSTATUS ndr_push_GUID(struct ndr_push *ndr, int ndr_flags, const  
struct GUID *r);
+NTSTATUS ndr_pull_GUID(struct ndr_pull *ndr, int ndr_flags, struct  
GUID *r);
+size_t ndr_size_GUID(const struct GUID *r, int flags);
+NTSTATUS GUID_from_string(const char *s, struct GUID *guid);
+struct GUID GUID_random(void);
+struct GUID GUID_zero(void);
+BOOL all_zero(const uint8_t *ptr, size_t size);
+BOOL GUID_all_zero(const struct GUID *u);
+BOOL GUID_equal(const struct GUID *u1, const struct GUID *u2);
+char *GUID_string(TALLOC_CTX *mem_ctx, const struct GUID *guid);
+char *GUID_string2(TALLOC_CTX *mem_ctx, const struct GUID *guid);
+void ndr_print_GUID(struct ndr_print *ndr, const char *name, const  
struct GUID *guid);
+BOOL policy_handle_empty(struct policy_handle *h) ;
+NTSTATUS ndr_push_policy_handle(struct ndr_push *ndr, int ndr_flags,  
const struct policy_handle *r);
+NTSTATUS ndr_pull_policy_handle(struct ndr_pull *ndr, int ndr_flags,  
struct policy_handle *r);
+void ndr_print_policy_handle(struct ndr_print *ndr, const char  
*name, const struct policy_handle *r);
+NTSTATUS ndr_push_server_id(struct ndr_push *ndr, int ndr_flags,  
const struct server_id *r);
+NTSTATUS ndr_pull_server_id(struct ndr_pull *ndr, int ndr_flags,  
struct server_id *r);
+void ndr_print_server_id(struct ndr_print *ndr, const char *name,  
const struct server_id *r);
+
+/* The following definitions come from librpc/ndr/ndr_sec_helper.c  */
+
+size_t ndr_size_dom_sid(const struct dom_sid *sid, int flags);
+size_t ndr_size_security_ace(const struct security_ace *ace, int  
flags);
+size_t ndr_size_security_acl(const struct security_acl *acl, int  
flags);
+size_t ndr_size_security_descriptor(const struct security_descriptor  
*sd, int flags);
+void ndr_print_dom_sid(struct ndr_print *ndr, const char *name,  
const struct dom_sid *sid);
+void ndr_print_dom_sid2(struct ndr_print *ndr, const char *name,  
const struct dom_sid *sid);
+void ndr_print_dom_sid28(struct ndr_print *ndr, const char *name,  
const struct dom_sid *sid);
+void ndr_print_security_ace_flags(struct ndr_print *ndr, const char  
*name, uint8_t r);
+void ndr_print_security_ace_type(struct ndr_print *ndr, const char  
*name, enum security_ace_type r);
+void ndr_print_security_ace_object_flags(struct ndr_print *ndr,  
const char *name, uint32_t r);
+void ndr_print_security_ace_object_type(struct ndr_print *ndr, const  
char *name, const union security_ace_object_type *r);
+void ndr_print_security_ace_object_inherited_type(struct ndr_print  
*ndr, const char *name, const union  
security_ace_object_inherited_type *r);
+void ndr_print_security_ace_object(struct ndr_print *ndr, const char  
*name, const struct security_ace_object *r);
+void ndr_print_security_ace_object_ctr(struct ndr_print *ndr, const  
char *name, const union security_ace_object_ctr *r);
+NTSTATUS ndr_push_security_ace(struct ndr_push *ndr, int ndr_flags,  
const struct security_ace *r);
+NTSTATUS ndr_pull_security_ace(struct ndr_pull *ndr, int ndr_flags,  
struct security_ace *r);
+void ndr_print_security_ace(struct ndr_print *ndr, const char *name,  
const struct security_ace *r);
+void ndr_print_security_acl_revision(struct ndr_print *ndr, const  
char *name, enum security_acl_revision r);
+NTSTATUS ndr_push_security_acl(struct ndr_push *ndr, int ndr_flags,  
const struct security_acl *r);
+NTSTATUS ndr_pull_security_acl(struct ndr_pull *ndr, int ndr_flags,  
struct security_acl *r);
+void ndr_print_security_acl(struct ndr_print *ndr, const char *name,  
const struct security_acl *r);
+void ndr_print_security_descriptor_revision(struct ndr_print *ndr,  
const char *name, enum security_descriptor_revision r);
+void ndr_print_security_descriptor_type(struct ndr_print *ndr, const  
char *name, uint16_t r);
+NTSTATUS ndr_push_security_descriptor(struct ndr_push *ndr, int  
ndr_flags, const struct security_descriptor *r);
+NTSTATUS ndr_pull_security_descriptor(struct ndr_pull *ndr, int  
ndr_flags, struct security_descriptor *r);
+void ndr_print_security_descriptor(struct ndr_print *ndr, const char  
*name, const struct security_descriptor *r);
+NTSTATUS ndr_push_security_secinfo(struct ndr_push *ndr, int  
ndr_flags, uint32_t r);
+NTSTATUS ndr_pull_security_secinfo(struct ndr_pull *ndr, int  
ndr_flags, uint32_t *r);
+void ndr_print_security_secinfo(struct ndr_print *ndr, const char  
*name, uint32_t r);
+
+/* The following definitions come from librpc/ndr/ndr_string.c  */
+
+NTSTATUS ndr_pull_string(struct ndr_pull *ndr, int ndr_flags, const  
char **s);
+NTSTATUS ndr_push_string(struct ndr_push *ndr, int ndr_flags, const  
char *s);
+size_t ndr_string_array_size(struct ndr_push *ndr, const char *s);
+void ndr_print_string(struct ndr_print *ndr, const char *name, const  
char *s);
+uint32_t ndr_size_string(int ret, const char * const* string, int  
flags) ;
+NTSTATUS ndr_pull_string_array(struct ndr_pull *ndr, int ndr_flags,  
const char ***_a);
+NTSTATUS ndr_push_string_array(struct ndr_push *ndr, int ndr_flags,  
const char **a);
+void ndr_print_string_array(struct ndr_print *ndr, const char *name,  
const char **a);
+uint32_t ndr_string_length(const void *_var, uint32_t element_size);
+NTSTATUS ndr_check_string_terminator(struct ndr_pull *ndr, uint32_t  
count, uint32_t element_size);
+NTSTATUS ndr_pull_charset(struct ndr_pull *ndr, int ndr_flags, const  
char **var, uint32_t length, uint8_t byte_mul, charset_t chset);
+NTSTATUS ndr_push_charset(struct ndr_push *ndr, int ndr_flags, const  
char *var,
+			  uint32_t length, uint8_t byte_mul, charset_t chset);
+uint32_t ndr_charset_length(const void *var, int chset);
+
+/* The following definitions come from librpc/ndr/sid.c  */
+
+NTSTATUS ndr_push_dom_sid(struct ndr_push *ndr, int ndr_flags, const  
struct dom_sid *r);
+NTSTATUS ndr_pull_dom_sid(struct ndr_pull *ndr, int ndr_flags,  
struct dom_sid *r);
+char *dom_sid_string(TALLOC_CTX *mem_ctx, const struct dom_sid *sid);
+NTSTATUS ndr_pull_dom_sid2(struct ndr_pull *ndr, int ndr_flags,  
struct dom_sid *sid);
+NTSTATUS ndr_push_dom_sid2(struct ndr_push *ndr, int ndr_flags,  
const struct dom_sid *sid);
+NTSTATUS ndr_pull_dom_sid28(struct ndr_pull *ndr, int ndr_flags,  
struct dom_sid *sid);
+NTSTATUS ndr_push_dom_sid28(struct ndr_push *ndr, int ndr_flags,  
const struct dom_sid *sid);
+NTSTATUS ndr_push_sec_desc_buf(struct ndr_push *ndr, int ndr_flags,  
const struct sec_desc_buf *r);
+NTSTATUS ndr_pull_sec_desc_buf(struct ndr_pull *ndr, int ndr_flags,  
struct sec_desc_buf *r);
+void ndr_print_sec_desc_buf(struct ndr_print *ndr, const char *name,  
const struct sec_desc_buf *r);
+
+/* The following definitions come from libsmb/asn1.c  */
+
+void asn1_free(ASN1_DATA *data);
+BOOL asn1_write(ASN1_DATA *data, const void *p, int len);
+BOOL asn1_write_uint8(ASN1_DATA *data, uint8 v);
+BOOL asn1_push_tag(ASN1_DATA *data, uint8 tag);
+BOOL asn1_pop_tag(ASN1_DATA *data);
+BOOL asn1_write_Integer(ASN1_DATA *data, int i);
+BOOL asn1_write_OID(ASN1_DATA *data, const char *OID);
+BOOL asn1_write_OctetString(ASN1_DATA *data, const void *p, size_t  
length);
+BOOL asn1_write_GeneralString(ASN1_DATA *data, const char *s);
+BOOL asn1_write_BOOLEAN(ASN1_DATA *data, BOOL v);
+BOOL asn1_write_BOOLEAN2(ASN1_DATA *data, BOOL v);
+BOOL asn1_check_BOOLEAN(ASN1_DATA *data, BOOL v);
+BOOL asn1_load(ASN1_DATA *data, DATA_BLOB blob);
+BOOL asn1_read(ASN1_DATA *data, void *p, int len);
+BOOL asn1_read_uint8(ASN1_DATA *data, uint8 *v);
+BOOL asn1_start_tag(ASN1_DATA *data, uint8 tag);
+BOOL asn1_end_tag(ASN1_DATA *data);
+int asn1_tag_remaining(ASN1_DATA *data);
+BOOL asn1_read_OID(ASN1_DATA *data, char **OID);
+BOOL asn1_check_OID(ASN1_DATA *data, const char *OID);
+BOOL asn1_read_GeneralString(ASN1_DATA *data, char **s);
+BOOL asn1_read_OctetString(ASN1_DATA *data, DATA_BLOB *blob);
+BOOL asn1_read_Integer(ASN1_DATA *data, int *i);
+BOOL asn1_check_enumerated(ASN1_DATA *data, int v);
+BOOL asn1_write_enumerated(ASN1_DATA *data, uint8 v);
+
+/* The following definitions come from libsmb/cliconnect.c  */
+
+ADS_STATUS cli_session_setup_spnego(struct cli_state *cli, const  
char *user,
+			      const char *pass, const char *domain);
+NTSTATUS cli_session_setup(struct cli_state *cli,
+			   const char *user,
+			   const char *pass, int passlen,
+			   const char *ntpass, int ntpasslen,
+			   const char *workgroup);
+BOOL cli_ulogoff(struct cli_state *cli);
+BOOL cli_send_tconX(struct cli_state *cli,
+		    const char *share, const char *dev, const char *pass, int  
passlen);
+BOOL cli_tdis(struct cli_state *cli);
+void cli_negprot_send(struct cli_state *cli);
+BOOL cli_negprot(struct cli_state *cli);
+BOOL cli_session_request(struct cli_state *cli,
+			 struct nmb_name *calling, struct nmb_name *called);
+BOOL cli_connect(struct cli_state *cli, const char *host, struct  
in_addr *ip);
+NTSTATUS cli_start_connection(struct cli_state **output_cli,
+			      const char *my_name,
+			      const char *dest_host,
+			      struct in_addr *dest_ip, int port,
+			      int signing_state, int flags,
+			      BOOL *retry) ;
+NTSTATUS cli_full_connection(struct cli_state **output_cli,
+			     const char *my_name,
+			     const char *dest_host,
+			     struct in_addr *dest_ip, int port,
+			     const char *service, const char *service_type,
+			     const char *user, const char *domain,
+			     const char *password, int flags,
+			     int signing_state,
+			     BOOL *retry) ;
+BOOL attempt_netbios_session_request(struct cli_state **ppcli, const  
char *srchost, const char *desthost,
+                                     struct in_addr *pdest_ip);
+NTSTATUS cli_raw_tcon(struct cli_state *cli,
+		      const char *service, const char *pass, const char *dev,
+		      uint16 *max_xmit, uint16 *tid);
+struct cli_state *get_ipc_connect(char *server, struct in_addr  
*server_ip,
+                                         struct user_auth_info  
*user_info);
+struct cli_state *get_ipc_connect_master_ip(struct ip_service *  
mb_ip, pstring workgroup, struct user_auth_info *user_info);
+struct cli_state *get_ipc_connect_master_ip_bcast(pstring workgroup,  
struct user_auth_info *user_info);
+
+/* The following definitions come from libsmb/clidfs.c  */
+
+const char *cli_cm_get_mntpoint( struct cli_state *c );
+struct cli_state *cli_cm_open(const char *server,
+				const char *share,
+				BOOL show_hdr);
+void cli_cm_shutdown( void );
+void cli_cm_display(void);
+void cli_cm_set_credentials( struct user_auth_info *user );
+void cli_cm_set_port( int port_number );
+void cli_cm_set_dest_name_type( int type );
+void cli_cm_set_dest_ip(struct in_addr ip );
+BOOL cli_dfs_get_referral( struct cli_state *cli,
+			const char *path,
+			CLIENT_DFS_REFERRAL**refs,
+			size_t *num_refs,
+			uint16 *consumed);
+BOOL cli_resolve_path( const char *mountpt,
+			struct cli_state *rootcli,
+			const char *path,
+			struct cli_state **targetcli,
+			pstring targetpath);
+BOOL cli_check_msdfs_proxy( struct cli_state *cli, const char  
*sharename,
+                            fstring newserver, fstring newshare );
+
+/* The following definitions come from libsmb/clidgram.c  */
+
+BOOL cli_send_mailslot(struct messaging_context *msg_ctx,
+		       BOOL unique, const char *mailslot,
+		       uint16 priority,
+		       char *buf, int len,
+		       const char *srcname, int src_type,
+		       const char *dstname, int dest_type,
+		       struct in_addr dest_ip);
+BOOL cli_get_response(const char *mailslot, char *buf, int bufsiz);
+int cli_get_backup_list(struct messaging_context *msg_ctx,
+			const char *myname, const char *send_to_name);
+int cli_get_backup_server(struct messaging_context *msg_ctx,
+			  char *my_name, char *target, char *servername,
+			  int namesize);
+
+/* The following definitions come from libsmb/clientgen.c  */
+
+unsigned int cli_set_timeout(struct cli_state *cli, unsigned int  
timeout);
+int cli_set_port(struct cli_state *cli, int port);
+BOOL cli_receive_smb_internal(struct cli_state *cli, BOOL  
eat_keepalives);
+BOOL cli_receive_smb(struct cli_state *cli);
+BOOL cli_receive_smb_return_keepalive(struct cli_state *cli);
+ssize_t cli_receive_smb_data(struct cli_state *cli, char *buffer,  
size_t len);
+BOOL cli_receive_smb_readX_header(struct cli_state *cli);
+BOOL cli_send_smb(struct cli_state *cli);
+void cli_setup_packet(struct cli_state *cli);
+void cli_setup_bcc(struct cli_state *cli, void *p);
+void cli_init_creds(struct cli_state *cli, const char *username,  
const char *domain, const char *password);
+void cli_setup_signing_state(struct cli_state *cli, int signing_state);
+struct cli_state *cli_initialise(void);
+BOOL cli_rpc_pipe_close(struct rpc_pipe_client *cli);
+void cli_nt_pipes_close(struct cli_state *cli);
+void cli_shutdown(struct cli_state *cli);
+void cli_sockopt(struct cli_state *cli, const char *options);
+uint16 cli_setpid(struct cli_state *cli, uint16 pid);
+BOOL cli_set_case_sensitive(struct cli_state *cli, BOOL  
case_sensitive);
+BOOL cli_send_keepalive(struct cli_state *cli);
+BOOL cli_echo(struct cli_state *cli, unsigned char *data, size_t  
length);
+
+/* The following definitions come from libsmb/clierror.c  */
+
+const char *cli_errstr(struct cli_state *cli);
+NTSTATUS cli_nt_error(struct cli_state *cli);
+void cli_dos_error(struct cli_state *cli, uint8 *eclass, uint32  
*ecode);
+int cli_errno(struct cli_state *cli);
+BOOL cli_is_error(struct cli_state *cli);
+BOOL cli_is_nt_error(struct cli_state *cli);
+BOOL cli_is_dos_error(struct cli_state *cli);
+NTSTATUS cli_get_nt_error(struct cli_state *cli);
+void cli_set_nt_error(struct cli_state *cli, NTSTATUS status);
+
+/* The following definitions come from libsmb/clifile.c  */
+
+uint32 unix_perms_to_wire(mode_t perms);
+mode_t wire_perms_to_unix(uint32 perms);
+BOOL cli_unix_getfacl(struct cli_state *cli, const char *name,  
size_t *prb_size, char **retbuf);
+BOOL cli_unix_stat(struct cli_state *cli, const char *name,  
SMB_STRUCT_STAT *sbuf);
+BOOL cli_unix_symlink(struct cli_state *cli, const char *oldname,  
const char *newname);
+BOOL cli_unix_hardlink(struct cli_state *cli, const char *oldname,  
const char *newname);
+BOOL cli_unix_chmod(struct cli_state *cli, const char *fname, mode_t  
mode);
+BOOL cli_unix_chown(struct cli_state *cli, const char *fname, uid_t  
uid, gid_t gid);
+BOOL cli_rename(struct cli_state *cli, const char *fname_src, const  
char *fname_dst);
+BOOL cli_ntrename(struct cli_state *cli, const char *fname_src,  
const char *fname_dst);
+BOOL cli_nt_hardlink(struct cli_state *cli, const char *fname_src,  
const char *fname_dst);
+BOOL cli_unlink_full(struct cli_state *cli, const char *fname,  
uint16 attrs);
+BOOL cli_unlink(struct cli_state *cli, const char *fname);
+BOOL cli_mkdir(struct cli_state *cli, const char *dname);
+BOOL cli_rmdir(struct cli_state *cli, const char *dname);
+int cli_nt_delete_on_close(struct cli_state *cli, int fnum, BOOL flag);
+int cli_nt_create_full(struct cli_state *cli, const char *fname,
+		 uint32 CreatFlags, uint32 DesiredAccess,
+		 uint32 FileAttributes, uint32 ShareAccess,
+		 uint32 CreateDisposition, uint32 CreateOptions,
+		 uint8 SecuityFlags);
+int cli_nt_create(struct cli_state *cli, const char *fname, uint32  
DesiredAccess);
+int cli_open(struct cli_state *cli, const char *fname, int flags,  
int share_mode);
+BOOL cli_close(struct cli_state *cli, int fnum);
+NTSTATUS cli_locktype(struct cli_state *cli, int fnum,
+		      uint32 offset, uint32 len, int timeout, unsigned char  
locktype);
+BOOL cli_lock(struct cli_state *cli, int fnum,
+	      uint32 offset, uint32 len, int timeout, enum brl_type  
lock_type);
+BOOL cli_unlock(struct cli_state *cli, int fnum, uint32 offset,  
uint32 len);
+BOOL cli_lock64(struct cli_state *cli, int fnum,
+		SMB_BIG_UINT offset, SMB_BIG_UINT len, int timeout, enum brl_type  
lock_type);
+BOOL cli_unlock64(struct cli_state *cli, int fnum, SMB_BIG_UINT  
offset, SMB_BIG_UINT len);
+BOOL cli_posix_lock(struct cli_state *cli, int fnum,
+			SMB_BIG_UINT offset, SMB_BIG_UINT len,
+			BOOL wait_lock, enum brl_type lock_type);
+BOOL cli_posix_unlock(struct cli_state *cli, int fnum, SMB_BIG_UINT  
offset, SMB_BIG_UINT len);
+BOOL cli_posix_getlock(struct cli_state *cli, int fnum, SMB_BIG_UINT  
*poffset, SMB_BIG_UINT *plen);
+BOOL cli_getattrE(struct cli_state *cli, int fd,
+		  uint16 *attr, SMB_OFF_T *size,
+		  time_t *change_time,
+                  time_t *access_time,
+                  time_t *write_time);
+BOOL cli_getatr(struct cli_state *cli, const char *fname,
+		uint16 *attr, SMB_OFF_T *size, time_t *write_time);
+BOOL cli_setattrE(struct cli_state *cli, int fd,
+		  time_t change_time,
+                  time_t access_time,
+                  time_t write_time);
+BOOL cli_setatr(struct cli_state *cli, const char *fname, uint16  
attr, time_t t);
+BOOL cli_chkpath(struct cli_state *cli, const char *path);
+BOOL cli_dskattr(struct cli_state *cli, int *bsize, int *total, int  
*avail);
+int cli_ctemp(struct cli_state *cli, const char *path, char  
**tmp_path);
+NTSTATUS cli_raw_ioctl(struct cli_state *cli, int fnum, uint32 code,  
DATA_BLOB *blob);
+BOOL cli_set_ea_path(struct cli_state *cli, const char *path, const  
char *ea_name, const char *ea_val, size_t ea_len);
+BOOL cli_set_ea_fnum(struct cli_state *cli, int fnum, const char  
*ea_name, const char *ea_val, size_t ea_len);
+BOOL cli_get_ea_list_path(struct cli_state *cli, const char *path,
+		TALLOC_CTX *ctx,
+		size_t *pnum_eas,
+		struct ea_struct **pea_list);
+BOOL cli_get_ea_list_fnum(struct cli_state *cli, int fnum,
+		TALLOC_CTX *ctx,
+		size_t *pnum_eas,
+		struct ea_struct **pea_list);
+int cli_posix_open(struct cli_state *cli, const char *fname, int  
flags, mode_t mode);
+int cli_posix_mkdir(struct cli_state *cli, const char *fname, mode_t  
mode);
+BOOL cli_posix_unlink(struct cli_state *cli, const char *fname);
+int cli_posix_rmdir(struct cli_state *cli, const char *fname);
+
+/* The following definitions come from libsmb/clifsinfo.c  */
+
+BOOL cli_unix_extensions_version(struct cli_state *cli, uint16  
*pmajor, uint16 *pminor,
+                                        uint32 *pcaplow, uint32  
*pcaphigh);
+BOOL cli_set_unix_extensions_capabilities(struct cli_state *cli,  
uint16 major, uint16 minor,
+                                        uint32 caplow, uint32 caphigh);
+BOOL cli_get_fs_attr_info(struct cli_state *cli, uint32 *fs_attr);
+BOOL cli_get_fs_volume_info_old(struct cli_state *cli, fstring  
volume_name, uint32 *pserial_number);
+BOOL cli_get_fs_volume_info(struct cli_state *cli, fstring  
volume_name, uint32 *pserial_number, time_t *pdate);
+NTSTATUS cli_raw_ntlm_smb_encryption_start(struct cli_state *cli,
+				const char *user,
+				const char *pass,
+				const char *domain);
+NTSTATUS cli_gss_smb_encryption_start(struct cli_state *cli);
+NTSTATUS cli_gss_smb_encryption_start(struct cli_state *cli);
+
+/* The following definitions come from libsmb/clikrb5.c  */
+
+BOOL unwrap_edata_ntstatus(TALLOC_CTX *mem_ctx,
+			   DATA_BLOB *edata,
+			   DATA_BLOB *edata_out);
+BOOL unwrap_pac(TALLOC_CTX *mem_ctx, DATA_BLOB *auth_data, DATA_BLOB  
*unwrapped_pac_data);
+int cli_krb5_get_ticket(const char *principal, time_t time_offset,
+			DATA_BLOB *ticket, DATA_BLOB *session_key_krb5,
+			uint32 extra_ap_opts, const char *ccname,
+			time_t *tgs_expire);
+
+/* The following definitions come from libsmb/clilist.c  */
+
+int cli_list_new(struct cli_state *cli,const char *Mask,uint16  
attribute,
+		 void (*fn)(const char *, file_info *, const char *, void *), void  
*state);
+int cli_list_old(struct cli_state *cli,const char *Mask,uint16  
attribute,
+		 void (*fn)(const char *, file_info *, const char *, void *), void  
*state);
+int cli_list(struct cli_state *cli,const char *Mask,uint16 attribute,
+	     void (*fn)(const char *, file_info *, const char *, void *),  
void *state);
+
+/* The following definitions come from libsmb/climessage.c  */
+
+int cli_message_start_build(struct cli_state *cli, char *host, char  
*username);
+BOOL cli_message_start(struct cli_state *cli, char *host, char  
*username,
+			      int *grp);
+int cli_message_text_build(struct cli_state *cli, char *msg, int  
len, int grp);
+BOOL cli_message_text(struct cli_state *cli, char *msg, int len, int  
grp);
+int cli_message_end_build(struct cli_state *cli, int grp);
+BOOL cli_message_end(struct cli_state *cli, int grp);
+
+/* The following definitions come from libsmb/clioplock.c  */
+
+BOOL cli_oplock_ack(struct cli_state *cli, int fnum, unsigned char  
level);
+void cli_oplock_handler(struct cli_state *cli,
+			BOOL (*handler)(struct cli_state *, int, unsigned char));
+
+/* The following definitions come from libsmb/cliprint.c  */
+
+int cli_print_queue(struct cli_state *cli,
+		    void (*fn)(struct print_job_info *));
+int cli_printjob_del(struct cli_state *cli, int job);
+int cli_spl_open(struct cli_state *cli, const char *fname, int  
flags, int share_mode);
+BOOL cli_spl_close(struct cli_state *cli, int fnum);
+
+/* The following definitions come from libsmb/cliquota.c  */
+
+BOOL cli_get_quota_handle(struct cli_state *cli, int *quota_fnum);
+void free_ntquota_list(SMB_NTQUOTA_LIST **qt_list);
+BOOL cli_get_user_quota(struct cli_state *cli, int quota_fnum,  
SMB_NTQUOTA_STRUCT *pqt);
+BOOL cli_set_user_quota(struct cli_state *cli, int quota_fnum,  
SMB_NTQUOTA_STRUCT *pqt);
+BOOL cli_list_user_quota(struct cli_state *cli, int quota_fnum,  
SMB_NTQUOTA_LIST **pqt_list);
+BOOL cli_get_fs_quota_info(struct cli_state *cli, int quota_fnum,  
SMB_NTQUOTA_STRUCT *pqt);
+BOOL cli_set_fs_quota_info(struct cli_state *cli, int quota_fnum,  
SMB_NTQUOTA_STRUCT *pqt);
+void dump_ntquota(SMB_NTQUOTA_STRUCT *qt, BOOL _verbose, BOOL  
_numeric, void (*_sidtostring)(fstring str, DOM_SID *sid, BOOL  
_numeric));
+void dump_ntquota_list(SMB_NTQUOTA_LIST **qtl, BOOL _verbose, BOOL  
_numeric, void (*_sidtostring)(fstring str, DOM_SID *sid, BOOL  
_numeric));
+
+/* The following definitions come from libsmb/clirap.c  */
+
+BOOL cli_api_pipe(struct cli_state *cli, const char *pipe_name,
+                  uint16 *setup, uint32 setup_count, uint32  
max_setup_count,
+                  char *params, uint32 param_count, uint32  
max_param_count,
+                  char *data, uint32 data_count, uint32 max_data_count,
+                  char **rparam, uint32 *rparam_count,
+                  char **rdata, uint32 *rdata_count);
+BOOL cli_api(struct cli_state *cli,
+	     char *param, int prcnt, int mprcnt,
+	     char *data, int drcnt, int mdrcnt,
+	     char **rparam, unsigned int *rprcnt,
+	     char **rdata, unsigned int *rdrcnt);
+BOOL cli_NetWkstaUserLogon(struct cli_state *cli,char *user, char  
*workstation);
+int cli_RNetShareEnum(struct cli_state *cli, void (*fn)(const char  
*, uint32, const char *, void *), void *state);
+BOOL cli_NetServerEnum(struct cli_state *cli, char *workgroup,  
uint32 stype,
+		       void (*fn)(const char *, uint32, const char *, void *),
+		       void *state);
+BOOL cli_oem_change_password(struct cli_state *cli, const char  
*user, const char *new_password,
+                             const char *old_password);
+BOOL cli_qpathinfo(struct cli_state *cli, const char *fname,
+		   time_t *change_time,
+                   time_t *access_time,
+                   time_t *write_time,
+		   SMB_OFF_T *size, uint16 *mode);
+BOOL cli_setpathinfo(struct cli_state *cli, const char *fname,
+                     time_t create_time,
+                     time_t access_time,
+                     time_t write_time,
+                     time_t change_time,
+                     uint16 mode);
+BOOL cli_qpathinfo2(struct cli_state *cli, const char *fname,
+		    struct timespec *create_time,
+                    struct timespec *access_time,
+                    struct timespec *write_time,
+		    struct timespec *change_time,
+                    SMB_OFF_T *size, uint16 *mode,
+		    SMB_INO_T *ino);
+BOOL cli_qfilename(struct cli_state *cli, int fnum,
+		   pstring name);
+BOOL cli_qfileinfo(struct cli_state *cli, int fnum,
+		   uint16 *mode, SMB_OFF_T *size,
+		   struct timespec *create_time,
+                   struct timespec *access_time,
+                   struct timespec *write_time,
+		   struct timespec *change_time,
+                   SMB_INO_T *ino);
+BOOL cli_qpathinfo_basic( struct cli_state *cli, const char *name,
+                          SMB_STRUCT_STAT *sbuf, uint32 *attributes );
+BOOL cli_qfileinfo_test(struct cli_state *cli, int fnum, int level,  
char **poutdata, uint32 *poutlen);
+NTSTATUS cli_qpathinfo_alt_name(struct cli_state *cli, const char  
*fname, fstring alt_name);
+
+/* The following definitions come from libsmb/clirap2.c  */
+
+int cli_NetGroupDelete(struct cli_state *cli, const char *group_name );
+int cli_NetGroupAdd(struct cli_state *cli, RAP_GROUP_INFO_1 * grinfo );
+int cli_RNetGroupEnum(struct cli_state *cli, void (*fn)(const char  
*, const char *, void *), void *state);
+int cli_RNetGroupEnum0(struct cli_state *cli,
+		       void (*fn)(const char *, void *),
+		       void *state);
+int cli_NetGroupDelUser(struct cli_state * cli, const char  
*group_name, const char *user_name);
+int cli_NetGroupAddUser(struct cli_state * cli, const char  
*group_name, const char *user_name);
+int cli_NetGroupGetUsers(struct cli_state * cli, const char  
*group_name, void (*fn)(const char *, void *), void *state );
+int cli_NetUserGetGroups(struct cli_state * cli, const char  
*user_name, void (*fn)(const char *, void *), void *state );
+int cli_NetUserDelete(struct cli_state *cli, const char * user_name );
+int cli_NetUserAdd(struct cli_state *cli, RAP_USER_INFO_1 * userinfo );
+int cli_RNetUserEnum(struct cli_state *cli, void (*fn)(const char *,  
const char *, const char *, const char *, void *), void *state);
+int cli_RNetUserEnum0(struct cli_state *cli,
+		      void (*fn)(const char *, void *),
+		      void *state);
+int cli_NetFileClose(struct cli_state *cli, uint32 file_id );
+int cli_NetFileGetInfo(struct cli_state *cli, uint32 file_id, void  
(*fn)(const char *, const char *, uint16, uint16, uint32));
+int cli_NetFileEnum(struct cli_state *cli, char * user, char *  
base_path, void (*fn)(const char *, const char *, uint16, uint16,  
uint32));
+int cli_NetShareAdd(struct cli_state *cli, RAP_SHARE_INFO_2 * sinfo );
+int cli_NetShareDelete(struct cli_state *cli, const char *  
share_name );
+BOOL cli_get_pdc_name(struct cli_state *cli, char *workgroup, char  
*pdc_name);
+BOOL cli_get_server_domain(struct cli_state *cli);
+BOOL cli_get_server_type(struct cli_state *cli, uint32 *pstype);
+BOOL cli_get_server_name(TALLOC_CTX *mem_ctx, struct cli_state *cli,
+			 char **servername);
+BOOL cli_ns_check_server_type(struct cli_state *cli, char  
*workgroup, uint32 stype);
+BOOL cli_NetWkstaUserLogoff(struct cli_state *cli,char *user, char  
*workstation);
+int cli_NetPrintQEnum(struct cli_state *cli,
+		void (*qfn)(const char*,uint16,uint16,uint16,const char*,const  
char*,const char*,const char*,const char*,uint16,uint16),
+		void (*jfn)(uint16,const char*,const char*,const char*,const  
char*,uint16,uint16,const char*,uint,uint,const char*));
+int cli_NetPrintQGetInfo(struct cli_state *cli, const char *printer,
+	void (*qfn)(const char*,uint16,uint16,uint16,const char*,const  
char*,const char*,const char*,const char*,uint16,uint16),
+	void (*jfn)(uint16,const char*,const char*,const char*,const  
char*,uint16,uint16,const char*,uint,uint,const char*));
+int cli_RNetServiceEnum(struct cli_state *cli, void (*fn)(const char  
*, const char *, void *), void *state);
+int cli_NetSessionEnum(struct cli_state *cli, void (*fn)(char *,  
char *, uint16, uint16, uint16, uint, uint, uint, char *));
+int cli_NetSessionGetInfo(struct cli_state *cli, const char  
*workstation, void (*fn)(const char *, const char *, uint16, uint16,  
uint16, uint, uint, uint, const char *));
+int cli_NetSessionDel(struct cli_state *cli, const char *workstation);
+int cli_NetConnectionEnum(struct cli_state *cli, const char  
*qualifier, void (*fn)(uint16 conid, uint16 contype, uint16 numopens,  
uint16 numusers, uint32 contime, const char *username, const char  
*netname));
+
+/* The following definitions come from libsmb/clireadwrite.c  */
+
+ssize_t cli_read(struct cli_state *cli, int fnum, char *buf, off_t  
offset, size_t size);
+ssize_t cli_readraw(struct cli_state *cli, int fnum, char *buf,  
off_t offset, size_t size);
+ssize_t cli_write(struct cli_state *cli,
+    	         int fnum, uint16 write_mode,
+		 const char *buf, off_t offset, size_t size);
+ssize_t cli_smbwrite(struct cli_state *cli,
+		     int fnum, char *buf, off_t offset, size_t size1);
+
+/* The following definitions come from libsmb/clisecdesc.c  */
+
+SEC_DESC *cli_query_secdesc(struct cli_state *cli, int fnum,
+			    TALLOC_CTX *mem_ctx);
+BOOL cli_set_secdesc(struct cli_state *cli, int fnum, SEC_DESC *sd);
+
+/* The following definitions come from libsmb/clispnego.c  */
+
+DATA_BLOB spnego_gen_negTokenInit(char guid[16],
+				  const char *OIDs[],
+				  const char *principal);
+DATA_BLOB gen_negTokenInit(const char *OID, DATA_BLOB blob);
+BOOL spnego_parse_negTokenInit(DATA_BLOB blob,
+			       char *OIDs[ASN1_MAX_OIDS],
+			       char **principal);
+DATA_BLOB gen_negTokenTarg(const char *OIDs[], DATA_BLOB blob);
+BOOL parse_negTokenTarg(DATA_BLOB blob, char *OIDs[ASN1_MAX_OIDS],  
DATA_BLOB *secblob);
+DATA_BLOB spnego_gen_krb5_wrap(const DATA_BLOB ticket, const uint8  
tok_id[2]);
+BOOL spnego_parse_krb5_wrap(DATA_BLOB blob, DATA_BLOB *ticket, uint8  
tok_id[2]);
+int spnego_gen_negTokenTarg(const char *principal, int time_offset,
+			    DATA_BLOB *targ,
+			    DATA_BLOB *session_key_krb5, uint32 extra_ap_opts,
+			    time_t *expire_time);
+BOOL spnego_parse_challenge(const DATA_BLOB blob,
+			    DATA_BLOB *chal1, DATA_BLOB *chal2);
+DATA_BLOB spnego_gen_auth(DATA_BLOB blob);
+BOOL spnego_parse_auth(DATA_BLOB blob, DATA_BLOB *auth);
+DATA_BLOB spnego_gen_auth_response(DATA_BLOB *reply, NTSTATUS  
nt_status,
+				   const char *mechOID);
+BOOL spnego_parse_auth_response(DATA_BLOB blob, NTSTATUS nt_status,
+				const char *mechOID,
+				DATA_BLOB *auth);
+
+/* The following definitions come from libsmb/clistr.c  */
+
+size_t clistr_push_fn(const char *function, unsigned int line,
+		   struct cli_state *cli, void *dest,
+		   const char *src, int dest_len, int flags);
+size_t clistr_pull_fn(const char *function, unsigned int line,
+		   struct cli_state *cli, char *dest, const void *src,
+		   int dest_len, int src_len,
+		   int flags);
+size_t clistr_align_out(struct cli_state *cli, const void *p, int  
flags);
+size_t clistr_align_in(struct cli_state *cli, const void *p, int  
flags);
+
+/* The following definitions come from libsmb/clitrans.c  */
+
+BOOL cli_send_trans(struct cli_state *cli, int trans,
+		    const char *pipe_name,
+		    int fid, int flags,
+		    uint16 *setup, unsigned int lsetup, unsigned int msetup,
+		    const char *param, unsigned int lparam, unsigned int mparam,
+		    const char *data, unsigned int ldata, unsigned int mdata);
+BOOL cli_receive_trans(struct cli_state *cli,int trans,
+                              char **param, unsigned int *param_len,
+                              char **data, unsigned int *data_len);
+BOOL cli_send_nt_trans(struct cli_state *cli,
+		       int function,
+		       int flags,
+		       uint16 *setup, unsigned int lsetup, unsigned int msetup,
+		       char *param, unsigned int lparam, unsigned int mparam,
+		       char *data, unsigned int ldata, unsigned int mdata);
+BOOL cli_receive_nt_trans(struct cli_state *cli,
+			  char **param, unsigned int *param_len,
+			  char **data, unsigned int *data_len);
+
+/* The following definitions come from libsmb/conncache.c  */
+
+NTSTATUS check_negative_conn_cache_timeout( const char *domain,  
const char *server, unsigned int failed_cache_timeout );
+NTSTATUS check_negative_conn_cache( const char *domain, const char  
*server);
+void add_failed_connection_entry(const char *domain, const char  
*server, NTSTATUS result) ;
+void flush_negative_conn_cache( void );
+void flush_negative_conn_cache_for_domain(const char *domain);
+
+/* The following definitions come from libsmb/credentials.c  */
+
+char *credstr(const unsigned char *cred);
+void creds_server_init(uint32 neg_flags,
+			struct dcinfo *dc,
+			DOM_CHAL *clnt_chal,
+			DOM_CHAL *srv_chal,
+			const unsigned char mach_pw[16],
+			DOM_CHAL *init_chal_out);
+BOOL creds_server_check(const struct dcinfo *dc, const DOM_CHAL  
*rcv_cli_chal_in);
+BOOL creds_server_step(struct dcinfo *dc, const DOM_CRED  
*received_cred, DOM_CRED *cred_out);
+void creds_client_init(uint32 neg_flags,
+			struct dcinfo *dc,
+			DOM_CHAL *clnt_chal,
+			DOM_CHAL *srv_chal,
+			const unsigned char mach_pw[16],
+			DOM_CHAL *init_chal_out);
+BOOL creds_client_check(const struct dcinfo *dc, const DOM_CHAL  
*rcv_srv_chal_in);
+void creds_client_step(struct dcinfo *dc, DOM_CRED *next_cred_out);
+
+/* The following definitions come from libsmb/dcerpc_err.c  */
+
+const char *dcerpc_errstr(uint32 fault_code);
+
+/* The following definitions come from libsmb/doserr.c  */
+
+const char *dos_errstr(WERROR werror);
+
+/* The following definitions come from libsmb/errormap.c  */
+
+NTSTATUS dos_to_ntstatus(uint8 eclass, uint32 ecode);
+void ntstatus_to_dos(NTSTATUS ntstatus, uint8 *eclass, uint32 *ecode);
+NTSTATUS werror_to_ntstatus(WERROR error);
+WERROR ntstatus_to_werror(NTSTATUS error);
+NTSTATUS map_nt_error_from_gss(uint32 gss_maj, uint32 minor);
+
+/* The following definitions come from libsmb/namecache.c  */
+
+BOOL namecache_enable(void);
+BOOL namecache_shutdown(void);
+BOOL namecache_store(const char *name, int name_type,
+                     int num_names, struct ip_service *ip_list);
+BOOL namecache_fetch(const char *name, int name_type, struct  
ip_service **ip_list,
+                     int *num_names);
+BOOL namecache_delete(const char *name, int name_type);
+void namecache_flush(void);
+BOOL namecache_status_store(const char *keyname, int keyname_type,
+		int name_type, struct in_addr keyip,
+		const char *srvname);
+BOOL namecache_status_fetch(const char *keyname, int keyname_type,
+			int name_type, struct in_addr keyip, char *srvname_out);
+
+/* The following definitions come from libsmb/namequery.c  */
+
+BOOL saf_store( const char *domain, const char *servername );
+BOOL saf_delete( const char *domain );
+char *saf_fetch( const char *domain );
+NODE_STATUS_STRUCT *node_status_query(int fd,struct nmb_name *name,
+				      struct in_addr to_ip, int *num_names,
+				      struct node_status_extra *extra);
+BOOL name_status_find(const char *q_name, int q_type, int type,  
struct in_addr to_ip, fstring name);
+int ip_service_compare(struct ip_service *ip1, struct ip_service *ip2);
+struct in_addr *name_query(int fd,const char *name,int name_type,
+			   BOOL bcast,BOOL recurse,
+			   struct in_addr to_ip, int *count, int *flags,
+			   BOOL *timed_out);
+XFILE *startlmhosts(const char *fname);
+BOOL getlmhostsent( XFILE *fp, pstring name, int *name_type, struct  
in_addr *ipaddr);
+void endlmhosts(XFILE *fp);
+BOOL name_resolve_bcast(const char *name, int name_type,
+			struct ip_service **return_iplist, int *return_count);
+BOOL resolve_wins(const char *name, int name_type,
+		  struct ip_service **return_iplist, int *return_count);
+BOOL internal_resolve_name(const char *name, int name_type,
+			   const char *sitename,
+			   struct ip_service **return_iplist,
+			   int *return_count, const char *resolve_order);
+BOOL resolve_name(const char *name, struct in_addr *return_ip, int  
name_type);
+BOOL find_master_ip(const char *group, struct in_addr *master_ip);
+BOOL get_pdc_ip(const char *domain, struct in_addr *ip);
+NTSTATUS get_sorted_dc_list( const char *domain, const char  
*sitename, struct ip_service **ip_list, int *count, BOOL ads_only );
+NTSTATUS get_kdc_list( const char *realm, const char *sitename,  
struct ip_service **ip_list, int *count);
+
+/* The following definitions come from libsmb/namequery_dc.c  */
+
+BOOL get_dc_name(const char *domain, const char *realm, fstring  
srv_name, struct in_addr *ip_out);
+
+/* The following definitions come from libsmb/nmblib.c  */
+
+void debug_nmb_packet(struct packet_struct *p);
+void put_name(char *dest, const char *name, int pad, unsigned int  
name_type);
+char *nmb_namestr(const struct nmb_name *n);
+struct packet_struct *copy_packet(struct packet_struct *packet);
+void free_packet(struct packet_struct *packet);
+struct packet_struct *parse_packet(char *buf,int length,
+				   enum packet_type packet_type);
+struct packet_struct *read_packet(int fd,enum packet_type packet_type);
+void make_nmb_name( struct nmb_name *n, const char *name, int type);
+BOOL nmb_name_equal(struct nmb_name *n1, struct nmb_name *n2);
+int build_packet(char *buf, struct packet_struct *p);
+BOOL send_packet(struct packet_struct *p);
+struct packet_struct *receive_packet(int fd,enum packet_type  
type,int t);
+struct packet_struct *receive_nmb_packet(int fd, int t, int trn_id);
+struct packet_struct *receive_dgram_packet(int fd, int t, const char  
*mailslot_name);
+BOOL match_mailslot_name(struct packet_struct *p, const char  
*mailslot_name);
+int matching_quad_bits(unsigned char *p1, unsigned char *p2);
+void sort_query_replies(char *data, int n, struct in_addr ip);
+char *dns_to_netbios_name(const char *dns_name);
+int name_mangle( char *In, char *Out, char name_type );
+int name_extract(char *buf,int ofs, fstring name);
+int name_len(char *s1);
+
+/* The following definitions come from libsmb/nterr.c  */
+
+const char *nt_errstr(NTSTATUS nt_code);
+const char *get_friendly_nt_error_msg(NTSTATUS nt_code);
+const char *get_nt_error_c_code(NTSTATUS nt_code);
+NTSTATUS nt_status_string_to_code(char *nt_status_str);
+NTSTATUS nt_status_squash(NTSTATUS nt_status);
+
+/* The following definitions come from libsmb/ntlm_check.c  */
+
+NTSTATUS ntlm_password_check(TALLOC_CTX *mem_ctx,
+			     const DATA_BLOB *challenge,
+			     const DATA_BLOB *lm_response,
+			     const DATA_BLOB *nt_response,
+			     const DATA_BLOB *lm_interactive_pwd,
+			     const DATA_BLOB *nt_interactive_pwd,
+			     const char *username,
+			     const char *client_username,
+			     const char *client_domain,
+			     const uint8 *lm_pw, const uint8 *nt_pw,
+			     DATA_BLOB *user_sess_key,
+			     DATA_BLOB *lm_sess_key);
+
+/* The following definitions come from libsmb/ntlmssp.c  */
+
+void debug_ntlmssp_flags(uint32 neg_flags);
+NTSTATUS ntlmssp_set_username(NTLMSSP_STATE *ntlmssp_state, const  
char *user) ;
+NTSTATUS ntlmssp_set_hashes(NTLMSSP_STATE *ntlmssp_state,
+		const unsigned char lm_hash[16],
+		const unsigned char nt_hash[16]) ;
+NTSTATUS ntlmssp_set_password(NTLMSSP_STATE *ntlmssp_state, const  
char *password) ;
+NTSTATUS ntlmssp_set_domain(NTLMSSP_STATE *ntlmssp_state, const char  
*domain) ;
+NTSTATUS ntlmssp_set_workstation(NTLMSSP_STATE *ntlmssp_state, const  
char *workstation) ;
+NTSTATUS ntlmssp_store_response(NTLMSSP_STATE *ntlmssp_state,
+				DATA_BLOB response) ;
+void ntlmssp_want_feature_list(NTLMSSP_STATE *ntlmssp_state, char  
*feature_list);
+void ntlmssp_want_feature(NTLMSSP_STATE *ntlmssp_state, uint32  
feature);
+NTSTATUS ntlmssp_update(NTLMSSP_STATE *ntlmssp_state,
+			const DATA_BLOB in, DATA_BLOB *out) ;
+void ntlmssp_end(NTLMSSP_STATE **ntlmssp_state);
+DATA_BLOB ntlmssp_weaken_keys(NTLMSSP_STATE *ntlmssp_state,  
TALLOC_CTX *mem_ctx);
+NTSTATUS ntlmssp_server_start(NTLMSSP_STATE **ntlmssp_state);
+NTSTATUS ntlmssp_client_start(NTLMSSP_STATE **ntlmssp_state);
+
+/* The following definitions come from libsmb/ntlmssp_parse.c  */
+
+BOOL msrpc_gen(DATA_BLOB *blob,
+	       const char *format, ...);
+BOOL msrpc_parse(const DATA_BLOB *blob,
+		 const char *format, ...);
+
+/* The following definitions come from libsmb/ntlmssp_sign.c  */
+
+NTSTATUS ntlmssp_sign_packet(NTLMSSP_STATE *ntlmssp_state,
+				    const uchar *data, size_t length,
+				    const uchar *whole_pdu, size_t pdu_length,
+				    DATA_BLOB *sig) ;
+NTSTATUS ntlmssp_check_packet(NTLMSSP_STATE *ntlmssp_state,
+				const uchar *data, size_t length,
+				const uchar *whole_pdu, size_t pdu_length,
+				const DATA_BLOB *sig) ;
+NTSTATUS ntlmssp_seal_packet(NTLMSSP_STATE *ntlmssp_state,
+			     uchar *data, size_t length,
+			     uchar *whole_pdu, size_t pdu_length,
+			     DATA_BLOB *sig);
+NTSTATUS ntlmssp_unseal_packet(NTLMSSP_STATE *ntlmssp_state,
+				uchar *data, size_t length,
+				uchar *whole_pdu, size_t pdu_length,
+				DATA_BLOB *sig);
+NTSTATUS ntlmssp_sign_init(NTLMSSP_STATE *ntlmssp_state);
+
+/* The following definitions come from libsmb/passchange.c  */
+
+NTSTATUS remote_password_change(const char *remote_machine, const  
char *user_name,
+			    const char *old_passwd, const char *new_passwd,
+			    char *err_str, size_t err_str_len);
+
+/* The following definitions come from libsmb/pwd_cache.c  */
+
+void pwd_set_cleartext(struct pwd_info *pwd, const char *clr);
+void pwd_get_cleartext(struct pwd_info *pwd, fstring clr);
+
+/* The following definitions come from libsmb/samlogon_cache.c  */
+
+BOOL netsamlogon_cache_init(void);
+BOOL netsamlogon_cache_shutdown(void);
+void netsamlogon_clear_cached_user(TDB_CONTEXT *tdb, NET_USER_INFO_3  
*user);
+BOOL netsamlogon_cache_store( const char *username, NET_USER_INFO_3  
*user );
+NET_USER_INFO_3* netsamlogon_cache_get( TALLOC_CTX *mem_ctx, const  
DOM_SID *user_sid);
+BOOL netsamlogon_cache_have(const DOM_SID *user_sid);
+
+/* The following definitions come from libsmb/smb_seal.c  */
+
+NTSTATUS get_enc_ctx_num(char *buf, uint16 *p_enc_ctx_num);
+BOOL common_encryption_on(struct smb_trans_enc_state *es);
+NTSTATUS common_ntlm_decrypt_buffer(NTLMSSP_STATE *ntlmssp_state,  
char *buf);
+NTSTATUS common_ntlm_encrypt_buffer(NTLMSSP_STATE *ntlmssp_state,
+				uint16 enc_ctx_num,
+				char *buf,
+				char **ppbuf_out);
+NTSTATUS common_encrypt_buffer(struct smb_trans_enc_state *es, char  
*buffer, char **buf_out);
+NTSTATUS common_decrypt_buffer(struct smb_trans_enc_state *es, char  
*buf);
+void common_free_encryption_state(struct smb_trans_enc_state **pp_es);
+void common_free_enc_buffer(struct smb_trans_enc_state *es, char *buf);
+BOOL cli_encryption_on(struct cli_state *cli);
+void cli_free_encryption_context(struct cli_state *cli);
+void cli_free_enc_buffer(struct cli_state *cli, char *buf);
+NTSTATUS cli_decrypt_message(struct cli_state *cli);
+NTSTATUS cli_encrypt_message(struct cli_state *cli, char **buf_out);
+
+/* The following definitions come from libsmb/smb_signing.c  */
+
+BOOL cli_simple_set_signing(struct cli_state *cli,
+			    const DATA_BLOB user_session_key,
+			    const DATA_BLOB response);
+BOOL cli_null_set_signing(struct cli_state *cli);
+BOOL cli_temp_set_signing(struct cli_state *cli);
+void cli_free_signing_context(struct cli_state *cli);
+void cli_calculate_sign_mac(struct cli_state *cli);
+BOOL cli_check_sign_mac(struct cli_state *cli) ;
+BOOL client_set_trans_sign_state_on(struct cli_state *cli, uint16 mid);
+BOOL client_set_trans_sign_state_off(struct cli_state *cli, uint16  
mid);
+BOOL client_is_signing_on(struct cli_state *cli);
+BOOL srv_oplock_set_signing(BOOL onoff);
+BOOL srv_check_sign_mac(char *inbuf, BOOL must_be_ok);
+void srv_calculate_sign_mac(char *outbuf);
+void srv_defer_sign_response(uint16 mid);
+void srv_cancel_sign_response(uint16 mid);
+void srv_set_signing_negotiated(void);
+BOOL srv_is_signing_active(void);
+BOOL srv_is_signing_negotiated(void);
+BOOL srv_signing_started(void);
+void srv_set_signing(const DATA_BLOB user_session_key, const  
DATA_BLOB response);
+
+/* The following definitions come from libsmb/smbdes.c  */
+
+void des_crypt56(unsigned char *out, const unsigned char *in, const  
unsigned char *key, int forw);
+void E_P16(const unsigned char *p14,unsigned char *p16);
+void E_P24(const unsigned char *p21, const unsigned char *c8,  
unsigned char *p24);
+void D_P16(const unsigned char *p14, const unsigned char *in,  
unsigned char *out);
+void E_old_pw_hash( unsigned char *p14, const unsigned char *in,  
unsigned char *out);
+void des_crypt128(unsigned char out[8], const unsigned char in[8],  
const unsigned char key[16]);
+void des_crypt64(unsigned char out[8], const unsigned char in[8],  
const unsigned char key[8]);
+void des_crypt112(unsigned char out[8], const unsigned char in[8],  
const unsigned char key[14], int forw);
+void cred_hash3(unsigned char *out, const unsigned char *in, const  
unsigned char *key, int forw);
+void des_crypt112_16(unsigned char out[16], unsigned char in[16],  
const unsigned char key[14], int forw);
+void SamOEMhash( unsigned char *data, const unsigned char key[16],  
size_t len);
+void SamOEMhashBlob( unsigned char *data, size_t len, DATA_BLOB *key);
+void sam_pwd_hash(unsigned int rid, const uchar *in, uchar *out, int  
forw);
+
+/* The following definitions come from libsmb/smbencrypt.c  */
+
+void SMBencrypt_hash(const uchar lm_hash[16], const uchar *c8, uchar  
p24[24]);
+BOOL SMBencrypt(const char *passwd, const uchar *c8, uchar p24[24]);
+void E_md4hash(const char *passwd, uchar p16[16]);
+void E_md5hash(const uchar salt[16], const uchar nthash[16], uchar  
hash_out[16]);
+BOOL E_deshash(const char *passwd, uchar p16[16]);
+void nt_lm_owf_gen(const char *pwd, uchar nt_p16[16], uchar p16[16]);
+BOOL ntv2_owf_gen(const uchar owf[16],
+		  const char *user_in, const char *domain_in,
+		  BOOL upper_case_domain, /* Transform the domain into UPPER case */
+		  uchar kr_buf[16]);
+void SMBOWFencrypt(const uchar passwd[16], const uchar *c8, uchar p24 
[24]);
+void NTLMSSPOWFencrypt(const uchar passwd[8], const uchar  
*ntlmchalresp, uchar p24[24]);
+void SMBNTencrypt_hash(const uchar nt_hash[16], uchar *c8, uchar *p24);
+void SMBNTencrypt(const char *passwd, uchar *c8, uchar *p24);
+void SMBOWFencrypt_ntv2(const uchar kr[16],
+			const DATA_BLOB *srv_chal,
+			const DATA_BLOB *cli_chal,
+			uchar resp_buf[16]);
+void SMBsesskeygen_ntv2(const uchar kr[16],
+			const uchar * nt_resp, uint8 sess_key[16]);
+void SMBsesskeygen_ntv1(const uchar kr[16],
+			const uchar * nt_resp, uint8 sess_key[16]);
+void SMBsesskeygen_lm_sess_key(const uchar lm_hash[16],
+			const uchar lm_resp[24], /* only uses 8 */
+			uint8 sess_key[16]);
+DATA_BLOB NTLMv2_generate_names_blob(const char *hostname,
+				     const char *domain);
+BOOL SMBNTLMv2encrypt_hash(const char *user, const char *domain,  
const uchar nt_hash[16],
+		      const DATA_BLOB *server_chal,
+		      const DATA_BLOB *names_blob,
+		      DATA_BLOB *lm_response, DATA_BLOB *nt_response,
+		      DATA_BLOB *user_session_key) ;
+BOOL SMBNTLMv2encrypt(const char *user, const char *domain, const  
char *password,
+		      const DATA_BLOB *server_chal,
+		      const DATA_BLOB *names_blob,
+		      DATA_BLOB *lm_response, DATA_BLOB *nt_response,
+		      DATA_BLOB *user_session_key) ;
+BOOL encode_pw_buffer(uint8 buffer[516], const char *password, int  
string_flags);
+BOOL decode_pw_buffer(uint8 in_buffer[516], char *new_pwrd,
+		      int new_pwrd_size, uint32 *new_pw_len,
+		      int string_flags);
+void encode_or_decode_arc4_passwd_buffer(unsigned char pw_buf[532],  
const DATA_BLOB *psession_key);
+void sess_crypt_blob(DATA_BLOB *out, const DATA_BLOB *in, const  
DATA_BLOB *session_key, int forward);
+char *decrypt_trustdom_secret(const char *pass, DATA_BLOB *data_in);
+
+/* The following definitions come from libsmb/smberr.c  */
+
+const char *smb_dos_err_name(uint8 e_class, uint16 num);
+const char *get_dos_error_msg(WERROR result);
+const char *smb_dos_err_class(uint8 e_class);
+char *smb_dos_errstr(char *inbuf);
+WERROR map_werror_from_unix(int error);
+
+/* The following definitions come from libsmb/spnego.c  */
+
+ssize_t read_spnego_data(DATA_BLOB data, SPNEGO_DATA *token);
+ssize_t write_spnego_data(DATA_BLOB *blob, SPNEGO_DATA *spnego);
+BOOL free_spnego_data(SPNEGO_DATA *spnego);
+
+/* The following definitions come from libsmb/trustdom_cache.c  */
+
+BOOL trustdom_cache_enable(void);
+BOOL trustdom_cache_shutdown(void);
+BOOL trustdom_cache_store(char* name, char* alt_name, const DOM_SID  
*sid,
+                          time_t timeout);
+BOOL trustdom_cache_fetch(const char* name, DOM_SID* sid);
+uint32 trustdom_cache_fetch_timestamp( void );
+BOOL trustdom_cache_store_timestamp( uint32 t, time_t timeout );
+void trustdom_cache_flush(void);
+void update_trustdom_cache( void );
+
+/* The following definitions come from libsmb/trusts_util.c  */
+
+NTSTATUS trust_pw_change_and_store_it(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				      const char *domain,
+				      unsigned char orig_trust_passwd_hash[16],
+				      uint32 sec_channel_type);
+NTSTATUS trust_pw_find_change_and_store_it(struct rpc_pipe_client *cli,
+					   TALLOC_CTX *mem_ctx,
+					   const char *domain) ;
+BOOL enumerate_domain_trusts( TALLOC_CTX *mem_ctx, const char *domain,
+                                     char ***domain_names, uint32  
*num_domains,
+				     DOM_SID **sids );
+
+/* The following definitions come from libsmb/unexpected.c  */
+
+void unexpected_packet(struct packet_struct *p);
+void clear_unexpected(time_t t);
+struct packet_struct *receive_unexpected(enum packet_type  
packet_type, int id,
+					 const char *mailslot_name);
+
+/* The following definitions come from locking/brlock.c  */
+
+BOOL brl_same_context(const struct lock_context *ctx1,
+			     const struct lock_context *ctx2);
+void brl_init(int read_only);
+void brl_shutdown(int read_only);
+NTSTATUS brl_lock(struct messaging_context *msg_ctx,
+		struct byte_range_lock *br_lck,
+		uint32 smbpid,
+		struct server_id pid,
+		br_off start,
+		br_off size,
+		enum brl_type lock_type,
+		enum brl_flavour lock_flav,
+		BOOL blocking_lock,
+		uint32 *psmbpid);
+BOOL brl_unlock(struct messaging_context *msg_ctx,
+		struct byte_range_lock *br_lck,
+		uint32 smbpid,
+		struct server_id pid,
+		br_off start,
+		br_off size,
+		enum brl_flavour lock_flav);
+BOOL brl_locktest(struct byte_range_lock *br_lck,
+		uint32 smbpid,
+		struct server_id pid,
+		br_off start,
+		br_off size,
+		enum brl_type lock_type,
+		enum brl_flavour lock_flav);
+NTSTATUS brl_lockquery(struct byte_range_lock *br_lck,
+		uint32 *psmbpid,
+		struct server_id pid,
+		br_off *pstart,
+		br_off *psize,
+		enum brl_type *plock_type,
+		enum brl_flavour lock_flav);
+BOOL brl_lock_cancel(struct byte_range_lock *br_lck,
+		uint32 smbpid,
+		struct server_id pid,
+		br_off start,
+		br_off size,
+		enum brl_flavour lock_flav);
+void brl_close_fnum(struct messaging_context *msg_ctx,
+		    struct byte_range_lock *br_lck);
+int brl_forall(void (*fn)(struct file_id id, struct server_id pid,
+			  enum brl_type lock_type,
+			  enum brl_flavour lock_flav,
+			  br_off start, br_off size,
+			  void *private_data),
+	       void *private_data);
+struct byte_range_lock *brl_get_locks(TALLOC_CTX *mem_ctx,
+					files_struct *fsp);
+struct byte_range_lock *brl_get_locks_readonly(TALLOC_CTX *mem_ctx,
+					files_struct *fsp);
+void brl_register_msgs(struct messaging_context *msg_ctx);
+
+/* The following definitions come from locking/locking.c  */
+
+const char *lock_type_name(enum brl_type lock_type);
+const char *lock_flav_name(enum brl_flavour lock_flav);
+BOOL is_locked(files_struct *fsp,
+		uint32 smbpid,
+		SMB_BIG_UINT count,
+		SMB_BIG_UINT offset,
+		enum brl_type lock_type);
+NTSTATUS query_lock(files_struct *fsp,
+			uint32 *psmbpid,
+			SMB_BIG_UINT *pcount,
+			SMB_BIG_UINT *poffset,
+			enum brl_type *plock_type,
+			enum brl_flavour lock_flav);
+struct byte_range_lock *do_lock(struct messaging_context *msg_ctx,
+			files_struct *fsp,
+			uint32 lock_pid,
+			SMB_BIG_UINT count,
+			SMB_BIG_UINT offset,
+			enum brl_type lock_type,
+			enum brl_flavour lock_flav,
+			BOOL blocking_lock,
+			NTSTATUS *perr,
+			uint32 *plock_pid);
+NTSTATUS do_unlock(struct messaging_context *msg_ctx,
+			files_struct *fsp,
+			uint32 lock_pid,
+			SMB_BIG_UINT count,
+			SMB_BIG_UINT offset,
+			enum brl_flavour lock_flav);
+NTSTATUS do_lock_cancel(files_struct *fsp,
+			uint32 lock_pid,
+			SMB_BIG_UINT count,
+			SMB_BIG_UINT offset,
+			enum brl_flavour lock_flav);
+void locking_close_file(struct messaging_context *msg_ctx,
+			files_struct *fsp);
+BOOL locking_init(int read_only);
+BOOL locking_end(void);
+char *share_mode_str(int num, struct share_mode_entry *e);
+struct share_mode_lock *get_share_mode_lock(TALLOC_CTX *mem_ctx,
+					    struct file_id id,
+					    const char *servicepath,
+					    const char *fname);
+struct share_mode_lock *fetch_share_mode_unlocked(TALLOC_CTX *mem_ctx,
+						  struct file_id id,
+						  const char *servicepath,
+						  const char *fname);
+BOOL rename_share_filename(struct messaging_context *msg_ctx,
+			struct share_mode_lock *lck,
+			const char *servicepath,
+			const char *newname);
+BOOL get_delete_on_close_flag(struct file_id id);
+BOOL is_valid_share_mode_entry(const struct share_mode_entry *e);
+BOOL is_deferred_open_entry(const struct share_mode_entry *e);
+BOOL is_unused_share_mode_entry(const struct share_mode_entry *e);
+void set_share_mode(struct share_mode_lock *lck, files_struct *fsp,
+			uid_t uid, uint16 mid, uint16 op_type, BOOL  
initial_delete_on_close_allowed);
+void add_deferred_open(struct share_mode_lock *lck, uint16 mid,
+		       struct timeval request_time,
+		       struct file_id id);
+BOOL del_share_mode(struct share_mode_lock *lck, files_struct *fsp);
+void del_deferred_open_entry(struct share_mode_lock *lck, uint16 mid);
+BOOL remove_share_oplock(struct share_mode_lock *lck, files_struct  
*fsp);
+BOOL downgrade_share_oplock(struct share_mode_lock *lck,  
files_struct *fsp);
+NTSTATUS can_set_delete_on_close(files_struct *fsp, BOOL  
delete_on_close,
+				 uint32 dosmode);
+BOOL can_set_initial_delete_on_close(const struct share_mode_lock  
*lck);
+void set_delete_on_close_token(struct share_mode_lock *lck,  
UNIX_USER_TOKEN *tok);
+void set_delete_on_close_lck(struct share_mode_lock *lck, BOOL  
delete_on_close, UNIX_USER_TOKEN *tok);
+BOOL set_delete_on_close(files_struct *fsp, BOOL delete_on_close,  
UNIX_USER_TOKEN *tok);
+BOOL set_allow_initial_delete_on_close(struct share_mode_lock *lck,  
files_struct *fsp, BOOL delete_on_close);
+int share_mode_forall(void (*fn)(const struct share_mode_entry *,  
const char *,
+				 const char *, void *),
+		      void *private_data);
+
+/* The following definitions come from locking/posix.c  */
+
+BOOL is_posix_locked(files_struct *fsp,
+			SMB_BIG_UINT *pu_offset,
+			SMB_BIG_UINT *pu_count,
+			enum brl_type *plock_type,
+			enum brl_flavour lock_flav);
+BOOL posix_locking_init(int read_only);
+BOOL posix_locking_end(void);
+void reduce_windows_lock_ref_count(files_struct *fsp, unsigned int  
dcount);
+NTSTATUS fd_close_posix(struct connection_struct *conn, files_struct  
*fsp);
+BOOL set_posix_lock_windows_flavour(files_struct *fsp,
+			SMB_BIG_UINT u_offset,
+			SMB_BIG_UINT u_count,
+			enum brl_type lock_type,
+			const struct lock_context *lock_ctx,
+			const struct lock_struct *plocks,
+			int num_locks,
+			int *errno_ret);
+BOOL release_posix_lock_windows_flavour(files_struct *fsp,
+				SMB_BIG_UINT u_offset,
+				SMB_BIG_UINT u_count,
+				enum brl_type deleted_lock_type,
+				const struct lock_context *lock_ctx,
+				const struct lock_struct *plocks,
+				int num_locks);
+BOOL set_posix_lock_posix_flavour(files_struct *fsp,
+			SMB_BIG_UINT u_offset,
+			SMB_BIG_UINT u_count,
+			enum brl_type lock_type,
+			int *errno_ret);
+BOOL release_posix_lock_posix_flavour(files_struct *fsp,
+				SMB_BIG_UINT u_offset,
+				SMB_BIG_UINT u_count,
+				const struct lock_context *lock_ctx,
+				const struct lock_struct *plocks,
+				int num_locks);
+
+/* The following definitions come from modules/vfs_default.c  */
+
+int vfswrap_lstat(vfs_handle_struct *handle,  const char *path,  
SMB_STRUCT_STAT *sbuf);
+ssize_t vfswrap_llistxattr(struct vfs_handle_struct *handle, const  
char *path, char *list, size_t size);
+ssize_t vfswrap_flistxattr(struct vfs_handle_struct *handle, struct  
files_struct *fsp,int fd, char *list, size_t size);
+NTSTATUS vfs_default_init(void);
+
+/* The following definitions come from nmbd/asyncdns.c  */
+
+int asyncdns_fd(void);
+void kill_async_dns_child(void);
+void start_async_dns(void);
+void run_dns_queue(void);
+BOOL queue_dns_query(struct packet_struct *p,struct nmb_name  
*question);
+BOOL queue_dns_query(struct packet_struct *p,struct nmb_name  
*question);
+void kill_async_dns_child(void);
+
+/* The following definitions come from nmbd/nmbd.c  */
+
+struct event_context *nmbd_event_context(void);
+struct messaging_context *nmbd_messaging_context(void);
+
+/* The following definitions come from nmbd/nmbd_become_dmb.c  */
+
+void add_domain_names(time_t t);
+
+/* The following definitions come from nmbd/nmbd_become_lmb.c  */
+
+void insert_permanent_name_into_unicast( struct subnet_record *subrec,
+                                                struct nmb_name  
*nmbname, uint16 nb_type );
+void unbecome_local_master_browser(struct subnet_record *subrec,  
struct work_record *work,
+                                   BOOL force_new_election);
+void become_local_master_browser(struct subnet_record *subrec,  
struct work_record *work);
+void set_workgroup_local_master_browser_name( struct work_record  
*work, const char *newname);
+
+/* The following definitions come from nmbd/nmbd_browserdb.c  */
+
+void update_browser_death_time( struct browse_cache_record *browc );
+struct browse_cache_record *create_browser_in_lmb_cache( const char  
*work_name,
+                                                         const char  
*browser_name,
+                                                         struct  
in_addr ip );
+struct browse_cache_record *find_browser_in_lmb_cache( const char  
*browser_name );
+void expire_lmb_browsers( time_t t );
+
+/* The following definitions come from nmbd/nmbd_browsesync.c  */
+
+void dmb_expire_and_sync_browser_lists(time_t t);
+void announce_and_sync_with_domain_master_browser( struct  
subnet_record *subrec,
+                                                   struct  
work_record *work);
+void collect_all_workgroup_names_from_wins_server(time_t t);
+void sync_all_dmbs(time_t t);
+
+/* The following definitions come from nmbd/nmbd_elections.c  */
+
+void check_master_browser_exists(time_t t);
+void run_elections(time_t t);
+void process_election(struct subnet_record *subrec, struct  
packet_struct *p, char *buf);
+BOOL check_elections(void);
+void nmbd_message_election(struct messaging_context *msg,
+			   void *private_data,
+			   uint32_t msg_type,
+			   struct server_id server_id,
+			   DATA_BLOB *data);
+
+/* The following definitions come from nmbd/nmbd_incomingdgrams.c  */
+
+void tell_become_backup(void);
+void process_host_announce(struct subnet_record *subrec, struct  
packet_struct *p, char *buf);
+void process_workgroup_announce(struct subnet_record *subrec, struct  
packet_struct *p, char *buf);
+void process_local_master_announce(struct subnet_record *subrec,  
struct packet_struct *p, char *buf);
+void process_master_browser_announce(struct subnet_record *subrec,
+                                     struct packet_struct *p,char  
*buf);
+void process_lm_host_announce(struct subnet_record *subrec, struct  
packet_struct *p, char *buf, int len);
+void process_get_backup_list_request(struct subnet_record *subrec,
+                                     struct packet_struct *p,char  
*buf);
+void process_reset_browser(struct subnet_record *subrec,
+                                  struct packet_struct *p,char *buf);
+void process_announce_request(struct subnet_record *subrec, struct  
packet_struct *p, char *buf);
+void process_lm_announce_request(struct subnet_record *subrec,  
struct packet_struct *p, char *buf, int len);
+
+/* The following definitions come from nmbd/nmbd_incomingrequests.c  */
+
+void process_name_release_request(struct subnet_record *subrec,
+                                  struct packet_struct *p);
+void process_name_refresh_request(struct subnet_record *subrec,
+                                  struct packet_struct *p);
+void process_name_registration_request(struct subnet_record *subrec,
+                                       struct packet_struct *p);
+void process_node_status_request(struct subnet_record *subrec,  
struct packet_struct *p);
+void process_name_query_request(struct subnet_record *subrec, struct  
packet_struct *p);
+
+/* The following definitions come from nmbd/nmbd_lmhosts.c  */
+
+void load_lmhosts_file(const char *fname);
+BOOL find_name_in_lmhosts(struct nmb_name *nmbname, struct  
name_record **namerecp);
+
+/* The following definitions come from nmbd/nmbd_logonnames.c  */
+
+void add_logon_names(void);
+
+/* The following definitions come from nmbd/nmbd_mynames.c  */
+
+void register_my_workgroup_one_subnet(struct subnet_record *subrec);
+BOOL register_my_workgroup_and_names(void);
+void release_wins_names(void);
+void refresh_my_names(time_t t);
+
+/* The following definitions come from nmbd/nmbd_namelistdb.c  */
+
+void set_samba_nb_type(void);
+void remove_name_from_namelist(struct subnet_record *subrec,
+				struct name_record *namerec );
+struct name_record *find_name_on_subnet(struct subnet_record *subrec,
+				const struct nmb_name *nmbname,
+				BOOL self_only);
+struct name_record *find_name_for_remote_broadcast_subnet(struct  
nmb_name *nmbname,
+						BOOL self_only);
+void update_name_ttl( struct name_record *namerec, int ttl );
+BOOL add_name_to_subnet( struct subnet_record *subrec,
+			const char *name,
+			int type,
+			uint16 nb_flags,
+			int ttl,
+			enum name_source source,
+			int num_ips,
+			struct in_addr *iplist);
+void standard_success_register(struct subnet_record *subrec,
+                             struct userdata_struct *userdata,
+                             struct nmb_name *nmbname, uint16  
nb_flags, int ttl,
+                             struct in_addr registered_ip);
+void standard_fail_register( struct subnet_record   *subrec,
+                             struct response_record *rrec,
+                             struct nmb_name        *nmbname );
+BOOL find_ip_in_name_record( struct name_record *namerec, struct  
in_addr ip );
+void add_ip_to_name_record( struct name_record *namerec, struct  
in_addr new_ip );
+void remove_ip_from_name_record( struct name_record *namerec,
+                                 struct in_addr      remove_ip );
+void standard_success_release( struct subnet_record   *subrec,
+                               struct userdata_struct *userdata,
+                               struct nmb_name        *nmbname,
+                               struct in_addr          released_ip );
+void expire_names(time_t t);
+void add_samba_names_to_subnet( struct subnet_record *subrec );
+void dump_name_record( struct name_record *namerec, XFILE *fp);
+void dump_all_namelists(void);
+
+/* The following definitions come from nmbd/nmbd_namequery.c  */
+
+BOOL query_name(struct subnet_record *subrec, const char *name, int  
type,
+                   query_name_success_function success_fn,
+                   query_name_fail_function fail_fn,
+                   struct userdata_struct *userdata);
+BOOL query_name_from_wins_server(struct in_addr ip_to,
+                   const char *name, int type,
+                   query_name_success_function success_fn,
+                   query_name_fail_function fail_fn,
+                   struct userdata_struct *userdata);
+
+/* The following definitions come from nmbd/nmbd_nameregister.c  */
+
+void register_name(struct subnet_record *subrec,
+                   const char *name, int type, uint16 nb_flags,
+                   register_name_success_function success_fn,
+                   register_name_fail_function fail_fn,
+                   struct userdata_struct *userdata);
+void wins_refresh_name(struct name_record *namerec);
+
+/* The following definitions come from nmbd/nmbd_namerelease.c  */
+
+void release_name(struct subnet_record *subrec, struct name_record  
*namerec,
+		  release_name_success_function success_fn,
+		  release_name_fail_function fail_fn,
+		  struct userdata_struct *userdata);
+
+/* The following definitions come from nmbd/nmbd_nodestatus.c  */
+
+BOOL node_status(struct subnet_record *subrec, struct nmb_name  
*nmbname,
+                 struct in_addr send_ip,  
node_status_success_function success_fn,
+                 node_status_fail_function fail_fn, struct  
userdata_struct *userdata);
+
+/* The following definitions come from nmbd/nmbd_packets.c  */
+
+uint16 get_nb_flags(char *buf);
+void set_nb_flags(char *buf, uint16 nb_flags);
+struct response_record *queue_register_name( struct subnet_record  
*subrec,
+                          response_function resp_fn,
+                          timeout_response_function timeout_fn,
+                          register_name_success_function success_fn,
+                          register_name_fail_function fail_fn,
+                          struct userdata_struct *userdata,
+                          struct nmb_name *nmbname,
+                          uint16 nb_flags);
+void queue_wins_refresh(struct nmb_name *nmbname,
+			response_function resp_fn,
+			timeout_response_function timeout_fn,
+			uint16 nb_flags,
+			struct in_addr refresh_ip,
+			const char *tag);
+struct response_record *queue_register_multihomed_name( struct  
subnet_record *subrec,
+							response_function resp_fn,
+							timeout_response_function timeout_fn,
+							register_name_success_function success_fn,
+							register_name_fail_function fail_fn,
+							struct userdata_struct *userdata,
+							struct nmb_name *nmbname,
+							uint16 nb_flags,
+							struct in_addr register_ip,
+							struct in_addr wins_ip);
+struct response_record *queue_release_name( struct subnet_record  
*subrec,
+					    response_function resp_fn,
+					    timeout_response_function timeout_fn,
+					    release_name_success_function success_fn,
+					    release_name_fail_function fail_fn,
+					    struct userdata_struct *userdata,
+					    struct nmb_name *nmbname,
+					    uint16 nb_flags,
+					    struct in_addr release_ip,
+					    struct in_addr dest_ip);
+struct response_record *queue_query_name( struct subnet_record *subrec,
+                          response_function resp_fn,
+                          timeout_response_function timeout_fn,
+                          query_name_success_function success_fn,
+                          query_name_fail_function fail_fn,
+                          struct userdata_struct *userdata,
+                          struct nmb_name *nmbname);
+struct response_record *queue_query_name_from_wins_server( struct  
in_addr to_ip,
+                          response_function resp_fn,
+                          timeout_response_function timeout_fn,
+                          query_name_success_function success_fn,
+                          query_name_fail_function fail_fn,
+                          struct userdata_struct *userdata,
+                          struct nmb_name *nmbname);
+struct response_record *queue_node_status( struct subnet_record  
*subrec,
+                          response_function resp_fn,
+                          timeout_response_function timeout_fn,
+                          node_status_success_function success_fn,
+                          node_status_fail_function fail_fn,
+                          struct userdata_struct *userdata,
+                          struct nmb_name *nmbname,
+                          struct in_addr send_ip);
+void reply_netbios_packet(struct packet_struct *orig_packet,
+                          int rcode, enum netbios_reply_type_code  
rcv_code, int opcode,
+                          int ttl, char *data,int len);
+void run_packet_queue(void);
+void retransmit_or_expire_response_records(time_t t);
+BOOL listen_for_packets(BOOL run_election);
+BOOL send_mailslot(BOOL unique, const char *mailslot,char *buf,  
size_t len,
+                   const char *srcname, int src_type,
+                   const char *dstname, int dest_type,
+                   struct in_addr dest_ip,struct in_addr src_ip,
+		   int dest_port);
+
+/* The following definitions come from nmbd/nmbd_processlogon.c  */
+
+void process_logon_packet(struct packet_struct *p, char *buf,int len,
+                          const char *mailslot);
+
+/* The following definitions come from nmbd/ 
nmbd_responserecordsdb.c  */
+
+void remove_response_record(struct subnet_record *subrec,
+				struct response_record *rrec);
+struct response_record *make_response_record( struct subnet_record  
*subrec,
+					      struct packet_struct *p,
+					      response_function resp_fn,
+					      timeout_response_function timeout_fn,
+					      success_function success_fn,
+					      fail_function fail_fn,
+					      struct userdata_struct *userdata);
+struct response_record *find_response_record(struct subnet_record  
**ppsubrec,
+				uint16 id);
+BOOL is_refresh_already_queued(struct subnet_record *subrec, struct  
name_record *namerec);
+
+/* The following definitions come from nmbd/nmbd_sendannounce.c  */
+
+void send_browser_reset(int reset_type, const char *to_name, int  
to_type, struct in_addr to_ip);
+void broadcast_announce_request(struct subnet_record *subrec, struct  
work_record *work);
+void announce_my_server_names(time_t t);
+void announce_my_lm_server_names(time_t t);
+void reset_announce_timer(void);
+void announce_myself_to_domain_master_browser(time_t t);
+void announce_my_servers_removed(void);
+void announce_remote(time_t t);
+void browse_sync_remote(time_t t);
+
+/* The following definitions come from nmbd/nmbd_serverlistdb.c  */
+
+void remove_all_servers(struct work_record *work);
+struct server_record *find_server_in_workgroup(struct work_record  
*work, const char *name);
+void remove_server_from_workgroup(struct work_record *work, struct  
server_record *servrec);
+struct server_record *create_server_on_workgroup(struct work_record  
*work,
+                                                 const char  
*name,int servertype,
+                                                 int ttl, const char  
*comment);
+void update_server_ttl(struct server_record *servrec, int ttl);
+void expire_servers(struct work_record *work, time_t t);
+void write_browse_list_entry(XFILE *fp, const char *name, uint32  
rec_type,
+		const char *local_master_browser_name, const char *description);
+void write_browse_list(time_t t, BOOL force_write);
+
+/* The following definitions come from nmbd/nmbd_subnetdb.c  */
+
+void close_subnet(struct subnet_record *subrec);
+struct subnet_record *make_normal_subnet(struct interface *iface);
+BOOL create_subnets(void);
+BOOL we_are_a_wins_client(void);
+struct subnet_record *get_next_subnet_maybe_unicast(struct  
subnet_record *subrec);
+struct subnet_record *get_next_subnet_maybe_unicast_or_wins_server 
(struct subnet_record *subrec);
+
+/* The following definitions come from nmbd/nmbd_synclists.c  */
+
+void sync_browse_lists(struct work_record *work,
+		       char *name, int nm_type,
+		       struct in_addr ip, BOOL local, BOOL servers);
+void sync_check_completion(void);
+
+/* The following definitions come from nmbd/nmbd_winsproxy.c  */
+
+void make_wins_proxy_name_query_request( struct subnet_record *subrec,
+                                         struct packet_struct  
*incoming_packet,
+                                         struct nmb_name  
*question_name);
+
+/* The following definitions come from nmbd/nmbd_winsserver.c  */
+
+struct name_record *find_name_on_wins_subnet(const struct nmb_name  
*nmbname, BOOL self_only);
+BOOL wins_store_changed_namerec(const struct name_record *namerec);
+BOOL add_name_to_wins_subnet(const struct name_record *namerec);
+BOOL remove_name_from_wins_namelist(struct name_record *namerec);
+void dump_wins_subnet_namelist(XFILE *fp);
+BOOL packet_is_for_wins_server(struct packet_struct *packet);
+BOOL initialise_wins(void);
+void wins_process_name_refresh_request( struct subnet_record *subrec,
+                                        struct packet_struct *p );
+void wins_process_name_registration_request(struct subnet_record  
*subrec,
+                                            struct packet_struct *p);
+void wins_process_multihomed_name_registration_request( struct  
subnet_record *subrec,
+                                                        struct  
packet_struct *p);
+void fetch_all_active_wins_1b_names(void);
+void send_wins_name_query_response(int rcode, struct packet_struct *p,
+                                          struct name_record *namerec);
+void wins_process_name_query_request(struct subnet_record *subrec,
+                                     struct packet_struct *p);
+void wins_process_name_release_request(struct subnet_record *subrec,
+                                       struct packet_struct *p);
+void initiate_wins_processing(time_t t);
+void wins_write_name_record(struct name_record *namerec, XFILE *fp);
+void wins_write_database(time_t t, BOOL background);
+void nmbd_wins_new_entry(struct messaging_context *msg,
+                                       void *private_data,
+                                       uint32_t msg_type,
+                                       struct server_id server_id,
+                                       DATA_BLOB *data);
+
+/* The following definitions come from nmbd/nmbd_workgroupdb.c  */
+
+struct work_record *find_workgroup_on_subnet(struct subnet_record  
*subrec,
+                                             const char *name);
+struct work_record *create_workgroup_on_subnet(struct subnet_record  
*subrec,
+                                               const char *name, int  
ttl);
+void update_workgroup_ttl(struct work_record *work, int ttl);
+void initiate_myworkgroup_startup(struct subnet_record *subrec,  
struct work_record *work);
+void dump_workgroups(BOOL force_write);
+void expire_workgroups_and_servers(time_t t);
+
+/* The following definitions come from nsswitch/idmap.c  */
+
+BOOL idmap_is_offline(void);
+NTSTATUS smb_register_idmap(int version, const char *name, struct  
idmap_methods *methods);
+NTSTATUS smb_register_idmap_alloc(int version, const char *name,  
struct idmap_alloc_methods *methods);
+NTSTATUS idmap_close(void);
+NTSTATUS idmap_init_cache(void);
+NTSTATUS idmap_init(void);
+NTSTATUS idmap_allocate_uid(struct unixid *id);
+NTSTATUS idmap_allocate_gid(struct unixid *id);
+NTSTATUS idmap_set_uid_hwm(struct unixid *id);
+NTSTATUS idmap_set_gid_hwm(struct unixid *id);
+NTSTATUS idmap_unixids_to_sids(struct id_map **ids);
+NTSTATUS idmap_sids_to_unixids(struct id_map **ids);
+NTSTATUS idmap_set_mapping(const struct id_map *id);
+void idmap_dump_maps(char *logfile);
+char *idmap_fetch_secret(const char *backend, bool alloc,
+			       const char *domain, const char *identity);
+
+/* The following definitions come from nsswitch/idmap_cache.c  */
+
+struct idmap_cache_ctx *idmap_cache_init(TALLOC_CTX *memctx);
+void idmap_cache_shutdown(struct idmap_cache_ctx *cache);
+NTSTATUS idmap_cache_build_sidkey(TALLOC_CTX *ctx, char **sidkey,  
const struct id_map *id);
+NTSTATUS idmap_cache_build_idkey(TALLOC_CTX *ctx, char **idkey,  
const struct id_map *id);
+NTSTATUS idmap_cache_set(struct idmap_cache_ctx *cache, const struct  
id_map *id);
+NTSTATUS idmap_cache_set_negative_sid(struct idmap_cache_ctx *cache,  
const struct id_map *id);
+NTSTATUS idmap_cache_set_negative_id(struct idmap_cache_ctx *cache,  
const struct id_map *id);
+NTSTATUS idmap_cache_fill_map(struct id_map *id, const char *value);
+BOOL idmap_cache_is_negative(const char *val);
+NTSTATUS idmap_cache_map_sid(struct idmap_cache_ctx *cache, struct  
id_map *id);
+NTSTATUS idmap_cache_map_id(struct idmap_cache_ctx *cache, struct  
id_map *id);
+
+/* The following definitions come from nsswitch/idmap_ldap.c  */
+
+NTSTATUS idmap_alloc_ldap_init(void);
+NTSTATUS idmap_ldap_init(void);
+
+/* The following definitions come from nsswitch/idmap_nss.c  */
+
+NTSTATUS idmap_nss_init(void);
+
+/* The following definitions come from nsswitch/idmap_passdb.c  */
+
+NTSTATUS idmap_passdb_init(void);
+
+/* The following definitions come from nsswitch/idmap_tdb.c  */
+
+BOOL idmap_tdb_tdb_close(TDB_CONTEXT *tdbctx);
+NTSTATUS idmap_alloc_tdb_init(void);
+NTSTATUS idmap_tdb_init(void);
+
+/* The following definitions come from nsswitch/idmap_util.c  */
+
+NTSTATUS idmap_uid_to_sid(DOM_SID *sid, uid_t uid);
+NTSTATUS idmap_gid_to_sid(DOM_SID *sid, gid_t gid);
+NTSTATUS idmap_sid_to_uid(DOM_SID *sid, uid_t *uid);
+NTSTATUS idmap_sid_to_gid(DOM_SID *sid, gid_t *gid);
+
+/* The following definitions come from nsswitch/nss_info.c  */
+
+
+/* The following definitions come from nsswitch/nss_info_template.c  */
+
+NTSTATUS nss_info_template_init( void );
+
+/* The following definitions come from nsswitch/wb_client.c  */
+
+NSS_STATUS winbindd_request_response(int req_type,
+                                 struct winbindd_request *request,
+                                 struct winbindd_response *response);
+
+/* Call winbindd to convert a name to a sid */
+
+BOOL winbind_lookup_name(const char *dom_name, const char *name,  
DOM_SID *sid,
+                         enum lsa_SidType *name_type);
+BOOL winbind_lookup_sid(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+			const char **domain, const char **name,
+                        enum lsa_SidType *name_type);
+BOOL winbind_lookup_rids(TALLOC_CTX *mem_ctx,
+			 const DOM_SID *domain_sid,
+			 int num_rids, uint32 *rids,
+			 const char **domain_name,
+			 const char ***names, enum lsa_SidType **types);
+BOOL winbind_sid_to_uid(uid_t *puid, const DOM_SID *sid);
+BOOL winbind_uid_to_sid(DOM_SID *sid, uid_t uid);
+BOOL winbind_sid_to_gid(gid_t *pgid, const DOM_SID *sid);
+BOOL winbind_gid_to_sid(DOM_SID *sid, gid_t gid);
+BOOL winbind_sids_to_unixids(struct id_map *ids, int num_ids);
+BOOL winbind_idmap_dump_maps(TALLOC_CTX *memctx, const char *file);
+BOOL winbind_allocate_uid(uid_t *uid);
+BOOL winbind_allocate_gid(gid_t *gid);
+BOOL winbind_set_mapping(const struct id_map *map);
+BOOL winbind_set_uid_hwm(unsigned long id);
+BOOL winbind_set_gid_hwm(unsigned long id);
+BOOL winbind_ping( void );
+NSS_STATUS wb_is_trusted_domain(const char *domain);
+
+/* The following definitions come from nsswitch/wb_common.c  */
+
+void free_response(struct winbindd_response *response);
+void init_request(struct winbindd_request *request, int request_type);
+void close_sock(void);
+int write_sock(void *buffer, int count, int recursing, int need_priv);
+int read_reply(struct winbindd_response *response);
+BOOL winbind_env_set( void );
+NSS_STATUS winbindd_send_request(int req_type, int need_priv,
+				 struct winbindd_request *request);
+NSS_STATUS winbindd_get_response(struct winbindd_response *response);
+NSS_STATUS winbindd_request_response(int req_type,
+			    struct winbindd_request *request,
+			    struct winbindd_response *response);
+NSS_STATUS winbindd_priv_request_response(int req_type,
+					  struct winbindd_request *request,
+					  struct winbindd_response *response);
+BOOL winbind_off( void );
+BOOL winbind_on( void );
+
+/* The following definitions come from param/loadparm.c  */
+
+void lp_TALLOC_FREE(void);
+TALLOC_CTX *tmp_talloc_ctx(void);
+char *lp_smb_ports(void);
+char *lp_dos_charset(void);
+char *lp_unix_charset(void);
+char *lp_display_charset(void);
+char *lp_logfile(void);
+char *lp_configfile(void);
+char *lp_smb_passwd_file(void);
+char *lp_private_dir(void);
+char *lp_serverstring(void);
+int lp_printcap_cache_time(void);
+char *lp_addport_cmd(void);
+char *lp_enumports_cmd(void);
+char *lp_addprinter_cmd(void);
+char *lp_deleteprinter_cmd(void);
+char *lp_os2_driver_map(void);
+char *lp_lockdir(void);
+char *lp_piddir(void);
+char *lp_mangling_method(void);
+int lp_mangle_prefix(void);
+char *lp_utmpdir(void);
+char *lp_wtmpdir(void);
+BOOL lp_utmp(void);
+char *lp_rootdir(void);
+char *lp_defaultservice(void);
+char *lp_msg_command(void);
+char *lp_get_quota_command(void);
+char *lp_set_quota_command(void);
+char *lp_auto_services(void);
+char *lp_passwd_program(void);
+char *lp_passwd_chat(void);
+char *lp_passwordserver(void);
+char *lp_name_resolve_order(void);
+char *lp_realm(void);
+const char *lp_afs_username_map(void);
+int lp_afs_token_lifetime(void);
+char *lp_log_nt_token_command(void);
+char *lp_username_map(void);
+const char *lp_logon_script(void);
+const char *lp_logon_path(void);
+const char *lp_logon_drive(void);
+const char *lp_logon_home(void);
+char *lp_remote_announce(void);
+char *lp_remote_browse_sync(void);
+const char **lp_wins_server_list(void);
+const char **lp_interfaces(void);
+char *lp_socket_address(void);
+char *lp_nis_home_map_name(void);
+const char **lp_netbios_aliases(void);
+const char *lp_passdb_backend(void);
+const char **lp_preload_modules(void);
+char *lp_panic_action(void);
+char *lp_adduser_script(void);
+char *lp_renameuser_script(void);
+char *lp_deluser_script(void);
+const char *lp_guestaccount(void);
+char *lp_addgroup_script(void);
+char *lp_delgroup_script(void);
+char *lp_addusertogroup_script(void);
+char *lp_deluserfromgroup_script(void);
+char *lp_setprimarygroup_script(void);
+char *lp_addmachine_script(void);
+char *lp_shutdown_script(void);
+char *lp_abort_shutdown_script(void);
+char *lp_username_map_script(void);
+char *lp_check_password_script(void);
+char *lp_wins_hook(void);
+const char *lp_template_homedir(void);
+const char *lp_template_shell(void);
+const char *lp_winbind_separator(void);
+int lp_acl_compatibility(void);
+BOOL lp_winbind_enum_users(void);
+BOOL lp_winbind_enum_groups(void);
+BOOL lp_winbind_use_default_domain(void);
+BOOL lp_winbind_trusted_domains_only(void);
+BOOL lp_winbind_nested_groups(void);
+BOOL lp_winbind_refresh_tickets(void);
+BOOL lp_winbind_offline_logon(void);
+BOOL lp_winbind_normalize_names(void);
+const char **lp_idmap_domains(void);
+const char **lp_idmap_backend(void);
+char *lp_idmap_alloc_backend(void);
+int lp_idmap_cache_time(void);
+int lp_idmap_negative_cache_time(void);
+int lp_keepalive(void);
+BOOL lp_passdb_expand_explicit(void);
+char *lp_ldap_suffix(void);
+char *lp_ldap_admin_dn(void);
+int lp_ldap_ssl(void);
+int lp_ldap_passwd_sync(void);
+BOOL lp_ldap_delete_dn(void);
+int lp_ldap_replication_sleep(void);
+int lp_ldap_timeout(void);
+int lp_ldap_page_size(void);
+char *lp_add_share_cmd(void);
+char *lp_change_share_cmd(void);
+char *lp_delete_share_cmd(void);
+char *lp_usershare_path(void);
+const char **lp_usershare_prefix_allow_list(void);
+const char **lp_usershare_prefix_deny_list(void);
+const char **lp_eventlog_list(void);
+BOOL lp_registry_shares(void);
+BOOL lp_usershare_allow_guests(void);
+BOOL lp_usershare_owner_only(void);
+BOOL lp_disable_netbios(void);
+BOOL lp_reset_on_zero_vc(void);
+BOOL lp_ms_add_printer_wizard(void);
+BOOL lp_dns_proxy(void);
+BOOL lp_wins_support(void);
+BOOL lp_we_are_a_wins_server(void);
+BOOL lp_wins_proxy(void);
+BOOL lp_local_master(void);
+BOOL lp_domain_logons(void);
+BOOL lp_load_printers(void);
+BOOL lp_readbmpx(void);
+BOOL lp_readraw(void);
+BOOL lp_large_readwrite(void);
+BOOL lp_writeraw(void);
+BOOL lp_null_passwords(void);
+BOOL lp_obey_pam_restrictions(void);
+BOOL lp_encrypted_passwords(void);
+BOOL lp_update_encrypted(void);
+int lp_client_schannel(void);
+int lp_server_schannel(void);
+BOOL lp_syslog_only(void);
+BOOL lp_timestamp_logs(void);
+BOOL lp_debug_prefix_timestamp(void);
+BOOL lp_debug_hires_timestamp(void);
+BOOL lp_debug_pid(void);
+BOOL lp_debug_uid(void);
+BOOL lp_enable_core_files(void);
+BOOL lp_browse_list(void);
+BOOL lp_nis_home_map(void);
+BOOL lp_bind_interfaces_only(void);
+BOOL lp_pam_password_change(void);
+BOOL lp_unix_password_sync(void);
+BOOL lp_passwd_chat_debug(void);
+int lp_passwd_chat_timeout(void);
+BOOL lp_nt_pipe_support(void);
+BOOL lp_nt_status_support(void);
+BOOL lp_stat_cache(void);
+int lp_max_stat_cache_size(void);
+BOOL lp_allow_trusted_domains(void);
+int lp_restrict_anonymous(void);
+BOOL lp_lanman_auth(void);
+BOOL lp_ntlm_auth(void);
+BOOL lp_client_plaintext_auth(void);
+BOOL lp_client_lanman_auth(void);
+BOOL lp_client_ntlmv2_auth(void);
+BOOL lp_host_msdfs(void);
+BOOL lp_kernel_oplocks(void);
+BOOL lp_enhanced_browsing(void);
+BOOL lp_use_mmap(void);
+BOOL lp_unix_extensions(void);
+BOOL lp_use_spnego(void);
+BOOL lp_client_use_spnego(void);
+BOOL lp_hostname_lookups(void);
+BOOL lp_change_notify(const struct share_params *p );
+BOOL lp_kernel_change_notify(const struct share_params *p );
+BOOL lp_use_kerberos_keytab(void);
+BOOL lp_defer_sharing_violations(void);
+BOOL lp_enable_privileges(void);
+BOOL lp_enable_asu_support(void);
+int lp_os_level(void);
+int lp_max_ttl(void);
+int lp_max_wins_ttl(void);
+int lp_min_wins_ttl(void);
+int lp_max_log_size(void);
+int lp_max_open_files(void);
+int lp_open_files_db_hash_size(void);
+int lp_maxxmit(void);
+int lp_maxmux(void);
+int lp_passwordlevel(void);
+int lp_usernamelevel(void);
+int lp_deadtime(void);
+int lp_maxprotocol(void);
+int lp_minprotocol(void);
+int lp_security(void);
+const char **lp_auth_methods(void);
+BOOL lp_paranoid_server_security(void);
+int lp_maxdisksize(void);
+int lp_lpqcachetime(void);
+int lp_max_smbd_processes(void);
+int _lp_disable_spoolss(void);
+int lp_syslog(void);
+int lp_lm_announce(void);
+int lp_lm_interval(void);
+int lp_machine_password_timeout(void);
+int lp_map_to_guest(void);
+int lp_oplock_break_wait_time(void);
+int lp_lock_spin_time(void);
+int lp_usershare_max_shares(void);
+char *lp_preexec(int );
+char *lp_postexec(int );
+char *lp_rootpreexec(int );
+char *lp_rootpostexec(int );
+char *lp_servicename(int );
+const char *lp_const_servicename(int );
+char *lp_pathname(int );
+char *lp_dontdescend(int );
+char *lp_username(int );
+const char **lp_invalid_users(int );
+const char **lp_valid_users(int );
+const char **lp_admin_users(int );
+const char **lp_svcctl_list(void);
+char *lp_cups_options(int );
+char *lp_cups_server(void);
+char *lp_iprint_server(void);
+char *lp_printcommand(int );
+char *lp_lpqcommand(int );
+char *lp_lprmcommand(int );
+char *lp_lppausecommand(int );
+char *lp_lpresumecommand(int );
+char *lp_queuepausecommand(int );
+char *lp_queueresumecommand(int );
+const char *lp_printjob_username(int );
+const char **lp_hostsallow(int );
+const char **lp_hostsdeny(int );
+char *lp_magicscript(int );
+char *lp_magicoutput(int );
+char *lp_comment(int );
+char *lp_force_user(int );
+char *lp_force_group(int );
+const char **lp_readlist(int );
+const char **lp_writelist(int );
+const char **lp_printer_admin(int );
+char *lp_fstype(int );
+const char **lp_vfs_objects(int );
+char *lp_msdfs_proxy(int );
+char *lp_mangled_map(const struct share_params *p );
+char *lp_veto_files(int );
+char *lp_hide_files(int );
+char *lp_veto_oplocks(int );
+BOOL lp_msdfs_root(int );
+char *lp_dfree_command(int );
+BOOL lp_autoloaded(int );
+BOOL lp_preexec_close(int );
+BOOL lp_rootpreexec_close(int );
+int lp_casesensitive(int );
+BOOL lp_preservecase(int );
+BOOL lp_shortpreservecase(int );
+BOOL lp_hide_dot_files(int );
+BOOL lp_hide_special_files(int );
+BOOL lp_hideunreadable(int );
+BOOL lp_hideunwriteable_files(int );
+BOOL lp_browseable(int );
+BOOL lp_readonly(int );
+BOOL lp_no_set_dir(int );
+BOOL lp_guest_ok(int );
+BOOL lp_guest_only(int );
+BOOL lp_print_ok(int );
+BOOL lp_map_hidden(int );
+BOOL lp_map_archive(int );
+BOOL lp_store_dos_attributes(int );
+BOOL lp_dmapi_support(int );
+BOOL lp_locking(const struct share_params *p );
+int lp_strict_locking(const struct share_params *p );
+BOOL lp_posix_locking(const struct share_params *p );
+BOOL lp_share_modes(int );
+BOOL lp_oplocks(int );
+BOOL lp_level2_oplocks(int );
+BOOL lp_onlyuser(int );
+BOOL lp_manglednames(const struct share_params *p );
+BOOL lp_widelinks(int );
+BOOL lp_symlinks(int );
+BOOL lp_syncalways(int );
+BOOL lp_strict_allocate(int );
+BOOL lp_strict_sync(int );
+BOOL lp_map_system(int );
+BOOL lp_delete_readonly(int );
+BOOL lp_fake_oplocks(int );
+BOOL lp_recursive_veto_delete(int );
+BOOL lp_dos_filemode(int );
+BOOL lp_dos_filetimes(int );
+BOOL lp_dos_filetime_resolution(int );
+BOOL lp_fake_dir_create_times(int );
+BOOL lp_blocking_locks(int );
+BOOL lp_inherit_perms(int );
+BOOL lp_inherit_acls(int );
+BOOL lp_inherit_owner(int );
+BOOL lp_use_client_driver(int );
+BOOL lp_default_devmode(int );
+BOOL lp_force_printername(int );
+BOOL lp_nt_acl_support(int );
+BOOL lp_force_unknown_acl_user(int );
+BOOL lp_ea_support(int );
+BOOL _lp_use_sendfile(int );
+BOOL lp_profile_acls(int );
+BOOL lp_map_acl_inherit(int );
+BOOL lp_afs_share(int );
+BOOL lp_acl_check_permissions(int );
+BOOL lp_acl_group_control(int );
+BOOL lp_acl_map_full_control(int );
+int lp_create_mask(int );
+int lp_force_create_mode(int );
+int lp_security_mask(int );
+int lp_force_security_mode(int );
+int lp_dir_mask(int );
+int lp_force_dir_mode(int );
+int lp_dir_security_mask(int );
+int lp_force_dir_security_mode(int );
+int lp_max_connections(int );
+int lp_defaultcase(int );
+int lp_minprintspace(int );
+int lp_printing(int );
+int lp_max_reported_jobs(int );
+int lp_oplock_contention_limit(int );
+int lp_csc_policy(int );
+int lp_write_cache_size(int );
+int lp_block_size(int );
+int lp_dfree_cache_time(int );
+int lp_allocation_roundup_size(int );
+int lp_aio_read_size(int );
+int lp_aio_write_size(int );
+int lp_map_readonly(int );
+char lp_magicchar(const struct share_params *p );
+int lp_winbind_cache_time(void);
+const char **lp_winbind_nss_info(void);
+int lp_algorithmic_rid_base(void);
+int lp_name_cache_timeout(void);
+int lp_client_signing(void);
+int lp_server_signing(void);
+char *lp_parm_talloc_string(int snum, const char *type, const char  
*option, const char *def);
+const char *lp_parm_const_string(int snum, const char *type, const  
char *option, const char *def);
+const char **lp_parm_string_list(int snum, const char *type, const  
char *option, const char **def);
+int lp_parm_int(int snum, const char *type, const char *option, int  
def);
+unsigned long lp_parm_ulong(int snum, const char *type, const char  
*option, unsigned long def);
+BOOL lp_parm_bool(int snum, const char *type, const char *option,  
BOOL def);
+int lp_parm_enum(int snum, const char *type, const char *option,
+		 const struct enum_list *_enum, int def);
+BOOL lp_add_home(const char *pszHomename, int iDefaultService,
+		 const char *user, const char *pszHomedir);
+int lp_add_service(const char *pszService, int iDefaultService);
+BOOL lp_add_printer(const char *pszPrintername, int iDefaultService);
+void show_parameter_list(void);
+BOOL service_ok(int iService);
+BOOL lp_file_list_changed(void);
+BOOL lp_idmap_uid(uid_t *low, uid_t *high);
+BOOL lp_idmap_gid(gid_t *low, gid_t *high);
+const char *lp_ldap_machine_suffix(void);
+const char *lp_ldap_user_suffix(void);
+const char *lp_ldap_group_suffix(void);
+const char *lp_ldap_idmap_suffix(void);
+void *lp_local_ptr(int snum, void *ptr);
+BOOL lp_do_parameter(int snum, const char *pszParmName, const char  
*pszParmValue);
+void init_locals(void);
+BOOL lp_is_default(int snum, struct parm_struct *parm);
+BOOL dump_a_parameter(int snum, char *parm_name, FILE * f, BOOL  
isGlobal);
+struct parm_struct *lp_next_parameter(int snum, int *i, int  
allparameters);
+BOOL lp_snum_ok(int iService);
+void lp_add_one_printer(char *name, char *comment);
+BOOL lp_loaded(void);
+void lp_killunused(BOOL (*snumused) (int));
+void lp_killservice(int iServiceIn);
+const char* server_role_str(uint32 role);
+enum usershare_err parse_usershare_file(TALLOC_CTX *ctx,
+			SMB_STRUCT_STAT *psbuf,
+			const char *servicename,
+			int snum,
+			char **lines,
+			int numlines,
+			pstring sharepath,
+			pstring comment,
+			SEC_DESC **ppsd,
+			BOOL *pallow_guest);
+int load_usershare_service(const char *servicename);
+int load_usershare_shares(void);
+void gfree_loadparm(void);
+BOOL lp_load(const char *pszFname,
+             BOOL global_only,
+             BOOL save_defaults,
+	     BOOL add_ipc,
+             BOOL initialize_globals);
+void lp_resetnumservices(void);
+int lp_numservices(void);
+void lp_dump(FILE *f, BOOL show_defaults, int maxtoprint);
+void lp_dump_one(FILE * f, BOOL show_defaults, int snum);
+int lp_servicenumber(const char *pszServiceName);
+BOOL share_defined(const char *service_name);
+struct share_params *get_share_params(TALLOC_CTX *mem_ctx,
+				      const char *sharename);
+struct share_iterator *share_list_all(TALLOC_CTX *mem_ctx);
+struct share_params *next_share(struct share_iterator *list);
+struct share_params *next_printer(struct share_iterator *list);
+struct share_params *snum2params_static(int snum);
+const char *volume_label(int snum);
+int lp_server_role(void);
+BOOL lp_domain_master(void);
+BOOL lp_preferred_master(void);
+void lp_remove_service(int snum);
+void lp_copy_service(int snum, const char *new_name);
+int lp_default_server_announce(void);
+int lp_major_announce_version(void);
+int lp_minor_announce_version(void);
+void lp_set_name_resolve_order(const char *new_order);
+const char *lp_printername(int snum);
+void lp_set_logfile(const char *name);
+int lp_maxprintjobs(int snum);
+const char *lp_printcapname(void);
+BOOL lp_disable_spoolss( void );
+void lp_set_spoolss_state( uint32 state );
+uint32 lp_get_spoolss_state( void );
+BOOL lp_use_sendfile(int snum);
+void set_use_sendfile(int snum, BOOL val);
+void set_store_dos_attributes(int snum, BOOL val);
+void lp_set_mangling_method(const char *new_method);
+BOOL lp_posix_pathnames(void);
+void lp_set_posix_pathnames(void);
+enum brl_flavour lp_posix_cifsu_locktype(files_struct *fsp);
+void lp_set_posix_default_cifsx_readwrite_locktype(enum brl_flavour  
val);
+
+/* The following definitions come from param/params.c  */
+
+BOOL pm_process( const char *FileName,
+		BOOL (*sfunc)(const char *),
+		BOOL (*pfunc)(const char *, const char *) );
+
+/* The following definitions come from passdb/login_cache.c  */
+
+BOOL login_cache_init(void);
+BOOL login_cache_shutdown(void);
+LOGIN_CACHE * login_cache_read(struct samu *sampass);
+BOOL login_cache_write(const struct samu *sampass, LOGIN_CACHE entry);
+BOOL login_cache_delentry(const struct samu *sampass);
+
+/* The following definitions come from passdb/lookup_sid.c  */
+
+BOOL lookup_name(TALLOC_CTX *mem_ctx,
+		 const char *full_name, int flags,
+		 const char **ret_domain, const char **ret_name,
+		 DOM_SID *ret_sid, enum lsa_SidType *ret_type);
+BOOL lookup_name_smbconf(TALLOC_CTX *mem_ctx,
+		 const char *full_name, int flags,
+		 const char **ret_domain, const char **ret_name,
+		 DOM_SID *ret_sid, enum lsa_SidType *ret_type);
+NTSTATUS lookup_sids(TALLOC_CTX *mem_ctx, int num_sids,
+		     const DOM_SID **sids, int level,
+		     struct lsa_dom_info **ret_domains,
+		     struct lsa_name_info **ret_names);
+BOOL lookup_sid(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+		const char **ret_domain, const char **ret_name,
+		enum lsa_SidType *ret_type);
+void store_uid_sid_cache(const DOM_SID *psid, uid_t uid);
+void store_gid_sid_cache(const DOM_SID *psid, gid_t gid);
+void uid_to_sid(DOM_SID *psid, uid_t uid);
+void gid_to_sid(DOM_SID *psid, gid_t gid);
+BOOL sid_to_uid(const DOM_SID *psid, uid_t *puid);
+BOOL sid_to_gid(const DOM_SID *psid, gid_t *pgid);
+
+/* The following definitions come from passdb/machine_sid.c  */
+
+DOM_SID *get_global_sam_sid(void);
+void reset_global_sam_sid(void) ;
+BOOL sid_check_is_domain(const DOM_SID *sid);
+BOOL sid_check_is_in_our_domain(const DOM_SID *sid);
+
+/* The following definitions come from passdb/passdb.c  */
+
+const char *my_sam_name(void);
+struct samu *samu_new( TALLOC_CTX *ctx );
+NTSTATUS samu_set_unix(struct samu *user, const struct passwd *pwd);
+NTSTATUS samu_alloc_rid_unix(struct samu *user, const struct passwd  
*pwd);
+char *pdb_encode_acct_ctrl(uint32 acct_ctrl, size_t length);
+uint32 pdb_decode_acct_ctrl(const char *p);
+void pdb_sethexpwd(char *p, const unsigned char *pwd, uint32  
acct_ctrl);
+BOOL pdb_gethexpwd(const char *p, unsigned char *pwd);
+void pdb_sethexhours(char *p, const unsigned char *hours);
+BOOL pdb_gethexhours(const char *p, unsigned char *hours);
+int algorithmic_rid_base(void);
+uid_t algorithmic_pdb_user_rid_to_uid(uint32 user_rid);
+uid_t max_algorithmic_uid(void);
+uint32 algorithmic_pdb_uid_to_user_rid(uid_t uid);
+gid_t pdb_group_rid_to_gid(uint32 group_rid);
+gid_t max_algorithmic_gid(void);
+uint32 algorithmic_pdb_gid_to_group_rid(gid_t gid);
+BOOL algorithmic_pdb_rid_is_user(uint32 rid);
+BOOL lookup_global_sam_name(const char *name, int flags, uint32_t *rid,
+			    enum lsa_SidType *type);
+NTSTATUS local_password_change(const char *user_name, int local_flags,
+			   const char *new_passwd,
+			   char *err_str, size_t err_str_len,
+			   char *msg_str, size_t msg_str_len);
+BOOL init_sam_from_buffer_v3(struct samu *sampass, uint8 *buf,  
uint32 buflen);
+uint32 init_buffer_from_sam_v3 (uint8 **buf, struct samu *sampass,  
BOOL size_only);
+BOOL pdb_copy_sam_account(struct samu *dst, struct samu *src );
+BOOL pdb_update_bad_password_count(struct samu *sampass, BOOL  
*updated);
+BOOL pdb_update_autolock_flag(struct samu *sampass, BOOL *updated);
+BOOL pdb_increment_bad_password_count(struct samu *sampass);
+BOOL get_trust_pw(const char *domain, uint8 ret_pwd[16], uint32  
*channel);
+
+/* The following definitions come from passdb/pdb_compat.c  */
+
+uint32 pdb_get_user_rid (const struct samu *sampass);
+uint32 pdb_get_group_rid (struct samu *sampass);
+BOOL pdb_set_user_sid_from_rid (struct samu *sampass, uint32 rid,  
enum pdb_value_state flag);
+BOOL pdb_set_group_sid_from_rid (struct samu *sampass, uint32 grid,  
enum pdb_value_state flag);
+
+/* The following definitions come from passdb/pdb_get_set.c  */
+
+uint32 pdb_get_acct_ctrl(const struct samu *sampass);
+time_t pdb_get_logon_time(const struct samu *sampass);
+time_t pdb_get_logoff_time(const struct samu *sampass);
+time_t pdb_get_kickoff_time(const struct samu *sampass);
+time_t pdb_get_bad_password_time(const struct samu *sampass);
+time_t pdb_get_pass_last_set_time(const struct samu *sampass);
+time_t pdb_get_pass_can_change_time(const struct samu *sampass);
+time_t pdb_get_pass_can_change_time_noncalc(const struct samu  
*sampass);
+time_t pdb_get_pass_must_change_time(const struct samu *sampass);
+BOOL pdb_get_pass_can_change(const struct samu *sampass);
+uint16 pdb_get_logon_divs(const struct samu *sampass);
+uint32 pdb_get_hours_len(const struct samu *sampass);
+const uint8 *pdb_get_hours(const struct samu *sampass);
+const uint8 *pdb_get_nt_passwd(const struct samu *sampass);
+const uint8 *pdb_get_lanman_passwd(const struct samu *sampass);
+const uint8 *pdb_get_pw_history(const struct samu *sampass, uint32  
*current_hist_len);
+const char *pdb_get_plaintext_passwd(const struct samu *sampass);
+const DOM_SID *pdb_get_user_sid(const struct samu *sampass);
+const DOM_SID *pdb_get_group_sid(struct samu *sampass);
+enum pdb_value_state pdb_get_init_flags(const struct samu *sampass,  
enum pdb_elements element);
+const char *pdb_get_username(const struct samu *sampass);
+const char *pdb_get_domain(const struct samu *sampass);
+const char *pdb_get_nt_username(const struct samu *sampass);
+const char *pdb_get_fullname(const struct samu *sampass);
+const char *pdb_get_homedir(const struct samu *sampass);
+const char *pdb_get_unix_homedir(const struct samu *sampass);
+const char *pdb_get_dir_drive(const struct samu *sampass);
+const char *pdb_get_logon_script(const struct samu *sampass);
+const char *pdb_get_profile_path(const struct samu *sampass);
+const char *pdb_get_acct_desc(const struct samu *sampass);
+const char *pdb_get_workstations(const struct samu *sampass);
+const char *pdb_get_comment(const struct samu *sampass);
+const char *pdb_get_munged_dial(const struct samu *sampass);
+uint16 pdb_get_bad_password_count(const struct samu *sampass);
+uint16 pdb_get_logon_count(const struct samu *sampass);
+uint32 pdb_get_unknown_6(const struct samu *sampass);
+void *pdb_get_backend_private_data(const struct samu *sampass, const  
struct pdb_methods *my_methods);
+BOOL pdb_set_acct_ctrl(struct samu *sampass, uint32 acct_ctrl, enum  
pdb_value_state flag);
+BOOL pdb_set_logon_time(struct samu *sampass, time_t mytime, enum  
pdb_value_state flag);
+BOOL pdb_set_logoff_time(struct samu *sampass, time_t mytime, enum  
pdb_value_state flag);
+BOOL pdb_set_kickoff_time(struct samu *sampass, time_t mytime, enum  
pdb_value_state flag);
+BOOL pdb_set_bad_password_time(struct samu *sampass, time_t mytime,  
enum pdb_value_state flag);
+BOOL pdb_set_pass_can_change_time(struct samu *sampass, time_t  
mytime, enum pdb_value_state flag);
+BOOL pdb_set_pass_must_change_time(struct samu *sampass, time_t  
mytime, enum pdb_value_state flag);
+BOOL pdb_set_pass_last_set_time(struct samu *sampass, time_t mytime,  
enum pdb_value_state flag);
+BOOL pdb_set_hours_len(struct samu *sampass, uint32 len, enum  
pdb_value_state flag);
+BOOL pdb_set_logon_divs(struct samu *sampass, uint16 hours, enum  
pdb_value_state flag);
+BOOL pdb_set_init_flags(struct samu *sampass, enum pdb_elements  
element, enum pdb_value_state value_flag);
+BOOL pdb_set_user_sid(struct samu *sampass, const DOM_SID *u_sid,  
enum pdb_value_state flag);
+BOOL pdb_set_user_sid_from_string(struct samu *sampass, fstring  
u_sid, enum pdb_value_state flag);
+BOOL pdb_set_group_sid(struct samu *sampass, const DOM_SID *g_sid,  
enum pdb_value_state flag);
+BOOL pdb_set_username(struct samu *sampass, const char *username,  
enum pdb_value_state flag);
+BOOL pdb_set_domain(struct samu *sampass, const char *domain, enum  
pdb_value_state flag);
+BOOL pdb_set_nt_username(struct samu *sampass, const char  
*nt_username, enum pdb_value_state flag);
+BOOL pdb_set_fullname(struct samu *sampass, const char *full_name,  
enum pdb_value_state flag);
+BOOL pdb_set_logon_script(struct samu *sampass, const char  
*logon_script, enum pdb_value_state flag);
+BOOL pdb_set_profile_path(struct samu *sampass, const char  
*profile_path, enum pdb_value_state flag);
+BOOL pdb_set_dir_drive(struct samu *sampass, const char *dir_drive,  
enum pdb_value_state flag);
+BOOL pdb_set_homedir(struct samu *sampass, const char *home_dir,  
enum pdb_value_state flag);
+BOOL pdb_set_acct_desc(struct samu *sampass, const char *acct_desc,  
enum pdb_value_state flag);
+BOOL pdb_set_workstations(struct samu *sampass, const char  
*workstations, enum pdb_value_state flag);
+BOOL pdb_set_comment(struct samu *sampass, const char *comment, enum  
pdb_value_state flag);
+BOOL pdb_set_munged_dial(struct samu *sampass, const char  
*munged_dial, enum pdb_value_state flag);
+BOOL pdb_set_nt_passwd(struct samu *sampass, const uint8 pwd 
[NT_HASH_LEN], enum pdb_value_state flag);
+BOOL pdb_set_lanman_passwd(struct samu *sampass, const uint8 pwd 
[LM_HASH_LEN], enum pdb_value_state flag);
+BOOL pdb_set_pw_history(struct samu *sampass, const uint8 *pwd,  
uint32 historyLen, enum pdb_value_state flag);
+BOOL pdb_set_plaintext_pw_only(struct samu *sampass, const char  
*password, enum pdb_value_state flag);
+BOOL pdb_set_bad_password_count(struct samu *sampass, uint16  
bad_password_count, enum pdb_value_state flag);
+BOOL pdb_set_logon_count(struct samu *sampass, uint16 logon_count,  
enum pdb_value_state flag);
+BOOL pdb_set_unknown_6(struct samu *sampass, uint32 unkn, enum  
pdb_value_state flag);
+BOOL pdb_set_hours(struct samu *sampass, const uint8 *hours, enum  
pdb_value_state flag);
+BOOL pdb_set_backend_private_data(struct samu *sampass, void  
*private_data,
+				   void (*free_fn)(void **),
+				   const struct pdb_methods *my_methods,
+				   enum pdb_value_state flag);
+BOOL pdb_set_pass_can_change(struct samu *sampass, BOOL canchange);
+BOOL pdb_set_plaintext_passwd(struct samu *sampass, const char  
*plaintext);
+uint32 pdb_build_fields_present(struct samu *sampass);
+
+/* The following definitions come from passdb/pdb_interface.c  */
+
+NTSTATUS smb_register_passdb(int version, const char *name,  
pdb_init_function init) ;
+struct pdb_init_function_entry *pdb_find_backend_entry(const char  
*name);
+struct event_context *pdb_get_event_context(void);
+NTSTATUS make_pdb_method_name(struct pdb_methods **methods, const  
char *selected);
+BOOL pdb_setsampwent(BOOL update, uint16 acb_mask) ;
+void pdb_endsampwent(void) ;
+BOOL pdb_getsampwent(struct samu *user) ;
+BOOL pdb_getsampwnam(struct samu *sam_acct, const char *username) ;
+BOOL guest_user_info( struct samu *user );
+BOOL pdb_getsampwsid(struct samu *sam_acct, const DOM_SID *sid) ;
+NTSTATUS pdb_create_user(TALLOC_CTX *mem_ctx, const char *name,  
uint32 flags,
+			 uint32 *rid);
+NTSTATUS pdb_delete_user(TALLOC_CTX *mem_ctx, struct samu *sam_acct);
+NTSTATUS pdb_add_sam_account(struct samu *sam_acct) ;
+NTSTATUS pdb_update_sam_account(struct samu *sam_acct) ;
+NTSTATUS pdb_delete_sam_account(struct samu *sam_acct) ;
+NTSTATUS pdb_rename_sam_account(struct samu *oldname, const char  
*newname);
+NTSTATUS pdb_update_login_attempts(struct samu *sam_acct, BOOL  
success);
+BOOL pdb_getgrsid(GROUP_MAP *map, DOM_SID sid);
+BOOL pdb_getgrgid(GROUP_MAP *map, gid_t gid);
+BOOL pdb_getgrnam(GROUP_MAP *map, const char *name);
+NTSTATUS pdb_create_dom_group(TALLOC_CTX *mem_ctx, const char *name,
+			      uint32 *rid);
+NTSTATUS pdb_delete_dom_group(TALLOC_CTX *mem_ctx, uint32 rid);
+NTSTATUS pdb_add_group_mapping_entry(GROUP_MAP *map);
+NTSTATUS pdb_update_group_mapping_entry(GROUP_MAP *map);
+NTSTATUS pdb_delete_group_mapping_entry(DOM_SID sid);
+BOOL pdb_enum_group_mapping(const DOM_SID *sid, enum lsa_SidType  
sid_name_use, GROUP_MAP **pp_rmap,
+			    size_t *p_num_entries, BOOL unix_only);
+NTSTATUS pdb_enum_group_members(TALLOC_CTX *mem_ctx,
+				const DOM_SID *sid,
+				uint32 **pp_member_rids,
+				size_t *p_num_members);
+NTSTATUS pdb_enum_group_memberships(TALLOC_CTX *mem_ctx, struct samu  
*user,
+				    DOM_SID **pp_sids, gid_t **pp_gids,
+				    size_t *p_num_groups);
+NTSTATUS pdb_set_unix_primary_group(TALLOC_CTX *mem_ctx, struct samu  
*user);
+NTSTATUS pdb_add_groupmem(TALLOC_CTX *mem_ctx, uint32 group_rid,
+			  uint32 member_rid);
+NTSTATUS pdb_del_groupmem(TALLOC_CTX *mem_ctx, uint32 group_rid,
+			  uint32 member_rid);
+NTSTATUS pdb_create_alias(const char *name, uint32 *rid);
+NTSTATUS pdb_delete_alias(const DOM_SID *sid);
+NTSTATUS pdb_get_aliasinfo(const DOM_SID *sid, struct acct_info *info);
+NTSTATUS pdb_set_aliasinfo(const DOM_SID *sid, struct acct_info *info);
+NTSTATUS pdb_add_aliasmem(const DOM_SID *alias, const DOM_SID *member);
+NTSTATUS pdb_del_aliasmem(const DOM_SID *alias, const DOM_SID *member);
+NTSTATUS pdb_enum_aliasmem(const DOM_SID *alias,
+			   DOM_SID **pp_members, size_t *p_num_members);
+NTSTATUS pdb_enum_alias_memberships(TALLOC_CTX *mem_ctx,
+				    const DOM_SID *domain_sid,
+				    const DOM_SID *members, size_t num_members,
+				    uint32 **pp_alias_rids,
+				    size_t *p_num_alias_rids);
+NTSTATUS pdb_lookup_rids(const DOM_SID *domain_sid,
+			 int num_rids,
+			 uint32 *rids,
+			 const char **names,
+			 enum lsa_SidType *attrs);
+NTSTATUS pdb_lookup_names(const DOM_SID *domain_sid,
+			  int num_names,
+			  const char **names,
+			  uint32 *rids,
+			  enum lsa_SidType *attrs);
+BOOL pdb_get_account_policy(int policy_index, uint32 *value);
+BOOL pdb_set_account_policy(int policy_index, uint32 value);
+BOOL pdb_get_seq_num(time_t *seq_num);
+BOOL pdb_uid_to_rid(uid_t uid, uint32 *rid);
+BOOL pdb_uid_to_sid(uid_t uid, DOM_SID *sid);
+BOOL pdb_gid_to_sid(gid_t gid, DOM_SID *sid);
+BOOL pdb_sid_to_id(const DOM_SID *sid, union unid_t *id,
+		   enum lsa_SidType *type);
+BOOL pdb_rid_algorithm(void);
+BOOL pdb_new_rid(uint32 *rid);
+BOOL initialize_password_db(BOOL reload, struct event_context  
*event_ctx);
+struct pdb_search *pdb_search_users(uint32 acct_flags);
+struct pdb_search *pdb_search_groups(void);
+struct pdb_search *pdb_search_aliases(const DOM_SID *sid);
+uint32 pdb_search_entries(struct pdb_search *search,
+			  uint32 start_idx, uint32 max_entries,
+			  struct samr_displayentry **result);
+void pdb_search_destroy(struct pdb_search *search);
+BOOL pdb_get_trusteddom_pw(const char *domain, char** pwd, DOM_SID  
*sid,
+			   time_t *pass_last_set_time);
+BOOL pdb_set_trusteddom_pw(const char* domain, const char* pwd,
+			   const DOM_SID *sid);
+BOOL pdb_del_trusteddom_pw(const char *domain);
+NTSTATUS pdb_enum_trusteddoms(TALLOC_CTX *mem_ctx, uint32 *num_domains,
+			      struct trustdom_info ***domains);
+NTSTATUS make_pdb_method( struct pdb_methods **methods ) ;
+
+/* The following definitions come from passdb/pdb_ldap.c  */
+
+const char** get_userattr_list( TALLOC_CTX *mem_ctx, int schema_ver );
+int ldapsam_search_suffix_by_name(struct ldapsam_privates *ldap_state,
+					  const char *user,
+					  LDAPMessage ** result,
+					  const char **attr);
+const char **talloc_attrs(TALLOC_CTX *mem_ctx, ...);
+NTSTATUS pdb_init_ldapsam_compat(struct pdb_methods **pdb_method,  
const char *location);
+NTSTATUS pdb_init_ldapsam(struct pdb_methods **pdb_method, const  
char *location);
+NTSTATUS pdb_ldap_init(void);
+
+/* The following definitions come from passdb/pdb_nds.c  */
+
+int pdb_nds_get_password(
+	struct smbldap_state *ldap_state,
+	char *object_dn,
+	size_t *pwd_len,
+	char *pwd );
+int pdb_nds_set_password(
+	struct smbldap_state *ldap_state,
+	char *object_dn,
+	const char *pwd );
+NTSTATUS pdb_nds_init(void);
+
+/* The following definitions come from passdb/pdb_smbpasswd.c  */
+
+NTSTATUS pdb_smbpasswd_init(void) ;
+
+/* The following definitions come from passdb/pdb_tdb.c  */
+
+BOOL init_sam_from_buffer_v2(struct samu *sampass, uint8 *buf,  
uint32 buflen);
+void tdbsam_close( void );
+NTSTATUS pdb_tdbsam_init(void);
+
+/* The following definitions come from passdb/secrets.c  */
+
+BOOL secrets_init(void);
+void *secrets_fetch(const char *key, size_t *size);
+BOOL secrets_store(const char *key, const void *data, size_t size);
+BOOL secrets_delete(const char *key);
+BOOL secrets_store_domain_sid(const char *domain, const DOM_SID *sid);
+BOOL secrets_fetch_domain_sid(const char *domain, DOM_SID *sid);
+BOOL secrets_store_domain_guid(const char *domain, struct GUID *guid);
+BOOL secrets_fetch_domain_guid(const char *domain, struct GUID *guid);
+BOOL secrets_lock_trust_account_password(const char *domain, BOOL  
dolock);
+uint32 get_default_sec_channel(void) ;
+BOOL secrets_fetch_trust_account_password(const char *domain, uint8  
ret_pwd[16],
+					  time_t *pass_last_set_time,
+					  uint32 *channel);
+BOOL secrets_fetch_trusted_domain_password(const char *domain,  
char** pwd,
+                                           DOM_SID *sid, time_t  
*pass_last_set_time);
+BOOL secrets_store_trusted_domain_password(const char* domain, const  
char* pwd,
+                                           const DOM_SID *sid);
+BOOL secrets_store_machine_password(const char *pass, const char  
*domain, uint32 sec_channel);
+char *secrets_fetch_machine_password(const char *domain,
+				     time_t *pass_last_set_time,
+				     uint32 *channel);
+BOOL trusted_domain_password_delete(const char *domain);
+BOOL secrets_store_ldap_pw(const char* dn, char* pw);
+BOOL fetch_ldap_pw(char **dn, char** pw);
+NTSTATUS secrets_trusted_domains(TALLOC_CTX *mem_ctx, uint32  
*num_domains,
+				 struct trustdom_info ***domains);
+BOOL secrets_named_mutex(const char *name, unsigned int timeout);
+void secrets_named_mutex_release(const char *name);
+BOOL secrets_store_afs_keyfile(const char *cell, const struct  
afs_keyfile *keyfile);
+BOOL secrets_fetch_afs_key(const char *cell, struct afs_key *result);
+void secrets_fetch_ipc_userpass(char **username, char **domain, char  
**password);
+BOOL secrets_store_schannel_session_info(TALLOC_CTX *mem_ctx,
+				const char *remote_machine,
+				const struct dcinfo *pdc);
+BOOL secrets_restore_schannel_session_info(TALLOC_CTX *mem_ctx,
+				const char *remote_machine,
+				struct dcinfo **ppdc);
+BOOL secrets_store_generic(const char *owner, const char *key, const  
char *secret);
+char *secrets_fetch_generic(const char *owner, const char *key);
+
+/* The following definitions come from passdb/util_builtin.c  */
+
+BOOL lookup_builtin_rid(TALLOC_CTX *mem_ctx, uint32 rid, const char  
**name);
+BOOL lookup_builtin_name(const char *name, uint32 *rid);
+const char *builtin_domain_name(void);
+BOOL sid_check_is_builtin(const DOM_SID *sid);
+BOOL sid_check_is_in_builtin(const DOM_SID *sid);
+
+/* The following definitions come from passdb/util_unixsids.c  */
+
+BOOL sid_check_is_unix_users(const DOM_SID *sid);
+BOOL sid_check_is_in_unix_users(const DOM_SID *sid);
+BOOL uid_to_unix_users_sid(uid_t uid, DOM_SID *sid);
+BOOL gid_to_unix_groups_sid(gid_t gid, DOM_SID *sid);
+const char *unix_users_domain_name(void);
+BOOL lookup_unix_user_name(const char *name, DOM_SID *sid);
+BOOL sid_check_is_unix_groups(const DOM_SID *sid);
+BOOL sid_check_is_in_unix_groups(const DOM_SID *sid);
+const char *unix_groups_domain_name(void);
+BOOL lookup_unix_group_name(const char *name, DOM_SID *sid);
+
+/* The following definitions come from passdb/util_wellknown.c  */
+
+BOOL sid_check_is_wellknown_domain(const DOM_SID *sid, const char  
**name);
+BOOL sid_check_is_in_wellknown_domain(const DOM_SID *sid);
+BOOL lookup_wellknown_sid(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+			  const char **domain, const char **name);
+BOOL lookup_wellknown_name(TALLOC_CTX *mem_ctx, const char *name,
+			   DOM_SID *sid, const char **domain);
+
+/* The following definitions come from printing/load.c  */
+
+void load_printers(void);
+
+/* The following definitions come from printing/lpq_parse.c  */
+
+BOOL parse_lpq_entry(enum printing_types printing_type,char *line,
+		     print_queue_struct *buf,
+		     print_status_struct *status,BOOL first);
+
+/* The following definitions come from printing/notify.c  */
+
+int print_queue_snum(const char *qname);
+BOOL print_notify_messages_pending(void);
+void print_notify_send_messages(struct messaging_context *msg_ctx,
+				unsigned int timeout);
+void notify_printer_status_byname(const char *sharename, uint32  
status);
+void notify_printer_status(int snum, uint32 status);
+void notify_job_status_byname(const char *sharename, uint32 jobid,  
uint32 status,
+			      uint32 flags);
+void notify_job_status(const char *sharename, uint32 jobid, uint32  
status);
+void notify_job_total_bytes(const char *sharename, uint32 jobid,
+			    uint32 size);
+void notify_job_total_pages(const char *sharename, uint32 jobid,
+			    uint32 pages);
+void notify_job_username(const char *sharename, uint32 jobid, char  
*name);
+void notify_job_name(const char *sharename, uint32 jobid, char *name);
+void notify_job_submitted(const char *sharename, uint32 jobid,
+			  time_t submitted);
+void notify_printer_driver(int snum, char *driver_name);
+void notify_printer_comment(int snum, char *comment);
+void notify_printer_sharename(int snum, char *share_name);
+void notify_printer_printername(int snum, char *printername);
+void notify_printer_port(int snum, char *port_name);
+void notify_printer_location(int snum, char *location);
+void notify_printer_byname( const char *printername, uint32 change,  
const char *value );
+BOOL print_notify_pid_list(const char *printername, TALLOC_CTX  
*mem_ctx, size_t *p_num_pids, pid_t **pp_pid_list);
+
+/* The following definitions come from printing/nt_printing.c  */
+
+BOOL nt_printing_init(struct messaging_context *msg_ctx);
+uint32 update_c_setprinter(BOOL initialize);
+uint32 get_c_setprinter(void);
+int get_builtin_ntforms(nt_forms_struct **list);
+BOOL get_a_builtin_ntform(UNISTR2 *uni_formname,nt_forms_struct *form);
+int get_ntforms(nt_forms_struct **list);
+int write_ntforms(nt_forms_struct **list, int number);
+BOOL add_a_form(nt_forms_struct **list, const FORM *form, int *count);
+BOOL delete_a_form(nt_forms_struct **list, UNISTR2 *del_name, int  
*count, WERROR *ret);
+void update_a_form(nt_forms_struct **list, const FORM *form, int  
count);
+int get_ntdrivers(fstring **list, const char *architecture, uint32  
version);
+const char *get_short_archi(const char *long_archi);
+WERROR clean_up_driver_struct(NT_PRINTER_DRIVER_INFO_LEVEL  
driver_abstract,
+							  uint32 level, struct current_user *user);
+WERROR move_driver_to_download_area(NT_PRINTER_DRIVER_INFO_LEVEL  
driver_abstract, uint32 level,
+				  struct current_user *user, WERROR *perr);
+int pack_devicemode(NT_DEVICEMODE *nt_devmode, uint8 *buf, int buflen);
+uint32 del_a_printer(const char *sharename);
+NT_DEVICEMODE *construct_nt_devicemode(const fstring  
default_devicename);
+NT_DEVICEMODE *dup_nt_devicemode(NT_DEVICEMODE *nt_devicemode);
+void free_nt_devicemode(NT_DEVICEMODE **devmode_ptr);
+int unpack_devicemode(NT_DEVICEMODE **nt_devmode, const uint8 *buf,  
int buflen);
+int add_new_printer_key( NT_PRINTER_DATA *data, const char *name );
+int delete_printer_key( NT_PRINTER_DATA *data, const char *name );
+int lookup_printerkey( NT_PRINTER_DATA *data, const char *name );
+int get_printer_subkeys( NT_PRINTER_DATA *data, const char* key,  
fstring **subkeys );
+WERROR nt_printer_publish(Printer_entry *print_hnd, int snum, int  
action);
+WERROR check_published_printers(void);
+BOOL is_printer_published(Printer_entry *print_hnd, int snum,
+			  struct GUID *guid);
+WERROR nt_printer_publish(Printer_entry *print_hnd, int snum, int  
action);
+WERROR check_published_printers(void);
+BOOL is_printer_published(Printer_entry *print_hnd, int snum,
+			  struct GUID *guid);
+WERROR delete_all_printer_data( NT_PRINTER_INFO_LEVEL_2 *p2, const  
char *key );
+WERROR delete_printer_data( NT_PRINTER_INFO_LEVEL_2 *p2, const char  
*key, const char *value );
+WERROR add_printer_data( NT_PRINTER_INFO_LEVEL_2 *p2, const char  
*key, const char *value,
+                           uint32 type, uint8 *data, int real_len );
+REGISTRY_VALUE* get_printer_data( NT_PRINTER_INFO_LEVEL_2 *p2, const  
char *key, const char *value );
+WERROR mod_a_printer(NT_PRINTER_INFO_LEVEL *printer, uint32 level);
+BOOL set_driver_init(NT_PRINTER_INFO_LEVEL *printer, uint32 level);
+BOOL del_driver_init(char *drivername);
+WERROR save_driver_init(NT_PRINTER_INFO_LEVEL *printer, uint32  
level, uint8 *data, uint32 data_len);
+WERROR get_a_printer( Printer_entry *print_hnd,  
NT_PRINTER_INFO_LEVEL **pp_printer, uint32 level,
+			const char *sharename);
+uint32 free_a_printer(NT_PRINTER_INFO_LEVEL **pp_printer, uint32  
level);
+uint32 add_a_printer_driver(NT_PRINTER_DRIVER_INFO_LEVEL driver,  
uint32 level);
+WERROR get_a_printer_driver(NT_PRINTER_DRIVER_INFO_LEVEL *driver,  
uint32 level,
+                            fstring drivername, const char  
*architecture, uint32 version);
+uint32 free_a_printer_driver(NT_PRINTER_DRIVER_INFO_LEVEL driver,  
uint32 level);
+BOOL printer_driver_in_use ( NT_PRINTER_DRIVER_INFO_LEVEL_3 *info_3 );
+BOOL printer_driver_files_in_use ( NT_PRINTER_DRIVER_INFO_LEVEL_3  
*info );
+WERROR delete_printer_driver( NT_PRINTER_DRIVER_INFO_LEVEL_3  
*info_3, struct current_user *user,
+                              uint32 version, BOOL delete_files );
+WERROR nt_printing_setsec(const char *sharename, SEC_DESC_BUF  
*secdesc_ctr);
+BOOL nt_printing_getsec(TALLOC_CTX *ctx, const char *sharename,  
SEC_DESC_BUF **secdesc_ctr);
+void map_printer_permissions(SEC_DESC *sd);
+BOOL print_access_check(struct current_user *user, int snum, int  
access_type);
+BOOL print_time_access_check(const char *servicename);
+char* get_server_name( Printer_entry *printer );
+
+/* The following definitions come from printing/pcap.c  */
+
+BOOL pcap_cache_add(const char *name, const char *comment);
+BOOL pcap_cache_loaded(void);
+void pcap_cache_reload(void);
+BOOL pcap_printername_ok(const char *printername);
+void pcap_printer_fn(void (*fn)(char *, char *));
+
+/* The following definitions come from printing/print_aix.c  */
+
+BOOL aix_cache_reload(void);
+
+/* The following definitions come from printing/print_cups.c  */
+
+BOOL cups_cache_reload(void);
+BOOL cups_pull_comment_location(NT_PRINTER_INFO_LEVEL_2 *printer);
+
+/* The following definitions come from printing/print_generic.c  */
+
+
+/* The following definitions come from printing/print_iprint.c  */
+
+BOOL iprint_cache_reload(void);
+
+/* The following definitions come from printing/print_svid.c  */
+
+BOOL sysv_cache_reload(void);
+
+/* The following definitions come from printing/print_test.c  */
+
+
+/* The following definitions come from printing/printfsp.c  */
+
+NTSTATUS print_fsp_open(connection_struct *conn, const char *fname,
+			files_struct **result);
+void print_fsp_end(files_struct *fsp, enum file_close_type close_type);
+
+/* The following definitions come from printing/printing.c  */
+
+uint16 pjobid_to_rap(const char* sharename, uint32 jobid);
+BOOL rap_to_pjobid(uint16 rap_jobid, fstring sharename, uint32  
*pjobid);
+BOOL print_backend_init(struct messaging_context *msg_ctx);
+void printing_end(void);
+int unpack_pjob( uint8 *buf, int buflen, struct printjob *pjob );
+uint32 sysjob_to_jobid(int unix_jobid);
+void pjob_delete(const char* sharename, uint32 jobid);
+void start_background_queue(void);
+BOOL print_notify_register_pid(int snum);
+BOOL print_notify_deregister_pid(int snum);
+BOOL print_job_exists(const char* sharename, uint32 jobid);
+int print_job_fd(const char* sharename, uint32 jobid);
+char *print_job_fname(const char* sharename, uint32 jobid);
+NT_DEVICEMODE *print_job_devmode(const char* sharename, uint32 jobid);
+BOOL print_job_set_place(const char *sharename, uint32 jobid, int  
place);
+BOOL print_job_set_name(const char *sharename, uint32 jobid, char  
*name);
+BOOL print_job_delete(struct current_user *user, int snum, uint32  
jobid, WERROR *errcode);
+BOOL print_job_pause(struct current_user *user, int snum, uint32  
jobid, WERROR *errcode);
+BOOL print_job_resume(struct current_user *user, int snum, uint32  
jobid, WERROR *errcode);
+ssize_t print_job_write(int snum, uint32 jobid, const char *buf,  
SMB_OFF_T pos, size_t size);
+int print_queue_length(int snum, print_status_struct *pstatus);
+uint32 print_job_start(struct current_user *user, int snum, char  
*jobname, NT_DEVICEMODE *nt_devmode );
+void print_job_endpage(int snum, uint32 jobid);
+BOOL print_job_end(int snum, uint32 jobid, enum file_close_type  
close_type);
+int print_queue_status(int snum,
+		       print_queue_struct **ppqueue,
+		       print_status_struct *status);
+BOOL print_queue_pause(struct current_user *user, int snum, WERROR  
*errcode);
+BOOL print_queue_resume(struct current_user *user, int snum, WERROR  
*errcode);
+BOOL print_queue_purge(struct current_user *user, int snum, WERROR  
*errcode);
+
+/* The following definitions come from printing/printing_db.c  */
+
+struct tdb_print_db *get_print_db_byname(const char *printername);
+void release_print_db( struct tdb_print_db *pdb);
+void close_all_print_db(void);
+TDB_DATA get_printer_notify_pid_list(TDB_CONTEXT *tdb, const char  
*printer_name, BOOL cleanlist);
+
+/* The following definitions come from profile/profile.c  */
+
+void set_profile_level(int level, struct server_id src);
+BOOL profile_setup(struct messaging_context *msg_ctx, BOOL rdonly);
+
+/* The following definitions come from registry/reg_api.c  */
+
+WERROR reg_openhive(TALLOC_CTX *mem_ctx, const char *hive,
+		    uint32 desired_access,
+		    const struct nt_user_token *token,
+		    struct registry_key **pkey);
+WERROR reg_openkey(TALLOC_CTX *mem_ctx, struct registry_key *parent,
+		   const char *name, uint32 desired_access,
+		   struct registry_key **pkey);
+WERROR reg_enumkey(TALLOC_CTX *mem_ctx, struct registry_key *key,
+		   uint32 idx, char **name, NTTIME *last_write_time);
+WERROR reg_enumvalue(TALLOC_CTX *mem_ctx, struct registry_key *key,
+		     uint32 idx, char **pname, struct registry_value **pval);
+WERROR reg_queryvalue(TALLOC_CTX *mem_ctx, struct registry_key *key,
+		      const char *name, struct registry_value **pval);
+WERROR reg_queryinfokey(struct registry_key *key, uint32_t  
*num_subkeys,
+			uint32_t *max_subkeylen, uint32_t *max_subkeysize,
+			uint32_t *num_values, uint32_t *max_valnamelen,
+			uint32_t *max_valbufsize, uint32_t *secdescsize,
+			NTTIME *last_changed_time);
+WERROR reg_createkey(TALLOC_CTX *ctx, struct registry_key *parent,
+		     const char *subkeypath, uint32 desired_access,
+		     struct registry_key **pkey,
+		     enum winreg_CreateAction *paction);
+WERROR reg_deletekey(struct registry_key *parent, const char *path);
+WERROR reg_setvalue(struct registry_key *key, const char *name,
+		    const struct registry_value *val);
+WERROR reg_deletevalue(struct registry_key *key, const char *name);
+WERROR reg_open_path(TALLOC_CTX *mem_ctx, const char *orig_path,
+		     uint32 desired_access, const struct nt_user_token *token,
+		     struct registry_key **pkey);
+
+/* The following definitions come from registry/reg_cachehook.c  */
+
+BOOL reghook_cache_init( void );
+BOOL reghook_cache_add( REGISTRY_HOOK *hook );
+REGISTRY_HOOK* reghook_cache_find( const char *keyname );
+void reghook_dump_cache( int debuglevel );
+
+/* The following definitions come from registry/reg_db.c  */
+
+BOOL regdb_init( void );
+WERROR regdb_open( void );
+int regdb_close( void );
+BOOL regdb_store_keys( const char *key, REGSUBKEY_CTR *ctr );
+int regdb_fetch_keys( const char* key, REGSUBKEY_CTR *ctr );
+int regdb_fetch_values( const char* key, REGVAL_CTR *values );
+BOOL regdb_store_values( const char *key, REGVAL_CTR *values );
+void normalize_dbkey(char *key);
+
+/* The following definitions come from registry/reg_dynamic.c  */
+
+int fetch_dynamic_reg_values( REGISTRY_KEY *key, REGVAL_CTR *val );
+BOOL check_dynamic_reg_values( REGISTRY_KEY *key );
+
+/* The following definitions come from registry/reg_eventlog.c  */
+
+BOOL eventlog_init_keys( void );
+BOOL eventlog_add_source( const char *eventlog, const char *sourcename,
+			  const char *messagefile );
+
+/* The following definitions come from registry/reg_frontend.c  */
+
+BOOL init_registry( void );
+WERROR regkey_open_internal( TALLOC_CTX *ctx, REGISTRY_KEY **regkey,
+			     const char *path,
+                             const struct nt_user_token *token,
+			     uint32 access_desired );
+WERROR regkey_set_secdesc(REGISTRY_KEY *key,
+			  struct security_descriptor *psecdesc);
+WERROR reg_create_path(TALLOC_CTX *mem_ctx, const char *orig_path,
+		       uint32 desired_access,
+		       const struct nt_user_token *token,
+		       enum winreg_CreateAction *paction,
+		       struct registry_key **pkey);
+WERROR reg_delete_path(const struct nt_user_token *token,
+		       const char *orig_path);
+
+/* The following definitions come from registry/ 
reg_frontend_hilvl.c  */
+
+BOOL store_reg_keys( REGISTRY_KEY *key, REGSUBKEY_CTR *subkeys );
+BOOL store_reg_values( REGISTRY_KEY *key, REGVAL_CTR *val );
+int fetch_reg_keys( REGISTRY_KEY *key, REGSUBKEY_CTR *subkey_ctr );
+int fetch_reg_values( REGISTRY_KEY *key, REGVAL_CTR *val );
+BOOL regkey_access_check( REGISTRY_KEY *key, uint32 requested,  
uint32 *granted,
+			  const struct nt_user_token *token );
+WERROR regkey_open_onelevel( TALLOC_CTX *mem_ctx, struct  
registry_key *parent,
+			     const char *name,
+			     const struct nt_user_token *token,
+			     uint32 access_desired,
+			     struct registry_key **pregkey);
+WERROR regkey_get_secdesc(TALLOC_CTX *mem_ctx, REGISTRY_KEY *key,
+			  struct security_descriptor **psecdesc);
+
+/* The following definitions come from registry/reg_objects.c  */
+
+WERROR regsubkey_ctr_addkey( REGSUBKEY_CTR *ctr, const char *keyname );
+int regsubkey_ctr_delkey( REGSUBKEY_CTR *ctr, const char *keyname );
+BOOL regsubkey_ctr_key_exists( REGSUBKEY_CTR *ctr, const char  
*keyname );
+int regsubkey_ctr_numkeys( REGSUBKEY_CTR *ctr );
+char* regsubkey_ctr_specific_key( REGSUBKEY_CTR *ctr, uint32  
key_index );
+int regval_ctr_numvals( REGVAL_CTR *ctr );
+REGISTRY_VALUE* dup_registry_value( REGISTRY_VALUE *val );
+void free_registry_value( REGISTRY_VALUE *val );
+uint8* regval_data_p( REGISTRY_VALUE *val );
+uint32 regval_size( REGISTRY_VALUE *val );
+char* regval_name( REGISTRY_VALUE *val );
+uint32 regval_type( REGISTRY_VALUE *val );
+REGISTRY_VALUE* regval_ctr_specific_value( REGVAL_CTR *ctr, uint32  
idx );
+BOOL regval_ctr_key_exists( REGVAL_CTR *ctr, const char *value );
+int regval_ctr_addvalue( REGVAL_CTR *ctr, const char *name, uint16  
type,
+                         const char *data_p, size_t size );
+int regval_ctr_copyvalue( REGVAL_CTR *ctr, REGISTRY_VALUE *val );
+int regval_ctr_delvalue( REGVAL_CTR *ctr, const char *name );
+REGISTRY_VALUE* regval_ctr_getvalue( REGVAL_CTR *ctr, const char  
*name );
+uint32 regval_dword( REGISTRY_VALUE *val );
+char* regval_sz( REGISTRY_VALUE *val );
+
+/* The following definitions come from registry/reg_perfcount.c  */
+
+void perfcount_init_keys( void );
+uint32 reg_perfcount_get_base_index(void);
+uint32 reg_perfcount_get_last_counter(uint32 base_index);
+uint32 reg_perfcount_get_last_help(uint32 last_counter);
+uint32 reg_perfcount_get_counter_help(uint32 base_index, char  
**retbuf);
+uint32 reg_perfcount_get_counter_names(uint32 base_index, char  
**retbuf);
+BOOL _reg_perfcount_get_counter_data(TDB_DATA key, TDB_DATA *data);
+BOOL _reg_perfcount_get_instance_info(PERF_INSTANCE_DEFINITION *inst,
+				      prs_struct *ps,
+				      int instId,
+				      PERF_OBJECT_TYPE *obj,
+				      TDB_CONTEXT *names);
+BOOL _reg_perfcount_add_instance(PERF_OBJECT_TYPE *obj,
+				 prs_struct *ps,
+				 int instInd,
+				 TDB_CONTEXT *names);
+uint32 reg_perfcount_get_perf_data_block(uint32 base_index,
+					 prs_struct *ps,
+					 PERF_DATA_BLOCK *block,
+					 const char *object_ids);
+WERROR reg_perfcount_get_hkpd(prs_struct *ps, uint32 max_buf_size,  
uint32 *outbuf_len, const char *object_ids);
+
+/* The following definitions come from registry/reg_printing.c  */
+
+
+/* The following definitions come from registry/reg_shares.c  */
+
+
+/* The following definitions come from registry/reg_smbconf.c  */
+
+
+/* The following definitions come from registry/reg_util.c  */
+
+BOOL reg_split_path( char *path, char **base, char **new_path );
+BOOL reg_split_key( char *path, char **base, char **key );
+void normalize_reg_path( pstring keyname );
+char* reg_remaining_path( const char *key );
+int regval_convert_multi_sz( uint16 *multi_string, size_t byte_len,  
char ***values );
+size_t regval_build_multi_sz( char **values, uint16 **buffer );
+
+/* The following definitions come from registry/regfio.c  */
+
+
+/* The following definitions come from rpc_client/cli_ds.c  */
+
+NTSTATUS rpccli_ds_getprimarydominfo(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     uint16 level, DS_DOMINFO_CTR *ctr);
+NTSTATUS rpccli_ds_enum_domain_trusts(struct rpc_pipe_client *cli,
+				      TALLOC_CTX *mem_ctx,
+				      const char *server, uint32 flags,
+				      struct ds_domain_trust **trusts,
+				      uint32 *num_domains);
+
+/* The following definitions come from rpc_client/cli_lsarpc.c  */
+
+NTSTATUS rpccli_lsa_open_policy(struct rpc_pipe_client *cli,
+				TALLOC_CTX *mem_ctx,
+				BOOL sec_qos, uint32 des_access,
+				POLICY_HND *pol);
+NTSTATUS rpccli_lsa_open_policy2(struct rpc_pipe_client *cli,
+				 TALLOC_CTX *mem_ctx, BOOL sec_qos,
+				 uint32 des_access, POLICY_HND *pol);
+NTSTATUS rpccli_lsa_lookup_sids_all(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    POLICY_HND *pol,
+				    int num_sids,
+				    const DOM_SID *sids,
+				    char ***domains,
+				    char ***names,
+				    enum lsa_SidType **types);
+NTSTATUS rpccli_lsa_lookup_sids(struct rpc_pipe_client *cli,
+				TALLOC_CTX *mem_ctx,
+				POLICY_HND *pol, int num_sids,
+				const DOM_SID *sids,
+				char ***domains,
+				char ***names,
+				enum lsa_SidType **types);
+NTSTATUS rpccli_lsa_lookup_names(struct rpc_pipe_client *cli,
+				 TALLOC_CTX *mem_ctx,
+				 POLICY_HND *pol, int num_names,
+				 const char **names,
+				 const char ***dom_names,
+				 DOM_SID **sids,
+				 enum lsa_SidType **types);
+NTSTATUS rpccli_lsa_query_info_policy_new(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+					  POLICY_HND *pol, uint16 info_class,
+					  LSA_INFO_CTR *ctr) ;
+NTSTATUS rpccli_lsa_query_info_policy2_new(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+					  POLICY_HND *pol, uint16 info_class,
+					  LSA_INFO_CTR2 *ctr) ;
+NTSTATUS rpccli_lsa_query_info_policy(struct rpc_pipe_client *cli,
+				      TALLOC_CTX *mem_ctx,
+				      POLICY_HND *pol, uint16 info_class,
+				      char **domain_name, DOM_SID **domain_sid);
+NTSTATUS rpccli_lsa_query_info_policy2(struct rpc_pipe_client *cli,
+				       TALLOC_CTX *mem_ctx,
+				       POLICY_HND *pol, uint16 info_class,
+				       char **domain_name, char **dns_name,
+				       char **forest_name,
+				       struct GUID **domain_guid,
+				       DOM_SID **domain_sid);
+NTSTATUS rpccli_lsa_set_info_policy(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				    POLICY_HND *pol, uint16 info_class,
+				    LSA_INFO_CTR ctr) ;
+NTSTATUS rpccli_lsa_enum_trust_dom(struct rpc_pipe_client *cli,
+				   TALLOC_CTX *mem_ctx,
+				   POLICY_HND *pol, uint32 *enum_ctx,
+				   uint32 *num_domains,
+				   char ***domain_names, DOM_SID **domain_sids);
+NTSTATUS rpccli_lsa_enum_privilege(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                POLICY_HND *pol, uint32  
*enum_context, uint32 pref_max_length,
+				uint32 *count, char ***privs_name, uint32 **privs_high, uint32  
**privs_low);
+NTSTATUS rpccli_lsa_get_dispname(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			      POLICY_HND *pol, const char *name,
+			      uint16 lang_id, uint16 lang_id_sys,
+			      fstring description, uint16 *lang_id_desc);
+NTSTATUS rpccli_lsa_enum_sids(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                POLICY_HND *pol, uint32 *enum_ctx,  
uint32 pref_max_length,
+                                uint32 *num_sids, DOM_SID **sids);
+NTSTATUS rpccli_lsa_create_account(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                             POLICY_HND *dom_pol, DOM_SID *sid,  
uint32 desired_access,
+			     POLICY_HND *user_pol);
+NTSTATUS rpccli_lsa_open_account(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                             POLICY_HND *dom_pol, DOM_SID *sid,  
uint32 des_access,
+			     POLICY_HND *user_pol);
+NTSTATUS rpccli_lsa_enum_privsaccount(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                             POLICY_HND *pol, uint32 *count,  
LUID_ATTR **set);
+NTSTATUS rpccli_lsa_lookup_priv_value(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				 POLICY_HND *pol, const char *name, LUID *luid);
+NTSTATUS rpccli_lsa_query_secobj(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			      POLICY_HND *pol, uint32 sec_info,
+			      SEC_DESC_BUF **psdb);
+NTSTATUS rpccli_lsa_enum_account_rights(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				     POLICY_HND *pol, DOM_SID *sid,
+				     uint32 *count, char ***priv_names);
+NTSTATUS rpccli_lsa_add_account_rights(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				    POLICY_HND *pol, DOM_SID sid,
+					uint32 count, const char **privs_name);
+NTSTATUS rpccli_lsa_remove_account_rights(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+				       POLICY_HND *pol, DOM_SID sid, BOOL removeall,
+				       uint32 count, const char **privs_name);
+BOOL fetch_domain_sid( char *domain, char *remote_machine, DOM_SID  
*psid);
+NTSTATUS rpccli_lsa_open_trusted_domain(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				     POLICY_HND *pol, DOM_SID *dom_sid, uint32 access_mask,
+				     POLICY_HND *trustdom_pol);
+NTSTATUS rpccli_lsa_query_trusted_domain_info(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+					   POLICY_HND *pol,
+					   uint16 info_class,
+					   LSA_TRUSTED_DOMAIN_INFO **info);
+NTSTATUS rpccli_lsa_open_trusted_domain_by_name(struct  
rpc_pipe_client *cli, TALLOC_CTX *mem_ctx,
+						POLICY_HND *pol, const char *name, uint32 access_mask,
+						POLICY_HND *trustdom_pol);
+NTSTATUS rpccli_lsa_query_trusted_domain_info_by_sid(struct  
rpc_pipe_client *cli, TALLOC_CTX *mem_ctx,
+						  POLICY_HND *pol,
+						  uint16 info_class, DOM_SID *dom_sid,
+						  LSA_TRUSTED_DOMAIN_INFO **info);
+NTSTATUS rpccli_lsa_query_trusted_domain_info_by_name(struct  
rpc_pipe_client *cli, TALLOC_CTX *mem_ctx,
+						   POLICY_HND *pol,
+						   uint16 info_class, const char *domain_name,
+						   LSA_TRUSTED_DOMAIN_INFO **info);
+NTSTATUS cli_lsa_query_domain_info_policy(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+					  POLICY_HND *pol,
+					  uint16 info_class, LSA_DOM_INFO_UNION **info);
+
+/* The following definitions come from rpc_client/cli_netlogon.c  */
+
+NTSTATUS rpccli_netlogon_setup_creds(struct rpc_pipe_client *cli,
+				const char *server_name,
+				const char *domain,
+				const char *clnt_name,
+				const char *machine_account,
+				const unsigned char machine_pwd[16],
+				uint32 sec_chan_type,
+				uint32 *neg_flags_inout);
+NTSTATUS rpccli_netlogon_logon_ctrl2(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                  uint32 query_level);
+WERROR rpccli_netlogon_getanydcname(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx, const char *mydcname,
+				    const char *domainname, fstring newdcname);
+NTSTATUS rpccli_netlogon_getdcname(struct rpc_pipe_client *cli,
+				   TALLOC_CTX *mem_ctx, const char *mydcname,
+				   const char *domainname, fstring newdcname);
+WERROR rpccli_netlogon_dsr_getdcname(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     const char *server_name,
+				     const char *domain_name,
+				     struct GUID *domain_guid,
+				     struct GUID *site_guid,
+				     uint32_t flags,
+				     struct DS_DOMAIN_CONTROLLER_INFO **info_out);
+WERROR rpccli_netlogon_dsr_getdcnameex(struct rpc_pipe_client *cli,
+				       TALLOC_CTX *mem_ctx,
+				       const char *server_name,
+				       const char *domain_name,
+				       struct GUID *domain_guid,
+				       const char *site_name,
+				       uint32_t flags,
+				       struct DS_DOMAIN_CONTROLLER_INFO **info_out);
+WERROR rpccli_netlogon_dsr_getdcnameex2(struct rpc_pipe_client *cli,
+					TALLOC_CTX *mem_ctx,
+					const char *server_name,
+					const char *client_account,
+					uint32 mask,
+					const char *domain_name,
+					struct GUID *domain_guid,
+					const char *site_name,
+					uint32_t flags,
+					struct DS_DOMAIN_CONTROLLER_INFO **info_out);
+WERROR rpccli_netlogon_dsr_getsitename(struct rpc_pipe_client *cli,
+				       TALLOC_CTX *mem_ctx,
+				       const char *computer_name,
+				       char **site_name);
+NTSTATUS rpccli_netlogon_sam_sync(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                               uint32 database_id, uint32 next_rid,  
uint32 *num_deltas,
+                               SAM_DELTA_HDR **hdr_deltas,
+                               SAM_DELTA_CTR **deltas);
+NTSTATUS rpccli_netlogon_sam_deltas(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                 uint32 database_id, uint64 seqnum,
+                                 uint32 *num_deltas,
+                                 SAM_DELTA_HDR **hdr_deltas,
+                                 SAM_DELTA_CTR **deltas);
+NTSTATUS rpccli_netlogon_sam_logon(struct rpc_pipe_client *cli,
+				   TALLOC_CTX *mem_ctx,
+				   uint32 logon_parameters,
+				   const char *domain,
+				   const char *username,
+				   const char *password,
+				   const char *workstation,
+				   int logon_type);
+NTSTATUS rpccli_netlogon_sam_network_logon(struct rpc_pipe_client *cli,
+					   TALLOC_CTX *mem_ctx,
+					   uint32 logon_parameters,
+					   const char *server,
+					   const char *username,
+					   const char *domain,
+					   const char *workstation,
+					   const uint8 chal[8],
+					   DATA_BLOB lm_response,
+					   DATA_BLOB nt_response,
+					   NET_USER_INFO_3 *info3);
+NTSTATUS rpccli_netlogon_sam_network_logon_ex(struct rpc_pipe_client  
*cli,
+					      TALLOC_CTX *mem_ctx,
+					      uint32 logon_parameters,
+					      const char *server,
+					      const char *username,
+					      const char *domain,
+					      const char *workstation,
+					      const uint8 chal[8],
+					      DATA_BLOB lm_response,
+					      DATA_BLOB nt_response,
+					      NET_USER_INFO_3 *info3);
+NTSTATUS rpccli_net_srv_pwset(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			   const char *machine_name, const uint8 hashed_mach_pwd[16]);
+
+/* The following definitions come from rpc_client/cli_pipe.c  */
+
+NTSTATUS rpc_api_pipe_req(struct rpc_pipe_client *cli,
+			uint8 op_num,
+			prs_struct *in_data,
+			prs_struct *out_data);
+struct rpc_pipe_client *cli_rpc_pipe_open_noauth(struct cli_state  
*cli, int pipe_idx, NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_ntlmssp(struct cli_state  
*cli,
+						int pipe_idx,
+						enum pipe_auth_level auth_level,
+						const char *domain,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_spnego_ntlmssp(struct  
cli_state *cli,
+						int pipe_idx,
+						enum pipe_auth_level auth_level,
+						const char *domain,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+struct rpc_pipe_client *get_schannel_session_key(struct cli_state *cli,
+							const char *domain,
+							uint32 *pneg_flags,
+							NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_schannel_with_key(struct  
cli_state *cli,
+					int pipe_idx,
+					enum pipe_auth_level auth_level,
+					const char *domain,
+					const struct dcinfo *pdc,
+					NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_ntlmssp_auth_schannel 
(struct cli_state *cli,
+                                                int pipe_idx,
+						enum pipe_auth_level auth_level,
+                                                const char *domain,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_schannel(struct cli_state  
*cli,
+                                                int pipe_idx,
+						enum pipe_auth_level auth_level,
+                                                const char *domain,
+						NTSTATUS *perr);
+struct rpc_pipe_client *cli_rpc_pipe_open_krb5(struct cli_state *cli,
+						int pipe_idx,
+						enum pipe_auth_level auth_level,
+						const char *service_princ,
+						const char *username,
+						const char *password,
+						NTSTATUS *perr);
+
+/* The following definitions come from rpc_client/cli_reg.c  */
+
+NTSTATUS rpccli_winreg_Connect(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                         uint32 reg_type, uint32 access_mask,
+                         POLICY_HND *reg_hnd);
+uint32 reg_init_regval_buffer( REGVAL_BUFFER *buf2, REGISTRY_VALUE  
*val );
+
+/* The following definitions come from rpc_client/cli_samr.c  */
+
+NTSTATUS rpccli_samr_connect(struct rpc_pipe_client *cli, TALLOC_CTX  
*mem_ctx,
+			     uint32 access_mask, POLICY_HND *connect_pol);
+NTSTATUS rpccli_samr_connect4(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			   uint32 access_mask, POLICY_HND *connect_pol);
+NTSTATUS rpccli_samr_close(struct rpc_pipe_client *cli, TALLOC_CTX  
*mem_ctx,
+			   POLICY_HND *connect_pol);
+NTSTATUS rpccli_samr_open_domain(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				 POLICY_HND *connect_pol, uint32 access_mask,
+				 const DOM_SID *domain_sid,
+				 POLICY_HND *domain_pol);
+NTSTATUS rpccli_samr_open_user(struct rpc_pipe_client *cli,
+			       TALLOC_CTX *mem_ctx,
+			       POLICY_HND *domain_pol, uint32 access_mask,
+			       uint32 user_rid, POLICY_HND *user_pol);
+NTSTATUS rpccli_samr_open_group(struct rpc_pipe_client *cli,
+				TALLOC_CTX *mem_ctx,
+				POLICY_HND *domain_pol, uint32 access_mask,
+				uint32 group_rid, POLICY_HND *group_pol);
+NTSTATUS rpccli_samr_create_dom_group(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				   POLICY_HND *domain_pol,
+				   const char *group_name,
+				   uint32 access_mask, POLICY_HND *group_pol);
+NTSTATUS rpccli_samr_add_groupmem(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			       POLICY_HND *group_pol, uint32 rid);
+NTSTATUS rpccli_samr_del_groupmem(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			       POLICY_HND *group_pol, uint32 rid);
+NTSTATUS rpccli_samr_query_userinfo(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    const POLICY_HND *user_pol,
+				    uint16 switch_value,
+				    SAM_USERINFO_CTR **ctr);
+NTSTATUS rpccli_samr_set_groupinfo(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				POLICY_HND *group_pol, GROUP_INFO_CTR *ctr);
+NTSTATUS rpccli_samr_query_groupinfo(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                  POLICY_HND *group_pol, uint32  
info_level,
+                                  GROUP_INFO_CTR **ctr);
+NTSTATUS rpccli_samr_query_usergroups(struct rpc_pipe_client *cli,
+				      TALLOC_CTX *mem_ctx,
+				      POLICY_HND *user_pol,
+				      uint32 *num_groups,
+				      DOM_GID **gid);
+NTSTATUS rpccli_samr_set_aliasinfo(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				POLICY_HND *alias_pol, ALIAS_INFO_CTR *ctr);
+NTSTATUS rpccli_samr_query_useraliases(struct rpc_pipe_client *cli,
+				       TALLOC_CTX *mem_ctx,
+				       POLICY_HND *dom_pol, uint32 num_sids,
+				       DOM_SID2 *sid,
+				       uint32 *num_aliases, uint32 **als_rids);
+NTSTATUS rpccli_samr_query_groupmem(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    POLICY_HND *group_pol, uint32 *num_mem,
+				    uint32 **rid, uint32 **attr);
+NTSTATUS rpccli_samr_enum_dom_users(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                 POLICY_HND *pol, uint32 *start_idx,  
uint32 acb_mask,
+                                 uint32 size, char ***dom_users,  
uint32 **rids,
+                                 uint32 *num_dom_users);
+NTSTATUS rpccli_samr_enum_dom_groups(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     POLICY_HND *pol, uint32 *start_idx,
+				     uint32 size, struct acct_info **dom_groups,
+				     uint32 *num_dom_groups);
+NTSTATUS rpccli_samr_enum_als_groups(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     POLICY_HND *pol, uint32 *start_idx,
+				     uint32 size, struct acct_info **dom_aliases,
+				     uint32 *num_dom_aliases);
+NTSTATUS rpccli_samr_query_aliasmem(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    POLICY_HND *alias_pol, uint32 *num_mem,
+				    DOM_SID **sids);
+NTSTATUS rpccli_samr_open_alias(struct rpc_pipe_client *cli,
+				TALLOC_CTX *mem_ctx,
+				POLICY_HND *domain_pol, uint32 access_mask,
+				uint32 alias_rid, POLICY_HND *alias_pol);
+NTSTATUS rpccli_samr_create_dom_alias(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				   POLICY_HND *domain_pol, const char *name,
+				   POLICY_HND *alias_pol);
+NTSTATUS rpccli_samr_add_aliasmem(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			       POLICY_HND *alias_pol, DOM_SID *member);
+NTSTATUS rpccli_samr_del_aliasmem(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			       POLICY_HND *alias_pol, DOM_SID *member);
+NTSTATUS rpccli_samr_query_alias_info(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				   POLICY_HND *alias_pol, uint16 switch_value,
+				   ALIAS_INFO_CTR *ctr);
+NTSTATUS rpccli_samr_query_dom_info(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    POLICY_HND *domain_pol,
+				    uint16 switch_value,
+				    SAM_UNK_CTR *ctr);
+NTSTATUS rpccli_samr_query_dom_info2(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     POLICY_HND *domain_pol,
+				     uint16 switch_value,
+				     SAM_UNK_CTR *ctr);
+NTSTATUS rpccli_samr_set_domain_info(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     POLICY_HND *domain_pol,
+				     uint16 switch_value,
+				     SAM_UNK_CTR *ctr);
+NTSTATUS rpccli_samr_chgpasswd_user(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    const char *username,
+				    const char *newpassword,
+				    const char *oldpassword );
+NTSTATUS rpccli_samr_chng_pswd_auth_crap(struct rpc_pipe_client *cli,
+					 TALLOC_CTX *mem_ctx,
+					 const char *username,
+					 DATA_BLOB new_nt_password,
+					 DATA_BLOB old_nt_hash_enc,
+					 DATA_BLOB new_lm_password,
+					 DATA_BLOB old_lm_hash_enc);
+NTSTATUS rpccli_samr_chgpasswd3(struct rpc_pipe_client *cli,
+				TALLOC_CTX *mem_ctx,
+				const char *username,
+				const char *newpassword,
+				const char *oldpassword,
+				SAM_UNK_INFO_1 *info,
+				SAMR_CHANGE_REJECT *reject);
+void get_query_dispinfo_params(int loop_count, uint32 *max_entries,
+			       uint32 *max_size);
+NTSTATUS rpccli_samr_query_dispinfo(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    POLICY_HND *domain_pol, uint32 *start_idx,
+				    uint16 switch_value, uint32 *num_entries,
+				    uint32 max_entries, uint32 max_size,
+				    SAM_DISPINFO_CTR *ctr);
+NTSTATUS rpccli_samr_query_dispinfo2(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     POLICY_HND *domain_pol, uint32 *start_idx,
+				     uint16 switch_value, uint32 *num_entries,
+				     uint32 max_entries, uint32 max_size,
+				     SAM_DISPINFO_CTR *ctr);
+NTSTATUS rpccli_samr_query_dispinfo3(struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx,
+				     POLICY_HND *domain_pol, uint32 *start_idx,
+				     uint16 switch_value, uint32 *num_entries,
+				     uint32 max_entries, uint32 max_size,
+				     SAM_DISPINFO_CTR *ctr);
+NTSTATUS rpccli_samr_get_dispenum_index(struct rpc_pipe_client *cli,
+					TALLOC_CTX *mem_ctx,
+					POLICY_HND *domain_pol,
+					uint16 switch_value,
+					const char *name,
+					uint32 *idx);
+NTSTATUS rpccli_samr_get_dispenum_index2(struct rpc_pipe_client *cli,
+					 TALLOC_CTX *mem_ctx,
+					 POLICY_HND *domain_pol,
+					 uint16 switch_value,
+					 const char *name,
+					 uint32 *idx);
+NTSTATUS rpccli_samr_lookup_rids(struct rpc_pipe_client *cli,
+				 TALLOC_CTX *mem_ctx,
+				 POLICY_HND *domain_pol,
+				 uint32 num_rids, uint32 *rids,
+				 uint32 *num_names, char ***names,
+				 uint32 **name_types);
+NTSTATUS rpccli_samr_lookup_names(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                               POLICY_HND *domain_pol, uint32 flags,
+                               uint32 num_names, const char **names,
+                               uint32 *num_rids, uint32 **rids,
+                               uint32 **rid_types);
+NTSTATUS rpccli_samr_create_dom_user(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                  POLICY_HND *domain_pol, const char  
*acct_name,
+                                  uint32 acb_info, uint32 unknown,
+                                  POLICY_HND *user_pol, uint32 *rid);
+NTSTATUS rpccli_samr_set_userinfo(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                               const POLICY_HND *user_pol, uint16  
switch_value,
+                               DATA_BLOB *sess_key, SAM_USERINFO_CTR  
*ctr);
+NTSTATUS rpccli_samr_set_userinfo2(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				   const POLICY_HND *user_pol, uint16 switch_value,
+                                DATA_BLOB *sess_key,  
SAM_USERINFO_CTR *ctr);
+NTSTATUS rpccli_samr_delete_dom_group(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                  POLICY_HND *group_pol);
+NTSTATUS rpccli_samr_delete_dom_alias(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                  POLICY_HND *alias_pol);
+NTSTATUS rpccli_samr_delete_dom_user(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                  POLICY_HND *user_pol);
+NTSTATUS rpccli_samr_remove_sid_foreign_domain(struct  
rpc_pipe_client *cli,
+					    TALLOC_CTX *mem_ctx,
+					    POLICY_HND *user_pol,
+					    DOM_SID *sid);
+NTSTATUS rpccli_samr_query_sec_obj(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                 POLICY_HND *user_pol, uint32 sec_info,
+                                 TALLOC_CTX *ctx, SEC_DESC_BUF  
**sec_desc_buf);
+NTSTATUS rpccli_samr_set_sec_obj(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                 POLICY_HND *user_pol, uint32 sec_info,
+                                 SEC_DESC_BUF *sec_desc_buf);
+NTSTATUS rpccli_samr_get_dom_pwinfo(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				 uint16 *min_pwd_length, uint32 *password_properties);
+NTSTATUS rpccli_samr_get_usrdom_pwinfo(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				       POLICY_HND *pol, uint16 *min_pwd_length,
+				       uint32 *password_properties, uint32 *unknown1);
+NTSTATUS rpccli_samr_lookup_domain(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				POLICY_HND *user_pol, char *domain_name,
+				DOM_SID *sid);
+
+/* The following definitions come from rpc_client/cli_spoolss.c  */
+
+WERROR rpccli_spoolss_open_printer_ex(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				const char *printername, const char *datatype, uint32  
access_required,
+				const char *station, const char *username, POLICY_HND *pol);
+WERROR rpccli_spoolss_close_printer(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				 POLICY_HND *pol);
+WERROR rpccli_spoolss_enum_printers(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				 char *name, uint32 flags, uint32 level,
+				 uint32 *num_printers, PRINTER_INFO_CTR *ctr);
+WERROR rpccli_spoolss_enum_ports(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			      uint32 level, uint32 *num_ports, PORT_INFO_CTR *ctr);
+WERROR rpccli_spoolss_getprinter(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			      POLICY_HND *pol, uint32 level,
+			      PRINTER_INFO_CTR *ctr);
+WERROR rpccli_spoolss_setprinter(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			      POLICY_HND *pol, uint32 level,
+			      PRINTER_INFO_CTR *ctr, uint32 command);
+WERROR rpccli_spoolss_getprinterdriver(struct rpc_pipe_client *cli,
+				    TALLOC_CTX *mem_ctx,
+				    POLICY_HND *pol, uint32 level,
+				    const char *env, int version, PRINTER_DRIVER_CTR *ctr);
+WERROR rpccli_spoolss_enumprinterdrivers (struct rpc_pipe_client *cli,
+				       TALLOC_CTX *mem_ctx,
+				       uint32 level, const char *env,
+				       uint32 *num_drivers,
+				       PRINTER_DRIVER_CTR *ctr);
+WERROR rpccli_spoolss_getprinterdriverdir (struct rpc_pipe_client *cli,
+					TALLOC_CTX *mem_ctx,
+					uint32 level, char *env,
+					DRIVER_DIRECTORY_CTR *ctr);
+WERROR rpccli_spoolss_addprinterdriver (struct rpc_pipe_client *cli,
+				     TALLOC_CTX *mem_ctx, uint32 level,
+				     PRINTER_DRIVER_CTR *ctr);
+WERROR rpccli_spoolss_addprinterex (struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				 uint32 level, PRINTER_INFO_CTR*ctr);
+WERROR rpccli_spoolss_deleteprinterdriverex(struct rpc_pipe_client  
*cli,
+                                         TALLOC_CTX *mem_ctx, const  
char *arch,
+                                         const char *driver, int  
version);
+WERROR rpccli_spoolss_deleteprinterdriver (struct rpc_pipe_client *cli,
+					TALLOC_CTX *mem_ctx, const char *arch,
+					const char *driver);
+WERROR rpccli_spoolss_getprintprocessordirectory(struct  
rpc_pipe_client *cli,
+					      TALLOC_CTX *mem_ctx,
+					      char *name, char *environment,
+					      fstring procdir);
+WERROR rpccli_spoolss_addform(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			   POLICY_HND *handle, uint32 level, FORM *form);
+WERROR rpccli_spoolss_setform(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			   POLICY_HND *handle, uint32 level,
+			   const char *form_name, FORM *form);
+WERROR rpccli_spoolss_getform(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			   POLICY_HND *handle, const char *formname,
+			   uint32 level, FORM_1 *form);
+WERROR rpccli_spoolss_deleteform(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			      POLICY_HND *handle, const char *form_name);
+WERROR rpccli_spoolss_enumforms(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			     POLICY_HND *handle, int level, uint32 *num_forms,
+			     FORM_1 **forms);
+WERROR rpccli_spoolss_enumjobs(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			    POLICY_HND *hnd, uint32 level, uint32 firstjob,
+			    uint32 num_jobs, uint32 *returned, JOB_INFO_CTR *ctr);
+WERROR rpccli_spoolss_setjob(struct rpc_pipe_client *cli, TALLOC_CTX  
*mem_ctx,
+			  POLICY_HND *hnd, uint32 jobid, uint32 level,
+			  uint32 command);
+WERROR rpccli_spoolss_getjob(struct rpc_pipe_client *cli, TALLOC_CTX  
*mem_ctx,
+			  POLICY_HND *hnd, uint32 jobid, uint32 level,
+			  JOB_INFO_CTR *ctr);
+WERROR rpccli_spoolss_startpageprinter(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				    POLICY_HND *hnd);
+WERROR rpccli_spoolss_endpageprinter(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				  POLICY_HND *hnd);
+WERROR rpccli_spoolss_startdocprinter(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				   POLICY_HND *hnd, char *docname,
+				   char *outputfile, char *datatype,
+				   uint32 *jobid);
+WERROR rpccli_spoolss_enddocprinter(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				  POLICY_HND *hnd);
+WERROR rpccli_spoolss_getprinterdata(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				  POLICY_HND *hnd, const char *valuename,
+				  REGISTRY_VALUE *value);
+WERROR rpccli_spoolss_getprinterdataex(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				    POLICY_HND *hnd, const char *keyname,
+				    const char *valuename,
+				    REGISTRY_VALUE *value);
+WERROR rpccli_spoolss_setprinterdata(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				  POLICY_HND *hnd, REGISTRY_VALUE *value);
+WERROR rpccli_spoolss_setprinterdataex(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				    POLICY_HND *hnd, char *keyname,
+				    REGISTRY_VALUE *value);
+WERROR rpccli_spoolss_enumprinterdata(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				   POLICY_HND *hnd, uint32 ndx,
+				   uint32 value_offered, uint32 data_offered,
+				   uint32 *value_needed, uint32 *data_needed,
+				   REGISTRY_VALUE *value);
+WERROR rpccli_spoolss_enumprinterdataex(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				     POLICY_HND *hnd, const char *keyname,
+				     REGVAL_CTR *ctr);
+WERROR rpccli_spoolss_writeprinter(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				POLICY_HND *hnd, uint32 data_size, char *data,
+				uint32 *num_written);
+WERROR rpccli_spoolss_deleteprinterdata(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				     POLICY_HND *hnd, char *valuename);
+WERROR rpccli_spoolss_deleteprinterdataex(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+				       POLICY_HND *hnd, char *keyname,
+				       char *valuename);
+WERROR rpccli_spoolss_enumprinterkey(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				  POLICY_HND *hnd, const char *keyname,
+				  uint16 **keylist, uint32 *len);
+WERROR rpccli_spoolss_deleteprinterkey(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+				    POLICY_HND *hnd, char *keyname);
+
+/* The following definitions come from rpc_client/ 
cli_spoolss_notify.c  */
+
+WERROR rpccli_spoolss_reply_open_printer(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+				      const char *printer, uint32 printerlocal, uint32 type,
+				      POLICY_HND *handle);
+WERROR rpccli_spoolss_reply_close_printer(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+				       POLICY_HND *handle);
+WERROR rpccli_spoolss_routerreplyprinter(struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+				      POLICY_HND *pol, uint32 condition, uint32 change_id);
+WERROR rpccli_spoolss_rrpcn(struct rpc_pipe_client *cli, TALLOC_CTX  
*mem_ctx,
+			 POLICY_HND *pol, uint32 notify_data_len,
+			 SPOOL_NOTIFY_INFO_DATA *notify_data,
+			 uint32 change_low, uint32 change_high);
+WERROR rpccli_spoolss_rffpcnex(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+			    POLICY_HND *pol, uint32 flags, uint32 options,
+			    const char *localmachine, uint32 printerlocal,
+			    SPOOL_NOTIFY_OPTION *option);
+
+/* The following definitions come from rpc_client/cli_svcctl.c  */
+
+const char* svc_status_string( uint32 state );
+WERROR rpccli_svcctl_open_scm(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                              POLICY_HND *hSCM, uint32  
access_desired );
+WERROR rpccli_svcctl_open_service( struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                POLICY_HND *hSCM, POLICY_HND *hService,
+				const char *servicename, uint32 access_desired );
+WERROR rpccli_svcctl_enumerate_services( struct rpc_pipe_client  
*cli, TALLOC_CTX *mem_ctx,
+                                      POLICY_HND *hSCM, uint32 type,  
uint32 state,
+				      uint32 *returned, ENUM_SERVICES_STATUS **service_array  );
+WERROR rpccli_svcctl_query_status( struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                POLICY_HND *hService, SERVICE_STATUS  
*status );
+WERROR rpccli_svcctl_query_config(struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                POLICY_HND *hService, SERVICE_CONFIG  
*config );
+WERROR rpccli_svcctl_start_service( struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                 POLICY_HND *hService,
+                                 const char **parm_array, uint32  
parmcount );
+WERROR rpccli_svcctl_control_service( struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                   POLICY_HND *hService, uint32  
control,
+				   SERVICE_STATUS *status );
+WERROR rpccli_svcctl_get_dispname( struct rpc_pipe_client *cli,  
TALLOC_CTX *mem_ctx,
+                                POLICY_HND *hService, fstring  
displayname );
+
+/* The following definitions come from rpc_client/ndr.c  */
+
+NTSTATUS cli_do_rpc_ndr(struct rpc_pipe_client *cli, TALLOC_CTX  
*mem_ctx,
+			int p_idx, int opnum, void *data,
+			ndr_pull_flags_fn_t pull_fn, ndr_push_flags_fn_t push_fn);
+
+/* The following definitions come from rpc_parse/parse_buffer.c  */
+
+void rpcbuf_init(RPC_BUFFER *buffer, uint32 size, TALLOC_CTX *ctx);
+BOOL prs_rpcbuffer(const char *desc, prs_struct *ps, int depth,  
RPC_BUFFER *buffer);
+BOOL prs_rpcbuffer_p(const char *desc, prs_struct *ps, int depth,  
RPC_BUFFER **buffer);
+BOOL rpcbuf_alloc_size(RPC_BUFFER *buffer, uint32 buffer_size);
+void rpcbuf_move(RPC_BUFFER *src, RPC_BUFFER **dest);
+uint32 rpcbuf_get_size(RPC_BUFFER *buffer);
+BOOL smb_io_relstr(const char *desc, RPC_BUFFER *buffer, int depth,  
UNISTR *string);
+BOOL smb_io_relarraystr(const char *desc, RPC_BUFFER *buffer, int  
depth, uint16 **string);
+BOOL smb_io_relsecdesc(const char *desc, RPC_BUFFER *buffer, int  
depth, SEC_DESC **secdesc);
+uint32 size_of_relative_string(UNISTR *string);
+
+/* The following definitions come from rpc_parse/parse_ds.c  */
+
+BOOL ds_io_q_getprimdominfo( const char *desc, DS_Q_GETPRIMDOMINFO  
*q_u, prs_struct *ps, int depth);
+BOOL ds_io_r_getprimdominfo( const char *desc, DS_R_GETPRIMDOMINFO  
*r_u, prs_struct *ps, int depth);
+BOOL init_q_ds_enum_domain_trusts( DS_Q_ENUM_DOM_TRUSTS *q, const  
char *server, uint32 flags );
+BOOL ds_io_q_enum_domain_trusts( const char *desc,  
DS_Q_ENUM_DOM_TRUSTS *q_u, prs_struct *ps, int depth);
+BOOL ds_io_r_enum_domain_trusts( const char *desc,  
DS_R_ENUM_DOM_TRUSTS *r_u, prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_eventlog.c  */
+
+BOOL prs_ev_open_unknown0( const char *desc, prs_struct *ps, int  
depth, EVENTLOG_OPEN_UNKNOWN0 *u );
+BOOL eventlog_io_q_open_eventlog(const char *desc,  
EVENTLOG_Q_OPEN_EVENTLOG *q_u,
+				 prs_struct *ps, int depth);
+BOOL eventlog_io_r_open_eventlog(const char *desc,  
EVENTLOG_R_OPEN_EVENTLOG *r_u,
+				 prs_struct *ps, int depth);
+BOOL eventlog_io_q_get_num_records(const char *desc,  
EVENTLOG_Q_GET_NUM_RECORDS *q_u,
+				   prs_struct *ps, int depth);
+BOOL eventlog_io_r_get_num_records(const char *desc,  
EVENTLOG_R_GET_NUM_RECORDS *r_u,
+				   prs_struct *ps, int depth);
+BOOL eventlog_io_q_get_oldest_entry(const char *desc,  
EVENTLOG_Q_GET_OLDEST_ENTRY *q_u,
+				    prs_struct *ps, int depth);
+BOOL eventlog_io_r_get_oldest_entry(const char *desc,  
EVENTLOG_R_GET_OLDEST_ENTRY *r_u,
+				    prs_struct *ps, int depth);
+BOOL eventlog_io_q_read_eventlog(const char *desc,  
EVENTLOG_Q_READ_EVENTLOG *q_u,
+				 prs_struct *ps, int depth);
+BOOL eventlog_io_r_read_eventlog(const char *desc,
+				 EVENTLOG_Q_READ_EVENTLOG *q_u,
+				 EVENTLOG_R_READ_EVENTLOG *r_u,
+				 prs_struct *ps,
+				 int depth);
+BOOL eventlog_io_q_clear_eventlog(const char *desc,  
EVENTLOG_Q_CLEAR_EVENTLOG *q_u,
+				  prs_struct *ps, int depth);
+BOOL eventlog_io_r_clear_eventlog(const char *desc,  
EVENTLOG_R_CLEAR_EVENTLOG *r_u,
+				  prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_lsa.c  */
+
+void init_lsa_trans_name(LSA_TRANS_NAME *trn, UNISTR2 *uni_name,
+			 uint16 sid_name_use, const char *name, uint32 idx);
+void init_lsa_trans_name2(LSA_TRANS_NAME2 *trn, UNISTR2 *uni_name,
+			 uint16 sid_name_use, const char *name, uint32 idx);
+void init_lsa_sec_qos(LSA_SEC_QOS *qos, uint16 imp_lev, uint8 ctxt,  
uint8 eff);
+void init_q_open_pol(LSA_Q_OPEN_POL *in, uint16 system_name,
+		     uint32 attributes, uint32 desired_access,
+		     LSA_SEC_QOS *qos);
+BOOL lsa_io_q_open_pol(const char *desc, LSA_Q_OPEN_POL *in,  
prs_struct *ps,
+		       int depth);
+BOOL lsa_io_r_open_pol(const char *desc, LSA_R_OPEN_POL *out,  
prs_struct *ps,
+		       int depth);
+void init_q_open_pol2(LSA_Q_OPEN_POL2 *in, const char *server_name,
+			uint32 attributes, uint32 desired_access,
+			LSA_SEC_QOS *qos);
+BOOL lsa_io_q_open_pol2(const char *desc, LSA_Q_OPEN_POL2 *in,  
prs_struct *ps,
+			int depth);
+BOOL lsa_io_r_open_pol2(const char *desc, LSA_R_OPEN_POL2 *out,  
prs_struct *ps,
+			int depth);
+void init_q_query_sec_obj(LSA_Q_QUERY_SEC_OBJ *in, const POLICY_HND  
*hnd,
+			  uint32 sec_info);
+BOOL lsa_io_q_query_sec_obj(const char *desc, LSA_Q_QUERY_SEC_OBJ *in,
+			    prs_struct *ps, int depth);
+BOOL lsa_io_r_query_sec_obj(const char *desc, LSA_R_QUERY_SEC_OBJ  
*out, prs_struct *ps, int depth);
+void init_q_query(LSA_Q_QUERY_INFO *in, POLICY_HND *hnd, uint16  
info_class);
+BOOL lsa_io_q_query(const char *desc, LSA_Q_QUERY_INFO *in,  
prs_struct *ps,
+		    int depth);
+BOOL init_q_enum_trust_dom(LSA_Q_ENUM_TRUST_DOM * q_e, POLICY_HND *pol,
+			   uint32 enum_context, uint32 preferred_len);
+BOOL lsa_io_q_enum_trust_dom(const char *desc, LSA_Q_ENUM_TRUST_DOM  
*q_e,
+			     prs_struct *ps, int depth);
+void init_r_enum_trust_dom(TALLOC_CTX *ctx, LSA_R_ENUM_TRUST_DOM *out,
+			   uint32 enum_context, uint32 num_domains,
+			   struct trustdom_info **td);
+BOOL lsa_io_domain_list( const char *desc, prs_struct *ps, int  
depth, DOMAIN_LIST *domlist );
+BOOL lsa_io_r_enum_trust_dom(const char *desc, LSA_R_ENUM_TRUST_DOM  
*out,
+			     prs_struct *ps, int depth);
+BOOL lsa_io_dom_query_12(const char *desc, DOM_QUERY_12 *info,  
prs_struct *ps, int depth);
+void init_q_set(LSA_Q_SET_INFO *in, POLICY_HND *hnd, uint16  
info_class, LSA_INFO_CTR ctr);
+BOOL lsa_io_r_query(const char *desc, LSA_R_QUERY_INFO *out,  
prs_struct *ps, int depth);
+BOOL lsa_io_q_set(const char *desc, LSA_Q_SET_INFO *in, prs_struct *ps,
+		  int depth);
+BOOL lsa_io_r_set(const char *desc, LSA_R_SET_INFO *out, prs_struct  
*ps, int depth);
+void init_q_lookup_sids(TALLOC_CTX *mem_ctx, LSA_Q_LOOKUP_SIDS *q_l,
+			POLICY_HND *hnd, int num_sids, const DOM_SID *sids,
+			uint16 level);
+BOOL lsa_io_q_lookup_sids(const char *desc, LSA_Q_LOOKUP_SIDS *q_s,  
prs_struct *ps,
+			  int depth);
+BOOL lsa_io_q_lookup_sids2(const char *desc, LSA_Q_LOOKUP_SIDS2  
*q_s, prs_struct *ps,
+			  int depth);
+BOOL lsa_io_q_lookup_sids3(const char *desc, LSA_Q_LOOKUP_SIDS3  
*q_s, prs_struct *ps,
+			  int depth);
+BOOL lsa_io_r_lookup_sids(const char *desc, LSA_R_LOOKUP_SIDS *r_s,
+			  prs_struct *ps, int depth);
+BOOL lsa_io_r_lookup_sids2(const char *desc, LSA_R_LOOKUP_SIDS2 *r_s,
+			  prs_struct *ps, int depth);
+BOOL lsa_io_r_lookup_sids3(const char *desc, LSA_R_LOOKUP_SIDS3 *r_s,
+			  prs_struct *ps, int depth);
+void init_q_lookup_names(TALLOC_CTX *mem_ctx, LSA_Q_LOOKUP_NAMES *q_l,
+			 POLICY_HND *hnd, int num_names, const char **names);
+BOOL lsa_io_q_lookup_names(const char *desc, LSA_Q_LOOKUP_NAMES *q_r,
+			   prs_struct *ps, int depth);
+BOOL lsa_io_r_lookup_names(const char *desc, LSA_R_LOOKUP_NAMES  
*out, prs_struct *ps, int depth);
+BOOL lsa_io_q_lookup_names2(const char *desc, LSA_Q_LOOKUP_NAMES2 *q_r,
+			   prs_struct *ps, int depth);
+BOOL lsa_io_r_lookup_names2(const char *desc, LSA_R_LOOKUP_NAMES2  
*out, prs_struct *ps, int depth);
+BOOL smb_io_lsa_translated_sids3(const char *desc,  
LSA_TRANSLATED_SID3 *q_r,
+			   prs_struct *ps, int depth);
+BOOL lsa_io_q_lookup_names3(const char *desc, LSA_Q_LOOKUP_NAMES3 *q_r,
+			   prs_struct *ps, int depth);
+BOOL lsa_io_r_lookup_names3(const char *desc, LSA_R_LOOKUP_NAMES3  
*out, prs_struct *ps, int depth);
+BOOL lsa_io_q_lookup_names4(const char *desc, LSA_Q_LOOKUP_NAMES4 *q_r,
+			   prs_struct *ps, int depth);
+BOOL lsa_io_r_lookup_names4(const char *desc, LSA_R_LOOKUP_NAMES4  
*out, prs_struct *ps, int depth);
+void init_lsa_q_close(LSA_Q_CLOSE *in, POLICY_HND *hnd);
+BOOL lsa_io_q_close(const char *desc, LSA_Q_CLOSE *in, prs_struct  
*ps, int depth);
+BOOL lsa_io_r_close(const char *desc,  LSA_R_CLOSE *out, prs_struct  
*ps, int depth);
+BOOL lsa_io_q_open_secret(const char *desc, LSA_Q_OPEN_SECRET *in,  
prs_struct *ps, int depth);
+BOOL lsa_io_r_open_secret(const char *desc, LSA_R_OPEN_SECRET *out,  
prs_struct *ps, int depth);
+void init_q_enum_privs(LSA_Q_ENUM_PRIVS *in, POLICY_HND *hnd, uint32  
enum_context, uint32 pref_max_length);
+BOOL lsa_io_q_enum_privs(const char *desc, LSA_Q_ENUM_PRIVS *in,  
prs_struct *ps, int depth);
+void init_lsa_r_enum_privs(LSA_R_ENUM_PRIVS *out, uint32 enum_context,
+			  uint32 count, LSA_PRIV_ENTRY *entries);
+BOOL lsa_io_r_enum_privs(const char *desc, LSA_R_ENUM_PRIVS *out,  
prs_struct *ps, int depth);
+void init_lsa_priv_get_dispname(LSA_Q_PRIV_GET_DISPNAME *trn,  
POLICY_HND *hnd, const char *name, uint16 lang_id, uint16 lang_id_sys);
+BOOL lsa_io_q_priv_get_dispname(const char *desc,  
LSA_Q_PRIV_GET_DISPNAME *in, prs_struct *ps, int depth);
+BOOL lsa_io_r_priv_get_dispname(const char *desc,  
LSA_R_PRIV_GET_DISPNAME *out, prs_struct *ps, int depth);
+void init_lsa_q_enum_accounts(LSA_Q_ENUM_ACCOUNTS *trn, POLICY_HND  
*hnd, uint32 enum_context, uint32 pref_max_length);
+BOOL lsa_io_q_enum_accounts(const char *desc, LSA_Q_ENUM_ACCOUNTS  
*in, prs_struct *ps, int depth);
+void init_lsa_r_enum_accounts(LSA_R_ENUM_ACCOUNTS *out, uint32  
enum_context);
+BOOL lsa_io_r_enum_accounts(const char *desc, LSA_R_ENUM_ACCOUNTS  
*out, prs_struct *ps, int depth);
+BOOL lsa_io_q_unk_get_connuser(const char *desc,  
LSA_Q_UNK_GET_CONNUSER *in, prs_struct *ps, int depth);
+BOOL lsa_io_r_unk_get_connuser(const char *desc,  
LSA_R_UNK_GET_CONNUSER *out, prs_struct *ps, int depth);
+void init_lsa_q_create_account(LSA_Q_CREATEACCOUNT *trn, POLICY_HND  
*hnd, DOM_SID *sid, uint32 desired_access);
+BOOL lsa_io_q_create_account(const char *desc, LSA_Q_CREATEACCOUNT  
*out, prs_struct *ps, int depth);
+BOOL lsa_io_r_create_account(const char *desc, LSA_R_CREATEACCOUNT   
*out, prs_struct *ps, int depth);
+void init_lsa_q_open_account(LSA_Q_OPENACCOUNT *trn, POLICY_HND  
*hnd, DOM_SID *sid, uint32 desired_access);
+BOOL lsa_io_q_open_account(const char *desc, LSA_Q_OPENACCOUNT *out,  
prs_struct *ps, int depth);
+BOOL lsa_io_r_open_account(const char *desc, LSA_R_OPENACCOUNT   
*out, prs_struct *ps, int depth);
+void init_lsa_q_enum_privsaccount(LSA_Q_ENUMPRIVSACCOUNT *trn,  
POLICY_HND *hnd);
+BOOL lsa_io_q_enum_privsaccount(const char *desc,  
LSA_Q_ENUMPRIVSACCOUNT *out, prs_struct *ps, int depth);
+NTSTATUS init_lsa_r_enum_privsaccount(TALLOC_CTX *mem_ctx,  
LSA_R_ENUMPRIVSACCOUNT *out, LUID_ATTR *set, uint32 count, uint32  
control);
+BOOL lsa_io_r_enum_privsaccount(const char *desc,  
LSA_R_ENUMPRIVSACCOUNT *out, prs_struct *ps, int depth);
+BOOL lsa_io_q_getsystemaccount(const char *desc,  
LSA_Q_GETSYSTEMACCOUNT  *out, prs_struct *ps, int depth);
+BOOL lsa_io_r_getsystemaccount(const char *desc,  
LSA_R_GETSYSTEMACCOUNT  *out, prs_struct *ps, int depth);
+BOOL lsa_io_q_setsystemaccount(const char *desc,  
LSA_Q_SETSYSTEMACCOUNT  *out, prs_struct *ps, int depth);
+BOOL lsa_io_r_setsystemaccount(const char *desc,  
LSA_R_SETSYSTEMACCOUNT  *out, prs_struct *ps, int depth);
+void init_lsa_string( LSA_STRING *uni, const char *string );
+void init_lsa_q_lookup_priv_value(LSA_Q_LOOKUP_PRIV_VALUE *q_u,  
POLICY_HND *hnd, const char *name);
+BOOL smb_io_lsa_string( const char *desc, LSA_STRING *string,  
prs_struct *ps, int depth );
+BOOL lsa_io_q_lookup_priv_value(const char *desc,  
LSA_Q_LOOKUP_PRIV_VALUE  *out, prs_struct *ps, int depth);
+BOOL lsa_io_r_lookup_priv_value(const char *desc,  
LSA_R_LOOKUP_PRIV_VALUE  *out, prs_struct *ps, int depth);
+BOOL lsa_io_q_addprivs(const char *desc, LSA_Q_ADDPRIVS *out,  
prs_struct *ps, int depth);
+BOOL lsa_io_r_addprivs(const char *desc, LSA_R_ADDPRIVS *out,  
prs_struct *ps, int depth);
+BOOL lsa_io_q_removeprivs(const char *desc, LSA_Q_REMOVEPRIVS *out,  
prs_struct *ps, int depth);
+BOOL lsa_io_r_removeprivs(const char *desc, LSA_R_REMOVEPRIVS *out,  
prs_struct *ps, int depth);
+BOOL policy_handle_is_valid(const POLICY_HND *hnd);
+void init_q_query2(LSA_Q_QUERY_INFO2 *in, POLICY_HND *hnd, uint16  
info_class);
+BOOL lsa_io_q_query_info2(const char *desc, LSA_Q_QUERY_INFO2 *in,  
prs_struct *ps, int depth);
+BOOL lsa_io_r_query_info2(const char *desc, LSA_R_QUERY_INFO2 *out,
+			  prs_struct *ps, int depth);
+void init_q_enum_acct_rights(LSA_Q_ENUM_ACCT_RIGHTS *in,
+			     POLICY_HND *hnd,
+			     uint32 count,
+			     DOM_SID *sid);
+NTSTATUS init_r_enum_acct_rights( LSA_R_ENUM_ACCT_RIGHTS *out,  
PRIVILEGE_SET *privileges );
+BOOL lsa_io_q_enum_acct_rights(const char *desc,  
LSA_Q_ENUM_ACCT_RIGHTS *in, prs_struct *ps, int depth);
+BOOL lsa_io_r_enum_acct_rights(const char *desc,  
LSA_R_ENUM_ACCT_RIGHTS *out, prs_struct *ps, int depth);
+void init_q_add_acct_rights( LSA_Q_ADD_ACCT_RIGHTS *in, POLICY_HND  
*hnd,
+                             DOM_SID *sid, uint32 count, const char  
**rights );
+BOOL lsa_io_q_add_acct_rights(const char *desc,  
LSA_Q_ADD_ACCT_RIGHTS *in, prs_struct *ps, int depth);
+BOOL lsa_io_r_add_acct_rights(const char *desc,  
LSA_R_ADD_ACCT_RIGHTS *out, prs_struct *ps, int depth);
+void init_q_remove_acct_rights(LSA_Q_REMOVE_ACCT_RIGHTS *in,
+			       POLICY_HND *hnd,
+			       DOM_SID *sid,
+			       uint32 removeall,
+			       uint32 count,
+			       const char **rights);
+BOOL lsa_io_q_remove_acct_rights(const char *desc,  
LSA_Q_REMOVE_ACCT_RIGHTS *in, prs_struct *ps, int depth);
+BOOL lsa_io_r_remove_acct_rights(const char *desc,  
LSA_R_REMOVE_ACCT_RIGHTS *out, prs_struct *ps, int depth);
+void init_lsa_q_open_trusted_domain(LSA_Q_OPEN_TRUSTED_DOMAIN *q,  
POLICY_HND *hnd, DOM_SID *sid, uint32 desired_access);
+BOOL lsa_io_q_open_trusted_domain(const char *desc,  
LSA_Q_OPEN_TRUSTED_DOMAIN *in, prs_struct *ps, int depth);
+void init_lsa_q_open_trusted_domain_by_name 
(LSA_Q_OPEN_TRUSTED_DOMAIN_BY_NAME *q,
+					    POLICY_HND *hnd,
+					    const char *name,
+					    uint32 desired_access);
+BOOL lsa_io_q_open_trusted_domain_by_name(const char *desc,  
LSA_Q_OPEN_TRUSTED_DOMAIN_BY_NAME *q_o, prs_struct *ps, int depth);
+BOOL lsa_io_r_open_trusted_domain_by_name(const char *desc,  
LSA_R_OPEN_TRUSTED_DOMAIN_BY_NAME *out, prs_struct *ps, int depth);
+BOOL lsa_io_q_open_trusted_domain(const char *desc,  
LSA_Q_OPEN_TRUSTED_DOMAIN *q_o, prs_struct *ps, int depth);
+BOOL lsa_io_r_open_trusted_domain(const char *desc,  
LSA_R_OPEN_TRUSTED_DOMAIN *out, prs_struct *ps, int depth);
+BOOL lsa_io_q_create_trusted_domain(const char *desc,  
LSA_Q_CREATE_TRUSTED_DOMAIN *in, prs_struct *ps, int depth);
+BOOL lsa_io_r_create_trusted_domain(const char *desc,  
LSA_R_CREATE_TRUSTED_DOMAIN *out, prs_struct *ps, int depth);
+BOOL lsa_io_q_create_secret(const char *desc, LSA_Q_CREATE_SECRET  
*in, prs_struct *ps, int depth);
+BOOL lsa_io_r_create_secret(const char *desc, LSA_R_CREATE_SECRET  
*out, prs_struct *ps, int depth);
+BOOL lsa_io_q_set_secret(const char *desc, LSA_Q_SET_SECRET *in,  
prs_struct *ps, int depth);
+BOOL lsa_io_r_set_secret(const char *desc, LSA_R_SET_SECRET *out,  
prs_struct *ps, int depth);
+BOOL lsa_io_q_delete_object(const char *desc, LSA_Q_DELETE_OBJECT  
*in, prs_struct *ps, int depth);
+BOOL lsa_io_r_delete_object(const char *desc, LSA_R_DELETE_OBJECT  
*out, prs_struct *ps, int depth);
+void init_q_query_trusted_domain_info 
(LSA_Q_QUERY_TRUSTED_DOMAIN_INFO *q,
+				      POLICY_HND *hnd, uint16 info_class) ;
+void init_q_query_trusted_domain_info_by_name 
(LSA_Q_QUERY_TRUSTED_DOMAIN_INFO_BY_NAME *q,
+					      POLICY_HND *hnd, uint16 info_class,
+					      const char *dom_name);
+void init_q_query_trusted_domain_info_by_sid 
(LSA_Q_QUERY_TRUSTED_DOMAIN_INFO_BY_SID *q,
+					     POLICY_HND *hnd, uint16 info_class,
+					     DOM_SID *dom_sid);
+BOOL lsa_io_q_query_trusted_domain_info(const char *desc,
+					LSA_Q_QUERY_TRUSTED_DOMAIN_INFO *q_q,
+					prs_struct *ps, int depth);
+BOOL lsa_io_q_query_trusted_domain_info_by_sid(const char *desc,
+					       LSA_Q_QUERY_TRUSTED_DOMAIN_INFO_BY_SID *q_q,
+					       prs_struct *ps, int depth);
+BOOL lsa_io_q_query_trusted_domain_info_by_name(const char *desc,
+					        LSA_Q_QUERY_TRUSTED_DOMAIN_INFO_BY_NAME *q_q,
+					        prs_struct *ps, int depth);
+BOOL lsa_io_r_query_trusted_domain_info(const char *desc,
+					LSA_R_QUERY_TRUSTED_DOMAIN_INFO *r_q,
+					prs_struct *ps, int depth);
+void init_q_query_dom_info(LSA_Q_QUERY_DOM_INFO_POLICY *in,  
POLICY_HND *hnd, uint16 info_class);
+BOOL lsa_io_q_query_dom_info(const char *desc,  
LSA_Q_QUERY_DOM_INFO_POLICY *in, prs_struct *ps, int depth);
+BOOL lsa_io_r_query_dom_info(const char *desc,  
LSA_R_QUERY_DOM_INFO_POLICY *out,
+			     prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_misc.c  */
+
+void set_current_rpc_talloc( TALLOC_CTX *ctx);
+void main_loop_TALLOC_FREE(void);
+TALLOC_CTX *main_loop_talloc_get(void);
+TALLOC_CTX *get_talloc_ctx(void);
+BOOL smb_io_time(const char *desc, NTTIME *nttime, prs_struct *ps,  
int depth);
+BOOL smb_io_nttime(const char *desc, prs_struct *ps, int depth,  
NTTIME *nttime);
+BOOL smb_io_dom_sid(const char *desc, DOM_SID *sid, prs_struct *ps,  
int depth);
+void init_dom_sid2(DOM_SID2 *sid2, const DOM_SID *sid);
+BOOL smb_io_dom_sid2_p(const char *desc, prs_struct *ps, int depth,  
DOM_SID2 **sid2);
+BOOL smb_io_dom_sid2(const char *desc, DOM_SID2 *sid, prs_struct  
*ps, int depth);
+BOOL smb_io_uuid(const char *desc, struct GUID *uuid,
+		 prs_struct *ps, int depth);
+void init_str_hdr(STRHDR *hdr, int max_len, int len, uint32 buffer);
+BOOL smb_io_strhdr(const char *desc,  STRHDR *hdr, prs_struct *ps,  
int depth);
+void init_uni_hdr(UNIHDR *hdr, UNISTR2 *str2);
+BOOL smb_io_unihdr(const char *desc, UNIHDR *hdr, prs_struct *ps,  
int depth);
+void init_buf_hdr(BUFHDR *hdr, int max_len, int len);
+BOOL smb_io_hdrbuf_pre(const char *desc, BUFHDR *hdr, prs_struct  
*ps, int depth, uint32 *offset);
+BOOL smb_io_hdrbuf_post(const char *desc, BUFHDR *hdr, prs_struct  
*ps, int depth,
+				uint32 ptr_hdrbuf, uint32 max_len, uint32 len);
+BOOL smb_io_hdrbuf(const char *desc, BUFHDR *hdr, prs_struct *ps,  
int depth);
+void init_unistr(UNISTR *str, const char *buf);
+BOOL smb_io_unistr(const char *desc, UNISTR *uni, prs_struct *ps,  
int depth);
+void init_rpc_blob_uint32(RPC_DATA_BLOB *str, uint32 val);
+void init_rpc_blob_str(RPC_DATA_BLOB *str, const char *buf, int len);
+void init_rpc_blob_hex(RPC_DATA_BLOB *str, const char *buf);
+void init_rpc_blob_bytes(RPC_DATA_BLOB *str, uint8 *buf, size_t len);
+BOOL smb_io_buffer5(const char *desc, BUFFER5 *buf5, prs_struct *ps,  
int depth);
+void init_regval_buffer(REGVAL_BUFFER *str, const uint8 *buf, size_t  
len);
+BOOL smb_io_regval_buffer(const char *desc, prs_struct *ps, int  
depth, REGVAL_BUFFER *buf2);
+void init_buf_unistr2(UNISTR2 *str, uint32 *ptr, const char *buf);
+void copy_unistr2(UNISTR2 *str, const UNISTR2 *from);
+void init_string2(STRING2 *str, const char *buf, size_t max_len,  
size_t str_len);
+BOOL smb_io_string2(const char *desc, STRING2 *str2, uint32 buffer,  
prs_struct *ps, int depth);
+void init_unistr2(UNISTR2 *str, const char *buf, enum  
unistr2_term_codes flags);
+void init_unistr4(UNISTR4 *uni4, const char *buf, enum  
unistr2_term_codes flags);
+void init_unistr4_w( TALLOC_CTX *ctx, UNISTR4 *uni4, const  
smb_ucs2_t *buf );
+void init_unistr2_w(TALLOC_CTX *ctx, UNISTR2 *str, const smb_ucs2_t  
*buf);
+void init_unistr2_from_unistr(UNISTR2 *to, const UNISTR *from);
+void init_unistr2_from_datablob(UNISTR2 *str, DATA_BLOB *blob) ;
+BOOL prs_io_unistr2_p(const char *desc, prs_struct *ps, int depth,  
UNISTR2 **uni2);
+BOOL prs_io_unistr2(const char *desc, prs_struct *ps, int depth,  
UNISTR2 *uni2 );
+BOOL smb_io_unistr2(const char *desc, UNISTR2 *uni2, uint32 buffer,  
prs_struct *ps, int depth);
+BOOL prs_unistr4(const char *desc, prs_struct *ps, int depth,  
UNISTR4 *uni4);
+BOOL prs_unistr4_hdr(const char *desc, prs_struct *ps, int depth,  
UNISTR4 *uni4);
+BOOL prs_unistr4_str(const char *desc, prs_struct *ps, int depth,  
UNISTR4 *uni4);
+BOOL prs_unistr4_array(const char *desc, prs_struct *ps, int depth,  
UNISTR4_ARRAY *array );
+BOOL init_unistr4_array( UNISTR4_ARRAY *array, uint32 count, const  
char **strings );
+BOOL smb_io_lockout_string_hdr(const char *desc, HDR_LOCKOUT_STRING  
*hdr_account_lockout, prs_struct *ps, int depth);
+BOOL smb_io_account_lockout_str(const char *desc, LOCKOUT_STRING  
*account_lockout, uint32 buffer, prs_struct *ps, int depth);
+void init_dom_rid(DOM_RID *prid, uint32 rid, uint16 type, uint32 idx);
+BOOL smb_io_dom_rid(const char *desc, DOM_RID *rid, prs_struct *ps,  
int depth);
+BOOL smb_io_dom_rid2(const char *desc, DOM_RID2 *rid, prs_struct  
*ps, int depth);
+void init_dom_rid3(DOM_RID3 *rid3, uint32 rid, uint8 type);
+BOOL smb_io_dom_rid3(const char *desc, DOM_RID3 *rid3, prs_struct  
*ps, int depth);
+void init_dom_rid4(DOM_RID4 *rid4, uint16 unknown, uint16 attr,  
uint32 rid);
+void init_clnt_srv(DOM_CLNT_SRV *logcln, const char *logon_srv,
+		   const char *comp_name);
+BOOL smb_io_clnt_srv(const char *desc, DOM_CLNT_SRV *logcln,  
prs_struct *ps, int depth);
+void init_log_info(DOM_LOG_INFO *loginfo, const char *logon_srv,  
const char *acct_name,
+		uint16 sec_chan, const char *comp_name);
+BOOL smb_io_log_info(const char *desc, DOM_LOG_INFO *loginfo,  
prs_struct *ps, int depth);
+BOOL smb_io_chal(const char *desc, DOM_CHAL *chal, prs_struct *ps,  
int depth);
+BOOL smb_io_cred(const char *desc,  DOM_CRED *cred, prs_struct *ps,  
int depth);
+void init_clnt_info2(DOM_CLNT_INFO2 *clnt,
+				const char *logon_srv, const char *comp_name,
+				const DOM_CRED *clnt_cred);
+BOOL smb_io_clnt_info2(const char *desc, DOM_CLNT_INFO2 *clnt,  
prs_struct *ps, int depth);
+void init_clnt_info(DOM_CLNT_INFO *clnt,
+		const char *logon_srv, const char *acct_name,
+		uint16 sec_chan, const char *comp_name,
+		const DOM_CRED *cred);
+BOOL smb_io_clnt_info(const char *desc,  DOM_CLNT_INFO *clnt,  
prs_struct *ps, int depth);
+void init_logon_id(DOM_LOGON_ID *logonid, uint32 log_id_low, uint32  
log_id_high);
+BOOL smb_io_logon_id(const char *desc, DOM_LOGON_ID *logonid,  
prs_struct *ps, int depth);
+void init_owf_info(OWF_INFO *hash, const uint8 data[16]);
+BOOL smb_io_owf_info(const char *desc, OWF_INFO *hash, prs_struct  
*ps, int depth);
+BOOL smb_io_gid(const char *desc,  DOM_GID *gid, prs_struct *ps, int  
depth);
+BOOL smb_io_pol_hnd(const char *desc, POLICY_HND *pol, prs_struct  
*ps, int depth);
+void init_unistr3(UNISTR3 *str, const char *buf);
+BOOL smb_io_unistr3(const char *desc, UNISTR3 *name, prs_struct *ps,  
int depth);
+BOOL prs_uint64(const char *name, prs_struct *ps, int depth, uint64  
*data64);
+BOOL smb_io_bufhdr2(const char *desc, BUFHDR2 *hdr, prs_struct *ps,  
int depth);
+BOOL smb_io_bufhdr4(const char *desc, BUFHDR4 *hdr, prs_struct *ps,  
int depth);
+BOOL smb_io_rpc_blob(const char *desc, RPC_DATA_BLOB *blob,  
prs_struct *ps, int depth);
+BOOL make_uni_hdr(UNIHDR *hdr, int len);
+BOOL make_bufhdr2(BUFHDR2 *hdr, uint32 info_level, uint32 length,  
uint32 buffer);
+uint32 str_len_uni(UNISTR *source);
+
+/* The following definitions come from rpc_parse/parse_net.c  */
+
+BOOL net_io_q_logon_ctrl2(const char *desc, NET_Q_LOGON_CTRL2 *q_l,  
prs_struct *ps, int depth);
+void init_net_q_logon_ctrl2(NET_Q_LOGON_CTRL2 *q_l, const char  
*srv_name,
+			    uint32 query_level);
+void init_net_r_logon_ctrl2(NET_R_LOGON_CTRL2 *r_l, uint32 query_level,
+			    uint32 flags, uint32 pdc_status,
+			    uint32 logon_attempts, uint32 tc_status,
+			    const char *trusted_domain_name);
+BOOL net_io_r_logon_ctrl2(const char *desc, NET_R_LOGON_CTRL2 *r_l,  
prs_struct *ps, int depth);
+BOOL net_io_q_logon_ctrl(const char *desc, NET_Q_LOGON_CTRL *q_l,  
prs_struct *ps,
+			 int depth);
+void init_net_q_logon_ctrl(NET_Q_LOGON_CTRL *q_l, const char *srv_name,
+			   uint32 query_level);
+void init_net_r_logon_ctrl(NET_R_LOGON_CTRL *r_l, uint32 query_level,
+			   uint32 flags, uint32 pdc_status);
+BOOL net_io_r_logon_ctrl(const char *desc, NET_R_LOGON_CTRL *r_l,  
prs_struct *ps,
+			 int depth);
+void init_net_q_getanydcname(NET_Q_GETANYDCNAME *r_t, const char  
*logon_server,
+			     const char *domainname);
+BOOL net_io_q_getanydcname(const char *desc, NET_Q_GETANYDCNAME  
*r_t, prs_struct *ps,
+			   int depth);
+void init_net_r_getanydcname(NET_R_GETANYDCNAME *r_t, const char  
*dcname);
+BOOL net_io_r_getanydcname(const char *desc, NET_R_GETANYDCNAME  
*r_t, prs_struct *ps,
+			   int depth);
+void init_net_q_getdcname(NET_Q_GETDCNAME *r_t, const char  
*logon_server,
+			  const char *domainname);
+BOOL net_io_q_getdcname(const char *desc, NET_Q_GETDCNAME *r_t,  
prs_struct *ps,
+			int depth);
+void init_net_r_getdcname(NET_R_GETDCNAME *r_t, const char *dcname);
+BOOL net_io_r_getdcname(const char *desc, NET_R_GETDCNAME *r_t,  
prs_struct *ps,
+			int depth);
+void init_r_trust_dom(NET_R_TRUST_DOM_LIST *r_t,
+			uint32 num_doms, const char *dom_name);
+BOOL net_io_r_trust_dom(const char *desc, NET_R_TRUST_DOM_LIST *r_t,  
prs_struct *ps, int depth);
+BOOL net_io_q_trust_dom(const char *desc, NET_Q_TRUST_DOM_LIST *q_l,  
prs_struct *ps, int depth);
+void init_q_req_chal(NET_Q_REQ_CHAL *q_c,
+		     const char *logon_srv, const char *logon_clnt,
+		     const DOM_CHAL *clnt_chal);
+BOOL net_io_q_req_chal(const char *desc,  NET_Q_REQ_CHAL *q_c,  
prs_struct *ps, int depth);
+BOOL net_io_r_req_chal(const char *desc, NET_R_REQ_CHAL *r_c,  
prs_struct *ps, int depth);
+BOOL net_io_q_auth(const char *desc, NET_Q_AUTH *q_a, prs_struct  
*ps, int depth);
+BOOL net_io_r_auth(const char *desc, NET_R_AUTH *r_a, prs_struct  
*ps, int depth);
+void init_q_auth_2(NET_Q_AUTH_2 *q_a,
+		const char *logon_srv, const char *acct_name, uint16 sec_chan,  
const char *comp_name,
+		const DOM_CHAL *clnt_chal, uint32 clnt_flgs);
+BOOL net_io_q_auth_2(const char *desc, NET_Q_AUTH_2 *q_a, prs_struct  
*ps, int depth);
+BOOL net_io_r_auth_2(const char *desc, NET_R_AUTH_2 *r_a, prs_struct  
*ps, int depth);
+void init_q_auth_3(NET_Q_AUTH_3 *q_a,
+		const char *logon_srv, const char *acct_name, uint16 sec_chan,  
const char *comp_name,
+		const DOM_CHAL *clnt_chal, uint32 clnt_flgs);
+BOOL net_io_q_auth_3(const char *desc, NET_Q_AUTH_3 *q_a, prs_struct  
*ps, int depth);
+BOOL net_io_r_auth_3(const char *desc, NET_R_AUTH_3 *r_a, prs_struct  
*ps, int depth);
+void init_q_srv_pwset(NET_Q_SRV_PWSET *q_s,
+		const char *logon_srv, const char *sess_key, const char *acct_name,
+                uint16 sec_chan, const char *comp_name,
+		DOM_CRED *cred, const uchar hashed_mach_pwd[16]);
+BOOL net_io_q_srv_pwset(const char *desc, NET_Q_SRV_PWSET *q_s,  
prs_struct *ps, int depth);
+BOOL net_io_r_srv_pwset(const char *desc, NET_R_SRV_PWSET *r_s,  
prs_struct *ps, int depth);
+void init_id_info1(NET_ID_INFO_1 *id, const char *domain_name,
+				uint32 param_ctrl, uint32 log_id_low, uint32 log_id_high,
+				const char *user_name, const char *wksta_name,
+				const char *sess_key,
+				unsigned char lm_cypher[16], unsigned char nt_cypher[16]);
+void init_id_info2(NET_ID_INFO_2 * id, const char *domain_name,
+		   uint32 param_ctrl,
+		   uint32 log_id_low, uint32 log_id_high,
+		   const char *user_name, const char *wksta_name,
+		   const uchar lm_challenge[8],
+		   const uchar * lm_chal_resp, size_t lm_chal_resp_len,
+		   const uchar * nt_chal_resp, size_t nt_chal_resp_len);
+void init_sam_info(DOM_SAM_INFO *sam,
+				const char *logon_srv, const char *comp_name,
+				DOM_CRED *clnt_cred,
+				DOM_CRED *rtn_cred, uint16 logon_level,
+				NET_ID_INFO_CTR *ctr);
+void init_sam_info_ex(DOM_SAM_INFO_EX *sam,
+		      const char *logon_srv, const char *comp_name,
+		      uint16 logon_level, NET_ID_INFO_CTR *ctr);
+void init_net_user_info3(TALLOC_CTX *ctx, NET_USER_INFO_3 *usr,
+			 uint32                user_rid,
+			 uint32                group_rid,
+
+			 const char*		user_name,
+			 const char*		full_name,
+			 const char*		home_dir,
+			 const char*		dir_drive,
+			 const char*		logon_script,
+			 const char*		profile_path,
+
+			 time_t unix_logon_time,
+			 time_t unix_logoff_time,
+			 time_t unix_kickoff_time,
+			 time_t unix_pass_last_set_time,
+			 time_t unix_pass_can_change_time,
+			 time_t unix_pass_must_change_time,
+			
+			 uint16 logon_count, uint16 bad_pw_count,
+ 		 	 uint32 num_groups, const DOM_GID *gids,
+			 uint32 user_flgs, uint32 acct_flags,
+			 uchar user_session_key[16],
+			 uchar lm_session_key[16],
+ 			 const char *logon_srv, const char *logon_dom,
+			 const DOM_SID *dom_sid);
+BOOL net_io_user_info3(const char *desc, NET_USER_INFO_3 *usr,  
prs_struct *ps,
+		       int depth, uint16 validation_level, BOOL  
kerb_validation_level);
+BOOL net_io_q_sam_logon(const char *desc, NET_Q_SAM_LOGON *q_l,  
prs_struct *ps, int depth);
+BOOL net_io_r_sam_logon(const char *desc, NET_R_SAM_LOGON *r_l,  
prs_struct *ps, int depth);
+BOOL net_io_q_sam_logon_ex(const char *desc, NET_Q_SAM_LOGON_EX  
*q_l, prs_struct *ps, int depth);
+BOOL net_io_r_sam_logon_ex(const char *desc, NET_R_SAM_LOGON_EX  
*r_l, prs_struct *ps, int depth);
+BOOL net_io_q_sam_logoff(const char *desc,  NET_Q_SAM_LOGOFF *q_l,  
prs_struct *ps, int depth);
+BOOL net_io_r_sam_logoff(const char *desc, NET_R_SAM_LOGOFF *r_l,  
prs_struct *ps, int depth);
+BOOL init_net_q_sam_sync(NET_Q_SAM_SYNC * q_s, const char *srv_name,
+                         const char *cli_name, DOM_CRED *cli_creds,
+                         DOM_CRED *ret_creds, uint32 database_id,
+			 uint32 next_rid);
+BOOL net_io_q_sam_sync(const char *desc, NET_Q_SAM_SYNC * q_s,  
prs_struct *ps,
+		       int depth);
+BOOL net_io_r_sam_sync(const char *desc,
+		       NET_R_SAM_SYNC * r_s, prs_struct *ps, int depth);
+BOOL init_net_q_sam_deltas(NET_Q_SAM_DELTAS *q_s, const char *srv_name,
+                           const char *cli_name, DOM_CRED *cli_creds,
+                           uint32 database_id, uint64 dom_mod_count);
+BOOL net_io_q_sam_deltas(const char *desc, NET_Q_SAM_DELTAS *q_s,  
prs_struct *ps,
+                         int depth);
+BOOL net_io_r_sam_deltas(const char *desc,
+                         NET_R_SAM_DELTAS *r_s, prs_struct *ps, int  
depth);
+void init_net_q_dsr_getdcname(NET_Q_DSR_GETDCNAME *r_t, const char  
*server_unc,
+			      const char *domain_name,
+			      struct GUID *domain_guid,
+			      struct GUID *site_guid,
+			      uint32_t flags);
+void init_net_q_dsr_getdcnameex(NET_Q_DSR_GETDCNAMEEX *r_t, const  
char *server_unc,
+				const char *domain_name,
+				struct GUID *domain_guid,
+				const char *site_name,
+				uint32_t flags);
+void init_net_q_dsr_getdcnameex2(NET_Q_DSR_GETDCNAMEEX2 *r_t, const  
char *server_unc,
+				 const char *domain_name,
+				 const char *client_account,
+				 uint32 mask,
+				 struct GUID *domain_guid,
+				 const char *site_name,
+				 uint32_t flags);
+BOOL net_io_q_dsr_getdcname(const char *desc, NET_Q_DSR_GETDCNAME *r_t,
+			    prs_struct *ps, int depth);
+BOOL net_io_q_dsr_getdcnameex(const char *desc,  
NET_Q_DSR_GETDCNAMEEX *r_t,
+			      prs_struct *ps, int depth);
+BOOL net_io_q_dsr_getdcnameex2(const char *desc,  
NET_Q_DSR_GETDCNAMEEX2 *r_t,
+			       prs_struct *ps, int depth);
+void init_net_r_dsr_getdcname(NET_R_DSR_GETDCNAME *r_t, const char  
*dc_unc,
+			      const char *dc_address, int32 dc_address_type,
+			      struct GUID domain_guid, const char *domain_name,
+			      const char *forest_name, uint32 dc_flags,
+			      const char *dc_site_name,
+			      const char *client_site_name);
+BOOL net_io_r_dsr_getdcname(const char *desc, NET_R_DSR_GETDCNAME *r_t,
+			    prs_struct *ps, int depth);
+void init_net_q_dsr_getsitename(NET_Q_DSR_GETSITENAME *r_t, const  
char *computer_name);
+BOOL net_io_q_dsr_getsitename(const char *desc,  
NET_Q_DSR_GETSITENAME *r_t,
+			      prs_struct *ps, int depth);
+BOOL net_io_r_dsr_getsitename(const char *desc,  
NET_R_DSR_GETSITENAME *r_t,
+			      prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_ntsvcs.c  */
+
+BOOL ntsvcs_io_q_get_version(const char *desc, NTSVCS_Q_GET_VERSION  
*q_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_r_get_version(const char *desc, NTSVCS_R_GET_VERSION  
*r_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_q_get_device_list_size(const char *desc,  
NTSVCS_Q_GET_DEVICE_LIST_SIZE *q_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_r_get_device_list_size(const char *desc,  
NTSVCS_R_GET_DEVICE_LIST_SIZE *r_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_q_get_device_list(const char *desc,  
NTSVCS_Q_GET_DEVICE_LIST *q_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_r_get_device_list(const char *desc,  
NTSVCS_R_GET_DEVICE_LIST *r_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_q_validate_device_instance(const char *desc,  
NTSVCS_Q_VALIDATE_DEVICE_INSTANCE *q_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_r_validate_device_instance(const char *desc,  
NTSVCS_R_VALIDATE_DEVICE_INSTANCE *r_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_q_get_device_reg_property(const char *desc,  
NTSVCS_Q_GET_DEVICE_REG_PROPERTY *q_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_r_get_device_reg_property(const char *desc,  
NTSVCS_R_GET_DEVICE_REG_PROPERTY *r_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_q_get_hw_profile_info(const char *desc,  
NTSVCS_Q_GET_HW_PROFILE_INFO *q_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_r_get_hw_profile_info(const char *desc,  
NTSVCS_R_GET_HW_PROFILE_INFO *r_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_q_hw_profile_flags(const char *desc,  
NTSVCS_Q_HW_PROFILE_FLAGS *q_u, prs_struct *ps, int depth);
+BOOL ntsvcs_io_r_hw_profile_flags(const char *desc,  
NTSVCS_R_HW_PROFILE_FLAGS *r_u, prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_prs.c  */
+
+void prs_dump(char *name, int v, prs_struct *ps);
+void prs_dump_before(char *name, int v, prs_struct *ps);
+void prs_dump_region(char *name, int v, prs_struct *ps,
+		     int from_off, int to_off);
+void prs_debug(prs_struct *ps, int depth, const char *desc, const  
char *fn_name);
+BOOL prs_init(prs_struct *ps, uint32 size, TALLOC_CTX *ctx, BOOL io);
+void prs_mem_free(prs_struct *ps);
+void prs_mem_clear(prs_struct *ps);
+char *prs_alloc_mem_(prs_struct *ps, size_t size, unsigned int count);
+char *prs_alloc_mem(prs_struct *ps, size_t size, unsigned int count);
+TALLOC_CTX *prs_get_mem_context(prs_struct *ps);
+void prs_give_memory(prs_struct *ps, char *buf, uint32 size, BOOL  
is_dynamic);
+char *prs_take_memory(prs_struct *ps, uint32 *psize);
+BOOL prs_set_buffer_size(prs_struct *ps, uint32 newsize);
+BOOL prs_grow(prs_struct *ps, uint32 extra_space);
+BOOL prs_force_grow(prs_struct *ps, uint32 extra_space);
+char *prs_data_p(prs_struct *ps);
+uint32 prs_data_size(prs_struct *ps);
+uint32 prs_offset(prs_struct *ps);
+BOOL prs_set_offset(prs_struct *ps, uint32 offset);
+BOOL prs_append_prs_data(prs_struct *dst, prs_struct *src);
+BOOL prs_append_some_prs_data(prs_struct *dst, prs_struct *src,  
int32 start, uint32 len);
+BOOL prs_copy_data_in(prs_struct *dst, const char *src, uint32 len);
+BOOL prs_copy_data_out(char *dst, prs_struct *src, uint32 len);
+BOOL prs_copy_all_data_out(char *dst, prs_struct *src);
+void prs_set_endian_data(prs_struct *ps, BOOL endian);
+BOOL prs_align(prs_struct *ps);
+BOOL prs_align_uint16(prs_struct *ps);
+BOOL prs_align_uint64(prs_struct *ps);
+BOOL prs_align_custom(prs_struct *ps, uint8 boundary);
+BOOL prs_align_needed(prs_struct *ps, uint32 needed);
+char *prs_mem_get(prs_struct *ps, uint32 extra_size);
+void prs_switch_type(prs_struct *ps, BOOL io);
+void prs_force_dynamic(prs_struct *ps);
+void prs_set_session_key(prs_struct *ps, const char sess_key[16]);
+BOOL prs_uint8(const char *name, prs_struct *ps, int depth, uint8  
*data8);
+BOOL prs_pointer( const char *name, prs_struct *ps, int depth,
+                 void *dta, size_t data_size,
+                 BOOL(*prs_fn)(const char*, prs_struct*, int, void*) );
+BOOL prs_uint16(const char *name, prs_struct *ps, int depth, uint16  
*data16);
+BOOL prs_uint32(const char *name, prs_struct *ps, int depth, uint32  
*data32);
+BOOL prs_int32(const char *name, prs_struct *ps, int depth, int32  
*data32);
+BOOL prs_ntstatus(const char *name, prs_struct *ps, int depth,  
NTSTATUS *status);
+BOOL prs_dcerpc_status(const char *name, prs_struct *ps, int depth,  
NTSTATUS *status);
+BOOL prs_werror(const char *name, prs_struct *ps, int depth, WERROR  
*status);
+BOOL prs_uint8s(BOOL charmode, const char *name, prs_struct *ps, int  
depth, uint8 *data8s, int len);
+BOOL prs_uint16s(BOOL charmode, const char *name, prs_struct *ps,  
int depth, uint16 *data16s, int len);
+BOOL prs_uint16uni(BOOL charmode, const char *name, prs_struct *ps,  
int depth, uint16 *data16s, int len);
+BOOL prs_uint32s(BOOL charmode, const char *name, prs_struct *ps,  
int depth, uint32 *data32s, int len);
+BOOL prs_buffer5(BOOL charmode, const char *name, prs_struct *ps,  
int depth, BUFFER5 *str);
+BOOL prs_regval_buffer(BOOL charmode, const char *name, prs_struct  
*ps, int depth, REGVAL_BUFFER *buf);
+BOOL prs_string2(BOOL charmode, const char *name, prs_struct *ps,  
int depth, STRING2 *str);
+BOOL prs_unistr2(BOOL charmode, const char *name, prs_struct *ps,  
int depth, UNISTR2 *str);
+BOOL prs_unistr3(BOOL charmode, const char *name, UNISTR3 *str,  
prs_struct *ps, int depth);
+BOOL prs_unistr(const char *name, prs_struct *ps, int depth, UNISTR  
*str);
+BOOL prs_string(const char *name, prs_struct *ps, int depth, char  
*str, int max_buf_size);
+BOOL prs_string_alloc(const char *name, prs_struct *ps, int depth,  
const char **str);
+BOOL prs_uint16_pre(const char *name, prs_struct *ps, int depth,  
uint16 *data16, uint32 *offset);
+BOOL prs_uint16_post(const char *name, prs_struct *ps, int depth,  
uint16 *data16,
+				uint32 ptr_uint16, uint32 start_offset);
+BOOL prs_uint32_pre(const char *name, prs_struct *ps, int depth,  
uint32 *data32, uint32 *offset);
+BOOL prs_uint32_post(const char *name, prs_struct *ps, int depth,  
uint32 *data32,
+				uint32 ptr_uint32, uint32 data_size);
+int tdb_prs_store(TDB_CONTEXT *tdb, TDB_DATA kbuf, prs_struct *ps);
+int tdb_prs_store_bystring(TDB_CONTEXT *tdb, char *keystr,  
prs_struct *ps);
+int tdb_prs_fetch(TDB_CONTEXT *tdb, TDB_DATA kbuf, prs_struct *ps,  
TALLOC_CTX *mem_ctx);
+int tdb_prs_fetch_bystring(TDB_CONTEXT *tdb, char *keystr,  
prs_struct *ps, TALLOC_CTX *mem_ctx);
+BOOL prs_hash1(prs_struct *ps, uint32 offset, int len);
+void schannel_encode(struct schannel_auth_struct *a, enum  
pipe_auth_level auth_level,
+		   enum schannel_direction direction,
+		   RPC_AUTH_SCHANNEL_CHK * verf,
+		   char *data, size_t data_len);
+BOOL schannel_decode(struct schannel_auth_struct *a, enum  
pipe_auth_level auth_level,
+		   enum schannel_direction direction,
+		   RPC_AUTH_SCHANNEL_CHK * verf, char *data, size_t data_len);
+BOOL prs_init_data_blob(prs_struct *prs, DATA_BLOB *blob, TALLOC_CTX  
*mem_ctx);
+BOOL prs_data_blob(prs_struct *prs, DATA_BLOB *blob, TALLOC_CTX  
*mem_ctx);
+
+/* The following definitions come from rpc_parse/parse_rpc.c  */
+
+const char *cli_get_pipe_name(int pipe_idx);
+void init_rpc_hdr(RPC_HDR *hdr, enum RPC_PKT_TYPE pkt_type, uint8  
flags,
+				uint32 call_id, int data_len, int auth_len);
+BOOL smb_io_rpc_hdr(const char *desc,  RPC_HDR *rpc, prs_struct *ps,  
int depth);
+void init_rpc_context(RPC_CONTEXT *rpc_ctx, uint16 context_id,  
RPC_IFACE *abstract, RPC_IFACE *transfer);
+void init_rpc_hdr_rb(RPC_HDR_RB *rpc,
+				uint16 max_tsize, uint16 max_rsize, uint32 assoc_gid,
+				RPC_CONTEXT *context);
+BOOL smb_io_rpc_context(const char *desc, RPC_CONTEXT *rpc_ctx,  
prs_struct *ps, int depth);
+BOOL smb_io_rpc_hdr_rb(const char *desc, RPC_HDR_RB *rpc, prs_struct  
*ps, int depth);
+void init_rpc_hdr_ba(RPC_HDR_BA *rpc,
+				uint16 max_tsize, uint16 max_rsize, uint32 assoc_gid,
+				const char *pipe_addr,
+				uint8 num_results, uint16 result, uint16 reason,
+				RPC_IFACE *transfer);
+BOOL smb_io_rpc_hdr_ba(const char *desc, RPC_HDR_BA *rpc, prs_struct  
*ps, int depth);
+void init_rpc_hdr_req(RPC_HDR_REQ *hdr, uint32 alloc_hint, uint16  
opnum);
+BOOL smb_io_rpc_hdr_req(const char *desc, RPC_HDR_REQ *rpc,  
prs_struct *ps, int depth);
+BOOL smb_io_rpc_hdr_resp(const char *desc, RPC_HDR_RESP *rpc,  
prs_struct *ps, int depth);
+BOOL smb_io_rpc_hdr_fault(const char *desc, RPC_HDR_FAULT *rpc,  
prs_struct *ps, int depth);
+void init_rpc_hdr_auth(RPC_HDR_AUTH *rai,
+				uint8 auth_type, uint8 auth_level,
+				uint8 auth_pad_len,
+				uint32 auth_context_id);
+BOOL smb_io_rpc_hdr_auth(const char *desc, RPC_HDR_AUTH *rai,  
prs_struct *ps, int depth);
+BOOL rpc_auth_verifier_chk(RPC_AUTH_VERIFIER *rav,
+				const char *signature, uint32 msg_type);
+void init_rpc_auth_verifier(RPC_AUTH_VERIFIER *rav,
+				const char *signature, uint32 msg_type);
+BOOL smb_io_rpc_auth_verifier(const char *desc, RPC_AUTH_VERIFIER  
*rav, prs_struct *ps, int depth);
+BOOL smb_io_rpc_schannel_verifier(const char *desc,  
RPC_AUTH_VERIFIER *rav, prs_struct *ps, int depth);
+void init_rpc_auth_schannel_neg(RPC_AUTH_SCHANNEL_NEG *neg,
+			      const char *domain, const char *myname);
+BOOL smb_io_rpc_auth_schannel_neg(const char *desc,  
RPC_AUTH_SCHANNEL_NEG *neg,
+				prs_struct *ps, int depth);
+BOOL smb_io_rpc_auth_schannel_chk(const char *desc, int auth_len,
+                                RPC_AUTH_SCHANNEL_CHK * chk,
+				prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_samr.c  */
+
+void init_samr_q_close_hnd(SAMR_Q_CLOSE_HND * q_c, POLICY_HND *hnd);
+BOOL samr_io_q_close_hnd(const char *desc, SAMR_Q_CLOSE_HND * q_u,
+			 prs_struct *ps, int depth);
+BOOL samr_io_r_close_hnd(const char *desc, SAMR_R_CLOSE_HND * r_u,
+			 prs_struct *ps, int depth);
+void init_samr_q_lookup_domain(SAMR_Q_LOOKUP_DOMAIN * q_u,
+			       POLICY_HND *pol, char *dom_name);
+BOOL samr_io_q_lookup_domain(const char *desc, SAMR_Q_LOOKUP_DOMAIN  
* q_u,
+			     prs_struct *ps, int depth);
+void init_samr_r_lookup_domain(SAMR_R_LOOKUP_DOMAIN * r_u,
+			       DOM_SID *dom_sid, NTSTATUS status);
+BOOL samr_io_r_lookup_domain(const char *desc, SAMR_R_LOOKUP_DOMAIN  
* r_u,
+			     prs_struct *ps, int depth);
+void init_samr_q_remove_sid_foreign_domain 
(SAMR_Q_REMOVE_SID_FOREIGN_DOMAIN * q_u, POLICY_HND *dom_pol, DOM_SID  
*sid);
+BOOL samr_io_q_remove_sid_foreign_domain(const char *desc,  
SAMR_Q_REMOVE_SID_FOREIGN_DOMAIN * q_u,
+			  prs_struct *ps, int depth);
+BOOL samr_io_r_remove_sid_foreign_domain(const char *desc,  
SAMR_R_REMOVE_SID_FOREIGN_DOMAIN * r_u,
+			  prs_struct *ps, int depth);
+void init_samr_q_open_domain(SAMR_Q_OPEN_DOMAIN * q_u,
+			     POLICY_HND *pol, uint32 flags,
+			     const DOM_SID *sid);
+BOOL samr_io_q_open_domain(const char *desc, SAMR_Q_OPEN_DOMAIN * q_u,
+			   prs_struct *ps, int depth);
+BOOL samr_io_r_open_domain(const char *desc, SAMR_R_OPEN_DOMAIN * r_u,
+			   prs_struct *ps, int depth);
+void init_samr_q_get_usrdom_pwinfo(SAMR_Q_GET_USRDOM_PWINFO * q_u,
+				   POLICY_HND *user_pol);
+BOOL samr_io_q_get_usrdom_pwinfo(const char *desc,  
SAMR_Q_GET_USRDOM_PWINFO * q_u,
+				 prs_struct *ps, int depth);
+void init_samr_r_get_usrdom_pwinfo(SAMR_R_GET_USRDOM_PWINFO *r_u,  
NTSTATUS status);
+BOOL samr_io_r_get_usrdom_pwinfo(const char *desc,  
SAMR_R_GET_USRDOM_PWINFO * r_u,
+				 prs_struct *ps, int depth);
+BOOL samr_io_q_set_sec_obj(const char *desc, SAMR_Q_SET_SEC_OBJ * q_u,
+			     prs_struct *ps, int depth);
+void init_samr_q_query_sec_obj(SAMR_Q_QUERY_SEC_OBJ * q_u,
+			       POLICY_HND *user_pol, uint32 sec_info);
+BOOL samr_io_q_query_sec_obj(const char *desc, SAMR_Q_QUERY_SEC_OBJ  
* q_u,
+			     prs_struct *ps, int depth);
+void init_samr_q_query_domain_info(SAMR_Q_QUERY_DOMAIN_INFO * q_u,
+				   POLICY_HND *domain_pol, uint16 switch_value);
+BOOL samr_io_q_query_domain_info(const char *desc,  
SAMR_Q_QUERY_DOMAIN_INFO * q_u,
+				 prs_struct *ps, int depth);
+void init_unk_info1(SAM_UNK_INFO_1 *u_1, uint16 min_pass_len, uint16  
pass_hist,
+		    uint32 password_properties, NTTIME nt_expire, NTTIME nt_min_age);
+void init_unk_info2(SAM_UNK_INFO_2 * u_2,
+			const char *comment, const char *domain, const char *server,
+			uint32 seq_num, uint32 num_users, uint32 num_groups, uint32  
num_alias, NTTIME nt_logout, uint32 server_role);
+void init_unk_info3(SAM_UNK_INFO_3 *u_3, NTTIME nt_logout);
+void init_unk_info4(SAM_UNK_INFO_4 * u_4,const char *comment);
+void init_unk_info5(SAM_UNK_INFO_5 * u_5,const char *domain);
+void init_unk_info6(SAM_UNK_INFO_6 * u_6, const char *server);
+void init_unk_info7(SAM_UNK_INFO_7 * u_7, uint32 server_role);
+void init_unk_info8(SAM_UNK_INFO_8 * u_8, uint32 seq_num);
+void init_unk_info9(SAM_UNK_INFO_9 * u_9, uint32 unknown);
+void init_unk_info12(SAM_UNK_INFO_12 * u_12, NTTIME  
nt_lock_duration, NTTIME nt_reset_time, uint16 lockout);
+void init_unk_info13(SAM_UNK_INFO_13 * u_13, uint32 seq_num);
+void init_samr_r_query_domain_info(SAMR_R_QUERY_DOMAIN_INFO * r_u,
+				   uint16 switch_value, SAM_UNK_CTR * ctr,
+				   NTSTATUS status);
+BOOL samr_io_r_query_domain_info(const char *desc,  
SAMR_R_QUERY_DOMAIN_INFO * r_u,
+				 prs_struct *ps, int depth);
+void init_samr_q_set_sec_obj(SAMR_Q_SET_SEC_OBJ * q_u,
+			     POLICY_HND *pol, uint32 sec_info, SEC_DESC_BUF *buf);
+BOOL samr_io_r_set_sec_obj(const char *desc, SAMR_R_SET_SEC_OBJ * r_u,
+			     prs_struct *ps, int depth);
+BOOL samr_io_r_query_sec_obj(const char *desc, SAMR_R_QUERY_SEC_OBJ  
* r_u,
+			     prs_struct *ps, int depth);
+void init_sam_entry(SAM_ENTRY *sam, UNISTR2 *uni2, uint32 rid);
+void init_samr_q_enum_dom_users(SAMR_Q_ENUM_DOM_USERS * q_e,  
POLICY_HND *pol,
+				uint32 start_idx,
+				uint32 acb_mask, uint32 size);
+BOOL samr_io_q_enum_dom_users(const char *desc,  
SAMR_Q_ENUM_DOM_USERS * q_e,
+			      prs_struct *ps, int depth);
+void init_samr_r_enum_dom_users(SAMR_R_ENUM_DOM_USERS * r_u,
+				uint32 next_idx, uint32 num_sam_entries);
+BOOL samr_io_r_enum_dom_users(const char *desc,  
SAMR_R_ENUM_DOM_USERS * r_u,
+			      prs_struct *ps, int depth);
+void init_samr_q_query_dispinfo(SAMR_Q_QUERY_DISPINFO * q_e,  
POLICY_HND *pol,
+				uint16 switch_level, uint32 start_idx,
+				uint32 max_entries, uint32 max_size);
+BOOL samr_io_q_query_dispinfo(const char *desc,  
SAMR_Q_QUERY_DISPINFO * q_e,
+			      prs_struct *ps, int depth);
+NTSTATUS init_sam_dispinfo_1(TALLOC_CTX *ctx, SAM_DISPINFO_1 **sam,
+			     uint32 num_entries, uint32 start_idx,
+			     struct samr_displayentry *entries);
+NTSTATUS init_sam_dispinfo_2(TALLOC_CTX *ctx, SAM_DISPINFO_2 **sam,
+			     uint32 num_entries, uint32 start_idx,
+			     struct samr_displayentry *entries);
+NTSTATUS init_sam_dispinfo_3(TALLOC_CTX *ctx, SAM_DISPINFO_3 **sam,
+			     uint32 num_entries, uint32 start_idx,
+			     struct samr_displayentry *entries);
+NTSTATUS init_sam_dispinfo_4(TALLOC_CTX *ctx, SAM_DISPINFO_4 **sam,
+			     uint32 num_entries, uint32 start_idx,
+			     struct samr_displayentry *entries);
+NTSTATUS init_sam_dispinfo_5(TALLOC_CTX *ctx, SAM_DISPINFO_5 **sam,
+			     uint32 num_entries, uint32 start_idx,
+			     struct samr_displayentry *entries);
+void init_samr_r_query_dispinfo(SAMR_R_QUERY_DISPINFO * r_u,
+				uint32 num_entries, uint32 total_size, uint32 data_size,
+				uint16 switch_level, SAM_DISPINFO_CTR * ctr,
+				NTSTATUS status);
+BOOL samr_io_r_query_dispinfo(const char *desc,  
SAMR_R_QUERY_DISPINFO * r_u,
+			      prs_struct *ps, int depth);
+void init_samr_q_get_dispenum_index(SAMR_Q_GET_DISPENUM_INDEX * q_e,  
POLICY_HND *pol,
+				    uint16 switch_level, const char *name);
+BOOL samr_io_q_get_dispenum_index(const char *desc,  
SAMR_Q_GET_DISPENUM_INDEX * q_e,
+				  prs_struct *ps, int depth);
+BOOL samr_io_r_get_dispenum_index(const char *desc,  
SAMR_R_GET_DISPENUM_INDEX * r_u,
+				  prs_struct *ps, int depth);
+void init_samr_q_open_group(SAMR_Q_OPEN_GROUP * q_c,
+			    POLICY_HND *hnd,
+			    uint32 access_mask, uint32 rid);
+BOOL samr_io_q_open_group(const char *desc, SAMR_Q_OPEN_GROUP * q_u,
+			  prs_struct *ps, int depth);
+BOOL samr_io_r_open_group(const char *desc, SAMR_R_OPEN_GROUP * r_u,
+			  prs_struct *ps, int depth);
+void init_samr_group_info1(GROUP_INFO1 * gr1,
+			   char *acct_name, char *acct_desc,
+			   uint32 num_members);
+BOOL samr_io_group_info1(const char *desc, GROUP_INFO1 * gr1,
+			 prs_struct *ps, int depth);
+void init_samr_group_info2(GROUP_INFO2 * gr2, const char *acct_name);
+BOOL samr_io_group_info2(const char *desc, GROUP_INFO2 *gr2,  
prs_struct *ps, int depth);
+void init_samr_group_info3(GROUP_INFO3 *gr3);
+BOOL samr_io_group_info3(const char *desc, GROUP_INFO3 *gr3,  
prs_struct *ps, int depth);
+void init_samr_group_info4(GROUP_INFO4 * gr4, const char *acct_desc);
+BOOL samr_io_group_info4(const char *desc, GROUP_INFO4 * gr4,
+			 prs_struct *ps, int depth);
+void init_samr_group_info5(GROUP_INFO5 * gr5,
+			   char *acct_name, char *acct_desc,
+			   uint32 num_members);
+BOOL samr_io_group_info5(const char *desc, GROUP_INFO5 * gr5,
+			 prs_struct *ps, int depth);
+void init_samr_q_create_dom_group(SAMR_Q_CREATE_DOM_GROUP * q_e,
+				  POLICY_HND *pol, const char *acct_desc,
+				  uint32 access_mask);
+BOOL samr_io_q_create_dom_group(const char *desc,  
SAMR_Q_CREATE_DOM_GROUP * q_e,
+				prs_struct *ps, int depth);
+BOOL samr_io_r_create_dom_group(const char *desc,  
SAMR_R_CREATE_DOM_GROUP * r_u,
+				prs_struct *ps, int depth);
+void init_samr_q_delete_dom_group(SAMR_Q_DELETE_DOM_GROUP * q_c,
+				  POLICY_HND *hnd);
+BOOL samr_io_q_delete_dom_group(const char *desc,  
SAMR_Q_DELETE_DOM_GROUP * q_u,
+				prs_struct *ps, int depth);
+BOOL samr_io_r_delete_dom_group(const char *desc,  
SAMR_R_DELETE_DOM_GROUP * r_u,
+				prs_struct *ps, int depth);
+void init_samr_q_del_groupmem(SAMR_Q_DEL_GROUPMEM * q_e,
+			      POLICY_HND *pol, uint32 rid);
+BOOL samr_io_q_del_groupmem(const char *desc, SAMR_Q_DEL_GROUPMEM *  
q_e,
+			    prs_struct *ps, int depth);
+void init_samr_r_del_groupmem(SAMR_R_DEL_GROUPMEM * r_u, POLICY_HND  
*pol,
+			      NTSTATUS status);
+BOOL samr_io_r_del_groupmem(const char *desc, SAMR_R_DEL_GROUPMEM *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_add_groupmem(SAMR_Q_ADD_GROUPMEM * q_e,
+			      POLICY_HND *pol, uint32 rid);
+BOOL samr_io_q_add_groupmem(const char *desc, SAMR_Q_ADD_GROUPMEM *  
q_e,
+			    prs_struct *ps, int depth);
+void init_samr_r_add_groupmem(SAMR_R_ADD_GROUPMEM * r_u, POLICY_HND  
*pol,
+			      NTSTATUS status);
+BOOL samr_io_r_add_groupmem(const char *desc, SAMR_R_ADD_GROUPMEM *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_set_groupinfo(SAMR_Q_SET_GROUPINFO * q_e,
+			       POLICY_HND *pol, GROUP_INFO_CTR * ctr);
+BOOL samr_io_q_set_groupinfo(const char *desc, SAMR_Q_SET_GROUPINFO  
* q_e,
+			     prs_struct *ps, int depth);
+void init_samr_r_set_groupinfo(SAMR_R_SET_GROUPINFO * r_u, NTSTATUS  
status);
+BOOL samr_io_r_set_groupinfo(const char *desc, SAMR_R_SET_GROUPINFO  
* r_u,
+			     prs_struct *ps, int depth);
+void init_samr_q_query_groupinfo(SAMR_Q_QUERY_GROUPINFO * q_e,
+				 POLICY_HND *pol, uint16 switch_level);
+BOOL samr_io_q_query_groupinfo(const char *desc,  
SAMR_Q_QUERY_GROUPINFO * q_e,
+			       prs_struct *ps, int depth);
+void init_samr_r_query_groupinfo(SAMR_R_QUERY_GROUPINFO * r_u,
+				 GROUP_INFO_CTR * ctr, NTSTATUS status);
+BOOL samr_io_r_query_groupinfo(const char *desc,  
SAMR_R_QUERY_GROUPINFO * r_u,
+			       prs_struct *ps, int depth);
+void init_samr_q_query_groupmem(SAMR_Q_QUERY_GROUPMEM * q_c,  
POLICY_HND *hnd);
+BOOL samr_io_q_query_groupmem(const char *desc,  
SAMR_Q_QUERY_GROUPMEM * q_u,
+			      prs_struct *ps, int depth);
+void init_samr_r_query_groupmem(SAMR_R_QUERY_GROUPMEM * r_u,
+				uint32 num_entries, uint32 *rid,
+				uint32 *attr, NTSTATUS status);
+BOOL samr_io_r_query_groupmem(const char *desc,  
SAMR_R_QUERY_GROUPMEM * r_u,
+			      prs_struct *ps, int depth);
+void init_samr_q_query_usergroups(SAMR_Q_QUERY_USERGROUPS * q_u,
+				  POLICY_HND *hnd);
+BOOL samr_io_q_query_usergroups(const char *desc,  
SAMR_Q_QUERY_USERGROUPS * q_u,
+				prs_struct *ps, int depth);
+void init_samr_r_query_usergroups(SAMR_R_QUERY_USERGROUPS * r_u,
+				  uint32 num_gids, DOM_GID * gid,
+				  NTSTATUS status);
+BOOL samr_io_gids(const char *desc, uint32 *num_gids, DOM_GID ** gid,
+		  prs_struct *ps, int depth);
+BOOL samr_io_r_query_usergroups(const char *desc,  
SAMR_R_QUERY_USERGROUPS * r_u,
+				prs_struct *ps, int depth);
+void init_samr_q_enum_domains(SAMR_Q_ENUM_DOMAINS * q_e,
+			      POLICY_HND *pol,
+			      uint32 start_idx, uint32 size);
+BOOL samr_io_q_enum_domains(const char *desc, SAMR_Q_ENUM_DOMAINS *  
q_e,
+			    prs_struct *ps, int depth);
+void init_samr_r_enum_domains(SAMR_R_ENUM_DOMAINS * r_u,
+			      uint32 next_idx, uint32 num_sam_entries);
+BOOL samr_io_r_enum_domains(const char *desc, SAMR_R_ENUM_DOMAINS *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_enum_dom_groups(SAMR_Q_ENUM_DOM_GROUPS * q_e,
+				 POLICY_HND *pol,
+				 uint32 start_idx, uint32 size);
+BOOL samr_io_q_enum_dom_groups(const char *desc,  
SAMR_Q_ENUM_DOM_GROUPS * q_e,
+			       prs_struct *ps, int depth);
+void init_samr_r_enum_dom_groups(SAMR_R_ENUM_DOM_GROUPS * r_u,
+				 uint32 next_idx, uint32 num_sam_entries);
+BOOL samr_io_r_enum_dom_groups(const char *desc,  
SAMR_R_ENUM_DOM_GROUPS * r_u,
+			       prs_struct *ps, int depth);
+void init_samr_q_enum_dom_aliases(SAMR_Q_ENUM_DOM_ALIASES * q_e,
+				  POLICY_HND *pol, uint32 start_idx,
+				  uint32 size);
+BOOL samr_io_q_enum_dom_aliases(const char *desc,  
SAMR_Q_ENUM_DOM_ALIASES * q_e,
+				prs_struct *ps, int depth);
+void init_samr_r_enum_dom_aliases(SAMR_R_ENUM_DOM_ALIASES *r_u,  
uint32 next_idx, uint32 num_sam_entries);
+BOOL samr_io_r_enum_dom_aliases(const char *desc,  
SAMR_R_ENUM_DOM_ALIASES * r_u,
+				prs_struct *ps, int depth);
+void init_samr_alias_info1(ALIAS_INFO1 * al1, char *acct_name,  
uint32 num_member, char *acct_desc);
+BOOL samr_io_alias_info1(const char *desc, ALIAS_INFO1 * al1,
+			 prs_struct *ps, int depth);
+void init_samr_alias_info3(ALIAS_INFO3 * al3, const char *acct_desc);
+BOOL samr_io_alias_info3(const char *desc, ALIAS_INFO3 *al3,
+			 prs_struct *ps, int depth);
+BOOL samr_io_alias_info2(const char *desc, ALIAS_INFO2 *al2,
+			 prs_struct *ps, int depth);
+BOOL samr_alias_info_ctr(const char *desc, prs_struct *ps, int  
depth, ALIAS_INFO_CTR * ctr);
+void init_samr_q_query_aliasinfo(SAMR_Q_QUERY_ALIASINFO * q_e,
+				 POLICY_HND *pol, uint32 switch_level);
+BOOL samr_io_q_query_aliasinfo(const char *desc,  
SAMR_Q_QUERY_ALIASINFO *in,
+			       prs_struct *ps, int depth);
+void init_samr_r_query_aliasinfo(SAMR_R_QUERY_ALIASINFO *out,
+				 ALIAS_INFO_CTR * ctr, NTSTATUS status);
+BOOL samr_io_r_query_aliasinfo(const char *desc,  
SAMR_R_QUERY_ALIASINFO *out,
+			       prs_struct *ps, int depth);
+void init_samr_q_set_aliasinfo(SAMR_Q_SET_ALIASINFO * q_u,
+			       POLICY_HND *hnd, ALIAS_INFO_CTR * ctr);
+BOOL samr_io_q_set_aliasinfo(const char *desc, SAMR_Q_SET_ALIASINFO  
* q_u,
+			     prs_struct *ps, int depth);
+BOOL samr_io_r_set_aliasinfo(const char *desc, SAMR_R_SET_ALIASINFO  
* r_u,
+			     prs_struct *ps, int depth);
+void init_samr_q_query_useraliases(SAMR_Q_QUERY_USERALIASES * q_u,
+				   POLICY_HND *hnd,
+				   uint32 num_sids,
+				   uint32 *ptr_sid, DOM_SID2 * sid);
+BOOL samr_io_q_query_useraliases(const char *desc,  
SAMR_Q_QUERY_USERALIASES * q_u,
+				 prs_struct *ps, int depth);
+void init_samr_r_query_useraliases(SAMR_R_QUERY_USERALIASES * r_u,
+				   uint32 num_rids, uint32 *rid,
+				   NTSTATUS status);
+BOOL samr_io_rids(const char *desc, uint32 *num_rids, uint32 **rid,
+		  prs_struct *ps, int depth);
+BOOL samr_io_r_query_useraliases(const char *desc,  
SAMR_R_QUERY_USERALIASES * r_u,
+				 prs_struct *ps, int depth);
+void init_samr_q_open_alias(SAMR_Q_OPEN_ALIAS * q_u, POLICY_HND *pol,
+			    uint32 access_mask, uint32 rid);
+BOOL samr_io_q_open_alias(const char *desc, SAMR_Q_OPEN_ALIAS * q_u,
+			  prs_struct *ps, int depth);
+BOOL samr_io_r_open_alias(const char *desc, SAMR_R_OPEN_ALIAS * r_u,
+			  prs_struct *ps, int depth);
+void init_samr_q_lookup_rids(TALLOC_CTX *ctx, SAMR_Q_LOOKUP_RIDS * q_u,
+			     POLICY_HND *pol, uint32 flags,
+			     uint32 num_rids, uint32 *rid);
+BOOL samr_io_q_lookup_rids(const char *desc, SAMR_Q_LOOKUP_RIDS * q_u,
+			   prs_struct *ps, int depth);
+void init_samr_r_lookup_rids(SAMR_R_LOOKUP_RIDS * r_u,
+			     uint32 num_names, UNIHDR * hdr_name,
+			     UNISTR2 *uni_name, uint32 *type);
+BOOL samr_io_r_lookup_rids(const char *desc, SAMR_R_LOOKUP_RIDS * r_u,
+			   prs_struct *ps, int depth);
+void init_samr_q_delete_alias(SAMR_Q_DELETE_DOM_ALIAS * q_u,  
POLICY_HND *hnd);
+BOOL samr_io_q_delete_alias(const char *desc,  
SAMR_Q_DELETE_DOM_ALIAS * q_u,
+			    prs_struct *ps, int depth);
+BOOL samr_io_r_delete_alias(const char *desc,  
SAMR_R_DELETE_DOM_ALIAS * r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_create_dom_alias(SAMR_Q_CREATE_DOM_ALIAS * q_u,
+				  POLICY_HND *hnd, const char *acct_desc);
+BOOL samr_io_q_create_dom_alias(const char *desc,  
SAMR_Q_CREATE_DOM_ALIAS * q_u,
+				prs_struct *ps, int depth);
+BOOL samr_io_r_create_dom_alias(const char *desc,  
SAMR_R_CREATE_DOM_ALIAS * r_u,
+				prs_struct *ps, int depth);
+void init_samr_q_add_aliasmem(SAMR_Q_ADD_ALIASMEM * q_u, POLICY_HND  
*hnd,
+			      DOM_SID *sid);
+BOOL samr_io_q_add_aliasmem(const char *desc, SAMR_Q_ADD_ALIASMEM *  
q_u,
+			    prs_struct *ps, int depth);
+BOOL samr_io_r_add_aliasmem(const char *desc, SAMR_R_ADD_ALIASMEM *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_del_aliasmem(SAMR_Q_DEL_ALIASMEM * q_u, POLICY_HND  
*hnd,
+			      DOM_SID *sid);
+BOOL samr_io_q_del_aliasmem(const char *desc, SAMR_Q_DEL_ALIASMEM *  
q_u,
+			    prs_struct *ps, int depth);
+BOOL samr_io_r_del_aliasmem(const char *desc, SAMR_R_DEL_ALIASMEM *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_delete_dom_alias(SAMR_Q_DELETE_DOM_ALIAS * q_c,
+				  POLICY_HND *hnd);
+BOOL samr_io_q_delete_dom_alias(const char *desc,  
SAMR_Q_DELETE_DOM_ALIAS * q_u,
+				prs_struct *ps, int depth);
+void init_samr_r_delete_dom_alias(SAMR_R_DELETE_DOM_ALIAS * r_u,
+				  NTSTATUS status);
+BOOL samr_io_r_delete_dom_alias(const char *desc,  
SAMR_R_DELETE_DOM_ALIAS * r_u,
+				prs_struct *ps, int depth);
+void init_samr_q_query_aliasmem(SAMR_Q_QUERY_ALIASMEM * q_c,
+				POLICY_HND *hnd);
+BOOL samr_io_q_query_aliasmem(const char *desc,  
SAMR_Q_QUERY_ALIASMEM * q_u,
+			      prs_struct *ps, int depth);
+void init_samr_r_query_aliasmem(SAMR_R_QUERY_ALIASMEM * r_u,
+				uint32 num_sids, DOM_SID2 * sid,
+				NTSTATUS status);
+BOOL samr_io_r_query_aliasmem(const char *desc,  
SAMR_R_QUERY_ALIASMEM * r_u,
+			      prs_struct *ps, int depth);
+NTSTATUS init_samr_q_lookup_names(TALLOC_CTX *ctx,  
SAMR_Q_LOOKUP_NAMES * q_u,
+			      POLICY_HND *pol, uint32 flags,
+			      uint32 num_names, const char **name);
+BOOL samr_io_q_lookup_names(const char *desc, SAMR_Q_LOOKUP_NAMES *  
q_u,
+			    prs_struct *ps, int depth);
+NTSTATUS init_samr_r_lookup_names(TALLOC_CTX *ctx,  
SAMR_R_LOOKUP_NAMES * r_u,
+			      uint32 num_rids,
+			      uint32 *rid, enum lsa_SidType *type,
+			      NTSTATUS status);
+BOOL samr_io_r_lookup_names(const char *desc, SAMR_R_LOOKUP_NAMES *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_delete_dom_user(SAMR_Q_DELETE_DOM_USER * q_c,
+				 POLICY_HND *hnd);
+BOOL samr_io_q_delete_dom_user(const char *desc,  
SAMR_Q_DELETE_DOM_USER * q_u,
+			       prs_struct *ps, int depth);
+BOOL samr_io_r_delete_dom_user(const char *desc,  
SAMR_R_DELETE_DOM_USER * r_u,
+			       prs_struct *ps, int depth);
+void init_samr_q_open_user(SAMR_Q_OPEN_USER * q_u,
+			   POLICY_HND *pol,
+			   uint32 access_mask, uint32 rid);
+BOOL samr_io_q_open_user(const char *desc, SAMR_Q_OPEN_USER * q_u,
+			 prs_struct *ps, int depth);
+BOOL samr_io_r_open_user(const char *desc, SAMR_R_OPEN_USER * r_u,
+			 prs_struct *ps, int depth);
+void init_samr_q_create_user(SAMR_Q_CREATE_USER * q_u,
+			     POLICY_HND *pol,
+			     const char *name,
+			     uint32 acb_info, uint32 access_mask);
+BOOL samr_io_q_create_user(const char *desc, SAMR_Q_CREATE_USER * q_u,
+			   prs_struct *ps, int depth);
+BOOL samr_io_r_create_user(const char *desc, SAMR_R_CREATE_USER * r_u,
+			   prs_struct *ps, int depth);
+void init_samr_q_query_userinfo(SAMR_Q_QUERY_USERINFO * q_u,
+				const POLICY_HND *hnd, uint16 switch_value);
+BOOL samr_io_q_query_userinfo(const char *desc,  
SAMR_Q_QUERY_USERINFO * q_u,
+			      prs_struct *ps, int depth);
+void init_sam_user_info18(SAM_USER_INFO_18 * usr,
+			  const uint8 lm_pwd[16], const uint8 nt_pwd[16]);
+void init_sam_user_info7(SAM_USER_INFO_7 * usr, const char *name);
+void init_sam_user_info9(SAM_USER_INFO_9 * usr, uint32 rid_group);
+void init_sam_user_info16(SAM_USER_INFO_16 * usr, uint32 acb_info);
+void init_sam_user_info17(SAM_USER_INFO_17 * usr,
+			  NTTIME * expiry,
+			  char *mach_acct,
+			  uint32 rid_user, uint32 rid_group, uint16 acct_ctrl);
+void init_sam_user_info24(SAM_USER_INFO_24 * usr, char newpass[516],
+			  uint8 pw_len);
+void init_sam_user_info23W(SAM_USER_INFO_23 * usr, NTTIME *  
logon_time,	/* all zeros */
+			NTTIME * logoff_time,	/* all zeros */
+			NTTIME * kickoff_time,	/* all zeros */
+			NTTIME * pass_last_set_time,	/* all zeros */
+			NTTIME * pass_can_change_time,	/* all zeros */
+			NTTIME * pass_must_change_time,	/* all zeros */
+			UNISTR2 *user_name,
+			UNISTR2 *full_name,
+			UNISTR2 *home_dir,
+			UNISTR2 *dir_drive,
+			UNISTR2 *log_scr,
+			UNISTR2 *prof_path,
+			UNISTR2 *desc,
+			UNISTR2 *wkstas,
+			UNISTR2 *unk_str,
+			UNISTR2 *mung_dial,
+			uint32 user_rid,	/* 0x0000 0000 */
+			uint32 group_rid,
+			uint32 acb_info,
+			uint32 fields_present,
+			uint16 logon_divs,
+			LOGON_HRS * hrs,
+			uint16 bad_password_count,
+			uint16 logon_count,
+			char newpass[516]);
+void init_sam_user_info23A(SAM_USER_INFO_23 * usr, NTTIME *  
logon_time,	/* all zeros */
+			   NTTIME * logoff_time,	/* all zeros */
+			   NTTIME * kickoff_time,	/* all zeros */
+			   NTTIME * pass_last_set_time,	/* all zeros */
+			   NTTIME * pass_can_change_time,	/* all zeros */
+			   NTTIME * pass_must_change_time,	/* all zeros */
+			   char *user_name,	/* NULL */
+			   char *full_name,
+			   char *home_dir, char *dir_drive, char *log_scr,
+			   char *prof_path, const char *desc, char *wkstas,
+			   char *unk_str, char *mung_dial, uint32 user_rid,	/* 0x0000  
0000 */
+			   uint32 group_rid, uint32 acb_info,
+			   uint32 fields_present, uint16 logon_divs,
+			   LOGON_HRS * hrs, uint16 bad_password_count, uint16 logon_count,
+			   char newpass[516]);
+void init_sam_user_info21W(SAM_USER_INFO_21 * usr,
+			   NTTIME * logon_time,
+			   NTTIME * logoff_time,
+			   NTTIME * kickoff_time,
+			   NTTIME * pass_last_set_time,
+			   NTTIME * pass_can_change_time,
+			   NTTIME * pass_must_change_time,
+			   UNISTR2 *user_name,
+			   UNISTR2 *full_name,
+			   UNISTR2 *home_dir,
+			   UNISTR2 *dir_drive,
+			   UNISTR2 *log_scr,
+			   UNISTR2 *prof_path,
+			   UNISTR2 *desc,
+			   UNISTR2 *wkstas,
+			   UNISTR2 *unk_str,
+			   UNISTR2 *mung_dial,
+			   uchar lm_pwd[16],
+			   uchar nt_pwd[16],
+			   uint32 user_rid,
+			   uint32 group_rid,
+			   uint32 acb_info,
+			   uint32 fields_present,
+			   uint16 logon_divs,
+			   LOGON_HRS * hrs,
+			   uint16 bad_password_count,
+			   uint16 logon_count);
+NTSTATUS init_sam_user_info21A(SAM_USER_INFO_21 *usr, struct samu  
*pw, DOM_SID *domain_sid);
+void init_sam_user_info20A(SAM_USER_INFO_20 *usr, struct samu *pw);
+NTSTATUS make_samr_userinfo_ctr_usr21(TALLOC_CTX *ctx,  
SAM_USERINFO_CTR * ctr,
+				    uint16 switch_value,
+				    SAM_USER_INFO_21 * usr);
+void init_samr_r_query_userinfo(SAMR_R_QUERY_USERINFO * r_u,
+				SAM_USERINFO_CTR * ctr, NTSTATUS status);
+BOOL samr_io_r_query_userinfo(const char *desc,  
SAMR_R_QUERY_USERINFO * r_u,
+			      prs_struct *ps, int depth);
+void init_samr_q_set_userinfo(SAMR_Q_SET_USERINFO * q_u,
+			      const POLICY_HND *hnd, DATA_BLOB *sess_key,
+			      uint16 switch_value, void *info);
+BOOL samr_io_q_set_userinfo(const char *desc, SAMR_Q_SET_USERINFO *  
q_u,
+			    prs_struct *ps, int depth);
+void init_samr_r_set_userinfo(SAMR_R_SET_USERINFO * r_u, NTSTATUS  
status);
+BOOL samr_io_r_set_userinfo(const char *desc, SAMR_R_SET_USERINFO *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_set_userinfo2(SAMR_Q_SET_USERINFO2 * q_u,
+			       const POLICY_HND *hnd, DATA_BLOB *sess_key,
+			       uint16 switch_value, SAM_USERINFO_CTR * ctr);
+BOOL samr_io_q_set_userinfo2(const char *desc, SAMR_Q_SET_USERINFO2  
* q_u,
+			     prs_struct *ps, int depth);
+void init_samr_r_set_userinfo2(SAMR_R_SET_USERINFO2 * r_u, NTSTATUS  
status);
+BOOL samr_io_r_set_userinfo2(const char *desc, SAMR_R_SET_USERINFO2  
* r_u,
+			     prs_struct *ps, int depth);
+void init_samr_q_connect(SAMR_Q_CONNECT * q_u,
+			 char *srv_name, uint32 access_mask);
+BOOL samr_io_q_connect(const char *desc, SAMR_Q_CONNECT * q_u,
+		       prs_struct *ps, int depth);
+BOOL samr_io_r_connect(const char *desc, SAMR_R_CONNECT * r_u,
+		       prs_struct *ps, int depth);
+void init_samr_q_connect4(SAMR_Q_CONNECT4 * q_u,
+			  char *srv_name, uint32 access_mask);
+BOOL samr_io_q_connect4(const char *desc, SAMR_Q_CONNECT4 * q_u,
+			prs_struct *ps, int depth);
+BOOL samr_io_r_connect4(const char *desc, SAMR_R_CONNECT4 * r_u,
+			prs_struct *ps, int depth);
+void init_samr_q_connect5(SAMR_Q_CONNECT5 * q_u,
+			  char *srv_name, uint32 access_mask);
+void init_samr_r_connect5(SAMR_R_CONNECT5 * r_u, POLICY_HND *pol,  
NTSTATUS status);
+BOOL samr_io_q_connect5(const char *desc, SAMR_Q_CONNECT5 * q_u,
+			prs_struct *ps, int depth);
+BOOL samr_io_r_connect5(const char *desc, SAMR_R_CONNECT5 * r_u,
+			prs_struct *ps, int depth);
+void init_samr_q_connect_anon(SAMR_Q_CONNECT_ANON * q_u);
+BOOL samr_io_q_connect_anon(const char *desc, SAMR_Q_CONNECT_ANON *  
q_u,
+			    prs_struct *ps, int depth);
+BOOL samr_io_r_connect_anon(const char *desc, SAMR_R_CONNECT_ANON *  
r_u,
+			    prs_struct *ps, int depth);
+void init_samr_q_get_dom_pwinfo(SAMR_Q_GET_DOM_PWINFO * q_u,
+				char *srv_name);
+BOOL samr_io_q_get_dom_pwinfo(const char *desc,  
SAMR_Q_GET_DOM_PWINFO * q_u,
+			      prs_struct *ps, int depth);
+BOOL samr_io_r_get_dom_pwinfo(const char *desc,  
SAMR_R_GET_DOM_PWINFO * r_u,
+			      prs_struct *ps, int depth);
+void init_enc_passwd(SAMR_ENC_PASSWD * pwd, const char pass[512]);
+BOOL samr_io_enc_passwd(const char *desc, SAMR_ENC_PASSWD * pwd,
+			prs_struct *ps, int depth);
+void init_enc_hash(SAMR_ENC_HASH * hsh, const uchar hash[16]);
+BOOL samr_io_enc_hash(const char *desc, SAMR_ENC_HASH * hsh,
+		      prs_struct *ps, int depth);
+void init_samr_q_chgpasswd_user(SAMR_Q_CHGPASSWD_USER * q_u,
+				const char *dest_host, const char *user_name,
+				const uchar nt_newpass[516],
+				const uchar nt_oldhash[16],
+				const uchar lm_newpass[516],
+				const uchar lm_oldhash[16]);
+BOOL samr_io_q_chgpasswd_user(const char *desc,  
SAMR_Q_CHGPASSWD_USER * q_u,
+			      prs_struct *ps, int depth);
+void init_samr_r_chgpasswd_user(SAMR_R_CHGPASSWD_USER * r_u,  
NTSTATUS status);
+BOOL samr_io_r_chgpasswd_user(const char *desc,  
SAMR_R_CHGPASSWD_USER * r_u,
+			      prs_struct *ps, int depth);
+void init_samr_q_chgpasswd_user3(SAMR_Q_CHGPASSWD_USER3 * q_u,
+				 const char *dest_host, const char *user_name,
+				 const uchar nt_newpass[516],
+				 const uchar nt_oldhash[16],
+				 const uchar lm_newpass[516],
+				 const uchar lm_oldhash[16]);
+BOOL samr_io_q_chgpasswd_user3(const char *desc,  
SAMR_Q_CHGPASSWD_USER3 * q_u,
+			       prs_struct *ps, int depth);
+void init_samr_r_chgpasswd_user3(SAMR_R_CHGPASSWD_USER3 *r_u,  
NTSTATUS status,
+				 SAMR_CHANGE_REJECT *reject, SAM_UNK_INFO_1 *info);
+BOOL samr_io_change_reject(const char *desc, SAMR_CHANGE_REJECT  
*reject, prs_struct *ps, int depth);
+BOOL samr_io_r_chgpasswd_user3(const char *desc,  
SAMR_R_CHGPASSWD_USER3 *r_u,
+			       prs_struct *ps, int depth);
+void init_samr_q_query_domain_info2(SAMR_Q_QUERY_DOMAIN_INFO2 *q_u,
+				POLICY_HND *domain_pol, uint16 switch_value);
+BOOL samr_io_q_query_domain_info2(const char *desc,  
SAMR_Q_QUERY_DOMAIN_INFO2 *q_u,
+			      prs_struct *ps, int depth);
+void init_samr_r_query_domain_info2(SAMR_R_QUERY_DOMAIN_INFO2 * r_u,
+				    uint16 switch_value, SAM_UNK_CTR * ctr,
+				    NTSTATUS status);
+BOOL samr_io_r_query_domain_info2(const char *desc,  
SAMR_R_QUERY_DOMAIN_INFO2 * r_u,
+				  prs_struct *ps, int depth);
+void init_samr_q_set_domain_info(SAMR_Q_SET_DOMAIN_INFO *q_u,
+				POLICY_HND *domain_pol, uint16 switch_value, SAM_UNK_CTR *ctr);
+BOOL samr_io_q_set_domain_info(const char *desc,  
SAMR_Q_SET_DOMAIN_INFO *q_u,
+			      prs_struct *ps, int depth);
+void init_samr_r_set_domain_info(SAMR_R_SET_DOMAIN_INFO * r_u,  
NTSTATUS status);
+BOOL samr_io_r_set_domain_info(const char *desc,  
SAMR_R_SET_DOMAIN_INFO * r_u,
+			      prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_sec.c  */
+
+BOOL sec_io_access(const char *desc, SEC_ACCESS *t, prs_struct *ps,  
int depth);
+BOOL sec_io_ace(const char *desc, SEC_ACE *psa, prs_struct *ps, int  
depth);
+BOOL sec_io_acl(const char *desc, SEC_ACL **ppsa, prs_struct *ps,  
int depth);
+BOOL sec_io_desc(const char *desc, SEC_DESC **ppsd, prs_struct *ps,  
int depth);
+BOOL sec_io_desc_buf(const char *desc, SEC_DESC_BUF **ppsdb,  
prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_parse/parse_spoolss.c  */
+
+BOOL spoolss_io_system_time(const char *desc, prs_struct *ps, int  
depth, SYSTEMTIME *systime);
+BOOL make_systemtime(SYSTEMTIME *systime, struct tm *unixtime);
+BOOL smb_io_notify_info_data_strings(const char  
*desc,SPOOL_NOTIFY_INFO_DATA *data,
+                                     prs_struct *ps, int depth);
+BOOL spool_io_user_level_1( const char *desc, prs_struct *ps, int  
depth, SPOOL_USER_1 *q_u );
+BOOL spoolss_io_devmode(const char *desc, prs_struct *ps, int depth,  
DEVICEMODE *devmode);
+BOOL make_spoolss_q_open_printer_ex(SPOOL_Q_OPEN_PRINTER_EX *q_u,
+		const fstring printername,
+		const fstring datatype,
+		uint32 access_required,
+		const fstring clientname,
+		const fstring user_name);
+BOOL make_spoolss_q_addprinterex( TALLOC_CTX *mem_ctx,  
SPOOL_Q_ADDPRINTEREX *q_u,
+	const char *srv_name, const char* clientname, const char* user_name,
+	uint32 level, PRINTER_INFO_CTR *ctr);
+BOOL make_spoolss_printer_info_2(TALLOC_CTX *mem_ctx,  
SPOOL_PRINTER_INFO_LEVEL_2 **spool_info2,
+				PRINTER_INFO_2 *info);
+BOOL make_spoolss_printer_info_3(TALLOC_CTX *mem_ctx,  
SPOOL_PRINTER_INFO_LEVEL_3 **spool_info3,
+				PRINTER_INFO_3 *info);
+BOOL make_spoolss_printer_info_7(TALLOC_CTX *mem_ctx,  
SPOOL_PRINTER_INFO_LEVEL_7 **spool_info7,
+				PRINTER_INFO_7 *info);
+BOOL spoolss_io_q_open_printer(const char *desc,  
SPOOL_Q_OPEN_PRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_open_printer(const char *desc,  
SPOOL_R_OPEN_PRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_open_printer_ex(const char *desc,  
SPOOL_Q_OPEN_PRINTER_EX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_open_printer_ex(const char *desc,  
SPOOL_R_OPEN_PRINTER_EX *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_deleteprinterdriverex( TALLOC_CTX *mem_ctx,
+                                            
SPOOL_Q_DELETEPRINTERDRIVEREX *q_u,
+                                           const char *server,
+                                           const char* arch,
+                                           const char* driver,
+                                           int version);
+BOOL make_spoolss_q_deleteprinterdriver(
+	TALLOC_CTX *mem_ctx,
+	SPOOL_Q_DELETEPRINTERDRIVER *q_u,
+	const char *server,
+	const char* arch,
+	const char* driver
+);
+BOOL make_spoolss_q_getprinterdata(SPOOL_Q_GETPRINTERDATA *q_u,
+				   const POLICY_HND *handle,
+				   const char *valuename, uint32 size);
+BOOL make_spoolss_q_getprinterdataex(SPOOL_Q_GETPRINTERDATAEX *q_u,
+				     const POLICY_HND *handle,
+				     const char *keyname,
+				     const char *valuename, uint32 size);
+BOOL spoolss_io_q_getprinterdata(const char *desc,  
SPOOL_Q_GETPRINTERDATA *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_deleteprinterdata(const char *desc,  
SPOOL_Q_DELETEPRINTERDATA *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_deleteprinterdata(const char *desc,  
SPOOL_R_DELETEPRINTERDATA *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_deleteprinterdataex(const char *desc,  
SPOOL_Q_DELETEPRINTERDATAEX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_deleteprinterdataex(const char *desc,  
SPOOL_R_DELETEPRINTERDATAEX *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_getprinterdata(const char *desc,  
SPOOL_R_GETPRINTERDATA *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_closeprinter(SPOOL_Q_CLOSEPRINTER *q_u,  
POLICY_HND *hnd);
+BOOL spoolss_io_q_abortprinter(const char *desc,  
SPOOL_Q_ABORTPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_abortprinter(const char *desc,  
SPOOL_R_ABORTPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_deleteprinter(const char *desc,  
SPOOL_Q_DELETEPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_deleteprinter(const char *desc,  
SPOOL_R_DELETEPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_deleteprinterdriver(const char *desc,  
SPOOL_Q_DELETEPRINTERDRIVER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_deleteprinterdriver(const char *desc,  
SPOOL_R_DELETEPRINTERDRIVER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_deleteprinterdriverex(const char *desc,  
SPOOL_Q_DELETEPRINTERDRIVEREX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_deleteprinterdriverex(const char *desc,  
SPOOL_R_DELETEPRINTERDRIVEREX *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_closeprinter(const char *desc,  
SPOOL_Q_CLOSEPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_closeprinter(const char *desc,  
SPOOL_R_CLOSEPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_startdocprinter(const char *desc,  
SPOOL_Q_STARTDOCPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_startdocprinter(const char *desc,  
SPOOL_R_STARTDOCPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enddocprinter(const char *desc,  
SPOOL_Q_ENDDOCPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enddocprinter(const char *desc,  
SPOOL_R_ENDDOCPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_startpageprinter(const char *desc,  
SPOOL_Q_STARTPAGEPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_startpageprinter(const char *desc,  
SPOOL_R_STARTPAGEPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_endpageprinter(const char *desc,  
SPOOL_Q_ENDPAGEPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_endpageprinter(const char *desc,  
SPOOL_R_ENDPAGEPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_writeprinter(const char *desc,  
SPOOL_Q_WRITEPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_writeprinter(const char *desc,  
SPOOL_R_WRITEPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_rffpcnex(const char *desc, SPOOL_Q_RFFPCNEX *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_rffpcnex(const char *desc, SPOOL_R_RFFPCNEX *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_q_rfnpcnex(const char *desc, SPOOL_Q_RFNPCNEX *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_rfnpcnex(const char *desc, SPOOL_R_RFNPCNEX *r_u,  
prs_struct *ps, int depth);
+BOOL smb_io_printer_info_0(const char *desc, RPC_BUFFER *buffer,  
PRINTER_INFO_0 *info, int depth);
+BOOL smb_io_printer_info_1(const char *desc, RPC_BUFFER *buffer,  
PRINTER_INFO_1 *info, int depth);
+BOOL smb_io_printer_info_2(const char *desc, RPC_BUFFER *buffer,  
PRINTER_INFO_2 *info, int depth);
+BOOL smb_io_printer_info_3(const char *desc, RPC_BUFFER *buffer,  
PRINTER_INFO_3 *info, int depth);
+BOOL smb_io_printer_info_4(const char *desc, RPC_BUFFER *buffer,  
PRINTER_INFO_4 *info, int depth);
+BOOL smb_io_printer_info_5(const char *desc, RPC_BUFFER *buffer,  
PRINTER_INFO_5 *info, int depth);
+BOOL smb_io_printer_info_6(const char *desc, RPC_BUFFER *buffer,
+			   PRINTER_INFO_6 *info, int depth);
+BOOL smb_io_printer_info_7(const char *desc, RPC_BUFFER *buffer,  
PRINTER_INFO_7 *info, int depth);
+BOOL smb_io_port_info_1(const char *desc, RPC_BUFFER *buffer,  
PORT_INFO_1 *info, int depth);
+BOOL smb_io_port_info_2(const char *desc, RPC_BUFFER *buffer,  
PORT_INFO_2 *info, int depth);
+BOOL smb_io_printer_driver_info_1(const char *desc, RPC_BUFFER  
*buffer, DRIVER_INFO_1 *info, int depth) ;
+BOOL smb_io_printer_driver_info_2(const char *desc, RPC_BUFFER  
*buffer, DRIVER_INFO_2 *info, int depth) ;
+BOOL smb_io_printer_driver_info_3(const char *desc, RPC_BUFFER  
*buffer, DRIVER_INFO_3 *info, int depth);
+BOOL smb_io_printer_driver_info_6(const char *desc, RPC_BUFFER  
*buffer, DRIVER_INFO_6 *info, int depth);
+BOOL smb_io_job_info_1(const char *desc, RPC_BUFFER *buffer,  
JOB_INFO_1 *info, int depth);
+BOOL smb_io_job_info_2(const char *desc, RPC_BUFFER *buffer,  
JOB_INFO_2 *info, int depth);
+BOOL smb_io_form_1(const char *desc, RPC_BUFFER *buffer, FORM_1  
*info, int depth);
+BOOL smb_io_driverdir_1(const char *desc, RPC_BUFFER *buffer,  
DRIVER_DIRECTORY_1 *info, int depth);
+BOOL smb_io_port_1(const char *desc, RPC_BUFFER *buffer, PORT_INFO_1  
*info, int depth);
+BOOL smb_io_port_2(const char *desc, RPC_BUFFER *buffer, PORT_INFO_2  
*info, int depth);
+BOOL smb_io_printprocessor_info_1(const char *desc, RPC_BUFFER  
*buffer, PRINTPROCESSOR_1 *info, int depth);
+BOOL smb_io_printprocdatatype_info_1(const char *desc, RPC_BUFFER  
*buffer, PRINTPROCDATATYPE_1 *info, int depth);
+BOOL smb_io_printmonitor_info_1(const char *desc, RPC_BUFFER  
*buffer, PRINTMONITOR_1 *info, int depth);
+BOOL smb_io_printmonitor_info_2(const char *desc, RPC_BUFFER  
*buffer, PRINTMONITOR_2 *info, int depth);
+uint32 spoolss_size_printer_info_0(PRINTER_INFO_0 *info);
+uint32 spoolss_size_printer_info_1(PRINTER_INFO_1 *info);
+uint32 spoolss_size_printer_info_2(PRINTER_INFO_2 *info);
+uint32 spoolss_size_printer_info_4(PRINTER_INFO_4 *info);
+uint32 spoolss_size_printer_info_5(PRINTER_INFO_5 *info);
+uint32 spoolss_size_printer_info_6(PRINTER_INFO_6 *info);
+uint32 spoolss_size_printer_info_3(PRINTER_INFO_3 *info);
+uint32 spoolss_size_printer_info_7(PRINTER_INFO_7 *info);
+uint32 spoolss_size_printer_driver_info_1(DRIVER_INFO_1 *info);
+uint32 spoolss_size_printer_driver_info_2(DRIVER_INFO_2 *info);
+uint32 spoolss_size_string_array(uint16 *string);
+uint32 spoolss_size_printer_driver_info_3(DRIVER_INFO_3 *info);
+uint32 spoolss_size_printer_driver_info_6(DRIVER_INFO_6 *info);
+uint32 spoolss_size_job_info_1(JOB_INFO_1 *info);
+uint32 spoolss_size_job_info_2(JOB_INFO_2 *info);
+uint32 spoolss_size_form_1(FORM_1 *info);
+uint32 spoolss_size_port_info_1(PORT_INFO_1 *info);
+uint32 spoolss_size_driverdir_info_1(DRIVER_DIRECTORY_1 *info);
+uint32 spoolss_size_printprocessordirectory_info_1 
(PRINTPROCESSOR_DIRECTORY_1 *info);
+uint32 spoolss_size_port_info_2(PORT_INFO_2 *info);
+uint32 spoolss_size_printprocessor_info_1(PRINTPROCESSOR_1 *info);
+uint32 spoolss_size_printprocdatatype_info_1(PRINTPROCDATATYPE_1  
*info);
+uint32 spoolss_size_printer_enum_values(PRINTER_ENUM_VALUES *p);
+uint32 spoolss_size_printmonitor_info_1(PRINTMONITOR_1 *info);
+uint32 spoolss_size_printmonitor_info_2(PRINTMONITOR_2 *info);
+BOOL make_spoolss_q_getprinterdriver2(SPOOL_Q_GETPRINTERDRIVER2 *q_u,
+			       const POLICY_HND *hnd,
+			       const fstring architecture,
+			       uint32 level, uint32 clientmajor, uint32 clientminor,
+			       RPC_BUFFER *buffer, uint32 offered);
+BOOL spoolss_io_q_getprinterdriver2(const char *desc,  
SPOOL_Q_GETPRINTERDRIVER2 *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_getprinterdriver2(const char *desc,  
SPOOL_R_GETPRINTERDRIVER2 *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_enumprinters(
+	SPOOL_Q_ENUMPRINTERS *q_u,
+	uint32 flags,
+	char *servername,
+	uint32 level,
+	RPC_BUFFER *buffer,
+	uint32 offered
+);
+BOOL make_spoolss_q_enumports(SPOOL_Q_ENUMPORTS *q_u,
+				fstring servername, uint32 level,
+				RPC_BUFFER *buffer, uint32 offered);
+BOOL spoolss_io_q_enumprinters(const char *desc,  
SPOOL_Q_ENUMPRINTERS *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprinters(const char *desc,  
SPOOL_R_ENUMPRINTERS *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_getprinter(const char *desc, SPOOL_R_GETPRINTER  
*r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_getprinter(const char *desc, SPOOL_Q_GETPRINTER  
*q_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_getprinter(
+	TALLOC_CTX *mem_ctx,
+	SPOOL_Q_GETPRINTER *q_u,
+	const POLICY_HND *hnd,
+	uint32 level,
+	RPC_BUFFER *buffer,
+	uint32 offered
+);
+BOOL make_spoolss_q_setprinter(TALLOC_CTX *mem_ctx,  
SPOOL_Q_SETPRINTER *q_u,
+				const POLICY_HND *hnd, uint32 level, PRINTER_INFO_CTR *info,
+				uint32 command);
+BOOL spoolss_io_r_setprinter(const char *desc, SPOOL_R_SETPRINTER  
*r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_setprinter(const char *desc, SPOOL_Q_SETPRINTER  
*q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_fcpn(const char *desc, SPOOL_R_FCPN *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_q_fcpn(const char *desc, SPOOL_Q_FCPN *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_addjob(const char *desc, SPOOL_R_ADDJOB *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_q_addjob(const char *desc, SPOOL_Q_ADDJOB *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumjobs(const char *desc, SPOOL_R_ENUMJOBS *r_u,  
prs_struct *ps, int depth);
+BOOL make_spoolss_q_enumjobs(SPOOL_Q_ENUMJOBS *q_u, const POLICY_HND  
*hnd,
+				uint32 firstjob,
+				uint32 numofjobs,
+				uint32 level,
+				RPC_BUFFER *buffer,
+				uint32 offered);
+BOOL spoolss_io_q_enumjobs(const char *desc, SPOOL_Q_ENUMJOBS *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_schedulejob(const char *desc, SPOOL_R_SCHEDULEJOB  
*r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_schedulejob(const char *desc, SPOOL_Q_SCHEDULEJOB  
*q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_setjob(const char *desc, SPOOL_R_SETJOB *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_q_setjob(const char *desc, SPOOL_Q_SETJOB *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprinterdrivers(const char *desc,  
SPOOL_R_ENUMPRINTERDRIVERS *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_enumprinterdrivers(SPOOL_Q_ENUMPRINTERDRIVERS *q_u,
+                                const char *name,
+                                const char *environment,
+                                uint32 level,
+                                RPC_BUFFER *buffer, uint32 offered);
+BOOL spoolss_io_q_enumprinterdrivers(const char *desc,  
SPOOL_Q_ENUMPRINTERDRIVERS *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enumforms(const char *desc, SPOOL_Q_ENUMFORMS  
*q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumforms(const char *desc, SPOOL_R_ENUMFORMS  
*r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_getform(const char *desc, SPOOL_Q_GETFORM *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_getform(const char *desc, SPOOL_R_GETFORM *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumports(const char *desc, SPOOL_R_ENUMPORTS  
*r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enumports(const char *desc, SPOOL_Q_ENUMPORTS  
*q_u, prs_struct *ps, int depth);
+BOOL spool_io_printer_info_level_1(const char *desc,  
SPOOL_PRINTER_INFO_LEVEL_1 *il, prs_struct *ps, int depth);
+BOOL spool_io_printer_info_level_3(const char *desc,  
SPOOL_PRINTER_INFO_LEVEL_3 *il, prs_struct *ps, int depth);
+BOOL spool_io_printer_info_level_2(const char *desc,  
SPOOL_PRINTER_INFO_LEVEL_2 *il, prs_struct *ps, int depth);
+BOOL spool_io_printer_info_level_7(const char *desc,  
SPOOL_PRINTER_INFO_LEVEL_7 *il, prs_struct *ps, int depth);
+BOOL spool_io_printer_info_level(const char *desc,  
SPOOL_PRINTER_INFO_LEVEL *il, prs_struct *ps, int depth);
+BOOL spoolss_io_q_addprinterex(const char *desc,  
SPOOL_Q_ADDPRINTEREX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_addprinterex(const char *desc,  
SPOOL_R_ADDPRINTEREX *r_u,
+			       prs_struct *ps, int depth);
+BOOL spool_io_printer_driver_info_level_3(const char *desc,  
SPOOL_PRINTER_DRIVER_INFO_LEVEL_3 **q_u,
+                                          prs_struct *ps, int depth);
+BOOL spool_io_printer_driver_info_level_6(const char *desc,  
SPOOL_PRINTER_DRIVER_INFO_LEVEL_6 **q_u,
+                                          prs_struct *ps, int depth);
+BOOL smb_io_unibuffer(const char *desc, UNISTR2 *buffer, prs_struct  
*ps, int depth);
+BOOL spool_io_printer_driver_info_level(const char *desc,  
SPOOL_PRINTER_DRIVER_INFO_LEVEL *il, prs_struct *ps, int depth);
+BOOL make_spoolss_q_addprinterdriver(TALLOC_CTX *mem_ctx,
+				SPOOL_Q_ADDPRINTERDRIVER *q_u, const char* srv_name,
+				uint32 level, PRINTER_DRIVER_CTR *info);
+BOOL make_spoolss_driver_info_3(TALLOC_CTX *mem_ctx,
+	SPOOL_PRINTER_DRIVER_INFO_LEVEL_3 **spool_drv_info,
+				DRIVER_INFO_3 *info3);
+BOOL make_spoolss_buffer5(TALLOC_CTX *mem_ctx, BUFFER5 *buf5, uint32  
len, uint16 *src);
+BOOL spoolss_io_q_addprinterdriver(const char *desc,  
SPOOL_Q_ADDPRINTERDRIVER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_addprinterdriver(const char *desc,  
SPOOL_R_ADDPRINTERDRIVER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_addprinterdriverex(const char *desc,  
SPOOL_Q_ADDPRINTERDRIVEREX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_addprinterdriverex(const char *desc,  
SPOOL_R_ADDPRINTERDRIVEREX *q_u, prs_struct *ps, int depth);
+BOOL uni_2_asc_printer_driver_3(SPOOL_PRINTER_DRIVER_INFO_LEVEL_3 *uni,
+                                NT_PRINTER_DRIVER_INFO_LEVEL_3 **asc);
+BOOL uni_2_asc_printer_driver_6(SPOOL_PRINTER_DRIVER_INFO_LEVEL_6 *uni,
+                                NT_PRINTER_DRIVER_INFO_LEVEL_6 **asc);
+BOOL uni_2_asc_printer_info_2(const SPOOL_PRINTER_INFO_LEVEL_2 *uni,
+                              NT_PRINTER_INFO_LEVEL_2  *d);
+BOOL make_spoolss_q_getprinterdriverdir(SPOOL_Q_GETPRINTERDRIVERDIR  
*q_u,
+                                fstring servername, fstring  
env_name, uint32 level,
+                                RPC_BUFFER *buffer, uint32 offered);
+BOOL spoolss_io_q_getprinterdriverdir(const char *desc,  
SPOOL_Q_GETPRINTERDRIVERDIR *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_getprinterdriverdir(const char *desc,  
SPOOL_R_GETPRINTERDRIVERDIR *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprintprocessors(const char *desc,  
SPOOL_R_ENUMPRINTPROCESSORS *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enumprintprocessors(const char *desc,  
SPOOL_Q_ENUMPRINTPROCESSORS *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_addprintprocessor(const char *desc,  
SPOOL_Q_ADDPRINTPROCESSOR *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_addprintprocessor(const char *desc,  
SPOOL_R_ADDPRINTPROCESSOR *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprintprocdatatypes(const char *desc,  
SPOOL_R_ENUMPRINTPROCDATATYPES *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enumprintprocdatatypes(const char *desc,  
SPOOL_Q_ENUMPRINTPROCDATATYPES *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enumprintmonitors(const char *desc,  
SPOOL_Q_ENUMPRINTMONITORS *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprintmonitors(const char *desc,  
SPOOL_R_ENUMPRINTMONITORS *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprinterdata(const char *desc,  
SPOOL_R_ENUMPRINTERDATA *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enumprinterdata(const char *desc,  
SPOOL_Q_ENUMPRINTERDATA *q_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_enumprinterdata(SPOOL_Q_ENUMPRINTERDATA *q_u,
+		const POLICY_HND *hnd,
+		uint32 idx, uint32 valuelen, uint32 datalen);
+BOOL make_spoolss_q_enumprinterdataex(SPOOL_Q_ENUMPRINTERDATAEX *q_u,
+				      const POLICY_HND *hnd, const char *key,
+				      uint32 size);
+BOOL make_spoolss_q_setprinterdata(SPOOL_Q_SETPRINTERDATA *q_u,  
const POLICY_HND *hnd,
+				   char* value, uint32 data_type, char* data, uint32 data_size);
+BOOL make_spoolss_q_setprinterdataex(SPOOL_Q_SETPRINTERDATAEX *q_u,  
const POLICY_HND *hnd,
+				     char *key, char* value, uint32 data_type, char* data,
+				     uint32 data_size);
+BOOL spoolss_io_q_setprinterdata(const char *desc,  
SPOOL_Q_SETPRINTERDATA *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_setprinterdata(const char *desc,  
SPOOL_R_SETPRINTERDATA *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_resetprinter(const char *desc,  
SPOOL_Q_RESETPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_resetprinter(const char *desc,  
SPOOL_R_RESETPRINTER *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_deleteform(const char *desc, SPOOL_Q_DELETEFORM  
*q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_deleteform(const char *desc, SPOOL_R_DELETEFORM  
*r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_addform(const char *desc, SPOOL_Q_ADDFORM *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_addform(const char *desc, SPOOL_R_ADDFORM *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_q_setform(const char *desc, SPOOL_Q_SETFORM *q_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_setform(const char *desc, SPOOL_R_SETFORM *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_r_getjob(const char *desc, SPOOL_R_GETJOB *r_u,  
prs_struct *ps, int depth);
+BOOL spoolss_io_q_getjob(const char *desc, SPOOL_Q_GETJOB *q_u,  
prs_struct *ps, int depth);
+void free_devmode(DEVICEMODE *devmode);
+void free_printer_info_1(PRINTER_INFO_1 *printer);
+void free_printer_info_2(PRINTER_INFO_2 *printer);
+void free_printer_info_3(PRINTER_INFO_3 *printer);
+void free_printer_info_4(PRINTER_INFO_4 *printer);
+void free_printer_info_5(PRINTER_INFO_5 *printer);
+void free_printer_info_6(PRINTER_INFO_6 *printer);
+void free_printer_info_7(PRINTER_INFO_7 *printer);
+void free_job_info_2(JOB_INFO_2 *job);
+BOOL make_spoolss_q_replyopenprinter(SPOOL_Q_REPLYOPENPRINTER *q_u,
+			       const fstring string, uint32 printer, uint32 type);
+BOOL spoolss_io_q_replyopenprinter(const char *desc,  
SPOOL_Q_REPLYOPENPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_replyopenprinter(const char *desc,  
SPOOL_R_REPLYOPENPRINTER *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_routerreplyprinter(SPOOL_Q_ROUTERREPLYPRINTER  
*q_u, POLICY_HND *hnd,
+					uint32 condition, uint32 change_id);
+BOOL spoolss_io_q_routerreplyprinter (const char *desc,  
SPOOL_Q_ROUTERREPLYPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_routerreplyprinter (const char *desc,  
SPOOL_R_ROUTERREPLYPRINTER *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_reply_closeprinter(SPOOL_Q_REPLYCLOSEPRINTER  
*q_u, POLICY_HND *hnd);
+BOOL spoolss_io_q_replycloseprinter(const char *desc,  
SPOOL_Q_REPLYCLOSEPRINTER *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_replycloseprinter(const char *desc,  
SPOOL_R_REPLYCLOSEPRINTER *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_reply_rrpcn(SPOOL_Q_REPLY_RRPCN *q_u, POLICY_HND  
*hnd,
+			        uint32 change_low, uint32 change_high,
+				SPOOL_NOTIFY_INFO *info);
+BOOL spoolss_io_q_reply_rrpcn(const char *desc, SPOOL_Q_REPLY_RRPCN  
*q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_reply_rrpcn(const char *desc, SPOOL_R_REPLY_RRPCN  
*r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_getprinterdataex(const char *desc,  
SPOOL_Q_GETPRINTERDATAEX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_getprinterdataex(const char *desc,  
SPOOL_R_GETPRINTERDATAEX *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_setprinterdataex(const char *desc,  
SPOOL_Q_SETPRINTERDATAEX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_setprinterdataex(const char *desc,  
SPOOL_R_SETPRINTERDATAEX *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_enumprinterkey(SPOOL_Q_ENUMPRINTERKEY *q_u,
+				   POLICY_HND *hnd, const char *key,
+				   uint32 size);
+BOOL spoolss_io_q_enumprinterkey(const char *desc,  
SPOOL_Q_ENUMPRINTERKEY *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprinterkey(const char *desc,  
SPOOL_R_ENUMPRINTERKEY *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_deleteprinterkey(SPOOL_Q_DELETEPRINTERKEY *q_u,
+				     POLICY_HND *hnd, char *keyname);
+BOOL spoolss_io_q_deleteprinterkey(const char *desc,  
SPOOL_Q_DELETEPRINTERKEY *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_deleteprinterkey(const char *desc,  
SPOOL_R_DELETEPRINTERKEY *r_u, prs_struct *ps, int depth);
+BOOL spoolss_io_q_enumprinterdataex(const char *desc,  
SPOOL_Q_ENUMPRINTERDATAEX *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_enumprinterdataex(const char *desc,  
SPOOL_R_ENUMPRINTERDATAEX *r_u, prs_struct *ps, int depth);
+BOOL make_spoolss_q_getprintprocessordirectory 
(SPOOL_Q_GETPRINTPROCESSORDIRECTORY *q_u, const char *name, char  
*environment, int level, RPC_BUFFER *buffer, uint32 offered);
+BOOL spoolss_io_q_getprintprocessordirectory(const char *desc,  
SPOOL_Q_GETPRINTPROCESSORDIRECTORY *q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_getprintprocessordirectory(const char *desc,  
SPOOL_R_GETPRINTPROCESSORDIRECTORY *r_u, prs_struct *ps, int depth);
+BOOL smb_io_printprocessordirectory_1(const char *desc, RPC_BUFFER  
*buffer, PRINTPROCESSOR_DIRECTORY_1 *info, int depth);
+BOOL make_spoolss_q_addform(SPOOL_Q_ADDFORM *q_u, POLICY_HND *handle,
+			    int level, FORM *form);
+BOOL make_spoolss_q_setform(SPOOL_Q_SETFORM *q_u, POLICY_HND *handle,
+			    int level, const char *form_name, FORM *form);
+BOOL make_spoolss_q_deleteform(SPOOL_Q_DELETEFORM *q_u, POLICY_HND  
*handle,
+			       const char *form);
+BOOL make_spoolss_q_getform(SPOOL_Q_GETFORM *q_u, POLICY_HND *handle,
+                            const char *formname, uint32 level,
+			    RPC_BUFFER *buffer, uint32 offered);
+BOOL make_spoolss_q_enumforms(SPOOL_Q_ENUMFORMS *q_u, POLICY_HND  
*handle,
+			      uint32 level, RPC_BUFFER *buffer,
+			      uint32 offered);
+BOOL make_spoolss_q_setjob(SPOOL_Q_SETJOB *q_u, POLICY_HND *handle,
+			   uint32 jobid, uint32 level, uint32 command);
+BOOL make_spoolss_q_getjob(SPOOL_Q_GETJOB *q_u, POLICY_HND *handle,
+			   uint32 jobid, uint32 level, RPC_BUFFER *buffer,
+			   uint32 offered);
+BOOL make_spoolss_q_startpageprinter(SPOOL_Q_STARTPAGEPRINTER *q_u,
+				     POLICY_HND *handle);
+BOOL make_spoolss_q_endpageprinter(SPOOL_Q_ENDPAGEPRINTER *q_u,
+				   POLICY_HND *handle);
+BOOL make_spoolss_q_startdocprinter(SPOOL_Q_STARTDOCPRINTER *q_u,
+				    POLICY_HND *handle, uint32 level,
+				    char *docname, char *outputfile,
+				    char *datatype);
+BOOL make_spoolss_q_enddocprinter(SPOOL_Q_ENDDOCPRINTER *q_u,
+				  POLICY_HND *handle);
+BOOL make_spoolss_q_writeprinter(SPOOL_Q_WRITEPRINTER *q_u,
+				 POLICY_HND *handle, uint32 data_size,
+				 char *data);
+BOOL make_spoolss_q_deleteprinterdata(SPOOL_Q_DELETEPRINTERDATA *q_u,
+				 POLICY_HND *handle, char *valuename);
+BOOL make_spoolss_q_deleteprinterdataex(SPOOL_Q_DELETEPRINTERDATAEX  
*q_u,
+					POLICY_HND *handle, char *key,
+					char *value);
+BOOL make_spoolss_q_rffpcnex(SPOOL_Q_RFFPCNEX *q_u, POLICY_HND *handle,
+			     uint32 flags, uint32 options, const char *localmachine,
+			     uint32 printerlocal, SPOOL_NOTIFY_OPTION *option);
+BOOL spoolss_io_q_xcvdataport(const char *desc, SPOOL_Q_XCVDATAPORT  
*q_u, prs_struct *ps, int depth);
+BOOL spoolss_io_r_xcvdataport(const char *desc, SPOOL_R_XCVDATAPORT  
*r_u, prs_struct *ps, int depth);
+BOOL make_monitorui_buf( RPC_BUFFER *buf, const char *dllname );
+BOOL convert_port_data_1( NT_PORT_DATA_1 *port1, RPC_BUFFER *buf ) ;
+
+/* The following definitions come from rpc_parse/parse_svcctl.c  */
+
+BOOL svcctl_io_enum_services_status( const char *desc,  
ENUM_SERVICES_STATUS *enum_status, RPC_BUFFER *buffer, int depth );
+BOOL svcctl_io_service_status_process( const char *desc,  
SERVICE_STATUS_PROCESS *status, RPC_BUFFER *buffer, int depth );
+uint32 svcctl_sizeof_enum_services_status( ENUM_SERVICES_STATUS  
*status );
+uint32 svcctl_sizeof_service_config( SERVICE_CONFIG *config );
+BOOL svcctl_io_q_open_scmanager(const char *desc,  
SVCCTL_Q_OPEN_SCMANAGER *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_open_scmanager(const char *desc,  
SVCCTL_R_OPEN_SCMANAGER *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_get_display_name(const char *desc,  
SVCCTL_Q_GET_DISPLAY_NAME *q_u, prs_struct *ps, int depth);
+BOOL init_svcctl_r_get_display_name( SVCCTL_R_GET_DISPLAY_NAME *r_u,  
const char *displayname );
+BOOL svcctl_io_r_get_display_name(const char *desc,  
SVCCTL_R_GET_DISPLAY_NAME *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_open_service(const char *desc,  
SVCCTL_Q_OPEN_SERVICE *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_open_service(const char *desc,  
SVCCTL_R_OPEN_SERVICE *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_query_status(const char *desc,  
SVCCTL_Q_QUERY_STATUS *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_query_status(const char *desc,  
SVCCTL_R_QUERY_STATUS *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_enum_services_status(const char *desc,  
SVCCTL_Q_ENUM_SERVICES_STATUS *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_enum_services_status(const char *desc,  
SVCCTL_R_ENUM_SERVICES_STATUS *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_start_service(const char *desc,  
SVCCTL_Q_START_SERVICE *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_start_service(const char *desc,  
SVCCTL_R_START_SERVICE *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_enum_dependent_services(const char *desc,  
SVCCTL_Q_ENUM_DEPENDENT_SERVICES *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_enum_dependent_services(const char *desc,  
SVCCTL_R_ENUM_DEPENDENT_SERVICES *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_control_service(const char *desc,  
SVCCTL_Q_CONTROL_SERVICE *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_control_service(const char *desc,  
SVCCTL_R_CONTROL_SERVICE *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_query_service_config(const char *desc,  
SVCCTL_Q_QUERY_SERVICE_CONFIG *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_query_service_config(const char *desc,  
SVCCTL_R_QUERY_SERVICE_CONFIG *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_query_service_config2(const char *desc,  
SVCCTL_Q_QUERY_SERVICE_CONFIG2 *q_u, prs_struct *ps, int depth);
+void init_service_description_buffer(SERVICE_DESCRIPTION *desc,  
const char *service_desc );
+BOOL svcctl_io_service_description( const char *desc,  
SERVICE_DESCRIPTION *description, RPC_BUFFER *buffer, int depth );
+uint32 svcctl_sizeof_service_description( SERVICE_DESCRIPTION *desc );
+BOOL svcctl_io_service_fa( const char *desc, SERVICE_FAILURE_ACTIONS  
*fa, RPC_BUFFER *buffer, int depth );
+uint32 svcctl_sizeof_service_fa( SERVICE_FAILURE_ACTIONS *fa);
+BOOL svcctl_io_r_query_service_config2(const char *desc,  
SVCCTL_R_QUERY_SERVICE_CONFIG2 *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_query_service_status_ex(const char *desc,  
SVCCTL_Q_QUERY_SERVICE_STATUSEX *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_query_service_status_ex(const char *desc,  
SVCCTL_R_QUERY_SERVICE_STATUSEX *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_lock_service_db(const char *desc,  
SVCCTL_Q_LOCK_SERVICE_DB *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_lock_service_db(const char *desc,  
SVCCTL_R_LOCK_SERVICE_DB *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_unlock_service_db(const char *desc,  
SVCCTL_Q_UNLOCK_SERVICE_DB *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_unlock_service_db(const char *desc,  
SVCCTL_R_UNLOCK_SERVICE_DB *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_query_service_sec(const char *desc,  
SVCCTL_Q_QUERY_SERVICE_SEC *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_query_service_sec(const char *desc,  
SVCCTL_R_QUERY_SERVICE_SEC *r_u, prs_struct *ps, int depth);
+BOOL svcctl_io_q_set_service_sec(const char *desc,  
SVCCTL_Q_SET_SERVICE_SEC *q_u, prs_struct *ps, int depth);
+BOOL svcctl_io_r_set_service_sec(const char *desc,  
SVCCTL_R_SET_SERVICE_SEC *r_u, prs_struct *ps, int depth);
+
+/* The following definitions come from rpc_server/srv_dfs_nt.c  */
+
+void _dfs_GetManagerVersion(pipes_struct *p, struct  
dfs_GetManagerVersion *r);
+WERROR _dfs_Add(pipes_struct *p, struct dfs_Add *r);
+WERROR _dfs_Remove(pipes_struct *p, struct dfs_Remove *r);
+WERROR _dfs_Enum(pipes_struct *p, struct dfs_Enum *r);
+WERROR _dfs_GetInfo(pipes_struct *p, struct dfs_GetInfo *r);
+WERROR _dfs_SetInfo(pipes_struct *p, struct dfs_SetInfo *r);
+WERROR _dfs_Rename(pipes_struct *p, struct dfs_Rename *r);
+WERROR _dfs_Move(pipes_struct *p, struct dfs_Move *r);
+WERROR _dfs_ManagerGetConfigInfo(pipes_struct *p, struct  
dfs_ManagerGetConfigInfo *r);
+WERROR _dfs_ManagerSendSiteInfo(pipes_struct *p, struct  
dfs_ManagerSendSiteInfo *r);
+WERROR _dfs_AddFtRoot(pipes_struct *p, struct dfs_AddFtRoot *r);
+WERROR _dfs_RemoveFtRoot(pipes_struct *p, struct dfs_RemoveFtRoot *r);
+WERROR _dfs_AddStdRoot(pipes_struct *p, struct dfs_AddStdRoot *r);
+WERROR _dfs_RemoveStdRoot(pipes_struct *p, struct dfs_RemoveStdRoot  
*r);
+WERROR _dfs_ManagerInitialize(pipes_struct *p, struct  
dfs_ManagerInitialize *r);
+WERROR _dfs_AddStdRootForced(pipes_struct *p, struct  
dfs_AddStdRootForced *r);
+WERROR _dfs_GetDcAddress(pipes_struct *p, struct dfs_GetDcAddress *r);
+WERROR _dfs_SetDcAddress(pipes_struct *p, struct dfs_SetDcAddress *r);
+WERROR _dfs_FlushFtTable(pipes_struct *p, struct dfs_FlushFtTable *r);
+WERROR _dfs_Add2(pipes_struct *p, struct dfs_Add2 *r);
+WERROR _dfs_Remove2(pipes_struct *p, struct dfs_Remove2 *r);
+WERROR _dfs_EnumEx(pipes_struct *p, struct dfs_EnumEx *r);
+WERROR _dfs_SetInfo2(pipes_struct *p, struct dfs_SetInfo2 *r);
+
+/* The following definitions come from rpc_server/srv_echo_nt.c  */
+
+void _echo_AddOne(pipes_struct *p, struct echo_AddOne *r );
+void _echo_EchoData(pipes_struct *p, struct echo_EchoData *r);
+void _echo_SinkData(pipes_struct *p, struct echo_SinkData *r);
+void _echo_SourceData(pipes_struct *p, struct echo_SourceData *r);
+void _echo_TestCall(pipes_struct *p, struct echo_TestCall *r);
+NTSTATUS _echo_TestCall2(pipes_struct *p, struct echo_TestCall2 *r);
+uint32 _echo_TestSleep(pipes_struct *p, struct echo_TestSleep *r);
+void _echo_TestEnum(pipes_struct *p, struct echo_TestEnum *r);
+void _echo_TestSurrounding(pipes_struct *p, struct  
echo_TestSurrounding *r);
+uint16 _echo_TestDoublePointer(pipes_struct *p, struct  
echo_TestDoublePointer *r);
+
+/* The following definitions come from rpc_server/srv_epmapper_nt.c  */
+
+uint32 _epm_MapAuth(pipes_struct *p, struct epm_MapAuth *r) ;
+uint32 _epm_MgmtDelete(pipes_struct *p, struct epm_MgmtDelete *r);
+uint32 _epm_InqObject(pipes_struct *p, struct epm_InqObject *r);
+uint32 _epm_LookupHandleFree(pipes_struct *p, struct  
epm_LookupHandleFree *r);
+uint32 _epm_Map(pipes_struct *p, struct epm_Map *r);
+uint32 _epm_Lookup(pipes_struct *p, struct epm_Lookup *r);
+uint32 _epm_Delete(pipes_struct *p, struct epm_Delete *r);
+uint32 _epm_Insert(pipes_struct *p, struct epm_Insert *r);
+
+/* The following definitions come from rpc_server/srv_eventlog.c  */
+
+NTSTATUS rpc_eventlog2_init(void);
+void eventlog2_get_pipe_fns(struct api_struct **fns, int *n_fns);
+
+/* The following definitions come from rpc_server/ 
srv_eventlog_lib.c  */
+
+TDB_CONTEXT *elog_init_tdb( char *tdbfilename );
+char *elog_tdbname( const char *name );
+int elog_tdb_size( TDB_CONTEXT * tdb, int *MaxSize, int *Retention );
+BOOL make_way_for_eventlogs( TDB_CONTEXT * the_tdb, int32 needed,
+			     BOOL whack_by_date );
+BOOL prune_eventlog( TDB_CONTEXT * tdb );
+BOOL can_write_to_eventlog( TDB_CONTEXT * tdb, int32 needed );
+ELOG_TDB *elog_open_tdb( char *logname, BOOL force_clear );
+int elog_close_tdb( ELOG_TDB *etdb, BOOL force_close );
+int write_eventlog_tdb( TDB_CONTEXT * the_tdb, Eventlog_entry * ee );
+void fixup_eventlog_entry( Eventlog_entry * ee );
+BOOL parse_logentry( char *line, Eventlog_entry * entry, BOOL * eor );
+
+/* The following definitions come from rpc_server/srv_eventlog_nt.c  */
+
+NTSTATUS _eventlog_open_eventlog( pipes_struct * p,
+				EVENTLOG_Q_OPEN_EVENTLOG * q_u,
+				EVENTLOG_R_OPEN_EVENTLOG * r_u );
+NTSTATUS _eventlog_clear_eventlog( pipes_struct * p,
+				 EVENTLOG_Q_CLEAR_EVENTLOG * q_u,
+				 EVENTLOG_R_CLEAR_EVENTLOG * r_u );
+NTSTATUS _eventlog_CloseEventLog( pipes_struct * p, struct  
eventlog_CloseEventLog *r );
+NTSTATUS _eventlog_read_eventlog( pipes_struct * p,
+				EVENTLOG_Q_READ_EVENTLOG * q_u,
+				EVENTLOG_R_READ_EVENTLOG * r_u );
+NTSTATUS _eventlog_get_oldest_entry( pipes_struct * p,
+				   EVENTLOG_Q_GET_OLDEST_ENTRY * q_u,
+				   EVENTLOG_R_GET_OLDEST_ENTRY * r_u );
+NTSTATUS _eventlog_get_num_records( pipes_struct * p,
+				  EVENTLOG_Q_GET_NUM_RECORDS * q_u,
+				  EVENTLOG_R_GET_NUM_RECORDS * r_u );
+NTSTATUS _eventlog_ClearEventLogW(pipes_struct *p, struct  
eventlog_ClearEventLogW *r);
+NTSTATUS _eventlog_BackupEventLogW(pipes_struct *p, struct  
eventlog_BackupEventLogW *r);
+NTSTATUS _eventlog_DeregisterEventSource(pipes_struct *p, struct  
eventlog_DeregisterEventSource *r);
+NTSTATUS _eventlog_GetNumRecords(pipes_struct *p, struct  
eventlog_GetNumRecords *r);
+NTSTATUS _eventlog_GetOldestRecord(pipes_struct *p, struct  
eventlog_GetOldestRecord *r);
+NTSTATUS _eventlog_ChangeNotify(pipes_struct *p, struct  
eventlog_ChangeNotify *r);
+NTSTATUS _eventlog_OpenEventLogW(pipes_struct *p, struct  
eventlog_OpenEventLogW *r);
+NTSTATUS _eventlog_RegisterEventSourceW(pipes_struct *p, struct  
eventlog_RegisterEventSourceW *r);
+NTSTATUS _eventlog_OpenBackupEventLogW(pipes_struct *p, struct  
eventlog_OpenBackupEventLogW *r);
+NTSTATUS _eventlog_ReadEventLogW(pipes_struct *p, struct  
eventlog_ReadEventLogW *r);
+NTSTATUS _eventlog_ReportEventW(pipes_struct *p, struct  
eventlog_ReportEventW *r);
+NTSTATUS _eventlog_ClearEventLogA(pipes_struct *p, struct  
eventlog_ClearEventLogA *r);
+NTSTATUS _eventlog_BackupEventLogA(pipes_struct *p, struct  
eventlog_BackupEventLogA *r);
+NTSTATUS _eventlog_OpenEventLogA(pipes_struct *p, struct  
eventlog_OpenEventLogA *r);
+NTSTATUS _eventlog_RegisterEventSourceA(pipes_struct *p, struct  
eventlog_RegisterEventSourceA *r);
+NTSTATUS _eventlog_OpenBackupEventLogA(pipes_struct *p, struct  
eventlog_OpenBackupEventLogA *r);
+NTSTATUS _eventlog_ReadEventLogA(pipes_struct *p, struct  
eventlog_ReadEventLogA *r);
+NTSTATUS _eventlog_ReportEventA(pipes_struct *p, struct  
eventlog_ReportEventA *r);
+NTSTATUS _eventlog_RegisterClusterSvc(pipes_struct *p, struct  
eventlog_RegisterClusterSvc *r);
+NTSTATUS _eventlog_DeregisterClusterSvc(pipes_struct *p, struct  
eventlog_DeregisterClusterSvc *r);
+NTSTATUS _eventlog_WriteClusterEvents(pipes_struct *p, struct  
eventlog_WriteClusterEvents *r);
+NTSTATUS _eventlog_GetLogIntormation(pipes_struct *p, struct  
eventlog_GetLogIntormation *r);
+NTSTATUS _eventlog_FlushEventLog(pipes_struct *p, struct  
eventlog_FlushEventLog *r);
+
+/* The following definitions come from rpc_server/ 
srv_initshutdown_nt.c  */
+
+WERROR _initshutdown_Init(pipes_struct *p, struct initshutdown_Init  
*r);
+WERROR _initshutdown_InitEx(pipes_struct *p, struct  
initshutdown_InitEx *r);
+WERROR _initshutdown_Abort(pipes_struct *p, struct  
initshutdown_Abort *r);
+
+/* The following definitions come from rpc_server/srv_lsa.c  */
+
+void lsa_get_pipe_fns( struct api_struct **fns, int *n_fns );
+NTSTATUS rpc_lsa_init(void);
+
+/* The following definitions come from rpc_server/srv_lsa_ds.c  */
+
+void lsa_ds_get_pipe_fns( struct api_struct **fns, int *n_fns );
+NTSTATUS rpc_lsa_ds_init(void);
+
+/* The following definitions come from rpc_server/srv_lsa_ds_nt.c  */
+
+NTSTATUS _dsrole_get_primary_dominfo(pipes_struct *p,  
DS_Q_GETPRIMDOMINFO *q_u, DS_R_GETPRIMDOMINFO *r_u);
+
+/* The following definitions come from rpc_server/srv_lsa_hnd.c  */
+
+BOOL init_pipe_handle_list(pipes_struct *p, char *pipe_name);
+BOOL create_policy_hnd(pipes_struct *p, POLICY_HND *hnd, void  
(*free_fn)(void *), void *data_ptr);
+BOOL find_policy_by_hnd(pipes_struct *p, POLICY_HND *hnd, void  
**data_p);
+BOOL close_policy_hnd(pipes_struct *p, POLICY_HND *hnd);
+void close_policy_by_pipe(pipes_struct *p);
+BOOL pipe_access_check(pipes_struct *p);
+
+/* The following definitions come from rpc_server/srv_lsa_nt.c  */
+
+NTSTATUS _lsa_open_policy2(pipes_struct *p, LSA_Q_OPEN_POL2 *q_u,  
LSA_R_OPEN_POL2 *r_u);
+NTSTATUS _lsa_open_policy(pipes_struct *p, LSA_Q_OPEN_POL *q_u,  
LSA_R_OPEN_POL *r_u);
+NTSTATUS _lsa_enum_trust_dom(pipes_struct *p, LSA_Q_ENUM_TRUST_DOM  
*q_u,
+			     LSA_R_ENUM_TRUST_DOM *r_u);
+NTSTATUS _lsa_query_info(pipes_struct *p, LSA_Q_QUERY_INFO *q_u,  
LSA_R_QUERY_INFO *r_u);
+NTSTATUS _lsa_lookup_sids(pipes_struct *p,
+			  LSA_Q_LOOKUP_SIDS *q_u,
+			  LSA_R_LOOKUP_SIDS *r_u);
+NTSTATUS _lsa_lookup_sids2(pipes_struct *p,
+			  LSA_Q_LOOKUP_SIDS2 *q_u,
+			  LSA_R_LOOKUP_SIDS2 *r_u);
+NTSTATUS _lsa_lookup_sids3(pipes_struct *p,
+			  LSA_Q_LOOKUP_SIDS3 *q_u,
+			  LSA_R_LOOKUP_SIDS3 *r_u);
+NTSTATUS _lsa_lookup_names(pipes_struct *p,LSA_Q_LOOKUP_NAMES *q_u,  
LSA_R_LOOKUP_NAMES *r_u);
+NTSTATUS _lsa_lookup_names2(pipes_struct *p, LSA_Q_LOOKUP_NAMES2  
*q_u, LSA_R_LOOKUP_NAMES2 *r_u);
+NTSTATUS _lsa_lookup_names3(pipes_struct *p, LSA_Q_LOOKUP_NAMES3  
*q_u, LSA_R_LOOKUP_NAMES3 *r_u);
+NTSTATUS _lsa_lookup_names4(pipes_struct *p, LSA_Q_LOOKUP_NAMES4  
*q_u, LSA_R_LOOKUP_NAMES4 *r_u);
+NTSTATUS _lsa_Close(pipes_struct *p, struct lsa_Close *r);
+NTSTATUS _lsa_OpenSecret(pipes_struct *p, struct lsa_OpenSecret *r);
+NTSTATUS _lsa_OpenTrustedDomain(pipes_struct *p, struct  
lsa_OpenTrustedDomain *r);
+NTSTATUS _lsa_CreateTrustedDomain(pipes_struct *p, struct  
lsa_CreateTrustedDomain *r);
+NTSTATUS _lsa_CreateSecret(pipes_struct *p, struct lsa_CreateSecret  
*r);
+NTSTATUS _lsa_SetSecret(pipes_struct *p, struct lsa_SetSecret *r);
+NTSTATUS _lsa_delete_object(pipes_struct *p, LSA_Q_DELETE_OBJECT  
*q_u, LSA_R_DELETE_OBJECT *r_u);
+NTSTATUS _lsa_enum_privs(pipes_struct *p, LSA_Q_ENUM_PRIVS *q_u,  
LSA_R_ENUM_PRIVS *r_u);
+NTSTATUS _lsa_priv_get_dispname(pipes_struct *p,  
LSA_Q_PRIV_GET_DISPNAME *q_u, LSA_R_PRIV_GET_DISPNAME *r_u);
+NTSTATUS _lsa_enum_accounts(pipes_struct *p, LSA_Q_ENUM_ACCOUNTS  
*q_u, LSA_R_ENUM_ACCOUNTS *r_u);
+NTSTATUS _lsa_unk_get_connuser(pipes_struct *p,  
LSA_Q_UNK_GET_CONNUSER *q_u, LSA_R_UNK_GET_CONNUSER *r_u);
+NTSTATUS _lsa_create_account(pipes_struct *p, LSA_Q_CREATEACCOUNT  
*q_u, LSA_R_CREATEACCOUNT *r_u);
+NTSTATUS _lsa_open_account(pipes_struct *p, LSA_Q_OPENACCOUNT *q_u,  
LSA_R_OPENACCOUNT *r_u);
+NTSTATUS _lsa_enum_privsaccount(pipes_struct *p, prs_struct *ps,  
LSA_Q_ENUMPRIVSACCOUNT *q_u, LSA_R_ENUMPRIVSACCOUNT *r_u);
+NTSTATUS _lsa_getsystemaccount(pipes_struct *p,  
LSA_Q_GETSYSTEMACCOUNT *q_u, LSA_R_GETSYSTEMACCOUNT *r_u);
+NTSTATUS _lsa_setsystemaccount(pipes_struct *p,  
LSA_Q_SETSYSTEMACCOUNT *q_u, LSA_R_SETSYSTEMACCOUNT *r_u);
+NTSTATUS _lsa_addprivs(pipes_struct *p, LSA_Q_ADDPRIVS *q_u,  
LSA_R_ADDPRIVS *r_u);
+NTSTATUS _lsa_removeprivs(pipes_struct *p, LSA_Q_REMOVEPRIVS *q_u,  
LSA_R_REMOVEPRIVS *r_u);
+NTSTATUS _lsa_query_secobj(pipes_struct *p, LSA_Q_QUERY_SEC_OBJ  
*q_u, LSA_R_QUERY_SEC_OBJ *r_u);
+NTSTATUS _lsa_query_info2(pipes_struct *p, LSA_Q_QUERY_INFO2 *q_u,  
LSA_R_QUERY_INFO2 *r_u);
+NTSTATUS _lsa_add_acct_rights(pipes_struct *p, LSA_Q_ADD_ACCT_RIGHTS  
*q_u, LSA_R_ADD_ACCT_RIGHTS *r_u);
+NTSTATUS _lsa_remove_acct_rights(pipes_struct *p,  
LSA_Q_REMOVE_ACCT_RIGHTS *q_u, LSA_R_REMOVE_ACCT_RIGHTS *r_u);
+NTSTATUS _lsa_enum_acct_rights(pipes_struct *p,  
LSA_Q_ENUM_ACCT_RIGHTS *q_u, LSA_R_ENUM_ACCT_RIGHTS *r_u);
+NTSTATUS _lsa_lookup_priv_value(pipes_struct *p,  
LSA_Q_LOOKUP_PRIV_VALUE *q_u, LSA_R_LOOKUP_PRIV_VALUE *r_u);
+NTSTATUS _lsa_Delete(pipes_struct *p, struct lsa_Delete *r);
+NTSTATUS _lsa_EnumPrivs(pipes_struct *p, struct lsa_EnumPrivs *r);
+NTSTATUS _lsa_QuerySecurity(pipes_struct *p, struct  
lsa_QuerySecurity *r);
+NTSTATUS _lsa_SetSecObj(pipes_struct *p, struct lsa_SetSecObj *r);
+NTSTATUS _lsa_ChangePassword(pipes_struct *p, struct  
lsa_ChangePassword *r);
+NTSTATUS _lsa_OpenPolicy(pipes_struct *p, struct lsa_OpenPolicy *r);
+NTSTATUS _lsa_QueryInfoPolicy(pipes_struct *p, struct  
lsa_QueryInfoPolicy *r);
+NTSTATUS _lsa_SetInfoPolicy(pipes_struct *p, struct  
lsa_SetInfoPolicy *r);
+NTSTATUS _lsa_ClearAuditLog(pipes_struct *p, struct  
lsa_ClearAuditLog *r);
+NTSTATUS _lsa_CreateAccount(pipes_struct *p, struct  
lsa_CreateAccount *r);
+NTSTATUS _lsa_EnumAccounts(pipes_struct *p, struct lsa_EnumAccounts  
*r);
+NTSTATUS _lsa_EnumTrustDom(pipes_struct *p, struct lsa_EnumTrustDom  
*r);
+NTSTATUS _lsa_LookupNames(pipes_struct *p, struct lsa_LookupNames *r);
+NTSTATUS _lsa_LookupSids(pipes_struct *p, struct lsa_LookupSids *r);
+NTSTATUS _lsa_OpenAccount(pipes_struct *p, struct lsa_OpenAccount *r);
+NTSTATUS _lsa_EnumPrivsAccount(pipes_struct *p, struct  
lsa_EnumPrivsAccount *r);
+NTSTATUS _lsa_AddPrivilegesToAccount(pipes_struct *p, struct  
lsa_AddPrivilegesToAccount *r);
+NTSTATUS _lsa_RemovePrivilegesFromAccount(pipes_struct *p, struct  
lsa_RemovePrivilegesFromAccount *r);
+NTSTATUS _lsa_GetQuotasForAccount(pipes_struct *p, struct  
lsa_GetQuotasForAccount *r);
+NTSTATUS _lsa_SetQuotasForAccount(pipes_struct *p, struct  
lsa_SetQuotasForAccount *r);
+NTSTATUS _lsa_GetSystemAccessAccount(pipes_struct *p, struct  
lsa_GetSystemAccessAccount *r);
+NTSTATUS _lsa_SetSystemAccessAccount(pipes_struct *p, struct  
lsa_SetSystemAccessAccount *r);
+NTSTATUS _lsa_QueryTrustedDomainInfo(pipes_struct *p, struct  
lsa_QueryTrustedDomainInfo *r);
+NTSTATUS _lsa_SetInformationTrustedDomain(pipes_struct *p, struct  
lsa_SetInformationTrustedDomain *r);
+NTSTATUS _lsa_QuerySecret(pipes_struct *p, struct lsa_QuerySecret *r);
+NTSTATUS _lsa_LookupPrivValue(pipes_struct *p, struct  
lsa_LookupPrivValue *r);
+NTSTATUS _lsa_LookupPrivName(pipes_struct *p, struct  
lsa_LookupPrivName *r);
+NTSTATUS _lsa_LookupPrivDisplayName(pipes_struct *p, struct  
lsa_LookupPrivDisplayName *r);
+NTSTATUS _lsa_DeleteObject(pipes_struct *p, struct lsa_DeleteObject  
*r);
+NTSTATUS _lsa_EnumAccountsWithUserRight(pipes_struct *p, struct  
lsa_EnumAccountsWithUserRight *r);
+NTSTATUS _lsa_EnumAccountRights(pipes_struct *p, struct  
lsa_EnumAccountRights *r);
+NTSTATUS _lsa_AddAccountRights(pipes_struct *p, struct  
lsa_AddAccountRights *r);
+NTSTATUS _lsa_RemoveAccountRights(pipes_struct *p, struct  
lsa_RemoveAccountRights *r);
+NTSTATUS _lsa_QueryTrustedDomainInfoBySid(pipes_struct *p, struct  
lsa_QueryTrustedDomainInfoBySid *r);
+NTSTATUS _lsa_SetTrustedDomainInfo(pipes_struct *p, struct  
lsa_SetTrustedDomainInfo *r);
+NTSTATUS _lsa_DeleteTrustedDomain(pipes_struct *p, struct  
lsa_DeleteTrustedDomain *r);
+NTSTATUS _lsa_StorePrivateData(pipes_struct *p, struct  
lsa_StorePrivateData *r);
+NTSTATUS _lsa_RetrievePrivateData(pipes_struct *p, struct  
lsa_RetrievePrivateData *r);
+NTSTATUS _lsa_OpenPolicy2(pipes_struct *p, struct lsa_OpenPolicy2 *r);
+NTSTATUS _lsa_GetUserName(pipes_struct *p, struct lsa_GetUserName *r);
+NTSTATUS _lsa_QueryInfoPolicy2(pipes_struct *p, struct  
lsa_QueryInfoPolicy2 *r);
+NTSTATUS _lsa_SetInfoPolicy2(pipes_struct *p, struct  
lsa_SetInfoPolicy2 *r);
+NTSTATUS _lsa_QueryTrustedDomainInfoByName(pipes_struct *p, struct  
lsa_QueryTrustedDomainInfoByName *r);
+NTSTATUS _lsa_SetTrustedDomainInfoByName(pipes_struct *p, struct  
lsa_SetTrustedDomainInfoByName *r);
+NTSTATUS _lsa_EnumTrustedDomainsEx(pipes_struct *p, struct  
lsa_EnumTrustedDomainsEx *r);
+NTSTATUS _lsa_CreateTrustedDomainEx(pipes_struct *p, struct  
lsa_CreateTrustedDomainEx *r);
+NTSTATUS _lsa_CloseTrustedDomainEx(pipes_struct *p, struct  
lsa_CloseTrustedDomainEx *r);
+NTSTATUS _lsa_QueryDomainInformationPolicy(pipes_struct *p, struct  
lsa_QueryDomainInformationPolicy *r);
+NTSTATUS _lsa_SetDomainInformationPolicy(pipes_struct *p, struct  
lsa_SetDomainInformationPolicy *r);
+NTSTATUS _lsa_OpenTrustedDomainByName(pipes_struct *p, struct  
lsa_OpenTrustedDomainByName *r);
+NTSTATUS _lsa_TestCall(pipes_struct *p, struct lsa_TestCall *r);
+NTSTATUS _lsa_LookupSids2(pipes_struct *p, struct lsa_LookupSids2 *r);
+NTSTATUS _lsa_LookupNames2(pipes_struct *p, struct lsa_LookupNames2  
*r);
+NTSTATUS _lsa_CreateTrustedDomainEx2(pipes_struct *p, struct  
lsa_CreateTrustedDomainEx2 *r);
+NTSTATUS _lsa_CREDRWRITE(pipes_struct *p, struct lsa_CREDRWRITE *r);
+NTSTATUS _lsa_CREDRREAD(pipes_struct *p, struct lsa_CREDRREAD *r);
+NTSTATUS _lsa_CREDRENUMERATE(pipes_struct *p, struct  
lsa_CREDRENUMERATE *r);
+NTSTATUS _lsa_CREDRWRITEDOMAINCREDENTIALS(pipes_struct *p, struct  
lsa_CREDRWRITEDOMAINCREDENTIALS *r);
+NTSTATUS _lsa_CREDRREADDOMAINCREDENTIALS(pipes_struct *p, struct  
lsa_CREDRREADDOMAINCREDENTIALS *r);
+NTSTATUS _lsa_CREDRDELETE(pipes_struct *p, struct lsa_CREDRDELETE *r);
+NTSTATUS _lsa_CREDRGETTARGETINFO(pipes_struct *p, struct  
lsa_CREDRGETTARGETINFO *r);
+NTSTATUS _lsa_CREDRPROFILELOADED(pipes_struct *p, struct  
lsa_CREDRPROFILELOADED *r);
+NTSTATUS _lsa_LookupNames3(pipes_struct *p, struct lsa_LookupNames3  
*r);
+NTSTATUS _lsa_CREDRGETSESSIONTYPES(pipes_struct *p, struct  
lsa_CREDRGETSESSIONTYPES *r);
+NTSTATUS _lsa_LSARREGISTERAUDITEVENT(pipes_struct *p, struct  
lsa_LSARREGISTERAUDITEVENT *r);
+NTSTATUS _lsa_LSARGENAUDITEVENT(pipes_struct *p, struct  
lsa_LSARGENAUDITEVENT *r);
+NTSTATUS _lsa_LSARUNREGISTERAUDITEVENT(pipes_struct *p, struct  
lsa_LSARUNREGISTERAUDITEVENT *r);
+NTSTATUS _lsa_LSARQUERYFORESTTRUSTINFORMATION(pipes_struct *p,  
struct lsa_LSARQUERYFORESTTRUSTINFORMATION *r);
+NTSTATUS _lsa_LSARSETFORESTTRUSTINFORMATION(pipes_struct *p, struct  
lsa_LSARSETFORESTTRUSTINFORMATION *r);
+NTSTATUS _lsa_CREDRRENAME(pipes_struct *p, struct lsa_CREDRRENAME *r);
+NTSTATUS _lsa_LookupSids3(pipes_struct *p, struct lsa_LookupSids3 *r);
+NTSTATUS _lsa_LookupNames4(pipes_struct *p, struct lsa_LookupNames4  
*r);
+NTSTATUS _lsa_LSAROPENPOLICYSCE(pipes_struct *p, struct  
lsa_LSAROPENPOLICYSCE *r);
+NTSTATUS _lsa_LSARADTREGISTERSECURITYEVENTSOURCE(pipes_struct *p,  
struct lsa_LSARADTREGISTERSECURITYEVENTSOURCE *r);
+NTSTATUS _lsa_LSARADTUNREGISTERSECURITYEVENTSOURCE(pipes_struct *p,  
struct lsa_LSARADTUNREGISTERSECURITYEVENTSOURCE *r);
+NTSTATUS _lsa_LSARADTREPORTSECURITYEVENT(pipes_struct *p, struct  
lsa_LSARADTREPORTSECURITYEVENT *r);
+
+/* The following definitions come from rpc_server/srv_netlog.c  */
+
+void netlog_get_pipe_fns( struct api_struct **fns, int *n_fns );
+NTSTATUS rpc_net_init(void);
+
+/* The following definitions come from rpc_server/srv_netlog_nt.c  */
+
+NTSTATUS _net_logon_ctrl(pipes_struct *p, NET_Q_LOGON_CTRL *q_u,
+		       NET_R_LOGON_CTRL *r_u);
+NTSTATUS _net_logon_ctrl2(pipes_struct *p, NET_Q_LOGON_CTRL2 *q_u,  
NET_R_LOGON_CTRL2 *r_u);
+NTSTATUS _net_trust_dom_list(pipes_struct *p, NET_Q_TRUST_DOM_LIST  
*q_u, NET_R_TRUST_DOM_LIST *r_u);
+NTSTATUS _net_req_chal(pipes_struct *p, NET_Q_REQ_CHAL *q_u,  
NET_R_REQ_CHAL *r_u);
+NTSTATUS _net_auth(pipes_struct *p, NET_Q_AUTH *q_u, NET_R_AUTH *r_u);
+NTSTATUS _net_auth_2(pipes_struct *p, NET_Q_AUTH_2 *q_u,  
NET_R_AUTH_2 *r_u);
+NTSTATUS _net_srv_pwset(pipes_struct *p, NET_Q_SRV_PWSET *q_u,  
NET_R_SRV_PWSET *r_u);
+NTSTATUS _net_sam_logoff(pipes_struct *p, NET_Q_SAM_LOGOFF *q_u,  
NET_R_SAM_LOGOFF *r_u);
+NTSTATUS _net_sam_logon(pipes_struct *p, NET_Q_SAM_LOGON *q_u,  
NET_R_SAM_LOGON *r_u);
+NTSTATUS _net_sam_logon_ex(pipes_struct *p, NET_Q_SAM_LOGON_EX *q_u,  
NET_R_SAM_LOGON_EX *r_u);
+NTSTATUS _ds_enum_dom_trusts(pipes_struct *p, DS_Q_ENUM_DOM_TRUSTS  
*q_u,
+			     DS_R_ENUM_DOM_TRUSTS *r_u);
+
+/* The following definitions come from rpc_server/srv_ntsvcs.c  */
+
+void ntsvcs_get_pipe_fns( struct api_struct **fns, int *n_fns );
+NTSTATUS rpc_ntsvcs_init(void);
+
+/* The following definitions come from rpc_server/srv_ntsvcs_nt.c  */
+
+WERROR _ntsvcs_get_version( pipes_struct *p, NTSVCS_Q_GET_VERSION  
*q_u, NTSVCS_R_GET_VERSION *r_u );
+WERROR _ntsvcs_get_device_list_size( pipes_struct *p,  
NTSVCS_Q_GET_DEVICE_LIST_SIZE *q_u, NTSVCS_R_GET_DEVICE_LIST_SIZE  
*r_u );
+WERROR _ntsvcs_get_device_list( pipes_struct *p,  
NTSVCS_Q_GET_DEVICE_LIST *q_u, NTSVCS_R_GET_DEVICE_LIST *r_u );
+WERROR _ntsvcs_get_device_reg_property( pipes_struct *p,  
NTSVCS_Q_GET_DEVICE_REG_PROPERTY *q_u,  
NTSVCS_R_GET_DEVICE_REG_PROPERTY *r_u );
+WERROR _ntsvcs_validate_device_instance( pipes_struct *p,  
NTSVCS_Q_VALIDATE_DEVICE_INSTANCE *q_u,  
NTSVCS_R_VALIDATE_DEVICE_INSTANCE *r_u );
+WERROR _ntsvcs_get_hw_profile_info( pipes_struct *p,  
NTSVCS_Q_GET_HW_PROFILE_INFO *q_u, NTSVCS_R_GET_HW_PROFILE_INFO *r_u );
+WERROR _ntsvcs_hw_profile_flags( pipes_struct *p,  
NTSVCS_Q_HW_PROFILE_FLAGS *q_u, NTSVCS_R_HW_PROFILE_FLAGS *r_u );
+
+/* The following definitions come from rpc_server/srv_pipe.c  */
+
+BOOL create_next_pdu(pipes_struct *p);
+BOOL api_pipe_bind_auth3(pipes_struct *p, prs_struct *rpc_in_p);
+BOOL setup_fault_pdu(pipes_struct *p, NTSTATUS status);
+BOOL setup_cancel_ack_reply(pipes_struct *p, prs_struct *rpc_in_p);
+BOOL check_bind_req(struct pipes_struct *p, RPC_IFACE* abstract,
+                    RPC_IFACE* transfer, uint32 context_id);
+NTSTATUS rpc_pipe_register_commands(int version, const char *clnt,  
const char *srv, const struct api_struct *cmds, int size);
+BOOL api_pipe_bind_req(pipes_struct *p, prs_struct *rpc_in_p);
+BOOL api_pipe_alter_context(pipes_struct *p, prs_struct *rpc_in_p);
+BOOL api_pipe_ntlmssp_auth_process(pipes_struct *p, prs_struct *rpc_in,
+					uint32 *p_ss_padding_len, NTSTATUS *pstatus);
+BOOL api_pipe_schannel_process(pipes_struct *p, prs_struct *rpc_in,  
uint32 *p_ss_padding_len);
+void free_pipe_rpc_context( PIPE_RPC_FNS *list );
+BOOL api_pipe_request(pipes_struct *p);
+BOOL api_rpcTNP(pipes_struct *p, const char *rpc_name,
+		const struct api_struct *api_rpc_cmds, int n_cmds);
+void get_pipe_fns( int idx, struct api_struct **fns, int *n_fns );
+
+/* The following definitions come from rpc_server/srv_pipe_hnd.c  */
+
+smb_np_struct *get_first_pipe(void);
+smb_np_struct *get_next_pipe(smb_np_struct *p);
+pipes_struct *get_first_internal_pipe(void);
+pipes_struct *get_next_internal_pipe(pipes_struct *p);
+void set_pipe_handle_offset(int max_open_files);
+void reset_chain_p(void);
+void init_rpc_pipe_hnd(void);
+smb_np_struct *open_rpc_pipe_p(char *pipe_name,
+			      connection_struct *conn, uint16 vuid);
+ssize_t write_to_pipe(smb_np_struct *p, char *data, size_t n);
+ssize_t read_from_pipe(smb_np_struct *p, char *data, size_t n,
+		BOOL *is_data_outstanding);
+BOOL wait_rpc_pipe_hnd_state(smb_np_struct *p, uint16 priority);
+BOOL set_rpc_pipe_hnd_state(smb_np_struct *p, uint16 device_state);
+BOOL close_rpc_pipe_hnd(smb_np_struct *p);
+void pipe_close_conn(connection_struct *conn);
+smb_np_struct *get_rpc_pipe_p(char *buf, int where);
+smb_np_struct *get_rpc_pipe(int pnum);
+
+/* The following definitions come from rpc_server/srv_samr.c  */
+
+void samr_get_pipe_fns( struct api_struct **fns, int *n_fns );
+NTSTATUS rpc_samr_init(void);
+
+/* The following definitions come from rpc_server/srv_samr_nt.c  */
+
+NTSTATUS _samr_close_hnd(pipes_struct *p, SAMR_Q_CLOSE_HND *q_u,  
SAMR_R_CLOSE_HND *r_u);
+NTSTATUS _samr_open_domain(pipes_struct *p, SAMR_Q_OPEN_DOMAIN *q_u,  
SAMR_R_OPEN_DOMAIN *r_u);
+NTSTATUS _samr_get_usrdom_pwinfo(pipes_struct *p,  
SAMR_Q_GET_USRDOM_PWINFO *q_u, SAMR_R_GET_USRDOM_PWINFO *r_u);
+NTSTATUS _samr_set_sec_obj(pipes_struct *p, SAMR_Q_SET_SEC_OBJ *q_u,  
SAMR_R_SET_SEC_OBJ *r_u);
+NTSTATUS _samr_query_sec_obj(pipes_struct *p, SAMR_Q_QUERY_SEC_OBJ  
*q_u, SAMR_R_QUERY_SEC_OBJ *r_u);
+NTSTATUS _samr_enum_dom_users(pipes_struct *p, SAMR_Q_ENUM_DOM_USERS  
*q_u,
+			      SAMR_R_ENUM_DOM_USERS *r_u);
+NTSTATUS _samr_enum_dom_groups(pipes_struct *p,  
SAMR_Q_ENUM_DOM_GROUPS *q_u, SAMR_R_ENUM_DOM_GROUPS *r_u);
+NTSTATUS _samr_enum_dom_aliases(pipes_struct *p,  
SAMR_Q_ENUM_DOM_ALIASES *q_u, SAMR_R_ENUM_DOM_ALIASES *r_u);
+NTSTATUS _samr_query_dispinfo(pipes_struct *p, SAMR_Q_QUERY_DISPINFO  
*q_u,
+			      SAMR_R_QUERY_DISPINFO *r_u);
+NTSTATUS _samr_query_aliasinfo(pipes_struct *p,  
SAMR_Q_QUERY_ALIASINFO *q_u, SAMR_R_QUERY_ALIASINFO *r_u);
+NTSTATUS _samr_lookup_names(pipes_struct *p, SAMR_Q_LOOKUP_NAMES  
*q_u, SAMR_R_LOOKUP_NAMES *r_u);
+NTSTATUS _samr_chgpasswd_user(pipes_struct *p, SAMR_Q_CHGPASSWD_USER  
*q_u, SAMR_R_CHGPASSWD_USER *r_u);
+NTSTATUS _samr_chgpasswd_user3(pipes_struct *p,  
SAMR_Q_CHGPASSWD_USER3 *q_u, SAMR_R_CHGPASSWD_USER3 *r_u);
+NTSTATUS _samr_lookup_rids(pipes_struct *p, SAMR_Q_LOOKUP_RIDS *q_u,  
SAMR_R_LOOKUP_RIDS *r_u);
+NTSTATUS _samr_open_user(pipes_struct *p, SAMR_Q_OPEN_USER *q_u,  
SAMR_R_OPEN_USER *r_u);
+NTSTATUS _samr_query_userinfo(pipes_struct *p, SAMR_Q_QUERY_USERINFO  
*q_u, SAMR_R_QUERY_USERINFO *r_u);
+NTSTATUS _samr_query_usergroups(pipes_struct *p,  
SAMR_Q_QUERY_USERGROUPS *q_u, SAMR_R_QUERY_USERGROUPS *r_u);
+NTSTATUS _samr_query_domain_info(pipes_struct *p,
+				 SAMR_Q_QUERY_DOMAIN_INFO *q_u,
+				 SAMR_R_QUERY_DOMAIN_INFO *r_u);
+NTSTATUS _samr_create_user(pipes_struct *p, SAMR_Q_CREATE_USER *q_u,
+			   SAMR_R_CREATE_USER *r_u);
+NTSTATUS _samr_connect_anon(pipes_struct *p, SAMR_Q_CONNECT_ANON  
*q_u, SAMR_R_CONNECT_ANON *r_u);
+NTSTATUS _samr_connect(pipes_struct *p, SAMR_Q_CONNECT *q_u,  
SAMR_R_CONNECT *r_u);
+NTSTATUS _samr_connect4(pipes_struct *p, SAMR_Q_CONNECT4 *q_u,  
SAMR_R_CONNECT4 *r_u);
+NTSTATUS _samr_connect5(pipes_struct *p, SAMR_Q_CONNECT5 *q_u,  
SAMR_R_CONNECT5 *r_u);
+NTSTATUS _samr_lookup_domain(pipes_struct *p, SAMR_Q_LOOKUP_DOMAIN  
*q_u, SAMR_R_LOOKUP_DOMAIN *r_u);
+NTSTATUS _samr_enum_domains(pipes_struct *p, SAMR_Q_ENUM_DOMAINS  
*q_u, SAMR_R_ENUM_DOMAINS *r_u);
+NTSTATUS _samr_open_alias(pipes_struct *p, SAMR_Q_OPEN_ALIAS *q_u,  
SAMR_R_OPEN_ALIAS *r_u);
+NTSTATUS _samr_set_userinfo(pipes_struct *p, SAMR_Q_SET_USERINFO  
*q_u, SAMR_R_SET_USERINFO *r_u);
+NTSTATUS _samr_set_userinfo2(pipes_struct *p, SAMR_Q_SET_USERINFO2  
*q_u, SAMR_R_SET_USERINFO2 *r_u);
+NTSTATUS _samr_query_useraliases(pipes_struct *p,  
SAMR_Q_QUERY_USERALIASES *q_u, SAMR_R_QUERY_USERALIASES *r_u);
+NTSTATUS _samr_query_aliasmem(pipes_struct *p, SAMR_Q_QUERY_ALIASMEM  
*q_u, SAMR_R_QUERY_ALIASMEM *r_u);
+NTSTATUS _samr_query_groupmem(pipes_struct *p, SAMR_Q_QUERY_GROUPMEM  
*q_u, SAMR_R_QUERY_GROUPMEM *r_u);
+NTSTATUS _samr_add_aliasmem(pipes_struct *p, SAMR_Q_ADD_ALIASMEM  
*q_u, SAMR_R_ADD_ALIASMEM *r_u);
+NTSTATUS _samr_del_aliasmem(pipes_struct *p, SAMR_Q_DEL_ALIASMEM  
*q_u, SAMR_R_DEL_ALIASMEM *r_u);
+NTSTATUS _samr_add_groupmem(pipes_struct *p, SAMR_Q_ADD_GROUPMEM  
*q_u, SAMR_R_ADD_GROUPMEM *r_u);
+NTSTATUS _samr_del_groupmem(pipes_struct *p, SAMR_Q_DEL_GROUPMEM  
*q_u, SAMR_R_DEL_GROUPMEM *r_u);
+NTSTATUS _samr_delete_dom_user(pipes_struct *p,  
SAMR_Q_DELETE_DOM_USER *q_u, SAMR_R_DELETE_DOM_USER *r_u );
+NTSTATUS _samr_delete_dom_group(pipes_struct *p,  
SAMR_Q_DELETE_DOM_GROUP *q_u, SAMR_R_DELETE_DOM_GROUP *r_u);
+NTSTATUS _samr_delete_dom_alias(pipes_struct *p,  
SAMR_Q_DELETE_DOM_ALIAS *q_u, SAMR_R_DELETE_DOM_ALIAS *r_u);
+NTSTATUS _samr_create_dom_group(pipes_struct *p,  
SAMR_Q_CREATE_DOM_GROUP *q_u, SAMR_R_CREATE_DOM_GROUP *r_u);
+NTSTATUS _samr_create_dom_alias(pipes_struct *p,  
SAMR_Q_CREATE_DOM_ALIAS *q_u, SAMR_R_CREATE_DOM_ALIAS *r_u);
+NTSTATUS _samr_query_groupinfo(pipes_struct *p,  
SAMR_Q_QUERY_GROUPINFO *q_u, SAMR_R_QUERY_GROUPINFO *r_u);
+NTSTATUS _samr_set_groupinfo(pipes_struct *p, SAMR_Q_SET_GROUPINFO  
*q_u, SAMR_R_SET_GROUPINFO *r_u);
+NTSTATUS _samr_set_aliasinfo(pipes_struct *p, SAMR_Q_SET_ALIASINFO  
*q_u, SAMR_R_SET_ALIASINFO *r_u);
+NTSTATUS _samr_get_dom_pwinfo(pipes_struct *p, SAMR_Q_GET_DOM_PWINFO  
*q_u, SAMR_R_GET_DOM_PWINFO *r_u);
+NTSTATUS _samr_open_group(pipes_struct *p, SAMR_Q_OPEN_GROUP *q_u,  
SAMR_R_OPEN_GROUP *r_u);
+NTSTATUS _samr_remove_sid_foreign_domain(pipes_struct *p,
+                                           
SAMR_Q_REMOVE_SID_FOREIGN_DOMAIN *q_u,
+                                           
SAMR_R_REMOVE_SID_FOREIGN_DOMAIN *r_u);
+NTSTATUS _samr_query_domain_info2(pipes_struct *p,
+				  SAMR_Q_QUERY_DOMAIN_INFO2 *q_u,
+				  SAMR_R_QUERY_DOMAIN_INFO2 *r_u);
+NTSTATUS _samr_set_dom_info(pipes_struct *p, SAMR_Q_SET_DOMAIN_INFO  
*q_u, SAMR_R_SET_DOMAIN_INFO *r_u);
+
+/* The following definitions come from rpc_server/srv_samr_util.c  */
+
+void copy_id20_to_sam_passwd(struct samu *to, SAM_USER_INFO_20 *from);
+void copy_id21_to_sam_passwd(struct samu *to, SAM_USER_INFO_21 *from);
+void copy_id23_to_sam_passwd(struct samu *to, SAM_USER_INFO_23 *from);
+void copy_id25_to_sam_passwd(struct samu *to, SAM_USER_INFO_25 *from);
+
+/* The following definitions come from rpc_server/srv_spoolss.c  */
+
+void spoolss_get_pipe_fns( struct api_struct **fns, int *n_fns );
+NTSTATUS rpc_spoolss_init(void);
+
+/* The following definitions come from rpc_server/srv_spoolss_nt.c  */
+
+WERROR delete_printer_hook( NT_USER_TOKEN *token, const char  
*sharename );
+void do_drv_upgrade_printer(struct messaging_context *msg,
+			    void *private_data,
+			    uint32_t msg_type,
+			    struct server_id server_id,
+			    DATA_BLOB *data);
+void update_monitored_printq_cache( void );
+void reset_all_printerdata(struct messaging_context *msg,
+			   void *private_data,
+			   uint32_t msg_type,
+			   struct server_id server_id,
+			   DATA_BLOB *data);
+WERROR _spoolss_open_printer(pipes_struct *p, SPOOL_Q_OPEN_PRINTER  
*q_u, SPOOL_R_OPEN_PRINTER *r_u);
+WERROR _spoolss_open_printer_ex( pipes_struct *p,  
SPOOL_Q_OPEN_PRINTER_EX *q_u, SPOOL_R_OPEN_PRINTER_EX *r_u);
+BOOL convert_devicemode(const char *printername, const DEVICEMODE  
*devmode,
+				NT_DEVICEMODE **pp_nt_devmode);
+WERROR _spoolss_closeprinter(pipes_struct *p, SPOOL_Q_CLOSEPRINTER  
*q_u, SPOOL_R_CLOSEPRINTER *r_u);
+WERROR _spoolss_deleteprinter(pipes_struct *p, SPOOL_Q_DELETEPRINTER  
*q_u, SPOOL_R_DELETEPRINTER *r_u);
+WERROR _spoolss_deleteprinterdriver(pipes_struct *p,  
SPOOL_Q_DELETEPRINTERDRIVER *q_u, SPOOL_R_DELETEPRINTERDRIVER *r_u);
+WERROR _spoolss_deleteprinterdriverex(pipes_struct *p,  
SPOOL_Q_DELETEPRINTERDRIVEREX *q_u, SPOOL_R_DELETEPRINTERDRIVEREX *r_u);
+WERROR set_printer_dataex( NT_PRINTER_INFO_LEVEL *printer, const  
char *key, const char *value,
+                                  uint32 type, uint8 *data, int  
real_len  );
+WERROR _spoolss_getprinterdata(pipes_struct *p,  
SPOOL_Q_GETPRINTERDATA *q_u, SPOOL_R_GETPRINTERDATA *r_u);
+WERROR _spoolss_rffpcnex(pipes_struct *p, SPOOL_Q_RFFPCNEX *q_u,  
SPOOL_R_RFFPCNEX *r_u);
+void spoolss_notify_server_name(int snum,
+				       SPOOL_NOTIFY_INFO_DATA *data,
+				       print_queue_struct *queue,
+				       NT_PRINTER_INFO_LEVEL *printer,
+				       TALLOC_CTX *mem_ctx) ;
+void spoolss_notify_printer_name(int snum,
+					SPOOL_NOTIFY_INFO_DATA *data,
+					print_queue_struct *queue,
+					NT_PRINTER_INFO_LEVEL *printer,
+					TALLOC_CTX *mem_ctx);
+void spoolss_notify_share_name(int snum,
+				      SPOOL_NOTIFY_INFO_DATA *data,
+				      print_queue_struct *queue,
+				      NT_PRINTER_INFO_LEVEL *printer,
+				      TALLOC_CTX *mem_ctx);
+void spoolss_notify_port_name(int snum,
+				     SPOOL_NOTIFY_INFO_DATA *data,
+				     print_queue_struct *queue,
+				     NT_PRINTER_INFO_LEVEL *printer,
+				     TALLOC_CTX *mem_ctx);
+void spoolss_notify_driver_name(int snum,
+				       SPOOL_NOTIFY_INFO_DATA *data,
+				       print_queue_struct *queue,
+				       NT_PRINTER_INFO_LEVEL *printer,
+				       TALLOC_CTX *mem_ctx);
+void spoolss_notify_comment(int snum,
+				   SPOOL_NOTIFY_INFO_DATA *data,
+				   print_queue_struct *queue,
+				   NT_PRINTER_INFO_LEVEL *printer,
+				   TALLOC_CTX *mem_ctx);
+void spoolss_notify_location(int snum,
+				    SPOOL_NOTIFY_INFO_DATA *data,
+				    print_queue_struct *queue,
+				    NT_PRINTER_INFO_LEVEL *printer,
+				    TALLOC_CTX *mem_ctx);
+void spoolss_notify_sepfile(int snum,
+				   SPOOL_NOTIFY_INFO_DATA *data,
+				   print_queue_struct *queue,
+				   NT_PRINTER_INFO_LEVEL *printer,
+				   TALLOC_CTX *mem_ctx);
+void spoolss_notify_print_processor(int snum,
+					   SPOOL_NOTIFY_INFO_DATA *data,
+					   print_queue_struct *queue,
+					   NT_PRINTER_INFO_LEVEL *printer,
+					   TALLOC_CTX *mem_ctx);
+void spoolss_notify_parameters(int snum,
+				      SPOOL_NOTIFY_INFO_DATA *data,
+				      print_queue_struct *queue,
+				      NT_PRINTER_INFO_LEVEL *printer,
+				      TALLOC_CTX *mem_ctx);
+void spoolss_notify_datatype(int snum,
+				    SPOOL_NOTIFY_INFO_DATA *data,
+				    print_queue_struct *queue,
+				    NT_PRINTER_INFO_LEVEL *printer,
+				    TALLOC_CTX *mem_ctx);
+void spoolss_notify_attributes(int snum,
+				      SPOOL_NOTIFY_INFO_DATA *data,
+				      print_queue_struct *queue,
+				      NT_PRINTER_INFO_LEVEL *printer,
+				      TALLOC_CTX *mem_ctx);
+void spoolss_notify_cjobs(int snum,
+				 SPOOL_NOTIFY_INFO_DATA *data,
+				 print_queue_struct *queue,
+				 NT_PRINTER_INFO_LEVEL *printer,
+				 TALLOC_CTX *mem_ctx);
+void construct_info_data(SPOOL_NOTIFY_INFO_DATA *info_data, uint16  
type, uint16 field, int id);
+WERROR _spoolss_rfnpcnex( pipes_struct *p, SPOOL_Q_RFNPCNEX *q_u,  
SPOOL_R_RFNPCNEX *r_u);
+DEVICEMODE *construct_dev_mode(const char *servicename);
+WERROR _spoolss_enumprinters( pipes_struct *p, SPOOL_Q_ENUMPRINTERS  
*q_u, SPOOL_R_ENUMPRINTERS *r_u);
+WERROR _spoolss_getprinter(pipes_struct *p, SPOOL_Q_GETPRINTER *q_u,  
SPOOL_R_GETPRINTER *r_u);
+WERROR _spoolss_getprinterdriver2(pipes_struct *p,  
SPOOL_Q_GETPRINTERDRIVER2 *q_u, SPOOL_R_GETPRINTERDRIVER2 *r_u);
+WERROR _spoolss_startpageprinter(pipes_struct *p,  
SPOOL_Q_STARTPAGEPRINTER *q_u, SPOOL_R_STARTPAGEPRINTER *r_u);
+WERROR _spoolss_endpageprinter(pipes_struct *p,  
SPOOL_Q_ENDPAGEPRINTER *q_u, SPOOL_R_ENDPAGEPRINTER *r_u);
+WERROR _spoolss_startdocprinter(pipes_struct *p,  
SPOOL_Q_STARTDOCPRINTER *q_u, SPOOL_R_STARTDOCPRINTER *r_u);
+WERROR _spoolss_enddocprinter(pipes_struct *p, SPOOL_Q_ENDDOCPRINTER  
*q_u, SPOOL_R_ENDDOCPRINTER *r_u);
+WERROR _spoolss_writeprinter(pipes_struct *p, SPOOL_Q_WRITEPRINTER  
*q_u, SPOOL_R_WRITEPRINTER *r_u);
+WERROR _spoolss_abortprinter(pipes_struct *p, SPOOL_Q_ABORTPRINTER  
*q_u, SPOOL_R_ABORTPRINTER *r_u);
+WERROR add_port_hook(NT_USER_TOKEN *token, const char *portname,  
const char *uri );
+BOOL add_printer_hook(NT_USER_TOKEN *token, NT_PRINTER_INFO_LEVEL  
*printer);
+WERROR _spoolss_setprinter(pipes_struct *p, SPOOL_Q_SETPRINTER *q_u,  
SPOOL_R_SETPRINTER *r_u);
+WERROR _spoolss_fcpn(pipes_struct *p, SPOOL_Q_FCPN *q_u,  
SPOOL_R_FCPN *r_u);
+WERROR _spoolss_addjob(pipes_struct *p, SPOOL_Q_ADDJOB *q_u,  
SPOOL_R_ADDJOB *r_u);
+WERROR _spoolss_enumjobs( pipes_struct *p, SPOOL_Q_ENUMJOBS *q_u,  
SPOOL_R_ENUMJOBS *r_u);
+WERROR _spoolss_schedulejob( pipes_struct *p, SPOOL_Q_SCHEDULEJOB  
*q_u, SPOOL_R_SCHEDULEJOB *r_u);
+WERROR _spoolss_setjob(pipes_struct *p, SPOOL_Q_SETJOB *q_u,  
SPOOL_R_SETJOB *r_u);
+WERROR _spoolss_enumprinterdrivers( pipes_struct *p,  
SPOOL_Q_ENUMPRINTERDRIVERS *q_u, SPOOL_R_ENUMPRINTERDRIVERS *r_u);
+WERROR _spoolss_enumforms(pipes_struct *p, SPOOL_Q_ENUMFORMS *q_u,  
SPOOL_R_ENUMFORMS *r_u);
+WERROR _spoolss_getform(pipes_struct *p, SPOOL_Q_GETFORM *q_u,  
SPOOL_R_GETFORM *r_u);
+WERROR enumports_hook( int *count, char ***lines );
+WERROR _spoolss_enumports( pipes_struct *p, SPOOL_Q_ENUMPORTS *q_u,  
SPOOL_R_ENUMPORTS *r_u);
+WERROR _spoolss_addprinterex( pipes_struct *p, SPOOL_Q_ADDPRINTEREX  
*q_u, SPOOL_R_ADDPRINTEREX *r_u);
+WERROR _spoolss_addprinterdriver(pipes_struct *p,  
SPOOL_Q_ADDPRINTERDRIVER *q_u, SPOOL_R_ADDPRINTERDRIVER *r_u);
+WERROR _spoolss_addprinterdriverex(pipes_struct *p,  
SPOOL_Q_ADDPRINTERDRIVEREX *q_u, SPOOL_R_ADDPRINTERDRIVEREX *r_u);
+WERROR _spoolss_getprinterdriverdirectory(pipes_struct *p,  
SPOOL_Q_GETPRINTERDRIVERDIR *q_u, SPOOL_R_GETPRINTERDRIVERDIR *r_u);
+WERROR _spoolss_enumprinterdata(pipes_struct *p,  
SPOOL_Q_ENUMPRINTERDATA *q_u, SPOOL_R_ENUMPRINTERDATA *r_u);
+WERROR _spoolss_setprinterdata( pipes_struct *p,  
SPOOL_Q_SETPRINTERDATA *q_u, SPOOL_R_SETPRINTERDATA *r_u);
+WERROR _spoolss_resetprinter(pipes_struct *p, SPOOL_Q_RESETPRINTER  
*q_u, SPOOL_R_RESETPRINTER *r_u);
+WERROR _spoolss_deleteprinterdata(pipes_struct *p,  
SPOOL_Q_DELETEPRINTERDATA *q_u, SPOOL_R_DELETEPRINTERDATA *r_u);
+WERROR _spoolss_addform( pipes_struct *p, SPOOL_Q_ADDFORM *q_u,  
SPOOL_R_ADDFORM *r_u);
+WERROR _spoolss_deleteform( pipes_struct *p, SPOOL_Q_DELETEFORM  
*q_u, SPOOL_R_DELETEFORM *r_u);
+WERROR _spoolss_setform(pipes_struct *p, SPOOL_Q_SETFORM *q_u,  
SPOOL_R_SETFORM *r_u);
+WERROR _spoolss_enumprintprocessors(pipes_struct *p,  
SPOOL_Q_ENUMPRINTPROCESSORS *q_u, SPOOL_R_ENUMPRINTPROCESSORS *r_u);
+WERROR _spoolss_enumprintprocdatatypes(pipes_struct *p,  
SPOOL_Q_ENUMPRINTPROCDATATYPES *q_u, SPOOL_R_ENUMPRINTPROCDATATYPES  
*r_u);
+WERROR _spoolss_enumprintmonitors(pipes_struct *p,  
SPOOL_Q_ENUMPRINTMONITORS *q_u, SPOOL_R_ENUMPRINTMONITORS *r_u);
+WERROR _spoolss_getjob( pipes_struct *p, SPOOL_Q_GETJOB *q_u,  
SPOOL_R_GETJOB *r_u);
+WERROR _spoolss_getprinterdataex(pipes_struct *p,  
SPOOL_Q_GETPRINTERDATAEX *q_u, SPOOL_R_GETPRINTERDATAEX *r_u);
+WERROR _spoolss_setprinterdataex(pipes_struct *p,  
SPOOL_Q_SETPRINTERDATAEX *q_u, SPOOL_R_SETPRINTERDATAEX *r_u);
+WERROR _spoolss_deleteprinterdataex(pipes_struct *p,  
SPOOL_Q_DELETEPRINTERDATAEX *q_u, SPOOL_R_DELETEPRINTERDATAEX *r_u);
+WERROR _spoolss_enumprinterkey(pipes_struct *p,  
SPOOL_Q_ENUMPRINTERKEY *q_u, SPOOL_R_ENUMPRINTERKEY *r_u);
+WERROR _spoolss_deleteprinterkey(pipes_struct *p,  
SPOOL_Q_DELETEPRINTERKEY *q_u, SPOOL_R_DELETEPRINTERKEY *r_u);
+WERROR _spoolss_enumprinterdataex(pipes_struct *p,  
SPOOL_Q_ENUMPRINTERDATAEX *q_u, SPOOL_R_ENUMPRINTERDATAEX *r_u);
+WERROR _spoolss_getprintprocessordirectory(pipes_struct *p,  
SPOOL_Q_GETPRINTPROCESSORDIRECTORY *q_u,  
SPOOL_R_GETPRINTPROCESSORDIRECTORY *r_u);
+WERROR _spoolss_xcvdataport(pipes_struct *p, SPOOL_Q_XCVDATAPORT  
*q_u, SPOOL_R_XCVDATAPORT *r_u);
+
+/* The following definitions come from rpc_server/srv_srvsvc_nt.c  */
+
+WERROR _srvsvc_NetFileEnum(pipes_struct *p, struct  
srvsvc_NetFileEnum *r);
+WERROR _srvsvc_NetSrvGetInfo(pipes_struct *p, struct  
srvsvc_NetSrvGetInfo *r);
+WERROR _srvsvc_NetSrvSetInfo(pipes_struct *p, struct  
srvsvc_NetSrvSetInfo *r);
+WERROR _srvsvc_NetConnEnum(pipes_struct *p, struct  
srvsvc_NetConnEnum *r);
+WERROR _srvsvc_NetSessEnum(pipes_struct *p, struct  
srvsvc_NetSessEnum *r);
+WERROR _srvsvc_NetSessDel(pipes_struct *p, struct srvsvc_NetSessDel  
*r);
+WERROR _srvsvc_NetShareEnumAll(pipes_struct *p, struct  
srvsvc_NetShareEnumAll *r);
+WERROR _srvsvc_NetShareEnum(pipes_struct *p, struct  
srvsvc_NetShareEnum *r);
+WERROR _srvsvc_NetShareGetInfo(pipes_struct *p, struct  
srvsvc_NetShareGetInfo *r);
+char *valid_share_pathname(char *dos_pathname);
+WERROR _srvsvc_NetShareSetInfo(pipes_struct *p, struct  
srvsvc_NetShareSetInfo *r);
+WERROR _srvsvc_NetShareAdd(pipes_struct *p, struct  
srvsvc_NetShareAdd *r);
+WERROR _srvsvc_NetShareDel(pipes_struct *p, struct  
srvsvc_NetShareDel *r);
+WERROR _srvsvc_NetShareDelSticky(pipes_struct *p, struct  
srvsvc_NetShareDelSticky *r);
+WERROR _srvsvc_NetRemoteTOD(pipes_struct *p, struct  
srvsvc_NetRemoteTOD *r);
+WERROR _srvsvc_NetGetFileSecurity(pipes_struct *p, struct  
srvsvc_NetGetFileSecurity *r);
+WERROR _srvsvc_NetSetFileSecurity(pipes_struct *p, struct  
srvsvc_NetSetFileSecurity *r);
+WERROR _srvsvc_NetDiskEnum(pipes_struct *p, struct  
srvsvc_NetDiskEnum *r);
+WERROR _srvsvc_NetNameValidate(pipes_struct *p, struct  
srvsvc_NetNameValidate *r);
+WERROR _srvsvc_NetFileClose(pipes_struct *p, struct  
srvsvc_NetFileClose *r);
+WERROR _srvsvc_NetCharDevEnum(pipes_struct *p, struct  
srvsvc_NetCharDevEnum *r);
+WERROR _srvsvc_NetCharDevGetInfo(pipes_struct *p, struct  
srvsvc_NetCharDevGetInfo *r);
+WERROR _srvsvc_NetCharDevControl(pipes_struct *p, struct  
srvsvc_NetCharDevControl *r);
+WERROR _srvsvc_NetCharDevQEnum(pipes_struct *p, struct  
srvsvc_NetCharDevQEnum *r);
+WERROR _srvsvc_NetCharDevQGetInfo(pipes_struct *p, struct  
srvsvc_NetCharDevQGetInfo *r);
+WERROR _srvsvc_NetCharDevQSetInfo(pipes_struct *p, struct  
srvsvc_NetCharDevQSetInfo *r);
+WERROR _srvsvc_NetCharDevQPurge(pipes_struct *p, struct  
srvsvc_NetCharDevQPurge *r);
+WERROR _srvsvc_NetCharDevQPurgeSelf(pipes_struct *p, struct  
srvsvc_NetCharDevQPurgeSelf *r);
+WERROR _srvsvc_NetFileGetInfo(pipes_struct *p, struct  
srvsvc_NetFileGetInfo *r);
+WERROR _srvsvc_NetShareCheck(pipes_struct *p, struct  
srvsvc_NetShareCheck *r);
+WERROR _srvsvc_NetServerStatisticsGet(pipes_struct *p, struct  
srvsvc_NetServerStatisticsGet *r);
+WERROR _srvsvc_NetTransportAdd(pipes_struct *p, struct  
srvsvc_NetTransportAdd *r);
+WERROR _srvsvc_NetTransportEnum(pipes_struct *p, struct  
srvsvc_NetTransportEnum *r);
+WERROR _srvsvc_NetTransportDel(pipes_struct *p, struct  
srvsvc_NetTransportDel *r);
+WERROR _srvsvc_NetSetServiceBits(pipes_struct *p, struct  
srvsvc_NetSetServiceBits *r);
+WERROR _srvsvc_NetPathType(pipes_struct *p, struct  
srvsvc_NetPathType *r);
+WERROR _srvsvc_NetPathCanonicalize(pipes_struct *p, struct  
srvsvc_NetPathCanonicalize *r);
+WERROR _srvsvc_NetPathCompare(pipes_struct *p, struct  
srvsvc_NetPathCompare *r);
+WERROR _srvsvc_NETRPRNAMECANONICALIZE(pipes_struct *p, struct  
srvsvc_NETRPRNAMECANONICALIZE *r);
+WERROR _srvsvc_NetPRNameCompare(pipes_struct *p, struct  
srvsvc_NetPRNameCompare *r);
+WERROR _srvsvc_NetShareDelStart(pipes_struct *p, struct  
srvsvc_NetShareDelStart *r);
+WERROR _srvsvc_NetShareDelCommit(pipes_struct *p, struct  
srvsvc_NetShareDelCommit *r);
+WERROR _srvsvc_NetServerTransportAddEx(pipes_struct *p, struct  
srvsvc_NetServerTransportAddEx *r);
+WERROR _srvsvc_NetServerSetServiceBitsEx(pipes_struct *p, struct  
srvsvc_NetServerSetServiceBitsEx *r);
+WERROR _srvsvc_NETRDFSGETVERSION(pipes_struct *p, struct  
srvsvc_NETRDFSGETVERSION *r);
+WERROR _srvsvc_NETRDFSCREATELOCALPARTITION(pipes_struct *p, struct  
srvsvc_NETRDFSCREATELOCALPARTITION *r);
+WERROR _srvsvc_NETRDFSDELETELOCALPARTITION(pipes_struct *p, struct  
srvsvc_NETRDFSDELETELOCALPARTITION *r);
+WERROR _srvsvc_NETRDFSSETLOCALVOLUMESTATE(pipes_struct *p, struct  
srvsvc_NETRDFSSETLOCALVOLUMESTATE *R);
+WERROR _srvsvc_NETRDFSSETSERVERINFO(pipes_struct *p, struct  
srvsvc_NETRDFSSETSERVERINFO *r);
+WERROR _srvsvc_NETRDFSCREATEEXITPOINT(pipes_struct *p, struct  
srvsvc_NETRDFSCREATEEXITPOINT *r);
+WERROR _srvsvc_NETRDFSDELETEEXITPOINT(pipes_struct *p, struct  
srvsvc_NETRDFSDELETEEXITPOINT *r);
+WERROR _srvsvc_NETRSERVERTRANSPORTDELEX(pipes_struct *p, struct  
srvsvc_NETRSERVERTRANSPORTDELEX *r);
+WERROR _srvsvc_NETRDFSMANAGERREPORTSITEINFO(pipes_struct *p, struct  
srvsvc_NETRDFSMANAGERREPORTSITEINFO *r);
+WERROR _srvsvc_NETRDFSMODIFYPREFIX(pipes_struct *p, struct  
srvsvc_NETRDFSMODIFYPREFIX *r);
+WERROR _srvsvc_NETRDFSFIXLOCALVOLUME(pipes_struct *p, struct  
srvsvc_NETRDFSFIXLOCALVOLUME *r);
+
+/* The following definitions come from rpc_server/srv_svcctl.c  */
+
+void svcctl2_get_pipe_fns( struct api_struct **fns, int *n_fns );
+NTSTATUS rpc_svcctl2_init(void);
+
+/* The following definitions come from rpc_server/srv_svcctl_nt.c  */
+
+BOOL init_service_op_table( void );
+WERROR _svcctl_open_scmanager(pipes_struct *p,  
SVCCTL_Q_OPEN_SCMANAGER *q_u, SVCCTL_R_OPEN_SCMANAGER *r_u);
+WERROR _svcctl_open_service(pipes_struct *p, SVCCTL_Q_OPEN_SERVICE  
*q_u, SVCCTL_R_OPEN_SERVICE *r_u);
+WERROR _svcctl_CloseServiceHandle(pipes_struct *p, struct  
svcctl_CloseServiceHandle *r);
+WERROR _svcctl_get_display_name(pipes_struct *p,  
SVCCTL_Q_GET_DISPLAY_NAME *q_u, SVCCTL_R_GET_DISPLAY_NAME *r_u);
+WERROR _svcctl_query_status(pipes_struct *p, SVCCTL_Q_QUERY_STATUS  
*q_u, SVCCTL_R_QUERY_STATUS *r_u);
+WERROR _svcctl_enum_services_status(pipes_struct *p,  
SVCCTL_Q_ENUM_SERVICES_STATUS *q_u, SVCCTL_R_ENUM_SERVICES_STATUS *r_u);
+WERROR _svcctl_start_service(pipes_struct *p, SVCCTL_Q_START_SERVICE  
*q_u, SVCCTL_R_START_SERVICE *r_u);
+WERROR _svcctl_control_service(pipes_struct *p,  
SVCCTL_Q_CONTROL_SERVICE *q_u, SVCCTL_R_CONTROL_SERVICE *r_u);
+WERROR _svcctl_enum_dependent_services( pipes_struct *p,  
SVCCTL_Q_ENUM_DEPENDENT_SERVICES *q_u,  
SVCCTL_R_ENUM_DEPENDENT_SERVICES *r_u );
+WERROR _svcctl_query_service_status_ex( pipes_struct *p,  
SVCCTL_Q_QUERY_SERVICE_STATUSEX *q_u, SVCCTL_R_QUERY_SERVICE_STATUSEX  
*r_u );
+WERROR _svcctl_query_service_config( pipes_struct *p,  
SVCCTL_Q_QUERY_SERVICE_CONFIG *q_u, SVCCTL_R_QUERY_SERVICE_CONFIG  
*r_u );
+WERROR _svcctl_query_service_config2( pipes_struct *p,  
SVCCTL_Q_QUERY_SERVICE_CONFIG2 *q_u, SVCCTL_R_QUERY_SERVICE_CONFIG2  
*r_u );
+WERROR _svcctl_lock_service_db( pipes_struct *p,  
SVCCTL_Q_LOCK_SERVICE_DB *q_u, SVCCTL_R_LOCK_SERVICE_DB *r_u );
+WERROR _svcctl_unlock_service_db( pipes_struct *p,  
SVCCTL_Q_UNLOCK_SERVICE_DB *q_u, SVCCTL_R_UNLOCK_SERVICE_DB *r_u );
+WERROR _svcctl_query_service_sec( pipes_struct *p,  
SVCCTL_Q_QUERY_SERVICE_SEC *q_u, SVCCTL_R_QUERY_SERVICE_SEC *r_u );
+WERROR _svcctl_set_service_sec( pipes_struct *p,  
SVCCTL_Q_SET_SERVICE_SEC *q_u, SVCCTL_R_SET_SERVICE_SEC *r_u );
+WERROR _svcctl_ControlService(pipes_struct *p, struct  
svcctl_ControlService *r);
+WERROR _svcctl_DeleteService(pipes_struct *p, struct  
svcctl_DeleteService *r);
+WERROR _svcctl_LockServiceDatabase(pipes_struct *p, struct  
svcctl_LockServiceDatabase *r);
+WERROR _svcctl_QueryServiceObjectSecurity(pipes_struct *p, struct  
svcctl_QueryServiceObjectSecurity *r);
+WERROR _svcctl_SetServiceObjectSecurity(pipes_struct *p, struct  
svcctl_SetServiceObjectSecurity *r);
+WERROR _svcctl_QueryServiceStatus(pipes_struct *p, struct  
svcctl_QueryServiceStatus *r);
+WERROR _svcctl_SetServiceStatus(pipes_struct *p, struct  
svcctl_SetServiceStatus *r);
+WERROR _svcctl_UnlockServiceDatabase(pipes_struct *p, struct  
svcctl_UnlockServiceDatabase *r);
+WERROR _svcctl_NotifyBootConfigStatus(pipes_struct *p, struct  
svcctl_NotifyBootConfigStatus *r);
+WERROR _svcctl_SCSetServiceBitsW(pipes_struct *p, struct  
svcctl_SCSetServiceBitsW *r);
+WERROR _svcctl_ChangeServiceConfigW(pipes_struct *p, struct  
svcctl_ChangeServiceConfigW *r);
+WERROR _svcctl_CreateServiceW(pipes_struct *p, struct  
svcctl_CreateServiceW *r);
+WERROR _svcctl_EnumDependentServicesW(pipes_struct *p, struct  
svcctl_EnumDependentServicesW *r);
+WERROR _svcctl_EnumServicesStatusW(pipes_struct *p, struct  
svcctl_EnumServicesStatusW *r);
+WERROR _svcctl_OpenSCManagerW(pipes_struct *p, struct  
svcctl_OpenSCManagerW *r);
+WERROR _svcctl_OpenServiceW(pipes_struct *p, struct  
svcctl_OpenServiceW *r);
+WERROR _svcctl_QueryServiceConfigW(pipes_struct *p, struct  
svcctl_QueryServiceConfigW *r);
+WERROR _svcctl_QueryServiceLockStatusW(pipes_struct *p, struct  
svcctl_QueryServiceLockStatusW *r);
+WERROR _svcctl_StartServiceW(pipes_struct *p, struct  
svcctl_StartServiceW *r);
+WERROR _svcctl_GetServiceDisplayNameW(pipes_struct *p, struct  
svcctl_GetServiceDisplayNameW *r);
+WERROR _svcctl_GetServiceKeyNameW(pipes_struct *p, struct  
svcctl_GetServiceKeyNameW *r);
+WERROR _svcctl_SCSetServiceBitsA(pipes_struct *p, struct  
svcctl_SCSetServiceBitsA *r);
+WERROR _svcctl_ChangeServiceConfigA(pipes_struct *p, struct  
svcctl_ChangeServiceConfigA *r);
+WERROR _svcctl_CreateServiceA(pipes_struct *p, struct  
svcctl_CreateServiceA *r);
+WERROR _svcctl_EnumDependentServicesA(pipes_struct *p, struct  
svcctl_EnumDependentServicesA *r);
+WERROR _svcctl_EnumServicesStatusA(pipes_struct *p, struct  
svcctl_EnumServicesStatusA *r);
+WERROR _svcctl_OpenSCManagerA(pipes_struct *p, struct  
svcctl_OpenSCManagerA *r);
+WERROR _svcctl_OpenServiceA(pipes_struct *p, struct  
svcctl_OpenServiceA *r);
+WERROR _svcctl_QueryServiceConfigA(pipes_struct *p, struct  
svcctl_QueryServiceConfigA *r);
+WERROR _svcctl_QueryServiceLockStatusA(pipes_struct *p, struct  
svcctl_QueryServiceLockStatusA *r);
+WERROR _svcctl_StartServiceA(pipes_struct *p, struct  
svcctl_StartServiceA *r);
+WERROR _svcctl_GetServiceDisplayNameA(pipes_struct *p, struct  
svcctl_GetServiceDisplayNameA *r);
+WERROR _svcctl_GetServiceKeyNameA(pipes_struct *p, struct  
svcctl_GetServiceKeyNameA *r);
+WERROR _svcctl_GetCurrentGroupeStateW(pipes_struct *p, struct  
svcctl_GetCurrentGroupeStateW *r);
+WERROR _svcctl_EnumServiceGroupW(pipes_struct *p, struct  
svcctl_EnumServiceGroupW *r);
+WERROR _svcctl_ChangeServiceConfig2A(pipes_struct *p, struct  
svcctl_ChangeServiceConfig2A *r);
+WERROR _svcctl_ChangeServiceConfig2W(pipes_struct *p, struct  
svcctl_ChangeServiceConfig2W *r);
+WERROR _svcctl_QueryServiceConfig2A(pipes_struct *p, struct  
svcctl_QueryServiceConfig2A *r);
+WERROR _svcctl_QueryServiceConfig2W(pipes_struct *p, struct  
svcctl_QueryServiceConfig2W *r);
+WERROR _svcctl_QueryServiceStatusEx(pipes_struct *p, struct  
svcctl_QueryServiceStatusEx *r);
+WERROR _EnumServicesStatusExA(pipes_struct *p, struct  
EnumServicesStatusExA *r);
+WERROR _EnumServicesStatusExW(pipes_struct *p, struct  
EnumServicesStatusExW *r);
+WERROR _svcctl_SCSendTSMessage(pipes_struct *p, struct  
svcctl_SCSendTSMessage *r);
+
+/* The following definitions come from rpc_server/srv_unixinfo_nt.c  */
+
+NTSTATUS _unixinfo_SidToUid(pipes_struct *p, struct  
unixinfo_SidToUid *r);
+NTSTATUS _unixinfo_UidToSid(pipes_struct *p, struct  
unixinfo_UidToSid *r);
+NTSTATUS _unixinfo_SidToGid(pipes_struct *p, struct  
unixinfo_SidToGid *r);
+NTSTATUS _unixinfo_GidToSid(pipes_struct *p, struct  
unixinfo_GidToSid *r);
+NTSTATUS _unixinfo_GetPWUid(pipes_struct *p, struct  
unixinfo_GetPWUid *r);
+
+/* The following definitions come from rpc_server/srv_winreg_nt.c  */
+
+WERROR _winreg_CloseKey(pipes_struct *p, struct winreg_CloseKey *r);
+WERROR _winreg_OpenHKLM(pipes_struct *p, struct winreg_OpenHKLM *r);
+WERROR _winreg_OpenHKPD(pipes_struct *p, struct winreg_OpenHKPD *r);
+WERROR _winreg_OpenHKPT(pipes_struct *p, struct winreg_OpenHKPT *r);
+WERROR _winreg_OpenHKCR(pipes_struct *p, struct winreg_OpenHKCR *r);
+WERROR _winreg_OpenHKU(pipes_struct *p, struct winreg_OpenHKU *r);
+WERROR _winreg_OpenHKCU(pipes_struct *p, struct winreg_OpenHKCU *r);
+WERROR _winreg_OpenHKCC(pipes_struct *p, struct winreg_OpenHKCC *r);
+WERROR _winreg_OpenHKDD(pipes_struct *p, struct winreg_OpenHKDD *r);
+WERROR _winreg_OpenHKPN(pipes_struct *p, struct winreg_OpenHKPN *r);
+WERROR _winreg_OpenKey(pipes_struct *p, struct winreg_OpenKey *r);
+WERROR _winreg_QueryValue(pipes_struct *p, struct winreg_QueryValue  
*r);
+WERROR _winreg_QueryInfoKey(pipes_struct *p, struct  
winreg_QueryInfoKey *r);
+WERROR _winreg_GetVersion(pipes_struct *p, struct winreg_GetVersion  
*r);
+WERROR _winreg_EnumKey(pipes_struct *p, struct winreg_EnumKey *r);
+WERROR _winreg_EnumValue(pipes_struct *p, struct winreg_EnumValue *r);
+WERROR _winreg_InitiateSystemShutdown(pipes_struct *p, struct  
winreg_InitiateSystemShutdown *r);
+WERROR _winreg_InitiateSystemShutdownEx(pipes_struct *p, struct  
winreg_InitiateSystemShutdownEx *r);
+WERROR _winreg_AbortSystemShutdown(pipes_struct *p, struct  
winreg_AbortSystemShutdown *r);
+WERROR _winreg_RestoreKey(pipes_struct *p, struct winreg_RestoreKey  
*r);
+WERROR _winreg_SaveKey(pipes_struct *p, struct winreg_SaveKey *r);
+WERROR _winreg_SaveKeyEx(pipes_struct *p, struct winreg_SaveKeyEx *r);
+WERROR _winreg_CreateKey( pipes_struct *p, struct winreg_CreateKey *r);
+WERROR _winreg_SetValue(pipes_struct *p, struct winreg_SetValue *r);
+WERROR _winreg_DeleteKey(pipes_struct *p, struct winreg_DeleteKey *r);
+WERROR _winreg_DeleteValue(pipes_struct *p, struct  
winreg_DeleteValue *r);
+WERROR _winreg_GetKeySecurity(pipes_struct *p, struct  
winreg_GetKeySecurity *r);
+WERROR _winreg_SetKeySecurity(pipes_struct *p, struct  
winreg_SetKeySecurity *r);
+WERROR _winreg_FlushKey(pipes_struct *p, struct winreg_FlushKey *r);
+WERROR _winreg_UnLoadKey(pipes_struct *p, struct winreg_UnLoadKey *r);
+WERROR _winreg_ReplaceKey(pipes_struct *p, struct winreg_ReplaceKey  
*r);
+WERROR _winreg_LoadKey(pipes_struct *p, struct winreg_LoadKey *r);
+WERROR _winreg_NotifyChangeKeyValue(pipes_struct *p, struct  
winreg_NotifyChangeKeyValue *r);
+WERROR _winreg_QueryMultipleValues(pipes_struct *p, struct  
winreg_QueryMultipleValues *r);
+WERROR _winreg_QueryMultipleValues2(pipes_struct *p, struct  
winreg_QueryMultipleValues2 *r);
+
+/* The following definitions come from rpc_server/srv_wkssvc_nt.c  */
+
+WERROR _wkssvc_NetWkstaGetInfo( pipes_struct *p, struct  
wkssvc_NetWkstaGetInfo *r);
+WERROR _wkssvc_NetWkstaSetInfo( pipes_struct *p, struct  
wkssvc_NetWkstaSetInfo *r);
+WERROR _wkssvc_NetWkstaEnumUsers( pipes_struct *p, struct  
wkssvc_NetWkstaEnumUsers *r);
+WERROR _WKSSVC_NETRWKSTAUSERGETINFO( pipes_struct *p, struct  
WKSSVC_NETRWKSTAUSERGETINFO *r );
+WERROR _WKSSVC_NETRWKSTAUSERSETINFO( pipes_struct *p, struct  
WKSSVC_NETRWKSTAUSERSETINFO *r );
+WERROR _wkssvc_NetWkstaTransportEnum( pipes_struct *p, struct  
wkssvc_NetWkstaTransportEnum *r);
+WERROR _WKSSVC_NETRWKSTATRANSPORTADD( pipes_struct *p, struct  
WKSSVC_NETRWKSTATRANSPORTADD *r );
+WERROR _WKSSVC_NETRWKSTATRANSPORTDEL( pipes_struct *p, struct  
WKSSVC_NETRWKSTATRANSPORTDEL *r );
+WERROR _WKSSVC_NETRUSEADD( pipes_struct *p, struct WKSSVC_NETRUSEADD  
*r );
+WERROR _WKSSVC_NETRUSEGETINFO( pipes_struct *p, struct  
WKSSVC_NETRUSEGETINFO *r );
+WERROR _WKSSVC_NETRUSEDEL( pipes_struct *p, struct WKSSVC_NETRUSEDEL  
*r );
+WERROR _WKSSVC_NETRUSEENUM( pipes_struct *p, struct  
WKSSVC_NETRUSEENUM *r );
+WERROR _WKSSVC_NETRMESSAGEBUFFERSEND( pipes_struct *p, struct  
WKSSVC_NETRMESSAGEBUFFERSEND *r );
+WERROR _WKSSVC_NETRWORKSTATIONSTATISTICSGET( pipes_struct *p, struct  
WKSSVC_NETRWORKSTATIONSTATISTICSGET *r );
+WERROR _WKSSVC_NETRLOGONDOMAINNAMEADD( pipes_struct *p, struct  
WKSSVC_NETRLOGONDOMAINNAMEADD *r );
+WERROR _WKSSVC_NETRLOGONDOMAINNAMEDEL( pipes_struct *p, struct  
WKSSVC_NETRLOGONDOMAINNAMEDEL *r );
+WERROR _WKSSVC_NETRJOINDOMAIN( pipes_struct *p, struct  
WKSSVC_NETRJOINDOMAIN *r );
+WERROR _WKSSVC_NETRUNJOINDOMAIN( pipes_struct *p, struct  
WKSSVC_NETRUNJOINDOMAIN *r );
+WERROR _WKSSVC_NETRRENAMEMACHINEINDOMAIN( pipes_struct *p, struct  
WKSSVC_NETRRENAMEMACHINEINDOMAIN *r );
+WERROR _WKSSVC_NETRVALIDATENAME( pipes_struct *p, struct  
WKSSVC_NETRVALIDATENAME *r );
+WERROR _WKSSVC_NETRGETJOININFORMATION( pipes_struct *p, struct  
WKSSVC_NETRGETJOININFORMATION *r );
+WERROR _WKSSVC_NETRGETJOINABLEOUS( pipes_struct *p, struct  
WKSSVC_NETRGETJOINABLEOUS *r );
+WERROR _wkssvc_NetrJoinDomain2(pipes_struct *p, struct  
wkssvc_NetrJoinDomain2 *r);
+WERROR _wkssvc_NetrUnjoinDomain2(pipes_struct *p, struct  
wkssvc_NetrUnjoinDomain2 *r);
+WERROR _wkssvc_NetrRenameMachineInDomain2(pipes_struct *p, struct  
wkssvc_NetrRenameMachineInDomain2 *r);
+WERROR _WKSSVC_NETRVALIDATENAME2( pipes_struct *p, struct  
WKSSVC_NETRVALIDATENAME2 *r );
+WERROR _WKSSVC_NETRGETJOINABLEOUS2( pipes_struct *p, struct  
WKSSVC_NETRGETJOINABLEOUS2 *r );
+WERROR _wkssvc_NetrAddAlternateComputerName(pipes_struct *p, struct  
wkssvc_NetrAddAlternateComputerName *r );
+WERROR _wkssvc_NetrRemoveAlternateComputerName(pipes_struct *p,  
struct wkssvc_NetrRemoveAlternateComputerName *r);
+WERROR _WKSSVC_NETRSETPRIMARYCOMPUTERNAME( pipes_struct *p, struct  
WKSSVC_NETRSETPRIMARYCOMPUTERNAME *r );
+WERROR _WKSSVC_NETRENUMERATECOMPUTERNAMES( pipes_struct *p, struct  
WKSSVC_NETRENUMERATECOMPUTERNAMES *r );
+
+/* The following definitions come from rpcclient/cmd_dfs.c  */
+
+
+/* The following definitions come from rpcclient/cmd_ds.c  */
+
+
+/* The following definitions come from rpcclient/cmd_echo.c  */
+
+
+/* The following definitions come from rpcclient/cmd_lsarpc.c  */
+
+
+/* The following definitions come from rpcclient/cmd_netlogon.c  */
+
+
+/* The following definitions come from rpcclient/cmd_samr.c  */
+
+
+/* The following definitions come from rpcclient/cmd_shutdown.c  */
+
+
+/* The following definitions come from rpcclient/cmd_spoolss.c  */
+
+void set_drv_info_3_env (DRIVER_INFO_3 *info, const char *arch);
+
+/* The following definitions come from rpcclient/cmd_srvsvc.c  */
+
+
+/* The following definitions come from rpcclient/cmd_test.c  */
+
+
+/* The following definitions come from rpcclient/cmd_unixinfo.c  */
+
+
+/* The following definitions come from rpcclient/rpcclient.c  */
+
+
+/* The following definitions come from services/services_db.c  */
+
+void svcctl_init_keys( void );
+SEC_DESC* svcctl_get_secdesc( TALLOC_CTX *ctx, const char *name,  
NT_USER_TOKEN *token );
+BOOL svcctl_set_secdesc( TALLOC_CTX *ctx, const char *name, SEC_DESC  
*sec_desc, NT_USER_TOKEN *token );
+char* svcctl_lookup_dispname( const char *name, NT_USER_TOKEN *token );
+char* svcctl_lookup_description( const char *name, NT_USER_TOKEN  
*token );
+REGVAL_CTR* svcctl_fetch_regvalues( const char *name, NT_USER_TOKEN  
*token );
+
+/* The following definitions come from services/svc_netlogon.c  */
+
+
+/* The following definitions come from services/svc_rcinit.c  */
+
+
+/* The following definitions come from services/svc_spoolss.c  */
+
+
+/* The following definitions come from services/svc_winreg.c  */
+
+
+/* The following definitions come from services/svc_wins.c  */
+
+
+/* The following definitions come from smbd/aio.c  */
+
+BOOL aio_finished(void);
+void initialize_async_io_handler(void);
+BOOL schedule_aio_read_and_X(connection_struct *conn,
+			     char *inbuf, char *outbuf,
+			     int length, int len_outbuf,
+			     files_struct *fsp, SMB_OFF_T startpos,
+			     size_t smb_maxcnt);
+BOOL schedule_aio_write_and_X(connection_struct *conn,
+				char *inbuf, char *outbuf,
+				int length, int len_outbuf,
+				files_struct *fsp, char *data,
+				SMB_OFF_T startpos,
+				size_t numtowrite);
+int process_aio_queue(void);
+void cancel_aio_by_fsp(files_struct *fsp);
+BOOL aio_finished(void);
+void initialize_async_io_handler(void);
+int process_aio_queue(void);
+BOOL schedule_aio_read_and_X(connection_struct *conn,
+			     char *inbuf, char *outbuf,
+			     int length, int len_outbuf,
+			     files_struct *fsp, SMB_OFF_T startpos,
+			     size_t smb_maxcnt);
+BOOL schedule_aio_write_and_X(connection_struct *conn,
+                                char *inbuf, char *outbuf,
+                                int length, int len_outbuf,
+                                files_struct *fsp, char *data,
+                                SMB_OFF_T startpos,
+                                size_t numtowrite);
+void cancel_aio_by_fsp(files_struct *fsp);
+
+/* The following definitions come from smbd/blocking.c  */
+
+BOOL push_blocking_lock_request( struct byte_range_lock *br_lck,
+		char *inbuf, int length,
+		files_struct *fsp,
+		int lock_timeout,
+		int lock_num,
+		uint32 lock_pid,
+		enum brl_type lock_type,
+		enum brl_flavour lock_flav,
+		SMB_BIG_UINT offset,
+		SMB_BIG_UINT count,
+		uint32 blocking_pid);
+void cancel_pending_lock_requests_by_fid(files_struct *fsp, struct  
byte_range_lock *br_lck);
+void remove_pending_lock_requests_by_mid(int mid);
+BOOL blocking_lock_was_deferred(int mid);
+BOOL blocking_lock_cancel(files_struct *fsp,
+			uint32 lock_pid,
+			SMB_BIG_UINT offset,
+			SMB_BIG_UINT count,
+			enum brl_flavour lock_flav,
+			unsigned char locktype,
+                        NTSTATUS err);
+
+/* The following definitions come from smbd/change_trust_pw.c  */
+
+NTSTATUS change_trust_account_password( const char *domain, const  
char *remote_machine);
+
+/* The following definitions come from smbd/chgpasswd.c  */
+
+BOOL chgpasswd(const char *name, const struct passwd *pass,
+	       const char *oldpass, const char *newpass, BOOL as_root);
+BOOL chgpasswd(const char *name, const struct passwd *pass,
+	       const char *oldpass, const char *newpass, BOOL as_root);
+BOOL check_lanman_password(char *user, uchar * pass1,
+			   uchar * pass2, struct samu **hnd);
+BOOL change_lanman_password(struct samu *sampass, uchar *pass2);
+NTSTATUS pass_oem_change(char *user,
+			 uchar password_encrypted_with_lm_hash[516],
+			 const uchar old_lm_hash_encrypted[16],
+			 uchar password_encrypted_with_nt_hash[516],
+			 const uchar old_nt_hash_encrypted[16],
+			 uint32 *reject_reason);
+NTSTATUS change_oem_password(struct samu *hnd, char *old_passwd,  
char *new_passwd, BOOL as_root, uint32 *samr_reject_reason);
+
+/* The following definitions come from smbd/close.c  */
+
+NTSTATUS close_stat(files_struct *fsp);
+NTSTATUS close_file(files_struct *fsp, enum file_close_type  
close_type);
+
+/* The following definitions come from smbd/conn.c  */
+
+void conn_init(void);
+int conn_num_open(void);
+BOOL conn_snum_used(int snum);
+connection_struct *conn_find(unsigned cnum);
+connection_struct *conn_new(void);
+void conn_close_all(void);
+BOOL conn_idle_all(time_t t);
+void conn_clear_vuid_cache(uint16 vuid);
+void conn_free_internal(connection_struct *conn);
+void conn_free(connection_struct *conn);
+void msg_force_tdis(struct messaging_context *msg,
+		    void *private_data,
+		    uint32_t msg_type,
+		    struct server_id server_id,
+		    DATA_BLOB *data);
+
+/* The following definitions come from smbd/connection.c  */
+
+BOOL yield_connection(connection_struct *conn, const char *name);
+int count_current_connections( const char *sharename, BOOL clear  );
+int count_all_current_connections(void);
+BOOL claim_connection(connection_struct *conn, const char *name,
+		      uint32 msg_flags);
+BOOL register_message_flags(BOOL doreg, uint32 msg_flags);
+BOOL store_pipe_opendb( smb_np_struct *p );
+BOOL delete_pipe_opendb( smb_np_struct *p );
+
+/* The following definitions come from smbd/dfree.c  */
+
+SMB_BIG_UINT sys_disk_free(connection_struct *conn, const char  
*path, BOOL small_query,
+                              SMB_BIG_UINT *bsize,SMB_BIG_UINT  
*dfree,SMB_BIG_UINT *dsize);
+SMB_BIG_UINT get_dfree_info(connection_struct *conn,
+			const char *path,
+			BOOL small_query,
+			SMB_BIG_UINT *bsize,
+			SMB_BIG_UINT *dfree,
+			SMB_BIG_UINT *dsize);
+
+/* The following definitions come from smbd/dir.c  */
+
+void make_dir_struct(char *buf, const char *mask, const char  
*fname,SMB_OFF_T size,uint32 mode,time_t date, BOOL uc);
+void init_dptrs(void);
+char *dptr_path(int key);
+char *dptr_wcard(int key);
+uint16 dptr_attr(int key);
+void dptr_close(int *key);
+void dptr_closecnum(connection_struct *conn);
+void dptr_idlecnum(connection_struct *conn);
+void dptr_closepath(char *path,uint16 spid);
+NTSTATUS dptr_create(connection_struct *conn, pstring path, BOOL  
old_handle, BOOL expect_close,uint16 spid,
+		const char *wcard, BOOL wcard_has_wild, uint32 attr, struct  
dptr_struct **dptr_ret);
+int dptr_CloseDir(struct dptr_struct *dptr);
+void dptr_SeekDir(struct dptr_struct *dptr, long offset);
+long dptr_TellDir(struct dptr_struct *dptr);
+BOOL dptr_has_wild(struct dptr_struct *dptr);
+int dptr_dnum(struct dptr_struct *dptr);
+const char *dptr_ReadDirName(struct dptr_struct *dptr, long  
*poffset, SMB_STRUCT_STAT *pst);
+BOOL dptr_SearchDir(struct dptr_struct *dptr, const char *name, long  
*poffset, SMB_STRUCT_STAT *pst);
+void dptr_DirCacheAdd(struct dptr_struct *dptr, const char *name,  
long offset);
+BOOL dptr_fill(char *buf1,unsigned int key);
+struct dptr_struct *dptr_fetch(char *buf,int *num);
+struct dptr_struct *dptr_fetch_lanman2(int dptr_num);
+BOOL dir_check_ftype(connection_struct *conn, uint32 mode, uint32  
dirtype);
+BOOL get_dir_entry(connection_struct *conn,char *mask,uint32  
dirtype, pstring fname,
+                   SMB_OFF_T *size,uint32 *mode,time_t *date,BOOL  
check_descend);
+BOOL is_visible_file(connection_struct *conn, const char *dir_path,  
const char *name, SMB_STRUCT_STAT *pst, BOOL use_veto);
+struct smb_Dir *OpenDir(connection_struct *conn, const char *name,  
const char *mask, uint32 attr);
+int CloseDir(struct smb_Dir *dirp);
+const char *ReadDirName(struct smb_Dir *dirp, long *poffset);
+void RewindDir(struct smb_Dir *dirp, long *poffset);
+void SeekDir(struct smb_Dir *dirp, long offset);
+long TellDir(struct smb_Dir *dirp);
+void DirCacheAdd(struct smb_Dir *dirp, const char *name, long offset);
+BOOL SearchDir(struct smb_Dir *dirp, const char *name, long *poffset);
+NTSTATUS can_delete_directory(struct connection_struct *conn,
+				const char *dirname);
+
+/* The following definitions come from smbd/dmapi.c  */
+
+BOOL dmapi_have_session(void);
+int dmapi_init_session(void);
+uint32 dmapi_file_flags(const char * const path);
+
+/* The following definitions come from smbd/dosmode.c  */
+
+mode_t unix_mode(connection_struct *conn, int dosmode, const char  
*fname,
+		 const char *inherit_from_dir);
+uint32 dos_mode_msdfs(connection_struct *conn, const char  
*path,SMB_STRUCT_STAT *sbuf);
+uint32 dos_mode(connection_struct *conn, const char  
*path,SMB_STRUCT_STAT *sbuf);
+int file_set_dosmode(connection_struct *conn, const char *fname,
+		     uint32 dosmode, SMB_STRUCT_STAT *st,
+		     const char *parent_dir);
+int file_ntimes(connection_struct *conn, const char *fname, const  
struct timespec ts[2]);
+BOOL set_filetime(connection_struct *conn, const char *fname,
+		const struct timespec mtime);
+
+/* The following definitions come from smbd/error.c  */
+
+int cached_error_packet(const char *inbuf,char *outbuf,files_struct  
*fsp,int line,const char *file);
+int unix_error_packet(const char *inbuf,char *outbuf,int  
def_class,uint32 def_code, NTSTATUS def_status, int line, const char  
*file);
+BOOL use_nt_status(void);
+void error_packet_set(char *outbuf, uint8 eclass, uint32 ecode,  
NTSTATUS ntstatus, int line, const char *file);
+int error_packet(const char *inbuf, char *outbuf, uint8 eclass,  
uint32 ecode, NTSTATUS ntstatus, int line, const char *file);
+
+/* The following definitions come from smbd/fake_file.c  */
+
+enum FAKE_FILE_TYPE is_fake_file(const char *fname);
+NTSTATUS open_fake_file(connection_struct *conn,
+				enum FAKE_FILE_TYPE fake_file_type,
+				const char *fname,
+				uint32 access_mask,
+				files_struct **result);
+void destroy_fake_file_handle(FAKE_FILE_HANDLE **fh);
+NTSTATUS close_fake_file(files_struct *fsp);
+
+/* The following definitions come from smbd/fileio.c  */
+
+ssize_t read_file(files_struct *fsp,char *data,SMB_OFF_T pos,size_t n);
+ssize_t write_file(files_struct *fsp, const char *data, SMB_OFF_T  
pos, size_t n);
+void delete_write_cache(files_struct *fsp);
+void set_filelen_write_cache(files_struct *fsp, SMB_OFF_T file_size);
+ssize_t flush_write_cache(files_struct *fsp, enum flush_reason_enum  
reason);
+void sync_file(connection_struct *conn, files_struct *fsp, BOOL  
write_through);
+int fsp_stat(files_struct *fsp, SMB_STRUCT_STAT *pst);
+
+/* The following definitions come from smbd/filename.c  */
+
+NTSTATUS unix_convert(connection_struct *conn,
+			pstring name,
+			BOOL allow_wcard_last_component,
+			char *saved_last_component,
+			SMB_STRUCT_STAT *pst);
+NTSTATUS check_name(connection_struct *conn, const pstring name);
+
+/* The following definitions come from smbd/files.c  */
+
+NTSTATUS file_new(connection_struct *conn, files_struct **result);
+void file_close_conn(connection_struct *conn);
+void file_close_pid(uint16 smbpid, int vuid);
+void file_init(void);
+void file_close_user(int vuid);
+void file_dump_open_table(void);
+files_struct *file_find_fd(int fd);
+files_struct *file_find_dif(struct file_id id, unsigned long gen_id);
+files_struct *file_find_fsp(files_struct *orig_fsp);
+files_struct *file_find_di_first(struct file_id id);
+files_struct *file_find_di_next(files_struct *start_fsp);
+files_struct *file_find_print(void);
+void fsp_set_pending_modtime(files_struct *tfsp, const struct  
timespec mod);
+void file_sync_all(connection_struct *conn);
+void file_free(files_struct *fsp);
+files_struct *file_fnum(uint16 fnum);
+files_struct *file_fsp(char *buf, int where);
+void file_chain_reset(void);
+NTSTATUS dup_file_fsp(files_struct *fsp,
+				uint32 access_mask,
+				uint32 share_access,
+				uint32 create_options,
+		      		files_struct **result);
+
+/* The following definitions come from smbd/ipc.c  */
+
+void send_trans_reply(const char *inbuf,
+			char *outbuf,
+			char *rparam,
+			int rparam_len,
+			char *rdata,
+			int rdata_len,
+			BOOL buffer_too_large);
+int reply_trans(connection_struct *conn,
+		char *inbuf,
+		char *outbuf,
+		int size,
+		int bufsize);
+int reply_transs(connection_struct *conn, char *inbuf,char *outbuf,
+		 int size, int bufsize);
+
+/* The following definitions come from smbd/lanman.c  */
+
+int api_reply(connection_struct *conn,
+		uint16 vuid,
+		const char *inbuf,
+		char *outbuf,
+		char *data,
+		char *params,
+		int tdscnt,
+		int tpscnt,
+		int mdrcnt,
+		int mprcnt);
+
+/* The following definitions come from smbd/mangle.c  */
+
+void mangle_reset_cache(void);
+void mangle_change_to_posix(void);
+BOOL mangle_is_mangled(const char *s, const struct share_params *p);
+BOOL mangle_is_8_3(const char *fname, BOOL check_case,
+		   const struct share_params *p);
+BOOL mangle_is_8_3_wildcards(const char *fname, BOOL check_case,
+			     const struct share_params *p);
+BOOL mangle_check_cache(char *s, size_t maxlen,
+			const struct share_params *p);
+void mangle_map(pstring OutName, BOOL need83, BOOL cache83,
+		const struct share_params *p);
+
+/* The following definitions come from smbd/mangle_hash.c  */
+
+struct mangle_fns *mangle_hash_init(void);
+
+/* The following definitions come from smbd/mangle_hash2.c  */
+
+struct mangle_fns *mangle_hash2_init(void);
+struct mangle_fns *posix_mangle_init(void);
+
+/* The following definitions come from smbd/mangle_map.c  */
+
+void mangle_map_filename(fstring fname, const struct share_params *p);
+
+/* The following definitions come from smbd/map_username.c  */
+
+BOOL map_username(fstring user);
+
+/* The following definitions come from smbd/message.c  */
+
+int reply_sends(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_sendstrt(connection_struct *conn, char *inbuf,char  
*outbuf, int dum_size, int dum_buffsize);
+int reply_sendtxt(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_sendend(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+
+/* The following definitions come from smbd/msdfs.c  */
+
+BOOL is_msdfs_link(connection_struct *conn,
+			const char *path,
+			pstring link_target,
+			SMB_STRUCT_STAT *sbufp);
+NTSTATUS get_referred_path(TALLOC_CTX *ctx,
+			const char *dfs_path,
+			struct junction_map *jucn,
+			int *consumedcntp,
+			BOOL *self_referralp);
+int setup_dfs_referral(connection_struct *orig_conn,
+			const char *dfs_path,
+			int max_referral_level,
+			char **ppdata, NTSTATUS *pstatus);
+BOOL create_junction(const char *dfs_path, struct junction_map *jucn);
+BOOL create_msdfs_link(struct junction_map *jucn, BOOL exists);
+BOOL remove_msdfs_link(struct junction_map *jucn);
+int enum_msdfs_links(TALLOC_CTX *ctx, struct junction_map *jucn, int  
jn_max);
+NTSTATUS resolve_dfspath(connection_struct *conn, BOOL  
dfs_pathnames, pstring name);
+NTSTATUS resolve_dfspath_wcard(connection_struct *conn, BOOL  
dfs_pathnames, pstring name, BOOL *ppath_contains_wcard);
+
+/* The following definitions come from smbd/negprot.c  */
+
+int reply_negprot(connection_struct *conn,
+		  char *inbuf,char *outbuf, int dum_size,
+		  int dum_buffsize);
+
+/* The following definitions come from smbd/notify.c  */
+
+void change_notify_reply(const char *request_buf, uint32  
max_param_count,
+			 struct notify_change_buf *notify_buf);
+NTSTATUS change_notify_create(struct files_struct *fsp, uint32 filter,
+			      BOOL recursive);
+NTSTATUS change_notify_add_request(const char *inbuf, uint32  
max_param_count,
+				   uint32 filter, BOOL recursive,
+				   struct files_struct *fsp);
+void remove_pending_change_notify_requests_by_mid(uint16 mid);
+void remove_pending_change_notify_requests_by_fid(files_struct *fsp,
+						  NTSTATUS status);
+void notify_fname(connection_struct *conn, uint32 action, uint32  
filter,
+		  const char *path);
+char *notify_filter_string(TALLOC_CTX *mem_ctx, uint32 filter);
+struct sys_notify_context *sys_notify_context_create 
(connection_struct *conn,
+						     TALLOC_CTX *mem_ctx,
+						     struct event_context *ev);
+NTSTATUS sys_notify_watch(struct sys_notify_context *ctx,
+			  struct notify_entry *e,
+			  void (*callback)(struct sys_notify_context *ctx,
+					   void *private_data,
+					   struct notify_event *ev),
+			  void *private_data, void *handle);
+
+/* The following definitions come from smbd/notify_inotify.c  */
+
+NTSTATUS inotify_watch(struct sys_notify_context *ctx,
+		       struct notify_entry *e,
+		       void (*callback)(struct sys_notify_context *ctx,
+					void *private_data,
+					struct notify_event *ev),
+		       void *private_data,
+		       void *handle_p);
+
+/* The following definitions come from smbd/notify_internal.c  */
+
+struct notify_context *notify_init(TALLOC_CTX *mem_ctx, struct  
server_id server,
+				   struct messaging_context *messaging_ctx,
+				   struct event_context *ev,
+				   connection_struct *conn);
+NTSTATUS notify_add(struct notify_context *notify, struct  
notify_entry *e0,
+		    void (*callback)(void *, const struct notify_event *),
+		    void *private_data);
+NTSTATUS notify_remove(struct notify_context *notify, void  
*private_data);
+void notify_trigger(struct notify_context *notify,
+		    uint32_t action, uint32_t filter, const char *path);
+
+/* The following definitions come from smbd/ntquotas.c  */
+
+int vfs_get_ntquota(files_struct *fsp, enum SMB_QUOTA_TYPE qtype,  
DOM_SID *psid, SMB_NTQUOTA_STRUCT *qt);
+int vfs_set_ntquota(files_struct *fsp, enum SMB_QUOTA_TYPE qtype,  
DOM_SID *psid, SMB_NTQUOTA_STRUCT *qt);
+int vfs_get_user_ntquota_list(files_struct *fsp, SMB_NTQUOTA_LIST  
**qt_list);
+void *init_quota_handle(TALLOC_CTX *mem_ctx);
+void destroy_quota_handle(void **pqt_handle);
+
+/* The following definitions come from smbd/nttrans.c  */
+
+int send_nt_replies(const char *inbuf,
+			char *outbuf,
+			int bufsize,
+			NTSTATUS nt_error,
+			char *params,
+			int paramsize,
+			char *pdata,
+			int datasize);
+BOOL is_ntfs_stream_name(const char *fname);
+int reply_ntcreate_and_X_quota(connection_struct *conn,
+				char *inbuf,
+				char *outbuf,
+				int length,
+				int bufsize,
+				enum FAKE_FILE_TYPE fake_file_type,
+				const char *fname);
+int reply_ntcreate_and_X(connection_struct *conn,
+			 char *inbuf,char *outbuf,int length,int bufsize);
+int reply_ntcancel(connection_struct *conn,
+		   char *inbuf,char *outbuf,int length,int bufsize);
+int reply_ntrename(connection_struct *conn,
+		   char *inbuf,char *outbuf,int length,int bufsize);
+int reply_nttrans(connection_struct *conn,
+			char *inbuf,char *outbuf,int size,int bufsize);
+int reply_nttranss(connection_struct *conn,  char *inbuf,char *outbuf,
+		   int size,int bufsize);
+
+/* The following definitions come from smbd/open.c  */
+
+NTSTATUS fd_close(struct connection_struct *conn, files_struct *fsp);
+BOOL map_open_params_to_ntcreate(const char *fname, int deny_mode,  
int open_func,
+				 uint32 *paccess_mask,
+				 uint32 *pshare_mode,
+				 uint32 *pcreate_disposition,
+				 uint32 *pcreate_options);
+NTSTATUS open_file_ntcreate(connection_struct *conn,
+			    const char *fname,
+			    SMB_STRUCT_STAT *psbuf,
+			    uint32 access_mask,		/* access bits (FILE_READ_DATA etc.) */
+			    uint32 share_access,	/* share constants (FILE_SHARE_READ etc) */
+			    uint32 create_disposition,	/* FILE_OPEN_IF etc. */
+			    uint32 create_options,	/* options such as delete on close. */
+			    uint32 new_dos_attributes,	/* attributes used for new file. */
+			    int oplock_request, 	/* internal Samba oplock codes. */
+				 			/* Information (FILE_EXISTS etc.) */
+			    int *pinfo,
+			    files_struct **result);
+NTSTATUS open_file_fchmod(connection_struct *conn, const char *fname,
+			  SMB_STRUCT_STAT *psbuf, files_struct **result);
+NTSTATUS close_file_fchmod(files_struct *fsp);
+NTSTATUS open_directory(connection_struct *conn,
+			const char *fname,
+			SMB_STRUCT_STAT *psbuf,
+			uint32 access_mask,
+			uint32 share_access,
+			uint32 create_disposition,
+			uint32 create_options,
+			uint32 file_attributes,
+			int *pinfo,
+			files_struct **result);
+NTSTATUS create_directory(connection_struct *conn, const char  
*directory);
+NTSTATUS open_file_stat(connection_struct *conn, const char *fname,
+			SMB_STRUCT_STAT *psbuf, files_struct **result);
+void msg_file_was_renamed(struct messaging_context *msg,
+			  void *private_data,
+			  uint32_t msg_type,
+			  struct server_id server_id,
+			  DATA_BLOB *data);
+
+/* The following definitions come from smbd/oplock.c  */
+
+int32 get_number_of_exclusive_open_oplocks(void);
+BOOL oplock_message_waiting(fd_set *fds);
+void process_kernel_oplocks(struct messaging_context *msg_ctx,  
fd_set *pfds);
+BOOL set_file_oplock(files_struct *fsp, int oplock_type);
+void release_file_oplock(files_struct *fsp);
+BOOL remove_oplock(files_struct *fsp);
+BOOL downgrade_oplock(files_struct *fsp);
+int oplock_notify_fd(void);
+void reply_to_oplock_break_requests(files_struct *fsp);
+void release_level_2_oplocks_on_change(files_struct *fsp);
+void share_mode_entry_to_message(char *msg, struct share_mode_entry  
*e);
+void message_to_share_mode_entry(struct share_mode_entry *e, char  
*msg);
+BOOL init_oplocks(struct messaging_context *msg_ctx);
+
+/* The following definitions come from smbd/oplock_irix.c  */
+
+struct kernel_oplocks *irix_init_kernel_oplocks(void) ;
+
+/* The following definitions come from smbd/oplock_linux.c  */
+
+int linux_set_lease_sighandler(int fd);
+int linux_setlease(int fd, int leasetype);
+struct kernel_oplocks *linux_init_kernel_oplocks(void) ;
+
+/* The following definitions come from smbd/password.c  */
+
+user_struct *get_valid_user_struct(uint16 vuid);
+user_struct *get_partial_auth_user_struct(uint16 vuid);
+void invalidate_vuid(uint16 vuid);
+void invalidate_all_vuids(void);
+int register_vuid(auth_serversupplied_info *server_info,
+		  DATA_BLOB session_key, DATA_BLOB response_blob,
+		  const char *smb_name);
+void add_session_user(const char *user);
+void add_session_workgroup(const char *workgroup);
+const char *get_session_workgroup(void);
+BOOL user_in_netgroup(const char *user, const char *ngname);
+BOOL user_in_list(const char *user,const char **list);
+BOOL authorise_login(int snum, fstring user, DATA_BLOB password,
+		     BOOL *guest);
+
+/* The following definitions come from smbd/pipes.c  */
+
+int reply_open_pipe_and_X(connection_struct *conn,
+			  char *inbuf,char *outbuf,int length,int bufsize);
+int reply_pipe_write(char *inbuf,char *outbuf,int length,int  
dum_bufsize);
+int reply_pipe_write_and_X(char *inbuf,char *outbuf,int length,int  
bufsize);
+int reply_pipe_read_and_X(char *inbuf,char *outbuf,int length,int  
bufsize);
+int reply_pipe_close(connection_struct *conn, char *inbuf,char  
*outbuf);
+
+/* The following definitions come from smbd/posix_acls.c  */
+
+BOOL unpack_nt_owners(int snum, uid_t *puser, gid_t *pgrp, uint32  
security_info_sent, SEC_DESC *psd);
+SMB_ACL_T free_empty_sys_acl(connection_struct *conn, SMB_ACL_T  
the_acl);
+size_t get_nt_acl(files_struct *fsp, uint32 security_info, SEC_DESC  
**ppdesc);
+int try_chown(connection_struct *conn, const char *fname, uid_t uid,  
gid_t gid);
+BOOL set_nt_acl(files_struct *fsp, uint32 security_info_sent,  
SEC_DESC *psd);
+int get_acl_group_bits( connection_struct *conn, const char *fname,  
mode_t *mode );
+int chmod_acl(connection_struct *conn, const char *name, mode_t mode);
+int inherit_access_acl(connection_struct *conn, const char  
*inherit_from_dir,
+		       const char *name, mode_t mode);
+int fchmod_acl(files_struct *fsp, int fd, mode_t mode);
+BOOL directory_has_default_acl(connection_struct *conn, const char  
*fname);
+BOOL set_unix_posix_default_acl(connection_struct *conn, const char  
*fname, SMB_STRUCT_STAT *psbuf,
+				uint16 num_def_acls, const char *pdata);
+BOOL set_unix_posix_acl(connection_struct *conn, files_struct *fsp,  
const char *fname, uint16 num_acls, const char *pdata);
+BOOL can_delete_file_in_directory(connection_struct *conn, const  
char *fname);
+BOOL can_access_file(connection_struct *conn, const char *fname,  
SMB_STRUCT_STAT *psbuf, uint32 access_mask);
+BOOL can_write_to_file(connection_struct *conn, const char *fname,  
SMB_STRUCT_STAT *psbuf);
+SEC_DESC* get_nt_acl_no_snum( TALLOC_CTX *ctx, const char *fname);
+
+/* The following definitions come from smbd/process.c  */
+
+uint16 get_current_mid(void);
+void remove_deferred_open_smb_message(uint16 mid);
+void schedule_deferred_open_smb_message(uint16 mid);
+BOOL open_was_deferred(uint16 mid);
+struct pending_message_list *get_open_deferred_message(uint16 mid);
+BOOL push_deferred_smb_message(uint16 mid,
+			       struct timeval request_time,
+			       struct timeval timeout,
+			       char *private_data, size_t priv_len);
+struct idle_event *event_add_idle(struct event_context *event_ctx,
+				  TALLOC_CTX *mem_ctx,
+				  struct timeval interval,
+				  const char *name,
+				  BOOL (*handler)(const struct timeval *now,
+						  void *private_data),
+				  void *private_data);
+NTSTATUS allow_new_trans(struct trans_state *list, int mid);
+void respond_to_all_remaining_local_messages(void);
+const char *smb_fn_name(int type);
+void add_to_common_flags2(uint32 v);
+void remove_from_common_flags2(uint32 v);
+void construct_reply_common(const char *inbuf, char *outbuf);
+int chain_reply(char *inbuf,char *outbuf,int size,int bufsize);
+void check_reload(time_t t);
+char *get_InBuffer(void);
+char *get_OutBuffer(void);
+void smbd_process(void);
+
+/* The following definitions come from smbd/quotas.c  */
+
+BOOL disk_quotas(const char *path, SMB_BIG_UINT *bsize, SMB_BIG_UINT  
*dfree, SMB_BIG_UINT *dsize);
+BOOL disk_quotas(const char *path, SMB_BIG_UINT *bsize, SMB_BIG_UINT  
*dfree, SMB_BIG_UINT *dsize);
+BOOL disk_quotas(const char *path, SMB_BIG_UINT *bsize, SMB_BIG_UINT  
*dfree, SMB_BIG_UINT *dsize);
+BOOL disk_quotas(const char *path, SMB_BIG_UINT *bsize, SMB_BIG_UINT  
*dfree, SMB_BIG_UINT *dsize);
+BOOL disk_quotas(const char *path, SMB_BIG_UINT *bsize, SMB_BIG_UINT  
*dfree, SMB_BIG_UINT *dsize);
+BOOL disk_quotas(const char *path, SMB_BIG_UINT *bsize, SMB_BIG_UINT  
*dfree, SMB_BIG_UINT *dsize);
+BOOL disk_quotas_vxfs(const pstring name, char *path, SMB_BIG_UINT  
*bsize, SMB_BIG_UINT *dfree, SMB_BIG_UINT *dsize);
+BOOL disk_quotas(const char *path,SMB_BIG_UINT *bsize,SMB_BIG_UINT  
*dfree,SMB_BIG_UINT *dsize);
+BOOL disk_quotas(const char *path,SMB_BIG_UINT *bsize,SMB_BIG_UINT  
*dfree,SMB_BIG_UINT *dsize);
+
+/* The following definitions come from smbd/reply.c  */
+
+NTSTATUS check_path_syntax_internal(pstring destname,
+				    const pstring srcname,
+				    BOOL posix_path,
+				    BOOL *p_last_component_contains_wcard);
+NTSTATUS check_path_syntax(pstring destname, const pstring srcname);
+NTSTATUS check_path_syntax_wcard(pstring destname, const pstring  
srcname, BOOL *p_contains_wcard);
+NTSTATUS check_path_syntax_posix(pstring destname, const pstring  
srcname);
+size_t srvstr_get_path_wcard(char *inbuf, char *dest, const char  
*src, size_t dest_len, size_t src_len, int flags,
+				NTSTATUS *err, BOOL *contains_wcard);
+size_t srvstr_get_path(char *inbuf, char *dest, const char *src,  
size_t dest_len, size_t src_len, int flags, NTSTATUS *err);
+int reply_special(char *inbuf,char *outbuf);
+int reply_tcon(connection_struct *conn,
+	       char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_tcon_and_X(connection_struct *conn, char *inbuf,char  
*outbuf,int length,int bufsize);
+int reply_unknown(char *inbuf,char *outbuf);
+int reply_ioctl(connection_struct *conn,
+		char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_checkpath(connection_struct *conn, char *inbuf,char  
*outbuf, int dum_size, int dum_buffsize);
+int reply_getatr(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_setatr(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_dskattr(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_search(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_fclose(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_open(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_open_and_X(connection_struct *conn, char *inbuf,char  
*outbuf,int length,int bufsize);
+int reply_ulogoffX(connection_struct *conn, char *inbuf,char  
*outbuf,int length,int bufsize);
+int reply_mknew(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_ctemp(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+NTSTATUS unlink_internals(connection_struct *conn, uint32 dirtype,
+			  char *name, BOOL has_wild, BOOL can_defer);
+int reply_unlink(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size,
+		 int dum_buffsize);
+void send_file_readbraw(connection_struct *conn, files_struct *fsp,  
SMB_OFF_T startpos, size_t nread,
+		ssize_t mincount, char *outbuf, int out_buffsize);
+int reply_readbraw(connection_struct *conn, char *inbuf, char  
*outbuf, int dum_size, int out_buffsize);
+int reply_lockread(connection_struct *conn, char *inbuf,char  
*outbuf, int length, int dum_buffsiz);
+int reply_read(connection_struct *conn, char *inbuf,char *outbuf,  
int size, int dum_buffsize);
+int send_file_readX(connection_struct *conn, char *inbuf,char  
*outbuf,int length, int len_outbuf,
+		files_struct *fsp, SMB_OFF_T startpos, size_t smb_maxcnt);
+int reply_read_and_X(connection_struct *conn, char *inbuf,char  
*outbuf,int length,int bufsize);
+int reply_writebraw(connection_struct *conn, char *inbuf,char  
*outbuf, int size, int dum_buffsize);
+int reply_writeunlock(connection_struct *conn, char *inbuf,char  
*outbuf,
+		      int size, int dum_buffsize);
+int reply_write(connection_struct *conn, char *inbuf,char  
*outbuf,int size,int dum_buffsize);
+int reply_write_and_X(connection_struct *conn, char *inbuf,char  
*outbuf,int length,int bufsize);
+int reply_lseek(connection_struct *conn, char *inbuf,char *outbuf,  
int size, int dum_buffsize);
+int reply_flush(connection_struct *conn, char *inbuf,char *outbuf,  
int size, int dum_buffsize);
+int reply_exit(connection_struct *conn,
+	       char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_close(connection_struct *conn, char *inbuf,char *outbuf,  
int size,
+                int dum_buffsize);
+int reply_writeclose(connection_struct *conn,
+		     char *inbuf,char *outbuf, int size, int dum_buffsize);
+int reply_lock(connection_struct *conn,
+	       char *inbuf,char *outbuf, int length, int dum_buffsize);
+int reply_unlock(connection_struct *conn, char *inbuf,char *outbuf,  
int size,
+		 int dum_buffsize);
+int reply_tdis(connection_struct *conn,
+	       char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_echo(connection_struct *conn,
+	       char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_printopen(connection_struct *conn,
+		    char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_printclose(connection_struct *conn,
+		     char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_printqueue(connection_struct *conn,
+		     char *inbuf,char *outbuf, int dum_size, int dum_buffsize);
+int reply_printwrite(connection_struct *conn, char *inbuf,char  
*outbuf, int dum_size, int dum_buffsize);
+int reply_mkdir(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+NTSTATUS rmdir_internals(connection_struct *conn, const char  
*directory);
+int reply_rmdir(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+NTSTATUS rename_internals_fsp(connection_struct *conn, files_struct  
*fsp, pstring newname, uint32 attrs, BOOL replace_if_exists);
+NTSTATUS rename_internals(connection_struct *conn,
+				pstring name,
+				pstring newname,
+				uint32 attrs,
+				BOOL replace_if_exists,
+				BOOL src_has_wild,
+				BOOL dest_has_wild);
+int reply_mv(connection_struct *conn, char *inbuf,char *outbuf, int  
dum_size,
+	     int dum_buffsize);
+NTSTATUS copy_file(connection_struct *conn,
+			char *src,
+			char *dest1,
+			int ofun,
+			int count,
+			BOOL target_is_directory);
+int reply_copy(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_setdir(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+uint32 get_lock_pid( char *data, int data_offset, BOOL  
large_file_format);
+SMB_BIG_UINT get_lock_count( char *data, int data_offset, BOOL  
large_file_format);
+SMB_BIG_UINT get_lock_offset( char *data, int data_offset, BOOL  
large_file_format, BOOL *err);
+int reply_lockingX(connection_struct *conn, char *inbuf, char *outbuf,
+		   int length, int bufsize);
+int reply_readbmpx(connection_struct *conn, char *inbuf,char  
*outbuf,int length,int bufsize);
+int reply_setattrE(connection_struct *conn, char *inbuf,char  
*outbuf, int size, int dum_buffsize);
+int reply_writebmpx(connection_struct *conn, char *inbuf,char  
*outbuf, int size, int dum_buffsize);
+int reply_writebs(connection_struct *conn, char *inbuf,char *outbuf,  
int dum_size, int dum_buffsize);
+int reply_getattrE(connection_struct *conn, char *inbuf,char  
*outbuf, int size, int dum_buffsize);
+
+/* The following definitions come from smbd/seal.c  */
+
+BOOL srv_encryption_on(void);
+void srv_free_enc_buffer(char *buf);
+NTSTATUS srv_decrypt_buffer(char *buf);
+NTSTATUS srv_encrypt_buffer(char *buf, char **buf_out);
+NTSTATUS srv_request_encryption_setup(connection_struct *conn,
+					unsigned char **ppdata,
+					size_t *p_data_size,
+					unsigned char **pparam,
+					size_t *p_param_size);
+NTSTATUS srv_encryption_start(connection_struct *conn);
+void server_encryption_shutdown(void);
+
+/* The following definitions come from smbd/sec_ctx.c  */
+
+BOOL push_sec_ctx(void);
+void set_sec_ctx(uid_t uid, gid_t gid, int ngroups, gid_t *groups,  
NT_USER_TOKEN *token);
+void set_root_sec_ctx(void);
+BOOL pop_sec_ctx(void);
+void init_sec_ctx(void);
+
+/* The following definitions come from smbd/server.c  */
+
+int smbd_server_fd(void);
+struct event_context *smbd_event_context(void);
+struct messaging_context *smbd_messaging_context(void);
+void reload_printers(void);
+BOOL reload_services(BOOL test);
+void exit_server(const char *const explanation);
+void exit_server_cleanly(const char *const explanation);
+void exit_server_fault(void);
+
+/* The following definitions come from smbd/service.c  */
+
+void set_conn_connectpath(connection_struct *conn, const pstring  
connectpath);
+BOOL set_current_service(connection_struct *conn, uint16 flags, BOOL  
do_chdir);
+int add_home_service(const char *service, const char *username,  
const char *homedir);
+void load_registry_shares(void);
+int find_service(fstring service);
+connection_struct *make_connection_with_chdir(const char *service_in,
+					      DATA_BLOB password,
+					      const char *dev, uint16 vuid,
+					      NTSTATUS *status);
+connection_struct *make_connection(const char *service_in, DATA_BLOB  
password,
+				   const char *pdev, uint16 vuid,
+				   NTSTATUS *status);
+void close_cnum(connection_struct *conn, uint16 vuid);
+
+/* The following definitions come from smbd/session.c  */
+
+BOOL session_init(void);
+BOOL session_claim(user_struct *vuser);
+void session_yield(user_struct *vuser);
+int list_sessions(TALLOC_CTX *mem_ctx, struct sessionid  
**session_list);
+
+/* The following definitions come from smbd/sesssetup.c  */
+
+NTSTATUS parse_spnego_mechanisms(DATA_BLOB blob_in, DATA_BLOB  
*pblob_out, BOOL *p_is_krb5);
+int reply_sesssetup_and_X(connection_struct *conn, char *inbuf,char  
*outbuf,
+			  int length,int bufsize);
+
+/* The following definitions come from smbd/share_access.c  */
+
+BOOL token_contains_name_in_list(const char *username,
+				 const char *sharename,
+				 const struct nt_user_token *token,
+				 const char **list);
+BOOL user_ok_token(const char *username, struct nt_user_token  
*token, int snum);
+BOOL is_share_read_only_for_token(const char *username,
+				  struct nt_user_token *token, int snum);
+
+/* The following definitions come from smbd/sockinit.c  */
+
+int smbd_sockinit(const char *cmdline_ports, int listenset[FD_SETSIZE],
+			struct timeval *idle);
+
+/* The following definitions come from smbd/srvstr.c  */
+
+size_t srvstr_push_fn(const char *function, unsigned int line,
+		      const char *base_ptr, void *dest,
+		      const char *src, int dest_len, int flags);
+
+/* The following definitions come from smbd/statcache.c  */
+
+void stat_cache_add( const char *full_orig_name, const char  
*orig_translated_path, BOOL case_sensitive);
+BOOL stat_cache_lookup(connection_struct *conn, pstring name,  
pstring dirpath,
+		       char **start, SMB_STRUCT_STAT *pst);
+void send_stat_cache_delete_message(const char *name);
+void stat_cache_delete(const char *name);
+unsigned int fast_string_hash(TDB_DATA *key);
+BOOL reset_stat_cache( void );
+
+/* The following definitions come from smbd/statvfs.c  */
+
+int sys_statvfs(const char *path, vfs_statvfs_struct *statbuf);
+
+/* The following definitions come from smbd/trans2.c  */
+
+SMB_BIG_UINT smb_roundup(connection_struct *conn, SMB_BIG_UINT val);
+SMB_BIG_UINT get_allocation_size(connection_struct *conn,  
files_struct *fsp, const SMB_STRUCT_STAT *sbuf);
+NTSTATUS set_ea(connection_struct *conn, files_struct *fsp, const  
char *fname, struct ea_list *ea_list);
+struct ea_list *read_ea_list_entry(TALLOC_CTX *ctx, const char  
*pdata, size_t data_size, size_t *pbytes_used);
+int send_trans2_replies(const char *inbuf,
+			char *outbuf,
+			int bufsize,
+			const char *params,
+			int paramsize,
+			const char *pdata,
+			int datasize,
+			int max_data_bytes);
+unsigned char *create_volume_objectid(connection_struct *conn,  
unsigned char objid[16]);
+NTSTATUS hardlink_internals(connection_struct *conn, pstring  
oldname, pstring newname);
+int reply_findclose(connection_struct *conn,
+		    char *inbuf,char *outbuf,int length,int bufsize);
+int reply_findnclose(connection_struct *conn,
+		     char *inbuf,char *outbuf,int length,int bufsize);
+int handle_trans2(connection_struct *conn,
+		  struct trans_state *state,
+		  char *inbuf, char *outbuf, int size, int bufsize);
+int reply_trans2(connection_struct *conn, char *inbuf,char *outbuf,
+		 int size, int bufsize);
+int reply_transs2(connection_struct *conn,
+		  char *inbuf,char *outbuf,int size,int bufsize);
+
+/* The following definitions come from smbd/uid.c  */
+
+gid_t get_current_user_gid_first(int *piterator);
+gid_t get_current_user_gid_next(int *piterator);
+BOOL change_to_guest(void);
+BOOL change_to_user(connection_struct *conn, uint16 vuid);
+BOOL change_to_root_user(void);
+BOOL become_authenticated_pipe_user(pipes_struct *p);
+BOOL unbecome_authenticated_pipe_user(void);
+void become_root(void);
+void unbecome_root(void);
+BOOL become_user(connection_struct *conn, uint16 vuid);
+BOOL unbecome_user(void);
+
+/* The following definitions come from smbd/utmp.c  */
+
+void sys_utmp_claim(const char *username, const char *hostname,
+		    struct in_addr *ipaddr,
+		    const char *id_str, int id_num);
+void sys_utmp_yield(const char *username, const char *hostname,
+		    struct in_addr *ipaddr,
+		    const char *id_str, int id_num);
+void sys_utmp_yield(const char *username, const char *hostname,
+		    struct in_addr *ipaddr,
+		    const char *id_str, int id_num);
+void sys_utmp_claim(const char *username, const char *hostname,
+		    struct in_addr *ipaddr,
+		    const char *id_str, int id_num);
+
+/* The following definitions come from smbd/vfs.c  */
+
+NTSTATUS smb_register_vfs(int version, const char *name,  
vfs_op_tuple *vfs_op_tuples);
+BOOL vfs_init_custom(connection_struct *conn, const char *vfs_object);
+void *vfs_add_fsp_extension_notype(vfs_handle_struct *handle,  
files_struct *fsp, size_t ext_size);
+void vfs_remove_fsp_extension(vfs_handle_struct *handle,  
files_struct *fsp);
+void *vfs_fetch_fsp_extension(vfs_handle_struct *handle,  
files_struct *fsp);
+BOOL smbd_vfs_init(connection_struct *conn);
+BOOL vfs_directory_exist(connection_struct *conn, const char *dname,  
SMB_STRUCT_STAT *st);
+BOOL vfs_object_exist(connection_struct *conn,const char  
*fname,SMB_STRUCT_STAT *sbuf);
+BOOL vfs_file_exist(connection_struct *conn, const char  
*fname,SMB_STRUCT_STAT *sbuf);
+ssize_t vfs_read_data(files_struct *fsp, char *buf, size_t byte_count);
+ssize_t vfs_pread_data(files_struct *fsp, char *buf,
+                size_t byte_count, SMB_OFF_T offset);
+ssize_t vfs_write_data(files_struct *fsp,const char *buffer,size_t N);
+ssize_t vfs_pwrite_data(files_struct *fsp,const char *buffer,
+                size_t N, SMB_OFF_T offset);
+int vfs_allocate_file_space(files_struct *fsp, SMB_BIG_UINT len);
+int vfs_set_filelen(files_struct *fsp, SMB_OFF_T len);
+int vfs_fill_sparse(files_struct *fsp, SMB_OFF_T len);
+SMB_OFF_T vfs_transfer_file(files_struct *in, files_struct *out,  
SMB_OFF_T n);
+char *vfs_readdirname(connection_struct *conn, void *p);
+int vfs_ChDir(connection_struct *conn, const char *path);
+char *vfs_GetWd(connection_struct *conn, char *path);
+NTSTATUS reduce_name(connection_struct *conn, const pstring fname);
+
+/* The following definitions come from torture/denytest.c  */
+
+BOOL torture_denytest1(int dummy);
+BOOL torture_denytest2(int dummy);
+
+/* The following definitions come from torture/mangle_test.c  */
+
+BOOL torture_mangle(int dummy);
+
+/* The following definitions come from torture/nbio.c  */
+
+double nbio_total(void);
+void nb_alarm(int ignore);
+void nbio_shmem(int n);
+void nb_setup(struct cli_state *cli);
+void nb_unlink(const char *fname);
+void nb_createx(const char *fname,
+		unsigned create_options, unsigned create_disposition, int handle);
+void nb_writex(int handle, int offset, int size, int ret_size);
+void nb_readx(int handle, int offset, int size, int ret_size);
+void nb_close(int handle);
+void nb_rmdir(const char *fname);
+void nb_rename(const char *oldname, const char *newname);
+void nb_qpathinfo(const char *fname);
+void nb_qfileinfo(int fnum);
+void nb_qfsinfo(int level);
+void nb_findfirst(const char *mask);
+void nb_flush(int fnum);
+void nb_deltree(const char *dname);
+void nb_cleanup(void);
+
+/* The following definitions come from torture/scanner.c  */
+
+BOOL torture_trans2_scan(int dummy);
+BOOL torture_nttrans_scan(int dummy);
+
+/* The following definitions come from torture/torture.c  */
+
+void start_timer(void);
+double end_timer(void);
+void *shm_setup(int size);
+BOOL smbcli_parse_unc(const char *unc_name, TALLOC_CTX *mem_ctx,
+		      char **hostname, char **sharename);
+void torture_open_connection_free_unclist(char **unc_list);
+BOOL torture_open_connection(struct cli_state **c, int conn_index);
+BOOL torture_cli_session_setup2(struct cli_state *cli, uint16  
*new_vuid);
+BOOL torture_close_connection(struct cli_state *c);
+BOOL torture_ioctl_test(int dummy);
+BOOL torture_chkpath_test(int dummy);
+
+/* The following definitions come from torture/utable.c  */
+
+BOOL torture_utable(int dummy);
+BOOL torture_casetable(int dummy);
+
+/* The following definitions come from utils/passwd_util.c  */
+
+char *stdin_new_passwd( void);
+char *get_pass( const char *prompt, BOOL stdin_get);
+
+#endif /*  _PROTO_H_  */
diff --git a/source/nsswitch/winbindd_proto.h b/source/nsswitch/ 
winbindd_proto.h
new file mode 100644
index 0000000..708f323
--- /dev/null
+++ b/source/nsswitch/winbindd_proto.h
@@ -0,0 +1,516 @@
+#ifndef _WINBINDD_PROTO_H_
+#define _WINBINDD_PROTO_H_
+
+/* This file is automatically generated with "make proto". DO NOT  
EDIT */
+
+
+/* The following definitions come from auth/token_util.c  */
+
+NT_USER_TOKEN *dup_nt_token(TALLOC_CTX *mem_ctx, const NT_USER_TOKEN  
*ptoken);
+BOOL nt_token_check_sid ( const DOM_SID *sid, const NT_USER_TOKEN  
*token );
+BOOL nt_token_check_domain_rid( NT_USER_TOKEN *token, uint32 rid ) ;
+NT_USER_TOKEN *get_root_nt_token( void );
+NTSTATUS add_aliases(const DOM_SID *domain_sid,
+		     struct nt_user_token *token);
+struct nt_user_token *create_local_nt_token(TALLOC_CTX *mem_ctx,
+					    const DOM_SID *user_sid,
+					    BOOL is_guest,
+					    int num_groupsids,
+					    const DOM_SID *groupsids);
+void debug_nt_user_token(int dbg_class, int dbg_lev, NT_USER_TOKEN  
*token);
+void debug_unix_user_token(int dbg_class, int dbg_lev, uid_t uid,  
gid_t gid,
+			   int n_groups, gid_t *groups);
+
+/* The following definitions come from nsswitch/winbindd.c  */
+
+struct event_context *winbind_event_context(void);
+struct messaging_context *winbind_messaging_context(void);
+void add_fd_event(struct fd_event *ev);
+void remove_fd_event(struct fd_event *ev);
+void setup_async_read(struct fd_event *event, void *data, size_t  
length,
+		      void (*finished)(void *private_data, BOOL success),
+		      void *private_data);
+void setup_async_write(struct fd_event *event, void *data, size_t  
length,
+		       void (*finished)(void *private_data, BOOL success),
+		       void *private_data);
+void request_error(struct winbindd_cli_state *state);
+void request_ok(struct winbindd_cli_state *state);
+void request_finished_cont(void *private_data, BOOL success);
+int main(int argc, char **argv, char **envp);
+
+/* The following definitions come from nsswitch/winbindd_ads.c  */
+
+
+/* The following definitions come from nsswitch/winbindd_async.c  */
+
+void do_async_domain(TALLOC_CTX *mem_ctx, struct winbindd_domain  
*domain,
+		     const struct winbindd_request *request,
+		     void (*cont)(TALLOC_CTX *mem_ctx, BOOL success,
+				  struct winbindd_response *response,
+				  void *c, void *private_data),
+		     void *c, void *private_data);
+void winbindd_set_mapping_async(TALLOC_CTX *mem_ctx, const struct  
id_map *map,
+			     void (*cont)(void *private_data, BOOL success),
+			     void *private_data);
+enum winbindd_result winbindd_dual_set_mapping(struct  
winbindd_domain *domain,
+					    struct winbindd_cli_state *state);
+void winbindd_set_hwm_async(TALLOC_CTX *mem_ctx, const struct unixid  
*xid,
+			     void (*cont)(void *private_data, BOOL success),
+			     void *private_data);
+enum winbindd_result winbindd_dual_set_hwm(struct winbindd_domain  
*domain,
+					    struct winbindd_cli_state *state);
+void winbindd_sids2xids_async(TALLOC_CTX *mem_ctx, void *sids, int  
size,
+			 void (*cont)(void *private_data, BOOL success, void *data, int  
len),
+			 void *private_data);
+enum winbindd_result winbindd_dual_sids2xids(struct winbindd_domain  
*domain,
+					   struct winbindd_cli_state *state);
+void winbindd_sid2uid_async(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+			 void (*cont)(void *private_data, BOOL success, uid_t uid),
+			 void *private_data);
+enum winbindd_result winbindd_dual_sid2uid(struct winbindd_domain  
*domain,
+					   struct winbindd_cli_state *state);
+void winbindd_uid2name_async(TALLOC_CTX *mem_ctx, uid_t uid,
+			     void (*cont)(void *private_data, BOOL success,
+					  const char *name),
+			     void *private_data);
+enum winbindd_result winbindd_dual_uid2name(struct winbindd_domain  
*domain,
+					    struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_name2uid(struct winbindd_domain  
*domain,
+					    struct winbindd_cli_state *state);
+void winbindd_sid2gid_async(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+			 void (*cont)(void *private_data, BOOL success, gid_t gid),
+			 void *private_data);
+enum winbindd_result winbindd_dual_sid2gid(struct winbindd_domain  
*domain,
+					   struct winbindd_cli_state *state);
+void winbindd_gid2name_async(TALLOC_CTX *mem_ctx, gid_t gid,
+			     void (*cont)(void *private_data, BOOL success,
+					  const char *name),
+			     void *private_data);
+enum winbindd_result winbindd_dual_gid2name(struct winbindd_domain  
*domain,
+					    struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_name2gid(struct winbindd_domain  
*domain,
+					    struct winbindd_cli_state *state);
+void winbindd_lookupsid_async(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+			      void (*cont)(void *private_data, BOOL success,
+					   const char *dom_name,
+					   const char *name,
+					   enum lsa_SidType type),
+			      void *private_data);
+enum winbindd_result winbindd_dual_lookupsid(struct winbindd_domain  
*domain,
+					     struct winbindd_cli_state *state);
+void winbindd_lookupname_async(TALLOC_CTX *mem_ctx,
+			       const char *dom_name, const char *name,
+			       void (*cont)(void *private_data, BOOL success,
+					    const DOM_SID *sid,
+					    enum lsa_SidType type),
+			       enum winbindd_cmd orig_cmd,
+			       void *private_data);
+enum winbindd_result winbindd_dual_lookupname(struct winbindd_domain  
*domain,
+					      struct winbindd_cli_state *state);
+BOOL print_sidlist(TALLOC_CTX *mem_ctx, const DOM_SID *sids,
+		   size_t num_sids, char **result, ssize_t *len);
+enum winbindd_result winbindd_dual_lookuprids(struct winbindd_domain  
*domain,
+					      struct winbindd_cli_state *state);
+void winbindd_getsidaliases_async(struct winbindd_domain *domain,
+				  TALLOC_CTX *mem_ctx,
+				  const DOM_SID *sids, size_t num_sids,
+			 	  void (*cont)(void *private_data,
+				 	       BOOL success,
+					       const DOM_SID *aliases,
+					       size_t num_aliases),
+				  void *private_data);
+enum winbindd_result winbindd_dual_getsidaliases(struct  
winbindd_domain *domain,
+						 struct winbindd_cli_state *state);
+void winbindd_gettoken_async(TALLOC_CTX *mem_ctx, const DOM_SID  
*user_sid,
+			     void (*cont)(void *private_data, BOOL success,
+					  DOM_SID *sids, size_t num_sids),
+			     void *private_data);
+void query_user_async(TALLOC_CTX *mem_ctx, struct winbindd_domain  
*domain,
+		      const DOM_SID *sid,
+		      void (*cont)(void *private_data, BOOL success,
+				   const char *acct_name,
+				   const char *full_name,
+				   const char *homedir,
+				   const char *shell,
+				   gid_t gid,
+				   uint32 group_rid),
+		      void *private_data);
+void winbindd_uid2sid_async(TALLOC_CTX *mem_ctx, uid_t uid,
+			    void (*cont)(void *private_data, BOOL success, const char *sid),
+			    void *private_data);
+enum winbindd_result winbindd_dual_uid2sid(struct winbindd_domain  
*domain,
+					   struct winbindd_cli_state *state);
+void winbindd_gid2sid_async(TALLOC_CTX *mem_ctx, gid_t gid,
+			    void (*cont)(void *private_data, BOOL success, const char *sid),
+			    void *private_data);
+enum winbindd_result winbindd_dual_gid2sid(struct winbindd_domain  
*domain,
+					   struct winbindd_cli_state *state);
+void winbindd_dump_maps_async(TALLOC_CTX *mem_ctx, void *data, int  
size,
+			 void (*cont)(void *private_data, BOOL success),
+			 void *private_data);
+enum winbindd_result winbindd_dual_dump_maps(struct winbindd_domain  
*domain,
+					   struct winbindd_cli_state *state);
+
+/* The following definitions come from nsswitch/winbindd_cache.c  */
+
+void winbindd_check_cache_size(time_t t);
+struct cache_entry *centry_start(struct winbindd_domain *domain,  
NTSTATUS status);
+NTSTATUS wcache_cached_creds_exist(struct winbindd_domain *domain,  
const DOM_SID *sid);
+NTSTATUS wcache_get_creds(struct winbindd_domain *domain,
+			  TALLOC_CTX *mem_ctx,
+			  const DOM_SID *sid,
+			  const uint8 **cached_nt_pass,
+			  const uint8 **cached_salt);
+NTSTATUS wcache_save_creds(struct winbindd_domain *domain,
+			   TALLOC_CTX *mem_ctx,
+			   const DOM_SID *sid,
+			   const uint8 nt_pass[NT_HASH_LEN]);
+void wcache_invalidate_samlogon(struct winbindd_domain *domain,
+				NET_USER_INFO_3 *info3);
+void wcache_invalidate_cache(void);
+BOOL init_wcache(void);
+BOOL initialize_winbindd_cache(void);
+void cache_store_response(pid_t pid, struct winbindd_response  
*response);
+BOOL cache_retrieve_response(pid_t pid, struct winbindd_response *  
response);
+void cache_cleanup_response(pid_t pid);
+BOOL lookup_cached_sid(TALLOC_CTX *mem_ctx, const DOM_SID *sid,
+		       char **domain_name, char **name,
+		       enum lsa_SidType *type);
+BOOL lookup_cached_name(TALLOC_CTX *mem_ctx,
+			const char *domain_name,
+			const char *name,
+			DOM_SID *sid,
+			enum lsa_SidType *type);
+void cache_name2sid(struct winbindd_domain *domain,
+		    const char *domain_name, const char *name,
+		    enum lsa_SidType type, const DOM_SID *sid);
+void wcache_flush_cache(void);
+NTSTATUS wcache_count_cached_creds(struct winbindd_domain *domain,  
int *count);
+NTSTATUS wcache_remove_oldest_cached_creds(struct winbindd_domain  
*domain, const DOM_SID *sid) ;
+BOOL set_global_winbindd_state_offline(void);
+void set_global_winbindd_state_online(void);
+BOOL get_global_winbindd_state_offline(void);
+int winbindd_validate_cache(void);
+BOOL wcache_tdc_fetch_list( struct winbindd_tdc_domain **domains,  
size_t *num_domains );
+BOOL wcache_tdc_add_domain( struct winbindd_domain *domain );
+struct winbindd_tdc_domain * wcache_tdc_fetch_domain( TALLOC_CTX  
*ctx, const char *name );
+void wcache_tdc_clear( void );
+NTSTATUS nss_get_info_cached( struct winbindd_domain *domain,
+			      const DOM_SID *user_sid,
+			      TALLOC_CTX *ctx,
+			      ADS_STRUCT *ads, LDAPMessage *msg,
+			      char **homedir, char **shell, char **gecos,
+			      gid_t *p_gid);
+
+/* The following definitions come from nsswitch/ 
winbindd_ccache_access.c  */
+
+void winbindd_ccache_ntlm_auth(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_ccache_ntlm_auth(struct  
winbindd_domain *domain,
+						struct winbindd_cli_state *state);
+
+/* The following definitions come from nsswitch/winbindd_cm.c  */
+
+void set_domain_offline(struct winbindd_domain *domain);
+void set_domain_online_request(struct winbindd_domain *domain);
+void winbind_add_failed_connection_entry(const struct  
winbindd_domain *domain,
+					const char *server,
+					NTSTATUS result);
+void invalidate_cm_connection(struct winbindd_cm_conn *conn);
+void close_conns_after_fork(void);
+NTSTATUS init_dc_connection(struct winbindd_domain *domain);
+NTSTATUS cm_connect_sam(struct winbindd_domain *domain, TALLOC_CTX  
*mem_ctx,
+			struct rpc_pipe_client **cli, POLICY_HND *sam_handle);
+NTSTATUS cm_connect_lsa(struct winbindd_domain *domain, TALLOC_CTX  
*mem_ctx,
+			struct rpc_pipe_client **cli, POLICY_HND *lsa_policy);
+NTSTATUS cm_connect_netlogon(struct winbindd_domain *domain,
+			     struct rpc_pipe_client **cli);
+
+/* The following definitions come from nsswitch/ 
winbindd_cred_cache.c  */
+
+BOOL ccache_entry_exists(const char *username);
+BOOL ccache_entry_identical(const char *username, uid_t uid, const  
char *ccname);
+NTSTATUS add_ccache_to_list(const char *princ_name,
+			    const char *ccname,
+			    const char *service,
+			    const char *username,
+			    const char *realm,
+			    uid_t uid,
+			    time_t create_time,
+			    time_t ticket_end,
+			    time_t renew_until,
+			    BOOL postponed_request);
+NTSTATUS remove_ccache(const char *username);
+struct WINBINDD_MEMORY_CREDS *find_memory_creds_by_name(const char  
*username);
+NTSTATUS winbindd_add_memory_creds(const char *username, uid_t uid,  
const char *pass);
+NTSTATUS winbindd_delete_memory_creds(const char *username);
+NTSTATUS winbindd_replace_memory_creds(const char *username, const  
char *pass);
+
+/* The following definitions come from nsswitch/winbindd_creds.c  */
+
+NTSTATUS winbindd_get_creds(struct winbindd_domain *domain,
+			    TALLOC_CTX *mem_ctx,
+			    const DOM_SID *sid,
+			    NET_USER_INFO_3 **info3,
+			    const uint8 *cached_nt_pass[NT_HASH_LEN],
+			    const uint8 *cred_salt[NT_HASH_LEN]);
+NTSTATUS winbindd_store_creds(struct winbindd_domain *domain,
+			      TALLOC_CTX *mem_ctx,
+			      const char *user,
+			      const char *pass,
+			      NET_USER_INFO_3 *info3,
+			      const DOM_SID *user_sid);
+NTSTATUS winbindd_update_creds_by_info3(struct winbindd_domain *domain,
+				        TALLOC_CTX *mem_ctx,
+				        const char *user,
+				        const char *pass,
+				        NET_USER_INFO_3 *info3);
+NTSTATUS winbindd_update_creds_by_sid(struct winbindd_domain *domain,
+				      TALLOC_CTX *mem_ctx,
+				      const DOM_SID *sid,
+				      const char *pass);
+NTSTATUS winbindd_update_creds_by_name(struct winbindd_domain *domain,
+				       TALLOC_CTX *mem_ctx,
+				       const char *user,
+				       const char *pass);
+
+/* The following definitions come from nsswitch/winbindd_dual.c  */
+
+void async_request(TALLOC_CTX *mem_ctx, struct winbindd_child *child,
+		   struct winbindd_request *request,
+		   struct winbindd_response *response,
+		   void (*continuation)(void *private_data, BOOL success),
+		   void *private_data);
+void async_domain_request(TALLOC_CTX *mem_ctx,
+			  struct winbindd_domain *domain,
+			  struct winbindd_request *request,
+			  struct winbindd_response *response,
+			  void (*continuation)(void *private_data_data, BOOL success),
+			  void *private_data_data);
+void sendto_child(struct winbindd_cli_state *state,
+		  struct winbindd_child *child);
+void sendto_domain(struct winbindd_cli_state *state,
+		   struct winbindd_domain *domain);
+void setup_domain_child(struct winbindd_domain *domain,
+			struct winbindd_child *child,
+			const char *explicit_logfile);
+void winbind_child_died(pid_t pid);
+void winbindd_flush_negative_conn_cache(struct winbindd_domain  
*domain);
+void winbind_msg_offline(struct messaging_context *msg_ctx,
+			 void *private_data,
+			 uint32_t msg_type,
+			 struct server_id server_id,
+			 DATA_BLOB *data);
+void winbind_msg_online(struct messaging_context *msg_ctx,
+			void *private_data,
+			uint32_t msg_type,
+			struct server_id server_id,
+			DATA_BLOB *data);
+void winbind_msg_onlinestatus(struct messaging_context *msg_ctx,
+			      void *private_data,
+			      uint32_t msg_type,
+			      struct server_id server_id,
+			      DATA_BLOB *data);
+
+/* The following definitions come from nsswitch/winbindd_group.c  */
+
+void winbindd_getgrnam(struct winbindd_cli_state *state);
+void winbindd_getgrgid(struct winbindd_cli_state *state);
+void winbindd_setgrent(struct winbindd_cli_state *state);
+void winbindd_endgrent(struct winbindd_cli_state *state);
+void winbindd_getgrent(struct winbindd_cli_state *state);
+void winbindd_list_groups(struct winbindd_cli_state *state);
+void winbindd_getgroups(struct winbindd_cli_state *state);
+void winbindd_getusersids(struct winbindd_cli_state *state);
+void winbindd_getuserdomgroups(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_getuserdomgroups(struct  
winbindd_domain *domain,
+						    struct winbindd_cli_state *state);
+
+/* The following definitions come from nsswitch/winbindd_misc.c  */
+
+void winbindd_check_machine_acct(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_check_machine_acct(struct  
winbindd_domain *domain,
+						      struct winbindd_cli_state *state);
+void winbindd_list_trusted_domains(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_list_trusted_domains(struct  
winbindd_domain *domain,
+							struct winbindd_cli_state *state);
+void winbindd_getdcname(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_getdcname(struct winbindd_domain  
*domain,
+					     struct winbindd_cli_state *state);
+void winbindd_show_sequence(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_show_sequence(struct  
winbindd_domain *domain,
+						 struct winbindd_cli_state *state);
+void winbindd_domain_info(struct winbindd_cli_state *state);
+void winbindd_ping(struct winbindd_cli_state *state);
+void winbindd_info(struct winbindd_cli_state *state);
+void winbindd_interface_version(struct winbindd_cli_state *state);
+void winbindd_domain_name(struct winbindd_cli_state *state);
+void winbindd_netbios_name(struct winbindd_cli_state *state);
+void winbindd_priv_pipe_dir(struct winbindd_cli_state *state);
+
+/* The following definitions come from nsswitch/winbindd_pam.c  */
+
+struct winbindd_domain *find_auth_domain(struct winbindd_cli_state  
*state,
+					const char *domain_name);
+void winbindd_pam_auth(struct winbindd_cli_state *state);
+NTSTATUS winbindd_dual_pam_auth_cached(struct winbindd_domain *domain,
+				       struct winbindd_cli_state *state,
+				       NET_USER_INFO_3 **info3);
+NTSTATUS winbindd_dual_pam_auth_kerberos(struct winbindd_domain  
*domain,
+					 struct winbindd_cli_state *state,
+					 NET_USER_INFO_3 **info3);
+NTSTATUS winbindd_dual_pam_auth_samlogon(struct winbindd_domain  
*domain,
+					 struct winbindd_cli_state *state,
+					 NET_USER_INFO_3 **info3);
+enum winbindd_result winbindd_dual_pam_auth(struct winbindd_domain  
*domain,
+					    struct winbindd_cli_state *state) ;
+void winbindd_pam_auth_crap(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_pam_auth_crap(struct  
winbindd_domain *domain,
+						 struct winbindd_cli_state *state) ;
+void winbindd_pam_chauthtok(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_pam_chauthtok(struct  
winbindd_domain *contact_domain,
+						 struct winbindd_cli_state *state);
+void winbindd_pam_logoff(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_pam_logoff(struct winbindd_domain  
*domain,
+					      struct winbindd_cli_state *state) ;
+void winbindd_pam_chng_pswd_auth_crap(struct winbindd_cli_state  
*state);
+enum winbindd_result winbindd_dual_pam_chng_pswd_auth_crap(struct  
winbindd_domain *domainSt, struct winbindd_cli_state *state);
+
+/* The following definitions come from nsswitch/winbindd_passdb.c  */
+
+
+/* The following definitions come from nsswitch/ 
winbindd_reconnect.c  */
+
+
+/* The following definitions come from nsswitch/winbindd_rpc.c  */
+
+NTSTATUS msrpc_name_to_sid(struct winbindd_domain *domain,
+			   TALLOC_CTX *mem_ctx,
+			   enum winbindd_cmd original_cmd,
+			   const char *domain_name,
+			   const char *name,
+			   DOM_SID *sid,
+			   enum lsa_SidType *type);
+NTSTATUS msrpc_sid_to_name(struct winbindd_domain *domain,
+			    TALLOC_CTX *mem_ctx,
+			    const DOM_SID *sid,
+			    char **domain_name,
+			    char **name,
+			    enum lsa_SidType *type);
+NTSTATUS msrpc_rids_to_names(struct winbindd_domain *domain,
+			     TALLOC_CTX *mem_ctx,
+			     const DOM_SID *sid,
+			     uint32 *rids,
+			     size_t num_rids,
+			     char **domain_name,
+			     char ***names,
+			     enum lsa_SidType **types);
+NTSTATUS msrpc_lookup_useraliases(struct winbindd_domain *domain,
+				  TALLOC_CTX *mem_ctx,
+				  uint32 num_sids, const DOM_SID *sids,
+				  uint32 *num_aliases, uint32 **alias_rids);
+NTSTATUS msrpc_lockout_policy(struct winbindd_domain *domain,
+			      TALLOC_CTX *mem_ctx,
+			      SAM_UNK_INFO_12 *lockout_policy);
+NTSTATUS msrpc_password_policy(struct winbindd_domain *domain,
+			       TALLOC_CTX *mem_ctx,
+			       SAM_UNK_INFO_1 *password_policy);
+
+/* The following definitions come from nsswitch/winbindd_sid.c  */
+
+void winbindd_lookupsid(struct winbindd_cli_state *state);
+void winbindd_lookupname(struct winbindd_cli_state *state);
+void winbindd_lookuprids(struct winbindd_cli_state *state);
+void init_idmap_child(void);
+struct winbindd_child *idmap_child(void);
+void winbindd_sid_to_uid(struct winbindd_cli_state *state);
+void winbindd_sid_to_gid(struct winbindd_cli_state *state);
+void winbindd_sids_to_unixids(struct winbindd_cli_state *state);
+void winbindd_set_mapping(struct winbindd_cli_state *state);
+void winbindd_set_hwm(struct winbindd_cli_state *state);
+void winbindd_uid_to_sid(struct winbindd_cli_state *state);
+void winbindd_gid_to_sid(struct winbindd_cli_state *state);
+void winbindd_allocate_uid(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_allocate_uid(struct  
winbindd_domain *domain,
+						struct winbindd_cli_state *state);
+void winbindd_allocate_gid(struct winbindd_cli_state *state);
+enum winbindd_result winbindd_dual_allocate_gid(struct  
winbindd_domain *domain,
+						struct winbindd_cli_state *state);
+void winbindd_dump_maps(struct winbindd_cli_state *state);
+
+/* The following definitions come from nsswitch/winbindd_sockinit.c  */
+
+BOOL winbindd_init_sockets(int *public_sock, int *priv_sock,
+				int *idle_timeout_sec);
+void winbindd_release_sockets(void);
+
+/* The following definitions come from nsswitch/winbindd_user.c  */
+
+enum winbindd_result winbindd_dual_userinfo(struct winbindd_domain  
*domain,
+					    struct winbindd_cli_state *state);
+void winbindd_getpwnam(struct winbindd_cli_state *state);
+void winbindd_getpwuid(struct winbindd_cli_state *state);
+void winbindd_setpwent(struct winbindd_cli_state *state);
+void winbindd_endpwent(struct winbindd_cli_state *state);
+void winbindd_getpwent(struct winbindd_cli_state *state);
+void winbindd_list_users(struct winbindd_cli_state *state);
+
+/* The following definitions come from nsswitch/winbindd_util.c  */
+
+struct winbindd_domain *domain_list(void);
+void free_domain_list(void);
+void rescan_trusted_domains( void );
+enum winbindd_result init_child_connection(struct winbindd_domain  
*domain,
+					   void (*continuation)(void *private_data,
+								BOOL success),
+					   void *private_data);
+enum winbindd_result winbindd_dual_init_connection(struct  
winbindd_domain *domain,
+						   struct winbindd_cli_state *state);
+BOOL init_domain_list(void);
+void check_domain_trusted( const char *name, const DOM_SID *user_sid );
+struct winbindd_domain *find_domain_from_name_noinit(const char  
*domain_name);
+struct winbindd_domain *find_domain_from_name(const char *domain_name);
+struct winbindd_domain *find_domain_from_sid_noinit(const DOM_SID  
*sid);
+struct winbindd_domain *find_domain_from_sid(const DOM_SID *sid);
+struct winbindd_domain *find_our_domain(void);
+struct winbindd_domain *find_root_domain(void);
+struct winbindd_domain *find_builtin_domain(void);
+struct winbindd_domain *find_lookup_domain_from_sid(const DOM_SID  
*sid);
+struct winbindd_domain *find_lookup_domain_from_name(const char  
*domain_name);
+BOOL winbindd_lookup_sid_by_name(TALLOC_CTX *mem_ctx,
+				 enum winbindd_cmd orig_cmd,
+				 struct winbindd_domain *domain,
+				 const char *domain_name,
+				 const char *name, DOM_SID *sid,
+				 enum lsa_SidType *type);
+BOOL winbindd_lookup_name_by_sid(TALLOC_CTX *mem_ctx,
+				 struct winbindd_domain *domain,
+				 DOM_SID *sid,
+				 char **dom_name,
+				 char **name,
+				 enum lsa_SidType *type);
+void free_getent_state(struct getent_state *state);
+BOOL parse_domain_user(const char *domuser, fstring domain, fstring  
user);
+BOOL parse_domain_user_talloc(TALLOC_CTX *mem_ctx, const char *domuser,
+			      char **domain, char **user);
+BOOL canonicalize_username(fstring username_inout, fstring domain,  
fstring user);
+void fill_domain_username(fstring name, const char *domain, const  
char *user, BOOL can_assume);
+char *get_winbind_priv_pipe_dir(void) ;
+struct winbindd_cli_state *winbindd_client_list(void);
+void winbindd_add_client(struct winbindd_cli_state *cli);
+void winbindd_remove_client(struct winbindd_cli_state *cli);
+void winbindd_kill_all_clients(void);
+int winbindd_num_clients(void);
+NTSTATUS lookup_usergroups_cached(struct winbindd_domain *domain,
+				  TALLOC_CTX *mem_ctx,
+				  const DOM_SID *user_sid,
+				  uint32 *p_num_groups, DOM_SID **user_sids);
+void ws_name_replace( char *name, char replace );
+void ws_name_return( char *name, char replace );
+BOOL winbindd_can_contact_domain( struct winbindd_domain *domain );
+
+/* The following definitions come from nsswitch/winbindd_wins.c  */
+
+void winbindd_wins_byip(struct winbindd_cli_state *state);
+void winbindd_wins_byname(struct winbindd_cli_state *state);
+
+#endif /*  _WINBINDD_PROTO_H_  */
diff --git a/source/utils/net_proto.h b/source/utils/net_proto.h
new file mode 100644
index 0000000..05c31e6
--- /dev/null
+++ b/source/utils/net_proto.h
@@ -0,0 +1,382 @@
+#ifndef _NET_PROTO_H_
+#define _NET_PROTO_H_
+
+/* This file is automatically generated with "make proto". DO NOT  
EDIT */
+
+
+/* The following definitions come from utils/net.c  */
+
+uint32 get_sec_channel_type(const char *param) ;
+int net_run_function(int argc, const char **argv, struct functable  
*table,
+		     int (*usage_fn)(int argc, const char **argv));
+int net_run_function2(int argc, const char **argv, const char *whoami,
+		      struct functable2 *table);
+NTSTATUS connect_to_service(struct cli_state **c, struct in_addr  
*server_ip,
+					const char *server_name,
+					const char *service_name,
+					const char *service_type);
+NTSTATUS connect_to_ipc(struct cli_state **c, struct in_addr  
*server_ip,
+					const char *server_name);
+NTSTATUS connect_to_ipc_anonymous(struct cli_state **c,
+			struct in_addr *server_ip, const char *server_name);
+NTSTATUS connect_to_ipc_krb5(struct cli_state **c,
+			struct in_addr *server_ip, const char *server_name);
+NTSTATUS connect_dst_pipe(struct cli_state **cli_dst, struct  
rpc_pipe_client **pp_pipe_hnd, int pipe_num);
+int net_use_machine_password(void) ;
+BOOL net_find_server(const char *domain, unsigned flags, struct  
in_addr *server_ip, char **server_name);
+BOOL net_find_pdc(struct in_addr *server_ip, fstring server_name,  
const char *domain_name);
+struct cli_state *net_make_ipc_connection( unsigned flags );
+struct cli_state *net_make_ipc_connection_ex( const char *domain,  
const char *server,
+                                              struct in_addr *ip,  
unsigned flags);
+int net_help_afs(int argc, const char **argv);
+
+/* The following definitions come from utils/net_ads.c  */
+
+int net_ads_usage(int argc, const char **argv);
+ADS_STATUS ads_startup(BOOL only_own_domain, ADS_STRUCT **ads);
+ADS_STATUS ads_startup_nobind(BOOL only_own_domain, ADS_STRUCT **ads);
+int net_ads_check_our_domain(void);
+int net_ads_check(void);
+int net_ads_user(int argc, const char **argv);
+int net_ads_group(int argc, const char **argv);
+int net_ads_testjoin(int argc, const char **argv);
+int net_ads_join(int argc, const char **argv);
+int net_ads_printer_usage(int argc, const char **argv);
+int net_ads_changetrustpw(int argc, const char **argv);
+int net_ads_keytab(int argc, const char **argv);
+int net_ads_help(int argc, const char **argv);
+int net_ads(int argc, const char **argv);
+int net_ads_keytab(int argc, const char **argv);
+int net_ads_usage(int argc, const char **argv);
+int net_ads_help(int argc, const char **argv);
+int net_ads_changetrustpw(int argc, const char **argv);
+int net_ads_join(int argc, const char **argv);
+int net_ads_user(int argc, const char **argv);
+int net_ads_group(int argc, const char **argv);
+int net_ads_check(void);
+int net_ads_check_our_domain(void);
+int net_ads(int argc, const char **argv);
+
+/* The following definitions come from utils/net_ads_gpo.c  */
+
+int net_ads_gpo(int argc, const char **argv);
+
+/* The following definitions come from utils/net_cache.c  */
+
+int net_cache(int argc, const char **argv);
+
+/* The following definitions come from utils/net_conf.c  */
+
+int net_conf_list(int argc, const char **argv);
+int net_conf_import(int argc, const char **argv);
+int net_conf_listshares(int argc, const char **argv);
+int net_conf_showshare(int argc, const char **argv);
+int net_conf_addshare(int argc, const char **argv);
+int net_conf_delshare(int argc, const char **argv);
+int net_conf(int argc, const char **argv);
+
+/* The following definitions come from utils/net_dns.c  */
+
+int get_my_ip_address( struct in_addr **ips );
+
+/* The following definitions come from utils/net_domain.c  */
+
+NTSTATUS netdom_leave_domain( TALLOC_CTX *mem_ctx, struct cli_state  
*cli,
+                         DOM_SID *dom_sid );
+int netdom_store_machine_account( const char *domain, DOM_SID *sid,  
const char *pw );
+NTSTATUS netdom_get_domain_sid( TALLOC_CTX *mem_ctx, struct  
cli_state *cli,
+				char **domain, DOM_SID **sid );
+NTSTATUS netdom_join_domain( TALLOC_CTX *mem_ctx, struct cli_state  
*cli,
+                           DOM_SID *dom_sid, const char *clear_pw,
+                           enum netdom_domain_t dom_type );
+
+/* The following definitions come from utils/net_groupmap.c  */
+
+int net_help_groupmap(int argc, const char **argv);
+int net_groupmap(int argc, const char **argv);
+
+/* The following definitions come from utils/net_help.c  */
+
+int net_common_methods_usage(int argc, const char**argv);
+int net_common_flags_usage(int argc, const char **argv);
+int net_help_user(int argc, const char **argv);
+int net_help_group(int argc, const char **argv);
+int net_help_join(int argc, const char **argv);
+int net_help_share(int argc, const char **argv);
+int net_help_file(int argc, const char **argv);
+int net_help_printer(int argc, const char **argv);
+int net_help_status(int argc, const char **argv);
+int net_help(int argc, const char **argv);
+
+/* The following definitions come from utils/net_idmap.c  */
+
+BOOL idmap_store_secret(const char *backend, bool alloc,
+			const char *domain, const char *identity,
+			const char *secret);
+int net_help_idmap(int argc, const char **argv);
+int net_idmap(int argc, const char **argv);
+
+/* The following definitions come from utils/net_lookup.c  */
+
+int net_lookup_usage(int argc, const char **argv);
+int net_lookup(int argc, const char **argv);
+
+/* The following definitions come from utils/net_rap.c  */
+
+int net_rap_file_usage(int argc, const char **argv);
+int net_rap_file(int argc, const char **argv);
+int net_rap_share_usage(int argc, const char **argv);
+int net_rap_share(int argc, const char **argv);
+int net_rap_session_usage(int argc, const char **argv);
+int net_rap_session(int argc, const char **argv);
+int net_rap_server_usage(int argc, const char **argv);
+int net_rap_server(int argc, const char **argv);
+int net_rap_domain_usage(int argc, const char **argv);
+int net_rap_domain(int argc, const char **argv);
+int net_rap_printq_usage(int argc, const char **argv);
+int net_rap_printq(int argc, const char **argv);
+int net_rap_user(int argc, const char **argv);
+int net_rap_group_usage(int argc, const char **argv);
+int net_rap_group(int argc, const char **argv);
+int net_rap_groupmember_usage(int argc, const char **argv);
+int net_rap_groupmember(int argc, const char **argv);
+int net_rap_validate_usage(int argc, const char **argv);
+int net_rap_validate(int argc, const char **argv);
+int net_rap_service_usage(int argc, const char **argv);
+int net_rap_service(int argc, const char **argv);
+int net_rap_password_usage(int argc, const char **argv);
+int net_rap_password(int argc, const char **argv);
+int net_rap_admin_usage(int argc, const char **argv);
+int net_rap_admin(int argc, const char **argv);
+int net_rap_usage(int argc, const char **argv);
+int net_rap_help(int argc, const char **argv);
+int net_rap(int argc, const char **argv);
+
+/* The following definitions come from utils/net_rpc.c  */
+
+NTSTATUS net_get_remote_domain_sid(struct cli_state *cli, TALLOC_CTX  
*mem_ctx,
+				   DOM_SID **domain_sid, char **domain_name);
+int run_rpc_command(struct cli_state *cli_arg,
+			const int pipe_idx,
+			int conn_flags,
+			rpc_command_fn fn,
+			int argc,
+			const char **argv) ;
+int net_rpc_changetrustpw(int argc, const char **argv) ;
+int net_rpc_join(int argc, const char **argv) ;
+NTSTATUS rpc_info_internals(const DOM_SID *domain_sid,
+			const char *domain_name,
+			struct cli_state *cli,
+			struct rpc_pipe_client *pipe_hnd,
+			TALLOC_CTX *mem_ctx,
+			int argc,
+			const char **argv);
+int net_rpc_info(int argc, const char **argv) ;
+int net_rpc_getsid(int argc, const char **argv) ;
+int net_rpc_user(int argc, const char **argv) ;
+struct rpc_sh_cmd *net_rpc_user_edit_cmds(TALLOC_CTX *mem_ctx,
+					  struct rpc_sh_ctx *ctx);
+struct rpc_sh_cmd *net_rpc_user_cmds(TALLOC_CTX *mem_ctx,
+				     struct rpc_sh_ctx *ctx);
+int net_rpc_group(int argc, const char **argv) ;
+BOOL sync_files(struct copy_clistate *cp_clistate, pstring mask);
+BOOL copy_top_level_perms(struct copy_clistate *cp_clistate,
+				const char *sharename);
+int net_usersidlist(int argc, const char **argv);
+int net_usersidlist_usage(int argc, const char **argv);
+int net_rpc_share(int argc, const char **argv) ;
+struct rpc_sh_cmd *net_rpc_share_cmds(TALLOC_CTX *mem_ctx,
+				      struct rpc_sh_ctx *ctx);
+int net_rpc_file(int argc, const char **argv) ;
+BOOL net_rpc_check(unsigned flags);
+int rpc_printer_migrate(int argc, const char **argv) ;
+int rpc_printer_usage(int argc, const char **argv);
+int net_rpc_printer(int argc, const char **argv) ;
+int net_rpc_usage(int argc, const char **argv) ;
+int net_rpc_help(int argc, const char **argv);
+int net_rpc(int argc, const char **argv);
+
+/* The following definitions come from utils/net_rpc_audit.c  */
+
+int net_rpc_audit(int argc, const char **argv) ;
+
+/* The following definitions come from utils/net_rpc_join.c  */
+
+int net_rpc_join_ok(const char *domain, const char *server, struct  
in_addr *ip );
+int net_rpc_join_newstyle(int argc, const char **argv) ;
+int net_rpc_testjoin(int argc, const char **argv) ;
+
+/* The following definitions come from utils/net_rpc_printer.c  */
+
+NTSTATUS net_copy_fileattr(TALLOC_CTX *mem_ctx,
+		  struct cli_state *cli_share_src,
+		  struct cli_state *cli_share_dst,
+		  const char *src_name, const char *dst_name,
+		  BOOL copy_acls, BOOL copy_attrs,
+		  BOOL copy_timestamps, BOOL is_file);
+NTSTATUS net_copy_file(TALLOC_CTX *mem_ctx,
+		       struct cli_state *cli_share_src,
+		       struct cli_state *cli_share_dst,
+		       const char *src_name, const char *dst_name,
+		       BOOL copy_acls, BOOL copy_attrs,
+		       BOOL copy_timestamps, BOOL is_file);
+NTSTATUS rpc_printer_list_internals(const DOM_SID *domain_sid,
+					const char *domain_name,
+					struct cli_state *cli,
+					struct rpc_pipe_client *pipe_hnd,
+					TALLOC_CTX *mem_ctx,
+					int argc,
+					const char **argv);
+NTSTATUS rpc_printer_driver_list_internals(const DOM_SID *domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_publish_publish_internals(const DOM_SID  
*domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_publish_unpublish_internals(const DOM_SID  
*domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_publish_update_internals(const DOM_SID  
*domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_publish_list_internals(const DOM_SID *domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_migrate_security_internals(const DOM_SID  
*domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_migrate_forms_internals(const DOM_SID *domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_migrate_drivers_internals(const DOM_SID  
*domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_migrate_printers_internals(const DOM_SID  
*domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+NTSTATUS rpc_printer_migrate_settings_internals(const DOM_SID  
*domain_sid,
+						const char *domain_name,
+						struct cli_state *cli,
+						struct rpc_pipe_client *pipe_hnd,
+						TALLOC_CTX *mem_ctx,
+						int argc,
+						const char **argv);
+
+/* The following definitions come from utils/net_rpc_registry.c  */
+
+int net_rpc_registry(int argc, const char **argv) ;
+
+/* The following definitions come from utils/net_rpc_rights.c  */
+
+int net_rpc_rights(int argc, const char **argv) ;
+struct rpc_sh_cmd *net_rpc_rights_cmds(TALLOC_CTX *mem_ctx,
+				       struct rpc_sh_ctx *ctx);
+
+/* The following definitions come from utils/net_rpc_samsync.c  */
+
+NTSTATUS rpc_samdump_internals(const DOM_SID *domain_sid,
+				const char *domain_name,
+				struct cli_state *cli,
+				struct rpc_pipe_client *pipe_hnd,
+				TALLOC_CTX *mem_ctx,
+				int argc,
+				const char **argv) ;
+int rpc_vampire_usage(int argc, const char **argv) ;
+NTSTATUS rpc_vampire_internals(const DOM_SID *domain_sid,
+				const char *domain_name,
+				struct cli_state *cli,
+				struct rpc_pipe_client *pipe_hnd,
+				TALLOC_CTX *mem_ctx,
+				int argc,
+				const char **argv) ;
+
+/* The following definitions come from utils/net_rpc_service.c  */
+
+int net_rpc_service(int argc, const char **argv) ;
+
+/* The following definitions come from utils/net_rpc_sh_acct.c  */
+
+struct rpc_sh_cmd *net_rpc_acct_cmds(TALLOC_CTX *mem_ctx,
+				     struct rpc_sh_ctx *ctx);
+
+/* The following definitions come from utils/net_rpc_shell.c  */
+
+int net_rpc_shell(int argc, const char **argv);
+
+/* The following definitions come from utils/net_sam.c  */
+
+int net_sam(int argc, const char **argv);
+
+/* The following definitions come from utils/net_status.c  */
+
+int net_status(int argc, const char **argv);
+
+/* The following definitions come from utils/net_time.c  */
+
+int net_time_usage(int argc, const char **argv);
+int net_time(int argc, const char **argv);
+
+/* The following definitions come from utils/net_usershare.c  */
+
+int net_usershare_usage(int argc, const char **argv);
+int net_usershare_help(int argc, const char **argv);
+int net_usershare(int argc, const char **argv);
+
+/* The following definitions come from utils/net_util.c  */
+
+BOOL is_valid_policy_hnd(const POLICY_HND *hnd);
+NTSTATUS net_rpc_lookup_name(TALLOC_CTX *mem_ctx, struct cli_state  
*cli,
+			     const char *name, const char **ret_domain,
+			     const char **ret_name, DOM_SID *ret_sid,
+			     enum lsa_SidType *ret_type);
+
+/* The following definitions come from utils/netlookup.c  */
+
+NTSTATUS net_lookup_name_from_sid(TALLOC_CTX *ctx,
+				DOM_SID *psid,
+				const char **ppdomain,
+				const char **ppname);
+NTSTATUS net_lookup_sid_from_name(TALLOC_CTX *ctx, const char  
*full_name, DOM_SID *pret_sid);
+
+/* The following definitions come from utils/passwd_util.c  */
+
+char *stdin_new_passwd( void);
+char *get_pass( const char *prompt, BOOL stdin_get);
+
+#endif /*  _NET_PROTO_H_  */
diff --git a/source/utils/ntlm_auth_proto.h b/source/utils/ 
ntlm_auth_proto.h
new file mode 100644
index 0000000..7dc0f44
--- /dev/null
+++ b/source/utils/ntlm_auth_proto.h
@@ -0,0 +1,28 @@
+#ifndef _NTLM_AUTH_PROTO_H_
+#define _NTLM_AUTH_PROTO_H_
+
+/* This file is automatically generated with "make proto". DO NOT  
EDIT */
+
+
+/* The following definitions come from utils/ntlm_auth.c  */
+
+const char *get_winbind_domain(void);
+const char *get_winbind_netbios_name(void);
+DATA_BLOB get_challenge(void) ;
+NTSTATUS contact_winbind_auth_crap(const char *username,
+				   const char *domain,
+				   const char *workstation,
+				   const DATA_BLOB *challenge,
+				   const DATA_BLOB *lm_response,
+				   const DATA_BLOB *nt_response,
+				   uint32 flags,
+				   uint8 lm_key[8],
+				   uint8 user_session_key[16],
+				   char **error_string,
+				   char **unix_name) ;
+
+/* The following definitions come from utils/ 
ntlm_auth_diagnostics.c  */
+
+BOOL diagnose_ntlm_auth(void);
+
+#endif /*  _NTLM_AUTH_PROTO_H_  */
diff --git a/source/utils/passwd_proto.h b/source/utils/passwd_proto.h
new file mode 100644
index 0000000..8e8fd4b
--- /dev/null
+++ b/source/utils/passwd_proto.h
@@ -0,0 +1,12 @@
+#ifndef _PASSWD_PROTO_H_
+#define _PASSWD_PROTO_H_
+
+/* This file is automatically generated with "make proto". DO NOT  
EDIT */
+
+
+/* The following definitions come from utils/passwd_util.c  */
+
+char *stdin_new_passwd( void);
+char *get_pass( const char *prompt, BOOL stdin_get);
+
+#endif /*  _PASSWD_PROTO_H_  */
diff --git a/source/web/swat_proto.h b/source/web/swat_proto.h
new file mode 100644
index 0000000..8384f44
--- /dev/null
+++ b/source/web/swat_proto.h
@@ -0,0 +1,49 @@
+#ifndef _SWAT_PROTO_H_
+#define _SWAT_PROTO_H_
+
+/* This file is automatically generated with "make proto". DO NOT  
EDIT */
+
+
+/* The following definitions come from web/cgi.c  */
+
+void cgi_load_variables(void);
+const char *cgi_variable(const char *name);
+const char *cgi_variable_nonull(const char *name);
+BOOL am_root(void);
+char *cgi_user_name(void);
+void cgi_setup(const char *rootdir, int auth_required);
+const char *cgi_baseurl(void);
+const char *cgi_pathinfo(void);
+char *cgi_remote_host(void);
+char *cgi_remote_addr(void);
+BOOL cgi_waspost(void);
+
+/* The following definitions come from web/diagnose.c  */
+
+BOOL winbindd_running(void);
+BOOL nmbd_running(void);
+BOOL smbd_running(void);
+
+/* The following definitions come from web/neg_lang.c  */
+
+int web_open(const char *fname, int flags, mode_t mode);
+void web_set_lang(const char *lang_string);
+
+/* The following definitions come from web/startstop.c  */
+
+void start_smbd(void);
+void start_nmbd(void);
+void start_winbindd(void);
+void stop_smbd(void);
+void stop_nmbd(void);
+void stop_winbindd(void);
+void kill_pid(struct server_id pid);
+
+/* The following definitions come from web/statuspage.c  */
+
+void status_page(void);
+
+/* The following definitions come from web/swat.c  */
+
+
+#endif /*  _SWAT_PROTO_H_  */
--
1.5.2.1


--
James Peach | jpeach at samba.org




More information about the samba-technical mailing list