diff options
author | Mike Frysinger <vapier@gentoo.org> | 2021-10-31 03:29:36 -0400 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2021-11-02 22:59:07 -0400 |
commit | 0a129eb19a773d930d60b084209570f663db2053 (patch) | |
tree | c29451f6fe7b9d2ae8ebc071b7a04fb36033973a /sim/cris | |
parent | d2a5dbc744548e173ba1687e1a63a8c2196c7122 (diff) | |
download | gdb-0a129eb19a773d930d60b084209570f663db2053.zip gdb-0a129eb19a773d930d60b084209570f663db2053.tar.gz gdb-0a129eb19a773d930d60b084209570f663db2053.tar.bz2 |
sim: hoist cgen mloop rules up to common builds
These rules don't depend on the target compiler settings, so hoist
the build logic up to the common builds for better parallelization.
We have to extend the genmloop.sh logic a bit to allow outputting
to a subdir since it always assumed cwd was the right place.
We leave the cgen maintainer rules in the subdirs for now as they
aren't normally run, and they rely on cgen logic that has not yet
been generalized.
Diffstat (limited to 'sim/cris')
-rw-r--r-- | sim/cris/Makefile.in | 32 | ||||
-rw-r--r-- | sim/cris/local.mk | 54 |
2 files changed, 55 insertions, 31 deletions
diff --git a/sim/cris/Makefile.in b/sim/cris/Makefile.in index 18dd2f4..8e6bb2e 100644 --- a/sim/cris/Makefile.in +++ b/sim/cris/Makefile.in @@ -66,48 +66,18 @@ CRISV10F_INCLUDE_DEPS = \ $(CGEN_MAIN_CPU_DEPS) \ cpuv10.h decodev10.h engv10.h -# FIXME: What is mono and what does "Use of `mono' is wip" mean (other -# than the apparent; some "mono" feature is work in progress)? -mloopv10f.c engv10.h: stamp-v10fmloop -stamp-v10fmloop: $(srcdir)/../common/genmloop.sh mloop.in Makefile - $(ECHO_STAMP) mloopv10f.c engv10.h - $(SILENCE) $(SHELL) $(srccom)/genmloop.sh -shell $(SHELL) \ - -mono -no-fast -pbb -switch semcrisv10f-switch.c \ - -cpu crisv10f -infile $(srcdir)/mloop.in - $(SILENCE) $(SHELL) $(srcroot)/move-if-change eng.hin engv10.h - $(SILENCE) $(SHELL) $(srcroot)/move-if-change mloop.cin mloopv10f.c - $(SILENCE) touch $@ - # CRISV32 objs CRISV32F_INCLUDE_DEPS = \ $(CGEN_MAIN_CPU_DEPS) \ cpuv32.h decodev32.h engv32.h -# FIXME: What is mono and what does "Use of `mono' is wip" mean (other -# than the apparent; some "mono" feature is work in progress)? -mloopv32f.c engv32.h: stamp-v32fmloop -# We depend on stamp-v10fmloop to get serialization to avoid -# racing with it for the same temporary file-names when "make -j". -stamp-v32fmloop: stamp-v10fmloop $(srcdir)/../common/genmloop.sh mloop.in Makefile - $(ECHO_STAMP) mloopv32f.c engv32.h - $(SILENCE) $(SHELL) $(srccom)/genmloop.sh -shell $(SHELL) \ - -mono -no-fast -pbb -switch semcrisv32f-switch.c \ - -cpu crisv32f -infile $(srcdir)/mloop.in - $(SILENCE) $(SHELL) $(srcroot)/move-if-change eng.hin engv32.h - $(SILENCE) $(SHELL) $(srcroot)/move-if-change mloop.cin mloopv32f.c - $(SILENCE) touch $@ - cris-clean: - for v in 10 32; do \ - rm -f mloopv$${v}f.c engv$${v}.h stamp-v$${v}fmloop; \ - rm -f stamp-v$${v}fcpu; \ - done -rm -f stamp-arch -rm -f tmp-* # Useful when making CGEN-generated files manually, without --enable-cgen-maint. -stamps: stamp-v10fmloop stamp-v32fmloop stamp-arch stamp-v10fcpu stamp-v32fcpu +stamps: stamp-arch stamp-v10fcpu stamp-v32fcpu stamp-arch: $(CGEN_READ_SCM) $(CGEN_ARCH_SCM) $(CPU_DIR)/cris.cpu Makefile $(MAKE) cgen-arch $(CGEN_FLAGS_TO_PASS) mach=crisv10,crisv32 \ diff --git a/sim/cris/local.mk b/sim/cris/local.mk new file mode 100644 index 0000000..c810bcd --- /dev/null +++ b/sim/cris/local.mk @@ -0,0 +1,54 @@ +# See sim/Makefile.am +# +# Copyright (C) 2004-2021 Free Software Foundation, Inc. +# Contributed by Axis Communications. +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + +%C%_BUILD_OUTPUTS = \ + %D%/engv10.h \ + %D%/mloopv10f.c \ + %D%/stamp-mloop-v10f \ + %D%/engv32.h \ + %D%/mloopv32f.c \ + %D%/stamp-mloop-v32f + +# This makes sure build tools are available before building the arch-subdirs. +SIM_ALL_RECURSIVE_DEPS += $(%C%_BUILD_OUTPUTS) + +# FIXME: What is mono and what does "Use of `mono' is wip" mean (other +# than the apparent; some "mono" feature is work in progress)? +%D%/mloopv10f.c %D%/engv10.h: %D%/stamp-mloop-v10f ; @true +%D%/stamp-mloop-v10f: $(srccom)/genmloop.sh %D%/mloop.in + $(AM_V_GEN)$(SHELL) $(srccom)/genmloop.sh -shell $(SHELL) \ + -mono -no-fast -pbb -switch semcrisv10f-switch.c \ + -cpu crisv10f \ + -infile $(srcdir)/%D%/mloop.in -outfile-prefix %D%/ -outfile-suffix -v10f + $(AM_V_at)$(SHELL) $(srcroot)/move-if-change %D%/eng-v10f.hin %D%/engv10.h + $(AM_V_at)$(SHELL) $(srcroot)/move-if-change %D%/mloop-v10f.cin %D%/mloopv10f.c + $(AM_V_at)touch $@ + +# FIXME: What is mono and what does "Use of `mono' is wip" mean (other +# than the apparent; some "mono" feature is work in progress)? +%D%/mloopv32f.c %D%/engv32.h: %D%/stamp-mloop-v32f ; @true +%D%/stamp-mloop-v32f: $(srccom)/genmloop.sh %D%/mloop.in + $(AM_V_GEN)$(SHELL) $(srccom)/genmloop.sh -shell $(SHELL) \ + -mono -no-fast -pbb -switch semcrisv32f-switch.c \ + -cpu crisv32f \ + -infile $(srcdir)/%D%/mloop.in -outfile-prefix %D%/ -outfile-suffix -v32f + $(AM_V_at)$(SHELL) $(srcroot)/move-if-change %D%/eng-v32f.hin %D%/engv32.h + $(AM_V_at)$(SHELL) $(srcroot)/move-if-change %D%/mloop-v32f.cin %D%/mloopv32f.c + $(AM_V_at)touch $@ + +MOSTLYCLEANFILES += $(%C%_BUILD_OUTPUTS) |