7f48aa8d25
The loaders will now just create a Kernel::Process, construct it and return it to the caller, which is responsible for setting it as the current process and configuring the global page table.
40 lines
1.1 KiB
C++
40 lines
1.1 KiB
C++
// Copyright 2013 Dolphin Emulator Project / 2014 Citra Emulator Project
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#pragma once
|
|
|
|
#include <string>
|
|
#include "common/common_types.h"
|
|
#include "core/loader/loader.h"
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
// Loader namespace
|
|
|
|
namespace Loader {
|
|
|
|
/// Loads an ELF/AXF file
|
|
class AppLoader_ELF final : public AppLoader {
|
|
public:
|
|
AppLoader_ELF(FileUtil::IOFile&& file, std::string filename)
|
|
: AppLoader(std::move(file)), filename(std::move(filename)) {}
|
|
|
|
/**
|
|
* Returns the type of the file
|
|
* @param file FileUtil::IOFile open file
|
|
* @return FileType found, or FileType::Error if this loader doesn't know it
|
|
*/
|
|
static FileType IdentifyType(FileUtil::IOFile& file);
|
|
|
|
FileType GetFileType() override {
|
|
return IdentifyType(file);
|
|
}
|
|
|
|
ResultStatus Load(Kernel::SharedPtr<Kernel::Process>& process) override;
|
|
|
|
private:
|
|
std::string filename;
|
|
};
|
|
|
|
} // namespace Loader
|