Add "pretty" build option
[openafs.git] / src / lwp / Makefile.in
index ffb0679..af5bdab 100644 (file)
@@ -4,40 +4,38 @@
 # This software has been released under the terms of the IBM Public
 # License.  For details, see the LICENSE file in the top-level source
 # directory or online at http://www.openafs.org/dl/license10.html
+#
+# Portions Copyright (c) 2003 Apple Computer, Inc.
+
+srcdir=@srcdir@
+include @TOP_OBJDIR@/src/config/Makefile.config
+include @TOP_OBJDIR@/src/config/Makefile.lwp
 
-DEST=@DEST@
-TOP_INCDIR=@TOP_INCDIR@
-TOP_LIBDIR=@TOP_LIBDIR@
-prefix=@prefix@
-exec_prefix=@exec_prefix@
-bindir=@bindir@
-sbindir=@sbindir@
-libexecdir=@libexecdir@
-libdir=@libdir@
-includedir=@includedir@
-mandir=@mandir@
-afssrvbindir=@afssrvbindir@
-afssrvsbindir=@afssrvsbindir@
-afssrvlibexecdir=@afssrvlibexecdir@
-COMPILE_ET=${TOP_SRCDIR}/comerr/compile_et
-RXGEN=${TOP_SRCDIR}/rxgen/rxgen
-TOP_SRCDIR=@TOP_SRCDIR@
-SYS_NAME=@AFS_SYSNAME@
-
-SHELL = /bin/sh
-
-include ../config/Makefile.${SYS_NAME}
-
-# this is important code, so let's optimize it.  The optimizer aggravates any
-# subtle bugs that may have been introduced in process.s, be warned!
-OPTIMIZE=${LWP_OPTMZ}
-
-CFLAGS=${OPTIMIZE} -I${TOP_SRCDIR}/config -I${TOP_INCDIR} ${XCFLAGS}
+
+DBG=${LWP_DBG}
+OPTMZ=${LWP_OPTMZ}
 
 LIBOBJS=lwp.o process.o lock.o iomgr.o timer.o fasttime.o preempt.o \
        waitkey.o threadname.o AFS_component_version_number.o
 
-all: ${TOP_LIBDIR}/liblwp.a ${TOP_INCDIR}/lock.h ${TOP_INCDIR}/lwp.h ${TOP_INCDIR}/preempt.h ${TOP_INCDIR}/timer.h
+all: ${TOP_LIBDIR}/liblwp.a depinstall
+
+depinstall: ${TOP_INCDIR}/lock.h ${TOP_INCDIR}/lwp.h ${TOP_INCDIR}/preempt.h ${TOP_INCDIR}/timer.h
+
+${TOP_LIBDIR}/liblwp.a: liblwp.a
+       ${INSTALL_DATA} $? $@
+
+${TOP_INCDIR}/lock.h: lock.h
+       ${INSTALL_DATA} $? $@
+
+${TOP_INCDIR}/lwp.h: lwp.h
+       ${INSTALL_DATA} $? $@
+
+${TOP_INCDIR}/preempt.h: preempt.h
+       ${INSTALL_DATA} $? $@
+
+${TOP_INCDIR}/timer.h: timer.h
+       ${INSTALL_DATA} $? $@
 
 #
 # Build rules
@@ -47,64 +45,133 @@ liblwp.a: ${LIBOBJS}
        $(AR) crv $@ ${LIBOBJS}
        $(RANLIB) $@
 
+# This is required so sgi_64+ does not try to build this file.
 process.s:
-       echo Nothing to be done for process.s
-       # This is required so sgi_64+ does not try to build this file.
-
-process.o      : process.s process.c
-       @case "$(SYS_NAME)" in \
-       pmax_he1) \
-               $(CC) -c -I${TOP_INCDIR} process.s;; \
-       sun4c_51 | sun4c_52 | sun4m_51 | sun4m_52 | sun4c_53 | sun4m_53  | sun4_53 | sun4_52 | sun4_54 | sun4c_54 | sun4m_54 | sun4x_5? | sunx86_54) \
-               /usr/ccs/lib/cpp -P -I${TOP_INCDIR} process.s process.ss; \
+       @echo Nothing to be done for process.s
+
+# Making process.o for $(SYS_NAME)
+process.o      : process.s process.i386.s process.amd64.s process.c lwp.o
+       @set -x; case "$(SYS_NAME)" in \
+       sun4c_51 | sun4c_52 | sun4m_51 | sun4m_52 | sun4c_53 | sun4m_53  | sun4_53 | sun4_52 | sun4_54 | sun4c_54 | sun4m_54 | sun4x_5* | arm_linux* ) \
+               $(PATH_CPP) -P -I${TOP_INCDIR} ${srcdir}/process.s > process.ss; \
                ${AS} process.ss -o process.o; \
                        $(RM) process.ss ;; \
        sgi_5* ) \
-               $(CC) -c -I${TOP_INCDIR} -KPIC -G0  process.s;; \
+               $(CCOBJ) ${LWP_DBG} ${LWP_OPTMZ} -c -I${TOP_INCDIR} -KPIC -G0  ${srcdir}/process.s;; \
        sgi_61 | sgi_62 | sgi_63 ) \
-               $(CC) -c ${XCFLAGS} -I${TOP_INCDIR} -KPIC -G0  process.s;; \
-       s390*) \
-               /lib/cpp -P -I${TOP_INCDIR} process.s >process.ss; \
+               $(CCOBJ) ${LWP_DBG} ${LWP_OPTMZ} -c ${XCFLAGS} ${ARCHFLAGS} -I${TOP_INCDIR} -KPIC -G0  ${srcdir}/process.s;; \
+       s390_*) \
+               $(PATH_CPP) -P -I${TOP_INCDIR} ${srcdir}/process.s390.s >process.ss; \
+               ${AS} -ahlns process.ss -o process.o >process.lst; \
+               $(RM) process.ss ;; \
+       s390x_*) \
+               $(PATH_CPP) -P -I${TOP_INCDIR} ${srcdir}/process.s390x.s >process.ss; \
                ${AS} -ahlns process.ss -o process.o >process.lst; \
                $(RM) process.ss ;; \
-       ppc_darwin* ) \
-               $(CC) -c ${XCFLAGS} -I${TOP_INCDIR} process.s;; \
-       i386_fbsd* ) \
-               /usr/bin/cpp -P process.fbsd.s > process.ss; \
+       *_darwin* ) \
+               $(RM) -f process.o ; \
+               CURRENTBUILDARCH="${ARCHFLAGS}"; \
+               if [ -z "$${CURRENTBUILDARCH}" ] ; then \
+                   CURRENTBUILDARCH=`$(CC) -dM -E -xc /dev/null | grep 'ppc\|i386\|x86_64\|arm'`; \
+               fi; \
+               ppc=`echo $${CURRENTBUILDARCH} | grep -q ppc && echo process.ppc.o` ; \
+               i386=`echo $${CURRENTBUILDARCH} | grep -q i386 && echo process.i386.o` ; \
+               amd64=`echo $${CURRENTBUILDARCH} | grep -q x86_64 && echo process.amd64.o` ; \
+               armv6=`echo $${CURRENTBUILDARCH} | grep -q armv6 && echo process.armv6.o` ; \
+               armv7=`echo $${CURRENTBUILDARCH} | grep -q armv7 && echo process.armv7.o` ; \
+               if [ -z "$${ppc}" -a -z "$${i386}" -a -z "$${amd64}" -a -z "$${armv6}" -a -z "$${armv7}" ] ; then \
+                       if [ `arch` = ppc ] ; then \
+                               ppc=yes ; \
+                       else \
+                               i386=yes ; \
+                       fi ; \
+               fi ; \
+               if [ -n "$${armv6}" ] ; then \
+                       $(CC) -x assembler-with-cpp -c -arch armv6 -I${TOP_INCDIR} -I${srcdir} ${srcdir}/process.s -o "$${armv6}" ; \
+                       if [ -z "$${i386}" -a -z "$${amd64}" -a -z "$${ppc}" -a -z "$${armv7}" ] ; then \
+                               ${MV} "$${armv6}" process.o ; \
+                       fi ; \
+               fi ; \
+               if [ -n "$${armv7}" ] ; then \
+                       $(CC) -x assembler-with-cpp -c -arch armv7 -I${TOP_INCDIR} -I${srcdir} ${srcdir}/process.s -o "$${armv7}" ; \
+                       if [ -z "$${i386}" -a -z "$${amd64}" -a -z "$${ppc}" -a -z "$${armv6}" ] ; then \
+                               ${MV} "$${armv7}" process.o ; \
+                       fi ; \
+               fi ; \
+               if [ -n "$${ppc}" ] ; then \
+                       $(CC) ${LWP_DBG} ${LWP_OPTMZ} -c -arch ppc -I${TOP_INCDIR} ${srcdir}/process.s -o "$${ppc}" ; \
+                       if [ -z "$${i386}" -a -z "$${amd64}" -a -z "$${armv6}" -a -z "$${armv7}" ] ; then \
+                               ${MV} "$${ppc}" process.o ; \
+                       fi ; \
+               fi ; \
+               if [ -n "$${i386}" ] ; then \
+                       $(CC) -x assembler-with-cpp -c -arch i386 -I${TOP_INCDIR} -I${srcdir} ${srcdir}/process.i386.s -o "$${i386}" ; \
+                       if [ -z "$${ppc}" -a -z "$${amd64}" -a -z "$${armv6}" -a -z "$${armv7}" ] ; then \
+                               ${MV} "$${i386}" process.o ; \
+                       fi ; \
+               fi ; \
+               if [ -n "$${amd64}" ] ; then \
+                       $(CC) -x assembler-with-cpp -c -arch x86_64 -I${TOP_INCDIR} -I${srcdir} ${srcdir}/process.amd64.s -o "$${amd64}" ; \
+                       if [ -z "$${ppc}" -a -z "$${i386}" -a -z "$${armv6}" -a -z "$${armv7}" ] ; then \
+                               ${MV} "$${amd64}" process.o ; \
+                       fi ; \
+               fi ; \
+               if [ ! -f process.o ] ; then \
+                       lipo -create $${amd64} $${i386} $${ppc} $${armv6} $${armv7} -output process.o ;\
+               fi ;; \
+       i386_*bsd*) \
+               cp ${srcdir}/process.i386.s process.S ; \
+               ${CCOBJ} -DIGNORE_STDS_H -E -I${srcdir} -I${TOP_INCDIR} process.S > process.ss ; \
+               ${AS} process.ss -o process.o ;  \
+               $(RM) -f process.S ;;\
+       amd64_*bsd*) \
+               cp ${srcdir}/process.amd64.s process.S ; \
+               ${CCOBJ} -DIGNORE_STDS_H -E -I${srcdir} -I${TOP_INCDIR} process.S > process.ss ; \
+               ${AS} process.ss -o process.o ;  \
+               $(RM) -f process.S ;;\
+       ncrx86_* | sunx86_58 | sunx86_59 ) \
+               $(PATH_CPP) -P -D__sun -D__i386 -DIGNORE_STDS_H -I${TOP_INCDIR} -I${srcdir} ${srcdir}/process.i386.s > process.ss; \
                ${AS} -o process.o process.ss; \
                $(RM) process.ss ;; \
-       hp* | *_linux* | sgi_64 | sgi_65 ) \
-               ${CC} ${CFLAGS} -c process.c;; \
-       ncrx86_*) \
-               /usr/ccs/lib/cpp -P -I${TOP_INCDIR} process.s process.ss; \
+       sunx86_510 | sunx86_511) \
+               if [ "${ASFLAGS}" = "-m64" ] ; then \
+                       CURRENTBUILDARCH=amd64 ; \
+               else \
+                       XCPPFLAGS="-D__i386" ; \
+                       CURRENTBUILDARCH=i386 ; \
+               fi ; \
+               $(PATH_CPP) $${XCPPFLAGS} -P -D__sun -DIGNORE_STDS_H -I${TOP_INCDIR} -I${srcdir} ${srcdir}/process.$${CURRENTBUILDARCH}.s > process.ss ; \
+               ${AS} ${ASFLAGS} -o process.o process.ss ; \
+               $(RM) process.ss ;; \
+       alpha_nbsd* ) \
+               $(PATH_CPP) -DASSEMBLER -P -I${TOP_INCDIR} ${srcdir}/process.s > process.ss; \
                ${AS} -o process.o process.ss; \
                $(RM) process.ss ;; \
+       hp* | *_linux* | *_umlinux* | sgi_64 | sgi_65 ) \
+               $(AFS_CCRULE_NOQ) -c ${srcdir}/process.c;; \
        alpha_osf1 | alpha_osf20 |  alpha_osf30 | alpha_osf32 | alpha_osf32c | alpha_dux?? ) \
-               ${AS} -v  -P -DOSF -I${TOP_INCDIR} -DASSEMBLER process.s; \
+               ${AS} -v  -P -DOSF -I${TOP_INCDIR} -DASSEMBLER ${srcdir}/process.s; \
                ${AS} -v process.i -o process.o;; \
-       *_obsd* ) \
-               cp process.s process.S ; \
-               ${CC} -E -I${TOP_INCDIR} process.S >process.ss ; \
-               ${AS} process.ss -o process.o ;  \
-               $(RM) -f process.S ;;\
-       hp_ux110 ) \
-               ${CC} ${CFLAGS} -c process.c;; \
+       ia64_hpux11* | hp_ux11* ) \
+               $(AFS_CCRULE_NOQ) -c ${srcdir}/process.c;; \
+       i386_*) \
+               $(PATH_CPP) -P -I${TOP_INCDIR} -I${srcdir} ${srcdir}/process.i386.s > process.ss; \
+               ${AS} process.ss -o process.o; \
+               $(RM) process.ss ;; \
        *) \
-               /lib/cpp -P -I${TOP_INCDIR} process.s process.ss; \
+               $(PATH_CPP) -P -I${TOP_INCDIR} ${srcdir}/process.s > process.ss; \
                ${AS} process.ss -o process.o; \
                $(RM) process.ss ;; \
        esac
 
 iomgr.o                : iomgr.c lwp.h timer.h
-               ${CC} -c ${CFLAGS} iomgr.c
-
 preempt.o      : preempt.c lwp.h preempt.h
 lwp.o          : lwp.c lwp.h
        case "$(SYS_NAME)" in \
                rs_aix*) \
-                       $(CC) -I${TOP_SRCDIR}/config -I${TOP_INCDIR} -c lwp.c;; \
+                       $(CCOBJ) ${LWP_DBG} ${LWP_OPTMZ} -I${srcdir} -I. -I${TOP_OBJDIR}/src/config -I${TOP_INCDIR} -c ${srcdir}/lwp.c;; \
                *)  \
-                       $(CC) ${CFLAGS} -c lwp.c;; \
+                       $(AFS_CCRULE_NOQ) ${srcdir}/lwp.c;; \
                esac
 lock.o         : lock.c lock.h lwp.h
 timer.o                : timer.c
@@ -117,31 +184,28 @@ exc_handling.o    : exc_handling.c
 # tests
 #
 rw: rw.o liblwp.a $(TOP_LIBDIR)/util.a
-       ${CC} ${CFLAGS} -o rw rw.o liblwp.a $(TOP_LIBDIR)/util.a
-
-rw.o: rw.c
-       ${CC} ${CFLAGS} -c rw.c
-
+       $(AFS_LDRULE) rw.o liblwp.a $(TOP_LIBDIR)/util.a
 
 #
 # Install targets
 #
-install: ${DESTDIR}${libdir}/liblwp.a ${DESTDIR}${includedir}/lock.h ${DESTDIR}${includedir}/lwp.h ${DESTDIR}${includedir}/preempt.h ${DESTDIR}${includedir}/timer.h
-
-${DEST}/lib/liblwp.a: liblwp.a
-       ${INSTALL} $? $@
-
-${DEST}/include/lock.h: lock.h
-       ${INSTALL} $? $@
-
-${DEST}/include/lwp.h: lwp.h
-       ${INSTALL} $? $@
-
-${DEST}/include/preempt.h: preempt.h
-       ${INSTALL} $? $@
-
-${DEST}/include/timer.h: timer.h
-       ${INSTALL} $? $@
+install: liblwp.a lock.h lwp.h preempt.h timer.h
+       ${INSTALL} -d ${DESTDIR}${libdir}
+       ${INSTALL} -d ${DESTDIR}${includedir}
+       ${INSTALL_DATA} liblwp.a ${DESTDIR}${libdir}/liblwp.a
+       ${INSTALL_DATA} ${srcdir}/lock.h ${DESTDIR}${includedir}/lock.h
+       ${INSTALL_DATA} ${srcdir}/lwp.h ${DESTDIR}${includedir}/lwp.h
+       ${INSTALL_DATA} ${srcdir}/preempt.h ${DESTDIR}${includedir}/preempt.h
+       ${INSTALL_DATA} ${srcdir}/timer.h ${DESTDIR}${includedir}/timer.h
+
+dest: liblwp.a lock.h lwp.h preempt.h timer.h
+       ${INSTALL} -d ${DEST}/lib
+       ${INSTALL} -d ${DEST}/include
+       ${INSTALL_DATA} liblwp.a ${DEST}/lib/liblwp.a
+       ${INSTALL_DATA} ${srcdir}/lock.h ${DEST}/include/lock.h
+       ${INSTALL_DATA} ${srcdir}/lwp.h ${DEST}/include/lwp.h
+       ${INSTALL_DATA} ${srcdir}/preempt.h ${DEST}/include/preempt.h
+       ${INSTALL_DATA} ${srcdir}/timer.h ${DEST}/include/timer.h
 
 #
 # Misc. targets
@@ -150,35 +214,3 @@ clean:
        $(RM) -f *.o *.a core AFS_component_version_number.c
 
 include ../config/Makefile.version
-${DESTDIR}${libdir}/liblwp.a: liblwp.a
-       ${INSTALL} $? $@
-
-${TOP_LIBDIR}/liblwp.a: liblwp.a
-       ${INSTALL} $? $@
-
-${DESTDIR}${includedir}/lock.h: lock.h
-       ${INSTALL} $? $@
-
-${TOP_INCDIR}/lock.h: lock.h
-       ${INSTALL} $? $@
-
-${DESTDIR}${includedir}/lwp.h: lwp.h
-       ${INSTALL} $? $@
-
-${TOP_INCDIR}/lwp.h: lwp.h
-       ${INSTALL} $? $@
-
-${DESTDIR}${includedir}/preempt.h: preempt.h
-       ${INSTALL} $? $@
-
-${TOP_INCDIR}/preempt.h: preempt.h
-       ${INSTALL} $? $@
-
-${DESTDIR}${includedir}/timer.h: timer.h
-       ${INSTALL} $? $@
-
-${TOP_INCDIR}/timer.h: timer.h
-       ${INSTALL} $? $@
-
-dest: ${DEST}/lib/liblwp.a ${DEST}/include/lock.h ${DEST}/include/lwp.h ${DEST}/include/preempt.h ${DEST}/include/timer.h
-