101 lines
2.9 KiB
C
Raw Normal View History

2013-06-05 18:35:38 +02:00
//===-- sanitizer_procmaps.h ------------------------------------*- C++ -*-===//
//
2022-07-15 14:33:44 +02:00
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
2013-06-05 18:35:38 +02:00
//
//===----------------------------------------------------------------------===//
//
// This file is shared between AddressSanitizer and ThreadSanitizer.
//
// Information about the process mappings.
//===----------------------------------------------------------------------===//
#ifndef SANITIZER_PROCMAPS_H
#define SANITIZER_PROCMAPS_H
2022-07-15 14:28:41 +02:00
#include "sanitizer_platform.h"
2022-07-15 14:33:44 +02:00
#if SANITIZER_LINUX || SANITIZER_FREEBSD || SANITIZER_NETBSD || \
SANITIZER_MAC || SANITIZER_SOLARIS || \
SANITIZER_FUCHSIA
2022-07-15 14:28:41 +02:00
2016-02-29 10:41:25 +01:00
#include "sanitizer_common.h"
2013-06-05 18:35:38 +02:00
#include "sanitizer_internal_defs.h"
2022-07-15 14:33:44 +02:00
#include "sanitizer_fuchsia.h"
2022-07-15 14:28:41 +02:00
#include "sanitizer_linux.h"
#include "sanitizer_mac.h"
2013-06-05 18:35:38 +02:00
#include "sanitizer_mutex.h"
namespace __sanitizer {
2022-07-15 14:28:41 +02:00
// Memory protection masks.
static const uptr kProtectionRead = 1;
static const uptr kProtectionWrite = 2;
static const uptr kProtectionExecute = 4;
static const uptr kProtectionShared = 8;
struct MemoryMappedSegmentData;
class MemoryMappedSegment {
public:
2022-07-15 14:33:44 +02:00
explicit MemoryMappedSegment(char *buff = nullptr, uptr size = 0)
2022-07-15 14:28:41 +02:00
: filename(buff), filename_size(size), data_(nullptr) {}
~MemoryMappedSegment() {}
bool IsReadable() const { return protection & kProtectionRead; }
bool IsWritable() const { return protection & kProtectionWrite; }
bool IsExecutable() const { return protection & kProtectionExecute; }
bool IsShared() const { return protection & kProtectionShared; }
void AddAddressRanges(LoadedModule *module);
uptr start;
uptr end;
uptr offset;
char *filename; // owned by caller
uptr filename_size;
uptr protection;
ModuleArch arch;
u8 uuid[kModuleUUIDSize];
private:
friend class MemoryMappingLayout;
// This field is assigned and owned by MemoryMappingLayout if needed
MemoryMappedSegmentData *data_;
};
2013-06-05 18:35:38 +02:00
class MemoryMappingLayout {
public:
2016-02-29 10:41:25 +01:00
explicit MemoryMappingLayout(bool cache_enabled);
~MemoryMappingLayout();
2022-07-15 14:28:41 +02:00
bool Next(MemoryMappedSegment *segment);
2022-07-15 14:33:44 +02:00
bool Error() const;
2013-06-05 18:35:38 +02:00
void Reset();
// In some cases, e.g. when running under a sandbox on Linux, ASan is unable
// to obtain the memory mappings. It should fall back to pre-cached data
// instead of aborting.
static void CacheMemoryMappings();
2016-02-29 10:41:25 +01:00
2022-07-15 14:14:32 +02:00
// Adds all mapped objects into a vector.
2022-07-15 14:28:41 +02:00
void DumpListOfModules(InternalMmapVectorNoCtor<LoadedModule> *modules);
2013-06-05 18:35:38 +02:00
private:
void LoadFromCache();
2016-02-29 10:41:25 +01:00
2022-07-15 14:28:41 +02:00
MemoryMappingLayoutData data_;
2013-06-05 18:35:38 +02:00
};
2016-02-29 10:41:25 +01:00
// Returns code range for the specified module.
bool GetCodeRangeForFile(const char *module, uptr *start, uptr *end);
bool IsDecimal(char c);
uptr ParseDecimal(const char **p);
bool IsHex(char c);
uptr ParseHex(const char **p);
2013-06-05 18:35:38 +02:00
} // namespace __sanitizer
2022-07-15 14:33:44 +02:00
#endif
2013-06-05 18:35:38 +02:00
#endif // SANITIZER_PROCMAPS_H