Compare commits
No commits in common. "f0b6844feb30050c8f68ae1c3604bf4a231b1ad6" and "762b7a4276f44999ee8da33420125d90cd172677" have entirely different histories.
f0b6844feb
...
762b7a4276
|
@ -201,7 +201,6 @@ namespace LibELF
|
||||||
return BAN::Error::from_errno(ENOMEM);
|
return BAN::Error::from_errno(ENOMEM);
|
||||||
|
|
||||||
m_page_table.map_page_at(paddr, vaddr, flags);
|
m_page_table.map_page_at(paddr, vaddr, flags);
|
||||||
m_physical_page_count++;
|
|
||||||
|
|
||||||
memset((void*)vaddr, 0x00, PAGE_SIZE);
|
memset((void*)vaddr, 0x00, PAGE_SIZE);
|
||||||
|
|
||||||
|
@ -281,7 +280,6 @@ namespace LibELF
|
||||||
m_page_table.unmap_page(0);
|
m_page_table.unmap_page(0);
|
||||||
|
|
||||||
new_page_table.map_page_at(paddr, start + i * PAGE_SIZE, flags);
|
new_page_table.map_page_at(paddr, start + i * PAGE_SIZE, flags);
|
||||||
elf->m_physical_page_count++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -34,7 +34,6 @@ namespace LibELF
|
||||||
BAN::ErrorOr<BAN::UniqPtr<LoadableELF>> clone(Kernel::PageTable&);
|
BAN::ErrorOr<BAN::UniqPtr<LoadableELF>> clone(Kernel::PageTable&);
|
||||||
|
|
||||||
size_t virtual_page_count() const { return m_virtual_page_count; }
|
size_t virtual_page_count() const { return m_virtual_page_count; }
|
||||||
size_t physical_page_count() const { return m_physical_page_count; }
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
LoadableELF(Kernel::PageTable&, BAN::RefPtr<Kernel::Inode>);
|
LoadableELF(Kernel::PageTable&, BAN::RefPtr<Kernel::Inode>);
|
||||||
|
@ -46,7 +45,6 @@ namespace LibELF
|
||||||
ElfNativeFileHeader m_file_header;
|
ElfNativeFileHeader m_file_header;
|
||||||
BAN::Vector<ElfNativeProgramHeader> m_program_headers;
|
BAN::Vector<ElfNativeProgramHeader> m_program_headers;
|
||||||
size_t m_virtual_page_count = 0;
|
size_t m_virtual_page_count = 0;
|
||||||
size_t m_physical_page_count = 0;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
|
@ -20,11 +20,11 @@ namespace Kernel
|
||||||
Process& m_process;
|
Process& m_process;
|
||||||
};
|
};
|
||||||
|
|
||||||
class ProcROInode final : public RamInode
|
class ProcMemInode final : public RamInode
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
static BAN::ErrorOr<BAN::RefPtr<ProcROInode>> create(Process&, size_t (Process::*callback)(off_t, void*, size_t) const, RamFileSystem&, mode_t, uid_t, gid_t);
|
static BAN::ErrorOr<BAN::RefPtr<ProcMemInode>> create(Process&, RamFileSystem&, mode_t, uid_t, gid_t);
|
||||||
~ProcROInode() = default;
|
~ProcMemInode() = default;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual BAN::ErrorOr<size_t> read_impl(off_t, void*, size_t) override;
|
virtual BAN::ErrorOr<size_t> read_impl(off_t, void*, size_t) override;
|
||||||
|
@ -35,11 +35,10 @@ namespace Kernel
|
||||||
virtual bool has_data_impl() const override { return true; }
|
virtual bool has_data_impl() const override { return true; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ProcROInode(Process&, size_t (Process::*)(off_t, void*, size_t) const, RamFileSystem&, const FullInodeInfo&);
|
ProcMemInode(Process&, RamFileSystem&, const FullInodeInfo&);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Process& m_process;
|
Process& m_process;
|
||||||
size_t (Process::*m_callback)(off_t, void*, size_t) const;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,10 +26,9 @@ namespace Kernel
|
||||||
static BAN::ErrorOr<BAN::UniqPtr<FileBackedRegion>> create(BAN::RefPtr<Inode>, PageTable&, off_t offset, size_t size, AddressRange address_range, Type, PageTable::flags_t);
|
static BAN::ErrorOr<BAN::UniqPtr<FileBackedRegion>> create(BAN::RefPtr<Inode>, PageTable&, off_t offset, size_t size, AddressRange address_range, Type, PageTable::flags_t);
|
||||||
~FileBackedRegion();
|
~FileBackedRegion();
|
||||||
|
|
||||||
virtual BAN::ErrorOr<BAN::UniqPtr<MemoryRegion>> clone(PageTable& new_page_table) override;
|
virtual BAN::ErrorOr<bool> allocate_page_containing(vaddr_t vaddr) override;
|
||||||
|
|
||||||
protected:
|
virtual BAN::ErrorOr<BAN::UniqPtr<MemoryRegion>> clone(PageTable& new_page_table) override;
|
||||||
virtual BAN::ErrorOr<bool> allocate_page_containing_impl(vaddr_t vaddr) override;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
FileBackedRegion(BAN::RefPtr<Inode>, PageTable&, off_t offset, ssize_t size, Type flags, PageTable::flags_t page_flags);
|
FileBackedRegion(BAN::RefPtr<Inode>, PageTable&, off_t offset, ssize_t size, Type flags, PageTable::flags_t page_flags);
|
||||||
|
|
|
@ -14,6 +14,7 @@ namespace Kernel
|
||||||
static BAN::ErrorOr<BAN::UniqPtr<MemoryBackedRegion>> create(PageTable&, size_t size, AddressRange, Type, PageTable::flags_t);
|
static BAN::ErrorOr<BAN::UniqPtr<MemoryBackedRegion>> create(PageTable&, size_t size, AddressRange, Type, PageTable::flags_t);
|
||||||
~MemoryBackedRegion();
|
~MemoryBackedRegion();
|
||||||
|
|
||||||
|
virtual BAN::ErrorOr<bool> allocate_page_containing(vaddr_t vaddr) override;
|
||||||
|
|
||||||
virtual BAN::ErrorOr<BAN::UniqPtr<MemoryRegion>> clone(PageTable& new_page_table) override;
|
virtual BAN::ErrorOr<BAN::UniqPtr<MemoryRegion>> clone(PageTable& new_page_table) override;
|
||||||
|
|
||||||
|
@ -21,9 +22,6 @@ namespace Kernel
|
||||||
// This can fail if no memory is mapped and no free memory was available
|
// This can fail if no memory is mapped and no free memory was available
|
||||||
BAN::ErrorOr<void> copy_data_to_region(size_t offset_into_region, const uint8_t* buffer, size_t buffer_size);
|
BAN::ErrorOr<void> copy_data_to_region(size_t offset_into_region, const uint8_t* buffer, size_t buffer_size);
|
||||||
|
|
||||||
protected:
|
|
||||||
virtual BAN::ErrorOr<bool> allocate_page_containing_impl(vaddr_t vaddr) override;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
MemoryBackedRegion(PageTable&, size_t size, Type, PageTable::flags_t);
|
MemoryBackedRegion(PageTable&, size_t size, Type, PageTable::flags_t);
|
||||||
};
|
};
|
||||||
|
|
|
@ -38,12 +38,11 @@ namespace Kernel
|
||||||
vaddr_t vaddr() const { return m_vaddr; }
|
vaddr_t vaddr() const { return m_vaddr; }
|
||||||
|
|
||||||
size_t virtual_page_count() const { return BAN::Math::div_round_up<size_t>(m_size, PAGE_SIZE); }
|
size_t virtual_page_count() const { return BAN::Math::div_round_up<size_t>(m_size, PAGE_SIZE); }
|
||||||
size_t physical_page_count() const { return m_physical_page_count; }
|
|
||||||
|
|
||||||
// Returns error if no memory was available
|
// Returns error if no memory was available
|
||||||
// Returns true if page was succesfully allocated
|
// Returns true if page was succesfully allocated
|
||||||
// Returns false if page was already allocated
|
// Returns false if page was already allocated
|
||||||
BAN::ErrorOr<bool> allocate_page_containing(vaddr_t address);
|
virtual BAN::ErrorOr<bool> allocate_page_containing(vaddr_t address) = 0;
|
||||||
|
|
||||||
virtual BAN::ErrorOr<BAN::UniqPtr<MemoryRegion>> clone(PageTable& new_page_table) = 0;
|
virtual BAN::ErrorOr<BAN::UniqPtr<MemoryRegion>> clone(PageTable& new_page_table) = 0;
|
||||||
|
|
||||||
|
@ -51,15 +50,12 @@ namespace Kernel
|
||||||
MemoryRegion(PageTable&, size_t size, Type type, PageTable::flags_t flags);
|
MemoryRegion(PageTable&, size_t size, Type type, PageTable::flags_t flags);
|
||||||
BAN::ErrorOr<void> initialize(AddressRange);
|
BAN::ErrorOr<void> initialize(AddressRange);
|
||||||
|
|
||||||
virtual BAN::ErrorOr<bool> allocate_page_containing_impl(vaddr_t address) = 0;
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
PageTable& m_page_table;
|
PageTable& m_page_table;
|
||||||
const size_t m_size;
|
const size_t m_size;
|
||||||
const Type m_type;
|
const Type m_type;
|
||||||
const PageTable::flags_t m_flags;
|
const PageTable::flags_t m_flags;
|
||||||
vaddr_t m_vaddr { 0 };
|
vaddr_t m_vaddr { 0 };
|
||||||
size_t m_physical_page_count { 0 };
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
|
@ -139,9 +139,7 @@ namespace Kernel
|
||||||
|
|
||||||
PageTable& page_table() { return m_page_table ? *m_page_table : PageTable::kernel(); }
|
PageTable& page_table() { return m_page_table ? *m_page_table : PageTable::kernel(); }
|
||||||
|
|
||||||
size_t proc_meminfo(off_t offset, void* buffer, size_t buffer_size) const;
|
void get_meminfo(proc_meminfo_t*) const;
|
||||||
size_t proc_cmdline(off_t offset, void* buffer, size_t buffer_size) const;
|
|
||||||
size_t proc_environ(off_t offset, void* buffer, size_t buffer_size) const;
|
|
||||||
|
|
||||||
bool is_userspace() const { return m_is_userspace; }
|
bool is_userspace() const { return m_is_userspace; }
|
||||||
const userspace_info_t& userspace_info() const { return m_userspace_info; }
|
const userspace_info_t& userspace_info() const { return m_userspace_info; }
|
||||||
|
@ -194,9 +192,6 @@ namespace Kernel
|
||||||
vaddr_t m_signal_handlers[_SIGMAX + 1] { };
|
vaddr_t m_signal_handlers[_SIGMAX + 1] { };
|
||||||
uint64_t m_signal_pending_mask { 0 };
|
uint64_t m_signal_pending_mask { 0 };
|
||||||
|
|
||||||
BAN::Vector<BAN::String> m_cmdline;
|
|
||||||
BAN::Vector<BAN::String> m_environ;
|
|
||||||
|
|
||||||
bool m_is_userspace { false };
|
bool m_is_userspace { false };
|
||||||
userspace_info_t m_userspace_info;
|
userspace_info_t m_userspace_info;
|
||||||
ExitStatus m_exit_status;
|
ExitStatus m_exit_status;
|
||||||
|
|
|
@ -84,7 +84,6 @@ namespace Kernel
|
||||||
bool is_userspace() const { return m_is_userspace; }
|
bool is_userspace() const { return m_is_userspace; }
|
||||||
|
|
||||||
size_t virtual_page_count() const { return m_stack->size() / PAGE_SIZE; }
|
size_t virtual_page_count() const { return m_stack->size() / PAGE_SIZE; }
|
||||||
size_t physical_page_count() const { return virtual_page_count(); }
|
|
||||||
|
|
||||||
#if __enable_sse
|
#if __enable_sse
|
||||||
void save_sse() { asm volatile("fxsave %0" :: "m"(m_sse_storage)); }
|
void save_sse() { asm volatile("fxsave %0" :: "m"(m_sse_storage)); }
|
||||||
|
|
|
@ -12,9 +12,7 @@ namespace Kernel
|
||||||
return BAN::Error::from_errno(ENOMEM);
|
return BAN::Error::from_errno(ENOMEM);
|
||||||
auto inode = BAN::RefPtr<ProcPidInode>::adopt(inode_ptr);
|
auto inode = BAN::RefPtr<ProcPidInode>::adopt(inode_ptr);
|
||||||
|
|
||||||
TRY(inode->add_inode("meminfo"sv, MUST(ProcROInode::create(process, &Process::proc_meminfo, fs, 0755, 0, 0))));
|
TRY(inode->add_inode("meminfo"sv, MUST(ProcMemInode::create(process, fs, 0755, 0, 0))));
|
||||||
TRY(inode->add_inode("cmdline"sv, MUST(ProcROInode::create(process, &Process::proc_cmdline, fs, 0755, 0, 0))));
|
|
||||||
TRY(inode->add_inode("environ"sv, MUST(ProcROInode::create(process, &Process::proc_environ, fs, 0755, 0, 0))));
|
|
||||||
|
|
||||||
return inode;
|
return inode;
|
||||||
}
|
}
|
||||||
|
@ -25,30 +23,36 @@ namespace Kernel
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<BAN::RefPtr<ProcROInode>> ProcROInode::create(Process& process, size_t (Process::*callback)(off_t, void*, size_t) const, RamFileSystem& fs, mode_t mode, uid_t uid, gid_t gid)
|
BAN::ErrorOr<BAN::RefPtr<ProcMemInode>> ProcMemInode::create(Process& process, RamFileSystem& fs, mode_t mode, uid_t uid, gid_t gid)
|
||||||
{
|
{
|
||||||
FullInodeInfo inode_info(fs, mode, uid, gid);
|
FullInodeInfo inode_info(fs, mode, uid, gid);
|
||||||
|
|
||||||
auto* inode_ptr = new ProcROInode(process, callback, fs, inode_info);
|
auto* inode_ptr = new ProcMemInode(process, fs, inode_info);
|
||||||
if (inode_ptr == nullptr)
|
if (inode_ptr == nullptr)
|
||||||
return BAN::Error::from_errno(ENOMEM);
|
return BAN::Error::from_errno(ENOMEM);
|
||||||
return BAN::RefPtr<ProcROInode>::adopt(inode_ptr);
|
return BAN::RefPtr<ProcMemInode>::adopt(inode_ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
ProcROInode::ProcROInode(Process& process, size_t (Process::*callback)(off_t, void*, size_t) const, RamFileSystem& fs, const FullInodeInfo& inode_info)
|
ProcMemInode::ProcMemInode(Process& process, RamFileSystem& fs, const FullInodeInfo& inode_info)
|
||||||
: RamInode(fs, inode_info)
|
: RamInode(fs, inode_info)
|
||||||
, m_process(process)
|
, m_process(process)
|
||||||
, m_callback(callback)
|
|
||||||
{
|
{
|
||||||
m_inode_info.mode |= Inode::Mode::IFREG;
|
m_inode_info.mode |= Inode::Mode::IFREG;
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<size_t> ProcROInode::read_impl(off_t offset, void* buffer, size_t buffer_size)
|
BAN::ErrorOr<size_t> ProcMemInode::read_impl(off_t offset, void* buffer, size_t buffer_size)
|
||||||
{
|
{
|
||||||
ASSERT(offset >= 0);
|
ASSERT(offset >= 0);
|
||||||
if ((size_t)offset >= sizeof(proc_meminfo_t))
|
if ((size_t)offset >= sizeof(proc_meminfo_t))
|
||||||
return 0;
|
return 0;
|
||||||
return (m_process.*m_callback)(offset, buffer, buffer_size);
|
|
||||||
|
proc_meminfo_t meminfo;
|
||||||
|
m_process.get_meminfo(&meminfo);
|
||||||
|
|
||||||
|
size_t bytes = BAN::Math::min<size_t>(buffer_size, sizeof(meminfo) - offset);
|
||||||
|
memcpy(buffer, &meminfo, bytes);
|
||||||
|
|
||||||
|
return bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -85,7 +85,7 @@ namespace Kernel
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<bool> FileBackedRegion::allocate_page_containing_impl(vaddr_t address)
|
BAN::ErrorOr<bool> FileBackedRegion::allocate_page_containing(vaddr_t address)
|
||||||
{
|
{
|
||||||
ASSERT(contains(address));
|
ASSERT(contains(address));
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@ namespace Kernel
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<bool> MemoryBackedRegion::allocate_page_containing_impl(vaddr_t address)
|
BAN::ErrorOr<bool> MemoryBackedRegion::allocate_page_containing(vaddr_t address)
|
||||||
{
|
{
|
||||||
ASSERT(m_type == Type::PRIVATE);
|
ASSERT(m_type == Type::PRIVATE);
|
||||||
|
|
||||||
|
|
|
@ -47,12 +47,4 @@ namespace Kernel
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<bool> MemoryRegion::allocate_page_containing(vaddr_t address)
|
|
||||||
{
|
|
||||||
auto ret = allocate_page_containing_impl(address);
|
|
||||||
if (!ret.is_error() && ret.value())
|
|
||||||
m_physical_page_count++;
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -119,9 +119,6 @@ namespace Kernel
|
||||||
MUST(process->m_working_directory.push_back('/'));
|
MUST(process->m_working_directory.push_back('/'));
|
||||||
process->m_page_table = BAN::UniqPtr<PageTable>::adopt(MUST(PageTable::create_userspace()));
|
process->m_page_table = BAN::UniqPtr<PageTable>::adopt(MUST(PageTable::create_userspace()));
|
||||||
|
|
||||||
TRY(process->m_cmdline.push_back({}));
|
|
||||||
TRY(process->m_cmdline.back().append(path));
|
|
||||||
|
|
||||||
process->m_loadable_elf = TRY(load_elf_for_exec(credentials, path, "/"sv, process->page_table()));
|
process->m_loadable_elf = TRY(load_elf_for_exec(credentials, path, "/"sv, process->page_table()));
|
||||||
process->m_loadable_elf->reserve_address_space();
|
process->m_loadable_elf->reserve_address_space();
|
||||||
|
|
||||||
|
@ -255,75 +252,19 @@ namespace Kernel
|
||||||
thread->set_terminating();
|
thread->set_terminating();
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t Process::proc_meminfo(off_t offset, void* buffer, size_t buffer_size) const
|
void Process::get_meminfo(proc_meminfo_t* out) const
|
||||||
{
|
|
||||||
ASSERT(offset >= 0);
|
|
||||||
if ((size_t)offset >= sizeof(proc_meminfo_t))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
proc_meminfo_t meminfo;
|
|
||||||
meminfo.page_size = PAGE_SIZE;
|
|
||||||
meminfo.virt_pages = 0;
|
|
||||||
meminfo.phys_pages = 0;
|
|
||||||
|
|
||||||
{
|
|
||||||
LockGuard _(m_lock);
|
|
||||||
for (auto* thread : m_threads)
|
|
||||||
{
|
|
||||||
meminfo.virt_pages += thread->virtual_page_count();
|
|
||||||
meminfo.phys_pages += thread->physical_page_count();
|
|
||||||
}
|
|
||||||
for (auto& region : m_mapped_regions)
|
|
||||||
{
|
|
||||||
meminfo.virt_pages += region->virtual_page_count();
|
|
||||||
meminfo.phys_pages += region->physical_page_count();
|
|
||||||
}
|
|
||||||
if (m_loadable_elf)
|
|
||||||
{
|
|
||||||
meminfo.virt_pages += m_loadable_elf->virtual_page_count();
|
|
||||||
meminfo.phys_pages += m_loadable_elf->physical_page_count();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t bytes = BAN::Math::min<size_t>(sizeof(proc_meminfo_t) - offset, buffer_size);
|
|
||||||
memcpy(buffer, (uint8_t*)&meminfo + offset, bytes);
|
|
||||||
return bytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
static size_t read_from_vec_of_str(const BAN::Vector<BAN::String>& container, size_t start, void* buffer, size_t buffer_size)
|
|
||||||
{
|
|
||||||
size_t offset = 0;
|
|
||||||
size_t written = 0;
|
|
||||||
for (const auto& elem : container)
|
|
||||||
{
|
|
||||||
if (start < offset + elem.size() + 1)
|
|
||||||
{
|
|
||||||
size_t elem_offset = 0;
|
|
||||||
if (offset < start)
|
|
||||||
elem_offset = start - offset;
|
|
||||||
|
|
||||||
size_t bytes = BAN::Math::min<size_t>(elem.size() + 1 - elem_offset, buffer_size - written);
|
|
||||||
memcpy((uint8_t*)buffer + written, elem.data() + elem_offset, bytes);
|
|
||||||
|
|
||||||
written += bytes;
|
|
||||||
if (written >= buffer_size)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
offset += elem.size() + 1;
|
|
||||||
}
|
|
||||||
return written;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t Process::proc_cmdline(off_t offset, void* buffer, size_t buffer_size) const
|
|
||||||
{
|
{
|
||||||
LockGuard _(m_lock);
|
LockGuard _(m_lock);
|
||||||
return read_from_vec_of_str(m_cmdline, offset, buffer, buffer_size);
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t Process::proc_environ(off_t offset, void* buffer, size_t buffer_size) const
|
out->page_size = PAGE_SIZE;
|
||||||
{
|
|
||||||
LockGuard _(m_lock);
|
out->virt_pages = 0;
|
||||||
return read_from_vec_of_str(m_environ, offset, buffer, buffer_size);
|
for (auto* thread : m_threads)
|
||||||
|
out->virt_pages += thread->virtual_page_count();
|
||||||
|
for (auto& region : m_mapped_regions)
|
||||||
|
out->virt_pages += region->virtual_page_count();
|
||||||
|
if (m_loadable_elf)
|
||||||
|
out->virt_pages += m_loadable_elf->virtual_page_count();
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<long> Process::sys_exit(int status)
|
BAN::ErrorOr<long> Process::sys_exit(int status)
|
||||||
|
@ -510,11 +451,8 @@ namespace Kernel
|
||||||
auto envp_region = MUST(create_region(str_envp.span()));
|
auto envp_region = MUST(create_region(str_envp.span()));
|
||||||
m_userspace_info.envp = (char**)envp_region->vaddr();
|
m_userspace_info.envp = (char**)envp_region->vaddr();
|
||||||
MUST(m_mapped_regions.push_back(BAN::move(envp_region)));
|
MUST(m_mapped_regions.push_back(BAN::move(envp_region)));
|
||||||
|
|
||||||
m_userspace_info.argc = str_argv.size();
|
|
||||||
|
|
||||||
m_cmdline = BAN::move(str_argv);
|
m_userspace_info.argc = str_argv.size();
|
||||||
m_environ = BAN::move(str_envp);
|
|
||||||
|
|
||||||
asm volatile("cli");
|
asm volatile("cli");
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,6 @@ struct proc_meminfo_t
|
||||||
{
|
{
|
||||||
size_t page_size;
|
size_t page_size;
|
||||||
size_t virt_pages;
|
size_t virt_pages;
|
||||||
size_t phys_pages;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -30,64 +30,27 @@ int main()
|
||||||
if (!is_only_digits(proc_ent->d_name))
|
if (!is_only_digits(proc_ent->d_name))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
printf("process: ");
|
strcpy(path_buffer, proc_ent->d_name);
|
||||||
|
strcat(path_buffer, "/meminfo");
|
||||||
|
|
||||||
|
int fd = openat(dirfd(proc), path_buffer, O_RDONLY);
|
||||||
|
if (fd == -1)
|
||||||
{
|
{
|
||||||
strcpy(path_buffer, proc_ent->d_name);
|
perror("openat");
|
||||||
strcat(path_buffer, "/cmdline");
|
continue;
|
||||||
|
|
||||||
int fd = openat(dirfd(proc), path_buffer, O_RDONLY);
|
|
||||||
if (fd == -1)
|
|
||||||
{
|
|
||||||
perror("openat");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (ssize_t nread = read(fd, path_buffer, sizeof(path_buffer) - 1))
|
|
||||||
{
|
|
||||||
if (nread == -1)
|
|
||||||
{
|
|
||||||
perror("read");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
for (int i = 0; i < nread; i++)
|
|
||||||
if (path_buffer[i] == '\0')
|
|
||||||
path_buffer[i] = ' ';
|
|
||||||
|
|
||||||
path_buffer[nread] = '\0';
|
|
||||||
|
|
||||||
int written = 0;
|
|
||||||
while (written < nread)
|
|
||||||
written += printf("%s ", path_buffer + written);
|
|
||||||
}
|
|
||||||
|
|
||||||
close(fd);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("\n pid: %s\n", proc_ent->d_name);
|
proc_meminfo_t meminfo;
|
||||||
|
if (read(fd, &meminfo, sizeof(meminfo)) == -1)
|
||||||
|
perror("read");
|
||||||
|
else
|
||||||
{
|
{
|
||||||
strcpy(path_buffer, proc_ent->d_name);
|
printf("process:\n");
|
||||||
strcat(path_buffer, "/meminfo");
|
printf(" pid: %s\n", proc_ent->d_name);
|
||||||
|
printf(" vmem: %zu pages (%zu bytes)\n", meminfo.virt_pages, meminfo.page_size * meminfo.virt_pages);
|
||||||
int fd = openat(dirfd(proc), path_buffer, O_RDONLY);
|
|
||||||
if (fd == -1)
|
|
||||||
{
|
|
||||||
perror("openat");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
proc_meminfo_t meminfo;
|
|
||||||
if (read(fd, &meminfo, sizeof(meminfo)) == -1)
|
|
||||||
perror("read");
|
|
||||||
else
|
|
||||||
{
|
|
||||||
printf(" vmem: %zu pages (%zu bytes)\n", meminfo.virt_pages, meminfo.page_size * meminfo.virt_pages);
|
|
||||||
printf(" pmem: %zu pages (%zu bytes)\n", meminfo.phys_pages, meminfo.page_size * meminfo.phys_pages);
|
|
||||||
}
|
|
||||||
|
|
||||||
close(fd);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
close(fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
closedir(proc);
|
closedir(proc);
|
||||||
|
|
Loading…
Reference in New Issue