mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 11:32:43 +00:00 
			
		
		
		
	 649d2faeab
			
		
	
	
		649d2faeab
		
	
	
	
	
		
			
			We had some inconsistencies before: - Sometimes "The", sometimes "the" - Sometimes trailing ".", sometimes no trailing "." I picked the most common one (lowecase "the", trailing ".") and applied it to all copyright headers. By using the exact same string everywhere we can ensure nothing gets missed during a global search (and replace), and that these inconsistencies are not spread any further (as copyright headers are commonly copied to new files).
		
			
				
	
	
		
			80 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/String.h>
 | |
| #include <AK/Types.h>
 | |
| #include <LibC/sys/arch/i386/regs.h>
 | |
| 
 | |
| namespace ELF::Core {
 | |
| 
 | |
| struct [[gnu::packed]] NotesEntryHeader {
 | |
|     enum Type : u8 {
 | |
|         Null = 0, // Terminates segment
 | |
|         ProcessInfo,
 | |
|         ThreadInfo,
 | |
|         MemoryRegionInfo,
 | |
|         Metadata,
 | |
|     };
 | |
|     Type type;
 | |
| };
 | |
| 
 | |
| struct [[gnu::packed]] NotesEntry {
 | |
|     NotesEntryHeader header;
 | |
|     char data[];
 | |
| };
 | |
| 
 | |
| struct [[gnu::packed]] ProcessInfo {
 | |
|     NotesEntryHeader header;
 | |
|     // Information is stored as JSON blob to allow arbitrary
 | |
|     // number and length of strings/objects/arrays.
 | |
|     //
 | |
|     // Keys:
 | |
|     // - "pid" (int)
 | |
|     // - "termination_signal" (u8)
 | |
|     // - "executable_path" (String)
 | |
|     // - "arguments" (Vector<String>)
 | |
|     // - "environment" (Vector<String>)
 | |
|     char json_data[]; // Null terminated
 | |
| };
 | |
| 
 | |
| struct [[gnu::packed]] ThreadInfo {
 | |
|     NotesEntryHeader header;
 | |
|     int tid;
 | |
|     PtraceRegisters regs;
 | |
| };
 | |
| 
 | |
| struct [[gnu::packed]] MemoryRegionInfo {
 | |
|     NotesEntryHeader header;
 | |
|     uint32_t region_start;
 | |
|     uint32_t region_end;
 | |
|     uint16_t program_header_index;
 | |
|     char region_name[]; // Null terminated
 | |
| 
 | |
|     String object_name() const
 | |
|     {
 | |
|         StringView memory_region_name { region_name };
 | |
|         if (memory_region_name.contains("Loader.so"))
 | |
|             return "Loader.so";
 | |
|         if (!memory_region_name.contains(":"))
 | |
|             return {};
 | |
|         return memory_region_name.substring_view(0, memory_region_name.find_first_of(":").value()).to_string();
 | |
|     }
 | |
| };
 | |
| 
 | |
| struct [[gnu::packed]] Metadata {
 | |
|     NotesEntryHeader header;
 | |
|     // Arbitrary metadata, set via SC_set_coredump_metadata.
 | |
|     // Limited to 16 entries and 16 KiB keys/values by the kernel.
 | |
|     //
 | |
|     // Well-known keys:
 | |
|     // - "assertion": Used by LibC's __assertion_failed() to store assertion info
 | |
|     // - "pledge_violation": Used by the Kernel's REQUIRE_PROMISE() to store pledge violation info
 | |
|     char json_data[]; // Null terminated
 | |
| };
 | |
| 
 | |
| }
 |