svn commit: r278792 - user/dchagin/lemul/sys/compat/linprocfs
Dmitry Chagin
dchagin at FreeBSD.org
Sun Feb 15 07:47:19 UTC 2015
Author: dchagin
Date: Sun Feb 15 07:47:18 2015
New Revision: 278792
URL: https://svnweb.freebsd.org/changeset/base/278792
Log:
Add vdso and stack names to the /proc/self/maps.
Modified:
user/dchagin/lemul/sys/compat/linprocfs/linprocfs.c
Modified: user/dchagin/lemul/sys/compat/linprocfs/linprocfs.c
==============================================================================
--- user/dchagin/lemul/sys/compat/linprocfs/linprocfs.c Sun Feb 15 01:34:00 2015 (r278791)
+++ user/dchagin/lemul/sys/compat/linprocfs/linprocfs.c Sun Feb 15 07:47:18 2015 (r278792)
@@ -989,6 +989,8 @@ linprocfs_doprocenviron(PFS_FILL_ARGS)
static char l32_map_str[] = "%08lx-%08lx %s%s%s%s %08lx %02x:%02x %lu%s%s\n";
static char l64_map_str[] = "%016lx-%016lx %s%s%s%s %08lx %02x:%02x %lu%s%s\n";
+static char vdso_str[] = " [vdso]";
+static char stack_str[] = " [stack]";
/*
* Filler function for proc/pid/maps
@@ -1025,6 +1027,11 @@ linprocfs_doprocmaps(PFS_FILL_ARGS)
vm = vmspace_acquire_ref(p);
if (vm == NULL)
return (ESRCH);
+
+ if (SV_CURPROC_FLAG(SV_LP64))
+ l_map_str = l64_map_str;
+ else
+ l_map_str = l32_map_str;
map = &vm->vm_map;
vm_map_lock_read(map);
for (entry = map->header.next; entry != &map->header;
@@ -1067,6 +1074,11 @@ linprocfs_doprocmaps(PFS_FILL_ARGS)
VOP_GETATTR(vp, &vat, td->td_ucred);
ino = vat.va_fileid;
vput(vp);
+ } else {
+ if (e_start == p->p_sysent->sv_shared_page_base)
+ name = vdso_str;
+ if (e_end == p->p_sysent->sv_usrstack)
+ name = stack_str;
}
} else {
flags = 0;
@@ -1078,10 +1090,6 @@ linprocfs_doprocmaps(PFS_FILL_ARGS)
* format:
* start, end, access, offset, major, minor, inode, name.
*/
- if (SV_CURPROC_FLAG(SV_LP64))
- l_map_str = l64_map_str;
- else
- l_map_str = l32_map_str;
error = sbuf_printf(sb, l_map_str,
(u_long)e_start, (u_long)e_end,
(e_prot & VM_PROT_READ)?"r":"-",
More information about the svn-src-user
mailing list