Auto sync2gitlab import of freerdp-2.2.0-8.el8.src.rpm
This commit is contained in:
parent
d8f886c72d
commit
e988dfe6ea
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
/FreeRDP-2.2.0.tar.gz
|
315
6741.patch
Normal file
315
6741.patch
Normal file
@ -0,0 +1,315 @@
|
||||
From 3ee4cabcfad3a9ccc3c59be21245b57c17e7ae75 Mon Sep 17 00:00:00 2001
|
||||
From: Ondrej Holy <oholy@redhat.com>
|
||||
Date: Thu, 21 Jan 2021 14:21:09 +0100
|
||||
Subject: [PATCH 1/3] client: Fix exit codes for /help and similar option
|
||||
|
||||
Currently, non-zero exit code is returned for /version, /buildconfig, /help,
|
||||
/monitor-list, /kbd-list and /kbd-lang-list command-line options for several
|
||||
clients. This is against conventions because 0 is usually returned in
|
||||
such cases. Also, there is potentially another problem that the returned
|
||||
codes overflow on UNIX systems (where the exit code is a number between 0
|
||||
and 255). Let's fix the clients to return 0 in the mentioned cases to honor
|
||||
conventions and 1 for the command-line parsing errors (or -1 for clients
|
||||
who already use that value).
|
||||
|
||||
Fixes: https://github.com/FreeRDP/FreeRDP/issues/6686
|
||||
---
|
||||
client/Sample/tf_freerdp.c | 9 +++++----
|
||||
client/Wayland/wlfreerdp.c | 13 +++++++------
|
||||
client/Windows/cli/wfreerdp.c | 4 ++++
|
||||
client/X11/cli/xfreerdp.c | 22 +++++++++++++---------
|
||||
winpr/include/winpr/cmdline.h | 1 +
|
||||
5 files changed, 30 insertions(+), 19 deletions(-)
|
||||
|
||||
diff --git a/client/Sample/tf_freerdp.c b/client/Sample/tf_freerdp.c
|
||||
index 3ba82c78338..49412cb417c 100644
|
||||
--- a/client/Sample/tf_freerdp.c
|
||||
+++ b/client/Sample/tf_freerdp.c
|
||||
@@ -338,12 +338,13 @@ int main(int argc, char* argv[])
|
||||
goto fail;
|
||||
|
||||
status = freerdp_client_settings_parse_command_line(context->settings, argc, argv, FALSE);
|
||||
- status =
|
||||
- freerdp_client_settings_command_line_status_print(context->settings, status, argc, argv);
|
||||
-
|
||||
if (status)
|
||||
{
|
||||
- rc = 0;
|
||||
+ freerdp_client_settings_command_line_status_print(context->settings, status, argc, argv);
|
||||
+
|
||||
+ if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
+ rc = 0;
|
||||
+
|
||||
goto fail;
|
||||
}
|
||||
|
||||
diff --git a/client/Wayland/wlfreerdp.c b/client/Wayland/wlfreerdp.c
|
||||
index 329d1200941..d77b47986ea 100644
|
||||
--- a/client/Wayland/wlfreerdp.c
|
||||
+++ b/client/Wayland/wlfreerdp.c
|
||||
@@ -628,18 +628,19 @@ int main(int argc, char* argv[])
|
||||
settings = context->settings;
|
||||
|
||||
status = freerdp_client_settings_parse_command_line(settings, argc, argv, FALSE);
|
||||
- status = freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
-
|
||||
if (status)
|
||||
{
|
||||
BOOL list = settings->ListMonitors;
|
||||
+
|
||||
+ freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
+
|
||||
if (list)
|
||||
wlf_list_monitors(wlc);
|
||||
|
||||
- freerdp_client_context_free(context);
|
||||
- if (list)
|
||||
- return 0;
|
||||
- return status;
|
||||
+ if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
+ rc = 0;
|
||||
+
|
||||
+ goto fail;
|
||||
}
|
||||
|
||||
if (freerdp_client_start(context) != 0)
|
||||
diff --git a/client/Windows/cli/wfreerdp.c b/client/Windows/cli/wfreerdp.c
|
||||
index 7a76eeb9b59..b623067e98e 100644
|
||||
--- a/client/Windows/cli/wfreerdp.c
|
||||
+++ b/client/Windows/cli/wfreerdp.c
|
||||
@@ -108,6 +108,10 @@ INT WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine
|
||||
if (status)
|
||||
{
|
||||
freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
+
|
||||
+ if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
+ rc = 0;
|
||||
+
|
||||
goto out;
|
||||
}
|
||||
|
||||
diff --git a/client/X11/cli/xfreerdp.c b/client/X11/cli/xfreerdp.c
|
||||
index c8a77f335f4..a3505b24d3c 100644
|
||||
--- a/client/X11/cli/xfreerdp.c
|
||||
+++ b/client/X11/cli/xfreerdp.c
|
||||
@@ -34,6 +34,7 @@
|
||||
|
||||
int main(int argc, char* argv[])
|
||||
{
|
||||
+ int rc = 1;
|
||||
int status;
|
||||
HANDLE thread;
|
||||
xfContext* xfc;
|
||||
@@ -56,31 +57,34 @@ int main(int argc, char* argv[])
|
||||
xfc = (xfContext*)context;
|
||||
|
||||
status = freerdp_client_settings_parse_command_line(context->settings, argc, argv, FALSE);
|
||||
-
|
||||
- status = freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
-
|
||||
if (status)
|
||||
{
|
||||
BOOL list = settings->ListMonitors;
|
||||
+
|
||||
+ freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
+
|
||||
if (list)
|
||||
xf_list_monitors(xfc);
|
||||
|
||||
- freerdp_client_context_free(context);
|
||||
- if (list)
|
||||
- return 0;
|
||||
- return status;
|
||||
+ if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
+ rc = 0;
|
||||
+
|
||||
+ goto out;
|
||||
}
|
||||
|
||||
- freerdp_client_start(context);
|
||||
+ if (freerdp_client_start(context) != 0)
|
||||
+ goto out;
|
||||
|
||||
thread = freerdp_client_get_thread(context);
|
||||
|
||||
WaitForSingleObject(thread, INFINITE);
|
||||
GetExitCodeThread(thread, &dwExitCode);
|
||||
+ rc = xf_exit_code_from_disconnect_reason(dwExitCode);
|
||||
|
||||
freerdp_client_stop(context);
|
||||
|
||||
+out:
|
||||
freerdp_client_context_free(context);
|
||||
|
||||
- return xf_exit_code_from_disconnect_reason(dwExitCode);
|
||||
+ return rc;
|
||||
}
|
||||
diff --git a/winpr/include/winpr/cmdline.h b/winpr/include/winpr/cmdline.h
|
||||
index 865ee8f25c7..9276cda8eb1 100644
|
||||
--- a/winpr/include/winpr/cmdline.h
|
||||
+++ b/winpr/include/winpr/cmdline.h
|
||||
@@ -81,6 +81,7 @@
|
||||
#define COMMAND_LINE_STATUS_PRINT_HELP -2002
|
||||
#define COMMAND_LINE_STATUS_PRINT_VERSION -2003
|
||||
#define COMMAND_LINE_STATUS_PRINT_BUILDCONFIG -2004
|
||||
+#define COMMAND_LINE_STATUS_PRINT_LAST -2999
|
||||
|
||||
/* Command-Line Macros */
|
||||
|
||||
|
||||
From 531dd81836f2c97fcfcfeabdb9671fb76409ce8d Mon Sep 17 00:00:00 2001
|
||||
From: akallabeth <akallabeth@posteo.net>
|
||||
Date: Fri, 22 Jan 2021 08:40:03 +0100
|
||||
Subject: [PATCH 2/3] Refactored
|
||||
freerdp_client_settings_command_line_status_print_ex
|
||||
|
||||
Now returns 0 if help or version information was requested.
|
||||
---
|
||||
client/Sample/tf_freerdp.c | 7 ++-----
|
||||
client/Wayland/wlfreerdp.c | 5 +----
|
||||
client/Windows/cli/wfreerdp.c | 6 +-----
|
||||
client/X11/cli/xfreerdp.c | 5 +----
|
||||
client/common/cmdline.c | 14 +++++++++-----
|
||||
5 files changed, 14 insertions(+), 23 deletions(-)
|
||||
|
||||
diff --git a/client/Sample/tf_freerdp.c b/client/Sample/tf_freerdp.c
|
||||
index 49412cb417c..e9b9fe8397e 100644
|
||||
--- a/client/Sample/tf_freerdp.c
|
||||
+++ b/client/Sample/tf_freerdp.c
|
||||
@@ -340,11 +340,8 @@ int main(int argc, char* argv[])
|
||||
status = freerdp_client_settings_parse_command_line(context->settings, argc, argv, FALSE);
|
||||
if (status)
|
||||
{
|
||||
- freerdp_client_settings_command_line_status_print(context->settings, status, argc, argv);
|
||||
-
|
||||
- if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
- rc = 0;
|
||||
-
|
||||
+ rc = freerdp_client_settings_command_line_status_print(context->settings, status, argc,
|
||||
+ argv);
|
||||
goto fail;
|
||||
}
|
||||
|
||||
diff --git a/client/Wayland/wlfreerdp.c b/client/Wayland/wlfreerdp.c
|
||||
index d77b47986ea..4a583068968 100644
|
||||
--- a/client/Wayland/wlfreerdp.c
|
||||
+++ b/client/Wayland/wlfreerdp.c
|
||||
@@ -632,14 +632,11 @@ int main(int argc, char* argv[])
|
||||
{
|
||||
BOOL list = settings->ListMonitors;
|
||||
|
||||
- freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
+ rc = freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
|
||||
if (list)
|
||||
wlf_list_monitors(wlc);
|
||||
|
||||
- if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
- rc = 0;
|
||||
-
|
||||
goto fail;
|
||||
}
|
||||
|
||||
diff --git a/client/Windows/cli/wfreerdp.c b/client/Windows/cli/wfreerdp.c
|
||||
index b623067e98e..e325f84771f 100644
|
||||
--- a/client/Windows/cli/wfreerdp.c
|
||||
+++ b/client/Windows/cli/wfreerdp.c
|
||||
@@ -107,11 +107,7 @@ INT WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine
|
||||
|
||||
if (status)
|
||||
{
|
||||
- freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
-
|
||||
- if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
- rc = 0;
|
||||
-
|
||||
+ ret = freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
goto out;
|
||||
}
|
||||
|
||||
diff --git a/client/X11/cli/xfreerdp.c b/client/X11/cli/xfreerdp.c
|
||||
index a3505b24d3c..5b702194448 100644
|
||||
--- a/client/X11/cli/xfreerdp.c
|
||||
+++ b/client/X11/cli/xfreerdp.c
|
||||
@@ -61,14 +61,11 @@ int main(int argc, char* argv[])
|
||||
{
|
||||
BOOL list = settings->ListMonitors;
|
||||
|
||||
- freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
+ rc = freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
|
||||
if (list)
|
||||
xf_list_monitors(xfc);
|
||||
|
||||
- if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
- rc = 0;
|
||||
-
|
||||
goto out;
|
||||
}
|
||||
|
||||
diff --git a/client/common/cmdline.c b/client/common/cmdline.c
|
||||
index ed467afb7d0..dc8367b7cd2 100644
|
||||
--- a/client/common/cmdline.c
|
||||
+++ b/client/common/cmdline.c
|
||||
@@ -1403,14 +1403,14 @@ int freerdp_client_settings_command_line_status_print_ex(rdpSettings* settings,
|
||||
if (status == COMMAND_LINE_STATUS_PRINT_VERSION)
|
||||
{
|
||||
freerdp_client_print_version();
|
||||
- return COMMAND_LINE_STATUS_PRINT_VERSION;
|
||||
+ goto out;
|
||||
}
|
||||
|
||||
if (status == COMMAND_LINE_STATUS_PRINT_BUILDCONFIG)
|
||||
{
|
||||
freerdp_client_print_version();
|
||||
freerdp_client_print_buildconfig();
|
||||
- return COMMAND_LINE_STATUS_PRINT_BUILDCONFIG;
|
||||
+ goto out;
|
||||
}
|
||||
else if (status == COMMAND_LINE_STATUS_PRINT)
|
||||
{
|
||||
@@ -1465,15 +1465,19 @@ int freerdp_client_settings_command_line_status_print_ex(rdpSettings* settings,
|
||||
settings->ListMonitors = TRUE;
|
||||
}
|
||||
|
||||
- return COMMAND_LINE_STATUS_PRINT;
|
||||
+ goto out;
|
||||
}
|
||||
else if (status < 0)
|
||||
{
|
||||
freerdp_client_print_command_line_help_ex(argc, argv, custom);
|
||||
- return COMMAND_LINE_STATUS_PRINT_HELP;
|
||||
+ status = COMMAND_LINE_STATUS_PRINT_HELP;
|
||||
+ goto out;
|
||||
}
|
||||
|
||||
- return 0;
|
||||
+out:
|
||||
+ if (status <= COMMAND_LINE_STATUS_PRINT && status >= COMMAND_LINE_STATUS_PRINT_LAST)
|
||||
+ return 0;
|
||||
+ return status;
|
||||
}
|
||||
|
||||
static BOOL ends_with(const char* str, const char* ext)
|
||||
|
||||
From 050a68fec901030c7428852f8f536ace055eb2f7 Mon Sep 17 00:00:00 2001
|
||||
From: akallabeth <akallabeth@posteo.net>
|
||||
Date: Fri, 22 Jan 2021 09:32:51 +0100
|
||||
Subject: [PATCH 3/3] Do not eliminate original error status.
|
||||
|
||||
---
|
||||
client/common/cmdline.c | 1 -
|
||||
1 file changed, 1 deletion(-)
|
||||
|
||||
diff --git a/client/common/cmdline.c b/client/common/cmdline.c
|
||||
index dc8367b7cd2..66d3c4fffef 100644
|
||||
--- a/client/common/cmdline.c
|
||||
+++ b/client/common/cmdline.c
|
||||
@@ -1470,7 +1470,6 @@ int freerdp_client_settings_command_line_status_print_ex(rdpSettings* settings,
|
||||
else if (status < 0)
|
||||
{
|
||||
freerdp_client_print_command_line_help_ex(argc, argv, custom);
|
||||
- status = COMMAND_LINE_STATUS_PRINT_HELP;
|
||||
goto out;
|
||||
}
|
||||
|
146
Add-checks-for-bitmap-and-glyph-width-heigth-values.patch
Normal file
146
Add-checks-for-bitmap-and-glyph-width-heigth-values.patch
Normal file
@ -0,0 +1,146 @@
|
||||
From 4a4ecc32b160e93ee1e37e5617a0197e2d022643 Mon Sep 17 00:00:00 2001
|
||||
From: Armin Novak <armin.novak@thincast.com>
|
||||
Date: Thu, 4 Nov 2021 11:07:41 +0100
|
||||
Subject: [PATCH] Add checks for bitmap and glyph width/heigth values
|
||||
|
||||
CVE-2021-41160
|
||||
|
||||
https://github.com/FreeRDP/FreeRDP/pull/7349
|
||||
|
||||
Signed-off-by: Felipe Borges <felipeborges@gnome.org>
|
||||
---
|
||||
libfreerdp/core/orders.c | 14 ++++++++++++
|
||||
libfreerdp/core/surface.c | 45 +++++++++++++++++++++++++++++++++++++++
|
||||
libfreerdp/core/update.c | 7 ++++++
|
||||
3 files changed, 66 insertions(+)
|
||||
|
||||
diff --git a/libfreerdp/core/orders.c b/libfreerdp/core/orders.c
|
||||
index 74870fae6..44d23a61a 100644
|
||||
--- a/libfreerdp/core/orders.c
|
||||
+++ b/libfreerdp/core/orders.c
|
||||
@@ -1848,6 +1848,13 @@ static BOOL update_read_fast_glyph_order(wStream* s, const ORDER_INFO* orderInfo
|
||||
new_cb = ((glyph->cx + 7) / 8) * glyph->cy;
|
||||
new_cb += ((new_cb % 4) > 0) ? 4 - (new_cb % 4) : 0;
|
||||
|
||||
+ if ((glyph->cx == 0) || (glyph->cy == 0))
|
||||
+ {
|
||||
+ WLog_ERR(TAG, "GLYPH_DATA_V2::cx=%" PRIu32 ", GLYPH_DATA_V2::cy=%" PRIu32,
|
||||
+ glyph->cx, glyph->cy);
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
if (fastGlyph->cbData < new_cb)
|
||||
return FALSE;
|
||||
|
||||
@@ -2825,6 +2832,13 @@ update_read_create_offscreen_bitmap_order(wStream* s,
|
||||
Stream_Read_UINT16(s, create_offscreen_bitmap->cy); /* cy (2 bytes) */
|
||||
deleteList = &(create_offscreen_bitmap->deleteList);
|
||||
|
||||
+ if ((create_offscreen_bitmap->cx == 0) || (create_offscreen_bitmap->cy == 0))
|
||||
+ {
|
||||
+ WLog_ERR(TAG, "Invalid OFFSCREEN_DELETE_LIST: cx=%" PRIu16 ", cy=%" PRIu16,
|
||||
+ create_offscreen_bitmap->cx, create_offscreen_bitmap->cy);
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
if (deleteListPresent)
|
||||
{
|
||||
UINT32 i;
|
||||
diff --git a/libfreerdp/core/surface.c b/libfreerdp/core/surface.c
|
||||
index d5c709885..ca89d230c 100644
|
||||
--- a/libfreerdp/core/surface.c
|
||||
+++ b/libfreerdp/core/surface.c
|
||||
@@ -21,6 +21,8 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
+#include <assert.h>
|
||||
+
|
||||
#include <freerdp/utils/pcap.h>
|
||||
#include <freerdp/log.h>
|
||||
|
||||
@@ -62,6 +64,13 @@ static BOOL update_recv_surfcmd_bitmap_ex(wStream* s, TS_BITMAP_DATA_EX* bmp)
|
||||
Stream_Read_UINT16(s, bmp->height);
|
||||
Stream_Read_UINT32(s, bmp->bitmapDataLength);
|
||||
|
||||
+ if ((bmp->width == 0) || (bmp->height == 0))
|
||||
+ {
|
||||
+ WLog_ERR(TAG, "invalid size value width=%" PRIu16 ", height=%" PRIu16, bmp->width,
|
||||
+ bmp->height);
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
if ((bmp->bpp < 1) || (bmp->bpp > 32))
|
||||
{
|
||||
WLog_ERR(TAG, "invalid bpp value %" PRIu32 "", bmp->bpp);
|
||||
@@ -85,6 +94,39 @@ static BOOL update_recv_surfcmd_bitmap_ex(wStream* s, TS_BITMAP_DATA_EX* bmp)
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
+static BOOL update_recv_surfcmd_is_rect_valid(const rdpContext* context,
|
||||
+ const SURFACE_BITS_COMMAND* cmd)
|
||||
+{
|
||||
+ assert(context);
|
||||
+ assert(context->settings);
|
||||
+ assert(cmd);
|
||||
+
|
||||
+ /* We need a rectangle with left/top being smaller than right/bottom.
|
||||
+ * Also do not allow empty rectangles. */
|
||||
+ if ((cmd->destTop >= cmd->destBottom) || (cmd->destLeft >= cmd->destRight))
|
||||
+ {
|
||||
+ WLog_WARN(TAG,
|
||||
+ "Empty surface bits command rectangle: %" PRIu16 "x%" PRIu16 "-%" PRIu16
|
||||
+ "x%" PRIu16,
|
||||
+ cmd->destLeft, cmd->destTop, cmd->destRight, cmd->destBottom);
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
+ /* The rectangle needs to fit into our session size */
|
||||
+ if ((cmd->destRight > context->settings->DesktopWidth) ||
|
||||
+ (cmd->destBottom > context->settings->DesktopHeight))
|
||||
+ {
|
||||
+ WLog_WARN(TAG,
|
||||
+ "Invalid surface bits command rectangle: %" PRIu16 "x%" PRIu16 "-%" PRIu16
|
||||
+ "x%" PRIu16 " does not fit %" PRIu32 "x%" PRIu32,
|
||||
+ cmd->destLeft, cmd->destTop, cmd->destRight, cmd->destBottom,
|
||||
+ context->settings->DesktopWidth, context->settings->DesktopHeight);
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
+ return TRUE;
|
||||
+}
|
||||
+
|
||||
static BOOL update_recv_surfcmd_surface_bits(rdpUpdate* update, wStream* s, UINT16 cmdType)
|
||||
{
|
||||
SURFACE_BITS_COMMAND cmd = { 0 };
|
||||
@@ -98,6 +140,9 @@ static BOOL update_recv_surfcmd_surface_bits(rdpUpdate* update, wStream* s, UINT
|
||||
Stream_Read_UINT16(s, cmd.destRight);
|
||||
Stream_Read_UINT16(s, cmd.destBottom);
|
||||
|
||||
+ if (!update_recv_surfcmd_is_rect_valid(update->context, &cmd))
|
||||
+ goto fail;
|
||||
+
|
||||
if (!update_recv_surfcmd_bitmap_ex(s, &cmd.bmp))
|
||||
goto fail;
|
||||
|
||||
diff --git a/libfreerdp/core/update.c b/libfreerdp/core/update.c
|
||||
index ebb82fc2d..e137c3de8 100644
|
||||
--- a/libfreerdp/core/update.c
|
||||
+++ b/libfreerdp/core/update.c
|
||||
@@ -99,6 +99,13 @@ static BOOL update_read_bitmap_data(rdpUpdate* update, wStream* s, BITMAP_DATA*
|
||||
Stream_Read_UINT16(s, bitmapData->flags);
|
||||
Stream_Read_UINT16(s, bitmapData->bitmapLength);
|
||||
|
||||
+ if ((bitmapData->width == 0) || (bitmapData->height == 0))
|
||||
+ {
|
||||
+ WLog_ERR(TAG, "Invalid BITMAP_DATA: width=%" PRIu16 ", height=%" PRIu16, bitmapData->width,
|
||||
+ bitmapData->height);
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
if (bitmapData->flags & BITMAP_COMPRESSION)
|
||||
{
|
||||
if (!(bitmapData->flags & NO_BITMAP_COMPRESSION_HDR))
|
||||
--
|
||||
2.32.0
|
||||
|
49
Fix-monitor-list-flag-being-ignored-on-X11-Wayland.patch
Normal file
49
Fix-monitor-list-flag-being-ignored-on-X11-Wayland.patch
Normal file
@ -0,0 +1,49 @@
|
||||
From bf9bce2c3e6c716cc708716484124c1fb47cb531 Mon Sep 17 00:00:00 2001
|
||||
From: Max Roncace <me@caseif.net>
|
||||
Date: Wed, 24 Feb 2021 17:44:28 -0500
|
||||
Subject: [PATCH] Fix /monitor-list flag being ignored on X11/Wayland
|
||||
|
||||
---
|
||||
client/Wayland/wlfreerdp.c | 4 +++-
|
||||
client/X11/cli/xfreerdp.c | 4 +++-
|
||||
2 files changed, 6 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/client/Wayland/wlfreerdp.c b/client/Wayland/wlfreerdp.c
|
||||
index aca734211..26c5452a5 100644
|
||||
--- a/client/Wayland/wlfreerdp.c
|
||||
+++ b/client/Wayland/wlfreerdp.c
|
||||
@@ -651,10 +651,12 @@ int main(int argc, char* argv[])
|
||||
status = freerdp_client_settings_parse_command_line(settings, argc, argv, FALSE);
|
||||
if (status)
|
||||
{
|
||||
- BOOL list = settings->ListMonitors;
|
||||
+ BOOL list;
|
||||
|
||||
rc = freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
|
||||
+ list = settings->ListMonitors;
|
||||
+
|
||||
if (list)
|
||||
wlf_list_monitors(wlc);
|
||||
|
||||
diff --git a/client/X11/cli/xfreerdp.c b/client/X11/cli/xfreerdp.c
|
||||
index 5b7021944..786a7eb5d 100644
|
||||
--- a/client/X11/cli/xfreerdp.c
|
||||
+++ b/client/X11/cli/xfreerdp.c
|
||||
@@ -59,10 +59,12 @@ int main(int argc, char* argv[])
|
||||
status = freerdp_client_settings_parse_command_line(context->settings, argc, argv, FALSE);
|
||||
if (status)
|
||||
{
|
||||
- BOOL list = settings->ListMonitors;
|
||||
+ BOOL list;
|
||||
|
||||
rc = freerdp_client_settings_command_line_status_print(settings, status, argc, argv);
|
||||
|
||||
+ list = settings->ListMonitors;
|
||||
+
|
||||
if (list)
|
||||
xf_list_monitors(xfc);
|
||||
|
||||
--
|
||||
2.37.1
|
||||
|
433
Implement-missing-TSG-debug-functions.patch
Normal file
433
Implement-missing-TSG-debug-functions.patch
Normal file
@ -0,0 +1,433 @@
|
||||
From ea20ba13ec764b30d6642cd570929e71e97d00f1 Mon Sep 17 00:00:00 2001
|
||||
From: akallabeth <akallabeth@posteo.net>
|
||||
Date: Tue, 12 Oct 2021 13:33:41 +0200
|
||||
Subject: [PATCH] Implemented missing TSG debug functions
|
||||
|
||||
(cherry picked from commit c06c4638061b0305a269dbb8f7c87009cf886f02)
|
||||
---
|
||||
libfreerdp/core/gateway/tsg.c | 330 ++++++++++++++++++++++++++++++++--
|
||||
1 file changed, 313 insertions(+), 17 deletions(-)
|
||||
|
||||
diff --git a/libfreerdp/core/gateway/tsg.c b/libfreerdp/core/gateway/tsg.c
|
||||
index 1626b91..3376fb0 100644
|
||||
--- a/libfreerdp/core/gateway/tsg.c
|
||||
+++ b/libfreerdp/core/gateway/tsg.c
|
||||
@@ -24,6 +24,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
+#include <winpr/assert.h>
|
||||
#include <winpr/crt.h>
|
||||
#include <winpr/ndr.h>
|
||||
#include <winpr/error.h>
|
||||
@@ -39,13 +40,14 @@
|
||||
|
||||
#define TAG FREERDP_TAG("core.gateway.tsg")
|
||||
|
||||
+#define TSG_CAPABILITY_TYPE_NAP 0x00000001
|
||||
+
|
||||
#define TSG_PACKET_TYPE_HEADER 0x00004844
|
||||
#define TSG_PACKET_TYPE_VERSIONCAPS 0x00005643
|
||||
#define TSG_PACKET_TYPE_QUARCONFIGREQUEST 0x00005143
|
||||
#define TSG_PACKET_TYPE_QUARREQUEST 0x00005152
|
||||
#define TSG_PACKET_TYPE_RESPONSE 0x00005052
|
||||
#define TSG_PACKET_TYPE_QUARENC_RESPONSE 0x00004552
|
||||
-#define TSG_CAPABILITY_TYPE_NAP 0x00000001
|
||||
#define TSG_PACKET_TYPE_CAPS_RESPONSE 0x00004350
|
||||
#define TSG_PACKET_TYPE_MSGREQUEST_PACKET 0x00004752
|
||||
#define TSG_PACKET_TYPE_MESSAGE_PACKET 0x00004750
|
||||
@@ -308,16 +310,35 @@ static BOOL tsg_print(char** buffer, size_t* len, const char* fmt, ...)
|
||||
static BOOL tsg_packet_header_to_string(char** buffer, size_t* length,
|
||||
const TSG_PACKET_HEADER* header)
|
||||
{
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(header);
|
||||
+
|
||||
return tsg_print(buffer, length,
|
||||
"header { ComponentId=0x%04" PRIx16 ", PacketId=0x%04" PRIx16 " }",
|
||||
header->ComponentId, header->PacketId);
|
||||
}
|
||||
|
||||
+static BOOL tsg_type_capability_nap_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_CAPABILITY_NAP* cur)
|
||||
+{
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(cur);
|
||||
+
|
||||
+ return tsg_print(buffer, length, "%s { capabilities=0x%08" PRIx32 " }",
|
||||
+ tsg_packet_id_to_string(TSG_CAPABILITY_TYPE_NAP), cur->capabilities);
|
||||
+}
|
||||
+
|
||||
static BOOL tsg_packet_capabilities_to_string(char** buffer, size_t* length,
|
||||
const TSG_PACKET_CAPABILITIES* caps, UINT32 numCaps)
|
||||
{
|
||||
UINT32 x;
|
||||
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
if (!tsg_print(buffer, length, "capabilities { "))
|
||||
return FALSE;
|
||||
|
||||
@@ -327,9 +348,7 @@ static BOOL tsg_packet_capabilities_to_string(char** buffer, size_t* length,
|
||||
switch (cur->capabilityType)
|
||||
{
|
||||
case TSG_CAPABILITY_TYPE_NAP:
|
||||
- if (!tsg_print(buffer, length, "%s { capabilities=0x%08" PRIx32 " }",
|
||||
- tsg_packet_id_to_string(cur->capabilityType),
|
||||
- cur->tsgPacket.tsgCapNap.capabilities))
|
||||
+ if (!tsg_type_capability_nap_to_string(buffer, length, &cur->tsgPacket.tsgCapNap))
|
||||
return FALSE;
|
||||
break;
|
||||
default:
|
||||
@@ -344,6 +363,10 @@ static BOOL tsg_packet_capabilities_to_string(char** buffer, size_t* length,
|
||||
static BOOL tsg_packet_versioncaps_to_string(char** buffer, size_t* length,
|
||||
const TSG_PACKET_VERSIONCAPS* caps)
|
||||
{
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
if (!tsg_print(buffer, length, "versioncaps { "))
|
||||
return FALSE;
|
||||
if (!tsg_packet_header_to_string(buffer, length, &caps->tsgHeader))
|
||||
@@ -365,6 +388,277 @@ static BOOL tsg_packet_versioncaps_to_string(char** buffer, size_t* length,
|
||||
return tsg_print(buffer, length, " }");
|
||||
}
|
||||
|
||||
+static BOOL tsg_packet_quarconfigrequest_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_QUARCONFIGREQUEST* caps)
|
||||
+{
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "quarconfigrequest { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, " "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, " flags=0x%08" PRIx32, caps->flags))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_quarrequest_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_QUARREQUEST* caps)
|
||||
+{
|
||||
+ BOOL rc = FALSE;
|
||||
+ char* name = NULL;
|
||||
+ char* strdata = NULL;
|
||||
+
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "quarrequest { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, " "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (caps->nameLength > 0)
|
||||
+ {
|
||||
+ if (ConvertFromUnicode(CP_UTF8, 0, caps->machineName, caps->nameLength, &name, 0, NULL,
|
||||
+ NULL) < 0)
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
+ strdata = winpr_BinToHexString(caps->data, caps->dataLen, TRUE);
|
||||
+ if (strdata || (caps->dataLen == 0))
|
||||
+ rc = tsg_print(buffer, length,
|
||||
+ " flags=0x%08" PRIx32 ", machineName=%s [%" PRIu32 "], data[%" PRIu32 "]=%s",
|
||||
+ caps->flags, name, caps->nameLength, caps->dataLen, strdata);
|
||||
+ free(name);
|
||||
+ free(strdata);
|
||||
+ if (!rc)
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static const char* tsg_bool_to_string(BOOL val)
|
||||
+{
|
||||
+ if (val)
|
||||
+ return "true";
|
||||
+ return "false";
|
||||
+}
|
||||
+
|
||||
+static const char* tsg_redirection_flags_to_string(char* buffer, size_t size,
|
||||
+ const TSG_REDIRECTION_FLAGS* flags)
|
||||
+{
|
||||
+ WINPR_ASSERT(buffer || (size == 0));
|
||||
+ WINPR_ASSERT(flags);
|
||||
+
|
||||
+ _snprintf(buffer, size,
|
||||
+ "enableAllRedirections=%s, disableAllRedirections=%s, driveRedirectionDisabled=%s, "
|
||||
+ "printerRedirectionDisabled=%s, portRedirectionDisabled=%s, reserved=%s, "
|
||||
+ "clipboardRedirectionDisabled=%s, pnpRedirectionDisabled=%s",
|
||||
+ tsg_bool_to_string(flags->enableAllRedirections),
|
||||
+ tsg_bool_to_string(flags->disableAllRedirections),
|
||||
+ tsg_bool_to_string(flags->driveRedirectionDisabled),
|
||||
+ tsg_bool_to_string(flags->printerRedirectionDisabled),
|
||||
+ tsg_bool_to_string(flags->portRedirectionDisabled),
|
||||
+ tsg_bool_to_string(flags->reserved),
|
||||
+ tsg_bool_to_string(flags->clipboardRedirectionDisabled),
|
||||
+ tsg_bool_to_string(flags->pnpRedirectionDisabled));
|
||||
+ return buffer;
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_response_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_RESPONSE* caps)
|
||||
+{
|
||||
+ BOOL rc = FALSE;
|
||||
+ char* strdata = NULL;
|
||||
+ char tbuffer[8192] = { 0 };
|
||||
+
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "response { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, " "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ strdata = winpr_BinToHexString(caps->responseData, caps->responseDataLen, TRUE);
|
||||
+ if (strdata || (caps->responseDataLen == 0))
|
||||
+ rc = tsg_print(
|
||||
+ buffer, length,
|
||||
+ " flags=0x%08" PRIx32 ", reserved=0x%08" PRIx32 ", responseData[%" PRIu32
|
||||
+ "]=%s, redirectionFlags={ %s }",
|
||||
+ caps->flags, caps->reserved, caps->responseDataLen, strdata,
|
||||
+ tsg_redirection_flags_to_string(tbuffer, ARRAYSIZE(tbuffer), &caps->redirectionFlags));
|
||||
+ free(strdata);
|
||||
+ if (!rc)
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_quarenc_response_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_QUARENC_RESPONSE* caps)
|
||||
+{
|
||||
+ BOOL rc = FALSE;
|
||||
+ char* strdata = NULL;
|
||||
+ RPC_CSTR uuid;
|
||||
+ char tbuffer[8192] = { 0 };
|
||||
+ size_t size = ARRAYSIZE(tbuffer);
|
||||
+ char* ptbuffer = tbuffer;
|
||||
+
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "quarenc_response { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, " "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (caps->certChainLen > 0)
|
||||
+ {
|
||||
+ if (ConvertFromUnicode(CP_UTF8, 0, caps->certChainData, caps->certChainLen, &strdata, 0,
|
||||
+ NULL, NULL) <= 0)
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+
|
||||
+ tsg_packet_versioncaps_to_string(&ptbuffer, &size, caps->versionCaps);
|
||||
+ UuidToStringA(&caps->nonce, &uuid);
|
||||
+ if (strdata || (caps->certChainLen == 0))
|
||||
+ rc =
|
||||
+ tsg_print(buffer, length,
|
||||
+ " flags=0x%08" PRIx32 ", certChain[%" PRIu32 "]=%s, nonce=%s, versionCaps=%s",
|
||||
+ caps->flags, caps->certChainLen, strdata, uuid, tbuffer);
|
||||
+ free(strdata);
|
||||
+ free(uuid);
|
||||
+ if (!rc)
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_message_response_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_MSG_RESPONSE* caps)
|
||||
+{
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "msg_response { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length,
|
||||
+ " msgID=0x%08" PRIx32 ", msgType=0x%08" PRIx32 ", isMsgPresent=%" PRId32,
|
||||
+ caps->msgID, caps->msgType, caps->isMsgPresent))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_caps_response_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_CAPS_RESPONSE* caps)
|
||||
+{
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "caps_response { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_packet_quarenc_response_to_string(buffer, length, &caps->pktQuarEncResponse))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_packet_message_response_to_string(buffer, length, &caps->pktConsentMessage))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_message_request_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_MSG_REQUEST* caps)
|
||||
+{
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "caps_message_request { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, " maxMessagesPerBatch=%" PRIu32, caps->maxMessagesPerBatch))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_auth_to_string(char** buffer, size_t* length, const TSG_PACKET_AUTH* caps)
|
||||
+{
|
||||
+ BOOL rc = FALSE;
|
||||
+ char* strdata = NULL;
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "caps_message_request { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_packet_versioncaps_to_string(buffer, length, &caps->tsgVersionCaps))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ strdata = winpr_BinToHexString(caps->cookie, caps->cookieLen, TRUE);
|
||||
+ if (strdata || (caps->cookieLen == 0))
|
||||
+ rc = tsg_print(buffer, length, " cookie[%" PRIu32 "]=%s", caps->cookieLen, strdata);
|
||||
+ free(strdata);
|
||||
+ if (!rc)
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
+static BOOL tsg_packet_reauth_to_string(char** buffer, size_t* length,
|
||||
+ const TSG_PACKET_REAUTH* caps)
|
||||
+{
|
||||
+ BOOL rc = FALSE;
|
||||
+ WINPR_ASSERT(buffer);
|
||||
+ WINPR_ASSERT(length);
|
||||
+ WINPR_ASSERT(caps);
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, "caps_message_request { "))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ if (!tsg_print(buffer, length, " tunnelContext=0x%08" PRIx32 ", packetId=%s [0x%08" PRIx32 "]",
|
||||
+ caps->tunnelContext, tsg_packet_id_to_string(caps->packetId), caps->packetId))
|
||||
+ return FALSE;
|
||||
+
|
||||
+ switch (caps->packetId)
|
||||
+ {
|
||||
+ case TSG_PACKET_TYPE_VERSIONCAPS:
|
||||
+ rc = tsg_packet_versioncaps_to_string(buffer, length,
|
||||
+ caps->tsgInitialPacket.packetVersionCaps);
|
||||
+ break;
|
||||
+ case TSG_PACKET_TYPE_AUTH:
|
||||
+ rc = tsg_packet_auth_to_string(buffer, length, caps->tsgInitialPacket.packetAuth);
|
||||
+ break;
|
||||
+ default:
|
||||
+ rc = tsg_print(buffer, length, "TODO: Unhandled packet type %s [0x%08" PRIx32 "]",
|
||||
+ tsg_packet_id_to_string(caps->packetId), caps->packetId);
|
||||
+ break;
|
||||
+ }
|
||||
+
|
||||
+ if (!rc)
|
||||
+ return FALSE;
|
||||
+
|
||||
+ return tsg_print(buffer, length, " }");
|
||||
+}
|
||||
+
|
||||
static const char* tsg_packet_to_string(const TSG_PACKET* packet)
|
||||
{
|
||||
size_t len = 8192;
|
||||
@@ -387,43 +681,45 @@ static const char* tsg_packet_to_string(const TSG_PACKET* packet)
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_QUARCONFIGREQUEST:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_quarconfigrequest_to_string(&buffer, &len,
|
||||
+ packet->tsgPacket.packetQuarConfigRequest))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_QUARREQUEST:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_quarrequest_to_string(&buffer, &len,
|
||||
+ packet->tsgPacket.packetQuarRequest))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_RESPONSE:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_response_to_string(&buffer, &len, packet->tsgPacket.packetResponse))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_QUARENC_RESPONSE:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
- goto fail;
|
||||
- break;
|
||||
- case TSG_CAPABILITY_TYPE_NAP:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_quarenc_response_to_string(&buffer, &len,
|
||||
+ packet->tsgPacket.packetQuarEncResponse))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_CAPS_RESPONSE:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_caps_response_to_string(&buffer, &len,
|
||||
+ packet->tsgPacket.packetCapsResponse))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_MSGREQUEST_PACKET:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_message_request_to_string(&buffer, &len,
|
||||
+ packet->tsgPacket.packetMsgRequest))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_MESSAGE_PACKET:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_message_response_to_string(&buffer, &len,
|
||||
+ packet->tsgPacket.packetMsgResponse))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_AUTH:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_auth_to_string(&buffer, &len, packet->tsgPacket.packetAuth))
|
||||
goto fail;
|
||||
break;
|
||||
case TSG_PACKET_TYPE_REAUTH:
|
||||
- if (!tsg_print(&buffer, &len, "TODO"))
|
||||
+ if (!tsg_packet_reauth_to_string(&buffer, &len, packet->tsgPacket.packetReauth))
|
||||
goto fail;
|
||||
break;
|
||||
default:
|
4950
Refactored-RPC-gateway-parser.patch
Normal file
4950
Refactored-RPC-gateway-parser.patch
Normal file
File diff suppressed because it is too large
Load Diff
428
freerdp.spec
Normal file
428
freerdp.spec
Normal file
@ -0,0 +1,428 @@
|
||||
# Can be rebuilt with FFmpeg/H264 support enabled by passing "--with=ffmpeg",
|
||||
# "--with=x264" or "--with=openh264" to mock/rpmbuild; or by globally setting
|
||||
# these variables:
|
||||
|
||||
#global _with_ffmpeg 1
|
||||
#global _with_x264 1
|
||||
#global _with_openh264 1
|
||||
|
||||
# Momentarily disable GSS support
|
||||
# https://github.com/FreeRDP/FreeRDP/issues/4348
|
||||
#global _with_gss 1
|
||||
|
||||
# Disable server support in RHEL
|
||||
# https://bugzilla.redhat.com/show_bug.cgi?id=1639165
|
||||
%{!?rhel:%global _with_server 1}
|
||||
|
||||
# Disable support for missing codecs in RHEL
|
||||
%{!?rhel:%global _with_soxr 1}
|
||||
%if 0%{?fedora} || 0%{?rhel} >= 8
|
||||
%global _with_lame 1
|
||||
%endif
|
||||
|
||||
Name: freerdp
|
||||
Version: 2.2.0
|
||||
Release: 8%{?dist}
|
||||
Epoch: 2
|
||||
Summary: Free implementation of the Remote Desktop Protocol (RDP)
|
||||
License: ASL 2.0
|
||||
URL: http://www.freerdp.com/
|
||||
|
||||
Source0: https://github.com/FreeRDP/FreeRDP/archive/%{version}/FreeRDP-%{version}.tar.gz
|
||||
|
||||
# https://bugzilla.redhat.com/show_bug.cgi?id=1910029
|
||||
Patch0: 6741.patch
|
||||
|
||||
# CVE-2021-41160 freerdp: improper region checks in all clients allow out of bound write to memory
|
||||
Patch1: Add-checks-for-bitmap-and-glyph-width-heigth-values.patch
|
||||
|
||||
# CVE-2021-41159 freerdp: improper client input validation for gateway connections allows to overwrite memory
|
||||
Patch2: Implement-missing-TSG-debug-functions.patch
|
||||
Patch3: Refactored-RPC-gateway-parser.patch
|
||||
|
||||
# https://bugzilla.redhat.com/show_bug.cgi?id=2108866
|
||||
Patch4: Fix-monitor-list-flag-being-ignored-on-X11-Wayland.patch
|
||||
|
||||
BuildRequires: gcc
|
||||
BuildRequires: gcc-c++
|
||||
BuildRequires: alsa-lib-devel
|
||||
BuildRequires: cmake >= 2.8
|
||||
BuildRequires: cups-devel
|
||||
BuildRequires: gsm-devel
|
||||
%{?_with_lame:BuildRequires: lame-devel}
|
||||
BuildRequires: libicu-devel
|
||||
BuildRequires: libjpeg-turbo-devel
|
||||
BuildRequires: libX11-devel
|
||||
BuildRequires: libXcursor-devel
|
||||
BuildRequires: libXdamage-devel
|
||||
BuildRequires: libXext-devel
|
||||
BuildRequires: libXi-devel
|
||||
BuildRequires: libXinerama-devel
|
||||
BuildRequires: libxkbfile-devel
|
||||
BuildRequires: libXrandr-devel
|
||||
%{?_with_server:BuildRequires: libXtst-devel}
|
||||
BuildRequires: libXv-devel
|
||||
%{?_with_openh264:BuildRequires: openh264-devel}
|
||||
%{?_with_x264:BuildRequires: x264-devel}
|
||||
%{?_with_server:BuildRequires: pam-devel}
|
||||
BuildRequires: xmlto
|
||||
BuildRequires: zlib-devel
|
||||
BuildRequires: multilib-rpm-config
|
||||
|
||||
BuildRequires: pkgconfig(cairo)
|
||||
BuildRequires: pkgconfig(dbus-1)
|
||||
BuildRequires: pkgconfig(dbus-glib-1)
|
||||
BuildRequires: pkgconfig(glib-2.0)
|
||||
BuildRequires: pkgconfig(gstreamer-1.0)
|
||||
BuildRequires: pkgconfig(gstreamer-base-1.0)
|
||||
BuildRequires: pkgconfig(gstreamer-app-1.0)
|
||||
BuildRequires: pkgconfig(gstreamer-audio-1.0)
|
||||
BuildRequires: pkgconfig(gstreamer-fft-1.0)
|
||||
BuildRequires: pkgconfig(gstreamer-pbutils-1.0)
|
||||
BuildRequires: pkgconfig(gstreamer-video-1.0)
|
||||
%{?_with_gss:BuildRequires: pkgconfig(krb5) >= 1.13}
|
||||
BuildRequires: pkgconfig(libpcsclite)
|
||||
BuildRequires: pkgconfig(libpulse)
|
||||
BuildRequires: pkgconfig(libsystemd)
|
||||
BuildRequires: pkgconfig(libusb-1.0)
|
||||
BuildRequires: pkgconfig(openssl)
|
||||
%{?_with_soxr:BuildRequires: pkgconfig(soxr)}
|
||||
BuildRequires: pkgconfig(wayland-client)
|
||||
BuildRequires: pkgconfig(wayland-scanner)
|
||||
BuildRequires: pkgconfig(xkbcommon)
|
||||
|
||||
%{?_with_ffmpeg:
|
||||
BuildRequires: pkgconfig(libavcodec) >= 57.48.101
|
||||
BuildRequires: pkgconfig(libavutil)
|
||||
}
|
||||
|
||||
Provides: xfreerdp = %{?epoch}:%{version}-%{release}
|
||||
Requires: %{name}-libs%{?_isa} = %{?epoch}:%{version}-%{release}
|
||||
Requires: libwinpr%{?_isa} = %{?epoch}:%{version}-%{release}
|
||||
|
||||
%description
|
||||
The xfreerdp & wlfreerdp Remote Desktop Protocol (RDP) clients from the FreeRDP
|
||||
project.
|
||||
|
||||
xfreerdp & wlfreerdp can connect to RDP servers such as Microsoft Windows
|
||||
machines, xrdp and VirtualBox.
|
||||
|
||||
%package libs
|
||||
Summary: Core libraries implementing the RDP protocol
|
||||
Requires: libwinpr%{?_isa} = %{?epoch}:%{version}-%{release}
|
||||
Obsoletes: %{name}-plugins < 1:1.1.0
|
||||
Provides: %{name}-plugins = %{?epoch}:%{version}-%{release}
|
||||
%description libs
|
||||
libfreerdp-core can be embedded in applications.
|
||||
|
||||
libfreerdp-channels and libfreerdp-kbd might be convenient to use in X
|
||||
applications together with libfreerdp-core.
|
||||
|
||||
libfreerdp-core can be extended with plugins handling RDP channels.
|
||||
|
||||
%package devel
|
||||
Summary: Development files for %{name}
|
||||
Requires: %{name}-libs%{?_isa} = %{?epoch}:%{version}-%{release}
|
||||
Requires: pkgconfig
|
||||
Requires: cmake >= 2.8
|
||||
|
||||
%description devel
|
||||
The %{name}-devel package contains libraries and header files for developing
|
||||
applications that use %{name}-libs.
|
||||
|
||||
%{?_with_server:
|
||||
%package server
|
||||
Summary: Server support for %{name}
|
||||
Requires: libwinpr%{?_isa} = %{?epoch}:%{version}-%{release}
|
||||
Requires: %{name}-libs%{?_isa} = %{?epoch}:%{version}-%{release}
|
||||
|
||||
%description server
|
||||
The %{name}-server package contains servers which can export a desktop via
|
||||
the RDP protocol.
|
||||
}
|
||||
|
||||
%package -n libwinpr
|
||||
Summary: Windows Portable Runtime
|
||||
Provides: %{name}-libwinpr = %{?epoch}:%{version}-%{release}
|
||||
Obsoletes: %{name}-libwinpr < 1:1.2.0
|
||||
|
||||
%description -n libwinpr
|
||||
WinPR provides API compatibility for applications targeting non-Windows
|
||||
environments. When on Windows, the original native API is being used instead of
|
||||
the equivalent WinPR implementation, without having to modify the code using it.
|
||||
|
||||
%package -n libwinpr-devel
|
||||
Summary: Windows Portable Runtime development files
|
||||
Requires: libwinpr%{?_isa} = %{?epoch}:%{version}-%{release}
|
||||
Requires: pkgconfig
|
||||
Requires: cmake >= 2.8
|
||||
|
||||
%description -n libwinpr-devel
|
||||
The %{name}-libwinpr-devel package contains libraries and header files for
|
||||
developing applications that use %{name}-libwinpr.
|
||||
|
||||
%prep
|
||||
%autosetup -p1 -n FreeRDP-%{version}
|
||||
|
||||
# Rpmlint fixes
|
||||
find . -name "*.h" -exec chmod 664 {} \;
|
||||
find . -name "*.c" -exec chmod 664 {} \;
|
||||
|
||||
%build
|
||||
%cmake %{?_cmake_skip_rpath} \
|
||||
-DCMAKE_INSTALL_LIBDIR:PATH=%{_lib} \
|
||||
-DWITH_ALSA=ON \
|
||||
-DWITH_CUPS=ON \
|
||||
-DWITH_CHANNELS=ON -DBUILTIN_CHANNELS=OFF \
|
||||
-DWITH_CLIENT=ON \
|
||||
-DWITH_DIRECTFB=OFF \
|
||||
-DWITH_FFMPEG=%{?_with_ffmpeg:ON}%{?!_with_ffmpeg:OFF} \
|
||||
-DWITH_GSM=ON \
|
||||
-DWITH_GSSAPI=%{?_with_gss:ON}%{?!_with_gss:OFF} \
|
||||
-DWITH_GSTREAMER_1_0=ON -DWITH_GSTREAMER_0_10=OFF \
|
||||
-DGSTREAMER_1_0_INCLUDE_DIRS=%{_includedir}/gstreamer-1.0 \
|
||||
-DWITH_ICU=ON \
|
||||
-DWITH_IPP=OFF \
|
||||
-DWITH_JPEG=ON \
|
||||
-DWITH_LAME=%{?_with_lame:ON}%{?!_with_lame:OFF} \
|
||||
-DWITH_MANPAGES=ON \
|
||||
-DWITH_OPENH264=%{?_with_openh264:ON}%{?!_with_openh264:OFF} \
|
||||
-DWITH_OPENSSL=ON \
|
||||
-DWITH_PCSC=ON \
|
||||
-DWITH_PULSE=ON \
|
||||
-DWITH_SERVER=%{?_with_server:ON}%{?!_with_server:OFF} \
|
||||
-DWITH_SERVER_INTERFACE=%{?_with_server:ON}%{?!_with_server:OFF} \
|
||||
-DWITH_SHADOW_X11=%{?_with_server:ON}%{?!_with_server:OFF} \
|
||||
-DWITH_SHADOW_MAC=%{?_with_server:ON}%{?!_with_server:OFF} \
|
||||
-DWITH_SOXR=%{?_with_soxr:ON}%{?!_with_soxr:OFF} \
|
||||
-DWITH_WAYLAND=ON \
|
||||
-DWITH_X11=ON \
|
||||
-DWITH_X264=%{?_with_x264:ON}%{?!_with_x264:OFF} \
|
||||
-DWITH_XCURSOR=ON \
|
||||
-DWITH_XEXT=ON \
|
||||
-DWITH_XKBFILE=ON \
|
||||
-DWITH_XI=ON \
|
||||
-DWITH_XINERAMA=ON \
|
||||
-DWITH_XRENDER=ON \
|
||||
-DWITH_XTEST=%{?_with_server:ON}%{?!_with_server:OFF} \
|
||||
-DWITH_XV=ON \
|
||||
-DWITH_ZLIB=ON \
|
||||
%ifarch x86_64
|
||||
-DWITH_SSE2=ON \
|
||||
-DWITH_VAAPI=%{?_with_ffmpeg:ON}%{?!_with_ffmpeg:OFF} \
|
||||
%else
|
||||
-DWITH_SSE2=OFF \
|
||||
%endif
|
||||
%ifarch armv7hl
|
||||
-DARM_FP_ABI=hard \
|
||||
-DWITH_NEON=OFF \
|
||||
%endif
|
||||
%ifarch armv7hnl
|
||||
-DARM_FP_ABI=hard \
|
||||
-DWITH_NEON=ON \
|
||||
%endif
|
||||
%ifarch armv5tel armv6l armv7l
|
||||
-DARM_FP_ABI=soft \
|
||||
-DWITH_NEON=OFF \
|
||||
%endif
|
||||
.
|
||||
|
||||
%make_build
|
||||
|
||||
pushd winpr/tools/makecert-cli
|
||||
%make_build
|
||||
popd
|
||||
|
||||
%install
|
||||
%make_install
|
||||
%make_install COMPONENT=tools
|
||||
|
||||
find %{buildroot} -name "*.a" -delete
|
||||
|
||||
%multilib_fix_c_header --file %{_includedir}/freerdp2/freerdp/build-config.h
|
||||
|
||||
%files
|
||||
%{_bindir}/winpr-hash
|
||||
%{_bindir}/winpr-makecert
|
||||
%{_bindir}/wlfreerdp
|
||||
%{_bindir}/xfreerdp
|
||||
%{_mandir}/man1/winpr-hash.1*
|
||||
%{_mandir}/man1/winpr-makecert.1*
|
||||
%{_mandir}/man1/wlfreerdp.1*
|
||||
%{_mandir}/man1/xfreerdp.1*
|
||||
|
||||
%files libs
|
||||
%license LICENSE
|
||||
%doc README.md ChangeLog
|
||||
%{_libdir}/freerdp2/
|
||||
%{_libdir}/libfreerdp-client2.so.*
|
||||
%{?_with_server:
|
||||
%{_libdir}/libfreerdp-server2.so.*
|
||||
%{_libdir}/libfreerdp-shadow2.so.*
|
||||
%{_libdir}/libfreerdp-shadow-subsystem2.so.*
|
||||
}
|
||||
%{_libdir}/libfreerdp2.so.*
|
||||
%{_libdir}/libuwac0.so.*
|
||||
%{_mandir}/man7/wlog.*
|
||||
|
||||
%files devel
|
||||
%{_includedir}/freerdp2
|
||||
%{_includedir}/uwac0
|
||||
%{_libdir}/cmake/FreeRDP2
|
||||
%{_libdir}/cmake/FreeRDP-Client2
|
||||
%{?_with_server:
|
||||
%{_libdir}/cmake/FreeRDP-Server2
|
||||
%{_libdir}/cmake/FreeRDP-Shadow2
|
||||
}
|
||||
%{_libdir}/cmake/uwac0
|
||||
%{_libdir}/libfreerdp-client2.so
|
||||
%{?_with_server:
|
||||
%{_libdir}/libfreerdp-server2.so
|
||||
%{_libdir}/libfreerdp-shadow2.so
|
||||
%{_libdir}/libfreerdp-shadow-subsystem2.so
|
||||
}
|
||||
%{_libdir}/libfreerdp2.so
|
||||
%{_libdir}/libuwac0.so
|
||||
%{_libdir}/pkgconfig/freerdp2.pc
|
||||
%{_libdir}/pkgconfig/freerdp-client2.pc
|
||||
%{?_with_server:
|
||||
%{_libdir}/pkgconfig/freerdp-server2.pc
|
||||
%{_libdir}/pkgconfig/freerdp-shadow2.pc
|
||||
}
|
||||
%{_libdir}/pkgconfig/uwac0.pc
|
||||
|
||||
%{?_with_server:
|
||||
%files server
|
||||
%{_bindir}/freerdp-proxy
|
||||
%{_bindir}/freerdp-shadow-cli
|
||||
%{_mandir}/man1/freerdp-shadow-cli.1*
|
||||
}
|
||||
|
||||
%files -n libwinpr
|
||||
%license LICENSE
|
||||
%doc README.md ChangeLog
|
||||
%{_libdir}/libwinpr2.so.*
|
||||
%{_libdir}/libwinpr-tools2.so.*
|
||||
|
||||
%files -n libwinpr-devel
|
||||
%{_libdir}/cmake/WinPR2
|
||||
%{_includedir}/winpr2
|
||||
%{_libdir}/libwinpr2.so
|
||||
%{_libdir}/libwinpr-tools2.so
|
||||
%{_libdir}/pkgconfig/winpr2.pc
|
||||
%{_libdir}/pkgconfig/winpr-tools2.pc
|
||||
|
||||
%changelog
|
||||
* Thu Aug 11 2022 Ondrej Holy <oholy@redhat.com> - 2:2.2.0-8
|
||||
- Fix /monitor-list output (rhbz#2108866)
|
||||
|
||||
* Wed Nov 10 2021 Ondrej Holy <oholy@redhat.com> - 2:2.2.0-4
|
||||
- Refactored RPC gateway parser (rhbz#2017949)
|
||||
|
||||
* Fri Nov 05 2021 Felipe Borges <feborges@redhat.com> - 2:2.2.0-3
|
||||
- Add checks for bitmap and glyph width and heigth values (rhbz#2017956)
|
||||
|
||||
* Wed Apr 28 2021 Ondrej Holy <oholy@redhat.com> - 2:2.2.0-2
|
||||
- Fix exit codes for /help and similar options (rhbz#1910029)
|
||||
|
||||
* Fri Nov 20 2020 Ondrej Holy <oholy@redhat.com> - 2:2.2.0-1
|
||||
- Update to 2.2.0 (rhbz#1881971)
|
||||
|
||||
* Mon May 25 2020 Ondrej Holy <oholy@redhat.com> - 2:2.1.1-1
|
||||
- Update to 2.1.1 (rhbz#1834287).
|
||||
|
||||
* Fri Apr 17 2020 Ondrej Holy <oholy@redhat.com> - 2:2.0.0-47.rc4
|
||||
- Fix SCARD_INSUFFICIENT_BUFFER error (rhbz#1803054)
|
||||
- Do not advertise /usb in help output (rhbz#1761144)
|
||||
|
||||
* Wed Nov 28 2018 Ondrej Holy <oholy@redhat.com> - 2:2.0.0-46.rc4
|
||||
- Update to 2.0.0-rc4 (#1624340)
|
||||
|
||||
* Mon Oct 15 2018 Ondrej Holy <oholy@redhat.com> - 2:2.0.0-45.rc3
|
||||
- Disable server support in RHEL (#1639165)
|
||||
|
||||
* Wed Oct 10 2018 Ondrej Holy <oholy@redhat.com> - 2:2.0.0-44.rc3
|
||||
- Fix packaging issues found by rpmdiff (#1637487)
|
||||
|
||||
* Tue Sep 25 2018 Ondrej Holy <oholy@redhat.com> - 2:2.0.0-43.rc3
|
||||
- Fix important defects found by covscan (#1602500)
|
||||
|
||||
* Thu Sep 06 2018 Ondrej Holy <oholy@redhat.com> - 2:2.0.0-42.rc3
|
||||
- Update to 2.0.0-rc3 (#1624340)
|
||||
|
||||
* Mon Apr 09 2018 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-41.20180405gita9ecd6a
|
||||
- Update to latest snapshot.
|
||||
|
||||
* Wed Mar 21 2018 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-40.20180320gitde83f4d
|
||||
- Add PAM support (fixes freerdp-shadow-cli). Thanks Paolo Zeppegno.
|
||||
- Update to latest snapshot.
|
||||
|
||||
* Thu Mar 15 2018 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-39.20180314gitf8baeb7
|
||||
- Update to latest snapshot.
|
||||
- Fixes connection to RDP servers with the latest Microsoft patches:
|
||||
https://github.com/FreeRDP/FreeRDP/issues/4449
|
||||
|
||||
* Wed Feb 07 2018 Fedora Release Engineering <releng@fedoraproject.org> - 2:2.0.0-38.20180115git8f52c7e
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild
|
||||
|
||||
* Thu Jan 18 2018 Karsten Hopp <karsten@redhat.com> - 2.0.0-37git}
|
||||
- use versioned build requirement on pkgconfig(openssl) to prevent using
|
||||
compat-openssl10-devel instead of openssl-devel
|
||||
|
||||
* Tue Jan 16 2018 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-36.20180115git8f52c7e
|
||||
- Update to latest snapshot.
|
||||
- Make GSS support optional and disable it for now (#1534094 and FreeRDP #4348,
|
||||
#1435, #4363).
|
||||
|
||||
* Wed Dec 20 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-35.20171220gitbfe8359
|
||||
- Update to latest snapshot post 2.0.0rc1.
|
||||
|
||||
* Mon Sep 11 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-34.20170831git3b83526
|
||||
- Update to latest snapshot.
|
||||
- Trim changelog.
|
||||
|
||||
* Mon Aug 07 2017 Björn Esser <besser82@fedoraproject.org> - 2:2.0.0-33.20170724gitf8c9f43
|
||||
- Rebuilt for AutoReq cmake-filesystem
|
||||
|
||||
* Wed Aug 02 2017 Fedora Release Engineering <releng@fedoraproject.org> - 2:2.0.0-32.20170724gitf8c9f43
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild
|
||||
|
||||
* Thu Jul 27 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-31.20170724gitf8c9f43
|
||||
- Update to latest snapshot, Talos security fixes.
|
||||
|
||||
* Wed Jul 26 2017 Fedora Release Engineering <releng@fedoraproject.org> - 2:2.0.0-30.20170710gitf580bea
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild
|
||||
|
||||
* Wed Jul 12 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-29.20170710gitf580bea
|
||||
- Update to latest snapshot.
|
||||
|
||||
* Mon Jun 26 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-28.20170623git9904c32
|
||||
- Update to latest snapshot.
|
||||
|
||||
* Mon May 15 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-27.20170512gitb1df835
|
||||
- Update to latest snapshot.
|
||||
|
||||
* Thu Apr 20 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-26.20170419gitbfcf8e7
|
||||
- Update to latest 2.0 snapshot.
|
||||
|
||||
* Thu Apr 13 2017 Orion Poplawski <orion@cora.nwra.com> - 2:2.0.0-25.20170317git8c68761
|
||||
- Install tools via make install
|
||||
|
||||
* Wed Mar 22 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-24.20170317git8c68761
|
||||
- Update to latest snapshot.
|
||||
|
||||
* Mon Mar 06 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-23.20170302git210de68
|
||||
- Remove shared libxfreerdp-client shared library.
|
||||
|
||||
* Thu Mar 02 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-22.20170302git210de68
|
||||
- Move libxfreerdp-client shared object into devel subpackage.
|
||||
|
||||
* Thu Mar 02 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-21.20170302git210de68
|
||||
- Update to latest snapshot.
|
||||
- Update build requirements, tune build options.
|
||||
|
||||
* Fri Feb 10 2017 Fedora Release Engineering <releng@fedoraproject.org> - 2:2.0.0-20.20161228git90877f5
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild
|
||||
|
||||
* Mon Jan 09 2017 Simone Caronni <negativo17@gmail.com> - 2:2.0.0-19.20161228git90877f5
|
||||
- Update to latest snapshot.
|
Loading…
Reference in New Issue
Block a user