mirror of
https://github.com/LongSoft/UEFITool.git
synced 2024-11-27 18:38:23 +08:00
63088afd87
+ FFSv3 support with large files and large sections + proper names for Flash Descriptor v2 regions (#89) + better alignment calculations (#96) + improved NVRAM parser + post IBB hash support for Boot Guard + bugfixes + companion tool updated
92 lines
4.3 KiB
C++
92 lines
4.3 KiB
C++
/* nvramparser.h
|
|
|
|
Copyright (c) 2016, Nikolaj Schlej. All rights reserved.
|
|
|
|
This program and the accompanying materials
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
http://opensource.org/licenses/bsd-license.php.
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
*/
|
|
|
|
#ifndef NVRAMPARSER_H
|
|
#define NVRAMPARSER_H
|
|
|
|
#include <vector>
|
|
|
|
#include "basetypes.h"
|
|
#include "ustring.h"
|
|
#include "ubytearray.h"
|
|
#include "treemodel.h"
|
|
#include "ffsparser.h"
|
|
|
|
#ifdef U_ENABLE_NVRAM_PARSING_SUPPORT
|
|
class NvramParser
|
|
{
|
|
public:
|
|
// Default constructor and destructor
|
|
NvramParser(TreeModel* treeModel, FfsParser* parser) : model(treeModel), ffsParser(parser) {}
|
|
~NvramParser() {}
|
|
|
|
// Returns messages
|
|
std::vector<std::pair<UString, UModelIndex> > getMessages() const { return messagesVector; }
|
|
// Clears messages
|
|
void clearMessages() { messagesVector.clear(); }
|
|
|
|
// NVRAM parsing
|
|
USTATUS parseNvramVolumeBody(const UModelIndex & index);
|
|
USTATUS parseNvarStore(const UModelIndex & index);
|
|
|
|
private:
|
|
TreeModel *model;
|
|
FfsParser *ffsParser;
|
|
std::vector<std::pair<UString, UModelIndex> > messagesVector;
|
|
void msg(const UString message, const UModelIndex index = UModelIndex()) {
|
|
messagesVector.push_back(std::pair<UString, UModelIndex>(message, index));
|
|
};
|
|
|
|
USTATUS findNextStore(const UModelIndex & index, const UByteArray & volume, const UINT32 localOffset, const UINT32 storeOffset, UINT32 & nextStoreOffset);
|
|
USTATUS getStoreSize(const UByteArray & data, const UINT32 storeOffset, UINT32 & storeSize);
|
|
USTATUS parseStoreHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
|
|
USTATUS parseVssStoreHeader(const UByteArray & store, const UINT32 localOffset, const bool sizeOverride, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseVss2StoreHeader(const UByteArray & store, const UINT32 localOffset, const bool sizeOverride, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseFtwStoreHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseFdcStoreHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseFsysStoreHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseEvsaStoreHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseFlashMapStoreHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseCmdbStoreHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseSlicPubkeyHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseSlicMarkerHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
USTATUS parseIntelMicrocodeHeader(const UByteArray & store, const UINT32 localOffset, const UModelIndex & parent, UModelIndex & index);
|
|
|
|
USTATUS parseFdcStoreBody(const UModelIndex & index);
|
|
USTATUS parseVssStoreBody(const UModelIndex & index, const UINT8 alignment);
|
|
USTATUS parseFsysStoreBody(const UModelIndex & index);
|
|
USTATUS parseEvsaStoreBody(const UModelIndex & index);
|
|
USTATUS parseFlashMapBody(const UModelIndex & index);
|
|
};
|
|
#else
|
|
class NvramParser
|
|
{
|
|
public:
|
|
// Default constructor and destructor
|
|
NvramParser(TreeModel* treeModel, FfsParser* parser) { U_UNUSED_PARAMETER(treeModel); U_UNUSED_PARAMETER(parser); }
|
|
~NvramParser() {}
|
|
|
|
// Returns messages
|
|
std::vector<std::pair<UString, UModelIndex> > getMessages() const { return std::vector<std::pair<UString, UModelIndex> >(); }
|
|
// Clears messages
|
|
void clearMessages() {}
|
|
|
|
// NVRAM parsing
|
|
USTATUS parseNvramVolumeBody(const UModelIndex &) { return U_SUCCESS; }
|
|
USTATUS parseNvarStore(const UModelIndex &) { return U_SUCCESS; }
|
|
};
|
|
#endif // U_ENABLE_NVRAM_PARSING_SUPPORT
|
|
#endif // NVRAMPARSER_H
|