mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 18:32:28 -05:00
1682f0b760
SPDX License Identifiers are a more compact / standardized way of representing file license information. See: https://spdx.dev/resources/use/#identifiers This was done with the `ambr` search and replace tool. ambr --no-parent-ignore --key-from-file --rep-from-file key.txt rep.txt *
98 lines
3.2 KiB
C++
98 lines
3.2 KiB
C++
/*
|
|
* Copyright (c) 2020, the SerenityOS developers.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/ByteBuffer.h>
|
|
#include <AK/JsonObject.h>
|
|
#include <AK/QuickSort.h>
|
|
#include <AK/String.h>
|
|
#include <LibCore/ArgsParser.h>
|
|
#include <LibCore/File.h>
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
if (pledge("stdio rpath", nullptr) < 0) {
|
|
perror("pledge");
|
|
return 1;
|
|
}
|
|
|
|
if (unveil("/proc", "r") < 0) {
|
|
perror("unveil");
|
|
return 1;
|
|
}
|
|
|
|
unveil(nullptr, nullptr);
|
|
|
|
const char* pid;
|
|
static bool extended = false;
|
|
|
|
Core::ArgsParser args_parser;
|
|
args_parser.add_option(extended, "Extended output", nullptr, 'x');
|
|
args_parser.add_positional_argument(pid, "PID", "PID", Core::ArgsParser::Required::Yes);
|
|
args_parser.parse(argc, argv);
|
|
|
|
auto file = Core::File::construct(String::formatted("/proc/{}/vm", pid));
|
|
if (!file->open(Core::IODevice::ReadOnly)) {
|
|
fprintf(stderr, "Error: %s\n", file->error_string());
|
|
return 1;
|
|
}
|
|
|
|
printf("%s:\n", pid);
|
|
|
|
if (extended) {
|
|
printf("Address Size Resident Dirty Access VMObject Type Purgeable CoW Pages Name\n");
|
|
} else {
|
|
printf("Address Size Access Name\n");
|
|
}
|
|
|
|
auto file_contents = file->read_all();
|
|
auto json = JsonValue::from_string(file_contents);
|
|
VERIFY(json.has_value());
|
|
|
|
Vector<JsonValue> sorted_regions = json.value().as_array().values();
|
|
quick_sort(sorted_regions, [](auto& a, auto& b) {
|
|
return a.as_object().get("address").to_u32() < b.as_object().get("address").to_u32();
|
|
});
|
|
|
|
for (auto& value : sorted_regions) {
|
|
auto map = value.as_object();
|
|
auto address = map.get("address").to_int();
|
|
auto size = map.get("size").to_string();
|
|
|
|
auto access = String::formatted("{}{}{}{}{}",
|
|
(map.get("readable").to_bool() ? "r" : "-"),
|
|
(map.get("writable").to_bool() ? "w" : "-"),
|
|
(map.get("executable").to_bool() ? "x" : "-"),
|
|
(map.get("shared").to_bool() ? "s" : "-"),
|
|
(map.get("syscall").to_bool() ? "c" : "-"));
|
|
|
|
printf("%08x ", address);
|
|
printf("%10s ", size.characters());
|
|
if (extended) {
|
|
auto resident = map.get("amount_resident").to_string();
|
|
auto dirty = map.get("amount_dirty").to_string();
|
|
auto vmobject = map.get("vmobject").to_string();
|
|
if (vmobject.ends_with("VMObject"))
|
|
vmobject = vmobject.substring(0, vmobject.length() - 8);
|
|
auto purgeable = map.get("purgeable").to_string();
|
|
auto cow_pages = map.get("cow_pages").to_string();
|
|
printf("%10s ", resident.characters());
|
|
printf("%10s ", dirty.characters());
|
|
printf("%-6s ", access.characters());
|
|
printf("%-14s ", vmobject.characters());
|
|
printf("%-10s ", purgeable.characters());
|
|
printf("%10s ", cow_pages.characters());
|
|
} else {
|
|
printf("%-6s ", access.characters());
|
|
}
|
|
auto name = map.get("name").to_string();
|
|
printf("%-20s", name.characters());
|
|
printf("\n");
|
|
}
|
|
|
|
return 0;
|
|
}
|