From c62a440d866ccd8259b408ec59a2c16069e0ce0c Mon Sep 17 00:00:00 2001 From: Justus Winter <4winter@informatik.uni-hamburg.de> Date: Thu, 15 Aug 2013 09:38:04 +0200 Subject: proc: keep track of {start,end}_code Any executable segments loaded from the ELF binary are in this range. * proc/proc.h (struct proc): Add {start,end}_code. * proc/mgt.h (S_proc_set_code): New function. * proc/mgt.h (S_proc_get_code): New function. --- proc/mgt.c | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) (limited to 'proc/mgt.c') diff --git a/proc/mgt.c b/proc/mgt.c index 6a10e915..c093b8fe 100644 --- a/proc/mgt.c +++ b/proc/mgt.c @@ -210,6 +210,15 @@ S_proc_child (struct proc *parentp, childp->p_parent->p_pid, childp->p_pgrp->pg_pgid, !childp->p_pgrp->pg_orphcnt); childp->p_parentset = 1; + + /* If these are not set in the child, it was probably fork(2)ed. If + so, it inherits the values of its parent. */ + if (! childp->start_code && ! childp->end_code) + { + childp->start_code = parentp->start_code; + childp->end_code = parentp->end_code; + } + return 0; } @@ -903,3 +912,33 @@ S_proc_is_important (struct proc *callerp, return 0; } + +/* Implement proc_set_code as described in . */ +error_t +S_proc_set_code (struct proc *callerp, + vm_address_t start_code, + vm_address_t end_code) +{ + if (!callerp) + return EOPNOTSUPP; + + callerp->start_code = start_code; + callerp->end_code = end_code; + + return 0; +} + +/* Implement proc_get_code as described in . */ +error_t +S_proc_get_code (struct proc *callerp, + vm_address_t *start_code, + vm_address_t *end_code) +{ + if (!callerp) + return EOPNOTSUPP; + + *start_code = callerp->start_code; + *end_code = callerp->end_code; + + return 0; +} -- cgit v1.2.3