istream-mmap.c revision 2c25e1360d4b5cc55eda969a3a7204d950de5a8f
/* Copyright (c) 2002-2003 Timo Sirainen */
#include "lib.h"
#include "ioloop.h"
#include "mmap-util.h"
#include "istream-internal.h"
#include <unistd.h>
struct mmap_istream {
struct timeval fstat_cache_stamp;
void *mmap_base;
unsigned int autoclose_fd:1;
};
static size_t mmap_pagemask = 0;
{
i_error("mmap_istream.close() failed: %m");
}
}
{
i_error("mmap_istream.munmap() failed: %m");
_stream->buffer_size = 0;
mstream->mmap_offset = 0;
}
}
{
}
{
/* allow only full page sizes */
if (max_size < mmap_get_page_size())
else {
if (max_size % mmap_get_page_size() != 0) {
max_size += mmap_get_page_size() -
(max_size % mmap_get_page_size());
}
}
}
{
/* more bytes available without needing to mmap() */
}
return -1;
}
/* didn't skip enough bytes */
return -2;
}
i_error("io_stream_read_mmaped(): munmap() failed: %m");
}
if (stream->buffer_size == 0) {
/* don't bother even trying mmap */
} else {
stream->buffer_size = 0;
i_error("mmap_istream.mmap() failed: %m");
return -1;
}
}
MADV_SEQUENTIAL) < 0)
i_error("mmap_istream.madvise(): %m");
}
}
bool mark __attr_unused__)
{
if (stream->buffer_size != 0 &&
/* already mmaped */
} else {
/* force reading next time */
}
}
{
}
{
return 0;
i_error("mmap_istream.fstat() failed: %m");
return -1;
}
return 0;
}
static const struct stat *
{
if (fstat_cached(mstream) < 0)
return NULL;
}
bool autoclose_fd)
{
struct mmap_istream *mstream;
if (mmap_pagemask == 0)
if (v_size == 0) {
i_error("i_stream_create_mmap(): fstat() failed: %m");
else {
if (start_offset > v_size)
v_size -= start_offset;
}
}
return istream;
}