[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[hurd] 05/07: Make start_code and end_code available in /proc/*/stat
From: |
Samuel Thibault |
Subject: |
[hurd] 05/07: Make start_code and end_code available in /proc/*/stat |
Date: |
Mon, 16 Sep 2013 07:41:32 +0000 |
This is an automated email from the git hooks/post-receive script.
sthibault pushed a commit to branch procfs-jkoenig
in repository hurd.
commit 690beb4d6679c66f45d09883408cb860337e31c2
Author: Justus Winter <address@hidden>
Date: Mon Aug 5 12:11:30 2013 +0200
Make start_code and end_code available in /proc/*/stat
This makes killall5 actually kill any processes not marked as
important.
* process.c (process_file_gc_stat): Fix {start,end}_code.
---
process.c | 24 +++++++++++++++++++++++-
1 file changed, 23 insertions(+), 1 deletion(-)
diff --git a/process.c b/process.c
index c5ef7d8..269a18b 100644
--- a/process.c
+++ b/process.c
@@ -116,6 +116,26 @@ process_file_gc_stat (struct proc_stat *ps, char
**contents)
thread_basic_info_t thbi = proc_stat_thread_basic_info (ps);
const char *fn = args_filename (proc_stat_args (ps));
+ vm_address_t start_code = 1; /* 0 would make killall5.c consider it
+ a kernel process, thus use 1 as
+ default. */
+ vm_address_t end_code = 1;
+ process_t p;
+ error_t err = proc_pid2proc (ps->context->server, ps->pid, &p);
+ if (! err)
+ {
+ boolean_t essential = 0;
+ proc_is_important (p, &essential);
+ if (essential)
+ start_code = end_code = 0; /* To make killall5.c consider it a
+ kernel process that is to be
+ left alone. */
+ else
+ proc_get_code (p, &start_code, &end_code);
+
+ mach_port_deallocate (mach_task_self (), p);
+ }
+
/* See proc(5) for more information about the contents of each field for the
Linux procfs. */
return asprintf (contents,
@@ -152,7 +172,9 @@ process_file_gc_stat (struct proc_stat *ps, char **contents)
timeval_jiffies (thbi->creation_time), /* FIXME: ... since boot */
(long unsigned) tbi->virtual_size,
(long unsigned) tbi->resident_size / PAGE_SIZE, 0L,
- 0L, 0L, 0L, 0L, 0L,
+ start_code,
+ end_code,
+ 0L, 0L, 0L,
0L, 0L, 0L, 0L,
(long unsigned) proc_stat_thread_rpc (ps), /* close enough */
0L, 0L,
--
Alioth's /usr/local/bin/git-commit-notice on
/srv/git.debian.org/git/pkg-hurd/hurd.git
- [hurd] branch procfs-jkoenig updated (edf72a0 -> 588be84), Samuel Thibault, 2013/09/16
- [hurd] 01/07: Fix argument parsing, Samuel Thibault, 2013/09/16
- [hurd] 05/07: Make start_code and end_code available in /proc/*/stat,
Samuel Thibault <=
- [hurd] 07/07: Merge remote-tracking branch 'procfs/master' into procfs-jkoenig, Samuel Thibault, 2013/09/16
- [hurd] 02/07: procfs: handle the --update parameter, Samuel Thibault, 2013/09/16
- [hurd] 04/07: procfs: provide a more meaningful response to fsys_get_options, Samuel Thibault, 2013/09/16
- [hurd] 03/07: procfs: define macros for the default argument values, Samuel Thibault, 2013/09/16
- [hurd] 06/07: Serve mounts node with a passive translator record, Samuel Thibault, 2013/09/16