Date: Sat, 1 Sep 2012 17:33:56 +0200 From: Holger Hans Peter Freyther <holger@freyther.de> To: freebsd-emulation@freebsd.org Subject: Re: Linux SHM inside a jail Message-ID: <20120901153356.GW1299@localhost> In-Reply-To: <20120822164106.GE4301@localhost> References: <20120822164106.GE4301@localhost>
next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, Aug 22, 2012 at 06:41:06PM +0200, Holger Hans Peter Freyther wrote:
> PS: I looked at both GLIBC ntpl/sem_open.c and linux_stats.c. One option
> would be to list another directory in /proc/mounts with tmpfs/shmfs and
> replicate the check in linux_stats.c for this alternative directory.
I went ahead and explored this route and created the following patch. Does
anyone have an idea how to make it work with a custom devfs.rule? With the
below patch I can use/run the python multiprocess module inside a jail.
comments?
>From 3eeb57564e0fb6b7234e3db50309fd359701d9dc Mon Sep 17 00:00:00 2001
From: Holger Hans Peter Freyther <holger@freyther.de>
Date: Sat, 1 Sep 2012 17:20:42 +0200
Subject: [PATCH] Announce shm on /tmp/shm
Make linprocfs announce shm and let statfs return the shmfs magic
for this directory. This makes it easy to use shmfs inside a jail.
---
 sys/compat/linprocfs/linprocfs.c | 4 ++++
 sys/compat/linux/linux_stats.c   | 4 +++-
 2 files changed, 7 insertions(+), 1 deletion(-)
diff --git a/sys/compat/linprocfs/linprocfs.c b/sys/compat/linprocfs/linprocfs.c
index 3adbe96..9a2f97e 100644
--- a/sys/compat/linprocfs/linprocfs.c
+++ b/sys/compat/linprocfs/linprocfs.c
@@ -390,6 +390,10 @@ linprocfs_domtab(PFS_FILL_ARGS)
 		/* a real Linux mtab will also show NFS options */
 		sbuf_printf(sb, " 0 0\n");
 	}
+
+	/* Add a mountpoint for shm inside jails */
+	sbuf_printf(sb, "tmpfs /tmp/shm tmpfs rw,nosuid,nodev,relatime 0 0\n");
+	
 	mtx_unlock(&mountlist_mtx);
 	if (flep != NULL)
 		free(flep, M_TEMP);
diff --git a/sys/compat/linux/linux_stats.c b/sys/compat/linux/linux_stats.c
index 2e05c85..7411570 100644
--- a/sys/compat/linux/linux_stats.c
+++ b/sys/compat/linux/linux_stats.c
@@ -409,9 +409,11 @@ linux_statfs(struct thread *td, struct linux_statfs_args *args)
 #endif
 	dev_shm = 0;
 	error = kern_statfs(td, path, UIO_SYSSPACE, &bsd_statfs);
-	if (strncmp(path, "/dev/shm", sizeof("/dev/shm") - 1) == 0)
+	if (strncmp(path, "/dev/shm", sizeof("/dev/shm") - 1) == 0 ||
+	    strncmp(path, "/tmp/shm", sizeof("/tmp/shm") - 1) == 0)
 		dev_shm = (path[8] == '\0'
 		    || (path[8] == '/' && path[9] == '\0'));
+		
 	LFREEPATH(path);
 	if (error)
 		return (error);
-- 
1.7.11.5
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20120901153356.GW1299>
