blob: 874ded584e287ad486b18c919dec5c6ec4c08d2c [file] [log] [blame]
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "mojo/edk/test/test_utils.h"
#include <errno.h>
#include <fcntl.h>
#include <unistd.h>
#include "base/posix/eintr_wrapper.h"
using mojo::platform::PlatformHandle;
namespace mojo {
namespace test {
bool BlockingWrite(const PlatformHandle& handle,
const void* buffer,
size_t bytes_to_write,
size_t* bytes_written) {
int original_flags = fcntl(handle.fd, F_GETFL);
if (original_flags == -1 ||
fcntl(handle.fd, F_SETFL, original_flags & (~O_NONBLOCK)) != 0) {
return false;
}
ssize_t result = HANDLE_EINTR(write(handle.fd, buffer, bytes_to_write));
fcntl(handle.fd, F_SETFL, original_flags);
if (result < 0)
return false;
*bytes_written = result;
return true;
}
bool BlockingRead(const PlatformHandle& handle,
void* buffer,
size_t buffer_size,
size_t* bytes_read) {
int original_flags = fcntl(handle.fd, F_GETFL);
if (original_flags == -1 ||
fcntl(handle.fd, F_SETFL, original_flags & (~O_NONBLOCK)) != 0) {
return false;
}
ssize_t result = HANDLE_EINTR(read(handle.fd, buffer, buffer_size));
fcntl(handle.fd, F_SETFL, original_flags);
if (result < 0)
return false;
*bytes_read = result;
return true;
}
bool NonBlockingRead(const PlatformHandle& handle,
void* buffer,
size_t buffer_size,
size_t* bytes_read) {
ssize_t result = HANDLE_EINTR(read(handle.fd, buffer, buffer_size));
if (result < 0) {
if (errno != EAGAIN && errno != EWOULDBLOCK)
return false;
*bytes_read = 0;
} else {
*bytes_read = result;
}
return true;
}
} // namespace test
} // namespace mojo