Files
swift-mirror/include/swift/SwiftReflection/MemoryReaderInterface.h
T
David Farler 579ce977f0 swift-reflection-test: Replace Mach IPC with pipes
This is more amenable to cross-platform remote reflection tests.

Also add a new callback to the memory reader: getSymbolAddress,
which will be used for getting the addresses of nominal type
descriptors for concrete and fixed generic types.
2016-03-17 19:02:01 -07:00

82 lines
2.7 KiB
C++

//===--- MemoryReaderInterface.h - Public reader interface ------*- C++ -*-===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2016 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See http://swift.org/LICENSE.txt for license information
// See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
///
/// \file
/// This header declares the MemoryReader interface struct, which is a
/// a collection of function pointers to provide reading memory from external
/// processes.
///
//===----------------------------------------------------------------------===//
#ifndef SWIFT_REFLECTION_MEMORYREADERINTERFACE_H
#define SWIFT_REFLECTION_MEMORYREADERINTERFACE_H
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
typedef uint64_t addr_t;
typedef struct MemoryReaderImpl {
/// Get the size in bytes of the target's pointer type.
uint8_t (*getPointerSize)();
/// Get the size in bytes of the target's size type.
uint8_t (*getSizeSize)();
// FIXME: -Wdocumentation complains about \param and \returns on function pointers.
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdocumentation"
/// Read a sequence of bytes at an address in the target.
///
/// \param address the address in the target address space
/// \param dest the caller-owned buffer into which to store the string
/// \param size the number of bytes to read
/// \returns true if the read was successful
bool (*readBytes)(addr_t address, uint8_t *dest, uint64_t size);
/// Read an integer scalar from the target.
///
/// \parameter address the address in the target address space
/// \param value the local address to store the result of the read
/// \param size the size in bytes of the integer type
/// \returns true if the read was successful.
bool (*readInteger)(addr_t address, uint64_t *value, uint8_t size);
/// Get the string length at the given address.
///
/// This scan always occurs in a read-only data section. If the scan
/// would go beyond the section boundary, a length of 0 should be
/// returned.
///
/// \param address the address in the target address space
/// \returns The length of the string or 0 if the scan was unsuccessful.
uint64_t (*getStringLength)(addr_t address);
/// Get the address of a symbol in the target address space.
///
/// \returns true if the lookup was successful.
addr_t (*getSymbolAddress)(const char *name, uint64_t name_length);
#pragma clang diagnostic pop
} MemoryReaderImpl;
#ifdef __cplusplus
} // extern "C"
#endif
#endif //SWIFT_REFLECTION_MEMORYREADERINTERFACE_H