image.h revision 53cb16b98acf3cf6f3a1e2204ad4958ecf1b5a3c
1/*
2 * Copyright (C) 2011 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_RUNTIME_IMAGE_H_
18#define ART_RUNTIME_IMAGE_H_
19
20#include <string.h>
21
22#include "globals.h"
23#include "mirror/object.h"
24#include "utils.h"
25
26namespace art {
27
28// header of image files written by ImageWriter, read and validated by Space.
29class PACKED(4) ImageHeader {
30 public:
31  ImageHeader() {}
32
33  ImageHeader(uint32_t image_begin,
34              uint32_t image_size_,
35              uint32_t image_bitmap_offset,
36              uint32_t image_bitmap_size,
37              uint32_t image_roots,
38              uint32_t oat_checksum,
39              uint32_t oat_file_begin,
40              uint32_t oat_data_begin,
41              uint32_t oat_data_end,
42              uint32_t oat_file_end);
43
44  bool IsValid() const;
45  const char* GetMagic() const;
46
47  byte* GetImageBegin() const {
48    return reinterpret_cast<byte*>(image_begin_);
49  }
50
51  size_t GetImageSize() const {
52    return static_cast<uint32_t>(image_size_);
53  }
54
55  size_t GetImageBitmapOffset() const {
56    return image_bitmap_offset_;
57  }
58
59  size_t GetImageBitmapSize() const {
60    return image_bitmap_size_;
61  }
62
63  uint32_t GetOatChecksum() const {
64    return oat_checksum_;
65  }
66
67  void SetOatChecksum(uint32_t oat_checksum) {
68    oat_checksum_ = oat_checksum;
69  }
70
71  byte* GetOatFileBegin() const {
72    return reinterpret_cast<byte*>(oat_file_begin_);
73  }
74
75  byte* GetOatDataBegin() const {
76    return reinterpret_cast<byte*>(oat_data_begin_);
77  }
78
79  byte* GetOatDataEnd() const {
80    return reinterpret_cast<byte*>(oat_data_end_);
81  }
82
83  byte* GetOatFileEnd() const {
84    return reinterpret_cast<byte*>(oat_file_end_);
85  }
86
87  off_t GetPatchDelta() const {
88    return patch_delta_;
89  }
90
91  size_t GetBitmapOffset() const {
92    return RoundUp(image_size_, kPageSize);
93  }
94
95  static std::string GetOatLocationFromImageLocation(const std::string& image) {
96    std::string oat_filename = image;
97    if (oat_filename.length() <= 3) {
98      oat_filename += ".oat";
99    } else {
100      oat_filename.replace(oat_filename.length() - 3, 3, "oat");
101    }
102    return oat_filename;
103  }
104
105  enum ImageRoot {
106    kResolutionMethod,
107    kImtConflictMethod,
108    kDefaultImt,
109    kCalleeSaveMethod,
110    kRefsOnlySaveMethod,
111    kRefsAndArgsSaveMethod,
112    kDexCaches,
113    kClassRoots,
114    kImageRootsMax,
115  };
116
117  mirror::Object* GetImageRoot(ImageRoot image_root) const
118      SHARED_LOCKS_REQUIRED(Locks::mutator_lock_);
119  mirror::ObjectArray<mirror::Object>* GetImageRoots() const;
120
121  void RelocateImage(off_t delta);
122
123 private:
124  static const byte kImageMagic[4];
125  static const byte kImageVersion[4];
126
127  byte magic_[4];
128  byte version_[4];
129
130  // Required base address for mapping the image.
131  uint32_t image_begin_;
132
133  // Image size, not page aligned.
134  uint32_t image_size_;
135
136  // Image bitmap offset in the file.
137  uint32_t image_bitmap_offset_;
138
139  // Size of the image bitmap.
140  uint32_t image_bitmap_size_;
141
142  // Checksum of the oat file we link to for load time sanity check.
143  uint32_t oat_checksum_;
144
145  // Start address for oat file. Will be before oat_data_begin_ for .so files.
146  uint32_t oat_file_begin_;
147
148  // Required oat address expected by image Method::GetCode() pointers.
149  uint32_t oat_data_begin_;
150
151  // End of oat data address range for this image file.
152  uint32_t oat_data_end_;
153
154  // End of oat file address range. will be after oat_data_end_ for
155  // .so files. Used for positioning a following alloc spaces.
156  uint32_t oat_file_end_;
157
158  // The total delta that this image has been patched.
159  int32_t patch_delta_;
160
161  // Absolute address of an Object[] of objects needed to reinitialize from an image.
162  uint32_t image_roots_;
163
164  friend class ImageWriter;
165};
166
167}  // namespace art
168
169#endif  // ART_RUNTIME_IMAGE_H_
170