s4:service_task: explicitly use dcerpc_binding_handle_set_sync_ev() for irpc
authorAndrew Bartlett <abartlet@samba.org>
Mon, 5 May 2014 04:27:59 +0000 (16:27 +1200)
committerStefan Metzmacher <metze@samba.org>
Mon, 12 May 2014 22:08:12 +0000 (00:08 +0200)
This indicates that we're using nested event loops...

Andrew Bartlett

Pair-Programmed-With: Stefan Metzmacher <metze@samba.org>

Change-Id: I7e147850566301a5ef2354b8615a044d121968b5
Signed-off-by: Andrew Bartlett <abartlet@samba.org>
Signed-off-by: Stefan Metzmacher <metze@samba.org>
source4/smbd/service_task.c

index 5d14fafec0437854270aaaff0fb83c90db3c9a6a..7422f2c3e9be2bb21af402ebf80dd32c5cb662e8 100644 (file)
@@ -41,6 +41,8 @@ void task_server_terminate(struct task_server *task, const char *reason, bool fa
                irpc_handle = irpc_binding_handle_by_name(task, task->msg_ctx,
                                                          "samba", &ndr_table_irpc);
                if (irpc_handle != NULL) {
+                       /* Note: this makes use of nested event loops... */
+                       dcerpc_binding_handle_set_sync_ev(irpc_handle, event_ctx);
                        r.in.reason = reason;
                        dcerpc_samba_terminate_r(irpc_handle, task, &r);
                }