* sim/ucsim/configure, sim/ucsim/cmd.src/newcmdcl.h,
[fw/sdcc] / sim / ucsim / s51.src / Makefile.in
1 #
2 # uCsim s51.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 SERIAL_AVAIL    = @SERIAL_AVAIL@
30
31 SDCC            = sdcc
32 SDCFLAGS        = --debug --stack-after-data --model-small
33 SDCPPFLAGS      = 
34
35 LIBS            = -L$(top_builddir) -lsim -lutil -lguiucsim -lcmd -lsim @LIBS@
36 DL              = @DL@
37 dl_ok           = @dl_ok@
38
39 prefix          = @prefix@
40 exec_prefix     = @exec_prefix@
41 bindir          = @bindir@
42 libdir          = @libdir@
43 datadir         = @datadir@
44 includedir      = @includedir@
45 mandir          = @mandir@
46 man1dir         = $(mandir)/man1
47 man2dir         = $(mandir)/man2
48 infodir         = @infodir@
49 srcdir          = @srcdir@
50 VPATH           = @srcdir@
51
52 EXEEXT          = @EXEEXT@
53
54 OBJECTS_SHARED  = glob.o sim51.o \
55                   inc.o jmp.o mov.o logic.o arith.o bit.o \
56                   timer0.o timer1.o timer2.o port.o interrupt.o \
57                   wdt.o pca.o \
58                   uc51.o uc52.o uc51r.o uc89c51r.o uc251.o \
59                   uc390.o uc390hw.o
60
61 ifeq ($(SERIAL_AVAIL), 1)
62 OBJECTS_SHARED += serial.o
63 endif
64
65 OBJECTS_EXE     = s51.o 
66 OBJECTS         = $(OBJECTS_SHARED) $(OBJECTS_EXE)
67
68 enable_dlso     = @enable_dlso@
69 dlso_ok         = @dlso_ok@
70
71
72 # Compiling entire program or any subproject
73 # ------------------------------------------
74 all: checkconf otherlibs s51.src
75
76
77 # Compiling and installing everything and runing test
78 # ---------------------------------------------------
79 install: all installdirs
80         $(INSTALL) s51$(EXEEXT) $(DESTDIR)$(bindir)/s51$(EXEEXT)
81         $(STRIP) $(DESTDIR)$(bindir)/s51$(EXEEXT)
82
83
84 # Deleting all the installed files
85 # --------------------------------
86 uninstall:
87         rm -f $(DESTDIR)$(bindir)/s51$(EXEEXT)
88
89
90 # Performing self-test
91 # --------------------
92 check: test
93
94 test: test_ser.ihx
95
96 test_ser.ihx: test_ser.rel
97         $(SDCC) $(SDCFLAGS) $<
98
99 # Performing installation test
100 # ----------------------------
101 installcheck:
102
103
104 # Creating installation directories
105 # ---------------------------------
106 installdirs:
107         test -d $(DESTDIR)$(bindir) || $(INSTALL) -d $(DESTDIR)$(bindir)
108
109
110 # Creating dependencies
111 # ---------------------
112 dep: Makefile.dep
113
114 Makefile.dep: $(srcdir)/*.cc $(srcdir)/*.h
115         $(CXXCPP) $(CPPFLAGS) $(M_OR_MM) $(filter %.cc,$^) >Makefile.dep
116
117 include Makefile.dep
118 include $(srcdir)/clean.mk
119
120 #parser.cc: parser.y
121
122 #plex.cc: plex.l
123
124 # My rules
125 # --------
126 .SUFFIXES: .rel
127
128 s51.src: s51$(EXEEXT) shared_lib
129
130 s51$(EXEEXT): $(OBJECTS) $(top_builddir)*.a
131         $(CXX) $(CXXFLAGS) $(OBJECTS) $(LIBS) -o $@
132
133 ifeq ($(dlso_ok),yes)
134 shared_lib: $(top_builddir)s51.so
135 else
136 shared_lib:
137         @$(top_srcdir)/mkecho $(top_builddir) "No 51 shared lib made."
138         @$(top_srcdir)/mkecho $(top_builddir) "(SHAREDLIB="$(SHAREDLIB)",dl_ok="$(dl_ok)",enable_dlso="$(enable_dlso)")"
139 endif
140
141 $(top_builddir)s51.so: $(OBJECTS_SHARED)
142         $(CXX) -shared $(OBJECTS_SHARED) -o $@
143
144 otherlibs:
145         $(MAKE) -C $(top_builddir) libs
146         $(MAKE) -C $(top_builddir)cmd.src all
147         $(MAKE) -C $(top_builddir)sim.src all
148         $(MAKE) -C $(top_builddir)gui.src checkconf ucsim_lib
149
150 .cc.o:
151         $(CXX) $(CXXFLAGS) $(PICOPT) $(CPPFLAGS) -c $< -o $@
152
153 .c.rel:
154         $(SDCC) $(SDCFLAGS) $(SDCPPFLAGS) -c $<
155
156
157 # Remaking configuration
158 # ----------------------
159 checkconf:
160         @if [ -f $(top_builddir)devel ]; then\
161           $(MAKE) -f conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" freshconf;\
162         fi
163
164 # End of s51.src/Makefile.in