blob: 3c7361320effc08bff170c7de920d47483f70e8a [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>
21#include <sys/types.h>
Brian Carlstromdb4d5402011-08-09 12:18:28 -070022
Brian Carlstrom27ec9612011-09-19 20:20:38 -070023#include "globals.h"
Brian Carlstromdb4d5402011-08-09 12:18:28 -070024
25namespace art {
26
27// Used to keep track of mmap segments.
28class MemMap {
29 public:
30
31 // Request an anonymous region of a specified length.
32 //
33 // On success, returns returns a MemMap instance. On failure, returns a NULL;
Brian Carlstrom4a289ed2011-08-16 17:17:49 -070034 static MemMap* Map(size_t length, int prot) {
35 return Map(NULL, length, prot);
36 }
37
38 // Request an anonymous region of a specified length and a requested base address.
39 //
40 // On success, returns returns a MemMap instance. On failure, returns a NULL;
Brian Carlstrom27ec9612011-09-19 20:20:38 -070041 static MemMap* Map(byte* addr, size_t length, int prot);
Brian Carlstromdb4d5402011-08-09 12:18:28 -070042
43 // Map part of a file, taking care of non-page aligned offsets. The
44 // "start" offset is absolute, not relative.
45 //
46 // On success, returns returns a MemMap instance. On failure, returns a NULL;
47 static MemMap* Map(size_t length, int prot, int flags, int fd, off_t start) {
Brian Carlstrom4a289ed2011-08-16 17:17:49 -070048 return Map(NULL, length, prot, flags, fd, start);
49 }
50
51 // Map part of a file, taking care of non-page aligned offsets. The
52 // "start" offset is absolute, not relative. This version allows
53 // requesting a specific address for the base of the mapping.
54 //
55 // On success, returns returns a MemMap instance. On failure, returns a NULL;
Brian Carlstrom27ec9612011-09-19 20:20:38 -070056 static MemMap* Map(byte* addr, size_t length, int prot, int flags, int fd, off_t start);
Brian Carlstromdb4d5402011-08-09 12:18:28 -070057
Brian Carlstrom27ec9612011-09-19 20:20:38 -070058 // Releases the memory mapping
59 ~MemMap();
Brian Carlstromdb4d5402011-08-09 12:18:28 -070060
61 byte* GetAddress() const {
62 return addr_;
63 }
64
65 size_t GetLength() const {
66 return length_;
67 }
68
Brian Carlstromb765be02011-08-17 23:54:10 -070069 byte* GetLimit() const {
70 return addr_ + length_;
71 }
72
Brian Carlstromdb4d5402011-08-09 12:18:28 -070073 private:
Brian Carlstrom27ec9612011-09-19 20:20:38 -070074 MemMap(byte* addr, size_t length, void* base_addr, size_t base_length);
Brian Carlstromdb4d5402011-08-09 12:18:28 -070075
76 byte* addr_; // start of data
77 size_t length_; // length of data
78
79 void* base_addr_; // page-aligned base address
80 size_t base_length_; // length of mapping
81};
82
83} // namespace art
84
85#endif // ART_SRC_MEM_MAP_H_