summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Kling <awesomekling@gmail.com>2019-04-15 19:43:12 +0200
committerAndreas Kling <awesomekling@gmail.com>2019-04-15 19:43:12 +0200
commite9c0f4567dae2ca6c3a9cc377d8f65b25ced74e9 (patch)
tree717bb1e9e91f4fe8ff9451eb545d87486cebb019
parent13041f894fbfcb89b78cd1dfb18f3ca5072eb62a (diff)
downloadserenity-e9c0f4567dae2ca6c3a9cc377d8f65b25ced74e9.zip
Kernel+ProcessManager: Expose the number of kmalloc/kfree calls.
This will be very helpful in tracking down unwanted kmalloc traffic. :^)
-rw-r--r--Applications/ProcessManager/MemoryStatsWidget.cpp18
-rw-r--r--Applications/ProcessManager/MemoryStatsWidget.h1
-rw-r--r--Kernel/FileSystem/ProcFS.cpp7
-rw-r--r--Kernel/kmalloc.cpp5
-rw-r--r--Kernel/kmalloc.h2
5 files changed, 25 insertions, 8 deletions
diff --git a/Applications/ProcessManager/MemoryStatsWidget.cpp b/Applications/ProcessManager/MemoryStatsWidget.cpp
index 4a1c7ff859..e80b03dda6 100644
--- a/Applications/ProcessManager/MemoryStatsWidget.cpp
+++ b/Applications/ProcessManager/MemoryStatsWidget.cpp
@@ -10,7 +10,7 @@ MemoryStatsWidget::MemoryStatsWidget(GWidget* parent)
: GWidget(parent)
{
set_size_policy(SizePolicy::Fill, SizePolicy::Fixed);
- set_preferred_size({ 0, 60 });
+ set_preferred_size({ 0, 72 });
set_layout(make<GBoxLayout>(Orientation::Vertical));
layout()->set_margins({ 0, 8, 0, 0 });
@@ -20,7 +20,7 @@ MemoryStatsWidget::MemoryStatsWidget(GWidget* parent)
auto* container = new GWidget(this);
container->set_layout(make<GBoxLayout>(Orientation::Horizontal));
container->set_size_policy(SizePolicy::Fixed, SizePolicy::Fixed);
- container->set_preferred_size({ 250, 12 });
+ container->set_preferred_size({ 255, 12 });
auto* description_label = new GLabel(description, container);
description_label->set_font(Font::default_bold_font());
description_label->set_text_alignment(TextAlignment::CenterLeft);
@@ -32,6 +32,7 @@ MemoryStatsWidget::MemoryStatsWidget(GWidget* parent)
m_user_physical_pages_label = build_widgets_for_label("Userspace physical:");
m_supervisor_physical_pages_label = build_widgets_for_label("Supervisor physical:");
m_kmalloc_label = build_widgets_for_label("Kernel heap:");
+ m_kmalloc_count_label = build_widgets_for_label("Calls kmalloc/kfree:");
start_timer(1000);
refresh();
@@ -65,7 +66,7 @@ void MemoryStatsWidget::refresh()
if (!ptr)
break;
auto parts = String(buf, Chomp).split(',');
- if (parts.size() < 7)
+ if (parts.size() < 9)
break;
bool ok;
unsigned kmalloc_sum_eternal = parts[0].to_uint(ok);
@@ -83,14 +84,19 @@ void MemoryStatsWidget::refresh()
ASSERT(ok);
unsigned supervisor_pages_free = parts[6].to_uint(ok);
ASSERT(ok);
+ unsigned kmalloc_call_count = parts[7].to_uint(ok);
+ ASSERT(ok);
+ unsigned kfree_call_count = parts[8].to_uint(ok);
+ ASSERT(ok);
size_t kmalloc_sum_available = kmalloc_sum_alloc + kmalloc_sum_free;
size_t user_pages_available = user_pages_alloc + user_pages_free;
size_t supervisor_pages_available = supervisor_pages_alloc + supervisor_pages_free;
- m_kmalloc_label->set_text(String::format("%uK/%uK\n", bytes_to_kb(kmalloc_sum_alloc), bytes_to_kb(kmalloc_sum_available)));
- m_user_physical_pages_label->set_text(String::format("%uK/%uK\n", page_count_to_kb(user_pages_alloc), page_count_to_kb(user_pages_available)));
- m_supervisor_physical_pages_label->set_text(String::format("%uK/%uK\n", page_count_to_kb(supervisor_pages_alloc), page_count_to_kb(supervisor_pages_available)));
+ m_kmalloc_label->set_text(String::format("%uK/%uK", bytes_to_kb(kmalloc_sum_alloc), bytes_to_kb(kmalloc_sum_available)));
+ m_user_physical_pages_label->set_text(String::format("%uK/%uK", page_count_to_kb(user_pages_alloc), page_count_to_kb(user_pages_available)));
+ m_supervisor_physical_pages_label->set_text(String::format("%uK/%uK", page_count_to_kb(supervisor_pages_alloc), page_count_to_kb(supervisor_pages_available)));
+ m_kmalloc_count_label->set_text(String::format("%u/%u (+%u)", kmalloc_call_count, kfree_call_count, kmalloc_call_count - kfree_call_count));
break;
}
diff --git a/Applications/ProcessManager/MemoryStatsWidget.h b/Applications/ProcessManager/MemoryStatsWidget.h
index 0c01c5acc8..38838b14b5 100644
--- a/Applications/ProcessManager/MemoryStatsWidget.h
+++ b/Applications/ProcessManager/MemoryStatsWidget.h
@@ -18,4 +18,5 @@ private:
GLabel* m_user_physical_pages_label { nullptr };
GLabel* m_supervisor_physical_pages_label { nullptr };
GLabel* m_kmalloc_label { nullptr };
+ GLabel* m_kmalloc_count_label { nullptr };
};
diff --git a/Kernel/FileSystem/ProcFS.cpp b/Kernel/FileSystem/ProcFS.cpp
index d9c28162bd..1aaf655101 100644
--- a/Kernel/FileSystem/ProcFS.cpp
+++ b/Kernel/FileSystem/ProcFS.cpp
@@ -8,6 +8,7 @@
#include "Console.h"
#include "Scheduler.h"
#include <Kernel/PCI.h>
+#include <Kernel/kmalloc.h>
#include <AK/StringBuilder.h>
#include <LibC/errno_numbers.h>
@@ -558,14 +559,16 @@ ByteBuffer procfs$memstat(InodeIdentifier)
{
InterruptDisabler disabler;
StringBuilder builder;
- builder.appendf("%u,%u,%u,%u,%u,%u,%u\n",
+ builder.appendf("%u,%u,%u,%u,%u,%u,%u,%u,%u\n",
kmalloc_sum_eternal,
sum_alloc,
sum_free,
MM.user_physical_pages_in_existence() - MM.m_free_physical_pages.size(),
MM.m_free_physical_pages.size(),
MM.super_physical_pages_in_existence() - MM.m_free_supervisor_physical_pages.size(),
- MM.m_free_supervisor_physical_pages.size()
+ MM.m_free_supervisor_physical_pages.size(),
+ g_kmalloc_call_count,
+ g_kfree_call_count
);
return builder.to_byte_buffer();
}
diff --git a/Kernel/kmalloc.cpp b/Kernel/kmalloc.cpp
index e52d80c607..9c952bf5cc 100644
--- a/Kernel/kmalloc.cpp
+++ b/Kernel/kmalloc.cpp
@@ -33,6 +33,9 @@ volatile size_t sum_alloc = 0;
volatile size_t sum_free = POOL_SIZE;
volatile size_t kmalloc_sum_eternal = 0;
+dword g_kmalloc_call_count;
+dword g_kfree_call_count;
+
static byte* s_next_eternal_ptr;
static byte* s_end_of_eternal_range;
@@ -90,6 +93,7 @@ void* kmalloc_page_aligned(size_t size)
void* kmalloc_impl(size_t size)
{
InterruptDisabler disabler;
+ ++g_kmalloc_call_count;
// We need space for the allocation_t structure at the head of the block.
size_t real_size = size + sizeof(allocation_t);
@@ -153,6 +157,7 @@ void* kmalloc_impl(size_t size)
void kfree(void *ptr)
{
+ ++g_kfree_call_count;
if (!ptr)
return;
diff --git a/Kernel/kmalloc.h b/Kernel/kmalloc.h
index 19e9fb9644..001d22da5a 100644
--- a/Kernel/kmalloc.h
+++ b/Kernel/kmalloc.h
@@ -18,6 +18,8 @@ extern volatile size_t sum_alloc;
extern volatile size_t sum_free;
extern volatile size_t kmalloc_sum_eternal;
extern volatile size_t kmalloc_sum_page_aligned;
+extern dword g_kmalloc_call_count;
+extern dword g_kfree_call_count;
inline void* operator new(size_t, void* p) { return p; }
inline void* operator new[](size_t, void* p) { return p; }