Buildroot Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Waldemar Brodkorb <wbx@openadk.org>
To: buildroot@busybox.net
Subject: [Buildroot] [RFC][PATCH] bfin: fix two issues with internal toolchain
Date: Tue, 9 Aug 2016 06:39:09 +0200	[thread overview]
Message-ID: <20160809043909.GR22524@waldemar-brodkorb.de> (raw)
In-Reply-To: <20160805195247.GA11252@waldemar-brodkorb.de>

Hi,
Waldemar Brodkorb wrote,

I think the patch is okay and should be used. But I give up on the
remaining problem for this release. 

I tried all version of binutils from 2.27 down to ADI toolchain
binutils 2.21. It seems not a binutils or linker problem.

I tried to convert the LOCAL symbols with objcopy to GLOBAL, but
the problem persist.

I recognized that the missing symbols in libstdc++.so are NOTYPE,
but in the working external toolchain they are FUNC.

Without help from some Blackfin developer from Analog Devices I see
no chance to fix it right now.

@Thomas: Can you disable C++ for internal Blackfin toolchain?
Thanks.

best regards
 Waldemar

> Allows to compile DWARF EH.
> 
> Signed-off-by: Waldemar Brodkorb <wbx@openadk.org>
> ---
> Hi,
> this is my present work on the Blackfin C++ issues with the internal
> toolchain. There is still following problem:
> $ ./output/host/usr/bin/bfin-buildroot-linux-uclibc-g++ -o foo foo.cc                                                                                                              
> /home/wbx/buildroot/output/host/usr/lib/gcc/bfin-buildroot-linux-uclibc/6.1.0/../../../../bfin-buildroot-linux-uclibc/lib/libstdc++.so:
> undefined reference to `_Unwind_GetRegionStart'
> ..
> $ cat foo.cc                                                                                                                                                                       
> #include <iostream>
> int main(void) { std::cout << "hello, world\n"; }
> 
> But libstdc++ should search for __Unwind_GetRegionStart:
> nm
> /home/wbx/buildroot/output/host/usr/lib/gcc/bfin-buildroot-linux-uclibc/6.1.0/../../../../bfin-buildroot-linux-uclibc/lib/libstdc++.so|grep
> _Unwind_GetRegionStart<
>          U __Unwind_GetRegionStart
> 
> And libgcc_s.so.1 provides it:
> ./output/host/usr/bin/bfin-buildroot-linux-uclibc-nm
> ./output/host/usr/bfin-buildroot-linux-uclibc/sysroot/lib/libgcc_s.so.1|grep
> _Unwind_GetRegionStart                         
> 00005d0c t __Unwind_GetRegionStart
> 
> So why is ld trying to find _Unwind_GetRegionStart instead of
> __Unwind_GetRegionStart when linking?
> Does ld ignores __USER_LABEL_PREFIX__?
> 
> Any ideas and help is really appreciated.
> 
> Here are some g++ verbose output logs from internal and external
> buildroot toolchain:
> http://debug.openadk.org/buildroot/
> 
> ---
>  package/gcc/6.1.0/892-disable-dwarf-bfin.patch     |   24 -------------
>  package/gcc/6.1.0/892-fix-dwarf-fdpic.patch        |   37 ++++++++++++++++++++
>  .../6.1.0/893-bfin-add-libgcc-linker-script.patch  |   20 +++++++++++
>  3 files changed, 57 insertions(+), 24 deletions(-)
>  delete mode 100644 package/gcc/6.1.0/892-disable-dwarf-bfin.patch
>  create mode 100644 package/gcc/6.1.0/892-fix-dwarf-fdpic.patch
>  create mode 100644 package/gcc/6.1.0/893-bfin-add-libgcc-linker-script.patch
> 
> diff --git a/package/gcc/6.1.0/892-disable-dwarf-bfin.patch b/package/gcc/6.1.0/892-disable-dwarf-bfin.patch
> deleted file mode 100644
> index ebd31a1..0000000
> --- a/package/gcc/6.1.0/892-disable-dwarf-bfin.patch
> +++ /dev/null
> @@ -1,24 +0,0 @@
> -Dwarf support does not compile on Blackfin
> -
> -Reported upstream:
> -https://gcc.gnu.org/bugzilla/show_bug.cgi?id=68468
> -
> -Signed-off-by: Waldemar Brodkorb <wbx@openadk.org>
> -
> -diff -Nur gcc-6.1.0.orig/libgcc/config.host gcc-6.1.0/libgcc/config.host
> ---- gcc-6.1.0.orig/libgcc/config.host	2016-02-26 21:02:28.000000000 +0100
> -+++ gcc-6.1.0/libgcc/config.host	2016-05-12 19:26:30.973350274 +0200
> -@@ -230,6 +230,13 @@
> -       ;;
> -   esac
> -   ;;
> -+bfin-*-*linux*)
> -+  tmake_file="$tmake_file t-crtstuff-pic t-libgcc-pic t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver t-linux"
> -+  extra_parts="crtbegin.o crtbeginS.o crtbeginT.o crtend.o crtendS.o"
> -+  if test x$enable_vtable_verify = xyes; then
> -+    extra_parts="$extra_parts vtv_start.o vtv_end.o vtv_start_preinit.o vtv_end_preinit.o"
> -+  fi
> -+  ;;
> - *-*-linux* | frv-*-*linux* | *-*-kfreebsd*-gnu | *-*-knetbsd*-gnu | *-*-gnu* | *-*-kopensolaris*-gnu)
> -   tmake_file="$tmake_file t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver t-linux"
> -   extra_parts="crtbegin.o crtbeginS.o crtbeginT.o crtend.o crtendS.o"
> diff --git a/package/gcc/6.1.0/892-fix-dwarf-fdpic.patch b/package/gcc/6.1.0/892-fix-dwarf-fdpic.patch
> new file mode 100644
> index 0000000..315b406
> --- /dev/null
> +++ b/package/gcc/6.1.0/892-fix-dwarf-fdpic.patch
> @@ -0,0 +1,37 @@
> +Fix DWARF compilation for FDPIC targets
> +
> +Signed-off-by: Waldemar Brodkorb <wbx@openadk.org>
> +
> +diff -Nur gcc-6.1.0.orig/libgcc/unwind-dw2-fde-dip.c gcc-6.1.0/libgcc/unwind-dw2-fde-dip.c
> +--- gcc-6.1.0.orig/libgcc/unwind-dw2-fde-dip.c	2016-01-04 15:30:50.000000000 +0100
> ++++ gcc-6.1.0/libgcc/unwind-dw2-fde-dip.c	2016-08-05 02:17:40.424195128 +0200
> +@@ -124,7 +124,11 @@
> + {
> +   _Unwind_Ptr pc_low;
> +   _Unwind_Ptr pc_high;
> ++#if defined __FRV_FDPIC__ || defined __BFIN_FDPIC__
> ++  struct elf32_fdpic_loadaddr load_base;
> ++#else
> +   _Unwind_Ptr load_base;
> ++#endif
> +   const ElfW(Phdr) *p_eh_frame_hdr;
> +   const ElfW(Phdr) *p_dynamic;
> +   struct frame_hdr_cache_element *link;
> +@@ -163,7 +167,7 @@
> +   struct unw_eh_callback_data *data = (struct unw_eh_callback_data *) ptr;
> +   const ElfW(Phdr) *phdr, *p_eh_frame_hdr, *p_dynamic;
> +   long n, match;
> +-#ifdef __FRV_FDPIC__
> ++#if defined __FRV_FDPIC__ || defined __BFIN_FDPIC__
> +   struct elf32_fdpic_loadaddr load_base;
> + #else
> +   _Unwind_Ptr load_base;
> +@@ -347,7 +351,7 @@
> + 	    break;
> + 	  }
> +     }
> +-# elif defined __FRV_FDPIC__ && defined __linux__
> ++# elif (defined __FRV_FDPIC__ || defined __BFIN_FDPIC__) && defined __linux__
> +   data->dbase = load_base.got_value;
> + # else
> + #  error What is DW_EH_PE_datarel base on this platform?
> diff --git a/package/gcc/6.1.0/893-bfin-add-libgcc-linker-script.patch b/package/gcc/6.1.0/893-bfin-add-libgcc-linker-script.patch
> new file mode 100644
> index 0000000..88548fc
> --- /dev/null
> +++ b/package/gcc/6.1.0/893-bfin-add-libgcc-linker-script.patch
> @@ -0,0 +1,20 @@
> +Add libgcc linker script for Blackfin FDPIC.
> +
> +Solves following linking error:
> +# bfin-openadk-linux-uclibc-g++ -o foo t.c
> +bfin-openadk-linux-uclibc/bin/ld: foo: hidden symbol `___udivsi3' in libgcc.a(_udivsi3.o) is referenced by DSO
> +
> +Signed-off-by: Waldemar Brodkorb <wbx@openadk.org>
> +
> +diff -Nur gcc-6.1.0.orig/libgcc/config.host gcc-6.1.0/libgcc/config.host
> +--- gcc-6.1.0.orig/libgcc/config.host	2016-02-26 21:02:28.000000000 +0100
> ++++ gcc-6.1.0/libgcc/config.host	2016-07-25 02:47:05.818797217 +0200
> +@@ -444,7 +444,7 @@
> + 	md_unwind_header=bfin/linux-unwind.h
> +         ;;
> + bfin*-linux-uclibc*)
> +-	tmake_file="$tmake_file bfin/t-bfin bfin/t-crtstuff t-libgcc-pic t-fdpbit bfin/t-linux"
> ++	tmake_file="$tmake_file bfin/t-bfin bfin/t-crtstuff t-libgcc-pic t-slibgcc-libgcc t-fdpbit bfin/t-linux"
> + 	# No need to build crtbeginT.o on uClibc systems.  Should probably
> + 	# be moved to the OS specific section above.
> + 	extra_parts="crtbegin.o crtbeginS.o crtend.o crtendS.o"
> -- 
> 1.7.10.4
> 
> _______________________________________________
> buildroot mailing list
> buildroot at busybox.net
> http://lists.busybox.net/mailman/listinfo/buildroot
> 

      parent reply	other threads:[~2016-08-09  4:39 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-08-05 19:52 [Buildroot] [RFC][PATCH] bfin: fix two issues with internal toolchain Waldemar Brodkorb
2016-08-05 20:43 ` Thomas Petazzoni
2016-08-05 22:40   ` Waldemar Brodkorb
2016-08-09  4:39 ` Waldemar Brodkorb [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20160809043909.GR22524@waldemar-brodkorb.de \
    --to=wbx@openadk.org \
    --cc=buildroot@busybox.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox