summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorDan McGee <dpmcgee@gmail.com>2012-02-16 23:30:13 -0600
committerAlon Levy <alevy@redhat.com>2012-02-21 10:20:47 +0200
commit016bc7513f0e758162d136476b8faa7e7832a60b (patch)
tree350fbff22a8a19fce2ff1e2f1d26ac75c64acf85 /server
parentbdfd6c234bca76232f4bac308fc21321ebba7f1a (diff)
downloadspice-016bc7513f0e758162d136476b8faa7e7832a60b.tar.gz
spice-016bc7513f0e758162d136476b8faa7e7832a60b.tar.xz
spice-016bc7513f0e758162d136476b8faa7e7832a60b.zip
Use standard IOV_MAX definition where applicable
This is provided by <limits.h> on all platforms as long as _XOPEN_SOURCE is defined. On Linux, this is 1024, on Solaris, this is 16, and on any other platform, we now respect the value supported by the OS. Signed-off-by: Dan McGee <dpmcgee@gmail.com>
Diffstat (limited to 'server')
-rw-r--r--server/main_channel.c2
-rw-r--r--server/red_channel.c2
-rw-r--r--server/red_channel.h11
-rw-r--r--server/snd_worker.c9
4 files changed, 15 insertions, 9 deletions
diff --git a/server/main_channel.c b/server/main_channel.c
index f7e1ab03..4d1f8ea5 100644
--- a/server/main_channel.c
+++ b/server/main_channel.c
@@ -47,8 +47,6 @@
#define ZERO_BUF_SIZE 4096
-#define REDS_MAX_SEND_IOVEC 100
-
#define NET_TEST_WARMUP_BYTES 0
#define NET_TEST_BYTES (1024 * 250)
diff --git a/server/red_channel.c b/server/red_channel.c
index 5b8027cb..2cd98daa 100644
--- a/server/red_channel.c
+++ b/server/red_channel.c
@@ -329,7 +329,7 @@ static void red_channel_client_peer_prepare_out_msg(
RedChannelClient *rcc = (RedChannelClient *)opaque;
*vec_size = spice_marshaller_fill_iovec(rcc->send_data.marshaller,
- vec, MAX_SEND_VEC, pos);
+ vec, IOV_MAX, pos);
}
static void red_channel_client_peer_on_out_block(void *opaque)
diff --git a/server/red_channel.h b/server/red_channel.h
index a360a302..ce534ca1 100644
--- a/server/red_channel.h
+++ b/server/red_channel.h
@@ -22,17 +22,22 @@
#ifndef _H_RED_CHANNEL
#define _H_RED_CHANNEL
-#include "red_common.h"
#include <pthread.h>
+#include <limits.h>
+
+#include "red_common.h"
#include "spice.h"
#include "ring.h"
#include "common/marshaller.h"
#include "server/demarshallers.h"
#define MAX_SEND_BUFS 1000
-#define MAX_SEND_VEC 100
#define CLIENT_ACK_WINDOW 20
+#ifndef IOV_MAX
+#define IOV_MAX 1024
+#endif
+
#define MAX_HEADER_SIZE sizeof(SpiceDataHeader)
/* Basic interface for channels, without using the RedChannel interface.
@@ -109,7 +114,7 @@ typedef struct OutgoingHandlerInterface {
typedef struct OutgoingHandler {
OutgoingHandlerInterface *cb;
void *opaque;
- struct iovec vec_buf[MAX_SEND_VEC];
+ struct iovec vec_buf[IOV_MAX];
int vec_size;
struct iovec *vec;
int pos;
diff --git a/server/snd_worker.c b/server/snd_worker.c
index 0e93a6fc..aa1ceb76 100644
--- a/server/snd_worker.c
+++ b/server/snd_worker.c
@@ -21,6 +21,7 @@
#include <fcntl.h>
#include <errno.h>
+#include <limits.h>
#include <sys/socket.h>
#include <netinet/ip.h>
#include <netinet/tcp.h>
@@ -36,7 +37,9 @@
#include "generated_marshallers.h"
#include "demarshallers.h"
-#define MAX_SEND_VEC 100
+#ifndef IOV_MAX
+#define IOV_MAX 1024
+#endif
#define RECIVE_BUF_SIZE (16 * 1024 * 2)
@@ -262,7 +265,7 @@ static int snd_send_data(SndChannel *channel)
}
for (;;) {
- struct iovec vec[MAX_SEND_VEC];
+ struct iovec vec[IOV_MAX];
int vec_size;
if (!n) {
@@ -276,7 +279,7 @@ static int snd_send_data(SndChannel *channel)
}
vec_size = spice_marshaller_fill_iovec(channel->send_data.marshaller,
- vec, MAX_SEND_VEC, channel->send_data.pos);
+ vec, IOV_MAX, channel->send_data.pos);
n = reds_stream_writev(channel->stream, vec, vec_size);
if (n == -1) {
switch (errno) {