| /* |
| * Copyright (C) 2011 The Android Open Source Project |
| * |
| * 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. |
| */ |
| |
| #ifndef ART_RUNTIME_GC_SPACE_IMAGE_SPACE_H_ |
| #define ART_RUNTIME_GC_SPACE_IMAGE_SPACE_H_ |
| |
| #include "space.h" |
| |
| namespace art { |
| |
| class OatFile; |
| |
| namespace gc { |
| namespace space { |
| |
| // An image space is a space backed with a memory mapped image. |
| class ImageSpace : public MemMapSpace { |
| public: |
| SpaceType GetType() const { |
| return kSpaceTypeImageSpace; |
| } |
| |
| // Create a Space from an image file. Cannot be used for future |
| // allocation or collected. |
| // |
| // Create also opens the OatFile associated with the image file so |
| // that it be contiguously allocated with the image before the |
| // creation of the alloc space. The ReleaseOatFile will later be |
| // used to transfer ownership of the OatFile to the ClassLinker when |
| // it is initialized. |
| static ImageSpace* Create(const char* image) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); |
| |
| // Releases the OatFile from the ImageSpace so it can be transfer to |
| // the caller, presumably the ClassLinker. |
| OatFile* ReleaseOatFile() |
| SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); |
| |
| void VerifyImageAllocations() |
| SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); |
| |
| const ImageHeader& GetImageHeader() const { |
| return *reinterpret_cast<ImageHeader*>(Begin()); |
| } |
| |
| const std::string GetImageFilename() const { |
| return GetName(); |
| } |
| |
| accounting::SpaceBitmap* GetLiveBitmap() const { |
| return live_bitmap_.get(); |
| } |
| |
| accounting::SpaceBitmap* GetMarkBitmap() const { |
| // ImageSpaces have the same bitmap for both live and marked. This helps reduce the number of |
| // special cases to test against. |
| return live_bitmap_.get(); |
| } |
| |
| void Dump(std::ostream& os) const; |
| |
| // Sweeping image spaces is a NOP. |
| void Sweep(bool /* swap_bitmaps */, size_t* /* freed_objects */, size_t* /* freed_bytes */) { |
| } |
| |
| private: |
| // Tries to initialize an ImageSpace from the given image path, |
| // returning NULL on error. |
| // |
| // If validate_oat_file is false (for /system), do not verify that |
| // image's OatFile is up-to-date relative to its DexFile |
| // inputs. Otherwise (for /data), validate the inputs and generate |
| // the OatFile in /data/dalvik-cache if necessary. |
| static ImageSpace* Init(const char* image, bool validate_oat_file, std::string* error_msg) |
| SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); |
| |
| OatFile* OpenOatFile(std::string* error_msg) const |
| SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); |
| |
| bool ValidateOatFile(std::string* error_msg) const |
| SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); |
| |
| friend class Space; |
| |
| static Atomic<uint32_t> bitmap_index_; |
| |
| UniquePtr<accounting::SpaceBitmap> live_bitmap_; |
| |
| ImageSpace(const std::string& name, MemMap* mem_map, accounting::SpaceBitmap* live_bitmap); |
| |
| // The OatFile associated with the image during early startup to |
| // reserve space contiguous to the image. It is later released to |
| // the ClassLinker during it's initialization. |
| UniquePtr<OatFile> oat_file_; |
| |
| DISALLOW_COPY_AND_ASSIGN(ImageSpace); |
| }; |
| |
| } // namespace space |
| } // namespace gc |
| } // namespace art |
| |
| #endif // ART_RUNTIME_GC_SPACE_IMAGE_SPACE_H_ |