diff options
author | Peter Wemm <peter@FreeBSD.org> | 1995-12-09 04:29:11 +0000 |
---|---|---|
committer | Peter Wemm <peter@FreeBSD.org> | 1995-12-09 04:29:11 +0000 |
commit | 1ed012f9699c8cbf6e2685801f26d6924c3b21b2 (patch) | |
tree | 3de7d7ce0562ddc16bed53d875d78c35a6f50986 /sys/kern/kern_exec.c | |
parent | d2f265fab89fec2b4d450a74eea4489401c61b1a (diff) | |
download | src-1ed012f9699c8cbf6e2685801f26d6924c3b21b2.tar.gz src-1ed012f9699c8cbf6e2685801f26d6924c3b21b2.zip |
Reorganise ps_strings in order to gain BSD/OS 2.0 binary compatability.
This is now in line with NetBSD as well..
Note that once this series of commits is finished, you must recompile
libkvm, then ps and maybe 'w'. If you are running the recently imported
sendmail-8.7, you should recompile that too (src/conf.c at least).
Notes
Notes:
svn path=/head/; revision=12679
Diffstat (limited to 'sys/kern/kern_exec.c')
-rw-r--r-- | sys/kern/kern_exec.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/sys/kern/kern_exec.c b/sys/kern/kern_exec.c index 2b0196009538..c8d22c6a830a 100644 --- a/sys/kern/kern_exec.c +++ b/sys/kern/kern_exec.c @@ -28,7 +28,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: kern_exec.c,v 1.27 1995/11/13 10:45:22 davidg Exp $ + * $Id: kern_exec.c,v 1.28 1995/12/07 12:46:40 davidg Exp $ */ #include <sys/param.h> @@ -451,7 +451,9 @@ exec_copyout_strings(imgp) * Calculate string base and vector table pointers. */ arginfo = PS_STRINGS; - destp = (caddr_t)arginfo - roundup((ARG_MAX - imgp->stringspace), sizeof(char *)); + destp = (caddr_t)arginfo - SPARE_USRSPACE - + roundup((ARG_MAX - imgp->stringspace), sizeof(char *)); + /* * The '+ 2' is for the null pointers at the end of each of the * arg and env vector sets @@ -476,7 +478,7 @@ exec_copyout_strings(imgp) /* * Fill in "ps_strings" struct for ps, w, etc. */ - suword(&arginfo->ps_argvstr, (int)destp); + suword(&arginfo->ps_argvstr, (int)vectp); suword(&arginfo->ps_nargvstr, argc); /* @@ -492,7 +494,7 @@ exec_copyout_strings(imgp) /* a null vector table pointer seperates the argp's from the envp's */ suword(vectp++, NULL); - suword(&arginfo->ps_envstr, (int)destp); + suword(&arginfo->ps_envstr, (int)vectp); suword(&arginfo->ps_nenvstr, envc); /* |