Bug 117375 - LibreOffice Calc hangs when opening an (oldish) .xls document; apparently in a loop in "SfxBroadcaster::RemoveListener"
Summary: LibreOffice Calc hangs when opening an (oldish) .xls document; apparently in ...
Status: RESOLVED INSUFFICIENTDATA
Alias: None
Product: LibreOffice
Classification: Unclassified
Component: Calc (show other bugs)
Version:
(earliest affected)
5.4.6.2 release
Hardware: x86-64 (AMD64) Linux (All)
: medium normal
Assignee: Not Assigned
URL:
Whiteboard:
Keywords:
Depends on:
Blocks:
 
Reported: 2018-05-01 14:13 UTC by David Tonhofer
Modified: 2018-12-03 13:20 UTC (History)
1 user (show)

See Also:
Crash report or crash signature:


Attachments
Backtrace of "soffice.bin" thread (15.50 KB, text/plain)
2018-05-01 14:14 UTC, David Tonhofer
Details

Note You need to log in before you can comment on or make changes to this bug.
Description David Tonhofer 2018-05-01 14:13:48 UTC
Description:
I open a an .xls document from long ago. It may have an embedded chart (unfortunately I cannot share the document). It has three tabs.

The document is displayed correctly. However, once one clicks anything, Calc seems to hang while using 100% CPU.

I have attached GDB to the process (not my usual line of work though). There are four threads. One called "soffice.bin" is doing low-level work in "SfxBroadcaster::RemoveListener" after having stacked through calls like "chart::ChartView::createShapes2D".

See attachment for backtrace.

The topmost stack line active before we go into the Standard Library is line 128 of https://docs.libreoffice.org/svl/html/SfxBroadcaster_8cxx_source.html

and the running loop is in

https://gcc.opensuse.org/gcc-lcov/usr/include/c++/7/bits/stl_algo.h.gcov.html

at line 120.

for (; __trip_count > 0; --__trip_count)
  {
    if (__pred(__first))
      return __first;
    ++__first;

    if (__pred(__first))
      return __first;
    ++__first;

    if (__pred(__first))
      return __first;
    ++__first;

    if (__pred(__first))
      return __first;
    ++__first;
  }

Unfortunately "__trip_count" has been "optimized out" but that loop seems not about stop. "__trip_count" seems to be very large?


Steps to Reproduce:
1. Open my mystery Excel document
2. Hangs!

Actual Results:  
Calc hangs.

Expected Results:
Calc should not hang.


Reproducible: Always


User Profile Reset: No



Additional Info:


User-Agent: Mozilla/5.0 (X11; Fedora; Linux x86_64; rv:59.0) Gecko/20100101 Firefox/59.0
Comment 1 David Tonhofer 2018-05-01 14:14:33 UTC
Created attachment 141816 [details]
Backtrace of "soffice.bin" thread
Comment 2 David Tonhofer 2018-05-01 15:06:11 UTC
Update: This document can be opened in Calligra Sheets and indeed has an embedded Chart.

Calligra Sheets mangles it though.

I don't have Excel at hand currently...
Comment 3 Xisco Faulí 2018-05-01 19:31:31 UTC
Thank you for reporting the bug. Please attach a sample document, as this makes it easier for us to verify the bug. 
(Please note that the attachment will be public, remove any sensitive information before attaching it. 
See https://wiki.documentfoundation.org/QA/FAQ#How_can_I_eliminate_confidential_data_from_a_sample_document.3F for help on how to do so.)

I have set the bug's status to 'NEEDINFO'. Please change it back to 'UNCONFIRMED' once the requested document is provided.
Comment 4 QA Administrators 2018-11-05 16:08:16 UTC Comment hidden (obsolete)
Comment 5 QA Administrators 2018-12-03 13:20:07 UTC
Dear Bug Submitter,

Please read this message in its entirety before proceeding.

Your bug report is being closed as INSUFFICIENTDATA due to inactivity and
a lack of information which is needed in order to accurately
reproduce and confirm the problem. We encourage you to retest
your bug against the latest release. If the issue is still
present in the latest stable release, we need the following
information (please ignore any that you've already provided):

a) Provide details of your system including your operating
   system and the latest version of LibreOffice that you have
   confirmed the bug to be present

b) Provide easy to reproduce steps – the simpler the better

c) Provide any test case(s) which will help us confirm the problem

d) Provide screenshots of the problem if you think it might help

e) Read all comments and provide any requested information

Once all of this is done, please set the bug back to UNCONFIRMED
and we will attempt to reproduce the issue. Please do not:

a) respond via email 

b) update the version field in the bug or any of the other details
   on the top section of our bug tracker

Warm Regards,
QA Team

MassPing-NeedInfo-20181203