# 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.
# This is a pthread safe library containing rx, rxkad and des.
srcdir=@srcdir@
include @TOP_OBJDIR@/src/config/Makefile.config
+include @TOP_OBJDIR@/src/config/Makefile.pthread
+
+
+MODULE_CFLAGS = -DRXDEBUG
-CC=${MT_CC}
-INCLUDES=-I. -I${srcdir} -I${TOP_INCDIR} -I.. -I${srcdir}/../rx -I${srcdir}../des -I../des \
- -I../rxkad -I${srcdir}/../rxkad -I../rxstat -I../fsint
-CFLAGS = ${OPTMZ} ${DBG} ${INCLUDES} -DRXDEBUG ${MT_CFLAGS} -I${TOP_OBJDIR}/src/config
SFLAGS=-P -I${TOP_INCDIR}
-RX = ../rx
-CCRULE = ${CC} ${CFLAGS} -c $?
-RXKAD = ../rxkad
-RXSTAT = ../rxstat
-FSINT = ../fsint
-DES = ../des
-COMERR = ../comerr
-UTIL = ../util
+
+RX = ${srcdir}/../rx
+RXKAD = ${srcdir}/../rxkad
+RXSTAT = ${srcdir}/../rxstat
+FSINT = ${srcdir}/../fsint
+COMERR = ${srcdir}/../comerr
+UTIL = ${srcdir}/../util
SYS = ${srcdir}/../sys
+LWP = ${srcdir}/../lwp
SYSOBJS =\
syscall.o
UTILOBJS =\
+ assert.o \
casestrcpy.o \
base64.o
xdr_array.o \
xdr_arrayn.o \
xdr_rx.o \
+ xdr_mem.o \
+ xdr_len.o \
xdr_int32.o \
xdr_int64.o \
xdr_afsuuid.o \
rx_pthread.o \
rx.o \
rx_null.o \
+ rx_opaque.o \
rx_conncache.o \
rx_globals.o \
+ rx_identity.o \
rx_getaddr.o \
rx_misc.o \
rx_packet.o \
rx_rdwr.o \
+ rx_stats.o \
rx_trace.o \
rx_multi.o
fcrypt.o \
crypt_conn.o
-DESOBJS =\
- des.o \
- cbc_encrypt.o \
- pcbc_encrypt.o \
- cksum.o \
- new_rnd_key.o \
- key_sched.o \
- debug_decl.o \
- quad_cksum.o \
- key_parity.o \
- weak_key.o \
- strng_to_key.o \
- misc.o \
- util.o
-
-CRYPT_OBJ = crypt.o
+LWPOBJS = \
+ fasttime.o \
+ lock.o
LIBOBJS = \
${RXOBJS} \
- ${DESOBJS} \
${XDROBJS} \
${RXKADOBJS} \
${COMERROBJS} \
${UTILOBJS} \
${SYSOBJS} \
- ${CRYPT_OBJ} \
${RXSTATOBJS} \
+ ${LWPOBJS} \
${FSINTOBJS}
all: ${TOP_LIBDIR}/libafsrpc.a
-install: ${DESTDIR}${libdir}/libafsrpc.a
-
-${DEST}/lib/libafsrpc.a: libafsrpc.a
- ${INSTALL} $? $@
+${TOP_LIBDIR}/libafsrpc.a: libafsrpc.a
+ ${INSTALL_DATA} $? $@
libafsrpc.a: ${LIBOBJS}
$(RM) -f $@
$(RANLIB) $@
case "${SYS_NAME}" in \
rs_aix*) \
- $(AR) crv $@ ${srcdir}/../sys/afsl.exp;; \
- esac
+ $(AR) crv $@ ../sys/afsl.exp;; \
+ esac
rx_event.o: ${RX}/rx_event.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_event.c
rx_user.o: ${RX}/rx_user.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_user.c
rx_pthread.o: ${RX}/rx_pthread.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_pthread.c
+CFLAGS_rx.o = @CFLAGS_NOERROR@
rx.o: ${RX}/rx.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx.c
rx_conncache.o: ${RX}/rx_conncache.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_conncache.c
rx_null.o: ${RX}/rx_null.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_null.c
+
+rx_opaque.o: ${RX}/rx_opaque.c
+ $(AFS_CCRULE) $(RX)/rx_opaque.c
+
+rx_globals.o: ${RX}/rx_globals.c
+ $(AFS_CCRULE) $(RX)/rx_globals.c
-rx_globals.o: ${RX}/rx_globals.c
- ${CCRULE}
+rx_identity.o: ${RX}/rx_identity.c
+ $(AFS_CCRULE) $(RX)/rx_identity.c
rx_getaddr.o: ${RX}/rx_getaddr.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_getaddr.c
rx_misc.o: ${RX}/rx_misc.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_misc.c
rx_packet.o: ${RX}/rx_packet.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_packet.c
+
+rx_stats.o: ${RX}/rx_stats.c
+ $(AFS_CCRULE) $(RX)/rx_stats.c
rx_rdwr.o: ${RX}/rx_rdwr.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_rdwr.c
rx_trace.o: ${RX}/rx_trace.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_trace.c
rx_multi.o: ${RX}/rx_multi.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/rx_multi.c
+
+${RXOBJS}: ${RX}/rx.h ${RX}/rx_user.h ${RX}/rx_globals.h \
+ ${RX}/rx_clock.h ${RX}/rx_queue.h ${RX}/rx_event.h
rxkad_client.o: ${RXKAD}/rxkad_client.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/rxkad_client.c
rxkad_server.o: ${RXKAD}/rxkad_server.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/rxkad_server.c
rxkad_common.o: ${RXKAD}/rxkad_common.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/rxkad_common.c
ticket.o: ${RXKAD}/ticket.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/ticket.c
+CFLAGS_ticket5.o = @CFLAGS_NOERROR@
ticket5.o: ${RXKAD}/ticket5.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad -I$(RXKAD) $(RXKAD)/ticket5.c
crc.o: ${RXKAD}/crc.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/crc.c
+
+md4.o: ${RXKAD}/md4.c
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/md4.c
+
+md5.o: ${RXKAD}/md5.c
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/md5.c
fcrypt.o: ${RXKAD}/fcrypt.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/fcrypt.c
crypt_conn.o: ${RXKAD}/crypt_conn.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/crypt_conn.c
-AFS_component_version_number.o: ${RX}/AFS_component_version_number.c
- ${CCRULE}
+AFS_component_version_number.o: ${TOP_OBJDIR}/src/rx/AFS_component_version_number.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/rx/AFS_component_version_number.c
xdr.o: ${RX}/xdr.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr.c
xdr_int32.o: ${RX}/xdr_int32.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_int32.c
xdr_int64.o: ${RX}/xdr_int64.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_int64.c
xdr_array.o: ${RX}/xdr_array.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_array.c
xdr_arrayn.o: ${RX}/xdr_arrayn.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_arrayn.c
xdr_float.o: ${RX}/xdr_float.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_float.c
+
+xdr_len.o: ${RX}/xdr_len.c
+ $(AFS_CCRULE) $(RX)/xdr_len.c
xdr_mem.o: ${RX}/xdr_mem.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_mem.c
xdr_rec.o: ${RX}/xdr_rec.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_rec.c
xdr_refernce.o: ${RX}/xdr_refernce.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_refernce.c
xdr_rx.o: ${RX}/xdr_rx.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_rx.c
xdr_update.o: ${RX}/xdr_update.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_update.c
xdr_afsuuid.o: ${RX}/xdr_afsuuid.c
- ${CCRULE}
-
-# Note that the special case statement for compiling des.c is present
-# simply to work around a compiler bug on HP-UX 11.0. The symptom of
-# the problem is that linking the pthread fileserver fails with messages
-# such as
-#
-# pxdb internal warning: cu[84]: SLT_SRCFILE[411] out of synch
-# Please contact your HP Support representative
-# pxdb internal warning: cu[84]: SLT_SRCFILE[442] out of synch
-# pxdb internal warning: cu[84]: SLT_SRCFILE[450] out of synch
-# pxdb internal warning: cu[84]: SLT_SRCFILE[529] out of synch
-# pxdb internal warning: cu[84]: SLT_SRCFILE[544] out of synch
-# ...
-# pxdb32: internal error. File won't be debuggable (still a valid executable)
-# *** Error exit code 10
-#
-# The problematic version of pxdb is:
-#
-# $ what /opt/langtools/bin/pxdb32
-# /opt/langtools/bin/pxdb32:
-# HP92453-02 A.10.0A HP-UX SYMBOLIC DEBUGGER (PXDB) $Revision$
-#
-# The problem occurs when -g and -O are both used when compiling des.c.
-# The simplest way to work around the problem is to leave out either -g or -O.
-# Since des.c is relatively stable I've chosen to eliminate -g rather
-# than take any hit in performance.
-
-des.o: ${DES}/des.c
- set -x; \
- case ${SYS_NAME} in \
- hp_ux11*) \
- set X `echo ${CCRULE} | sed s/-g//`; shift; \
- "$$@" \
- ;; \
- *) \
- ${CCRULE} \
- ;; \
- esac
-
-crypt.o: ${DES}/crypt.c
- ${CCRULE}
-
-cbc_encrypt.o: ${DES}/cbc_encrypt.c
- ${CCRULE}
-
-pcbc_encrypt.o: ${DES}/pcbc_encrypt.c
- ${CCRULE}
-
-cksum.o: ${DES}/cksum.c
- ${CCRULE}
-
-new_rnd_key.o: ${DES}/new_rnd_key.c
- ${CCRULE}
-
-key_sched.o: ${DES}/key_sched.c
- ${CCRULE}
-
-debug_decl.o: ${DES}/debug_decl.c
- ${CCRULE}
-
-quad_cksum.o: ${DES}/quad_cksum.c
- ${CCRULE}
-
-key_parity.o: ${DES}/key_parity.c
- ${CCRULE}
-
-weak_key.o: ${DES}/weak_key.c
- ${CCRULE}
-
-strng_to_key.o: ${DES}/strng_to_key.c
- ${CCRULE}
-
-misc.o: ${DES}/misc.c
- ${CCRULE}
-
-util.o: ${DES}/util.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RX)/xdr_afsuuid.c
error_msg.o: ${COMERR}/error_msg.c
- ${CCRULE}
+ $(AFS_CCRULE) $(COMERR)/error_msg.c
et_name.o: ${COMERR}/et_name.c
- ${CCRULE}
+ $(AFS_CCRULE) $(COMERR)/et_name.c
com_err.o: ${COMERR}/com_err.c
- ${CCRULE}
+ $(AFS_CCRULE) $(COMERR)/com_err.c
+
casestrcpy.o: ${UTIL}/casestrcpy.c
- ${CCRULE}
+ $(AFS_CCRULE) $(UTIL)/casestrcpy.c
+
+assert.o: ${UTIL}/assert.c
+ $(AFS_CCRULE) $(UTIL)/assert.c
base64.o: ${UTIL}/base64.c
- ${CCRULE}
+ $(AFS_CCRULE) $(UTIL)/base64.c
+
+fasttime.o: ${LWP}/fasttime.c
+ $(AFS_CCRULE) $(LWP)/fasttime.c
+
+lock.o: ${LWP}/lock.c
+ $(AFS_CCRULE) $(LWP)/lock.c
syscall.o: ${SYS}/syscall.s
case "$(SYS_NAME)" in \
sun4x_5* | sunx86_5*) \
- /usr/ccs/lib/cpp ${SFLAGS} ${SYS}/syscall.s syscall.ss; \
+ $(PATH_CPP) ${SFLAGS} ${SYS}/syscall.s > syscall.ss; \
as -o syscall.o syscall.ss; \
$(RM) syscall.ss;; \
- sgi_* | ppc_darwin* ) \
- ${CC} ${CFLAGS} -c ${SYS}/syscall.s;; \
+ arm_darwin_* ) \
+ touch syscall.c ; \
+ ${CC} ${AFS_CFLAGS} -c syscall.c;; \
+ sgi_* | *_darwin_* ) \
+ ${CC} ${AFS_CFLAGS} -c ${SYS}/syscall.s;; \
alpha_dux?? ) \
- ${AS} -P ${CFLAGS} -D_NO_PROTO -DMACH -DOSF -nostdinc -traditional -DASSEMBLER ${SYS}/syscall.s; \
+ ${AS} -P ${AFS_CFLAGS} -D_NO_PROTO -DMACH -DOSF -nostdinc -traditional -DASSEMBLER ${SYS}/syscall.s; \
${AS} -o syscall.o syscall.i; \
$(RM) -f syscall.ss syscall.i;; \
- *fbsd* ) \
- touch syscall.o ;; \
+ *bsd* ) \
+ touch syscall.c ; \
+ ${CC} ${AFS_CFLAGS} -c syscall.c;; \
*) \
- /lib/cpp ${SFLAGS} ${SYS}/syscall.s syscall.ss; \
+ $(PATH_CPP) ${SFLAGS} ${SYS}/syscall.s > syscall.ss; \
as -o syscall.o syscall.ss; \
$(RM) syscall.ss;; \
esac
rxstat.o: ${RXSTAT}/rxstat.c
- ${CCRULE}
+ $(AFS_CCRULE) $(RXSTAT)/rxstat.c
-rxstat.cs.o: ${RXSTAT}/rxstat.cs.c
- ${CCRULE}
+rxstat.cs.o: ${TOP_OBJDIR}/src/rxstat/rxstat.cs.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/rxstat/rxstat.cs.c
-rxstat.ss.o: ${RXSTAT}/rxstat.ss.c
- ${CCRULE}
+rxstat.ss.o: ${TOP_OBJDIR}/src/rxstat/rxstat.ss.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/rxstat/rxstat.ss.c
-rxstat.xdr.o: ${RXSTAT}/rxstat.xdr.c
- ${CCRULE}
+rxstat.xdr.o: ${TOP_OBJDIR}/src/rxstat/rxstat.xdr.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/rxstat/rxstat.xdr.c
-afsint.cs.o: ${FSINT}/afsint.cs.c
- ${CCRULE}
+afsint.cs.o: ${TOP_OBJDIR}/src/fsint/afsint.cs.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/fsint/afsint.cs.c
-afsint.xdr.o: ${FSINT}/afsint.xdr.c
- ${CCRULE}
+afsint.xdr.o: ${TOP_OBJDIR}/src/fsint/afsint.xdr.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/fsint/afsint.xdr.c
-afscbint.cs.o: ${FSINT}/afscbint.cs.c
- ${CCRULE}
+afscbint.cs.o: ${TOP_OBJDIR}/src/fsint/afscbint.cs.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/fsint/afscbint.cs.c
-afscbint.xdr.o: ${FSINT}/afscbint.xdr.c
- ${CCRULE}
+afscbint.xdr.o: ${TOP_OBJDIR}/src/fsint/afscbint.xdr.c
+ $(AFS_CCRULE) ${TOP_OBJDIR}/src/fsint/afscbint.xdr.c
afsaux.o: ${FSINT}/afsaux.c
- ${CCRULE}
+ $(AFS_CCRULE) -I../fsint ${FSINT}/afsaux.c
-clean:
- $(RM) -f *.o libafsrpc*
+install: libafsrpc.a
+ ${INSTALL} -d ${DESTDIR}${libdir}
+ ${INSTALL_DATA} libafsrpc.a ${DESTDIR}${libdir}/libafsrpc.a
-${DESTDIR}${libdir}/libafsrpc.a: libafsrpc.a
- ${INSTALL} $? $@
-
-${TOP_LIBDIR}/libafsrpc.a: libafsrpc.a
- ${INSTALL} $? $@
-
-dest: ${DEST}/lib/libafsrpc.a
+dest: libafsrpc.a
+ ${INSTALL} -d ${DEST}/lib
+ ${INSTALL_DATA} libafsrpc.a ${DEST}/lib/libafsrpc.a
+clean:
+ $(RM) -f *.o libafsrpc*