Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 12 Oct 2011 00:00:07 +0000
From:      Nali Toja <nalitoja@gmail.com>
To:        freebsd-current@freebsd.org
Subject:   crash in sb-concurrency tests after r216641 on x86-64/freebsd9/sb-thread
Message-ID:  <86mxd7qdzk.fsf@gmail.com>

next in thread | raw e-mail | index | archive | help
After r216641 sbcl built with sb-thread dies on mailbox tests. It also
dies when I try to complete a symbol in slime. The workaround seems to
be to revert libthr to r216640.

  http://www.freebsd.org/cgi/query-pr.cgi?pr=ports/154050
  http://svn.freebsd.org/changeset/base/216641
  http://www.freshports.org/lang/sbcl # or see ports/161444 for sbcl-1.0.52

Any clue whether it's a FreeBSD bug or a SBCL bug? I've Bcc'd sbcl-bugs@
in case it's the latter one.

  $ cd lang/sbcl
  $ rm files/patch-disable-failing-tests
  $ make # it should fail
  $ cd $(make -V WRKSRC)
  $ SBCL_HOME=contrib/ ./src/runtime/sbcl \
      --core output/sbcl.core --no-userinit --no-sysinit \
      --eval "(require 'sb-concurrency)" \
      --eval "(asdf:oos 'asdf:test-op :sb-concurrency-tests)"
  This is SBCL 1.0.52, an implementation of ANSI Common Lisp.
  More information about SBCL is available at <http://www.sbcl.org/>.

  SBCL is free software, provided as is, with absolutely no warranty.
  It is mostly in the public domain; some portions are provided under
  BSD-style licenses.  See the CREDITS and COPYING files in the
  distribution for more information.
  Doing 16 pending tests of 16 tests total.
   SB-CONCURRENCY-TEST::QUEUE.1 SB-CONCURRENCY-TEST::QUEUE.2
   SB-CONCURRENCY-TEST::QUEUE.3 SB-CONCURRENCY-TEST::QUEUE.4
   SB-CONCURRENCY-TEST::QUEUE.5 SB-CONCURRENCY-TEST::QUEUE.T.1
   SB-CONCURRENCY-TEST::QUEUE.T.2 SB-CONCURRENCY-TEST::QUEUE.T.3
   SB-CONCURRENCY-TEST::MAILBOX-TRIVIA.1 SB-CONCURRENCY-TEST::MAILBOX-TRIVIA.2
   SB-CONCURRENCY-TEST::MAILBOX-TRIVIA.3
   SB-CONCURRENCY-TEST::MAILBOX.SINGLE-PRODUCER-SINGLE-CONSUMER
   SB-CONCURRENCY-TEST::MAILBOX.SINGLE-PRODUCER-MULTIPLE-CONSUMERS
  FFatal error 'thread was already on queue.' at atal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  FaFtfatal error encounteredalal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in tal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  ine 222 in file /usr/src/lib/libthr/thread/thr_cond.c (erf in SBCL pid 1993rfatal error encounteredFatal error 'thread was already on queue.' at line infatal error encountered222 in file /usr/src/lib/libthr/thread/thr_cond.c (errnole /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  o = 0)
  (tid 34384826368)  in SBCL pid 1993= 0F)fatal error encounteredaFFataltfatal error encounteredatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
   error 'thread was already on queue.' aa
   in SBCL pid 1993t lFataFl error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  l error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  ine 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  :
  (tid 34384824320) in SBCL pid 1993fatal error encounteredfatal error encounteredfatal error encountered in SBCL pid 1993fatal error encounteredfatal error encountered in SBCL pid 1993(tid 34384815104):
  SIGABRT received.
  atal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)

  fatal error encountered(tid 34384823296)SIGABRT received.
  :
  (tid 34384822272) in SBCL pid 1993 in SBCL pid 1993 in SBCL pid 1993(tid 34384828416) in SBCL pid 1993(tid 34384813056)FFaFatal error 'thread was already on queue.' t
  at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  al error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  aFatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 Fatal error 'thread was already on queue.' at lFine 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (err in SBCL pid 1993:

  SIGABRT received.
  :
  (tid 34384816128)(tid 34384819200)(tid 34384817152):
  :
  fatal error encounteredfatal error encounteredfatal error encounteredfatal error encounteredfatal error encounteredfatal error encounteredfatal error encounteredfatal error encounteredfatal error encounteredfatal error encounteredfatal error encountered in SBCL pid 1993(tid 34381009920):
  SIGABRT received.


  tal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34384812032):
  SIGABRT received.


  atal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34384803840):
  SIGABRT received.


  (tid 34384814080):
  SIGABRT received.


  SIGABRT received.





  SIGABRT received.


  :
  SIGABRT received.


  :
  SIGABRT received.


  :
  SIGABRT received.


  SIGABRT received.


  SIGABRT received.


   in SBCL pid 1993(tid 34384806912):
  SIGABRT received.


   in SBCL pid 1993(tid 34384808960):
  SIGABRT received.


   in SBCL pid 1993(tid 34381020160):
  SIGABRT received.


   in SBCL pid 1993(tid 34384804864):
  SIGABRT received.


   in SBCL pid 1993(tid 34381018112):
  SIGABRT received.


   in SBCL pid 1993(tid 34381016064):
  SIGABRT received.


   in SBCL pid 1993(tid 34381015040):
  SIGABRT received.


   in SBCL pid 1993(tid 34381014016):
  SIGABRT received.


   in SBCL pid 1993(tid 34381010944):
  SIGABRT received.


   in SBCL pid 1993(tid 34381011968):
  SIGABRT received.


  no = 0)
  fatal error encountered in SBCL pid 1993(tid 34381007872):
  SIGABRT received.


  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34381003776):
  SIGABRT received.


  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34381002752):
  SIGABRT received.


  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34381001728):
  SIGABRT received.


  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34380999680):
  SIGABRT received.


  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34380792832):
  SIGABRT received.


  Fatal error 'thread was already on queue.' at line 222 in file /usr/src/lib/libthr/thread/thr_cond.c (errno = 0)
  fatal error encountered in SBCL pid 1993(tid 34380749824):
  SIGABRT received.


  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> Welcome to LDB, a low-level debugger for the Lisp runtime environment.
  ldb> backtrace
  Backtrace:
     0: Foreign function handle_trap, fp = 0x832e561b0, ra = 0x415040
     1: Foreign function handle_trap, fp = 0x832e56310, ra = 0x4152f8
     2: Foreign function ldb_monitor, fp = 0x832e56380, ra = 0x415344
     3: Foreign function monitor_or_something, fp = 0x832e56390, ra = 0x41539e
     4: Foreign function lose, fp = 0x832e563a0, ra = 0x41146d
     5: Foreign function lose, fp = 0x832e56490, ra = 0x41145d
     6: Foreign function sigabrt_handler, fp = 0x832e564c0, ra = 0x4144d2
     7: Foreign function handle_guard_page_triggered, fp = 0x832e56500, ra = 0x41427d
     8: Foreign fp = 0x832e56980, ra = 0x7ffffffff023
     9: Foreign function abort, fp = 0x832e569b0, ra = 0x8009e6063
    10: Foreign function _pthread_attr_getaffinity_np, fp = 0x832e569e0, ra = 0x800c61479
    11: Foreign function pthread_cond_destroy, fp = 0x832e56a30, ra = 0x800c5f548
    12: Foreign function pthread_cond_destroy, fp = 0x832e56a80, ra = 0x800c5f856
    13: Foreign function pthread_cond_wait, fp = 0x832e56aa0, ra = 0x800c5f8b7
    14: Foreign function pthread_cond_wait, fp = 0x832e56ad0, ra = 0x8009e9fa0
    15: Foreign function sig_stop_for_gc_handler, fp = 0x832e56af0, ra = 0x413574
    16: Foreign function sig_stop_for_gc_handler, fp = 0x832e56b30, ra = 0x4133a8
    17: Foreign function handle_guard_page_triggered, fp = 0x832e56b70, ra = 0x41427d
    18: Foreign fp = 0x832e57040, ra = 0x7ffffffff023
    19: Foreign function _pthread_kill, fp = 0x832e57070, ra = 0x800c5c04b
    20: Foreign function pthread_cond_destroy, fp = 0x832e570c0, ra = 0x800c5f5dd
    21: Foreign function pthread_cond_destroy, fp = 0x832e57110, ra = 0x800c5f856
    22: Foreign function pthread_cond_wait, fp = 0x832e57130, ra = 0x800c5f8b7
    23: Foreign function pthread_cond_wait, fp = 0x832e57160, ra = 0x8009e9fa0
    24: Foreign function lutex_wait, fp = 0x832e571a0, ra = 0x41804f
    25: (COMMON-LISP::FLET WITHOUT-INTERRUPTS-BODY-[CONDITION-WAIT]230)
    26: (SB-C::TL-XEP SB-THREAD::CONDITION-WAIT)
    27: (COMMON-LISP::FLET SB-THREAD::WITH-SYSTEM-MUTEX-THUNK)
    28: (COMMON-LISP::FLET WITHOUT-INTERRUPTS-BODY-[CALL-WITH-SYSTEM-MUTEX/ALLOW-WITH-INTERRUPTS]206)
    29: SB-THREAD::WAIT-ON-SEMAPHORE
    30: (COMMON-LISP::FLET WITHOUT-INTERRUPTS-BODY-[RECEIVE-MESSAGE]139)
    31: (SB-C::VARARGS-ENTRY SB-CONCURRENCY::RECEIVE-MESSAGE)
    32: (COMMON-LISP::LAMBDA ())
    33: (COMMON-LISP::FLET WITHOUT-INTERRUPTS-BODY-[BLOCK443]448)
    34: (COMMON-LISP::FLET SB-THREAD::WITH-MUTEX-THUNK)
    35: (COMMON-LISP::FLET WITHOUT-INTERRUPTS-BODY-[CALL-WITH-MUTEX]309)
    36: SB-THREAD::CALL-WITH-MUTEX
    37: SB-THREAD::INITIAL-THREAD-FUNCTION
    38: Foreign function call_into_lisp, fp = 0x832e57f30, ra = 0x426920
    39: Foreign function funcall0, fp = 0x832e57f60, ra = 0x40d61d
    40: Foreign function funcall0, fp = 0x832e57f90, ra = 0x40d5e6
    41: Foreign function new_thread_trampoline, fp = 0x832e57fc0, ra = 0x41ab26
    42: Foreign function pthread_create, fp = 0x832e57ff0, ra = 0x800c523fe
  ldb> kill 11
  Program received signal SIGSEGV, Segmentation fault.
  0x0000000800c5c7ec in _umtx_op_err () at /usr/src/lib/libthr/arch/amd64/amd64/_umtx_op_err.S:37
  37      RSYSCALL_ERR(_umtx_op)
  Current language:  auto; currently asm
  (gdb) bt
  #0  0x0000000800c5c7ec in _umtx_op_err () at /usr/src/lib/libthr/arch/amd64/amd64/_umtx_op_err.S:37
  #1  0x0000000800c5423e in _thr_umtx_timedwait_uint (mtx=0x8006d4ea8, id=0, clockid=0, abstime=0x0, shared=0) at /usr/src/lib/libthr/thread/thr_umtx.c:214
  #2  0x0000000800c5c04b in _thr_sleep (curthread=0x828d5d400, clockid=0, abstime=0x0) at /usr/src/lib/libthr/thread/thr_kern.c:212
  #3  0x0000000800c5f5dd in cond_wait_user (cvp=0x828fdf850, mp=0x828fe0970, abstime=0x0, cancel=1) at /usr/src/lib/libthr/thread/thr_cond.c:243
  #4  0x0000000800c5f856 in cond_wait_common (cond=0x8480f0008, mutex=0x8480f0000, abstime=0x0, cancel=1) at /usr/src/lib/libthr/thread/thr_cond.c:299
  #5  0x0000000800c5f8b7 in __pthread_cond_wait (cond=0x8480f0008, mutex=0x8480f0000) at /usr/src/lib/libthr/thread/thr_cond.c:313
  #6  0x00000008009e9fa0 in pthread_cond_wait_exp (p0=0x8480f0008, p1=0x8480f0000) at /usr/src/lib/libc/gen/_pthread_stubs.c:217
  #7  0x0000000000413574 in wait_for_thread_state_change (thread=0x8480f0010, state=16) at thread.h:53
  #8  0x00000000004133a8 in sig_stop_for_gc_handler (signal=31, info=0x847eef630, context=0x847eef2c0) at interrupt.c:1265
  #9  0x000000000041427d in low_level_handle_now_handler (signal=31, info=0x847eef630, void_context=0x847eef2c0) at interrupt.c:1729
  #10 0x00007ffffffff023 in ?? ()
  #11 0x0000000000414220 in low_level_unblock_me_trampoline () at interrupt.c:1723
  #12 0x000000100154c990 in ?? ()
  #13 0x000000000063eaa0 in interrupt_handlers ()
  #14 0x0000000200411d4f in ?? ()
  #15 0x0000001003375721 in ?? ()
  #16 0x38b485040000001a in ?? ()
  #17 0x00000000000a81f0 in ?? ()
  #18 0x0000000000000000 in ?? ()
  #19 0x0000000847eef840 in ?? ()
  #20 0x0000001003af2a2f in ?? ()
  #21 0x0000002004e9c3e1 in ?? ()
  #22 0x0000000800c58570 in _sigprocmask (how=Could not find the frame base for "_sigprocmask".
  ) at /usr/src/lib/libthr/thread/thr_sig.c:584
  Previous frame inner to this frame (corrupt stack?)
  (gdb) f 7
  #7  0x0000000000413574 in wait_for_thread_state_change (thread=0x8480f0010, state=16) at thread.h:53
  53              pthread_cond_wait(thread->state_cond, thread->state_lock);
  (gdb) l
  48      static inline void
  49      wait_for_thread_state_change(struct thread *thread, lispobj state)
  50      {
  51          pthread_mutex_lock(thread->state_lock);
  52          while (thread->state == state)
  53              pthread_cond_wait(thread->state_cond, thread->state_lock);
  54          pthread_mutex_unlock(thread->state_lock);
  55      }
  56
  57      extern pthread_key_t lisp_thread;



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?86mxd7qdzk.fsf>