diff options
author | midipix <writeonce@midipix.org> | 2017-07-30 21:21:21 +0000 |
---|---|---|
committer | midipix <writeonce@midipix.org> | 2017-07-31 08:43:36 -0400 |
commit | 029ed17d66b232d5e8bea0b3ab543ec8331e563d (patch) | |
tree | 3574a0f3adc9f6bebf8bcab9ff0f4c6aee822051 /src | |
parent | df0e429a0627515b82a23f88c7feeb9e9dd5ddb6 (diff) | |
download | ntapi-029ed17d66b232d5e8bea0b3ab543ec8331e563d.tar.bz2 ntapi-029ed17d66b232d5e8bea0b3ab543ec8331e563d.tar.xz |
subsystem interfaces: integrated __ntapi_tty_client_session_disconnect().
Diffstat (limited to 'src')
-rw-r--r-- | src/internal/ntapi.c | 1 | ||||
-rw-r--r-- | src/internal/ntapi_fnapi.h | 1 | ||||
-rw-r--r-- | src/tty/ntapi_tty_client_session_disconnect.c | 38 |
3 files changed, 40 insertions, 0 deletions
diff --git a/src/internal/ntapi.c b/src/internal/ntapi.c index 8e3c4b9..42812c0 100644 --- a/src/internal/ntapi.c +++ b/src/internal/ntapi.c @@ -327,6 +327,7 @@ static int32_t __fastcall __ntapi_init_once(ntapi_vtbl ** pvtbl) __ntapi->tty_create_session = __ntapi_tty_create_session; __ntapi->tty_join_session = __ntapi_tty_join_session; __ntapi->tty_connect = __ntapi_tty_connect; + __ntapi->tty_client_session_disconnect = __ntapi_tty_client_session_disconnect; __ntapi->tty_client_session_query = __ntapi_tty_client_session_query; __ntapi->tty_client_session_set = __ntapi_tty_client_session_set; __ntapi->tty_client_process_register = __ntapi_tty_client_process_register; diff --git a/src/internal/ntapi_fnapi.h b/src/internal/ntapi_fnapi.h index 9fa215c..39f8ac3 100644 --- a/src/internal/ntapi_fnapi.h +++ b/src/internal/ntapi_fnapi.h @@ -199,6 +199,7 @@ ntapi_vfd_dev_name_init __ntapi_vfd_dev_name_init; ntapi_tty_create_session __ntapi_tty_create_session; ntapi_tty_join_session __ntapi_tty_join_session; ntapi_tty_connect __ntapi_tty_connect; +ntapi_tty_client_session_disconnect __ntapi_tty_client_session_disconnect; ntapi_tty_client_session_query __ntapi_tty_client_session_query; ntapi_tty_client_session_set __ntapi_tty_client_session_set; ntapi_tty_client_process_register __ntapi_tty_client_process_register; diff --git a/src/tty/ntapi_tty_client_session_disconnect.c b/src/tty/ntapi_tty_client_session_disconnect.c new file mode 100644 index 0000000..e977749 --- /dev/null +++ b/src/tty/ntapi_tty_client_session_disconnect.c @@ -0,0 +1,38 @@ +/********************************************************/ +/* ntapi: Native API core library */ +/* Copyright (C) 2013--2017 Z. Gilboa */ +/* Released under GPLv2 and GPLv3; see COPYING.NTAPI. */ +/********************************************************/ + +#include <psxtypes/psxtypes.h> +#include <ntapi/nt_tty.h> +#include <ntapi/ntapi.h> +#include "ntapi_impl.h" + +typedef struct _nt_tty_disconnect_msg { + nt_port_message header; + struct { + nt_tty_msg_info ttyinfo; + } data; +} nt_tty_disconnect_msg; + +int32_t __stdcall __ntapi_tty_client_session_disconnect(void * hport) +{ + int32_t status; + nt_tty_disconnect_msg msg; + + hport = hport ? hport : __ntapi_internals()->hport_tty_session; + + __ntapi->tt_aligned_block_memset( + &msg,0,sizeof(msg)); + + msg.header.msg_type = NT_LPC_NEW_MESSAGE; + msg.header.data_size = sizeof(msg.data); + msg.header.msg_size = sizeof(msg); + msg.data.ttyinfo.opcode = NT_TTY_CLIENT_SESSION_DISCONNECT; + + if ((status = __ntapi->zw_request_wait_reply_port(hport,&msg,&msg))) + return status; + + return msg.data.ttyinfo.status; +} |