2 * QEMU I/O channel test helpers
4 * Copyright (c) 2015 Red Hat, Inc.
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
21 #include "qemu/osdep.h"
22 #include "io-channel-helpers.h"
23 #include "qapi/error.h"
26 struct QIOChannelTest
{
35 struct iovec
*outputv
;
41 /* This thread sends all data using iovecs */
42 static gpointer
test_io_thread_writer(gpointer opaque
)
44 QIOChannelTest
*data
= opaque
;
46 qio_channel_set_blocking(data
->src
, data
->blocking
, NULL
);
48 qio_channel_writev_all(data
->src
,
57 /* This thread receives all data using iovecs */
58 static gpointer
test_io_thread_reader(gpointer opaque
)
60 QIOChannelTest
*data
= opaque
;
62 qio_channel_set_blocking(data
->dst
, data
->blocking
, NULL
);
64 qio_channel_readv_all(data
->dst
,
73 QIOChannelTest
*qio_channel_test_new(void)
75 QIOChannelTest
*data
= g_new0(QIOChannelTest
, 1);
80 /* We'll send 1 MB of data */
81 #define CHUNK_COUNT 250
82 #define CHUNK_LEN 4194
84 data
->len
= CHUNK_COUNT
* CHUNK_LEN
;
85 data
->input
= g_new0(char, data
->len
);
86 data
->output
= g_new0(gchar
, data
->len
);
88 /* Fill input with a pattern */
89 for (i
= 0; i
< data
->len
; i
+= CHUNK_LEN
) {
90 memset(data
->input
+ i
, (i
/ CHUNK_LEN
), CHUNK_LEN
);
93 /* We'll split the data across a bunch of IO vecs */
94 data
->niov
= CHUNK_COUNT
;
95 data
->inputv
= g_new0(struct iovec
, data
->niov
);
96 data
->outputv
= g_new0(struct iovec
, data
->niov
);
98 for (i
= 0, offset
= 0; i
< data
->niov
; i
++, offset
+= CHUNK_LEN
) {
99 data
->inputv
[i
].iov_base
= data
->input
+ offset
;
100 data
->outputv
[i
].iov_base
= data
->output
+ offset
;
101 data
->inputv
[i
].iov_len
= CHUNK_LEN
;
102 data
->outputv
[i
].iov_len
= CHUNK_LEN
;
108 void qio_channel_test_run_threads(QIOChannelTest
*test
,
113 GThread
*reader
, *writer
;
117 test
->blocking
= blocking
;
119 reader
= g_thread_new("reader",
120 test_io_thread_reader
,
122 writer
= g_thread_new("writer",
123 test_io_thread_writer
,
126 g_thread_join(reader
);
127 g_thread_join(writer
);
129 test
->dst
= test
->src
= NULL
;
133 void qio_channel_test_run_writer(QIOChannelTest
*test
,
137 test_io_thread_writer(test
);
142 void qio_channel_test_run_reader(QIOChannelTest
*test
,
146 test_io_thread_reader(test
);
151 void qio_channel_test_validate(QIOChannelTest
*test
)
153 g_assert(test
->readerr
== NULL
);
154 g_assert(test
->writeerr
== NULL
);
155 g_assert_cmpint(memcmp(test
->input
,
159 g_free(test
->inputv
);
160 g_free(test
->outputv
);
162 g_free(test
->output
);