* configure.in: added missing mcs51 in status output
[fw/sdcc] / sim / ucsim / avr.src / Makefile.in
1 #
2 # uCsim avr.src/Makefile
3 #
4 # (c) Drotos Daniel, Talker Bt. 1997
5 #
6
7 STARTYEAR       = 1997
8
9 SHELL           = /bin/sh
10 CXX             = @CXX@
11 CPP             = @CPP@
12 CXXCPP          = @CXXCPP@
13 RANLIB          = @RANLIB@
14 INSTALL         = @INSTALL@
15 STRIP           = @STRIP@
16
17 top_builddir    = @top_builddir@
18 top_srcdir      = @top_srcdir@
19
20 DEFS            = $(subs -DHAVE_CONFIG_H,,@DEFS@)
21 CPPFLAGS        = @CPPFLAGS@ -I$(srcdir) -I$(top_srcdir) -I$(top_builddir) \
22                   -I$(top_srcdir)/cmd.src -I$(top_srcdir)/sim.src \
23                   -I$(top_srcdir)/gui.src
24 CFLAGS          = @CFLAGS@ -Wall
25 CXXFLAGS        = @CXXFLAGS@ -Wall
26 M_OR_MM         = @M_OR_MM@
27 PICOPT          = @PICOPT@
28 SHAREDLIB       = @SHAREDLIB@
29 EXEEXT          = @EXEEXT@
30
31 LIBS            = -L$(top_builddir) -lsim -lutil -lguiucsim -lcmd -lsim @LIBS@
32 DL              = @DL@
33 dl_ok           = @dl_ok@
34
35 prefix          = @prefix@
36 exec_prefix     = @exec_prefix@
37 bindir          = @bindir@
38 libdir          = @libdir@
39 datadir         = @datadir@
40 datarootdir     = @datarootdir@
41 includedir      = @includedir@
42 mandir          = @mandir@
43 man1dir         = $(mandir)/man1
44 man2dir         = $(mandir)/man2
45 infodir         = @infodir@
46 srcdir          = @srcdir@
47 VPATH           = @srcdir@
48
49 OBJECTS_SHARED  = glob.o \
50                   simavr.o avr.o port.o \
51                   inst.o bit_inst.o jump_inst.o move_inst.o logic_inst.o \
52                   arith_inst.o
53 OBJECTS_EXE     = savr.o
54 OBJECTS         = $(OBJECTS_SHARED) $(OBJECTS_EXE)
55
56 enable_dlso     = @enable_dlso@
57 dlso_ok         = @dlso_ok@
58
59 AVRASM          = tavrasm
60 TEST_OBJ        = test_bit.hex test_dis.hex test_mov.hex test_jmp.hex \
61                   test_arith.hex test_call.hex
62
63
64 # Compiling entire program or any subproject
65 # ------------------------------------------
66 all: checkconf otherlibs avr.src
67
68
69 # Compiling and installing everything and runing test
70 # ---------------------------------------------------
71 install: all installdirs
72         $(INSTALL) savr$(EXEEXT) $(DESTDIR)$(bindir)/savr$(EXEEXT)
73         $(STRIP) $(DESTDIR)$(bindir)/savr$(EXEEXT)
74
75
76 # Deleting all the installed files
77 # --------------------------------
78 uninstall:
79         rm -f $(DESTDIR)$(bindir)/savr
80
81
82 # Performing self-test
83 # --------------------
84 check: $(TEST_OBJ)
85
86 test:
87
88
89 # Performing installation test
90 # ----------------------------
91 installcheck:
92
93
94 # Creating installation directories
95 # ---------------------------------
96 installdirs:
97         test -d $(DESTDIR)$(bindir) || $(INSTALL) -d $(DESTDIR)$(bindir)
98
99
100 # Creating dependencies
101 # ---------------------
102 dep: Makefile.dep
103
104 Makefile.dep: $(srcdir)/*.cc $(srcdir)/*.h
105         $(CXXCPP) $(CPPFLAGS) $(M_OR_MM) $(filter %.cc,$^) >Makefile.dep
106
107 include Makefile.dep
108 include $(srcdir)/clean.mk
109
110 #parser.cc: parser.y
111
112 #plex.cc: plex.l
113
114 # My rules
115 # --------
116 .SUFFIXES: .asm .hex
117
118 avr.src: savr$(EXEEXT) shared_lib
119
120 savr$(EXEEXT): $(OBJECTS) $(top_builddir)/*.a
121         $(CXX) $(CXXFLAGS) $(OBJECTS) $(LIBS) -o $@
122
123 ifeq ($(dlso_ok),yes)
124 shared_lib: $(top_builddir)/savr.so
125 else
126 shared_lib:
127         @$(top_srcdir)/mkecho $(top_builddir) "No AVR shared lib made."
128         @$(top_srcdir)/mkecho $(top_builddir) "(SHAREDLIB="$(SHAREDLIB)",dl_ok="$(dl_ok)",enable_dlso="$(enable_dlso)")"
129 endif
130
131 $(top_builddir)/savr.so: $(OBJECTS_SHARED)
132         $(CXX) -shared $(OBJECTS_SHARED) -o $(top_builddir)/savr.so
133
134 otherlibs:
135         $(MAKE) -C $(top_builddir)/cmd.src all
136         $(MAKE) -C $(top_builddir)/sim.src all
137
138 .cc.o:
139         $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $< -o $@
140
141 .asm.hex:
142         $(AVRASM) -l $< -o $@ -e $<.lst
143
144
145 # Remaking configuration
146 # ----------------------
147 checkconf:
148         @if [ -f $(top_builddir)/devel ]; then\
149           $(MAKE) -f conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" freshconf;\
150         fi
151
152 # End of avr.src/Makefile.in