win,unix: uv_buf_init() accepts size_t

Change the signature of uv_buf_init() from (char*, unsigned int) to
(char*, size_t). This is to accommodate the fact that the "len" property
of uv_buf_t is a size_t, and fixes a problem where "len" is truncated
for large "base".

Fixes: https://github.com/libuv/libuv/issues/1233
Refs: https://github.com/libuv/libuv/pull/1236
PR-URL: https://github.com/libuv/libuv/pull/1806
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
This commit is contained in:
Trevor Norris 2017-02-28 21:58:44 -07:00 committed by cjihrig
parent c51ead5c70
commit 1c91d2a630
No known key found for this signature in database
GPG Key ID: 7434390BDBE9B9C5
8 changed files with 54 additions and 11 deletions

View File

@ -153,6 +153,7 @@ test_run_tests_SOURCES = test/blackhole-server.c \
test/test-async.c \
test/test-async-null-cb.c \
test/test-barrier.c \
test/test-buf.c \
test/test-callback-order.c \
test/test-callback-stack.c \
test/test-close-fd.c \

View File

@ -86,6 +86,7 @@ test/task.h
test/test-active.c
test/test-async.c
test/test-barrier.c
test/test-buf.c
test/test-callback-order.c
test/test-callback-stack.c
test/test-condvar.c

View File

@ -445,7 +445,7 @@ UV_EXTERN int uv_recv_buffer_size(uv_handle_t* handle, int* value);
UV_EXTERN int uv_fileno(const uv_handle_t* handle, uv_os_fd_t* fd);
UV_EXTERN uv_buf_t uv_buf_init(char* base, unsigned int len);
UV_EXTERN uv_buf_t uv_buf_init(char* base, size_t len);
/*

View File

@ -98,15 +98,6 @@
static int uv__run_pending(uv_loop_t* loop);
/* Verify that uv_buf_t is ABI-compatible with struct iovec. */
STATIC_ASSERT(sizeof(uv_buf_t) == sizeof(struct iovec));
STATIC_ASSERT(sizeof(&((uv_buf_t*) 0)->base) ==
sizeof(((struct iovec*) 0)->iov_base));
STATIC_ASSERT(sizeof(&((uv_buf_t*) 0)->len) ==
sizeof(((struct iovec*) 0)->iov_len));
STATIC_ASSERT(offsetof(uv_buf_t, base) == offsetof(struct iovec, iov_base));
STATIC_ASSERT(offsetof(uv_buf_t, len) == offsetof(struct iovec, iov_len));
uint64_t uv_hrtime(void) {
return uv__hrtime(UV_CLOCK_PRECISE);

View File

@ -137,7 +137,7 @@ size_t uv_loop_size(void) {
}
uv_buf_t uv_buf_init(char* base, unsigned int len) {
uv_buf_t uv_buf_init(char* base, size_t len) {
uv_buf_t buf;
buf.base = base;
buf.len = len;

47
test/test-buf.c Normal file
View File

@ -0,0 +1,47 @@
/* Copyright libuv contributors. All rights reserved.
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#include "uv.h"
#include "task.h"
#include <stdint.h>
TEST_IMPL(buf_large) {
uv_buf_t buf;
buf = uv_buf_init(NULL, SIZE_MAX);
ASSERT(buf.len == SIZE_MAX);
#ifdef _WIN32
WSABUF* wbuf;
wbuf = (WSABUF*) &buf;
ASSERT(wbuf->len == buf.len);
#else
struct iovec* iobuf;
iobuf = (struct iovec*) &buf;
ASSERT(iobuf->iov_len == buf.len);
/* Verify that uv_buf_t is ABI-compatible with struct iovec. */
ASSERT(sizeof(uv_buf_t) == sizeof(struct iovec));
ASSERT(sizeof(&((uv_buf_t*) 0)->base) ==
sizeof(((struct iovec*) 0)->iov_base));
ASSERT(sizeof(&((uv_buf_t*) 0)->len) == sizeof(((struct iovec*) 0)->iov_len));
ASSERT(offsetof(uv_buf_t, base) == offsetof(struct iovec, iov_base));
ASSERT(offsetof(uv_buf_t, len) == offsetof(struct iovec, iov_len));
#endif
return 0;
}

View File

@ -37,6 +37,7 @@ TEST_DECLARE (default_loop_close)
TEST_DECLARE (barrier_1)
TEST_DECLARE (barrier_2)
TEST_DECLARE (barrier_3)
TEST_DECLARE (buf_large)
TEST_DECLARE (condvar_1)
TEST_DECLARE (condvar_2)
TEST_DECLARE (condvar_3)
@ -456,6 +457,7 @@ TASK_LIST_START
TEST_ENTRY (barrier_1)
TEST_ENTRY (barrier_2)
TEST_ENTRY (barrier_3)
TEST_ENTRY (buf_large)
TEST_ENTRY (condvar_1)
TEST_ENTRY (condvar_2)
TEST_ENTRY (condvar_3)

View File

@ -125,6 +125,7 @@
'test-mutexes.c',
'test-thread.c',
'test-barrier.c',
'test-buf.c',
'test-condvar.c',
'test-timer-again.c',
'test-timer-from-check.c',