blob: f4425700008b2172e8478f2fe7ccab56224da992 [file] [log] [blame]
Brian Carlstromdb4d5402011-08-09 12:18:28 -07001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ART_SRC_MEM_MAP_H_
18#define ART_SRC_MEM_MAP_H_
19
Brian Carlstrom27ec9612011-09-19 20:20:38 -070020#include <stddef.h>
Elliott Hughesa168c832012-06-12 15:34:20 -070021#include <sys/mman.h> // For the PROT_* and MAP_* constants.
Brian Carlstrom27ec9612011-09-19 20:20:38 -070022#include <sys/types.h>
Brian Carlstromdb4d5402011-08-09 12:18:28 -070023
Brian Carlstrom27ec9612011-09-19 20:20:38 -070024#include "globals.h"
Brian Carlstromdb4d5402011-08-09 12:18:28 -070025
26namespace art {
27
28// Used to keep track of mmap segments.
29class MemMap {
30 public:
Elliott Hughesecd3a6f2012-06-06 18:16:37 -070031 // Request an anonymous region of length 'byte_count' and a requested base address.
Elliott Hughes6c9c06d2011-11-07 16:43:47 -080032 // Use NULL as the requested base address if you don't care.
33 //
34 // The word "anonymous" in this context means "not backed by a file". The supplied
35 // 'ashmem_name' will be used -- on systems that support it -- to give the mapping
36 // a name.
Brian Carlstrom4a289ed2011-08-16 17:17:49 -070037 //
38 // On success, returns returns a MemMap instance. On failure, returns a NULL;
Elliott Hughesecd3a6f2012-06-06 18:16:37 -070039 static MemMap* MapAnonymous(const char* ashmem_name, byte* addr, size_t byte_count, int prot);
Brian Carlstromdb4d5402011-08-09 12:18:28 -070040
41 // Map part of a file, taking care of non-page aligned offsets. The
42 // "start" offset is absolute, not relative.
43 //
44 // On success, returns returns a MemMap instance. On failure, returns a NULL;
Elliott Hughesecd3a6f2012-06-06 18:16:37 -070045 static MemMap* MapFile(size_t byte_count, int prot, int flags, int fd, off_t start) {
46 return MapFileAtAddress(NULL, byte_count, prot, flags, fd, start);
Brian Carlstrom4a289ed2011-08-16 17:17:49 -070047 }
48
49 // Map part of a file, taking care of non-page aligned offsets. The
50 // "start" offset is absolute, not relative. This version allows
51 // requesting a specific address for the base of the mapping.
52 //
53 // On success, returns returns a MemMap instance. On failure, returns a NULL;
Brian Carlstrom89521892011-12-07 22:05:07 -080054 static MemMap* MapFileAtAddress(
Elliott Hughesecd3a6f2012-06-06 18:16:37 -070055 byte* addr, size_t byte_count, int prot, int flags, int fd, off_t start);
Brian Carlstromdb4d5402011-08-09 12:18:28 -070056
Brian Carlstrom27ec9612011-09-19 20:20:38 -070057 // Releases the memory mapping
58 ~MemMap();
Brian Carlstromdb4d5402011-08-09 12:18:28 -070059
Logan Chiend88fa262012-06-06 15:23:32 +080060 bool Protect(int prot);
61
Ian Rogers1c849e52012-06-28 14:00:33 -070062 int GetProtect() const {
63 return prot_;
64 }
65
Ian Rogers30fab402012-01-23 15:43:46 -080066 byte* Begin() const {
67 return begin_;
Brian Carlstromdb4d5402011-08-09 12:18:28 -070068 }
69
Ian Rogers30fab402012-01-23 15:43:46 -080070 size_t Size() const {
71 return size_;
Brian Carlstromdb4d5402011-08-09 12:18:28 -070072 }
73
Ian Rogers30fab402012-01-23 15:43:46 -080074 byte* End() const {
75 return begin_ + size_;
Brian Carlstromb765be02011-08-17 23:54:10 -070076 }
77
Brian Carlstromdb4d5402011-08-09 12:18:28 -070078 private:
Ian Rogers1c849e52012-06-28 14:00:33 -070079 MemMap(byte* begin, size_t size, void* base_begin, size_t base_size, int prot);
Brian Carlstromdb4d5402011-08-09 12:18:28 -070080
Ian Rogers1c849e52012-06-28 14:00:33 -070081 byte* const begin_; // Start of data.
82 const size_t size_; // Length of data.
Brian Carlstromdb4d5402011-08-09 12:18:28 -070083
Ian Rogers1c849e52012-06-28 14:00:33 -070084 void* const base_begin_; // Page-aligned base address.
85 const size_t base_size_; // Length of mapping.
86 int prot_; // Protection of the map.
Brian Carlstromdb4d5402011-08-09 12:18:28 -070087};
88
89} // namespace art
90
91#endif // ART_SRC_MEM_MAP_H_