2 # uCsim s51.src/Makefile
4 # (c) Drotos Daniel, Talker Bt. 1997
17 top_builddir = @top_builddir@
18 top_srcdir = @top_srcdir@
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
29 SHAREDLIB = @SHAREDLIB@
32 SDCFLAGS = --debug --stack-after-data --model-small
35 LIBS = -L$(top_builddir) -lsim -lutil -lguiucsim -lcmd -lsim @LIBS@
40 exec_prefix = @exec_prefix@
44 datarootdir = @datarootdir@
45 includedir = @includedir@
47 man1dir = $(mandir)/man1
48 man2dir = $(mandir)/man2
55 OBJECTS_SHARED = glob.o sim51.o \
56 inc.o jmp.o mov.o logic.o arith.o bit.o \
57 timer0.o timer1.o timer2.o serial.o port.o interrupt.o \
59 uc51.o uc52.o uc51r.o uc89c51r.o uc251.o \
62 OBJECTS = $(OBJECTS_SHARED) $(OBJECTS_EXE)
64 enable_dlso = @enable_dlso@
68 # Compiling entire program or any subproject
69 # ------------------------------------------
70 all: checkconf otherlibs s51.src
73 # Compiling and installing everything and runing test
74 # ---------------------------------------------------
75 install: all installdirs
76 $(INSTALL) s51$(EXEEXT) $(DESTDIR)$(bindir)/s51$(EXEEXT)
77 $(STRIP) $(DESTDIR)$(bindir)/s51$(EXEEXT)
80 # Deleting all the installed files
81 # --------------------------------
83 rm -f $(DESTDIR)$(bindir)/s51$(EXEEXT)
86 # Performing self-test
87 # --------------------
92 test_ser.ihx: test_ser.rel
93 $(SDCC) $(SDCFLAGS) $<
95 # Performing installation test
96 # ----------------------------
100 # Creating installation directories
101 # ---------------------------------
103 test -d $(DESTDIR)$(bindir) || $(INSTALL) -d $(DESTDIR)$(bindir)
106 # Creating dependencies
107 # ---------------------
110 Makefile.dep: $(srcdir)/*.cc $(srcdir)/*.h
111 $(CXXCPP) $(CPPFLAGS) $(M_OR_MM) $(filter %.cc,$^) >Makefile.dep
114 include $(srcdir)/clean.mk
124 s51.src: s51$(EXEEXT) shared_lib
126 s51$(EXEEXT): $(OBJECTS) $(top_builddir)/*.a
127 $(CXX) $(CXXFLAGS) $(LDFLAGS) $(OBJECTS) $(LIBS) -o $@
129 ifeq ($(dlso_ok),yes)
130 shared_lib: $(top_builddir)/s51.so
133 @$(top_srcdir)/mkecho $(top_builddir) "No 51 shared lib made."
134 @$(top_srcdir)/mkecho $(top_builddir) "(SHAREDLIB="$(SHAREDLIB)",dl_ok="$(dl_ok)",enable_dlso="$(enable_dlso)")"
137 $(top_builddir)/s51.so: $(OBJECTS_SHARED)
138 $(CXX) -shared $(LDFLAGS) $(OBJECTS_SHARED) -o $@
141 $(MAKE) -C $(top_builddir) libs
142 $(MAKE) -C $(top_builddir)/cmd.src all
143 $(MAKE) -C $(top_builddir)/sim.src all
144 $(MAKE) -C $(top_builddir)/gui.src checkconf ucsim_lib
147 $(CXX) $(CXXFLAGS) $(PICOPT) $(CPPFLAGS) -c $< -o $@
150 $(SDCC) $(SDCFLAGS) $(SDCPPFLAGS) -c $<
153 # Remaking configuration
154 # ----------------------
156 @if [ -f $(top_builddir)/devel ]; then\
157 $(MAKE) -f conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" freshconf;\
160 # End of s51.src/Makefile.in