Home | History | Annotate | Line # | Download | only in cr16
      1 ## See sim/Makefile.am
      2 ##
      3 ## Copyright (C) 2008-2024 Free Software Foundation, Inc.
      4 ## Contributed by M Ranga Swami Reddy <MR.Swami.Reddy (at] nsc.com>
      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 	$(patsubst %,%D%/%,$(SIM_NEW_COMMON_OBJS)) \
     25 	$(patsubst %,%D%/dv-%.o,$(SIM_HW_DEVICES)) \
     26 	%D%/interp.o \
     27 	%D%/sim-resume.o \
     28 	%D%/simops.o \
     29 	%D%/table.o
     30 $(%C%_libsim_a_OBJECTS) $(%C%_libsim_a_LIBADD): %D%/hw-config.h
     31 
     32 noinst_LIBRARIES += %D%/libsim.a
     33 
     34 ## Override wildcards that trigger common/modules.c to be (incorrectly) used.
     35 %D%/modules.o: %D%/modules.c
     36 
     37 %D%/%.o: common/%.c ; $(SIM_COMPILE)
     38 -@am__include@ %D%/$(DEPDIR)/*.Po
     39 
     40 %C%_run_SOURCES =
     41 %C%_run_LDADD = \
     42 	%D%/nrun.o \
     43 	%D%/libsim.a \
     44 	$(SIM_COMMON_LIBS)
     45 
     46 noinst_PROGRAMS += %D%/run
     47 
     48 ## List all generated headers to help Automake dependency tracking.
     49 BUILT_SOURCES += %D%/simops.h
     50 %C%_BUILD_OUTPUTS = \
     51 	%D%/gencode$(EXEEXT) \
     52 	%D%/table.c
     53 
     54 ## Generating modules.c requires all sources to scan.
     55 %D%/modules.c: | $(%C%_BUILD_OUTPUTS)
     56 
     57 %C%_gencode_SOURCES = %D%/gencode.c
     58 %C%_gencode_LDADD = %D%/cr16-opc.o
     59 
     60 # These rules are copied from automake, but tweaked to use FOR_BUILD variables.
     61 %D%/gencode$(EXEEXT): $(%C%_gencode_OBJECTS) $(%C%_gencode_DEPENDENCIES) %D%/$(am__dirstamp)
     62 	$(AM_V_CCLD)$(LINK_FOR_BUILD) $(%C%_gencode_OBJECTS) $(%C%_gencode_LDADD)
     63 
     64 # gencode is a build-time only tool.  Override the default rules for it.
     65 %D%/gencode.o: %D%/gencode.c
     66 	$(AM_V_CC)$(COMPILE_FOR_BUILD) -c $< -o $@
     67 %D%/cr16-opc.o: ../opcodes/cr16-opc.c
     68 	$(AM_V_CC)$(COMPILE_FOR_BUILD) -c $< -o $@
     69 
     70 %D%/simops.h: %D%/gencode$(EXEEXT)
     71 	$(AM_V_GEN)$< -h >$@
     72 
     73 %D%/table.c: %D%/gencode$(EXEEXT)
     74 	$(AM_V_GEN)$< >$@
     75 
     76 EXTRA_PROGRAMS += %D%/gencode
     77 CLEANFILES += %D%/simops.h
     78 MOSTLYCLEANFILES += $(%C%_BUILD_OUTPUTS)
     79