Home | History | Annotate | Line # | Download | only in d10v
      1 ## See sim/Makefile.am
      2 ##
      3 ## Copyright (C) 1996-2024 Free Software Foundation, Inc.
      4 ## Written by Cygnus Support.
      5 ##
      6 ## This program is free software; you can redistribute it and/or modify
      7 ## it under the terms of the GNU General Public License as published by
      8 ## the Free Software Foundation; either version 3 of the License, or
      9 ## (at your option) any later version.
     10 ##
     11 ## This program is distributed in the hope that it will be useful,
     12 ## but WITHOUT ANY WARRANTY; without even the implied warranty of
     13 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     14 ## GNU General Public License for more details.
     15 ##
     16 ## You should have received a copy of the GNU General Public License
     17 ## along with this program.  If not, see <http://www.gnu.org/licenses/>.
     18 
     19 nodist_%C%_libsim_a_SOURCES = \
     20 	%D%/modules.c
     21 %C%_libsim_a_SOURCES = \
     22 	$(common_libcommon_a_SOURCES)
     23 %C%_libsim_a_LIBADD = \
     24 	%D%/interp.o \
     25 	$(patsubst %,%D%/%,$(SIM_NEW_COMMON_OBJS)) \
     26 	$(patsubst %,%D%/dv-%.o,$(SIM_HW_DEVICES)) \
     27 	%D%/endian.o \
     28 	%D%/sim-resume.o \
     29 	%D%/simops.o \
     30 	%D%/table.o
     31 $(%C%_libsim_a_OBJECTS) $(%C%_libsim_a_LIBADD): %D%/hw-config.h
     32 
     33 noinst_LIBRARIES += %D%/libsim.a
     34 
     35 ## Override wildcards that trigger common/modules.c to be (incorrectly) used.
     36 %D%/modules.o: %D%/modules.c
     37 
     38 %D%/%.o: common/%.c ; $(SIM_COMPILE)
     39 -@am__include@ %D%/$(DEPDIR)/*.Po
     40 
     41 %C%_run_SOURCES =
     42 %C%_run_LDADD = \
     43 	%D%/nrun.o \
     44 	%D%/libsim.a \
     45 	$(SIM_COMMON_LIBS)
     46 
     47 noinst_PROGRAMS += %D%/run
     48 
     49 ## List all generated headers to help Automake dependency tracking.
     50 BUILT_SOURCES += %D%/simops.h
     51 %C%_BUILD_OUTPUTS = \
     52 	%D%/gencode$(EXEEXT) \
     53 	%D%/table.c
     54 
     55 ## Generating modules.c requires all sources to scan.
     56 %D%/modules.c: | $(%C%_BUILD_OUTPUTS)
     57 
     58 %C%_gencode_SOURCES = %D%/gencode.c
     59 %C%_gencode_LDADD = %D%/d10v-opc.o
     60 
     61 # These rules are copied from automake, but tweaked to use FOR_BUILD variables.
     62 %D%/gencode$(EXEEXT): $(%C%_gencode_OBJECTS) $(%C%_gencode_DEPENDENCIES) %D%/$(am__dirstamp)
     63 	$(AM_V_CCLD)$(LINK_FOR_BUILD) $(%C%_gencode_OBJECTS) $(%C%_gencode_LDADD)
     64 
     65 # gencode is a build-time only tool.  Override the default rules for it.
     66 %D%/gencode.o: %D%/gencode.c
     67 	$(AM_V_CC)$(COMPILE_FOR_BUILD) -c $< -o $@
     68 %D%/d10v-opc.o: ../opcodes/d10v-opc.c
     69 	$(AM_V_CC)$(COMPILE_FOR_BUILD) -c $< -o $@
     70 
     71 %D%/simops.h: %D%/gencode$(EXEEXT)
     72 	$(AM_V_GEN)$< -h >$@
     73 
     74 %D%/table.c: %D%/gencode$(EXEEXT)
     75 	$(AM_V_GEN)$< >$@
     76 
     77 EXTRA_PROGRAMS += %D%/gencode
     78 CLEANFILES += %D%/simops.h
     79 MOSTLYCLEANFILES += $(%C%_BUILD_OUTPUTS)
     80