On 04/03/2014 12:55 AM, Daniel Colascione wrote: > On 04/03/2014 12:04 AM, Dmitry Antipov wrote: >> On 04/03/2014 10:59 AM, Dmitry Antipov wrote: >> >>> 3. Run 'emacs -Q', then M-x byte-force-recompile >>> /path/to/trunk/lis/org >> ^^^^^^^ >> Mean /path/to/trunk/lisp/org, i.e. all Org mode. > > Nice work. What gave you the idea of using byte-force-recompile to > repro? I'd tried a few other stress cases myself and couldn't find > anything. Your repro works perfectly. > Found the bug: that symbol's name is in pure storage, so we ignore the value of sym->s.gcmarkbit and assume the symbol is always live: we never put it on the free list, so we never set its function slot to Vdead. Later, during another GC pass, conservative GC scanning happens to find a pointer to the symbol. We begin marking it, descend into the function slot, which is still pointing to the old, dead object value. We try to mark memory being used for some other purpose and enter la-la land.