This provides a better layering of responsibilities among different aspects of PDB writing code. Some of the MSF related code was contained in CodeView, and some was in PDB prior to this. Further, we were often saying PDB when we meant MSF, and the two are actually independent of each other since in theory you can have other types of data besides PDB data in an MSF. So, this patch separates the MSF specific code into its own library, with no dependencies on anything else, and DebugInfoCodeView and DebugInfoPDB take dependencies on DebugInfoMsf. llvm-svn: 276458
49 lines
1.9 KiB
C++
49 lines
1.9 KiB
C++
//===- MsfCommon.cpp - Common types and functions for MSF files -*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/DebugInfo/Msf/MsfCommon.h"
|
|
#include "llvm/DebugInfo/Msf/MsfError.h"
|
|
|
|
using namespace llvm;
|
|
using namespace llvm::msf;
|
|
|
|
Error llvm::msf::validateSuperBlock(const SuperBlock &SB) {
|
|
// Check the magic bytes.
|
|
if (std::memcmp(SB.MagicBytes, Magic, sizeof(Magic)) != 0)
|
|
return make_error<MsfError>(msf_error_code::invalid_format,
|
|
"MSF magic header doesn't match");
|
|
|
|
if (!isValidBlockSize(SB.BlockSize))
|
|
return make_error<MsfError>(msf_error_code::invalid_format,
|
|
"Unsupported block size.");
|
|
|
|
// We don't support directories whose sizes aren't a multiple of four bytes.
|
|
if (SB.NumDirectoryBytes % sizeof(support::ulittle32_t) != 0)
|
|
return make_error<MsfError>(msf_error_code::invalid_format,
|
|
"Directory size is not multiple of 4.");
|
|
|
|
// The number of blocks which comprise the directory is a simple function of
|
|
// the number of bytes it contains.
|
|
uint64_t NumDirectoryBlocks =
|
|
bytesToBlocks(SB.NumDirectoryBytes, SB.BlockSize);
|
|
|
|
// The directory, as we understand it, is a block which consists of a list of
|
|
// block numbers. It is unclear what would happen if the number of blocks
|
|
// couldn't fit on a single block.
|
|
if (NumDirectoryBlocks > SB.BlockSize / sizeof(support::ulittle32_t))
|
|
return make_error<MsfError>(msf_error_code::invalid_format,
|
|
"Too many directory blocks.");
|
|
|
|
if (SB.BlockMapAddr == 0)
|
|
return make_error<MsfError>(msf_error_code::invalid_format,
|
|
"Block 0 is reserved");
|
|
|
|
return Error::success();
|
|
}
|