Date: Tue, 14 Mar 2017 08:23:26 +0000 From: bugzilla-noreply@freebsd.org To: freebsd-amd64@FreeBSD.org Subject: [Bug 217138] head (e.g.) -r313999 for arm64: sh vs. jemalloc asserts: include/jemalloc/internal/tsd.h:687: Failed assertion: "tsd_booted" once swapped in after being swapped out (comment 10) Message-ID: <bug-217138-6-w9RNeoFtXK@https.bugs.freebsd.org/bugzilla/> In-Reply-To: <bug-217138-6@https.bugs.freebsd.org/bugzilla/> References: <bug-217138-6@https.bugs.freebsd.org/bugzilla/>
next in thread | previous in thread | raw e-mail | index | archive | help
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=3D217138 --- Comment #18 from Mark Millard <markmi@dsl-only.net> --- Created attachment 180808 --> https://bugs.freebsd.org/bugzilla/attachment.cgi?id=3D180808&action= =3Dedit C source for showing fork/swap memory corruption failure I'm still at a loss about how to figure out what stages are messed up. (Memory coherency? Some memory not swapped out? Bad data swapped out? Wrong data swapped in?) But at least I've found a much smaller/simpler example to demonstrate some problem with in my Pine64+_ 2GB context. The Pine64+ 2GB is the only arm64 context that I have access to. The attached program fails its check for data having its expected byte pattern in dynamically allocated memory after a fork/swap-out/swap-in sequence. The bytes end up all zero instead. I'll note that the program sleeps for 60s after forking to give time to do something else to cause the parent and child processes to swap out (RES=3D0 as seen in top). A point is the size of the region matters: <=3D 14K Bytes fails and > 14K Bytes works for as much has I have tested. https://lists.freebsd.org/pipermail/freebsd-arm/2017-March/015869.html has more material, including lldb's disassembly of the compiled and linked C code. --=20 You are receiving this mail because: You are on the CC list for the bug.=
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?bug-217138-6-w9RNeoFtXK>