mirror of
https://gitlab.uni-freiburg.de/opensourcevdi/spice
synced 2025-12-26 22:48:19 +00:00
The patch seems pretty huge but mainly are mechanical steps: - remove GObject declarations - do not inherit from GObject - add SPICE_CXX_GLIB_ALLOCATOR to avoid using C++ allocators - CLASS_init and CLASS_constructor code goes into C++ constructor - CLASS_dispose and CLASS_finalize code goes into C++ destructor - g_object_new is replaced by new operator - class members goes into virtual methods - class parameters became argument to constructor - use push-visibility.h and pop-visibility.h to limit visibility - temporary use XXX_CAST for old GObject casts, they will be replaced - g_object_get is replaced by accessors Signed-off-by: Frediano Ziglio <fziglio@redhat.com>
79 lines
2.6 KiB
C++
79 lines
2.6 KiB
C++
/*
|
|
Copyright (C) 2009-2016 Red Hat, Inc.
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#include <config.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include "common-graphics-channel.h"
|
|
#include "dcc.h"
|
|
#include "red-client.h"
|
|
|
|
uint8_t *CommonGraphicsChannelClient::alloc_recv_buf(uint16_t type, uint32_t size)
|
|
{
|
|
/* SPICE_MSGC_MIGRATE_DATA is the only client message whose size is dynamic */
|
|
if (type == SPICE_MSGC_MIGRATE_DATA) {
|
|
return (uint8_t *) g_malloc(size);
|
|
}
|
|
|
|
if (size > sizeof(recv_buf)) {
|
|
spice_warning("unexpected message size %u (max is %zd)", size, sizeof(recv_buf));
|
|
return NULL;
|
|
}
|
|
return recv_buf;
|
|
}
|
|
|
|
void CommonGraphicsChannelClient::release_recv_buf(uint16_t type, uint32_t size, uint8_t* msg)
|
|
{
|
|
if (type == SPICE_MSGC_MIGRATE_DATA) {
|
|
g_free(msg);
|
|
}
|
|
}
|
|
|
|
bool CommonGraphicsChannelClient::config_socket()
|
|
{
|
|
RedClient *client = get_client();
|
|
MainChannelClient *mcc = red_client_get_main(client);
|
|
RedStream *stream = get_stream();
|
|
gboolean is_low_bandwidth;
|
|
|
|
// TODO - this should be dynamic, not one time at channel creation
|
|
is_low_bandwidth = main_channel_client_is_low_bandwidth(mcc);
|
|
if (!red_stream_set_auto_flush(stream, false)) {
|
|
/* FIXME: Using Nagle's Algorithm can lead to apparent delays, depending
|
|
* on the delayed ack timeout on the other side.
|
|
* Instead of using Nagle's, we need to implement message buffering on
|
|
* the application level.
|
|
* see: http://www.stuartcheshire.org/papers/NagleDelayedAck/
|
|
*/
|
|
red_stream_set_no_delay(stream, !is_low_bandwidth);
|
|
}
|
|
// TODO: move wide/narrow ack setting to red_channel.
|
|
ack_set_client_window(is_low_bandwidth ? WIDE_CLIENT_ACK_WINDOW : NARROW_CLIENT_ACK_WINDOW);
|
|
return true;
|
|
}
|
|
|
|
|
|
void common_graphics_channel_set_during_target_migrate(CommonGraphicsChannel *self, gboolean value)
|
|
{
|
|
self->during_target_migrate = value;
|
|
}
|
|
|
|
gboolean common_graphics_channel_get_during_target_migrate(CommonGraphicsChannel *self)
|
|
{
|
|
return self->during_target_migrate;
|
|
}
|