Commit f0863888 authored by Arseniy Krasnov's avatar Arseniy Krasnov Committed by Jakub Kicinski

vsock/test: fix SEQPACKET message bounds test

Tune message length calculation to make this test work on machines
where 'getpagesize()' returns >32KB. Now maximum message length is not
hardcoded (on machines above it was smaller than 'getpagesize()' return
value, thus we get negative value and test fails), but calculated at
runtime and always bigger than 'getpagesize()' result. Reproduced on
aarch64 with 64KB page size.

Fixes: 5c338112 ("test/vsock: rework message bounds test")
Signed-off-by: default avatarArseniy Krasnov <avkrasnov@salutedevices.com>
Reported-by: default avatarBogdan Marcynkov <bmarcynk@redhat.com>
Reviewed-by: default avatarStefano Garzarella <sgarzare@redhat.com>
Link: https://lore.kernel.org/r/20231121211642.163474-1-avkrasnov@salutedevices.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 4e20655e
...@@ -353,11 +353,12 @@ static void test_stream_msg_peek_server(const struct test_opts *opts) ...@@ -353,11 +353,12 @@ static void test_stream_msg_peek_server(const struct test_opts *opts)
} }
#define SOCK_BUF_SIZE (2 * 1024 * 1024) #define SOCK_BUF_SIZE (2 * 1024 * 1024)
#define MAX_MSG_SIZE (32 * 1024) #define MAX_MSG_PAGES 4
static void test_seqpacket_msg_bounds_client(const struct test_opts *opts) static void test_seqpacket_msg_bounds_client(const struct test_opts *opts)
{ {
unsigned long curr_hash; unsigned long curr_hash;
size_t max_msg_size;
int page_size; int page_size;
int msg_count; int msg_count;
int fd; int fd;
...@@ -373,7 +374,8 @@ static void test_seqpacket_msg_bounds_client(const struct test_opts *opts) ...@@ -373,7 +374,8 @@ static void test_seqpacket_msg_bounds_client(const struct test_opts *opts)
curr_hash = 0; curr_hash = 0;
page_size = getpagesize(); page_size = getpagesize();
msg_count = SOCK_BUF_SIZE / MAX_MSG_SIZE; max_msg_size = MAX_MSG_PAGES * page_size;
msg_count = SOCK_BUF_SIZE / max_msg_size;
for (int i = 0; i < msg_count; i++) { for (int i = 0; i < msg_count; i++) {
size_t buf_size; size_t buf_size;
...@@ -383,7 +385,7 @@ static void test_seqpacket_msg_bounds_client(const struct test_opts *opts) ...@@ -383,7 +385,7 @@ static void test_seqpacket_msg_bounds_client(const struct test_opts *opts)
/* Use "small" buffers and "big" buffers. */ /* Use "small" buffers and "big" buffers. */
if (i & 1) if (i & 1)
buf_size = page_size + buf_size = page_size +
(rand() % (MAX_MSG_SIZE - page_size)); (rand() % (max_msg_size - page_size));
else else
buf_size = 1 + (rand() % page_size); buf_size = 1 + (rand() % page_size);
...@@ -429,7 +431,6 @@ static void test_seqpacket_msg_bounds_server(const struct test_opts *opts) ...@@ -429,7 +431,6 @@ static void test_seqpacket_msg_bounds_server(const struct test_opts *opts)
unsigned long remote_hash; unsigned long remote_hash;
unsigned long curr_hash; unsigned long curr_hash;
int fd; int fd;
char buf[MAX_MSG_SIZE];
struct msghdr msg = {0}; struct msghdr msg = {0};
struct iovec iov = {0}; struct iovec iov = {0};
...@@ -457,8 +458,13 @@ static void test_seqpacket_msg_bounds_server(const struct test_opts *opts) ...@@ -457,8 +458,13 @@ static void test_seqpacket_msg_bounds_server(const struct test_opts *opts)
control_writeln("SRVREADY"); control_writeln("SRVREADY");
/* Wait, until peer sends whole data. */ /* Wait, until peer sends whole data. */
control_expectln("SENDDONE"); control_expectln("SENDDONE");
iov.iov_base = buf; iov.iov_len = MAX_MSG_PAGES * getpagesize();
iov.iov_len = sizeof(buf); iov.iov_base = malloc(iov.iov_len);
if (!iov.iov_base) {
perror("malloc");
exit(EXIT_FAILURE);
}
msg.msg_iov = &iov; msg.msg_iov = &iov;
msg.msg_iovlen = 1; msg.msg_iovlen = 1;
...@@ -483,6 +489,7 @@ static void test_seqpacket_msg_bounds_server(const struct test_opts *opts) ...@@ -483,6 +489,7 @@ static void test_seqpacket_msg_bounds_server(const struct test_opts *opts)
curr_hash += hash_djb2(msg.msg_iov[0].iov_base, recv_size); curr_hash += hash_djb2(msg.msg_iov[0].iov_base, recv_size);
} }
free(iov.iov_base);
close(fd); close(fd);
remote_hash = control_readulong(); remote_hash = control_readulong();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment