2 # uCsim hc08.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@
33 LIBS = -L$(top_builddir) -lsim -lutil -lguiucsim -lcmd -lsim @LIBS@
38 exec_prefix = @exec_prefix@
42 datarootdir = @datarootdir@
43 includedir = @includedir@
45 man1dir = $(mandir)/man1
46 man2dir = $(mandir)/man2
51 OBJECTS_SHARED = glob.o \
55 OBJECTS = $(OBJECTS_SHARED) $(OBJECTS_EXE)
59 enable_dlso = @enable_dlso@
62 #TEST_OBJ = test_bit.hex test_dis.hex test_mov.hex test_jmp.hex \
65 # Compiling entire program or any subproject
66 # ------------------------------------------
67 all: checkconf otherlibs hc08.src tests
72 # Compiling and installing everything and runing test
73 # ---------------------------------------------------
74 install: all installdirs
75 $(INSTALL) shc08$(EXEEXT) $(DESTDIR)$(bindir)/shc08$(EXEEXT)
76 $(STRIP) $(DESTDIR)$(bindir)/shc08$(EXEEXT)
79 # Deleting all the installed files
80 # --------------------------------
82 rm -f $(DESTDIR)$(bindir)/shc08$(EXEEXT)
85 # Performing self-test
86 # --------------------
92 # Performing installation test
93 # ----------------------------
97 # Creating installation directories
98 # ---------------------------------
100 test -d $(DESTDIR)$(bindir) || $(INSTALL) -d $(DESTDIR)$(bindir)
103 # Creating dependencies
104 # ---------------------
107 Makefile.dep: $(srcdir)/*.cc $(srcdir)/*.h
108 $(CXXCPP) $(CPPFLAGS) $(M_OR_MM) $(filter %.cc,$^) >Makefile.dep
110 -include Makefile.dep
111 include $(srcdir)/clean.mk
117 hc08.src: shc08$(EXEEXT) shared_lib
119 shc08$(EXEEXT): $(OBJECTS) $(top_builddir)/*.a
120 $(CXX) $(CXXFLAGS) $(LDFLAGS) -o $@ $(OBJECTS) $(LIBS)
122 ifeq ($(dlso_ok),yes)
123 shared_lib: $(top_builddir)/shc08.so
126 @$(top_srcdir)/mkecho $(top_builddir) "No hc08 shared lib made."
127 @$(top_srcdir)/mkecho $(top_builddir) "(SHAREDLIB="$(SHAREDLIB)",dl_ok="$(dl_ok)",enable_dlso="$(enable_dlso)")"
130 $(top_builddir)/shc08.so: $(OBJECTS_SHARED)
131 $(CXX) -shared $(LDFLAGS) $(OBJECTS_SHARED) -o $(top_builddir)/shc08.so
134 $(MAKE) -C $(top_builddir)/cmd.src all
135 $(MAKE) -C $(top_builddir)/sim.src all
138 $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $< -o $@
141 $(HC08ASM) -l $< -o $@ -e $<.lst
144 # Remaking configuration
145 # ----------------------
147 @if [ -f $(top_builddir)/devel ]; then\
148 $(MAKE) -f conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" freshconf;\
151 # End of hc08.src/Makefile.in