2022-04-23 04:59:50 -04:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2019 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2019-03-20 12:40:09 -04:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <cstddef>
|
|
|
|
|
2023-03-17 21:26:04 -04:00
|
|
|
#include "core/hle/kernel/k_typed_address.h"
|
2019-07-18 18:15:53 -04:00
|
|
|
#include "core/hle/kernel/physical_memory.h"
|
2019-03-20 12:40:09 -04:00
|
|
|
|
|
|
|
namespace Kernel {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents executable data that may be loaded into a kernel process.
|
|
|
|
*
|
|
|
|
* A code set consists of three basic segments:
|
|
|
|
* - A code (AKA text) segment,
|
|
|
|
* - A read-only data segment (rodata)
|
|
|
|
* - A data segment
|
|
|
|
*
|
|
|
|
* The code segment is the portion of the object file that contains
|
|
|
|
* executable instructions.
|
|
|
|
*
|
|
|
|
* The read-only data segment in the portion of the object file that
|
|
|
|
* contains (as one would expect) read-only data, such as fixed constant
|
|
|
|
* values and data structures.
|
|
|
|
*
|
|
|
|
* The data segment is similar to the read-only data segment -- it contains
|
|
|
|
* variables and data structures that have predefined values, however,
|
|
|
|
* entities within this segment can be modified.
|
|
|
|
*/
|
|
|
|
struct CodeSet final {
|
|
|
|
/// A single segment within a code set.
|
|
|
|
struct Segment final {
|
|
|
|
/// The byte offset that this segment is located at.
|
|
|
|
std::size_t offset = 0;
|
|
|
|
|
|
|
|
/// The address to map this segment to.
|
2023-03-17 21:26:04 -04:00
|
|
|
KProcessAddress addr = 0;
|
2019-03-20 12:40:09 -04:00
|
|
|
|
|
|
|
/// The size of this segment in bytes.
|
|
|
|
u32 size = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
explicit CodeSet();
|
|
|
|
~CodeSet();
|
|
|
|
|
|
|
|
CodeSet(const CodeSet&) = delete;
|
|
|
|
CodeSet& operator=(const CodeSet&) = delete;
|
|
|
|
|
|
|
|
CodeSet(CodeSet&&) = default;
|
|
|
|
CodeSet& operator=(CodeSet&&) = default;
|
|
|
|
|
|
|
|
Segment& CodeSegment() {
|
|
|
|
return segments[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
const Segment& CodeSegment() const {
|
|
|
|
return segments[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
Segment& RODataSegment() {
|
|
|
|
return segments[1];
|
|
|
|
}
|
|
|
|
|
|
|
|
const Segment& RODataSegment() const {
|
|
|
|
return segments[1];
|
|
|
|
}
|
|
|
|
|
|
|
|
Segment& DataSegment() {
|
|
|
|
return segments[2];
|
|
|
|
}
|
|
|
|
|
|
|
|
const Segment& DataSegment() const {
|
|
|
|
return segments[2];
|
|
|
|
}
|
|
|
|
|
|
|
|
/// The overall data that backs this code set.
|
2019-07-18 18:15:53 -04:00
|
|
|
Kernel::PhysicalMemory memory;
|
2019-03-20 12:40:09 -04:00
|
|
|
|
|
|
|
/// The segments that comprise this code set.
|
|
|
|
std::array<Segment, 3> segments;
|
|
|
|
|
|
|
|
/// The entry point address for this code set.
|
2023-03-17 21:26:04 -04:00
|
|
|
KProcessAddress entrypoint = 0;
|
2019-03-20 12:40:09 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Kernel
|