Date: Tue, 26 May 2015 00:31:03 +0300 From: Chagin Dmitry <dchagin@freebsd.org> To: Larry Rosenman <ler@lerctr.org> Cc: freebsd-current@FreeBSD.org Subject: Re: Linuxulator: CRASH Message-ID: <20150525213103.GA21369@dchagin.static.corbina.net> In-Reply-To: <20150525211232.GA1143@borg.lerctr.org> References: <20150525204118.GA1176@borg.lerctr.org> <20150525205536.GA6195@dchagin.static.corbina.net> <20150525211232.GA1143@borg.lerctr.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, May 25, 2015 at 04:12:32PM -0500, Larry Rosenman wrote:
> On Mon, May 25, 2015 at 11:55:36PM +0300, Chagin Dmitry wrote:
> > On Mon, May 25, 2015 at 03:41:18PM -0500, Larry Rosenman wrote:
> > > I have a boinc-client installation running World Community Grid science
> > > that's been working fine for months.
> > >
> > > Updated to current -HEAD, and now we crash the kernel if it's running.
> > >
> > > The backtrace points to the linuxulator.
> > >
> > r283544, but this is not final fix.
> >
> > chd
>
> Thanks! That fixes the crash -- I'll watch for follow-on commits.
>
this need more testing before land:
diff --git a/sys/compat/linux/linux_emul.c b/sys/compat/linux/linux_emul.c
index a28da8d..c2bf3ae 100644
--- a/sys/compat/linux/linux_emul.c
+++ b/sys/compat/linux/linux_emul.c
@@ -219,6 +219,18 @@ void
linux_proc_exec(void *arg __unused, struct proc *p, struct image_params *imgp)
{
struct thread *td = curthread;
+ struct thread *othertd;
+
+ /*
+ * In a case of execing from linux binary properly detach
+ * other threads from the user space.
+ */
+ if (__predict_false(SV_PROC_ABI(p) == SV_ABI_LINUX)) {
+ FOREACH_THREAD_IN_PROC(p, othertd) {
+ if (td != othertd)
+ (p->p_sysent->sv_thread_detach)(othertd);
+ }
+ }
/*
* In a case of execing to linux binary we create linux
--
Have fun!
chd
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20150525213103.GA21369>
