2009-03-01 13:13:25 +00:00
|
|
|
/*
|
|
|
|
* This file is part of MPlayer.
|
|
|
|
*
|
|
|
|
* MPlayer is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* MPlayer is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with MPlayer; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
|
|
|
|
2006-11-25 01:22:20 +00:00
|
|
|
/**
|
|
|
|
* \file mmap_anon.c
|
|
|
|
* \brief Provide a compatible anonymous space mapping function
|
|
|
|
*/
|
2006-11-26 13:55:55 +00:00
|
|
|
#include "config.h"
|
2006-11-25 01:22:20 +00:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <fcntl.h>
|
2006-12-05 00:01:19 +00:00
|
|
|
#include <sys/mman.h>
|
2006-11-25 01:22:20 +00:00
|
|
|
|
|
|
|
#if defined(MAP_ANON) && !defined(MAP_ANONYMOUS)
|
|
|
|
#define MAP_ANONYMOUS MAP_ANON
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* mmap() anonymous space, depending on the system's mmap() style. On systems
|
|
|
|
* that use the /dev/zero mapping idiom, zerofd will be set to the file descriptor
|
2009-05-13 02:58:57 +00:00
|
|
|
* of the opened /dev/zero.
|
2006-11-25 01:22:20 +00:00
|
|
|
*/
|
2009-05-13 02:58:57 +00:00
|
|
|
|
2006-11-25 01:22:20 +00:00
|
|
|
/**
|
|
|
|
* \brief mmap() anonymous space, depending on the system's mmap() style. On systems
|
|
|
|
* that use the /dev/zero mapping idiom, zerofd will be set to the file descriptor
|
|
|
|
* of the opened /dev/zero.
|
|
|
|
*
|
|
|
|
* \param addr address to map at.
|
|
|
|
* \param len number of bytes from addr to be mapped.
|
|
|
|
* \param prot protections (region accessibility).
|
|
|
|
* \param flags specifies the type of the mapped object.
|
|
|
|
* \param offset start mapping at byte offset.
|
2009-05-13 02:58:57 +00:00
|
|
|
* \param zerofd
|
2006-11-25 01:22:20 +00:00
|
|
|
* \return a pointer to the mapped region upon successful completion, -1 otherwise.
|
|
|
|
*/
|
2006-11-26 13:09:46 +00:00
|
|
|
void *mmap_anon(void *addr, size_t len, int prot, int flags, off_t offset)
|
2006-11-25 01:22:20 +00:00
|
|
|
{
|
|
|
|
void *result;
|
|
|
|
|
|
|
|
/* From loader/ext.c:
|
|
|
|
* "Linux EINVAL's on us if we don't pass MAP_PRIVATE to an anon mmap"
|
|
|
|
* Therefore we preserve the same behavior on all platforms, ie. no
|
|
|
|
* shared mappings of anon space (if the concepts are supported). */
|
|
|
|
#if defined(MAP_SHARED) && defined(MAP_PRIVATE)
|
|
|
|
flags = (flags & ~MAP_SHARED) | MAP_PRIVATE;
|
|
|
|
#endif /* defined(MAP_SHARED) && defined(MAP_PRIVATE) */
|
|
|
|
|
|
|
|
#ifdef MAP_ANONYMOUS
|
|
|
|
/* BSD-style anonymous mapping */
|
|
|
|
result = mmap(addr, len, prot, flags | MAP_ANONYMOUS, -1, offset);
|
|
|
|
#else
|
|
|
|
/* SysV-style anonymous mapping */
|
2007-08-25 17:09:09 +00:00
|
|
|
int fd;
|
2006-11-25 01:22:20 +00:00
|
|
|
fd = open("/dev/zero", O_RDWR);
|
|
|
|
if(fd < 0){
|
|
|
|
perror( "Cannot open /dev/zero for READ+WRITE. Check permissions! error: ");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
result = mmap(addr, len, prot, flags, fd, offset);
|
2006-11-26 13:09:46 +00:00
|
|
|
close(fd);
|
2006-11-25 01:22:20 +00:00
|
|
|
#endif /* MAP_ANONYMOUS */
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|