*** empty log message ***
This commit is contained in:
@@ -289,9 +289,11 @@ task_mem (struct task_struct *p, libgtop_proc_segment_t *proc_segment)
|
|||||||
struct vm_area_struct * vma = mm->mmap;
|
struct vm_area_struct * vma = mm->mmap;
|
||||||
unsigned long data = 0, stack = 0;
|
unsigned long data = 0, stack = 0;
|
||||||
unsigned long exec = 0, lib = 0;
|
unsigned long exec = 0, lib = 0;
|
||||||
|
unsigned long vsize = 0;
|
||||||
|
|
||||||
for (vma = mm->mmap; vma; vma = vma->vm_next) {
|
for (vma = mm->mmap; vma; vma = vma->vm_next) {
|
||||||
unsigned long len = (vma->vm_end - vma->vm_start) >> 10;
|
unsigned long len = (vma->vm_end - vma->vm_start) >> 10;
|
||||||
|
vsize += len;
|
||||||
if (!vma->vm_file) {
|
if (!vma->vm_file) {
|
||||||
data += len;
|
data += len;
|
||||||
if (vma->vm_flags & VM_GROWSDOWN)
|
if (vma->vm_flags & VM_GROWSDOWN)
|
||||||
@@ -308,6 +310,7 @@ task_mem (struct task_struct *p, libgtop_proc_segment_t *proc_segment)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proc_segment->vsize = vsize;
|
||||||
proc_segment->data = data;
|
proc_segment->data = data;
|
||||||
proc_segment->stack = stack;
|
proc_segment->stack = stack;
|
||||||
proc_segment->exec = exec;
|
proc_segment->exec = exec;
|
||||||
@@ -398,6 +401,7 @@ get_statm (struct task_struct *tsk, libgtop_proc_mem_t *proc_mem)
|
|||||||
{
|
{
|
||||||
int size=0, resident=0, share=0, trs=0, lrs=0, drs=0, dt=0;
|
int size=0, resident=0, share=0, trs=0, lrs=0, drs=0, dt=0;
|
||||||
unsigned long data=0, stack=0, exec=0, lib=0;
|
unsigned long data=0, stack=0, exec=0, lib=0;
|
||||||
|
unsigned long vsize = 0;
|
||||||
|
|
||||||
if (tsk->mm && tsk->mm != &init_mm) {
|
if (tsk->mm && tsk->mm != &init_mm) {
|
||||||
struct vm_area_struct * vma = tsk->mm->mmap;
|
struct vm_area_struct * vma = tsk->mm->mmap;
|
||||||
@@ -407,6 +411,8 @@ get_statm (struct task_struct *tsk, libgtop_proc_mem_t *proc_mem)
|
|||||||
pgd_t *pgd = pgd_offset(tsk->mm, vma->vm_start);
|
pgd_t *pgd = pgd_offset(tsk->mm, vma->vm_start);
|
||||||
int pages = 0, shared = 0, dirty = 0, total = 0;
|
int pages = 0, shared = 0, dirty = 0, total = 0;
|
||||||
|
|
||||||
|
vsize += len;
|
||||||
|
|
||||||
statm_pgd_range (pgd, vma->vm_start, vma->vm_end,
|
statm_pgd_range (pgd, vma->vm_start, vma->vm_end,
|
||||||
&pages, &shared, &dirty, &total);
|
&pages, &shared, &dirty, &total);
|
||||||
resident += pages;
|
resident += pages;
|
||||||
@@ -446,6 +452,7 @@ get_statm (struct task_struct *tsk, libgtop_proc_mem_t *proc_mem)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proc_mem->segment.vsize = vsize;
|
||||||
proc_mem->segment.data = data;
|
proc_mem->segment.data = data;
|
||||||
proc_mem->segment.stack = stack;
|
proc_mem->segment.stack = stack;
|
||||||
proc_mem->segment.exec = exec;
|
proc_mem->segment.exec = exec;
|
||||||
@@ -725,6 +732,9 @@ libgtop_sysctl_proc (ctl_table *table, int nlen, int *name,
|
|||||||
memset (proc_mem, 0, sizeof (libgtop_proc_mem_t));
|
memset (proc_mem, 0, sizeof (libgtop_proc_mem_t));
|
||||||
|
|
||||||
get_statm (tsk, proc_mem);
|
get_statm (tsk, proc_mem);
|
||||||
|
/* Use LIBGTOP_PROC_STAT if you only want rss and rlim. */
|
||||||
|
proc_mem->rss = tsk->mm->rss << PAGE_SHIFT;
|
||||||
|
proc_mem->rlim = tsk->rlim ? tsk->rlim[RLIMIT_RSS].rlim_cur : 0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@@ -128,13 +128,14 @@ struct libgtop_proc_kernel
|
|||||||
|
|
||||||
struct libgtop_proc_segment
|
struct libgtop_proc_segment
|
||||||
{
|
{
|
||||||
unsigned long data, exec, stack, lib;
|
unsigned long vsize, data, exec, stack, lib;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct libgtop_proc_mem
|
struct libgtop_proc_mem
|
||||||
{
|
{
|
||||||
libgtop_proc_segment_t segment;
|
libgtop_proc_segment_t segment;
|
||||||
int size, resident, share, trs, lrs, drs, dt;
|
int size, resident, share, trs, lrs, drs, dt;
|
||||||
|
unsigned long rss, rlim;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -15,6 +15,7 @@
|
|||||||
extern unsigned long total_forks;
|
extern unsigned long total_forks;
|
||||||
|
|
||||||
EXPORT_SYMBOL(task);
|
EXPORT_SYMBOL(task);
|
||||||
|
EXPORT_SYMBOL(init_mm);
|
||||||
EXPORT_SYMBOL(pidhash);
|
EXPORT_SYMBOL(pidhash);
|
||||||
EXPORT_SYMBOL(avenrun);
|
EXPORT_SYMBOL(avenrun);
|
||||||
EXPORT_SYMBOL(nr_running);
|
EXPORT_SYMBOL(nr_running);
|
||||||
@@ -23,3 +24,7 @@ EXPORT_SYMBOL(last_pid);
|
|||||||
EXPORT_SYMBOL(total_forks);
|
EXPORT_SYMBOL(total_forks);
|
||||||
EXPORT_SYMBOL(si_swapinfo);
|
EXPORT_SYMBOL(si_swapinfo);
|
||||||
|
|
||||||
|
extern void scheduling_functions_start_here(void);
|
||||||
|
extern void scheduling_functions_end_here(void);
|
||||||
|
EXPORT_SYMBOL(scheduling_functions_start_here);
|
||||||
|
EXPORT_SYMBOL(scheduling_functions_end_here);
|
||||||
|
@@ -44,6 +44,9 @@ int glibtop_get_proc_data_proclist_s (glibtop *server,
|
|||||||
int glibtop_get_proc_data_proc_state_s (glibtop *server,
|
int glibtop_get_proc_data_proc_state_s (glibtop *server,
|
||||||
libgtop_proc_state_t *proc_state,
|
libgtop_proc_state_t *proc_state,
|
||||||
pid_t pid);
|
pid_t pid);
|
||||||
|
int glibtop_get_proc_data_proc_mem_s (glibtop *server,
|
||||||
|
libgtop_proc_mem_t *proc_mem,
|
||||||
|
pid_t pid);
|
||||||
int glibtop_get_proc_data_proc_kernel_s (glibtop *server,
|
int glibtop_get_proc_data_proc_kernel_s (glibtop *server,
|
||||||
libgtop_proc_kernel_t *proc_kernel,
|
libgtop_proc_kernel_t *proc_kernel,
|
||||||
pid_t pid);
|
pid_t pid);
|
||||||
|
@@ -99,6 +99,22 @@ glibtop_get_proc_data_proc_state_s (glibtop *server,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
glibtop_get_proc_data_proc_mem_s (glibtop *server,
|
||||||
|
libgtop_proc_mem_t *proc_mem,
|
||||||
|
pid_t pid)
|
||||||
|
{
|
||||||
|
int name [3] = { CTL_LIBGTOP, LIBGTOP_PROC_MEM, pid };
|
||||||
|
size_t size = sizeof (libgtop_proc_mem_t);
|
||||||
|
|
||||||
|
if (sysctl (name, 3, proc_mem, &size, NULL, 0)) {
|
||||||
|
glibtop_warn_io_r (server, "sysctl (libgtop/proc_mem)");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
glibtop_get_proc_data_proc_kernel_s (glibtop *server,
|
glibtop_get_proc_data_proc_kernel_s (glibtop *server,
|
||||||
libgtop_proc_kernel_t *proc_kernel,
|
libgtop_proc_kernel_t *proc_kernel,
|
||||||
|
@@ -29,7 +29,9 @@
|
|||||||
|
|
||||||
#define GLIBTOP_PROCLIST_FLAGS 3
|
#define GLIBTOP_PROCLIST_FLAGS 3
|
||||||
|
|
||||||
static const unsigned long _glibtop_sysdeps_proclist = 0;
|
static const unsigned long _glibtop_sysdeps_proclist =
|
||||||
|
(1 << GLIBTOP_PROCLIST_NUMBER) + (1 << GLIBTOP_PROCLIST_SIZE) +
|
||||||
|
(1 << GLIBTOP_PROCLIST_TOTAL);
|
||||||
|
|
||||||
/* Init function. */
|
/* Init function. */
|
||||||
|
|
||||||
@@ -68,5 +70,7 @@ glibtop_get_proclist_s (glibtop *server, glibtop_proclist *buf,
|
|||||||
for (i = 0; i < proclist.count; i++)
|
for (i = 0; i < proclist.count; i++)
|
||||||
ret [i] = proclist.pids [i];
|
ret [i] = proclist.pids [i];
|
||||||
|
|
||||||
|
buf->flags |= _glibtop_sysdeps_proclist;
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@@ -24,14 +24,39 @@
|
|||||||
#include <glibtop.h>
|
#include <glibtop.h>
|
||||||
#include <glibtop/procmem.h>
|
#include <glibtop/procmem.h>
|
||||||
|
|
||||||
static const unsigned long _glibtop_sysdeps_proc_mem = 0;
|
#include <glibtop_private.h>
|
||||||
|
|
||||||
|
static const unsigned long _glibtop_sysdeps_proc_mem =
|
||||||
|
(1 << GLIBTOP_PROC_MEM_VSIZE) + (1 << GLIBTOP_PROC_MEM_SIZE) +
|
||||||
|
(1 << GLIBTOP_PROC_MEM_RESIDENT) + (1 << GLIBTOP_PROC_MEM_SHARE) +
|
||||||
|
(1 << GLIBTOP_PROC_MEM_RSS) + (1 << GLIBTOP_PROC_MEM_RSS_RLIM);
|
||||||
|
|
||||||
|
#ifndef LOG1024
|
||||||
|
#define LOG1024 10
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* these are for getting the memory statistics */
|
||||||
|
static int pageshift; /* log base 2 of the pagesize */
|
||||||
|
|
||||||
|
/* define pagetok in terms of pageshift */
|
||||||
|
#define pagetok(size) ((size) << pageshift)
|
||||||
|
|
||||||
/* Init function. */
|
/* Init function. */
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_init_proc_mem_s (glibtop *server)
|
glibtop_init_proc_mem_s (glibtop *server)
|
||||||
{
|
{
|
||||||
|
register int pagesize;
|
||||||
|
|
||||||
server->sysdeps.proc_mem = _glibtop_sysdeps_proc_mem;
|
server->sysdeps.proc_mem = _glibtop_sysdeps_proc_mem;
|
||||||
|
|
||||||
|
/* get the page size with "getpagesize" and calculate pageshift. */
|
||||||
|
pagesize = getpagesize ();
|
||||||
|
pageshift = 0;
|
||||||
|
while (pagesize > 1) {
|
||||||
|
pageshift++;
|
||||||
|
pagesize >>= 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Provides detailed information about a process. */
|
/* Provides detailed information about a process. */
|
||||||
@@ -40,5 +65,28 @@ void
|
|||||||
glibtop_get_proc_mem_s (glibtop *server, glibtop_proc_mem *buf,
|
glibtop_get_proc_mem_s (glibtop *server, glibtop_proc_mem *buf,
|
||||||
pid_t pid)
|
pid_t pid)
|
||||||
{
|
{
|
||||||
|
libgtop_proc_mem_t proc_mem;
|
||||||
|
|
||||||
memset (buf, 0, sizeof (glibtop_proc_mem));
|
memset (buf, 0, sizeof (glibtop_proc_mem));
|
||||||
|
|
||||||
|
if (glibtop_get_proc_data_proc_mem_s (server, &proc_mem, pid))
|
||||||
|
return;
|
||||||
|
|
||||||
|
buf->vsize = proc_mem.segment.vsize;
|
||||||
|
|
||||||
|
buf->size = proc_mem.size;
|
||||||
|
buf->resident = proc_mem.resident;
|
||||||
|
buf->share = proc_mem.share;
|
||||||
|
|
||||||
|
buf->rss = proc_mem.rss;
|
||||||
|
buf->rss_rlim = proc_mem.rlim;
|
||||||
|
|
||||||
|
buf->vsize <<= pageshift;
|
||||||
|
|
||||||
|
buf->size <<= pageshift;
|
||||||
|
buf->resident <<= pageshift;
|
||||||
|
buf->share <<= pageshift;
|
||||||
|
buf->rss <<= pageshift;
|
||||||
|
|
||||||
|
buf->flags = _glibtop_sysdeps_proc_mem;
|
||||||
}
|
}
|
||||||
|
@@ -24,14 +24,27 @@
|
|||||||
#include <glibtop.h>
|
#include <glibtop.h>
|
||||||
#include <glibtop/procsegment.h>
|
#include <glibtop/procsegment.h>
|
||||||
|
|
||||||
static const unsigned long _glibtop_sysdeps_proc_segment = 0;
|
#include <glibtop_private.h>
|
||||||
|
|
||||||
|
static const unsigned long _glibtop_sysdeps_proc_segment =
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_TEXT_RSS) +
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_SHLIB_RSS) +
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_DATA_RSS) +
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_STACK_RSS) +
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_DIRTY_SIZE);
|
||||||
|
|
||||||
|
static const unsigned long _glibtop_sysdeps_proc_segment_state =
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_START_CODE) +
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_END_CODE) +
|
||||||
|
(1 << GLIBTOP_PROC_SEGMENT_START_STACK);
|
||||||
|
|
||||||
/* Init function. */
|
/* Init function. */
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_init_proc_segment_s (glibtop *server)
|
glibtop_init_proc_segment_s (glibtop *server)
|
||||||
{
|
{
|
||||||
server->sysdeps.proc_segment = _glibtop_sysdeps_proc_segment;
|
server->sysdeps.proc_segment = _glibtop_sysdeps_proc_segment |
|
||||||
|
_glibtop_sysdeps_proc_segment_state;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Provides detailed information about a process. */
|
/* Provides detailed information about a process. */
|
||||||
@@ -40,5 +53,28 @@ void
|
|||||||
glibtop_get_proc_segment_s (glibtop *server, glibtop_proc_segment *buf,
|
glibtop_get_proc_segment_s (glibtop *server, glibtop_proc_segment *buf,
|
||||||
pid_t pid)
|
pid_t pid)
|
||||||
{
|
{
|
||||||
|
libgtop_proc_mem_t proc_mem;
|
||||||
|
libgtop_proc_state_t proc_state;
|
||||||
|
|
||||||
memset (buf, 0, sizeof (glibtop_proc_segment));
|
memset (buf, 0, sizeof (glibtop_proc_segment));
|
||||||
|
|
||||||
|
if (glibtop_get_proc_data_proc_mem_s (server, &proc_mem, pid))
|
||||||
|
return;
|
||||||
|
|
||||||
|
buf->text_rss = proc_mem.trs;
|
||||||
|
buf->shlib_rss = proc_mem.lrs;
|
||||||
|
buf->data_rss = proc_mem.drs;
|
||||||
|
buf->stack_rss = proc_mem.segment.stack;
|
||||||
|
buf->dirty_size = proc_mem.dt;
|
||||||
|
|
||||||
|
buf->flags = _glibtop_sysdeps_proc_segment;
|
||||||
|
|
||||||
|
if (glibtop_get_proc_data_proc_state_s (server, &proc_state, pid))
|
||||||
|
return;
|
||||||
|
|
||||||
|
buf->start_code = proc_state.start_code;
|
||||||
|
buf->end_code = proc_state.end_code;
|
||||||
|
buf->start_stack = proc_state.start_stack;
|
||||||
|
|
||||||
|
buf->flags |= _glibtop_sysdeps_proc_segment_state;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user