Bug 73695 - Other: soffice.bin crashed with SIGSEGV in Timer::ImplTimerCallbackProc()
Summary: Other: soffice.bin crashed with SIGSEGV in Timer::ImplTimerCallbackProc()
Alias: None
Product: LibreOffice
Classification: Unclassified
Component: Calc (show other bugs)
(earliest affected) release
Hardware: x86-64 (AMD64) Linux (All)
: medium critical
Assignee: Eike Rathke
Whiteboard: BSA target:4.4.0 target:4.3.5
Depends on:
Reported: 2014-01-16 10:26 UTC by Walter Garcia-Fontes
Modified: 2014-11-17 20:56 UTC (History)
2 users (show)

See Also:
Crash report or crash signature:
Regression By:

Spreadsheet with macros to reproduce this crash (342.25 KB, application/vnd.oasis.opendocument.spreadsheet)
2014-01-16 10:26 UTC, Walter Garcia-Fontes

Note You need to log in before you can comment on or make changes to this bug.
Description Walter Garcia-Fontes 2014-01-16 10:26:36 UTC
Created attachment 92215 [details]
Spreadsheet with macros to reproduce this crash

Problem description: 
I have a package composed by a collection of spreadsheets with macros. Since a couple of LibreOffice versions I get this crash. I attach a spreadsheet with macros where I can reproduce this crash 100% of the times. I will try to create a simpler test case since this spreadsheet is unnecessarily complex (a part of my package).

Steps to reproduce:
1) Open 1num1cat.ods (attached file). Press OK to the dialog that appears.
2) Go to the "Data entry" worksheet
3) Copy the range A2:B50 (any range here would do)
4) Double click on A1 or B1, a dialog opens, click OK.

Current behavior:
Libreoffice freezes for 20 seconds and then crashes

Expected behavior:
The macro should paste the data in the range A2:B50

For a stacktrace see:
Operating System: Ubuntu
Version: release
Comment 1 Christopher M. Penalver 2014-01-16 18:50:28 UTC
Not reproducible in MASTER:
Microsoft Windows Vista Business x86 6.0.6002 Service Pack 2 Build 6002
Build ID: 42f551d524a1df46f6a311d5897ac30bd8fc1aaf
TinderBox: Win-x86@42, Branch:master, Time: 2014-01-15_22:51:46

Is reproducible in:
lsb_release -rd
Description: Ubuntu Trusty Tahr (development branch)
Release: 14.04

apt-cache policy libreoffice-calc
  Installed: 1:4.1.3-0ubuntu3
  Candidate: 1:4.1.3-0ubuntu3
  Version table:
 *** 1:4.1.3-0ubuntu3 0
        500 http://us.archive.ubuntu.com/ubuntu/ trusty/main amd64 Packages
        100 /var/lib/dpkg/status

May be linux only and/or older version only issue.
Comment 2 Walter Garcia-Fontes 2014-03-27 13:36:10 UTC
I can also reproduce it in:

lsb_release -rd 
Description:	Ubuntu Trusty Tahr (development branch)
Release:	14.04

apt-cache policy libreoffice-calc
  Installed: 1:4.2.1-0ubuntu1
  Candidate: 1:4.2.1-0ubuntu1
  Version table:
 *** 1:4.2.1-0ubuntu1 0
        500 http://ftp.caliu.cat/pub/distribucions/ubuntu/archive/ trusty/main amd64 Packages
        100 /var/lib/dpkg/status
Comment 3 Walter Garcia-Fontes 2014-06-13 12:04:31 UTC
Still reproducing it in:

  Installed: 1:4.2.3~rc3-0ubuntu2
  Candidate: 1:4.2.3~rc3-0ubuntu2
  Version table:
 *** 1:4.2.3~rc3-0ubuntu2 0
        500 http://ftp.caliu.cat/pub/distribucions/ubuntu/archive/ trusty/universe amd64 Packages
        100 /var/lib/dpkg/status
Comment 4 Walter Garcia-Fontes 2014-10-02 16:39:04 UTC
Still reproducing it in (the testcase above crashes Libreoffice after some seconds of unresponsiveness):

Description:	Ubuntu Utopic Unicorn (development branch)
Release:	14.10

apt-cache policy libreoffice-calc
  Installed: 1:4.3.2-0ubuntu1
  Candidate: 1:4.3.2-0ubuntu1
  Version table:
 *** 1:4.3.2-0ubuntu1 0
        500 http://ftp.caliu.cat/pub/distribucions/ubuntu/archive/ utopic/main amd64 Packages
        100 /var/lib/dpkg/status

Not able to reproduce in Windows, I haven't tried in this last versions but in 4.2.3 I cannot reproduce it.

It's also working in the Mac version.
Comment 5 Walter Garcia-Fontes 2014-11-13 06:27:06 UTC
Right now I'm able to reproduce this bug in all 4.3.X versions in all platforms: Windows, Mac and Linux
Comment 6 Eike Rathke 2014-11-15 00:56:07 UTC
This is a re-entrance problem. While the charts are updated there are chart data listeners in BASIC that in turn modify things such that charts are inserted/removed from the listener chain, invalidating the iterator.
Comment 7 Commit Notification 2014-11-15 01:09:44 UTC
Eike Rathke committed a patch related to this issue.
It has been pushed to "master":


fdo#73695 prevent use of invalidated iterator due to re-entrance

It will be available in 4.4.0.

The patch should be included in the daily builds available at
http://dev-builds.libreoffice.org/daily/ in the next 24-48 hours. More
information about daily builds can be found at:
Affected users are encouraged to test the fix and report feedback.
Comment 8 Eike Rathke 2014-11-15 01:31:33 UTC
Pending review for 4-3 at https://gerrit.libreoffice.org/12434