summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source3/rpc_server/rpc_ncacn_np_internal.c145
1 files changed, 0 insertions, 145 deletions
diff --git a/source3/rpc_server/rpc_ncacn_np_internal.c b/source3/rpc_server/rpc_ncacn_np_internal.c
index 58727600cf..71a14be845 100644
--- a/source3/rpc_server/rpc_ncacn_np_internal.c
+++ b/source3/rpc_server/rpc_ncacn_np_internal.c
@@ -171,150 +171,6 @@ struct pipes_struct *make_internal_rpc_pipe_p(TALLOC_CTX *mem_ctx,
return p;
}
-/****************************************************************************
-****************************************************************************/
-
-static NTSTATUS internal_ndr_push(TALLOC_CTX *mem_ctx,
- struct rpc_pipe_client *cli,
- const struct ndr_interface_table *table,
- uint32_t opnum,
- void *r)
-{
- const struct ndr_interface_call *call;
- struct ndr_push *push;
- enum ndr_err_code ndr_err;
-
- if (!ndr_syntax_id_equal(&table->syntax_id, &cli->abstract_syntax) ||
- (opnum >= table->num_calls)) {
- return NT_STATUS_INVALID_PARAMETER;
- }
-
- call = &table->calls[opnum];
-
- if (DEBUGLEVEL >= 10) {
- ndr_print_function_debug(call->ndr_print,
- call->name, NDR_IN, r);
- }
-
- push = ndr_push_init_ctx(mem_ctx);
- if (push == NULL) {
- return NT_STATUS_NO_MEMORY;
- }
-
- ndr_err = call->ndr_push(push, NDR_IN, r);
- if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
- TALLOC_FREE(push);
- return ndr_map_error2ntstatus(ndr_err);
- }
-
- cli->pipes_struct->in_data.data = ndr_push_blob(push);
- talloc_steal(cli->pipes_struct->mem_ctx,
- cli->pipes_struct->in_data.data.data);
- TALLOC_FREE(push);
-
- return NT_STATUS_OK;
-}
-
-/****************************************************************************
-****************************************************************************/
-
-static NTSTATUS internal_ndr_pull(TALLOC_CTX *mem_ctx,
- struct rpc_pipe_client *cli,
- const struct ndr_interface_table *table,
- uint32_t opnum,
- void *r)
-{
- const struct ndr_interface_call *call;
- struct ndr_pull *pull;
- enum ndr_err_code ndr_err;
-
- if (!ndr_syntax_id_equal(&table->syntax_id, &cli->abstract_syntax) ||
- (opnum >= table->num_calls)) {
- return NT_STATUS_INVALID_PARAMETER;
- }
-
- call = &table->calls[opnum];
-
- pull = ndr_pull_init_blob(&cli->pipes_struct->out_data.rdata,
- mem_ctx);
- if (pull == NULL) {
- return NT_STATUS_NO_MEMORY;
- }
-
- /* have the ndr parser alloc memory for us */
- pull->flags |= LIBNDR_FLAG_REF_ALLOC;
- ndr_err = call->ndr_pull(pull, NDR_OUT, r);
- TALLOC_FREE(pull);
-
- if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
- return ndr_map_error2ntstatus(ndr_err);
- }
-
- if (DEBUGLEVEL >= 10) {
- ndr_print_function_debug(call->ndr_print,
- call->name, NDR_OUT, r);
- }
-
- return NT_STATUS_OK;
-}
-
-/****************************************************************************
-****************************************************************************/
-
-static NTSTATUS rpc_pipe_internal_dispatch(struct rpc_pipe_client *cli,
- TALLOC_CTX *mem_ctx,
- const struct ndr_interface_table *table,
- uint32_t opnum, void *r)
-{
- NTSTATUS status;
- int num_cmds = rpc_srv_get_pipe_num_cmds(&table->syntax_id);
- const struct api_struct *cmds = rpc_srv_get_pipe_cmds(&table->syntax_id);
- int i;
-
- if (cli->pipes_struct == NULL) {
- return NT_STATUS_INVALID_PARAMETER;
- }
-
- /* set opnum */
- cli->pipes_struct->opnum = opnum;
-
- for (i = 0; i < num_cmds; i++) {
- if (cmds[i].opnum == opnum && cmds[i].fn != NULL) {
- break;
- }
- }
-
- if (i == num_cmds) {
- return NT_STATUS_INVALID_PARAMETER;
- }
-
- status = internal_ndr_push(mem_ctx, cli, table, opnum, r);
- if (!NT_STATUS_IS_OK(status)) {
- return status;
- }
-
- if (!cmds[i].fn(cli->pipes_struct)) {
- data_blob_free(&cli->pipes_struct->in_data.data);
- data_blob_free(&cli->pipes_struct->out_data.rdata);
- talloc_free_children(cli->pipes_struct->mem_ctx);
- return NT_STATUS_UNSUCCESSFUL;
- }
-
- status = internal_ndr_pull(mem_ctx, cli, table, opnum, r);
- if (!NT_STATUS_IS_OK(status)) {
- data_blob_free(&cli->pipes_struct->in_data.data);
- data_blob_free(&cli->pipes_struct->out_data.rdata);
- talloc_free_children(cli->pipes_struct->mem_ctx);
- return status;
- }
-
- data_blob_free(&cli->pipes_struct->in_data.data);
- data_blob_free(&cli->pipes_struct->out_data.rdata);
- talloc_free_children(cli->pipes_struct->mem_ctx);
-
- return NT_STATUS_OK;
-}
-
static NTSTATUS rpcint_dispatch(struct pipes_struct *p,
TALLOC_CTX *mem_ctx,
uint32_t opnum,
@@ -625,7 +481,6 @@ NTSTATUS rpc_pipe_open_internal(TALLOC_CTX *mem_ctx,
result->abstract_syntax = *abstract_syntax;
result->transfer_syntax = ndr_transfer_syntax;
- result->dispatch = rpc_pipe_internal_dispatch;
result->pipes_struct = make_internal_rpc_pipe_p(
result, abstract_syntax, "", serversupplied_info, msg_ctx);