2020-11-06 08:09:51 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2019-2020, Jesse Buhagiar <jooster669@gmail.com>
|
|
|
|
* Copyright (c) 2020, Itamar S. <itamar8910@gmail.com>
|
|
|
|
*
|
2021-04-22 08:24:48 +00:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-11-06 08:09:51 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2020-11-11 20:02:39 +00:00
|
|
|
|
2020-11-06 08:09:51 +00:00
|
|
|
#include <AK/OwnPtr.h>
|
2022-08-23 18:51:42 +00:00
|
|
|
#include <AK/Vector.h>
|
2020-11-06 08:09:51 +00:00
|
|
|
#include <Kernel/Forward.h>
|
2022-08-19 18:53:40 +00:00
|
|
|
#include <Kernel/Library/NonnullLockRefPtr.h>
|
2022-08-23 18:51:42 +00:00
|
|
|
#include <Kernel/Memory/Region.h>
|
2020-11-06 08:09:51 +00:00
|
|
|
|
|
|
|
namespace Kernel {
|
|
|
|
|
2021-08-22 12:51:04 +00:00
|
|
|
class Coredump {
|
2020-11-06 08:09:51 +00:00
|
|
|
public:
|
2022-08-19 18:53:40 +00:00
|
|
|
static ErrorOr<NonnullOwnPtr<Coredump>> try_create(NonnullLockRefPtr<Process>, StringView output_path);
|
2020-11-06 08:09:51 +00:00
|
|
|
|
2021-08-22 12:51:04 +00:00
|
|
|
~Coredump() = default;
|
2021-11-07 23:51:39 +00:00
|
|
|
ErrorOr<void> write();
|
2020-11-06 08:09:51 +00:00
|
|
|
|
|
|
|
private:
|
2022-08-23 18:51:42 +00:00
|
|
|
class FlatRegionData {
|
|
|
|
public:
|
|
|
|
explicit FlatRegionData(Memory::Region const& region, NonnullOwnPtr<KString> name)
|
|
|
|
: m_access(region.access())
|
|
|
|
, m_is_executable(region.is_executable())
|
|
|
|
, m_is_kernel(region.is_kernel())
|
|
|
|
, m_is_readable(region.is_readable())
|
|
|
|
, m_is_writable(region.is_writable())
|
|
|
|
, m_name(move(name))
|
|
|
|
, m_page_count(region.page_count())
|
|
|
|
, m_size(region.size())
|
|
|
|
, m_vaddr(region.vaddr())
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
auto access() const { return m_access; }
|
|
|
|
auto name() const { return m_name->view(); }
|
|
|
|
auto is_executable() const { return m_is_executable; }
|
|
|
|
auto is_kernel() const { return m_is_kernel; }
|
|
|
|
auto is_readable() const { return m_is_readable; }
|
|
|
|
auto is_writable() const { return m_is_writable; }
|
|
|
|
auto page_count() const { return m_page_count; }
|
|
|
|
auto size() const { return m_size; }
|
|
|
|
auto vaddr() const { return m_vaddr; }
|
|
|
|
|
|
|
|
bool looks_like_userspace_heap_region() const;
|
|
|
|
bool is_consistent_with_region(Memory::Region const& region) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
Memory::Region::Access m_access;
|
|
|
|
bool m_is_executable;
|
|
|
|
bool m_is_kernel;
|
|
|
|
bool m_is_readable;
|
|
|
|
bool m_is_writable;
|
|
|
|
NonnullOwnPtr<KString> m_name;
|
|
|
|
size_t m_page_count;
|
|
|
|
size_t m_size;
|
|
|
|
VirtualAddress m_vaddr;
|
|
|
|
};
|
|
|
|
|
|
|
|
Coredump(NonnullLockRefPtr<Process>, NonnullLockRefPtr<OpenFileDescription>, Vector<FlatRegionData>);
|
2022-08-19 18:53:40 +00:00
|
|
|
static ErrorOr<NonnullLockRefPtr<OpenFileDescription>> try_create_target_file(Process const&, StringView output_path);
|
2021-11-07 23:51:39 +00:00
|
|
|
|
|
|
|
ErrorOr<void> write_elf_header();
|
|
|
|
ErrorOr<void> write_program_headers(size_t notes_size);
|
|
|
|
ErrorOr<void> write_regions();
|
|
|
|
ErrorOr<void> write_notes_segment(ReadonlyBytes);
|
|
|
|
|
|
|
|
ErrorOr<void> create_notes_segment_data(auto&) const;
|
|
|
|
ErrorOr<void> create_notes_process_data(auto&) const;
|
|
|
|
ErrorOr<void> create_notes_threads_data(auto&) const;
|
|
|
|
ErrorOr<void> create_notes_regions_data(auto&) const;
|
|
|
|
ErrorOr<void> create_notes_metadata_data(auto&) const;
|
2020-11-06 08:09:51 +00:00
|
|
|
|
2022-08-19 18:53:40 +00:00
|
|
|
NonnullLockRefPtr<Process> m_process;
|
|
|
|
NonnullLockRefPtr<OpenFileDescription> m_description;
|
2021-09-30 15:52:02 +00:00
|
|
|
size_t m_num_program_headers { 0 };
|
2022-08-23 18:51:42 +00:00
|
|
|
Vector<FlatRegionData> m_regions;
|
2020-11-06 08:09:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|