Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/gpl3/gcc/lib/libgcc add support for arm64 lse.S.



details:   https://anonhg.NetBSD.org/src/rev/6605419b7d38
branches:  trunk
changeset: 1020603:6605419b7d38
user:      mrg <mrg%NetBSD.org@localhost>
date:      Sat Apr 17 10:54:46 2021 +0000

description:
add support for arm64 lse.S.

arm64 userland much happier now.  /usr/bin/gcc as gcc 10 on arm64
is fine, build is complete, though i did not test xsrc yet.

diffstat:

 external/gpl3/gcc/lib/libgcc/Makefile.inc    |  42 ++++++++++++++++++++++++++--
 external/gpl3/gcc/lib/libgcc/libgcc/Makefile |   5 ++-
 2 files changed, 42 insertions(+), 5 deletions(-)

diffs (83 lines):

diff -r dd0f81f72a29 -r 6605419b7d38 external/gpl3/gcc/lib/libgcc/Makefile.inc
--- a/external/gpl3/gcc/lib/libgcc/Makefile.inc Sat Apr 17 10:53:18 2021 +0000
+++ b/external/gpl3/gcc/lib/libgcc/Makefile.inc Sat Apr 17 10:54:46 2021 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile.inc,v 1.47 2021/04/12 00:05:55 mrg Exp $
+#      $NetBSD: Makefile.inc,v 1.48 2021/04/17 10:54:46 mrg Exp $
 
 LIBGCC_MACHINE_ARCH?=${MACHINE_ARCH:S/earmv5/earm/}
 GCC_MACHINE_SUBDIR=${MACHINE_CPU:C/powerpc.*/rs6000/:C/x86_64/i386/}
@@ -30,9 +30,11 @@
 .if ${LIBGCC_MACHINE_ARCH} == "powerpc" || \
     ${LIBGCC_MACHINE_ARCH} == "sh3el" || \
     ${LIBGCC_MACHINE_ARCH} == "sh3eb" || \
-    ${LIBGCC_MACHINE_ARCH} == "m68000"
+    ${LIBGCC_MACHINE_ARCH} == "m68000" || \
+    ${LIBGCC_MACHINE_ARCH} == "aarch64" || \
+    ${LIBGCC_MACHINE_ARCH} == "aarch64eb"
 _TRADITIONAL_CPP=
-COMPILE.S=     ${CC} ${AFLAGS} ${CPPFLAGS} -c
+COMPILE.S=     ${CC} ${AFLAGS} ${CPPFLAGS} ${CPPFLAGS.${.IMPSRC:T}} -c 
 .endif
 
 .if ${LIBGCC_MACHINE_ARCH} == "powerpc"
@@ -166,6 +168,40 @@
        printf '#define L${.PREFIX}\n#include <${G_LIB1ASMSRC}>\n' >${.TARGET}
 .endif
 
+.if ${LIB} == "gcc" && \
+    (${LIBGCC_MACHINE_ARCH} == "aarch64" || \
+     ${LIBGCC_MACHINE_ARCH} == "aarch64be") # {
+# XXX lse.S objects are placed directly into "libgcc-objects" for GCC, and
+# are not pulled out by mknative-gcc easily.
+. for s in 1 2 4 8 16
+.  for m in 1 2 3 4
+.   for n in cas
+LSE_NAMES+=                    ${n}_${s}_${m}
+CPPFLAGS.${n}_${s}_${m}+=      -DL_${n} -DSIZE=${s} -DMODEL=${m}
+.   endfor
+.  endfor
+. endfor
+
+. for s in 1 2 4 8
+.  for m in 1 2 3 4
+.   for n in swp ldadd ldclr ldeor ldset
+LSE_NAMES+=                    ${n}_${s}_${m}
+CPPFLAGS.${n}_${s}_${m}+=      -DL_${n} -DSIZE=${s} -DMODEL=${m}
+.   endfor
+.  endfor
+. endfor
+
+LSE_SRC=       ${GNUHOSTDIST}/libgcc/config/aarch64/lse.S
+
+${LSE_NAMES:=.o}: ${LSE_SRC} Makefile
+       ${_MKTARGET_COMPILE}
+       ${COMPILE.S} ${CPPFLAGS.${.TARGET:T:.o=}} -o ${.TARGET} ${LSE_SRC}
+
+# lse-init.c currently compiles to nothing for us
+G_LIB2ADD+=    ${GNUHOSTDIST}/libgcc/config/aarch64/lse-init.c
+
+.endif # } arm64
+
 # Use dynamic sources to arrange for the C file to be the first dependency
 # so ${.IMPSRC} will work.
 
diff -r dd0f81f72a29 -r 6605419b7d38 external/gpl3/gcc/lib/libgcc/libgcc/Makefile
--- a/external/gpl3/gcc/lib/libgcc/libgcc/Makefile      Sat Apr 17 10:53:18 2021 +0000
+++ b/external/gpl3/gcc/lib/libgcc/libgcc/Makefile      Sat Apr 17 10:54:46 2021 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.29 2021/04/12 00:05:55 mrg Exp $
+#      $NetBSD: Makefile,v 1.30 2021/04/17 10:54:46 mrg Exp $
 
 REQUIRETOOLS=  yes
 NOLINT=                # defined
@@ -32,7 +32,8 @@
 SRCS+=         ${LIB2FUNCS} ${LIB2FUNCS_ST} ${LIB2DIVMOD} \
                ${LIB2ADD_EDITED} \
                ${LIB2ADD_HACK:T:S/.asm/.S/} \
-               ${G_LIB2ADD_ST:T} ${LIB1ASMFUNCS}
+               ${G_LIB2ADD_ST:T} ${LIB1ASMFUNCS} \
+               ${LSE_NAMES:=.o}
 .if ${MKPIC} == "no"
 .if empty(LIBGCC_MACHINE_ARCH:Mearm*)
 SRCS+=         ${LIB2_EH} ${LIB2_EHASM}



Home | Main Index | Thread Index | Old Index