Hi, I'm trying to analyze using given *.o and *.dot files using "-fdump-tree-all-graph" options.
but after building there are no *.o and *.dot files per each file, there are only rusefi.elf.ltrans.....dot files.
After quick check, it seems that ruesfi's build system itself compile each each files into /tmp with random name, and after linking they just simply remove it.
Can I change this to other directory, not changing to random name, and not to removing?
https://github.com/rusefi/rusefi/issues/1079
^ Related issue
[help needed] Build files (*.o, etc..) are saved in /tmp?
- AndreyB
- Site Admin
- Posts: 14469
- Joined: Wed Aug 28, 2013 1:28 am
- Location: Jersey City
- Github Username: rusefillc
- Slack: Andrey B
Re: Build files (*.o, etc..) are saved in /tmp?
Please provide much, much more details on what _exactly_ are you doing how _exactly_ since this all sounds so odd.
Very limited telepathic abilities - please post logs & tunes where appropriate - http://rusefi.com/s/questions
Always looking for C/C++/Java/PHP developers! Please help us see https://rusefi.com/s/howtocontribute
Always looking for C/C++/Java/PHP developers! Please help us see https://rusefi.com/s/howtocontribute
Re: Build files (*.o, etc..) are saved in /tmp?
Hi AndreyB, I'm sorry for not explaining my situation exactly.
I resolved this issue, so I'll just post it the ways I resolved.
The reason why object files are saved into /tmp and after linking removes, is caused by LTO options.
So I just add -fno-lto flag for disable it.
Code: Select all
On the Makefile...
...
# Compiler options here.
# yes we have two kinds of EXTRA_*PARAMS so that we can define those in two different places independently
#
ifeq ($(USE_OPT),)
USE_OPT = $(EXTRA_PARAMS) $(EXTRA_2_PARAMS) $(DEBUG_LEVEL_OPT) $(RFLAGS) -fno-lto -fdump-tree-optimized-graph -fomit-frame-pointer -fsingle-precision-constant -fno-inline-functions
endif
# EFI_UNIT_TEST determines if we are running in a unit test (hide things from hw/sim)
# EFI_PROD_CODE determines if we are running on real hardware (hide things from tests/sim)
# EFI_SIMULATOR determines if we are running in the simulator (hide things from hw/tests)
USE_OPT += $(RUSEFI_OPT) -DEFI_UNIT_TEST=0 -DEFI_PROD_CODE=1 -DEFI_SIMULATOR=0
# signalling to libfirmware that we have criticalError() method
USE_OPT += -DWE_HAVE_CRITICAL_ERROR_METHOD -fstack-usage
# C specific options here (added to USE_OPT).
ifeq ($(USE_COPT),)
USE_COPT = -fgnu89-inline -std=gnu99 -Wno-error=implicit-fallthrough -fdump-tree-optimized-graph -fno-devirtualize -fstack-usage
endif
# C++ specific options here (added to USE_OPT).
ifeq ($(USE_CPPOPT),)
USE_CPPOPT = -std=c++20 -Wno-register -fno-rtti -fno-threadsafe-statics -fno-exceptions -fno-use-cxa-atexit -fdump-tree-optimized-graph -fno-devirtualize -fstack-usage -fdump-lang-class
# gcc-10 c++ 20 depricated uses of volatile errors
USE_CPPOPT += -Wno-deprecated
endif
...
# (Comment or remove these lines)
# Enable this if you want link time optimizations (LTO)
# ifeq ($(USE_LTO),)
# ChibiOS has not yet migrated to gcc12 syntax of '-flto' thus some weird code here
#
# drama: in case of 'syntax error near unexpected token' on Windows either comment out the two lines below
# or just more your GCC into a folder without spaces in the path like 'C:\stuff\arm-gcc-12.2'
#
# USE_LTO = no
# USE_OPT += -flto=auto
# endif
...
Code: Select all
ubuntu@DESKTOP-0DMMSRG:~/lab/rusefi/firmware/build/obj$ ls | head
AemXSeriesEgt.cpp.001l.class
AemXSeriesEgt.cpp.252t.optimized
AemXSeriesEgt.cpp.252t.optimized.dot
AemXSeriesEgt.o
AemXSeriesEgt.su
AemXSeriesLambda.cpp.001l.class
AemXSeriesLambda.cpp.252t.optimized
AemXSeriesLambda.cpp.252t.optimized.dot
AemXSeriesLambda.o
AemXSeriesLambda.su