8301129: Link to debuginfo files should only be made after stripping
Reviewed-by: erikj, ihse
This commit is contained in:
parent
938b409608
commit
c6b3f2dd10
@ -1062,10 +1062,13 @@ define SetupNativeCompilationBody
|
|||||||
$1_DEBUGINFO_FILES := $$($1_SYMBOLS_DIR)/$$($1_NOSUFFIX).debuginfo
|
$1_DEBUGINFO_FILES := $$($1_SYMBOLS_DIR)/$$($1_NOSUFFIX).debuginfo
|
||||||
# Setup the command line creating debuginfo files, to be run after linking.
|
# Setup the command line creating debuginfo files, to be run after linking.
|
||||||
# It cannot be run separately since it updates the original target file
|
# It cannot be run separately since it updates the original target file
|
||||||
|
# Creating the debuglink is done in another command rather than all at once
|
||||||
|
# so we can run it after strip is called, since strip can sometimes mangle the
|
||||||
|
# embedded debuglink, which we want to avoid.
|
||||||
$1_CREATE_DEBUGINFO_CMDS := \
|
$1_CREATE_DEBUGINFO_CMDS := \
|
||||||
$$($1_OBJCOPY) --only-keep-debug $$($1_TARGET) $$($1_DEBUGINFO_FILES) $$(NEWLINE) \
|
$$($1_OBJCOPY) --only-keep-debug $$($1_TARGET) $$($1_DEBUGINFO_FILES) $$(NEWLINE)
|
||||||
$(CD) $$($1_SYMBOLS_DIR) && \
|
$1_CREATE_DEBUGLINK_CMDS := $(CD) $$($1_SYMBOLS_DIR) && \
|
||||||
$$($1_OBJCOPY) --add-gnu-debuglink=$$($1_DEBUGINFO_FILES) $$($1_TARGET)
|
$$($1_OBJCOPY) --add-gnu-debuglink=$$($1_DEBUGINFO_FILES) $$($1_TARGET)
|
||||||
|
|
||||||
else ifeq ($(call isTargetOs, aix), true)
|
else ifeq ($(call isTargetOs, aix), true)
|
||||||
# AIX does not provide the equivalent of OBJCOPY to extract debug symbols,
|
# AIX does not provide the equivalent of OBJCOPY to extract debug symbols,
|
||||||
@ -1194,7 +1197,7 @@ define SetupNativeCompilationBody
|
|||||||
$1_VARDEPS := $$($1_LD) $$($1_SYSROOT_LDFLAGS) $$($1_LDFLAGS) $$($1_EXTRA_LDFLAGS) \
|
$1_VARDEPS := $$($1_LD) $$($1_SYSROOT_LDFLAGS) $$($1_LDFLAGS) $$($1_EXTRA_LDFLAGS) \
|
||||||
$$($1_LIBS) $$($1_EXTRA_LIBS) $$($1_MT) \
|
$$($1_LIBS) $$($1_EXTRA_LIBS) $$($1_MT) \
|
||||||
$$($1_CREATE_DEBUGINFO_CMDS) $$($1_MANIFEST_VERSION) \
|
$$($1_CREATE_DEBUGINFO_CMDS) $$($1_MANIFEST_VERSION) \
|
||||||
$$($1_STRIP_CMD)
|
$$($1_STRIP_CMD) $$($1_CREATE_DEBUGLINK_CMDS)
|
||||||
$1_VARDEPS_FILE := $$(call DependOnVariable, $1_VARDEPS, \
|
$1_VARDEPS_FILE := $$(call DependOnVariable, $1_VARDEPS, \
|
||||||
$$($1_OBJECT_DIR)/$$($1_NOSUFFIX).vardeps)
|
$$($1_OBJECT_DIR)/$$($1_NOSUFFIX).vardeps)
|
||||||
|
|
||||||
@ -1257,6 +1260,7 @@ define SetupNativeCompilationBody
|
|||||||
test "$$$$?" = "1" ; \
|
test "$$$$?" = "1" ; \
|
||||||
$$($1_CREATE_DEBUGINFO_CMDS)
|
$$($1_CREATE_DEBUGINFO_CMDS)
|
||||||
$$($1_STRIP_CMD)
|
$$($1_STRIP_CMD)
|
||||||
|
$$($1_CREATE_DEBUGLINK_CMDS)
|
||||||
ifeq ($(call isBuildOsEnv, windows.wsl2), true)
|
ifeq ($(call isBuildOsEnv, windows.wsl2), true)
|
||||||
$$(CHMOD) +x $$($1_TARGET)
|
$$(CHMOD) +x $$($1_TARGET)
|
||||||
endif
|
endif
|
||||||
@ -1268,6 +1272,7 @@ define SetupNativeCompilationBody
|
|||||||
$$($1_LIBS) $$($1_EXTRA_LIBS)) ; \
|
$$($1_LIBS) $$($1_EXTRA_LIBS)) ; \
|
||||||
$$($1_CREATE_DEBUGINFO_CMDS)
|
$$($1_CREATE_DEBUGINFO_CMDS)
|
||||||
$$($1_STRIP_CMD)
|
$$($1_STRIP_CMD)
|
||||||
|
$$($1_CREATE_DEBUGLINK_CMDS)
|
||||||
endif
|
endif
|
||||||
ifeq ($(call isTargetOs, windows), true)
|
ifeq ($(call isTargetOs, windows), true)
|
||||||
ifneq ($$($1_MANIFEST), )
|
ifneq ($$($1_MANIFEST), )
|
||||||
|
Loading…
Reference in New Issue
Block a user