Fix API troubles with FreeRDP 2.0 v2

With FreeRDP 2.0 the crypto needs to be initialized or we fail as soon as we try to
compute a md5. The API also changed for the suppress output callback.

Reviewed-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
dev
David Fort 7 years ago committed by Pekka Paalanen
parent fa41bdfbc0
commit be2f6b0f75
  1. 14
      libweston/compositor-rdp.c

@ -76,6 +76,10 @@
#include <freerdp/locale/keyboard.h> #include <freerdp/locale/keyboard.h>
#include <winpr/input.h> #include <winpr/input.h>
#if FREERDP_VERSION_MAJOR >= 2
#include <winpr/ssl.h>
#endif
#include "shared/helpers.h" #include "shared/helpers.h"
#include "compositor.h" #include "compositor.h"
#include "compositor-rdp.h" #include "compositor-rdp.h"
@ -1013,7 +1017,8 @@ xf_peer_activate(freerdp_peer* client)
return TRUE; return TRUE;
} }
static BOOL xf_peer_post_connect(freerdp_peer *client) static BOOL
xf_peer_post_connect(freerdp_peer *client)
{ {
return TRUE; return TRUE;
} }
@ -1166,7 +1171,7 @@ xf_input_unicode_keyboard_event(rdpInput *input, UINT16 flags, UINT16 code)
static FREERDP_CB_RET_TYPE static FREERDP_CB_RET_TYPE
xf_suppress_output(rdpContext *context, BYTE allow, RECTANGLE_16 *area) xf_suppress_output(rdpContext *context, BYTE allow, const RECTANGLE_16 *area)
{ {
RdpPeerContext *peerContext = (RdpPeerContext *)context; RdpPeerContext *peerContext = (RdpPeerContext *)context;
@ -1227,7 +1232,7 @@ rdp_peer_init(freerdp_peer *client, struct rdp_backend *b)
client->PostConnect = xf_peer_post_connect; client->PostConnect = xf_peer_post_connect;
client->Activate = xf_peer_activate; client->Activate = xf_peer_activate;
client->update->SuppressOutput = xf_suppress_output; client->update->SuppressOutput = (pSuppressOutput)xf_suppress_output;
input = client->input; input = client->input;
input->SynchronizeEvent = xf_input_synchronize_event; input->SynchronizeEvent = xf_input_synchronize_event;
@ -1387,6 +1392,9 @@ weston_backend_init(struct weston_compositor *compositor,
struct weston_rdp_backend_config config = {{ 0, }}; struct weston_rdp_backend_config config = {{ 0, }};
int major, minor, revision; int major, minor, revision;
#if FREERDP_VERSION_MAJOR >= 2
winpr_InitializeSSL(0);
#endif
freerdp_get_version(&major, &minor, &revision); freerdp_get_version(&major, &minor, &revision);
weston_log("using FreeRDP version %d.%d.%d\n", major, minor, revision); weston_log("using FreeRDP version %d.%d.%d\n", major, minor, revision);

Loading…
Cancel
Save