123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860 |
- #
- # This file is part of the program psim.
- #
- # Copyright 1994, 1995, 1996, 1997, 2003 Andrew Cagney
- #
- # 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/>.
- #
- default: all
- VPATH = @srcdir@
- srcdir = @srcdir@
- srccom = $(srcdir)/../common
- srcroot = $(srcdir)/../..
- srcsim = $(srcdir)/..
- include $(srcroot)/gdb/silent-rules.mk
- # Helper code from gnulib.
- GNULIB_PARENT_DIR = ../..
- include $(GNULIB_PARENT_DIR)/gnulib/Makefile.gnulib.inc
- # Settings from top-level configure.
- include ../arch-subdir.mk
- prefix = @prefix@
- exec_prefix = @exec_prefix@
- bindir = @bindir@
- libdir = @libdir@
- tooldir = $(libdir)/$(target_alias)
- datarootdir = @datarootdir@
- datadir = @datadir@
- mandir = @mandir@
- man1dir = $(mandir)/man1
- man2dir = $(mandir)/man2
- man3dir = $(mandir)/man3
- man4dir = $(mandir)/man4
- man5dir = $(mandir)/man5
- man6dir = $(mandir)/man6
- man7dir = $(mandir)/man7
- man8dir = $(mandir)/man8
- man9dir = $(mandir)/man9
- infodir = @infodir@
- includedir = @includedir@
- # This can be referenced by the gettext configuration code.
- top_builddir = ..
- SHELL = /bin/sh
- BISON = bison
- MAKEINFO = makeinfo
- INLINE_CFLAGS = $(SIM_INLINE)
- SMP_CFLAGS = @sim_smp@
- XOR_ENDIAN_CFLAGS = @sim_xor_endian@
- BITSIZE_CFLAGS = @sim_bitsize@
- HOSTBITSIZE_CFLAGS = @sim_hostbitsize@
- TIMEBASE_CFLAGS = @sim_timebase@
- FLOAT_CFLAGS = @sim_float@
- MONITOR_CFLAGS = @sim_monitor@
- MODEL_CFLAGS = @sim_model@ @sim_default_model@ @sim_model_issue@
- TERMIO_CFLAGS = @sim_termio@
- DEVZERO_CFLAGS = @sim_devzero@
- CONFIG_CFLAGS = \
- $(SMP_CFLAGS) \
- $(XOR_ENDIAN_CFLAGS) \
- $(BITSIZE_CFLAGS) \
- $(HOSTBITSIZE_CFLAGS) \
- $(TIMEBASE_CFLAGS) \
- $(FLOAT_CFLAGS) \
- $(MONITOR_CFLAGS) \
- $(MODEL_CFLAGS) \
- $(TERMIO_CFLAGS) \
- $(DEVZERO_CFLAGS)
- SIM_FPU_CFLAGS = -DHAVE_COMMON_FPU -I../common -I${srcdir}/../common
- STD_CFLAGS = $(CFLAGS) $(WERROR_CFLAGS) $(INLINE_CFLAGS) $(CONFIG_CFLAGS) $(WARN_CFLAGS) $(INCLUDES) $(INCGNU) $(INTL_CFLAGS) $(SIM_FPU_CFLAGS)
- NOWARN_CFLAGS = $(CFLAGS) $(INLINE_CFLAGS) $(CONFIG_CFLAGS) $(INCLUDES) $(SIM_FPU_CFLAGS)
- BUILD_CFLAGS = $(CFLAGS_FOR_BUILD) $(INCLUDES) $(WARN_CFLAGS)
- LIBS = $(COMMON_LIBS) @LIBS@ $(LIBGNU) $(LIBGNU_EXTRA_LIBS)
- COMPILE_FOR_BUILD = $(CC_FOR_BUILD) $(BUILD_CFLAGS)
- LINK_FOR_BUILD = $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(LDFLAGS_FOR_BUILD) -o $@
- IGEN_OPCODE_RULES = @sim_opcode@
- IGEN_DECODE_MECHANISM = @sim_decode_mechanism@
- IGEN_DUPLICATE = @sim_dup@
- IGEN_JUMP = @sim_jump@
- IGEN_FILTER = @sim_filter@
- IGEN_ICACHE = @sim_icache@
- IGEN_SMP = @sim_igen_smp@
- IGEN_LINE_NR = @sim_line_nr@
- DGEN_FLAGS = @sim_switch@
- IGEN_FLAGS = \
- $(IGEN_DECODE_MECHANISM) \
- $(IGEN_DUPLICATE) \
- $(IGEN_JUMP) \
- $(IGEN_FILTER) \
- $(IGEN_ICACHE) \
- $(IGEN_SMP) \
- $(IGEN_LINE_NR)
- # igen/dgen leak memory, and therefore makes AddressSanitizer unhappy. Disable
- # leak detection while running them.
- IGEN = ASAN_OPTIONS=detect_leaks=0 ./igen
- DGEN = ASAN_OPTIONS=detect_leaks=0 ./dgen
- .NOEXPORT:
- MAKEOVERRIDES=
- LIB_INCLUDES = -I$(srcdir)/../../include
- BFD_INCLUDES = -I../../bfd -I$(srcdir)/../../bfd
- GDB_INCLUDES = -I../../gdb -I$(srcdir)/../../gdb -I$(srcdir)/../../gdb/config
- INCLUDES = -I. -I$(srcdir) $(LIB_INCLUDES) $(BFD_INCLUDES) $(GDB_INCLUDES) -I../..
- LIBIBERTY_LIB = ../../libiberty/libiberty.a
- BFD_LIB = ../../bfd/libbfd.a
- ZLIB = $(zlibdir) -lz
- TARGETLIB = libsim.a
- all: run$(EXEEXT) $(TARGETLIB) $(GDB_OBJ)
- .c.o:
- $(ECHO_CC) $(CC) -c $(STD_CFLAGS) $<
- # Headers outside sim/ppc.
- ANSIDECL_H = $(srcroot)/include/ansidecl.h
- BFD_H = ../../bfd/bfd.h
- GDB_CALLBACK_H = $(srcroot)/include/sim/callback.h
- GDB_REMOTE_SIM_H = $(srcroot)/include/sim/sim.h
- GDB_SIM_PPC_H = $(srcroot)/include/gdb/sim-ppc.h
- COMMON_SIM_BASE_H = $(srcroot)/sim/common/sim-base.h
- COMMON_SIM_BASICS_H = $(srcroot)/sim/common/sim-basics.h
- COMMON_SIM_FPU_H = $(srcroot)/sim/common/sim-fpu.h
- COMMON_SIM_INLINE_H = $(srcroot)/sim/common/sim-inline.h
- COMMON_SIM_SIGNAL_H = $(srcroot)/sim/common/sim-signal.h
- # Headers in sim/ppc.
- ACCONFIG_H = \
- acconfig.h
- ALTIVEC_EXPRESSION_H = \
- altivec_expression.h
- ALTIVEC_REGISTERS_H = \
- altivec_registers.h
- BASICS_H = \
- basics.h \
- $(CONFIG_H) \
- $(INLINE_H) \
- $(SIM_CALLBACKS_H) \
- $(DEBUG_H) \
- $(WORDS_H) \
- $(BITS_H) \
- $(SIM_ENDIAN_H)
- BITS_H = \
- bits.h \
- bits.c
- CAP_H = \
- cap.h \
- $(BASICS_H)
- COREFILE_H = \
- corefile.h
- COREFILE_N_H = \
- corefile-n.h
- CPU_H = \
- cpu.h \
- $(BASICS_H) \
- $(REGISTERS_H) \
- $(DEVICE_H) \
- $(COREFILE_H) \
- $(VM_H) \
- $(EVENTS_H) \
- $(INTERRUPTS_H) \
- $(PSIM_H) \
- $(IDECODE_H) \
- $(ITABLE_H) \
- $(OS_EMUL_H) \
- $(MON_H) \
- $(MODEL_H) \
- cpu.c
- DEBUG_H = \
- debug.h \
- $(FILTER_FILENAME_H)
- DEVICE_H = \
- device.h
- DEVICE_TABLE_H = \
- device_table.h \
- $(BASICS_H) \
- $(DEVICE_H) \
- $(TREE_H) \
- $(HW_H)
- E500_EXPRESSION_H = \
- e500_expression.h
- E500_REGISTERS_H = \
- e500_registers.h
- EMUL_BUGAPI_H = \
- emul_bugapi.h
- EMUL_CHIRP_H = \
- emul_chirp.h
- EMUL_GENERIC_H = \
- emul_generic.h \
- $(CPU_H) \
- $(IDECODE_H) \
- $(OS_EMUL_H) \
- $(TREE_H) \
- $(BFD_H)
- EMUL_NETBSD_H = \
- emul_netbsd.h
- EMUL_UNIX_H = \
- emul_unix.h
- EVENTS_H = \
- events.h
- FILTER_FILENAME_H = \
- filter_filename.h
- FILTER_H = \
- filter.h
- GEN_ICACHE_H = \
- gen-icache.h
- GEN_IDECODE_H = \
- gen-idecode.h
- GEN_ITABLE_H = \
- gen-itable.h
- GEN_MODEL_H = \
- gen-model.h
- GEN_SEMANTICS_H = \
- gen-semantics.h
- GEN_SUPPORT_H = \
- gen-support.h
- HW_CPU_H = \
- hw_cpu.h
- HW_PHB_H = \
- hw_phb.h
- IDECODE_BRANCH_H = \
- idecode_branch.h
- IDECODE_EXPRESSION_H = \
- idecode_expression.h \
- $(ALTIVEC_EXPRESSION_H) \
- $(E500_EXPRESSION_H)
- IDECODE_FIELDS_H = \
- idecode_fields.h
- IGEN_H = \
- igen.h
- INLINE_H = \
- inline.h
- INTERRUPTS_H = \
- interrupts.h
- LD_CACHE_H = \
- ld-cache.h
- LD_DECODE_H = \
- ld-decode.h
- LD_INSN_H = \
- ld-insn.h
- LF_H = \
- lf.h
- MISC_H = \
- misc.h \
- $(CONFIG_H) \
- $(FILTER_FILENAME_H)
- MON_H = \
- mon.h \
- $(BASICS_H) \
- $(ITABLE_H)
- OPTIONS_H = \
- options.h
- OS_EMUL_H = \
- os_emul.h
- PSIM_H = \
- psim.h \
- $(BASICS_H)
- REGISTERS_H = \
- registers.h \
- $(E500_REGISTERS_H) \
- $(ALTIVEC_REGISTERS_H) \
- $(SPREG_H)
- SIM_CALLBACKS_H = \
- sim_callbacks.h
- SIM_ENDIAN_H = \
- sim-endian.h \
- sim-endian.c
- SIM_ENDIAN_N_H = \
- sim-endian-n.h
- SIM_MAIN_H = \
- sim-main.h \
- $(COMMON_SIM_BASICS_H) \
- $(COMMON_SIM_SIGNAL_H) \
- $(COMMON_SIM_BASE_H)
- STD_CONFIG_H = \
- std-config.h
- TABLE_H = \
- table.h
- TREE_H = \
- tree.h
- VM_H = \
- vm.h
- VM_N_H = \
- vm_n.h
- WORDS_H = \
- words.h
- # Generated headers.
- CONFIG_H = \
- config.h
- DEFINES_H = \
- defines.h
- HW_H = \
- hw.h
- ICACHE_H = \
- icache.h
- IDECODE_H = \
- idecode.h \
- $(IDECODE_EXPRESSION_H) \
- $(IDECODE_FIELDS_H) \
- $(IDECODE_BRANCH_H)
- ITABLE_H = \
- itable.h
- MODEL_H = \
- model.h
- PK_H = \
- pk.h
- SEMANTICS_H = \
- semantics.h
- SPREG_H = \
- spreg.h
- SUPPORT_H = \
- support.h \
- support.c
- INLINE = \
- inline.h \
- inline.c
- BUILT_SRC_WO_CONFIG = \
- icache.h icache.c \
- support.h support.c \
- idecode.h idecode.c \
- semantics.h semantics.c \
- itable.h itable.c \
- spreg.h spreg.c \
- model.h model.c \
- support.h support.c \
- pk.h \
- hw.h hw.c \
- filter_host.c
- BUILT_SRC = \
- $(BUILT_SRC_WO_CONFIG) \
- config.h
- LIB_INLINE_SRC = \
- psim.c \
- bits.c \
- debug.c \
- sim-endian.c \
- sim-endian.h \
- sim-endian-n.h \
- vm.c \
- vm_n.h \
- corefile.c \
- events.c \
- os_emul.c \
- registers.c \
- cpu.c \
- interrupts.c \
- device.c \
- tree.c \
- device_table.c \
- cap.c \
- mon.c \
- options.c
- LIB_SRC = \
- $(PACKAGE_SRC) \
- $(HW_SRC) \
- $(LIB_INLINE_SRC)
- MAIN_SRC = \
- main.c \
- gdb-sim.c \
- sim_calls.c
- COMMON_OBJS_NAMES = \
- callback.o \
- target-newlib-errno.o \
- target-newlib-open.o \
- target-newlib-signal.o \
- target-newlib-syscall.o \
- version.o
- COMMON_OBJS = $(COMMON_OBJS_NAMES:%=../common/common_libcommon_a-%)
- # NOTE: semantics, idecode and psim put last so smaller files are compiled
- # first
- LIB_OBJ = \
- debug.o \
- filter_filename.o \
- bits.o \
- sim-endian.o \
- os_emul.o \
- emul_generic.o \
- emul_bugapi.o \
- emul_chirp.o \
- emul_netbsd.o \
- emul_unix.o \
- registers.o \
- vm.o \
- corefile.o \
- model.o \
- spreg.o \
- cpu.o \
- interrupts.o \
- events.o \
- cap.o \
- device.o \
- tree.o \
- device_table.o \
- itable.o \
- mon.o \
- icache.o \
- semantics.o \
- idecode.o \
- support.o \
- sim-fpu.o \
- psim.o \
- $(COMMON_OBJS) \
- $(PACKAGE_OBJ) \
- $(HW_OBJ) \
- options.o
- GDB_OBJ = gdb-sim.o sim_calls.o
- HW_SRC = @sim_hw_src@
- HW_OBJ = @sim_hw_obj@
- PACKAGE_SRC = @sim_pk_src@
- PACKAGE_OBJ = @sim_pk_obj@
- psim$(EXEEXT): $(TARGETLIB) main.o $(LIBIBERTY_LIB) $(BFD_LIB) $(LIBINTL_DEP)
- $(ECHO_CCLD) $(CC) $(CFLAGS) $(LDFLAGS) -o psim$(EXEEXT) main.o $(TARGETLIB) $(BFD_LIB) $(ZLIB) $(LIBINTL) $(LIBIBERTY_LIB) $(LIBS)
- run$(EXEEXT): psim$(EXEEXT)
- $(SILENCE) rm -f $@
- $(ECHO_GEN) ln $< $@ 2>/dev/null || $(LN_S) $< $@ 2>/dev/null || cp -p $< $@
- $(TARGETLIB): tmp-igen tmp-dgen tmp-hw tmp-pk tmp-defines $(LIB_OBJ) $(GDB_OBJ)
- $(ECHO_AR) $(AR) $(AR_FLAGS) $(TARGETLIB) $(LIB_OBJ) $(GDB_OBJ)
- $(ECHO_RANLIB) $(RANLIB) $(TARGETLIB)
- psim.o: psim.c $(CPU_H) $(IDECODE_H) $(OPTIONS_H) $(TREE_H) $(BFD_H)
- bits.o: bits.c $(BASICS_H)
- debug.o: debug.c $(CONFIG_H) $(BASICS_H)
- filter_filename.o: filter_filename.c $(CONFIG_H) $(FILTER_FILENAME_H)
- sim-endian.o: sim-endian.c $(CONFIG_H) $(BASICS_H) $(SIM_ENDIAN_N_H)
- os_emul.o: os_emul.c $(CPU_H) $(IDECODE_H) $(OS_EMUL_H) $(EMUL_GENERIC_H) $(EMUL_NETBSD_H) $(EMUL_UNIX_H) $(EMUL_CHIRP_H) $(EMUL_BUGAPI_H)
- emul_generic.o: emul_generic.c $(EMUL_GENERIC_H)
- emul_bugapi.o: emul_bugapi.c $(EMUL_GENERIC_H) $(EMUL_BUGAPI_H)
- emul_chirp.o: emul_chirp.c $(EMUL_GENERIC_H) $(EMUL_CHIRP_H)
- emul_netbsd.o: emul_netbsd.c $(EMUL_GENERIC_H) $(EMUL_NETBSD_H)
- emul_unix.o: emul_unix.c $(EMUL_GENERIC_H) $(EMUL_UNIX_H)
- registers.o: registers.c $(BASICS_H) $(REGISTERS_H)
- cpu.o: cpu.c $(CPU_H) $(IDECODE_H)
- interrupts.o: interrupts.c $(CPU_H) $(IDECODE_H) $(OS_EMUL_H)
- # Given that inlines are turned on now, rebuild idecode whenever
- # anything changes.
- idecode.o: idecode.c $(CPU_H) $(IDECODE_H) $(SEMANTICS_H) $(LIB_INLINE_SRC) $(BUILT_SRC)
- # double.o: double.c dp-bit.c
- vm.o: vm.c $(BASICS_H) $(REGISTERS_H) $(DEVICE_H) $(COREFILE_H) $(VM_H) $(INTERRUPTS_H) $(MON_H) $(CPU_H) $(VM_N_H)
- corefile.o: corefile.c $(BASICS_H) $(DEVICE_TABLE_H) $(COREFILE_H) $(COREFILE_N_H)
- model.o: model.c $(CPU_H) $(MON_H)
- events.o: events.c $(BASICS_H) $(EVENTS_H)
- sim_calls.o: sim_calls.c $(PSIM_H) $(OPTIONS_H) $(DEFS_H) $(BFD_H) $(GDB_CALLBACK_H) $(GDB_REMOTE_SIM_H)
- gdb-sim.o: gdb-sim.c $(PSIM_H) $(OPTIONS_H) $(REGISTERS_H) $(GDB_REMOTE_SIM_H) $(GDB_SIM_PPC_H) $(SIM_CALLBACK_H)
- spreg.o: spreg.c $(BASICS_H) $(SPREG_H)
- main.o: main.c $(PSIM_H) $(OPTIONS_H) $(DEVICE_H) $(EVENTS_H) $(BFD_H) $(GDB_CALLBACK_H) $(GDB_REMOTE_SIM_H)
- device.o: device.c $(DEVICE_TABLE_H) $(CAP_H) $(EVENTS_H) $(PSIM_H)
- tree.o: tree.c $(BASICS_H) $(DEVICE_H) $(TREE_H)
- device_table.o: device_table.c $(DEVICE_TABLE_H) hw.c
- cap.o: cap.c $(CAP_H)
- semantics.o: semantics.c $(CPU_H) $(IDECODE_H) $(SEMANTICS_H) $(COMMON_SIM_INLINE_H) $(COMMON_SIM_FPU_H) $(SUPPORT_H)
- icache.o: icache.c $(CPU_H) $(IDECODE_H) $(SEMANTICS_H) $(ICACHE_H) $(COMMON_SIM_INLINE_H) $(COMMON_SIM_FPU_H) $(SUPPORT_H)
- support.o: support.c $(CPU_H) $(IDECODE_H) $(COMMON_SIM_INLINE_H) $(COMMON_SIM_FPU_H) $(SUPPORT_H)
- itable.o: itable.c $(ITABLE_H)
- mon.o: mon.c $(BASICS_H) $(CPU_H) $(MON_H)
- sim-fpu.o: $(srcdir)/../common/sim-fpu.c $(CONFIG_H)
- $(ECHO_CC) $(CC) -c $(STD_CFLAGS) -DHAVE_CONFIG_H $(srcdir)/../common/sim-fpu.c
- # Rebuild options whenever something changes so the date/time is up to date.
- options.o: options.c $(CPU_H) $(OPTIONS_H) $(DEFINES_H) $(BASICS_H) $(IDECODE_H) $(INLINE) $(LIB_SRC) $(BUILT_SRC) config.status Makefile
- $(ECHO_CC) $(CC) -c $(STD_CFLAGS) '-DOPCODE_RULES="@sim_opcode@"' '-DIGEN_FLAGS="$(IGEN_FLAGS)"' '-DDGEN_FLAGS="$(DGEN_FLAGS)"' $(srcdir)/options.c
- defines.h: tmp-defines; @true
- tmp-defines: config.h Makefile
- $(ECHO_GEN) sed -n -e '/^#define HAVE_/s/ 1$$/",/' -e '/^#define HAVE_/s//"HAVE_/p' < config.h > tmp-defines.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-defines.h defines.h
- $(SILENCE) touch $@
- #
- # Rules to create the built c source code files
- #
- tmp-dgen: dgen ppc-spr-table $(srcroot)/move-if-change
- $(ECHO_GEN) $(DGEN) $(DGEN_FLAGS) \
- -r $(srcdir)/ppc-spr-table \
- -n spreg.h -hp tmp-spreg.h \
- -n spreg.c -p tmp-spreg.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-spreg.h spreg.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-spreg.c spreg.c
- $(SILENCE) touch $@
- tmp-igen: igen $(srcdir)/ppc-instructions $(srcdir)/altivec.igen $(srcdir)/e500.igen $(IGEN_OPCODE_RULES) $(srcroot)/move-if-change tmp-ld-decode tmp-ld-cache tmp-ld-insn tmp-filter
- $(ECHO_GEN) $(IGEN) $(IGEN_FLAGS) \
- -o $(srcdir)/$(IGEN_OPCODE_RULES) \
- -I $(srcdir) -i $(srcdir)/ppc-instructions \
- -n icache.h -hc tmp-icache.h \
- -n icache.c -c tmp-icache.c \
- -n semantics.h -hs tmp-semantics.h \
- -n semantics.c -s tmp-semantics.c \
- -n idecode.h -hd tmp-idecode.h \
- -n idecode.c -d tmp-idecode.c \
- -n itable.h -ht tmp-itable.h \
- -n itable.c -t tmp-itable.c \
- -n model.h -hm tmp-model.h \
- -n model.c -m tmp-model.c \
- -n support.h -hf tmp-support.h \
- -n support.c -f tmp-support.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-icache.h icache.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-icache.c icache.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-idecode.h idecode.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-idecode.c idecode.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-semantics.h semantics.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-semantics.c semantics.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-itable.h itable.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-itable.c itable.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-model.h model.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-model.c model.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-support.h support.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-support.c support.c
- $(SILENCE) touch $@
- # NOTE: Some versions of make don't handle files created as side-effects
- # uncomment the below if that is the case.
- $(TARGETLIB): tmp-igen tmp-dgen
- itable.h itable.c icache.h icache.c idecode.h idecode.c semantics.h semantics.c model.h model.c support.h support.c: tmp-igen
- spreg.h spreg.c: tmp-dgen
- dgen: dgen.o table.o lf.o misc.o filter_host.o
- $(ECHO_CCLD) $(LINK_FOR_BUILD) dgen.o table.o lf.o misc.o filter_host.o
- igen: igen.o table.o lf.o misc.o filter_host.o ld-decode.o ld-cache.o filter.o ld-insn.o gen-model.o gen-itable.o gen-icache.o gen-semantics.o gen-idecode.o gen-support.o
- $(ECHO_CCLD) $(LINK_FOR_BUILD) igen.o table.o lf.o misc.o filter_host.o ld-decode.o ld-cache.o filter.o ld-insn.o gen-model.o gen-itable.o gen-icache.o gen-semantics.o gen-idecode.o gen-support.o
- filter_host.c: filter_filename.c
- $(ECHO_GEN) cat $(srcdir)/filter_filename.c > filter_host.c
- filter_host.o: filter_host.c $(CONFIG_H) $(FILTER_FILENAME_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c filter_host.c
- table.o: table.c $(CONFIG_H) $(MISC_H) $(LF_H) $(TABLE_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/table.c
- lf.o: lf.c $(CONFIG_H) $(MISC_H) $(LF_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/lf.c
- filter.o: filter.c $(CONFIG_H) $(MISC_H) $(FILTER_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/filter.c
- tmp-filter: filter.c $(MISC_H) misc.o
- $(ECHO_CCLD) $(LINK_FOR_BUILD) -DMAIN $(srcdir)/filter.c misc.o
- ld-decode.o: ld-decode.c $(MISC_H) $(LF_H) $(TABLE_H) $(LD_DECODE_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/ld-decode.c
- tmp-ld-decode: ld-decode.c misc.o lf.o table.o filter_host.o
- $(ECHO_CCLD) $(LINK_FOR_BUILD) -DMAIN $(srcdir)/ld-decode.c misc.o lf.o table.o filter_host.o
- ld-cache.o: ld-cache.c $(MISC_H) $(LF_H) $(TABLE_H) $(LD_CACHE_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/ld-cache.c
- tmp-ld-cache: ld-cache.c misc.o lf.o table.o filter_host.o
- $(ECHO_CCLD) $(LINK_FOR_BUILD) -DMAIN $(srcdir)/ld-cache.c misc.o lf.o table.o filter_host.o
- ld-insn.o: ld-insn.c $(MISC_H) $(LF_H) $(TABLE_H) $(FILTER_H) $(LD_DECODE_H) $(LD_CACHE_H) $(LD_INSN_H) $(IGEN_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/ld-insn.c
- tmp-ld-insn: ld-insn.c ld-cache.o misc.o lf.o table.o ld-decode.o filter_host.o filter.o
- $(ECHO_CCLD) $(LINK_FOR_BUILD) -DMAIN $(srcdir)/ld-insn.c ld-cache.o misc.o lf.o table.o ld-decode.o filter_host.o filter.o
- gen-model.o: gen-model.c $(MISC_H) $(LF_H) $(TABLE_H) $(FILTER_H) $(LD_CACHE_H) $(LD_DECODE_H) $(LD_INSN_H) $(GEN_MODEL_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/gen-model.c
- gen-itable.o: gen-itable.c $(MISC_H) $(LF_H) $(TABLE_H) $(FILTER_H) $(LD_CACHE_H) $(LD_DECODE_H) $(LD_INSN_H) $(IGEN_H) $(GEN_ITABLE_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/gen-itable.c
- gen-icache.o: gen-icache.c $(MISC_H) $(LF_H) $(TABLE_H) $(FILTER_H) $(LD_DECODE_H) $(LD_CACHE_H) $(LD_INSN_H) $(IGEN_H) $(GEN_SEMANTICS_H) $(GEN_IDECODE_H) $(GEN_ICACHE_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/gen-icache.c
- gen-semantics.o: gen-semantics.c $(MISC_H) $(LF_H) $(TABLE_H) $(FILTER_H) $(LD_DECODE_H) $(LD_CACHE_H) $(LD_INSN_H) $(IGEN_H) $(GEN_SEMANTICS_H) $(GEN_ICACHE_H) $(GEN_IDECODE_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/gen-semantics.c
- gen-idecode.o: gen-idecode.c $(MISC_H) $(LF_H) $(TABLE_H) $(FILTER_H) $(LD_DECODE_H) $(LD_CACHE_H) $(LD_INSN_H) $(IGEN_H) $(GEN_IDECODE_H) $(GEN_ICACHE_H) $(GEN_SEMANTICS_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/gen-idecode.c
- gen-support.o: gen-support.c $(MISC_H) $(LF_H) $(TABLE_H) $(FILTER_H) $(LD_DECODE_H) $(LD_CACHE_H) $(LD_INSN_H) $(IGEN_H) $(GEN_SEMANTICS_H) $(GEN_SUPPORT_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/gen-support.c
- dgen.o: dgen.c $(CONFIG_H) $(MISC_H) $(LF_H) $(TABLE_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/dgen.c
- igen.o: igen.c $(MISC_H) $(LF_H) $(TABLE_H) $(CONFIG_H) $(FILTER_H) $(LD_CACHE_H) $(LD_DECODE_H) $(LD_INSN_H) $(IGEN_H) $(GEN_MODEL_H) $(GEN_ICACHE_H) $(GEN_ITABLE_H) $(GEN_IDECODE_H) $(GEN_SEMANTICS_H) $(GEN_SUPPORT_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/igen.c
- misc.o: misc.c $(CONFIG_H) $(MISC_H)
- $(ECHO_CC) $(COMPILE_FOR_BUILD) -c $(srcdir)/misc.c
- # real hardware
- hw.c hw.h: tmp-hw; @true
- tmp-hw: Makefile $(HW_SRC) $(srcroot)/move-if-change
- $(ECHO_GEN)# The first for loop is to remove duplicates.
- $(SILENCE) f=""; \
- for i in $(HW_SRC) ; do \
- case " $$f " in \
- *" $$i "*) ;; \
- *) f="$$f $$i" ;; \
- esac ; \
- done ; \
- for hw in $$f ; do echo $$hw ; done \
- | sed -e 's/^.*\(hw_.*\)\.c/\1/' \
- -e 's/^/extern const device_descriptor /' \
- -e 's/$$/_device_descriptor\[\];/' \
- > tmp-hw.h
- $(SILENCE) f=""; \
- for i in $(HW_SRC) ; do \
- case " $$f " in \
- *" $$i "*) ;; \
- *) f="$$f $$i" ;; \
- esac ; \
- done ; \
- for hw in $$f ; do echo $$hw ; done \
- | sed -e 's/^.*\(hw_.*\)\.c/\1/' \
- -e 's/^/ /' \
- -e 's/$$/_device_descriptor,/' \
- > tmp-hw.c
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-hw.h hw.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-hw.c hw.c
- $(SILENCE) touch $@
- hw_cpu.o: hw_cpu.c $(DEVICE_TABLE_H) $(HW_CPU_H) $(INTERRUPTS_H) $(CPU_H)
- hw_com.o: hw_com.c $(DEVICE_TABLE_H)
- hw_core.o: hw_core.c $(DEVICE_TABLE_H) $(COREFILE_H)
- hw_disk.o: hw_disk.c $(DEVICE_TABLE_H) $(PK_H)
- hw_eeprom.o: hw_eeprom.c $(DEVICE_TABLE_H)
- hw_glue.o: hw_glue.c $(DEVICE_TABLE_H)
- hw_htab.o: hw_htab.c $(DEVICE_TABLE_H) $(BFD_H)
- hw_ide.o: hw_ide.c $(DEVICE_TABLE_H)
- hw_init.o: hw_init.c $(DEVICE_TABLE_H) $(BFD_H) $(PSIM_H)
- hw_iobus.o: hw_iobus.c $(DEVICE_TABLE_H)
- hw_memory.o: hw_memory.c $(DEVICE_TABLE_H)
- hw_nvram.o: hw_nvram.c $(DEVICE_TABLE_H)
- hw_opic.o: hw_opic.c $(DEVICE_TABLE_H)
- hw_pal.o: hw_pal.c $(DEVICE_TABLE_H) $(CPU_H)
- hw_phb.o: hw_phb.c $(DEVICE_TABLE_H) $(HW_PHB_H) $(COREFILE_H)
- hw_register.o: hw_register.c $(DEVICE_TABLE_H) $(PSIM_H)
- hw_sem.o: hw_sem.c $(DEVICE_TABLE_H) $(PSIM_H)
- hw_shm.o: hw_shm.c $(DEVICE_TABLE_H) $(PSIM_H)
- hw_trace.o: hw_trace.c $(DEVICE_TABLE_H)
- hw_vm.o: hw_vm.c $(DEVICE_TABLE_H) $(CPU_H)
- # ignore this line, it stops make from getting confused
- # real packages
- pk.h: tmp-pk; @true
- tmp-pk: Makefile $(PACKAGE_SRC) $(srcroot)/move-if-change
- $(ECHO_GEN)# The first for loop is to remove duplicates.
- $(SILENCE) f=""; \
- for i in $(PACKAGE_SRC) ; do \
- case " $$f " in \
- *" $$i "*) ;; \
- *) f="$$f $$i" ;; \
- esac ; \
- done ; \
- for pk in $$f ; do echo $$pk ; done \
- | sed -e 's/^.*pk_\(.*\)\.c/\1/' \
- -e 's/^/extern package_create_instance_callback pk_/' \
- -e 's/$$/_create_instance;/' \
- > tmp-pk.h
- $(SILENCE) $(SHELL) $(srcroot)/move-if-change tmp-pk.h pk.h
- $(SILENCE) touch $@
- pk_disklabel.o: pk_disklabel.c $(DEVICE_TABLE_H) $(PK_H)
- # ignore this line, it stops make from getting confused
- tags etags: TAGS
- TAGS: $(BUILT_SRC)
- etags $(srcdir)/*.h $(srcdir)/*.c $(BUILT_SRC)
- clean mostlyclean:
- rm -f tmp-* *.[oasi] core psim$(EXEEXT) run$(EXEEXT) igen dgen $(BUILT_SRC_WO_CONFIG)
- distclean realclean: clean
- rm -f TAGS Makefile config.cache config.status config.h defines.h stamp-h config.log
- maintainer-clean: distclean
- rm -f *~ *.log core *.core
- Makefile: Makefile.in config.status
- CONFIG_FILES=Makefile CONFIG_HEADERS= $(SHELL) ./config.status
- config.h: stamp-h ; @true
- stamp-h: config.in config.status
- CONFIG_FILES= CONFIG_HEADERS=config.h:config.in $(SHELL) ./config.status
- config.status: configure
- $(SHELL) ./config.status --recheck
- check:
- html:
- clean-html:
- install-html:
- info:
- clean-info:
- install-info:
- pdf:
- clean-pdf:
- install-pdf:
- install: installdirs
- a=`basename "$$(pwd)"`; \
- n=`echo run | sed '$(program_transform_name)'`; \
- [ "$(SIM_PRIMARY_TARGET)" = "$$a" ] || n="$$n-$$a"; \
- $(INSTALL_PROGRAM) run$(EXEEXT) $(DESTDIR)$(bindir)/$$n$(EXEEXT)
- install-strip: installdirs
- a=`basename "$$(pwd)"`; \
- n=`echo run | sed '$(program_transform_name)'`; \
- [ "$(SIM_PRIMARY_TARGET)" = "$$a" ] || n="$$n-$$a"; \
- $(INSTALL_PROGRAM) run$(EXEEXT) $(DESTDIR)$(bindir)/$$n$(EXEEXT)
- $(STRIP) $(DESTDIR)$(bindir)/$$n$(EXEEXT)
- installdirs:
- $(SHELL) $(srcdir)/../../mkinstalldirs $(DESTDIR)$(bindir)
|