//////////////////////////////////////////////////////////////////////////////// /// @brief memory mapped files /// /// @file /// /// DISCLAIMER /// /// Copyright 2014 ArangoDB GmbH, Cologne, Germany /// Copyright 2004-2014 triAGENS GmbH, Cologne, Germany /// /// Licensed under the Apache License, Version 2.0 (the "License"); /// you may not use this file except in compliance with the License. /// You may obtain a copy of the License at /// /// http://www.apache.org/licenses/LICENSE-2.0 /// /// Unless required by applicable law or agreed to in writing, software /// distributed under the License is distributed on an "AS IS" BASIS, /// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. /// See the License for the specific language governing permissions and /// limitations under the License. /// /// Copyright holder is ArangoDB GmbH, Cologne, Germany /// /// @author Dr. Oreste Costa-Panaia /// @author Copyright 2014, ArangoDB GmbH, Cologne, Germany /// @author Copyright 2012-2013, triAGENS GmbH, Cologne, Germany //////////////////////////////////////////////////////////////////////////////// #ifndef ARANGODB_BASICS_C_MEMORY__MAP_H #define ARANGODB_BASICS_C_MEMORY__MAP_H 1 #include "Basics/Common.h" //////////////////////////////////////////////////////////////////////////////// /// @brief wrapper macro for anonymous memory mapping /// /// it might or might not be defined by one of the following includes /// if still empty after the includes, no anonymous memory mapping is available /// on the platform //////////////////////////////////////////////////////////////////////////////// #undef TRI_MMAP_ANONYMOUS //////////////////////////////////////////////////////////////////////////////// /// @brief posix memory map //////////////////////////////////////////////////////////////////////////////// #ifdef TRI_HAVE_POSIX_MMAP #include "Basics/memory-map-posix.h" #endif //////////////////////////////////////////////////////////////////////////////// /// @brief windows memory map //////////////////////////////////////////////////////////////////////////////// #ifdef TRI_HAVE_WIN32_MMAP #include "Basics/memory-map-win32.h" #endif // ----------------------------------------------------------------------------- // --SECTION-- MEMORY MAPPING // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @brief flushes changes made in memory back to disk //////////////////////////////////////////////////////////////////////////////// int TRI_FlushMMFile (int fileDescriptor, void* startingAddress, size_t numOfBytesToFlush, int flags); //////////////////////////////////////////////////////////////////////////////// /// @brief maps a file on disk onto memory //////////////////////////////////////////////////////////////////////////////// int TRI_MMFile (void* memoryAddress, size_t numOfBytesToInitialize, int memoryProtection, int flags, int fileDescriptor, void** mmHandle, int64_t offset, void** result); //////////////////////////////////////////////////////////////////////////////// /// @brief 'unmaps' or removes memory associated with a memory mapped file //////////////////////////////////////////////////////////////////////////////// int TRI_UNMMFile (void* memoryAddress, size_t numOfBytesToUnMap, int fileDescriptor, void** mmHandle); //////////////////////////////////////////////////////////////////////////////// /// @brief sets various protection levels with the memory mapped file //////////////////////////////////////////////////////////////////////////////// int TRI_ProtectMMFile (void* memoryAddress, size_t numOfBytesToProtect, int flags, int fileDescriptor, void** mmHandle); //////////////////////////////////////////////////////////////////////////////// /// @brief gives hints about upcoming memory usage //////////////////////////////////////////////////////////////////////////////// int TRI_MMFileAdvise (void* memoryAddress, size_t numOfBytes, int advice); #endif // ----------------------------------------------------------------------------- // --SECTION-- END-OF-FILE // ----------------------------------------------------------------------------- // Local Variables: // mode: outline-minor // outline-regexp: "/// @brief\\|/// {@inheritDoc}\\|/// @page\\|// --SECTION--\\|/// @\\}" // End: