[Pkg-deepin-devel] Bug#1015382: deepin-calculator: ftbfs with LTO (link time optimization) enabled

Matthias Klose doko at debian.org
Tue Jul 19 17:51:22 BST 2022


Package: src:deepin-calculator
Version: 5.7.20-1
Severity: minor
Tags: sid bookworm
User: debian-gcc at lists.debian.org
Usertags: ftbfs-lto

This package currently fails to build (at least on the amd64
architecture) with link time optimizations enabled.  For a background
for LTO please see

https://wiki.debian.org/ToolChain/LTO

The goal is to enable this optimization by default in an upcoming
Debian release in dpkg-buildflags for 64bit architectures.  The goal
is to get this package to build with link time optimizations, or to
explicitly disable link time optimizations for this package build.

To reproduce the build failure, enable the lto optimization in
testing/unstable by adding "optimize=+lto" to DEB_BUILD_MAINT_OPTIONS
in the debian/rules file, or if this macro is unset, just set it:

export DEB_BUILD_MAINT_OPTIONS = optimize=+lto

Please try to fix the build with lto enabled, fixing the packaging or
forwarding the issue upstream. If the issue cannot be fixed,
explicitly disallow building the package with lto by adding to your
rules file:

export DEB_BUILD_MAINT_OPTIONS = optimize=-lto

or adding that string to your existing setting of DEB_BUILD_MAINT_OPTIONS.

The full build log can be found at:
http://qa-logs.debian.net/2022/06/09/dpkglto/deepin-calculator_5.7.20-1_unstable_dpkglto.log
The last lines of the build log are at the end of this report.

[...]
/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests/../../src/widgets/../../3rdparty/core/evaluator.h:68:57: warning: ‘QString::null’ is deprecated: use QString() [-Wdeprecated-declarations]
   68 |     Token(Type = stxUnknown, const QString & = QString::null, int pos = -1,
      |                                                         ^~~~
In file included from /usr/include/x86_64-linux-gnu/qt5/QtTest/qtestcase.h:45,
                 from /usr/include/x86_64-linux-gnu/qt5/QtTest/qtest.h:45,
                 from /usr/include/x86_64-linux-gnu/qt5/QtTest/QTest:1,
                 from /<<PKGBUILDDIR>>/tests/src/widgets/ut_sciexpressionbar.h:6,
                 from /<<PKGBUILDDIR>>/tests/src/widgets/ut_sciexpressionbar.cpp:1:
/usr/include/x86_64-linux-gnu/qt5/QtCore/qstring.h:954:23: note: declared here
  954 |     static const Null null;
      |                       ^~~~
[100%] Linking CXX executable deepin-calculator-test
cd /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests && /usr/bin/cmake -E cmake_link_script CMakeFiles/deepin-calculator-test.dir/link.txt --verbose=1
/usr/bin/c++ -g -O2 -ffile-prefix-map=/<<PKGBUILDDIR>>=. -flto=auto -ffat-lto-objects -fstack-protector-strong -Wformat -Werror=format-security -Wdate-time -D_FORTIFY_SOURCE=2 -Wl,-z,now -g -Wall -Wl,--as-needed -fPIE -O3 -DCMAKE_SAFETYTEST_ARG_OFF -g -Wall -Wl,--as-needed -fPIE -O3 -DCMAKE_SAFETYTEST_ARG_OFF -O3 -DNDEBUG -pie "CMakeFiles/deepin-calculator-test.dir/deepin-calculator-test_autogen/mocs_compilation.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/basickeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/bitbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/equalbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/iconbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/memhiskeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/memorybutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/memorykeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/procheckbtnkeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/programmerkeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/prosystemkeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/scientifickeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/control/textbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/dsettings.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/mainwindow.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/memorypublic.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/utils.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/memoryitemdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/memoryitemwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/memorylistwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/memorywidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/programmerarrowdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/programmeritemwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/prolistdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/prolistmodel.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/prolistview.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/simplelistdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/simplelistmodel.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/views/simplelistview.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/arrowrectangle.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/basicmodule.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/expressionbar.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/inputedit.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/memhiswidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/probitwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/proexpressionbar.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/programmodule.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/scientificmodule.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/src/widgets/sciexpressionbar.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatcommon.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatconst.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatconvert.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floaterf.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatexp.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatgamma.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floathmath.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatincgamma.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatio.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatipower.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatlog.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatlogic.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatlong.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatnum.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatpower.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floatseries.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/floattrig.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/number.c.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/book.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/constants.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/evaluator.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/functions.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/manualserver.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/numberformatter.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/opcode.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/pageserver.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/session.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/sessionhistory.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/settings.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/userfunction.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/core/variable.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/cmath.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/cnumberparser.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/hmath.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/quantity.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/rational.cpp.o" "CMakeFiles/deepin-calculator-test.dir/__/3rdparty/math/units.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_basickeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_bitbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_equalbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_iconbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_memhiskeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_memorybutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_memorykeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_procheckbtnkeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_programmerkeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_prosystemkeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_scientifickeypad.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/control/ut_textbutton.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/main.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/ut_dsetting.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/ut_mainwindow.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/ut_memorypublic.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/ut_utils.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_memoryitemdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_memoryitemwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_memorylistwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_memorywidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_programmerarrowdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_programmeritemwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_prolistdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_prolistmodel.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_prolistview.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_simplelistdelegate.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_simplelistmodel.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/views/ut_simplelistview.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_arrowrectangle.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_basicmodul.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_expressionbar.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_inputedit.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_memhiswidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_probitwidget.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_proexpressionbar.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_programmodule.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_scientificmodule.cpp.o" "CMakeFiles/deepin-calculator-test.dir/src/widgets/ut_sciexpressionbar.cpp.o" -o deepin-calculator-test  -lgmock -lgmock_main -lgtest -lgtest_main -lpthread /usr/lib/x86_64-linux-gnu/libQt5DBus.so.5.15.2 /usr/lib/x86_64-linux-gnu/libQt5Xml.so.5.15.2 /usr/lib/x86_64-linux-gnu/libQt5Svg.so.5.15.2 /usr/lib/x86_64-linux-gnu/libQt5Test.so.5.15.2 -ldtkwidget -ldtkcore -ldtkgui -ldtkcore -ldtkcore -ldframeworkdbus -ldtkgui -ldframeworkdbus /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5.15.2 /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5.15.2 /usr/lib/x86_64-linux-gnu/libQt5Core.so.5.15.2 
make[3]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
[100%] Built target deepin-calculator-test
make[2]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
/usr/bin/cmake -E cmake_progress_start /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/CMakeFiles 0
make[1]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
   dh_auto_test
	cd obj-x86_64-linux-gnu && make -j8 test ARGS\+=--verbose ARGS\+=-j8
make[1]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
/usr/bin/cmake -S/<<PKGBUILDDIR>> -B/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu --check-build-system CMakeFiles/Makefile.cmake 0
make  -f CMakeFiles/Makefile2 test
make[2]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
/usr/bin/cmake -S/<<PKGBUILDDIR>> -B/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu --check-build-system CMakeFiles/Makefile.cmake 0
/usr/bin/cmake -E cmake_progress_start /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/CMakeFiles 59
make  -f CMakeFiles/Makefile2 tests/CMakeFiles/test.dir/all
make[3]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make  -f tests/CMakeFiles/deepin-calculator-test_autogen.dir/build.make tests/CMakeFiles/deepin-calculator-test_autogen.dir/depend
make[4]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
cd /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu && /usr/bin/cmake -E cmake_depends "Unix Makefiles" /<<PKGBUILDDIR>> /<<PKGBUILDDIR>>/tests /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests/CMakeFiles/deepin-calculator-test_autogen.dir/DependInfo.cmake --color=
make[4]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make  -f tests/CMakeFiles/deepin-calculator-test_autogen.dir/build.make tests/CMakeFiles/deepin-calculator-test_autogen.dir/build
make[4]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
[  1%] Automatic MOC for target deepin-calculator-test
cd /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests && /usr/bin/cmake -E cmake_autogen /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests/CMakeFiles/deepin-calculator-test_autogen.dir/AutogenInfo.json Release
make[4]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
[  1%] Built target deepin-calculator-test_autogen
make  -f tests/CMakeFiles/deepin-calculator-test.dir/build.make tests/CMakeFiles/deepin-calculator-test.dir/depend
make[4]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
cd /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu && /usr/bin/cmake -E cmake_depends "Unix Makefiles" /<<PKGBUILDDIR>> /<<PKGBUILDDIR>>/tests /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests/CMakeFiles/deepin-calculator-test.dir/DependInfo.cmake --color=
Consolidate compiler generated dependencies of target deepin-calculator-test
make[4]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make  -f tests/CMakeFiles/deepin-calculator-test.dir/build.make tests/CMakeFiles/deepin-calculator-test.dir/build
make[4]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make[4]: Nothing to be done for 'tests/CMakeFiles/deepin-calculator-test.dir/build'.
make[4]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
[100%] Built target deepin-calculator-test
make  -f tests/CMakeFiles/test.dir/build.make tests/CMakeFiles/test.dir/depend
make[4]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
cd /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu && /usr/bin/cmake -E cmake_depends "Unix Makefiles" /<<PKGBUILDDIR>> /<<PKGBUILDDIR>>/tests /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests/CMakeFiles/test.dir/DependInfo.cmake --color=
make[4]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make  -f tests/CMakeFiles/test.dir/build.make tests/CMakeFiles/test.dir/build
make[4]: Entering directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
cd /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests && echo \ ===================\ CREAT\ LCOV\ REPROT\ BEGIN\ ====================\ 
 =================== CREAT LCOV REPROT BEGIN ==================== 
cd /<<PKGBUILDDIR>>/obj-x86_64-linux-gnu/tests && ./deepin-calculator-test
Segmentation fault
make[4]: *** [tests/CMakeFiles/test.dir/build.make:74: test] Error 139
make[4]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make[3]: *** [CMakeFiles/Makefile2:184: tests/CMakeFiles/test.dir/all] Error 2
make[3]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make[2]: *** [CMakeFiles/Makefile2:191: tests/CMakeFiles/test.dir/rule] Error 2
make[2]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
make[1]: *** [Makefile:211: test] Error 2
make[1]: Leaving directory '/<<PKGBUILDDIR>>/obj-x86_64-linux-gnu'
dh_auto_test: error: cd obj-x86_64-linux-gnu && make -j8 test ARGS\+=--verbose ARGS\+=-j8 returned exit code 2
make: *** [debian/rules:15: binary] Error 25
dpkg-buildpackage: error: debian/rules binary subprocess returned exit status 2



More information about the Pkg-deepin-devel mailing list