Mike Frysinger
9a7472d7c5
sim: igen: simplify build logic a little
...
Now that all ports (that use igen) build in the top-level and depend
on igen, we can move the conditional logic out of configure. We also
switch from noinst_LIBRARIES to EXTRA_LIBRARIES so that the library
is only built when needed (i.e. the igen tool is used).
2023-01-15 02:07:43 -05:00
Mike Frysinger
eaa13962f2
sim: build: drop depdir subdir hack
...
Now that all the ports compile some C files in their arch dirs, Automake
guarantees creating the depdir for us, so we can drop our configure hack.
2023-01-14 21:02:12 -05:00
Mike Frysinger
1b907fc09f
sim: common: simplify modules.c deps
...
Now that all ports (other than ppc) build in the top-level, we don't
need to expand all the modules.c targets as a recursive dep. Each
port depends on their respective file now, and the ppc port doesn't
use it at all.
2023-01-14 21:01:33 -05:00
Mike Frysinger
72be276fff
sim: common: move modules.c to source tracking
...
This makes sure the arch-specific modules.c wildcard is matched and
not the common/%.c so that we compile it correctly. It also makes
sure each subdir has depdir logic enabled.
2023-01-14 20:53:13 -05:00
Mike Frysinger
4df7470704
sim: common: move libcommon.a dep to ppc code
...
Rather than force this to be built ahead of time for all targets,
move the dep to the ppc code since it's the only user of it now.
2023-01-14 20:51:53 -05:00
Mike Frysinger
ee3134d028
sim: build: drop most recursive build deps
...
Now that we build these objects in the top dir & generate modules.c
there, we don't need to generate them all first -- we can let the
normal dependency graph take care of building things in parallel.
2023-01-14 20:50:36 -05:00
Mike Frysinger
eac2fbdc4b
sim: common: move libcommon.a objects to sources
...
This simplifies the build logic and avoids an Automake bug where the
common_libcommon_a_OBJECTS variable isn't set in the arch libsim.a
DEPENDENCIES for targets that, alphabetically, come before "common".
We aren't affected by that bug with the current code, but as we move
things out of SIM_ALL_RECURSIVE_DEPS and rely on finer dependencies,
we will trip over it.
2023-01-14 20:48:49 -05:00
Mike Frysinger
0e7c397dbf
sim: igen: simplify build dep
...
Now that all ports (other than ppc) build in the top-level, we don't
need to mark the igen tool as a recursive dep. Each port depends on
the tool if it actually uses it, and ppc doesn't use it at all.
2023-01-14 20:46:00 -05:00
Mike Frysinger
49444feaef
sim: common: simplify hw-config.h deps
...
Now that all ports (other than ppc) build in the top-level, we don't
need to expand all the hw-config.h targets as a recursive dep. Each
port depends on their respective header now, and the ppc port doesn't
use it at all.
2023-01-14 20:44:40 -05:00
Mike Frysinger
068b723abc
sim: build: drop AM_MAKEFLAGS settings
...
We don't have any recursive builds anymore, so we can drop this logic.
2023-01-14 20:41:24 -05:00
Mike Frysinger
fe0adb538f
sim: build: delete Make-common.in logic
...
Now that all (other than ppc) build in the top-level, this logic is
unused, so punt it all.
2023-01-13 17:34:53 -05:00
Mike Frysinger
6baf06097b
sim: build: drop subdir Makefile.in files
...
These aren't used anymore, so punt them all.
2023-01-11 22:49:28 -05:00
Mike Frysinger
fd95c73ef5
sim: disable recursive make in (most) subdirs
...
Now that all (other than ppc) build in the top-level, we can disable
the recursive make calls to them. This speeds things up nicely.
2023-01-10 01:22:00 -05:00
Mike Frysinger
b014c9b087
sim: common: move test-hw-events to top-level build
...
This is an internal developer target that isn't normally compiled,
but it can still be occasionally useful. Move it to the top-level
build so we can kill off common/Make-common.in.
2023-01-10 01:15:29 -05:00
Mike Frysinger
b36a89d135
sim: move arch-specific file compilation of common/ files to top-level
2023-01-10 01:15:29 -05:00
Mike Frysinger
8f5fc30fcf
sim: v850: move arch-specific file compilation to top-level
...
The arch-specific compiler flags are duplicated, but they'll be cleaned
up once we move all subdir compiles to the top-level.
2023-01-10 01:15:29 -05:00
Mike Frysinger
d667f7b30a
sim: sh: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
3e3e7217b0
sim: rx: move arch-specific file compilation to top-level
...
The arch-specific flags are only used by the arch-specific modules,
not the common/ files, so we can delete them too.
2023-01-10 01:15:28 -05:00
Mike Frysinger
0db0b664a6
sim: rl78: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
e7699de502
sim: riscv: move arch-specific file compilation to top-level
...
The arch-specific compiler flags are duplicated, but they'll be cleaned
up once we move all subdir compiles to the top-level.
2023-01-10 01:15:28 -05:00
Mike Frysinger
51bc8f3a16
sim: pru: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
b7bd5fe99b
sim: or1k: move arch-specific file compilation to top-level
...
The arch-specific compiler flags are duplicated, but they'll be cleaned
up once we move all subdir compiles to the top-level.
2023-01-10 01:15:28 -05:00
Mike Frysinger
4fff443a11
sim: msp430: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
ae0411a485
sim: moxie: move arch-specific file compilation to top-level
...
The arch-specific flags are only used by the arch-specific modules,
not the common/ files, so we can delete them too.
2023-01-10 01:15:28 -05:00
Mike Frysinger
63a9d59e88
sim: mn10300: move arch-specific file compilation to top-level
...
The arch-specific compiler flags are duplicated, but they'll be cleaned
up once we move all subdir compiles to the top-level.
2023-01-10 01:15:28 -05:00
Mike Frysinger
1546cb4540
sim: mips: move arch-specific file compilation to top-level
...
The arch-specific compiler flags are duplicated, but they'll be cleaned
up once we move all subdir compiles to the top-level.
2023-01-10 01:15:28 -05:00
Mike Frysinger
b7375a2dda
sim: microblaze: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
28ae9bed3d
sim: mcore: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
5a71cd470f
sim: m68hc11: move arch-specific file compilation to top-level
...
The arch-specific compiler flags are duplicated, but they'll be cleaned
up once we move all subdir compiles to the top-level.
2023-01-10 01:15:28 -05:00
Mike Frysinger
9b5a17d2be
sim: m32r: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
cd7aa21771
sim: m32c: move arch-specific file compilation to top-level
...
The arch-specific flags are only used by the arch-specific modules,
not the common/ files, so we can delete them too.
2023-01-10 01:15:28 -05:00
Mike Frysinger
2d3b0c959d
sim: lm32: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
d2c06f6bcd
sim: iq2000: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
dced2faff5
sim: h8300: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
abc4c2173c
sim: ft32: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
5ea1eaea7a
sim: frv: move arch-specific file compilation to top-level
...
The arch-specific flags are only used by the arch-specific modules,
not the common/ files, so we can delete them too.
2023-01-10 01:15:28 -05:00
Mike Frysinger
8ba643c31e
sim: example-synacor: move arch-specific file compilation to top-level
2023-01-10 01:15:28 -05:00
Mike Frysinger
304195bcf8
sim: erc32: move arch-specific file compilation to top-level
...
The arch-specific flags are only used by the arch-specific modules,
not the common/ files, so we can delete them too.
2023-01-10 01:15:28 -05:00
Mike Frysinger
2206990476
sim: d10v: move arch-specific file compilation to top-level
2023-01-10 01:15:27 -05:00
Mike Frysinger
71fa869293
sim: cris: move arch-specific file compilation to top-level
2023-01-10 01:15:27 -05:00
Mike Frysinger
df4b07f4b7
sim: cr16: move arch-specific file compilation to top-level
2023-01-10 01:15:27 -05:00
Mike Frysinger
a8e175e578
sim: bfin: move arch-specific file compilation to top-level
...
The arch-specific flags are only used by the arch-specific modules,
not the common/ files, so we can delete them too.
2023-01-10 01:15:27 -05:00
Mike Frysinger
75015a129f
sim: bpf: move arch-specific file compilation to top-level
...
We can drop the arch-specific rules from the subdir as they're no
longer used.
2023-01-10 01:15:27 -05:00
Mike Frysinger
98331de786
sim: avr: move arch-specific file compilation to top-level
2023-01-10 01:15:27 -05:00
Mike Frysinger
688fba23d2
sim: arm: move arch-specific file compilation to top-level
...
The arch-specific flags are only used by the arch-specific modules,
not the common/ files, so we can delete them too.
2023-01-10 01:15:27 -05:00
Mike Frysinger
b3e1c5d43d
sim: aarch64: move arch-specific file compilation to top-level
2023-01-10 01:15:27 -05:00
Mike Frysinger
bc438b3e59
sim: build: add basic framework for compiling arch objects in top-level
...
The code so far has been assuming that we only compile common/ objects.
Now that we're ready to compile arch-specific objects, refactor some of
the flags & checks a bit to support both.
2023-01-10 01:15:26 -05:00
Mike Frysinger
54e26255ca
sim: modules.c: move generation to top-level
...
Now that all arches create libsim.a from the top-level, we have full
access to their inputs, and can move the actual generation from the
subdir up to the top-level. This avoids recursive makes and will
help simplify state passing between the two.
2023-01-10 01:15:26 -05:00
Mike Frysinger
638a9300b5
sim: build: drop common/nrun.o subdir hack
...
Now that all the subdirs handle their own builds, we can drop this
common rule as it's unused, and we don't want to use it anymore.
2023-01-10 01:15:26 -05:00
Mike Frysinger
e732fe9b4f
sim: build: drop support for creating libsim.a in subdirs
...
Now that all ports have moved to creating libsim.a in the top-level,
drop all the support code to create it in a subdir.
2023-01-10 01:15:26 -05:00