Message ID | 1445245676-21017-1-git-send-email-patrickdepinguin@gmail.com |
---|---|
State | Superseded |
Headers | show |
On Mon, Oct 19, 2015 at 11:07 AM, Thomas De Schampheleire <patrickdepinguin@gmail.com> wrote: > From: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> > > Currently, following symbolic links are created in both target and > staging directories: > - lib(32|64) --> lib > - usr/lib(32|64) --> lib > > The decision for lib32 or lib64 is based on the target architecture > configuration in buildroot (BR2_ARCH_IS_64). > > In at least one case this is not correct: when building for a Cavium Octeon > III processor using the toolchain from the Cavium Networks SDK, and > specifying -march=octeon3 in BR2_TARGET_OPTIMIZATION, libraries are expected > in directory 'lib32-fp' rather than 'lib32' (likewise for lib64-fp). > > More generally, for external toolchains, the correct symbolic link is > from (usr/)${ARCH_LIB_DIR} to lib. For internal toolchains, current > toolchains always use either lib32 or lib64. > > Fix the problem as follows: > - create a symlink creation helper in toolchain/helpers.mk > - for external toolchains, call these helpers based on ARCH_LIB_DIR > - for internal toolchains, call these helpers based on the existing > fixed lib32/lib64 logic, moved from Makefile into gcc-initial. > > Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> > > --- > v6: rebase only > No feedback on v5, last discussion was on v4, see > http://lists.busybox.net/pipermail/buildroot/2015-July/132978.html Sorry that I forgot to add 'v6' in the subject-prefix.
On Mon, Oct 19, 2015 at 11:07 AM, Thomas De Schampheleire <patrickdepinguin@gmail.com> wrote: > From: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> > > Currently, following symbolic links are created in both target and > staging directories: > - lib(32|64) --> lib > - usr/lib(32|64) --> lib > > The decision for lib32 or lib64 is based on the target architecture > configuration in buildroot (BR2_ARCH_IS_64). > > In at least one case this is not correct: when building for a Cavium Octeon > III processor using the toolchain from the Cavium Networks SDK, and > specifying -march=octeon3 in BR2_TARGET_OPTIMIZATION, libraries are expected > in directory 'lib32-fp' rather than 'lib32' (likewise for lib64-fp). > > More generally, for external toolchains, the correct symbolic link is > from (usr/)${ARCH_LIB_DIR} to lib. For internal toolchains, current > toolchains always use either lib32 or lib64. > > Fix the problem as follows: > - create a symlink creation helper in toolchain/helpers.mk > - for external toolchains, call these helpers based on ARCH_LIB_DIR > - for internal toolchains, call these helpers based on the existing > fixed lib32/lib64 logic, moved from Makefile into gcc-initial. > > Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> > > --- > v6: rebase only > No feedback on v5, last discussion was on v4, see > http://lists.busybox.net/pipermail/buildroot/2015-July/132978.html > v5: > - move internal toolchain logic into gcc-initial.mk > - also silence the internal toolchain link steps with $(Q) > v4: > - merge both helpers into one > - remove the separate target for the internal toolchain and hook into > gcc-initial > - re-add deleted comment about MIPS64/n32 > v3: > - update commit message wrapping > - change dependency on $(BUILD_DIR) to a order-only dependency > v2: > - fix 'lib32-fp' leftover in toolchain-buildroot > - silence commands creating symlink with $(Q) > - fix case where ARCH_LIB_DIR is 'lib' > > Note: in output/staging/usr/ there would still be more directories than I > think are really necessary. This behavior is not changed by this patch, it > was already present before. > For example, with the mentioned Octeon III toolchain, output/staging/usr/ > contains: > bin bin32 bin32-fp bin64-fp, > lib lib32-fp lib64-fp > libexec libexec32 libexec32-fp libexec64-fp > sbin sbin32 sbin32-fp sbin64-fp > > where bin/lib/libexec/sbin seem to be the 64-bit equivalents of > bin32/lib32/libexec32/sbin32. > This is related to the behavior of copy_toolchain_sysroot in > toolchain/helpers.mk. It already attempts to filter out lib32 and lib64, but > does not care about any bin/sbin/libexec directories, nor about such names > as lib32-fp. > As the behavior is not changed by this patch, and as I'm not fully aware > about which directories are really needed in all cases, I am not touching > this area. > --- > Makefile | 10 ---------- > package/gcc/gcc-initial/gcc-initial.mk | 17 +++++++++++++++++ > package/skeleton/skeleton.mk | 2 -- > toolchain/helpers.mk | 13 +++++++++++++ > toolchain/toolchain-external/toolchain-external.mk | 12 ++++++++++++ > 5 files changed, 42 insertions(+), 12 deletions(-) > > diff --git a/Makefile b/Makefile > index dd8959f..eba6ff4 100644 > --- a/Makefile > +++ b/Makefile > @@ -449,20 +449,10 @@ world: target-post-image > $(BUILD_DIR) $(TARGET_DIR) $(HOST_DIR) $(BINARIES_DIR) $(LEGAL_INFO_DIR) $(REDIST_SOURCES_DIR_TARGET) $(REDIST_SOURCES_DIR_HOST): > @mkdir -p $@ > > -# We make a symlink lib32->lib or lib64->lib as appropriate > -# MIPS64/n32 requires lib32 even though it's a 64-bit arch. > -ifeq ($(BR2_ARCH_IS_64)$(BR2_MIPS_NABI32),y) > -LIB_SYMLINK = lib64 > -else > -LIB_SYMLINK = lib32 > -endif > - > $(STAGING_DIR): > @mkdir -p $(STAGING_DIR)/bin > @mkdir -p $(STAGING_DIR)/lib > - @ln -snf lib $(STAGING_DIR)/$(LIB_SYMLINK) > @mkdir -p $(STAGING_DIR)/usr/lib > - @ln -snf lib $(STAGING_DIR)/usr/$(LIB_SYMLINK) > @mkdir -p $(STAGING_DIR)/usr/include > @mkdir -p $(STAGING_DIR)/usr/bin > @ln -snf $(STAGING_DIR) $(BASE_DIR)/staging > diff --git a/package/gcc/gcc-initial/gcc-initial.mk b/package/gcc/gcc-initial/gcc-initial.mk > index c0b5eaf..bd40c7f 100644 > --- a/package/gcc/gcc-initial/gcc-initial.mk > +++ b/package/gcc/gcc-initial/gcc-initial.mk > @@ -63,4 +63,21 @@ HOST_GCC_INITIAL_TOOLCHAIN_WRAPPER_ARGS += $(HOST_GCC_COMMON_TOOLCHAIN_WRAPPER_A > HOST_GCC_INITIAL_POST_BUILD_HOOKS += TOOLCHAIN_BUILD_WRAPPER > HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INSTALL_WRAPPER_AND_SIMPLE_SYMLINKS > > +# The creation of lib32/lib64 symlinks into target and staging directories > +# needs to be done before the C library is installed. Hooking into the libc > +# hooks directly is tricky because there are multiple C libraries supported. > +# Instead, hook into the install step of host-gcc-initial. > +# > +# MIPS64/n32 requires lib32 even though it's a 64-bit arch. > +ifeq ($(BR2_ARCH_IS_64)$(BR2_MIPS_NABI32),y) > +HOST_GCC_INITIAL_LIB_SYMLINK = lib64 > +else > +HOST_GCC_INITIAL_LIB_SYMLINK = lib32 > +endif > +define HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK > + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(STAGING_DIR)) > + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(TARGET_DIR)) > +endef > +HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK > + > $(eval $(host-autotools-package)) > diff --git a/package/skeleton/skeleton.mk b/package/skeleton/skeleton.mk > index 920d3b4..a255c5c 100644 > --- a/package/skeleton/skeleton.mk > +++ b/package/skeleton/skeleton.mk > @@ -38,8 +38,6 @@ define SKELETON_INSTALL_TARGET_CMDS > --chmod=u=rwX,go=rX --exclude .empty --exclude '*~' \ > $(SKELETON_PATH)/ $(TARGET_DIR)/ > $(SKELETON_USR_SYMLINKS_OR_DIRS) > - ln -snf lib $(TARGET_DIR)/$(LIB_SYMLINK) > - ln -snf lib $(TARGET_DIR)/usr/$(LIB_SYMLINK) > $(INSTALL) -m 0644 support/misc/target-dir-warning.txt \ > $(TARGET_DIR_WARNING_FILE) > endef > diff --git a/toolchain/helpers.mk b/toolchain/helpers.mk > index 1452ec6..ed89043 100644 > --- a/toolchain/helpers.mk > +++ b/toolchain/helpers.mk > @@ -1,5 +1,18 @@ > # This Makefile fragment declares toolchain related helper functions. > > +# Create the necessary symlink from (usr/)lib32|lib64|lib32-fp|... to lib > +# In general, for external toolchains, the correct link name is $ARCH_LIB_DIR. > +# $1: link name > +# $2: destination directory (TARGET_DIR / STAGING_DIR) > +create_lib_symlinks = \ > + LIB_SYMLINK="$(strip $1)" ; \ > + DESTDIR="$(strip $2)" ; \ > + if [ "$${LIB_SYMLINK}" != "lib" ]; then \ > + mkdir -p "$${DESTDIR}/usr" ; \ > + ln -snf lib "$${DESTDIR}/$${LIB_SYMLINK}" ; \ > + ln -snf lib "$${DESTDIR}/usr/$${LIB_SYMLINK}" ; \ > + fi > + > # The copy_toolchain_lib_root function copies a toolchain library and > # its symbolic links from the sysroot directory to the target > # directory. Note that this function is used both by the external > diff --git a/toolchain/toolchain-external/toolchain-external.mk b/toolchain/toolchain-external/toolchain-external.mk > index 4e12a1c..2a224de 100644 > --- a/toolchain/toolchain-external/toolchain-external.mk > +++ b/toolchain/toolchain-external/toolchain-external.mk > @@ -655,6 +655,16 @@ define TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS > $(call copy_toolchain_sysroot,$${SYSROOT_DIR},$${ARCH_SYSROOT_DIR},$${ARCH_SUBDIR},$${ARCH_LIB_DIR},$${SUPPORT_LIB_DIR}) > endef > > +define TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK > + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ > + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(STAGING_DIR)) > +endef > + > +define TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK > + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ > + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(TARGET_DIR)) > +endef > + > # Special installation target used on the Blackfin architecture when > # FDPIC is not the primary binary format being used, but the user has > # nonetheless requested the installation of the FDPIC libraries to the > @@ -769,6 +779,7 @@ endef > TOOLCHAIN_EXTERNAL_BUILD_CMDS = $(TOOLCHAIN_BUILD_WRAPPER) > > define TOOLCHAIN_EXTERNAL_INSTALL_STAGING_CMDS > + $(TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK) > $(TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS) > $(TOOLCHAIN_EXTERNAL_INSTALL_WRAPPER) > $(TOOLCHAIN_EXTERNAL_INSTALL_GDBINIT) > @@ -778,6 +789,7 @@ endef > # and the target directory, we do everything within the > # install-staging step, arbitrarily. > define TOOLCHAIN_EXTERNAL_INSTALL_TARGET_CMDS > + $(TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK) > $(TOOLCHAIN_EXTERNAL_INSTALL_TARGET_LIBS) > $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FDPIC) > $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FLAT) > -- > 1.9.5 > Bump (I realize that patches on toolchain/ are not very sexy, but still I think they are relevant)
On Wed, Nov 4, 2015 at 10:50 AM, Thomas De Schampheleire <patrickdepinguin@gmail.com> wrote: > On Mon, Oct 19, 2015 at 11:07 AM, Thomas De Schampheleire > <patrickdepinguin@gmail.com> wrote: >> From: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> >> >> Currently, following symbolic links are created in both target and >> staging directories: >> - lib(32|64) --> lib >> - usr/lib(32|64) --> lib >> >> The decision for lib32 or lib64 is based on the target architecture >> configuration in buildroot (BR2_ARCH_IS_64). >> >> In at least one case this is not correct: when building for a Cavium Octeon >> III processor using the toolchain from the Cavium Networks SDK, and >> specifying -march=octeon3 in BR2_TARGET_OPTIMIZATION, libraries are expected >> in directory 'lib32-fp' rather than 'lib32' (likewise for lib64-fp). >> >> More generally, for external toolchains, the correct symbolic link is >> from (usr/)${ARCH_LIB_DIR} to lib. For internal toolchains, current >> toolchains always use either lib32 or lib64. >> >> Fix the problem as follows: >> - create a symlink creation helper in toolchain/helpers.mk >> - for external toolchains, call these helpers based on ARCH_LIB_DIR >> - for internal toolchains, call these helpers based on the existing >> fixed lib32/lib64 logic, moved from Makefile into gcc-initial. >> >> Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> >> >> --- >> v6: rebase only >> No feedback on v5, last discussion was on v4, see >> http://lists.busybox.net/pipermail/buildroot/2015-July/132978.html >> v5: >> - move internal toolchain logic into gcc-initial.mk >> - also silence the internal toolchain link steps with $(Q) >> v4: >> - merge both helpers into one >> - remove the separate target for the internal toolchain and hook into >> gcc-initial >> - re-add deleted comment about MIPS64/n32 >> v3: >> - update commit message wrapping >> - change dependency on $(BUILD_DIR) to a order-only dependency >> v2: >> - fix 'lib32-fp' leftover in toolchain-buildroot >> - silence commands creating symlink with $(Q) >> - fix case where ARCH_LIB_DIR is 'lib' >> >> Note: in output/staging/usr/ there would still be more directories than I >> think are really necessary. This behavior is not changed by this patch, it >> was already present before. >> For example, with the mentioned Octeon III toolchain, output/staging/usr/ >> contains: >> bin bin32 bin32-fp bin64-fp, >> lib lib32-fp lib64-fp >> libexec libexec32 libexec32-fp libexec64-fp >> sbin sbin32 sbin32-fp sbin64-fp >> >> where bin/lib/libexec/sbin seem to be the 64-bit equivalents of >> bin32/lib32/libexec32/sbin32. >> This is related to the behavior of copy_toolchain_sysroot in >> toolchain/helpers.mk. It already attempts to filter out lib32 and lib64, but >> does not care about any bin/sbin/libexec directories, nor about such names >> as lib32-fp. >> As the behavior is not changed by this patch, and as I'm not fully aware >> about which directories are really needed in all cases, I am not touching >> this area. >> --- >> Makefile | 10 ---------- >> package/gcc/gcc-initial/gcc-initial.mk | 17 +++++++++++++++++ >> package/skeleton/skeleton.mk | 2 -- >> toolchain/helpers.mk | 13 +++++++++++++ >> toolchain/toolchain-external/toolchain-external.mk | 12 ++++++++++++ >> 5 files changed, 42 insertions(+), 12 deletions(-) >> >> diff --git a/Makefile b/Makefile >> index dd8959f..eba6ff4 100644 >> --- a/Makefile >> +++ b/Makefile >> @@ -449,20 +449,10 @@ world: target-post-image >> $(BUILD_DIR) $(TARGET_DIR) $(HOST_DIR) $(BINARIES_DIR) $(LEGAL_INFO_DIR) $(REDIST_SOURCES_DIR_TARGET) $(REDIST_SOURCES_DIR_HOST): >> @mkdir -p $@ >> >> -# We make a symlink lib32->lib or lib64->lib as appropriate >> -# MIPS64/n32 requires lib32 even though it's a 64-bit arch. >> -ifeq ($(BR2_ARCH_IS_64)$(BR2_MIPS_NABI32),y) >> -LIB_SYMLINK = lib64 >> -else >> -LIB_SYMLINK = lib32 >> -endif >> - >> $(STAGING_DIR): >> @mkdir -p $(STAGING_DIR)/bin >> @mkdir -p $(STAGING_DIR)/lib >> - @ln -snf lib $(STAGING_DIR)/$(LIB_SYMLINK) >> @mkdir -p $(STAGING_DIR)/usr/lib >> - @ln -snf lib $(STAGING_DIR)/usr/$(LIB_SYMLINK) >> @mkdir -p $(STAGING_DIR)/usr/include >> @mkdir -p $(STAGING_DIR)/usr/bin >> @ln -snf $(STAGING_DIR) $(BASE_DIR)/staging >> diff --git a/package/gcc/gcc-initial/gcc-initial.mk b/package/gcc/gcc-initial/gcc-initial.mk >> index c0b5eaf..bd40c7f 100644 >> --- a/package/gcc/gcc-initial/gcc-initial.mk >> +++ b/package/gcc/gcc-initial/gcc-initial.mk >> @@ -63,4 +63,21 @@ HOST_GCC_INITIAL_TOOLCHAIN_WRAPPER_ARGS += $(HOST_GCC_COMMON_TOOLCHAIN_WRAPPER_A >> HOST_GCC_INITIAL_POST_BUILD_HOOKS += TOOLCHAIN_BUILD_WRAPPER >> HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INSTALL_WRAPPER_AND_SIMPLE_SYMLINKS >> >> +# The creation of lib32/lib64 symlinks into target and staging directories >> +# needs to be done before the C library is installed. Hooking into the libc >> +# hooks directly is tricky because there are multiple C libraries supported. >> +# Instead, hook into the install step of host-gcc-initial. >> +# >> +# MIPS64/n32 requires lib32 even though it's a 64-bit arch. >> +ifeq ($(BR2_ARCH_IS_64)$(BR2_MIPS_NABI32),y) >> +HOST_GCC_INITIAL_LIB_SYMLINK = lib64 >> +else >> +HOST_GCC_INITIAL_LIB_SYMLINK = lib32 >> +endif >> +define HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK >> + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(STAGING_DIR)) >> + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(TARGET_DIR)) >> +endef >> +HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK >> + >> $(eval $(host-autotools-package)) >> diff --git a/package/skeleton/skeleton.mk b/package/skeleton/skeleton.mk >> index 920d3b4..a255c5c 100644 >> --- a/package/skeleton/skeleton.mk >> +++ b/package/skeleton/skeleton.mk >> @@ -38,8 +38,6 @@ define SKELETON_INSTALL_TARGET_CMDS >> --chmod=u=rwX,go=rX --exclude .empty --exclude '*~' \ >> $(SKELETON_PATH)/ $(TARGET_DIR)/ >> $(SKELETON_USR_SYMLINKS_OR_DIRS) >> - ln -snf lib $(TARGET_DIR)/$(LIB_SYMLINK) >> - ln -snf lib $(TARGET_DIR)/usr/$(LIB_SYMLINK) >> $(INSTALL) -m 0644 support/misc/target-dir-warning.txt \ >> $(TARGET_DIR_WARNING_FILE) >> endef >> diff --git a/toolchain/helpers.mk b/toolchain/helpers.mk >> index 1452ec6..ed89043 100644 >> --- a/toolchain/helpers.mk >> +++ b/toolchain/helpers.mk >> @@ -1,5 +1,18 @@ >> # This Makefile fragment declares toolchain related helper functions. >> >> +# Create the necessary symlink from (usr/)lib32|lib64|lib32-fp|... to lib >> +# In general, for external toolchains, the correct link name is $ARCH_LIB_DIR. >> +# $1: link name >> +# $2: destination directory (TARGET_DIR / STAGING_DIR) >> +create_lib_symlinks = \ >> + LIB_SYMLINK="$(strip $1)" ; \ >> + DESTDIR="$(strip $2)" ; \ >> + if [ "$${LIB_SYMLINK}" != "lib" ]; then \ >> + mkdir -p "$${DESTDIR}/usr" ; \ >> + ln -snf lib "$${DESTDIR}/$${LIB_SYMLINK}" ; \ >> + ln -snf lib "$${DESTDIR}/usr/$${LIB_SYMLINK}" ; \ >> + fi >> + >> # The copy_toolchain_lib_root function copies a toolchain library and >> # its symbolic links from the sysroot directory to the target >> # directory. Note that this function is used both by the external >> diff --git a/toolchain/toolchain-external/toolchain-external.mk b/toolchain/toolchain-external/toolchain-external.mk >> index 4e12a1c..2a224de 100644 >> --- a/toolchain/toolchain-external/toolchain-external.mk >> +++ b/toolchain/toolchain-external/toolchain-external.mk >> @@ -655,6 +655,16 @@ define TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS >> $(call copy_toolchain_sysroot,$${SYSROOT_DIR},$${ARCH_SYSROOT_DIR},$${ARCH_SUBDIR},$${ARCH_LIB_DIR},$${SUPPORT_LIB_DIR}) >> endef >> >> +define TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK >> + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ >> + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(STAGING_DIR)) >> +endef >> + >> +define TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK >> + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ >> + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(TARGET_DIR)) >> +endef >> + >> # Special installation target used on the Blackfin architecture when >> # FDPIC is not the primary binary format being used, but the user has >> # nonetheless requested the installation of the FDPIC libraries to the >> @@ -769,6 +779,7 @@ endef >> TOOLCHAIN_EXTERNAL_BUILD_CMDS = $(TOOLCHAIN_BUILD_WRAPPER) >> >> define TOOLCHAIN_EXTERNAL_INSTALL_STAGING_CMDS >> + $(TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK) >> $(TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS) >> $(TOOLCHAIN_EXTERNAL_INSTALL_WRAPPER) >> $(TOOLCHAIN_EXTERNAL_INSTALL_GDBINIT) >> @@ -778,6 +789,7 @@ endef >> # and the target directory, we do everything within the >> # install-staging step, arbitrarily. >> define TOOLCHAIN_EXTERNAL_INSTALL_TARGET_CMDS >> + $(TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK) >> $(TOOLCHAIN_EXTERNAL_INSTALL_TARGET_LIBS) >> $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FDPIC) >> $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FLAT) >> -- >> 1.9.5 >> > > Bump (I realize that patches on toolchain/ are not very sexy, but > still I think they are relevant) Bump
Hi Thomas, On 19-10-15 11:07, Thomas De Schampheleire wrote: > From: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> > > Currently, following symbolic links are created in both target and > staging directories: > - lib(32|64) --> lib > - usr/lib(32|64) --> lib > > The decision for lib32 or lib64 is based on the target architecture > configuration in buildroot (BR2_ARCH_IS_64). > > In at least one case this is not correct: when building for a Cavium Octeon > III processor using the toolchain from the Cavium Networks SDK, and > specifying -march=octeon3 in BR2_TARGET_OPTIMIZATION, libraries are expected > in directory 'lib32-fp' rather than 'lib32' (likewise for lib64-fp). > > More generally, for external toolchains, the correct symbolic link is > from (usr/)${ARCH_LIB_DIR} to lib. For internal toolchains, current > toolchains always use either lib32 or lib64. Sorry, it's not OK (yet). The reason we add the lib32 and lib64 symlinks for the internal toolchain as well is because there are some slightly broken packages that expect these directories to exist. With this patch, the symlink is no longer created for some external toolchains, e.g. musl. Unfortunately, I'm not sure which packages are problematic. A quick search through the archives points at libatomic_ops as a candidate. So I think the solution is to keep on creating the symlink like is done now, and just check if ${ARCH_LIB_DIR} exists for the external toolchains. Some minor coding style comments below (some of them probably not relevant anymore). > > Fix the problem as follows: > - create a symlink creation helper in toolchain/helpers.mk > - for external toolchains, call these helpers based on ARCH_LIB_DIR > - for internal toolchains, call these helpers based on the existing > fixed lib32/lib64 logic, moved from Makefile into gcc-initial. > > Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> [snip] > diff --git a/package/gcc/gcc-initial/gcc-initial.mk b/package/gcc/gcc-initial/gcc-initial.mk > index c0b5eaf..bd40c7f 100644 > --- a/package/gcc/gcc-initial/gcc-initial.mk > +++ b/package/gcc/gcc-initial/gcc-initial.mk > @@ -63,4 +63,21 @@ HOST_GCC_INITIAL_TOOLCHAIN_WRAPPER_ARGS += $(HOST_GCC_COMMON_TOOLCHAIN_WRAPPER_A > HOST_GCC_INITIAL_POST_BUILD_HOOKS += TOOLCHAIN_BUILD_WRAPPER > HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INSTALL_WRAPPER_AND_SIMPLE_SYMLINKS > > +# The creation of lib32/lib64 symlinks into target and staging directories > +# needs to be done before the C library is installed. Hooking into the libc > +# hooks directly is tricky because there are multiple C libraries supported. > +# Instead, hook into the install step of host-gcc-initial. > +# > +# MIPS64/n32 requires lib32 even though it's a 64-bit arch. > +ifeq ($(BR2_ARCH_IS_64)$(BR2_MIPS_NABI32),y) > +HOST_GCC_INITIAL_LIB_SYMLINK = lib64 > +else > +HOST_GCC_INITIAL_LIB_SYMLINK = lib32 > +endif > +define HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK > + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(STAGING_DIR)) > + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(TARGET_DIR)) It's simpler and clearer IMHO to create the symlinks here directly (it's just two ln -s calls after all). > +endef > +HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK > + > $(eval $(host-autotools-package)) > diff --git a/package/skeleton/skeleton.mk b/package/skeleton/skeleton.mk > index 920d3b4..a255c5c 100644 > --- a/package/skeleton/skeleton.mk > +++ b/package/skeleton/skeleton.mk > @@ -38,8 +38,6 @@ define SKELETON_INSTALL_TARGET_CMDS > --chmod=u=rwX,go=rX --exclude .empty --exclude '*~' \ > $(SKELETON_PATH)/ $(TARGET_DIR)/ > $(SKELETON_USR_SYMLINKS_OR_DIRS) > - ln -snf lib $(TARGET_DIR)/$(LIB_SYMLINK) > - ln -snf lib $(TARGET_DIR)/usr/$(LIB_SYMLINK) > $(INSTALL) -m 0644 support/misc/target-dir-warning.txt \ > $(TARGET_DIR_WARNING_FILE) > endef > diff --git a/toolchain/helpers.mk b/toolchain/helpers.mk > index 1452ec6..ed89043 100644 > --- a/toolchain/helpers.mk > +++ b/toolchain/helpers.mk > @@ -1,5 +1,18 @@ > # This Makefile fragment declares toolchain related helper functions. > > +# Create the necessary symlink from (usr/)lib32|lib64|lib32-fp|... to lib > +# In general, for external toolchains, the correct link name is $ARCH_LIB_DIR. > +# $1: link name > +# $2: destination directory (TARGET_DIR / STAGING_DIR) > +create_lib_symlinks = \ > + LIB_SYMLINK="$(strip $1)" ; \ > + DESTDIR="$(strip $2)" ; \ > + if [ "$${LIB_SYMLINK}" != "lib" ]; then \ > + mkdir -p "$${DESTDIR}/usr" ; \ > + ln -snf lib "$${DESTDIR}/$${LIB_SYMLINK}" ; \ > + ln -snf lib "$${DESTDIR}/usr/$${LIB_SYMLINK}" ; \ > + fi > + > # The copy_toolchain_lib_root function copies a toolchain library and > # its symbolic links from the sysroot directory to the target > # directory. Note that this function is used both by the external > diff --git a/toolchain/toolchain-external/toolchain-external.mk b/toolchain/toolchain-external/toolchain-external.mk > index 4e12a1c..2a224de 100644 > --- a/toolchain/toolchain-external/toolchain-external.mk > +++ b/toolchain/toolchain-external/toolchain-external.mk > @@ -655,6 +655,16 @@ define TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS > $(call copy_toolchain_sysroot,$${SYSROOT_DIR},$${ARCH_SYSROOT_DIR},$${ARCH_SUBDIR},$${ARCH_LIB_DIR},$${SUPPORT_LIB_DIR}) > endef > > +define TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK > + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ If gcc doesn't call create_lib_symlinks anymore, this can be part of that function. Regards, Arnout > + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(STAGING_DIR)) > +endef > + > +define TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK > + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ > + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(TARGET_DIR)) > +endef > + > # Special installation target used on the Blackfin architecture when > # FDPIC is not the primary binary format being used, but the user has > # nonetheless requested the installation of the FDPIC libraries to the > @@ -769,6 +779,7 @@ endef > TOOLCHAIN_EXTERNAL_BUILD_CMDS = $(TOOLCHAIN_BUILD_WRAPPER) > > define TOOLCHAIN_EXTERNAL_INSTALL_STAGING_CMDS > + $(TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK) > $(TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS) > $(TOOLCHAIN_EXTERNAL_INSTALL_WRAPPER) > $(TOOLCHAIN_EXTERNAL_INSTALL_GDBINIT) > @@ -778,6 +789,7 @@ endef > # and the target directory, we do everything within the > # install-staging step, arbitrarily. > define TOOLCHAIN_EXTERNAL_INSTALL_TARGET_CMDS > + $(TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK) > $(TOOLCHAIN_EXTERNAL_INSTALL_TARGET_LIBS) > $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FDPIC) > $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FLAT) >
Hi Arnout, Sorry, I completely missed your reply. Thanks for reviewing. See below... On Mon, Nov 16, 2015 at 10:57 PM, Arnout Vandecappelle <arnout@mind.be> wrote: > Hi Thomas, > > On 19-10-15 11:07, Thomas De Schampheleire wrote: >> From: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> >> >> Currently, following symbolic links are created in both target and >> staging directories: >> - lib(32|64) --> lib >> - usr/lib(32|64) --> lib >> >> The decision for lib32 or lib64 is based on the target architecture >> configuration in buildroot (BR2_ARCH_IS_64). >> >> In at least one case this is not correct: when building for a Cavium Octeon >> III processor using the toolchain from the Cavium Networks SDK, and >> specifying -march=octeon3 in BR2_TARGET_OPTIMIZATION, libraries are expected >> in directory 'lib32-fp' rather than 'lib32' (likewise for lib64-fp). >> >> More generally, for external toolchains, the correct symbolic link is >> from (usr/)${ARCH_LIB_DIR} to lib. For internal toolchains, current >> toolchains always use either lib32 or lib64. > > Sorry, it's not OK (yet). The reason we add the lib32 and lib64 symlinks for > the internal toolchain as well is because there are some slightly broken > packages that expect these directories to exist. With this patch, the symlink is > no longer created for some external toolchains, e.g. musl. Unfortunately, I'm > not sure which packages are problematic. A quick search through the archives > points at libatomic_ops as a candidate. Did you mean 'external' instead of 'internal' in the second sentence of this paragraph? For internal toolchains, the lib32 or lib64 symlink is always created, with and without this patch. Agreed? For external toolchains, if ARCH_LIB_DIR == 'lib', previously symbolic links lib32 or lib64 would be created anyhow, but with this patch they are not. I guess this is the case you refer to? > > So I think the solution is to keep on creating the symlink like is done now, > and just check if ${ARCH_LIB_DIR} exists for the external toolchains. You mean to create a lib32/lib64 symlink as before, and additionally a link '${ARCH_LIB_DIR} -> lib' in case ARCH_LIB_DIR is different from 'lib32' and 'lib64', right? Thanks, Thomas
On 21-12-15 14:29, Thomas De Schampheleire wrote: > Hi Arnout, > > Sorry, I completely missed your reply. Thanks for reviewing. See below... > > On Mon, Nov 16, 2015 at 10:57 PM, Arnout Vandecappelle <arnout@mind.be> wrote: >> Hi Thomas, >> >> On 19-10-15 11:07, Thomas De Schampheleire wrote: >>> From: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> >>> >>> Currently, following symbolic links are created in both target and >>> staging directories: >>> - lib(32|64) --> lib >>> - usr/lib(32|64) --> lib >>> >>> The decision for lib32 or lib64 is based on the target architecture >>> configuration in buildroot (BR2_ARCH_IS_64). >>> >>> In at least one case this is not correct: when building for a Cavium Octeon >>> III processor using the toolchain from the Cavium Networks SDK, and >>> specifying -march=octeon3 in BR2_TARGET_OPTIMIZATION, libraries are expected >>> in directory 'lib32-fp' rather than 'lib32' (likewise for lib64-fp). >>> >>> More generally, for external toolchains, the correct symbolic link is >>> from (usr/)${ARCH_LIB_DIR} to lib. For internal toolchains, current >>> toolchains always use either lib32 or lib64. >> >> Sorry, it's not OK (yet). The reason we add the lib32 and lib64 symlinks for >> the internal toolchain as well is because there are some slightly broken >> packages that expect these directories to exist. With this patch, the symlink is >> no longer created for some external toolchains, e.g. musl. Unfortunately, I'm >> not sure which packages are problematic. A quick search through the archives >> points at libatomic_ops as a candidate. > > Did you mean 'external' instead of 'internal' in the second sentence > of this paragraph? No, I meant external. But I agree that my explanation wasn't very clear. > > For internal toolchains, the lib32 or lib64 symlink is always created, > with and without this patch. Agreed? For internal toolchains, things are still OK with your patch. > > For external toolchains, if ARCH_LIB_DIR == 'lib', previously symbolic > links lib32 or lib64 would be created anyhow, but with this patch they > are not. I guess this is the case you refer to? Exactly, and for example external musl toolchains are in this situation. > >> >> So I think the solution is to keep on creating the symlink like is done now, >> and just check if ${ARCH_LIB_DIR} exists for the external toolchains. > > You mean to create a lib32/lib64 symlink as before, and additionally a > link '${ARCH_LIB_DIR} -> lib' in case ARCH_LIB_DIR is different from > 'lib32' and 'lib64', right? Yep. Though it probably will make things even uglier. Regards, Arnout > > Thanks, > Thomas >
Hi Arnout, On Mon, Dec 28, 2015 at 11:08 PM, Arnout Vandecappelle <arnout@mind.be> wrote: > On 21-12-15 14:29, Thomas De Schampheleire wrote: >> Hi Arnout, >> >> Sorry, I completely missed your reply. Thanks for reviewing. See below... >> >> On Mon, Nov 16, 2015 at 10:57 PM, Arnout Vandecappelle <arnout@mind.be> wrote: >>> Hi Thomas, >>> >>> On 19-10-15 11:07, Thomas De Schampheleire wrote: >>>> From: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com> >>>> >>>> Currently, following symbolic links are created in both target and >>>> staging directories: >>>> - lib(32|64) --> lib >>>> - usr/lib(32|64) --> lib >>>> >>>> The decision for lib32 or lib64 is based on the target architecture >>>> configuration in buildroot (BR2_ARCH_IS_64). >>>> >>>> In at least one case this is not correct: when building for a Cavium Octeon >>>> III processor using the toolchain from the Cavium Networks SDK, and >>>> specifying -march=octeon3 in BR2_TARGET_OPTIMIZATION, libraries are expected >>>> in directory 'lib32-fp' rather than 'lib32' (likewise for lib64-fp). >>>> >>>> More generally, for external toolchains, the correct symbolic link is >>>> from (usr/)${ARCH_LIB_DIR} to lib. For internal toolchains, current >>>> toolchains always use either lib32 or lib64. >>> >>> Sorry, it's not OK (yet). The reason we add the lib32 and lib64 symlinks for >>> the internal toolchain as well is because there are some slightly broken >>> packages that expect these directories to exist. With this patch, the symlink is >>> no longer created for some external toolchains, e.g. musl. Unfortunately, I'm >>> not sure which packages are problematic. A quick search through the archives >>> points at libatomic_ops as a candidate. >> >> Did you mean 'external' instead of 'internal' in the second sentence >> of this paragraph? > > No, I meant external. But I agree that my explanation wasn't very clear. > >> >> For internal toolchains, the lib32 or lib64 symlink is always created, >> with and without this patch. Agreed? > > For internal toolchains, things are still OK with your patch. > >> >> For external toolchains, if ARCH_LIB_DIR == 'lib', previously symbolic >> links lib32 or lib64 would be created anyhow, but with this patch they >> are not. I guess this is the case you refer to? > > Exactly, and for example external musl toolchains are in this situation. > >> >>> >>> So I think the solution is to keep on creating the symlink like is done now, >>> and just check if ${ARCH_LIB_DIR} exists for the external toolchains. >> >> You mean to create a lib32/lib64 symlink as before, and additionally a >> link '${ARCH_LIB_DIR} -> lib' in case ARCH_LIB_DIR is different from >> 'lib32' and 'lib64', right? > > Yep. Though it probably will make things even uglier. Thanks for clarifying. I think these comments are addressed in v9: http://patchwork.ozlabs.org/patch/560003/ Care to review? Thanks a lot, Thomas
diff --git a/Makefile b/Makefile index dd8959f..eba6ff4 100644 --- a/Makefile +++ b/Makefile @@ -449,20 +449,10 @@ world: target-post-image $(BUILD_DIR) $(TARGET_DIR) $(HOST_DIR) $(BINARIES_DIR) $(LEGAL_INFO_DIR) $(REDIST_SOURCES_DIR_TARGET) $(REDIST_SOURCES_DIR_HOST): @mkdir -p $@ -# We make a symlink lib32->lib or lib64->lib as appropriate -# MIPS64/n32 requires lib32 even though it's a 64-bit arch. -ifeq ($(BR2_ARCH_IS_64)$(BR2_MIPS_NABI32),y) -LIB_SYMLINK = lib64 -else -LIB_SYMLINK = lib32 -endif - $(STAGING_DIR): @mkdir -p $(STAGING_DIR)/bin @mkdir -p $(STAGING_DIR)/lib - @ln -snf lib $(STAGING_DIR)/$(LIB_SYMLINK) @mkdir -p $(STAGING_DIR)/usr/lib - @ln -snf lib $(STAGING_DIR)/usr/$(LIB_SYMLINK) @mkdir -p $(STAGING_DIR)/usr/include @mkdir -p $(STAGING_DIR)/usr/bin @ln -snf $(STAGING_DIR) $(BASE_DIR)/staging diff --git a/package/gcc/gcc-initial/gcc-initial.mk b/package/gcc/gcc-initial/gcc-initial.mk index c0b5eaf..bd40c7f 100644 --- a/package/gcc/gcc-initial/gcc-initial.mk +++ b/package/gcc/gcc-initial/gcc-initial.mk @@ -63,4 +63,21 @@ HOST_GCC_INITIAL_TOOLCHAIN_WRAPPER_ARGS += $(HOST_GCC_COMMON_TOOLCHAIN_WRAPPER_A HOST_GCC_INITIAL_POST_BUILD_HOOKS += TOOLCHAIN_BUILD_WRAPPER HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INSTALL_WRAPPER_AND_SIMPLE_SYMLINKS +# The creation of lib32/lib64 symlinks into target and staging directories +# needs to be done before the C library is installed. Hooking into the libc +# hooks directly is tricky because there are multiple C libraries supported. +# Instead, hook into the install step of host-gcc-initial. +# +# MIPS64/n32 requires lib32 even though it's a 64-bit arch. +ifeq ($(BR2_ARCH_IS_64)$(BR2_MIPS_NABI32),y) +HOST_GCC_INITIAL_LIB_SYMLINK = lib64 +else +HOST_GCC_INITIAL_LIB_SYMLINK = lib32 +endif +define HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(STAGING_DIR)) + $(Q)$(call create_lib_symlinks,$(HOST_GCC_INITIAL_LIB_SYMLINK),$(TARGET_DIR)) +endef +HOST_GCC_INITIAL_POST_INSTALL_HOOKS += HOST_GCC_INITIAL_CREATE_STAGING_TARGET_SYMLINK + $(eval $(host-autotools-package)) diff --git a/package/skeleton/skeleton.mk b/package/skeleton/skeleton.mk index 920d3b4..a255c5c 100644 --- a/package/skeleton/skeleton.mk +++ b/package/skeleton/skeleton.mk @@ -38,8 +38,6 @@ define SKELETON_INSTALL_TARGET_CMDS --chmod=u=rwX,go=rX --exclude .empty --exclude '*~' \ $(SKELETON_PATH)/ $(TARGET_DIR)/ $(SKELETON_USR_SYMLINKS_OR_DIRS) - ln -snf lib $(TARGET_DIR)/$(LIB_SYMLINK) - ln -snf lib $(TARGET_DIR)/usr/$(LIB_SYMLINK) $(INSTALL) -m 0644 support/misc/target-dir-warning.txt \ $(TARGET_DIR_WARNING_FILE) endef diff --git a/toolchain/helpers.mk b/toolchain/helpers.mk index 1452ec6..ed89043 100644 --- a/toolchain/helpers.mk +++ b/toolchain/helpers.mk @@ -1,5 +1,18 @@ # This Makefile fragment declares toolchain related helper functions. +# Create the necessary symlink from (usr/)lib32|lib64|lib32-fp|... to lib +# In general, for external toolchains, the correct link name is $ARCH_LIB_DIR. +# $1: link name +# $2: destination directory (TARGET_DIR / STAGING_DIR) +create_lib_symlinks = \ + LIB_SYMLINK="$(strip $1)" ; \ + DESTDIR="$(strip $2)" ; \ + if [ "$${LIB_SYMLINK}" != "lib" ]; then \ + mkdir -p "$${DESTDIR}/usr" ; \ + ln -snf lib "$${DESTDIR}/$${LIB_SYMLINK}" ; \ + ln -snf lib "$${DESTDIR}/usr/$${LIB_SYMLINK}" ; \ + fi + # The copy_toolchain_lib_root function copies a toolchain library and # its symbolic links from the sysroot directory to the target # directory. Note that this function is used both by the external diff --git a/toolchain/toolchain-external/toolchain-external.mk b/toolchain/toolchain-external/toolchain-external.mk index 4e12a1c..2a224de 100644 --- a/toolchain/toolchain-external/toolchain-external.mk +++ b/toolchain/toolchain-external/toolchain-external.mk @@ -655,6 +655,16 @@ define TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS $(call copy_toolchain_sysroot,$${SYSROOT_DIR},$${ARCH_SYSROOT_DIR},$${ARCH_SUBDIR},$${ARCH_LIB_DIR},$${SUPPORT_LIB_DIR}) endef +define TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(STAGING_DIR)) +endef + +define TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK + $(Q)ARCH_LIB_DIR="$(call toolchain_find_libdir,$(TOOLCHAIN_EXTERNAL_CC) $(TOOLCHAIN_EXTERNAL_CFLAGS))" ; \ + $(call create_lib_symlinks,$${ARCH_LIB_DIR},$(TARGET_DIR)) +endef + # Special installation target used on the Blackfin architecture when # FDPIC is not the primary binary format being used, but the user has # nonetheless requested the installation of the FDPIC libraries to the @@ -769,6 +779,7 @@ endef TOOLCHAIN_EXTERNAL_BUILD_CMDS = $(TOOLCHAIN_BUILD_WRAPPER) define TOOLCHAIN_EXTERNAL_INSTALL_STAGING_CMDS + $(TOOLCHAIN_EXTERNAL_CREATE_STAGING_LIB_SYMLINK) $(TOOLCHAIN_EXTERNAL_INSTALL_SYSROOT_LIBS) $(TOOLCHAIN_EXTERNAL_INSTALL_WRAPPER) $(TOOLCHAIN_EXTERNAL_INSTALL_GDBINIT) @@ -778,6 +789,7 @@ endef # and the target directory, we do everything within the # install-staging step, arbitrarily. define TOOLCHAIN_EXTERNAL_INSTALL_TARGET_CMDS + $(TOOLCHAIN_EXTERNAL_CREATE_TARGET_LIB_SYMLINK) $(TOOLCHAIN_EXTERNAL_INSTALL_TARGET_LIBS) $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FDPIC) $(TOOLCHAIN_EXTERNAL_INSTALL_BFIN_FLAT)