summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/daemon/ptyc_daemon_init.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/daemon/ptyc_daemon_init.c b/src/daemon/ptyc_daemon_init.c
index c7fa5eb..b8d1170 100644
--- a/src/daemon/ptyc_daemon_init.c
+++ b/src/daemon/ptyc_daemon_init.c
@@ -14,7 +14,7 @@
static const nt_guid ptyc_daemon_guid = PTYC_PORT_GUID_DAEMON;
-static int32_t ptyc_daemon_init_impl(struct ptyc_daemon_ctx * dctx)
+static int32_t ptyc_daemon_init_impl(struct ptyc_daemon_ctx * dctx, void * htty)
{
int32_t status;
nt_daemon_params dparams;
@@ -66,7 +66,14 @@ static int32_t ptyc_daemon_init_impl(struct ptyc_daemon_ctx * dctx)
dparams.stack_size_commit = 8192;
dparams.stack_size_reserve = 8192;
- return ntapi->dsr_init(&dparams);
+ if ((status = ntapi->dsr_init(&dparams)))
+ return status;
+
+ return ntapi->tty_request_peer(
+ htty,
+ PTYC_DAEMON_TTYSIGNAL,
+ 0,&(nt_guid)TTY_PTS_GUID,
+ &dctx->daemon_attr);
}
static int32_t ptyc_daemon_once = 0;
@@ -92,7 +99,7 @@ int32_t __stdcall ptyc_daemon_init(struct ptyc_daemon_ctx * dctx, uint64_t drvfl
/* once */
switch (at_locked_cas_32(&ptyc_daemon_once,0,1)) {
case 0:
- if ((status = ptyc_daemon_init_impl(dctx))) {
+ if ((status = ptyc_daemon_init_impl(dctx,rtdata->hsession))) {
at_locked_add_32(&ptyc_daemon_once,2);
return status;
}