/* Copyright (c) 2002-2018 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "ioloop.h"
#include "memarea.h"
#include "mmap-util.h"
#include "istream-private.h"
#include <unistd.h>
struct mmap_memarea {
void *mmap_base;
};
struct mmap_istream {
};
bool close_parent ATTR_UNUSED)
{
i_error("mmap_istream.close(%s) failed: %m",
}
}
}
{
_stream->buffer_size = 0;
mstream->mmap_offset = 0;
} else {
}
}
{
}
{
(mmap_get_page_size() - 1);
}
{
i_error("mmap_istream.munmap() failed: %m");
}
{
/* more bytes available without needing to mmap() */
}
return -1;
}
/* didn't skip enough bytes */
return -2;
}
if (stream->buffer_size == 0) {
/* don't bother even trying mmap */
} else {
void *mmap_base =
if (mmap_base == MAP_FAILED) {
stream->buffer_size = 0;
"mmap() failed: %m");
i_error("mmap_istream.mmap(%s) failed: %m",
return -1;
}
MADV_SEQUENTIAL) < 0) {
i_error("mmap_istream.madvise(%s): %m",
}
}
}
}
bool mark ATTR_UNUSED)
{
if (stream->buffer_size != 0 &&
/* already mmaped */
} else {
/* force reading next time */
}
}
{
}
{
return 0;
i_error("mmap_istream.fstat(%s) failed: %m",
return -1;
}
return 0;
}
static int
{
return fstat_cached(mstream);
}
bool autoclose_fd)
{
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;
}