mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
832d563044
Summary: This patch adds the ability to read a yaml form of a minidump file and write it out as binary. Apart from the minidump header and the stream directory, only three basic stream kinds are supported: - Text: This kind is used for streams which contain textual data. This is typically the contents of a /proc file on linux (e.g. /proc/PID/maps). In this case, we just put the raw stream contents into the yaml. - SystemInfo: This stream contains various bits of information about the host system in binary form. We expose the data in a structured form. - Raw: This kind is used as a fallback when we don't have any special knowledge about the stream. In this case, we just print the stream contents in hex. For this code to be really useful, more stream kinds will need to be added (particularly for things like lists of memory regions and loaded modules). However, these can be added incrementally. Reviewers: jhenderson, zturner, clayborg, aprantl Subscribers: mgorny, lemo, llvm-commits, lldb-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D59482 llvm-svn: 356753
66 lines
2.7 KiB
C++
66 lines
2.7 KiB
C++
//===- ObjectYAML.cpp - YAML utilities for object files -------------------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines a wrapper class for handling tagged YAML input
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/ObjectYAML/ObjectYAML.h"
|
|
#include "llvm/ADT/Twine.h"
|
|
#include "llvm/Support/YAMLParser.h"
|
|
#include "llvm/Support/YAMLTraits.h"
|
|
#include <string>
|
|
|
|
using namespace llvm;
|
|
using namespace yaml;
|
|
|
|
void MappingTraits<YamlObjectFile>::mapping(IO &IO,
|
|
YamlObjectFile &ObjectFile) {
|
|
if (IO.outputting()) {
|
|
if (ObjectFile.Elf)
|
|
MappingTraits<ELFYAML::Object>::mapping(IO, *ObjectFile.Elf);
|
|
if (ObjectFile.Coff)
|
|
MappingTraits<COFFYAML::Object>::mapping(IO, *ObjectFile.Coff);
|
|
if (ObjectFile.MachO)
|
|
MappingTraits<MachOYAML::Object>::mapping(IO, *ObjectFile.MachO);
|
|
if (ObjectFile.FatMachO)
|
|
MappingTraits<MachOYAML::UniversalBinary>::mapping(IO,
|
|
*ObjectFile.FatMachO);
|
|
} else {
|
|
if (IO.mapTag("!ELF")) {
|
|
ObjectFile.Elf.reset(new ELFYAML::Object());
|
|
MappingTraits<ELFYAML::Object>::mapping(IO, *ObjectFile.Elf);
|
|
} else if (IO.mapTag("!COFF")) {
|
|
ObjectFile.Coff.reset(new COFFYAML::Object());
|
|
MappingTraits<COFFYAML::Object>::mapping(IO, *ObjectFile.Coff);
|
|
} else if (IO.mapTag("!mach-o")) {
|
|
ObjectFile.MachO.reset(new MachOYAML::Object());
|
|
MappingTraits<MachOYAML::Object>::mapping(IO, *ObjectFile.MachO);
|
|
} else if (IO.mapTag("!fat-mach-o")) {
|
|
ObjectFile.FatMachO.reset(new MachOYAML::UniversalBinary());
|
|
MappingTraits<MachOYAML::UniversalBinary>::mapping(IO,
|
|
*ObjectFile.FatMachO);
|
|
} else if (IO.mapTag("!minidump")) {
|
|
ObjectFile.Minidump.reset(new MinidumpYAML::Object());
|
|
MappingTraits<MinidumpYAML::Object>::mapping(IO, *ObjectFile.Minidump);
|
|
} else if (IO.mapTag("!WASM")) {
|
|
ObjectFile.Wasm.reset(new WasmYAML::Object());
|
|
MappingTraits<WasmYAML::Object>::mapping(IO, *ObjectFile.Wasm);
|
|
} else {
|
|
Input &In = (Input &)IO;
|
|
std::string Tag = In.getCurrentNode()->getRawTag();
|
|
if (Tag.empty())
|
|
IO.setError("YAML Object File missing document type tag!");
|
|
else
|
|
IO.setError(
|
|
Twine("YAML Object File unsupported document type tag '") +
|
|
Twine(Tag) + Twine("'!"));
|
|
}
|
|
}
|
|
}
|