summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source3/smbd/server.c19
1 files changed, 15 insertions, 4 deletions
diff --git a/source3/smbd/server.c b/source3/smbd/server.c
index a9762e0b52..f6d2657289 100644
--- a/source3/smbd/server.c
+++ b/source3/smbd/server.c
@@ -42,6 +42,9 @@
extern void start_epmd(struct tevent_context *ev_ctx,
struct messaging_context *msg_ctx);
+extern void start_lsasd(struct event_context *ev_ctx,
+ struct messaging_context *msg_ctx);
+
#ifdef WITH_DFS
extern int dcelogin_atmost_once;
#endif /* WITH_DFS */
@@ -1221,11 +1224,19 @@ extern void build_options(bool screen);
/* only start other daemons if we are running as a daemon
* -- bad things will happen if smbd is launched via inetd
* and we fork a copy of ourselves here */
- if (is_daemon && !interactive && !_lp_disable_spoolss()) {
- bool bgq = lp_parm_bool(-1, "smbd", "backgroundqueue", true);
+ if (is_daemon && !interactive) {
+ enum rpc_service_mode_e lsarpc_mode = rpc_lsarpc_mode();
- if (!printing_subsystem_init(ev_ctx, msg_ctx, true, bgq)) {
- exit(1);
+ if (lsarpc_mode == RPC_SERVICE_MODE_DAEMON) {
+ start_lsasd(ev_ctx, msg_ctx);
+ }
+
+ if (!_lp_disable_spoolss()) {
+ bool bgq = lp_parm_bool(-1, "smbd", "backgroundqueue", true);
+
+ if (!printing_subsystem_init(ev_ctx, msg_ctx, true, bgq)) {
+ exit(1);
+ }
}
} else if (!_lp_disable_spoolss()) {
if (!printing_subsystem_init(ev_ctx, msg_ctx, false, false)) {