/* * Copyright (C) 2016 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 _LIBUNWINDSTACK_MAP_INFO_H #define _LIBUNWINDSTACK_MAP_INFO_H #include <stdint.h> #include <atomic> #include <memory> #include <mutex> #include <string> #include <unwindstack/Elf.h> #include <unwindstack/Memory.h> namespace unwindstack { struct MapInfo { MapInfo(MapInfo* map_info, uint64_t start, uint64_t end, uint64_t offset, uint64_t flags, const char* name) : start(start), end(end), offset(offset), flags(flags), name(name), prev_map(map_info), load_bias(static_cast<uint64_t>(-1)), build_id(0) {} MapInfo(MapInfo* map_info, uint64_t start, uint64_t end, uint64_t offset, uint64_t flags, const std::string& name) : start(start), end(end), offset(offset), flags(flags), name(name), prev_map(map_info), load_bias(static_cast<uint64_t>(-1)), build_id(0) {} ~MapInfo(); uint64_t start = 0; uint64_t end = 0; uint64_t offset = 0; uint16_t flags = 0; std::string name; std::shared_ptr<Elf> elf; // This value is only non-zero if the offset is non-zero but there is // no elf signature found at that offset. uint64_t elf_offset = 0; // This value is the offset from the map in memory that is the start // of the elf. This is not equal to offset when the linker splits // shared libraries into a read-only and read-execute map. uint64_t elf_start_offset = 0; MapInfo* prev_map = nullptr; std::atomic_uint64_t load_bias; // This is a pointer to a new'd std::string. // Using an atomic value means that we don't need to lock and will // make it easier to move to a fine grained lock in the future. std::atomic_uintptr_t build_id; // Set to true if the elf file data is coming from memory. bool memory_backed_elf = false; // This function guarantees it will never return nullptr. Elf* GetElf(const std::shared_ptr<Memory>& process_memory, ArchEnum expected_arch); uint64_t GetLoadBias(const std::shared_ptr<Memory>& process_memory); Memory* CreateMemory(const std::shared_ptr<Memory>& process_memory); bool GetFunctionName(uint64_t addr, std::string* name, uint64_t* func_offset); // Returns the raw build id read from the elf data. std::string GetBuildID(); // Returns the printable version of the build id (hex dump of raw data). std::string GetPrintableBuildID(); private: MapInfo(const MapInfo&) = delete; void operator=(const MapInfo&) = delete; Memory* GetFileMemory(); bool InitFileMemoryFromPreviousReadOnlyMap(MemoryFileAtOffset* memory); // Protect the creation of the elf object. std::mutex mutex_; }; } // namespace unwindstack #endif // _LIBUNWINDSTACK_MAP_INFO_H