# API version. When something changes, increment as appropriate.
# Ignore at your own risk.
LIBAFSRPCMAJOR=1
-LIBAFSRPCMINOR=0
+LIBAFSRPCMINOR=4
# Copyright 2000, International Business Machines Corporation and others.
# All Rights Reserved.
# 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.shared
+
+
+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 ${SHLIB_CFLAGS}
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 \
+ xdr_update.o \
+ xdr_refernce.o \
AFS_component_version_number.o
RXOBJS =\
rx_pthread.o \
rx.o \
rx_null.o \
+ rx_opaque.o \
rx_conncache.o \
rx_globals.o \
rx_getaddr.o \
+ rx_identity.o \
rx_misc.o \
rx_packet.o \
rx_rdwr.o \
+ rx_stats.o \
rx_trace.o \
rx_multi.o
rxkad_server.o \
rxkad_common.o \
ticket.o \
+ ticket5.o \
+ crc.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
LIBOBJS = \
${RXOBJS} \
- ${DESOBJS} \
${XDROBJS} \
${RXKADOBJS} \
${COMERROBJS} \
${UTILOBJS} \
${SYSOBJS} \
- ${CRYPT_OBJ} \
${RXSTATOBJS} \
+ ${LWPOBJS} \
${FSINTOBJS}
LIBAFSRPC = libafsrpc.${SHLIB_SUFFIX}.${LIBAFSRPCMAJOR}.${LIBAFSRPCMINOR}
-all: ${TOP_LIBDIR}/${LIBAFSRPC} ${TOP_LIBDIR}/libafsrpc.${SHLIB_SUFFIX}
+all: ${TOP_LIBDIR}/${LIBAFSRPC} ${TOP_LIBDIR}/libafsrpc_pic.a
-install: ${DESTDIR}${libdir}/${LIBAFSRPC} ${DESTDIR}${libdir}/libafsrpc.${SHLIB_SUFFIX}
+${TOP_LIBDIR}/${LIBAFSRPC}: ${LIBAFSRPC}
+ ../config/shlib-install -d ${TOP_LIBDIR} \
+ -l libafsrpc -M ${LIBAFSRPCMAJOR} -m ${LIBAFSRPCMINOR}
-${DEST}/lib/${LIBAFSRPC}: ${LIBAFSRPC}
- ${INSTALL} ${LIBAFSRPC} ${DEST}/lib/${LIBAFSRPC}
+${TOP_LIBDIR}/libafsrpc_pic.a: libafsrpc_pic.a
+ ${INSTALL_DATA} libafsrpc_pic.a $@
-${DEST}/lib/libafsrpc.${SHLIB_SUFFIX}: ${DEST}/lib/${LIBAFSRPC}
- -ln -f -s ${LIBAFSRPC} ${DEST}/lib/libafsrpc.${SHLIB_SUFFIX}
+install: ${LIBAFSRPC} libafsrpc_pic.a
+ ../config/shlib-install -d ${DESTDIR}${libdir} \
+ -l libafsrpc -M ${LIBAFSRPCMAJOR} -m ${LIBAFSRPCMINOR}
+ ${INSTALL_DATA} libafsrpc_pic.a ${DESTDIR}${libdir}/libafsrpc_pic.a
-${LIBAFSRPC}: ${LIBOBJS}
- case ${SYS_NAME} in \
- rs_aix4*) \
- ${SHLIB_LINKER} -o ${LIBAFSRPC} ${LIBOBJS} -bE:afsrpc.exp ${MT_LIBS};; \
- sun*_5*) \
- ${SHLIB_LINKER} -h ${LIBAFSRPC} -o ${LIBAFSRPC} ${LIBOBJS} ${MT_LIBS};; \
- *) \
- ${SHLIB_LINKER} -o ${LIBAFSRPC} ${LIBOBJS} ${MT_LIBS};; \
- esac
+dest: ${LIBAFSRPC} libafsrpc_pic.a
+ ../config/shlib-install -d ${DEST}/lib \
+ -l libafsrpc -M ${LIBAFSRPCMAJOR} -m ${LIBAFSRPCMINOR}
+ ${INSTALL_DATA} libafsrpc_pic.a ${DEST}/lib/libafsrpc_pic.a
+
+${LIBAFSRPC}: ${LIBOBJS} libafsrpc.map
+ ../config/shlib-build -d $(srcdir) -l libafsrpc \
+ -M ${LIBAFSRPCMAJOR} -m ${LIBAFSRPCMINOR} -- \
+ $(LDFLAGS_roken) $(LDFLAGS_hcrypto) \
+ ${LIBOBJS} $(LIB_hcrypto) $(LIB_roken) $(MT_LIBS)
+
+libafsrpc_pic.a: ${LIBOBJS}
+ $(RM) -f $@
+ $(AR) crv $@ ${LIBOBJS}
+ $(RANLIB) $@
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
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
- ${CCRULE}
+rx_globals.o: ${RX}/rx_globals.c
+ $(AFS_CCRULE) $(RX)/rx_globals.c
+
+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
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
+ $(AFS_CCRULE) -I../rxkad -I$(RXKAD) $(RXKAD)/ticket5.c
+
+crc.o: ${RXKAD}/crc.c
+ $(AFS_CCRULE) -I../rxkad $(RXKAD)/crc.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
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 ;; \
+ touch syscall.c ; \
+ ${CC} ${AFS_CFLAGS} -c syscall.c;; \
*) \
- /lib/cpp ${SFLAGS} ${SYS}/syscall.s syscall.ss; \
- as -o syscall.o syscall.ss; \
+ $(PATH_CPP) ${SFLAGS} ${SYS}/syscall.s > syscall.ss; \
+ as $(ASFLAGS) -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*
-
-${DESTDIR}${libdir}/${LIBAFSRPC}: ${LIBAFSRPC}
- ${INSTALL} ${LIBAFSRPC} ${DESTDIR}${libdir}/${LIBAFSRPC}
-
-${DESTDIR}${libdir}/libafsrpc.${SHLIB_SUFFIX}: ${DESTDIR}${libdir}/${LIBAFSRPC}
- -ln -f -s ${LIBAFSRPC} ${DESTDIR}${libdir}/libafsrpc.${SHLIB_SUFFIX}
-
-${TOP_LIBDIR}/${LIBAFSRPC}: ${LIBAFSRPC}
- ${INSTALL} ${LIBAFSRPC} ${TOP_LIBDIR}/${LIBAFSRPC}
-
-${TOP_LIBDIR}/libafsrpc.${SHLIB_SUFFIX}: ${TOP_LIBDIR}/${LIBAFSRPC}
- -ln -f -s ${LIBAFSRPC} ${TOP_LIBDIR}/libafsrpc.${SHLIB_SUFFIX}
-
-dest: ${DEST}/lib/${LIBAFSRPC} ${DEST}/lib/libafsrpc.${SHLIB_SUFFIX}
-
+ $(RM) -f *.o libafsrpc.a* libafsrpc.sl* libafsrpc.so* \
+ libafsrpc_pic.a libafsrpc.dylib.* libafsrpc.exp