[Spice-devel] [vdagent-win v1] vdagent-win: start vdagent with lock info from session

Victor Toso victortoso at redhat.com
Mon Dec 12 21:46:34 UTC 2016


Hi,

On Mon, Dec 12, 2016 at 10:42:43PM +0100, Victor Toso wrote:
> From: Frediano Ziglio <fziglio at redhat.com>
>
> Would be something like this (not tested)

I would just add the commit log from:
https://lists.freedesktop.org/archives/spice-devel/2016-August/031381.html

> ---
>  common/vdcommon.h       |  1 +
>  vdagent/vdagent.cpp     | 12 ++++++++++++
>  vdservice/vdservice.cpp |  7 +++++++
>  3 files changed, 20 insertions(+)
> 
> diff --git a/common/vdcommon.h b/common/vdcommon.h
> index c1920e9..6b53327 100644
> --- a/common/vdcommon.h
> +++ b/common/vdcommon.h
> @@ -66,6 +66,7 @@ typedef Mutex mutex_t;
>  
>  #define VD_AGENT_REGISTRY_KEY "SOFTWARE\\Red Hat\\Spice\\vdagent\\"
>  #define VD_AGENT_STOP_EVENT   TEXT("Global\\vdagent_stop_event")
> +#define VD_AGENT_SESSION_UNLOCKED_EVENT TEXT("Global\\vdagent_session_unlocked_event")
>
>  #if defined __GNUC__
>  #define ALIGN_GCC __attribute__ ((packed))
> diff --git a/vdagent/vdagent.cpp b/vdagent/vdagent.cpp
> index e3ba14b..0396a11 100644
> --- a/vdagent/vdagent.cpp
> +++ b/vdagent/vdagent.cpp
> @@ -236,6 +236,18 @@ VDAgent::VDAgent()
>      ZeroMemory(&_write_overlapped, sizeof(_write_overlapped));
>      ZeroMemory(_read_buf, sizeof(_read_buf));
>
> +    HANDLE _session_unlocked_event = OpenEvent(SYNCHRONIZE, FALSE, VD_AGENT_SESSION_UNLOCKED_EVENT);

and maybe move the variable definition to the top?

Acked-by: Victor Toso <victortoso at redhat.com>

  toso
> +    switch (WaitForSingleObject(_session_unlocked_event, 0)) {
> +    case WAIT_OBJECT_0:
> +        _session_is_locked = false;
> +        break;
> +    default:
> +    case WAIT_TIMEOUT:
> +        _session_is_locked = true;
> +        break;
> +    }
> +    CloseHandle(_session_unlocked_event);
> +
>      _singleton = this;
>  }
>  
> diff --git a/vdservice/vdservice.cpp b/vdservice/vdservice.cpp
> index 1892b72..65adf72 100644
> --- a/vdservice/vdservice.cpp
> +++ b/vdservice/vdservice.cpp
> @@ -91,6 +91,7 @@ private:
>      PROCESS_INFORMATION _agent_proc_info;
>      HANDLE _control_event;
>      HANDLE _agent_stop_event;
> +    HANDLE _session_unlocked_event;
>      HANDLE* _events;
>      TCHAR _agent_path[MAX_PATH];
>      VDControlQueue _control_queue;
> @@ -123,11 +124,13 @@ VDService::VDService()
>      _system_version = supported_system_version();
>      _control_event = CreateEvent(NULL, FALSE, FALSE, NULL);
>      _agent_stop_event = CreateEvent(NULL, FALSE, FALSE, VD_AGENT_STOP_EVENT);
> +    _session_unlocked_event = CreateEvent(NULL, TRUE, TRUE, VD_AGENT_SESSION_UNLOCKED_EVENT);
>      _agent_path[0] = wchar_t('\0');
>  }
>  
>  VDService::~VDService()
>  {
> +    CloseHandle(_session_unlocked_event);
>      CloseHandle(_agent_stop_event);
>      CloseHandle(_control_event);
>      delete[] _events;
> @@ -290,6 +293,10 @@ DWORD WINAPI VDService::control_handler(DWORD control, DWORD event_type, LPVOID
>          if (event_type == WTS_CONSOLE_CONNECT) {
>              s->_session_id = session_id;
>              s->set_control_event(VD_CONTROL_RESTART_AGENT);
> +        } else if (event_type == WTS_SESSION_LOCK) {
> +            ResetEvent(s->_session_unlocked_event);
> +        } else if (event_type == WTS_SESSION_UNLOCK) {
> +            SetEvent(s->_session_unlocked_event);
>          }
>          break;
>      }
> -- 
> 2.9.3
> 
> _______________________________________________
> Spice-devel mailing list
> Spice-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/spice-devel
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/spice-devel/attachments/20161212/3b1469d1/attachment.sig>


More information about the Spice-devel mailing list