# Copyright (c) 1993 Xerox Corporation. All rights reserved. # #-$Id$ # #-$Date$ # MYHOME = /tilde/nanolan MYBIN = $(MYHOME)/bin # # VERY IMPORTANT: # NO target-config-dependent things go in in Makefile directly. # ALL target-config-dependent things go in config.mk, below. # # # # include config.mk here to define: # # PACKAGE - name of this package (e.g. libc) # TARGET_ARCH - target machine architecture (e.g. mc68000) # TARGET_CONFIG - target machine configuration name (e.g. BASE) # # CC - C compiler # CONFIG_CPPFLAGS # CONFIG_CFLAGS # # ASPP - assembler preprocessor (CPP) # CONFIG_ASPPFLAGS # # AS - assembler # CONFIG_ASFLAGS # # LD - loader # CONFIG_LDFLAGS # include config.mk # # location of shared sources # SHARED_SRC_TREE = $(MYHOME)/lib/src INCLUDE = -I. -I$(SHARED_SRC_TREE)/libc -I$(SHARED_SRC_TREE) # # locations of object files # CONFIG_OBJ_TREE = $(MYHOME)/lib/$(TARGET_CONFIG) INSTALL_LIB = $(CONFIG_OBJ_TREE)/lib INSTALL_BIN = $(CONFIG_OBJ_TREE)/bin # # compilation flags, etc. # CPPFLAGS = $(INCLUDE) -D$(TARGET_CONFIG) $(CONFIG_CPPFLAGS) CFLAGS =-c -O $(CONFIG_CFLAGS) ASPPFLAGS = $(INCLUDE) $(CONFIG_ASPPFLAGS) -DASM -D$(TARGET_CONFIG) ASFLAGS = $(CONFIG_ASFLAGS) LDFLAGS = -N -Ttext 0 $(CONFIG_LDFLAGS) # # standard commands and default rules # CHECKIN = $(MYBIN)/checkin CHECKOUT = $(MYBIN)/checkout INSTALL = cp -p .s.o: $(ASPP) $(ASPPFLAGS) $< | $(AS) $(ASFLAGS) -o $@ .c.o: $(CC) $(CPPFLAGS) $(CFLAGS) -c $< -o $@ # # # # # BEGIN PACKAGE-SPECIFIC PART # # # # # # Default target # default: ???? # # SOURCE FILE DEFINITION # # define CSRC SSRC MISCSRC HDEFS MISCDEFS. # # define MAKEDEP_MISCSRC = commands to make MISCSRC dependencies # (dependencies for .c and .s files are done automatically). # CSRC = ???.c SSRC = ???.s MISCSRC = SRC = $(CSRC) $(SSRC) $(MISCSRC) MAKEDEP_MISCSRC = HDEFS = ???.h MISCDEFS = DEFS = $(HDEFS) $(MISCDEFS) # # # INSTALL DEFINITION # # define INSTALL_LIBFILES = targets to be copied into INSTALL_LIB # define INSTALL_BINFILES = targets to be copied into INSTALL_BIN # INSTALL_LIBFILES = ????.a INSTALL_BINFILES = ????.o # # package-specific definitions and rules # COBJ = mypkg.o SOBJ = mypkg_support.o MISCOBJ = mypkg: $(COBJ) $(SOBJ) $(MISCOBJ) $(LD) -o mypkg $(COBJ) $(SOBJ) $(MISCOBJ) \ $(CONFIG_OBJ_TREE)/other/libother.a # # # # # END PACKAGE-SPECIFIC PART # # # # # # # STANDARD TARGETS # # # # make install # install: $(INSTALL_LIBFILES) $(INSTALL_BINFILES) if [ -n "$(INSTALL_LIBFILES)" ] ; then \ ( cd $(INSTALL_LIB) ; rm -f $(INSTALL_LIBFILES) ) ; \ $(INSTALL) $(INSTALL_LIBFILES) $(INSTALL_LIB) ; \ fi if [ -n "$(INSTALL_BINFILES)" ] ; then \ ( cd $(INSTALL_BIN) ; rm -f $(INSTALL_BINFILES) ) ; \ $(INSTALL) $(INSTALL_BINFILES) $(INSTALL_BIN) ; \ fi $(CHECKIN) -l # # make clean # clean: rm -f *.o *~ core a.out *.a *.BAK *.bak *.CKP logmsg.txt # # make get -- get source files without locking # get: $(CHECKOUT) -calledfrommake -u $(SRC) $(DEFS) # # make checkout -- checkout and lock source files # checkout: $(CHECKOUT) -calledfrommake -l Makefile $(SRC) $(DEFS) # # make unlock -- check in and unlock all files # unlock: $(CHECKIN) -calledfrommake -u $(SRC) $(DEFS) Makefile $(MAKE) push # # make save -- check in files but keep locks and working copies # save: $(CHECKIN) -calledfrommake -l $(SRC) $(DEFS) Makefile $(MAKE) push # # make checkin -- check in files, delete working copies # checkin: $(CHECKIN) $(SRC) $(DEFS) $(CHECKIN) -calledfrommake -u -logmsg /dev/null Makefile $(MAKE) push # # make push -- update src directory copies # push: (cd $(SHARED_SRC_TREE)/$(PACKAGE); \ $(CHECKOUT) -calledfrommake -u $(SRC) $(DEFS) ) # # make depend # # NOTE: the makefile must include "# DO NOT DELETE THIS LINE" # and at least one additional line of text after the last target. # "make depend" will replace everything following that line # by a newly-constructed list of dependencies. # # You can modify the behavior of this target by defining $(MAKEDEP_MISCSRC). # makedep: $(CSRC) $(SSRC) $(MISCSRC) echo -n > makedep $(MAKEDEP_MISCSRC) if [ "x$(CSRC)" != x ]; then \ $(CC) -M $(CPPFLAGS) $(CSRC) \ | sed -e '/:$$/d' >> makedep ; \ fi for x in $(SSRC) END ; \ do if [ $$x != END ]; then \ $(ASPP) -M $(ASPPFLAGS) $$x \ | sed -e '/:$$/d' \ | sed -e 's/[.]s[.]o :/.o :/g' >> makedep ; \ fi ; \ done depend: makedep echo '/^# DO NOT DELETE THIS LINE/+1,$$d' > eddep echo '$$r makedep' >> eddep echo 'w' >> eddep rm -f Makefile.bak mv Makefile Makefile.bak cp Makefile.bak Makefile chmod u+w Makefile ex - Makefile < eddep if [ ! -w Makefile.bak ] ; then chmod u-w Makefile ; fi rm -f eddep makedep # # # END OF HUMAN-EDITABLE PART # # # #-$Log$ # # # DO NOT DELETE THIS LINE -- make depend depends on it # and there had better be at least one additional line