2010-06-09 00:52:24 +08:00
|
|
|
//===-- DNBDataRef.h --------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08: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
|
2010-06-09 00:52:24 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// Created by Greg Clayton on 1/11/06.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// DNBDataRef is a class that can extract data in normal or byte
|
|
|
|
// swapped order from a data buffer that someone else owns. The data
|
|
|
|
// buffer needs to remain intact as long as the DNBDataRef object
|
|
|
|
// needs the data. Strings returned are pointers into the data buffer
|
|
|
|
// and will need to be copied if they are needed after the data buffer
|
|
|
|
// is no longer around.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2020-02-18 07:57:45 +08:00
|
|
|
#ifndef LLDB_TOOLS_DEBUGSERVER_SOURCE_DNBDATAREF_H
|
|
|
|
#define LLDB_TOOLS_DEBUGSERVER_SOURCE_DNBDATAREF_H
|
2010-06-09 00:52:24 +08:00
|
|
|
|
|
|
|
#include "DNBDefs.h"
|
|
|
|
#include <limits.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
class DNBDataRef {
|
|
|
|
public:
|
|
|
|
// For use with Dump
|
2019-05-14 16:55:50 +08:00
|
|
|
enum Type {
|
2010-06-09 00:52:24 +08:00
|
|
|
TypeUInt8 = 0,
|
|
|
|
TypeChar,
|
|
|
|
TypeUInt16,
|
|
|
|
TypeUInt32,
|
|
|
|
TypeUInt64,
|
|
|
|
TypePointer,
|
|
|
|
TypeULEB128,
|
|
|
|
TypeSLEB128
|
2019-05-14 16:55:50 +08:00
|
|
|
};
|
2010-06-09 00:52:24 +08:00
|
|
|
typedef uint32_t offset_t;
|
|
|
|
typedef nub_addr_t addr_t;
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
DNBDataRef();
|
|
|
|
DNBDataRef(const uint8_t *start, size_t size, bool swap);
|
|
|
|
~DNBDataRef();
|
|
|
|
void Clear() {
|
|
|
|
DNBDataRef::SetData(NULL, 0);
|
|
|
|
m_swap = false;
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
|
|
|
|
size_t BytesLeft(size_t offset) const {
|
|
|
|
const size_t size = GetSize();
|
2013-03-21 08:24:59 +08:00
|
|
|
if (size > offset)
|
2010-06-09 00:52:24 +08:00
|
|
|
return size - offset;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2015-03-10 03:45:23 +08:00
|
|
|
bool ValidOffset(offset_t offset) const { return BytesLeft(offset) > 0; }
|
|
|
|
bool ValidOffsetForDataOfSize(offset_t offset, uint32_t num_bytes) const {
|
2013-03-21 08:24:59 +08:00
|
|
|
return num_bytes <= BytesLeft(offset);
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2015-03-10 03:45:23 +08:00
|
|
|
size_t GetSize() const { return m_end - m_start; }
|
2010-06-09 00:52:24 +08:00
|
|
|
const uint8_t *GetDataStart() const { return m_start; }
|
2013-03-21 08:24:59 +08:00
|
|
|
const uint8_t *GetDataEnd() const { return m_end; }
|
2015-03-10 03:45:23 +08:00
|
|
|
bool GetSwap() const { return m_swap; }
|
2010-06-09 00:52:24 +08:00
|
|
|
void SetSwap(bool swap) { m_swap = swap; }
|
2015-03-10 03:45:23 +08:00
|
|
|
void SetData(const uint8_t *start, size_t size) {
|
2010-06-09 00:52:24 +08:00
|
|
|
m_start = start;
|
|
|
|
if (m_start != NULL)
|
|
|
|
m_end = start + size;
|
2016-09-07 04:57:50 +08:00
|
|
|
else
|
2010-06-09 00:52:24 +08:00
|
|
|
m_end = NULL;
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
uint8_t GetPointerSize() const { return m_ptrSize; }
|
2015-03-10 03:45:23 +08:00
|
|
|
void SetPointerSize(uint8_t size) { m_ptrSize = size; }
|
2010-06-09 00:52:24 +08:00
|
|
|
void SetEHPtrBaseAddrPCRelative(addr_t addr = INVALID_NUB_ADDRESS) {
|
2013-03-21 08:24:59 +08:00
|
|
|
m_addrPCRelative = addr;
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
void SetEHPtrBaseAddrTEXT(addr_t addr = INVALID_NUB_ADDRESS) {
|
|
|
|
m_addrTEXT = addr;
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
void SetEHPtrBaseAddrDATA(addr_t addr = INVALID_NUB_ADDRESS) {
|
|
|
|
m_addrDATA = addr;
|
2016-09-07 04:57:50 +08:00
|
|
|
}
|
2010-06-09 00:52:24 +08:00
|
|
|
uint8_t Get8(offset_t *offset_ptr) const;
|
|
|
|
uint16_t Get16(offset_t *offset_ptr) const;
|
|
|
|
uint32_t Get32(offset_t *offset_ptr) const;
|
|
|
|
uint64_t Get64(offset_t *offset_ptr) const;
|
2013-03-21 08:24:59 +08:00
|
|
|
uint32_t GetMax32(offset_t *offset_ptr, uint32_t byte_size) const;
|
2010-06-09 00:52:24 +08:00
|
|
|
uint64_t GetMax64(offset_t *offset_ptr, uint32_t byte_size) const;
|
|
|
|
uint64_t GetPointer(offset_t *offset_ptr) const;
|
|
|
|
// uint64_t GetDwarfEHPtr(offset_t *offset_ptr, uint32_t eh_ptr_enc)
|
|
|
|
// const;
|
|
|
|
const char *GetCStr(offset_t *offset_ptr, uint32_t fixed_length = 0) const;
|
2013-03-21 08:24:59 +08:00
|
|
|
const char *PeekCStr(offset_t offset) const {
|
|
|
|
if (ValidOffset(offset))
|
|
|
|
return (const char *)m_start + offset;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
const uint8_t *GetData(offset_t *offset_ptr, uint32_t length) const;
|
2010-06-09 00:52:24 +08:00
|
|
|
uint64_t Get_ULEB128(offset_t *offset_ptr) const;
|
|
|
|
int64_t Get_SLEB128(offset_t *offset_ptr) const;
|
|
|
|
void Skip_LEB128(offset_t *offset_ptr) const;
|
|
|
|
|
|
|
|
uint32_t Dump(offset_t startOffset, offset_t endOffset, uint64_t offsetBase,
|
|
|
|
DNBDataRef::Type type, uint32_t numPerLine,
|
|
|
|
const char *typeFormat = NULL);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
const uint8_t *m_start;
|
|
|
|
const uint8_t *m_end;
|
|
|
|
bool m_swap;
|
|
|
|
uint8_t m_ptrSize;
|
|
|
|
addr_t m_addrPCRelative;
|
|
|
|
addr_t m_addrTEXT;
|
|
|
|
addr_t m_addrDATA;
|
|
|
|
};
|
|
|
|
|
2020-02-18 07:57:45 +08:00
|
|
|
#endif // LLDB_TOOLS_DEBUGSERVER_SOURCE_DNBDATAREF_H
|