I'm getting -EINVAL
for some reason, and it's not clear to me why. Here's where I open and attempt to mmap
the file:
if ((fd = open(argv[1], O_RDWR)) < 0)
{
fprintf(stderr, "Failed to open %s: %s\n", argv[1], strerror(errno));
return 1;
}
struct stat statbuf;
if (fstat(fd, &statbuf))
{
fprintf(stderr, "stat filed: %s\n", strerror(errno));
return 1;
}
char* fbase = mmap(NULL, statbuf.st_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);
if (fbase == MAP_FAILED)
{
fprintf(stderr, "mmap failed: %s\n", strerror(errno));
return 1;
}
EDIT: I should add, the error is occurring in the mmap
.
Your
statbuf.st_size
is0
.mmap()
will fail if the length parameter is0
.There are 3 listed reasons for
EINVAL
errormmap()
:Turns out changing theMAP_SHARED
toMAP_PRIVATE
allows this to succeed.This reason this was failing is subtle: My code is running inside a VirtualBox VM, and the file I was attempting to
mmap
was in a shared directory on my host machine. The VirtualBox virtual filesystem apparently doesn't implementmmap
with theMAP_SHARED
option across the boundary of the hypervisor.If you'll read jxh's helpful comments on both my question and on his answer, it turns out that this code was working for him because he was likely attempting to
mmap
a host filesystem file into the host memory.My observation that switching from
MAP_SHARED
toMAP_PRIVATE
is also consistent with this: since privately mapped memory is invisible to other processes, the virtual filesystem driver will probably have no objection to mapping the memory.The solution was to move the file I wanted to map into the guest's hard drive and perform manipulation from there.