Public bug reported:

When a DcmFileFormat is copied in a thread, there is a possible race
condition that may lead to SIGSEGV because of a null pointer
dereference.

A test case is attached. It creates an empty DcmFileFormat, then spawns
12 threads that will copy the DcmFileFormat 1000 times. In my
experiments, in about 75% of the runs, it crashes with a segmentation
fault with the following stack trace:

-----8<-----
* thread #4: tid = 21848, 0x00007f7275242b33 
libdcmdata.so.2`DcmSequenceOfItems::DcmSequenceOfItems(DcmSequenceOfItems 
const&) + 131, name = 'testcase', stop reason = invalid address (fault address: 
0x0)
  * frame #0: 0x00007f7275242b33 
libdcmdata.so.2`DcmSequenceOfItems::DcmSequenceOfItems(DcmSequenceOfItems 
const&) + 131
    frame #1: 0x00007f7275249441 
libdcmdata.so.2`DcmFileFormat::DcmFileFormat(DcmFileFormat const&) + 17
    frame #2: 0x00000000004014bd 
testcase`operator(__closure=0x0000000002150e80) + 63 at testcase.cpp:17
    frame #3: 0x00000000004018c2 
testcase`_M_invoke(__functor=0x0000000002157a20) + 32 at functional:2071
----->8------

The test case contains a commented out line that will lock a mutex
before performing the copy; if this line is uncommented, no crashes are
seen, confirming suspicions of a race condition.

I compile the test case using the following command:

  g++ -o testcase testcase.cpp -g -Wall -std=c++11 -DHAVE_CONFIG_H
-ldcmdata

I'm reporting this here because I use the Ubuntu repository version of
the package. If you want me to, I can report this upstream as well,
after verifying that the problem is not caused by Ubuntu/Debian-specific
patches.

ProblemType: Bug
DistroRelease: Ubuntu 14.04
Package: libdcmtk2 3.6.0-15
ProcVersionSignature: Ubuntu 3.13.0-61.100-generic 3.13.11-ckt22
Uname: Linux 3.13.0-61-generic x86_64
NonfreeKernelModules: nvidia
ApportVersion: 2.14.1-0ubuntu3.12
Architecture: amd64
CurrentDesktop: XFCE
Date: Fri Aug 21 11:26:49 2015
InstallationDate: Installed on 2015-02-18 (183 days ago)
InstallationMedia: Xubuntu 14.04.1 LTS "Trusty Tahr" - Release amd64 (20140723)
SourcePackage: dcmtk
UpgradeStatus: No upgrade log present (probably fresh install)

** Affects: dcmtk (Ubuntu)
     Importance: Undecided
         Status: New


** Tags: amd64 apport-bug trusty

** Attachment added: "Test case"
   
https://bugs.launchpad.net/bugs/1487389/+attachment/4450148/+files/testcase.cpp

-- 
You received this bug notification because you are a member of Ubuntu
Bugs, which is subscribed to Ubuntu.
https://bugs.launchpad.net/bugs/1487389

Title:
  SIGSEGV on threaded copy of DcmFileFormat

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/dcmtk/+bug/1487389/+subscriptions

-- 
ubuntu-bugs mailing list
ubuntu-bugs@lists.ubuntu.com
https://lists.ubuntu.com/mailman/listinfo/ubuntu-bugs

Reply via email to