| 
									
										
										
										
											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
 |