On Thu, Mar 7, 2013 at 3:15 AM, Jakub Jelinek <ja...@redhat.com> wrote:
> Hi!
>
> AFAIK aarch64 libraries are supposed to go into /usr/lib64 etc.
> directories similarly to x86-64 etc., but as aarch64 isn't a true
> multilib target (having two different backends for 32-bit vs. 64-bit code),
> currently gcc -print-multi-os-directory prints . instead of ../lib64.

I think glibc is broken also. So after this change, the build using
the released 2.17 and this new gcc breaks.

Thanks,
Andrew


>
> The following patch fixes that.  As for --disable-multilib purposes
> gcc.c does:
>       /* When --disable-multilib was used but target defines
>          MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
>          with .:: for multiarch configurations) are there just to find
>          multilib_os_dir, so skip them from output.  */
>       if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
>         skip = 1;
> we need to actually emit
> static const char *const multilib_raw[] = {
> ". ;",
> ".:../lib64 ;",
> NULL
> };
> for --disable-multiarch resp.
> static const char *const multilib_raw[] = {
> ". ;",
> ".:../lib64:aarch64-linux-gnu ;",
> NULL
> };
> for --enable-multiarch.  Tested (with cross compiler) configured with
> --target aarch64-linux --enable-languages=c {,--disable-multilib} 
> {,--enable-multarch}
> (all 4 combinations) and output of all
> ./xgcc -B ./ --print-{multiarch,multi-lib,multi-directory,multi-os-directory}
> looks good to me with it (i.e. as before the patch, except
> --print-multi-so-directory prints ../lib64 instead of . previously.
>
> Ok for trunk?
>
> 2013-03-07  Jakub Jelinek  <ja...@redhat.com>
>
>         * config/aarch64/t-aarch64-linux (MULTARCH_DIRNAME): Remove.
>         (MULTILIB_OSDIRNAMES): Set.
>         * genmultilib: If defaultosdirname doesn't start with :: , set
>         defaultosdirname2 instead, clear it and emit two . multilib_raw
>         entries instead of just one.
>
> --- gcc/config/aarch64/t-aarch64-linux.jj       2013-01-11 09:03:10.000000000 
> +0100
> +++ gcc/config/aarch64/t-aarch64-linux  2013-03-07 11:23:07.602568188 +0100
> @@ -22,4 +22,4 @@ LIB1ASMSRC   = aarch64/lib1funcs.asm
>  LIB1ASMFUNCS = _aarch64_sync_cache_range
>
>  AARCH_BE = $(if $(findstring TARGET_BIG_ENDIAN_DEFAULT=1, $(tm_defines)),_be)
> -MULTIARCH_DIRNAME = $(call if_multiarch,aarch64$(AARCH_BE)-linux-gnu)
> +MULTILIB_OSDIRNAMES = .=../lib64$(call 
> if_multiarch,:aarch64$(AARCH_BE)-linux-gnu)
> --- gcc/genmultilib.jj  2013-01-13 13:23:38.000000000 +0100
> +++ gcc/genmultilib     2013-03-07 11:35:22.881982721 +0100
> @@ -267,6 +267,7 @@ fi
>  # names.
>  toosdirnames=
>  defaultosdirname=
> +defaultosdirname2=
>  if [ -n "${multiarch}" ]; then
>    defaultosdirname=::${multiarch}
>  fi
> @@ -280,6 +281,13 @@ if [ -n "${osdirnames}" ]; then
>         if [ -n "${multiarch}" ]; then
>           defaultosdirname=${defaultosdirname}:${multiarch}
>         fi
> +       case "$defaultosdirname" in
> +         ::*) ;;
> +         *)
> +           defaultosdirname2=${defaultosdirname}
> +           defaultosdirname=
> +           ;;
> +       esac
>         shift
>         ;;
>        *=*)
> @@ -352,6 +360,7 @@ for set in ${options}; do
>  done
>  optout=`echo ${optout} | sed -e 's/^ //'`
>  echo "\".${defaultosdirname} ${optout};\","
> +[ -n "${defaultosdirname2}" ] && echo "\".${defaultosdirname2} ${optout};\","
>
>  # This part of code convert an option combination to
>  # its corresponding directory names.
>
>         Jakub

Reply via email to