[krbdev.mit.edu #2990] Static version of k5crypto library complains when used in Solaris

The RT System itself via RT rt-comment at krbdev.mit.edu
Tue Mar 29 18:17:33 EST 2005


>From krb5-bugs-incoming-bounces at PCH.mit.edu  Tue Mar 29 18:17:23 2005
Received: from pch.mit.edu (PCH.MIT.EDU [18.7.21.90]) by krbdev.mit.edu (8.9.3p2) with ESMTP
	id SAA13200; Tue, 29 Mar 2005 18:17:22 -0500 (EST)
Received: from pch.mit.edu (pch.mit.edu [127.0.0.1])
	by pch.mit.edu (8.12.8p2/8.12.8) with ESMTP id j2TNGqh7020614
	for <krb5-send-pr at krbdev.mit.edu>; Tue, 29 Mar 2005 18:16:52 -0500
Received: from pacific-carrier-annex.mit.edu (PACIFIC-CARRIER-ANNEX.MIT.EDU
	[18.7.21.83])
	by pch.mit.edu (8.12.8p2/8.12.8) with ESMTP id j2T93Nh7027904
	for <krb5-bugs-incoming at PCH.mit.edu>; Tue, 29 Mar 2005 04:03:28 -0500
Received: from waveriders.net (smtp.waveriders.net [204.209.55.5])
	j2T93Fgn005503
	for <krb5-bugs at mit.edu>; Tue, 29 Mar 2005 04:03:15 -0500 (EST)
Received: from waveriders.net (localhost.waveriders.net [127.0.0.1])
	by waveriders.net (8.12.10/8.12.11) with ESMTP id j2T93Bkt003577
	for <krb5-bugs at mit.edu>; Tue, 29 Mar 2005 02:03:11 -0700 (MST)
Received: (from antoine at localhost)
	by waveriders.net (8.12.10/8.12.11/Submit) id j2T93Bip015890
	for krb5-bugs at mit.edu; Tue, 29 Mar 2005 02:03:11 -0700 (MST)
Resent-From: antoine at verheijen.ca
Resent-Date: Tue, 29 Mar 2005 02:03:11 -0700
Resent-Message-ID: <20050329090311.GA10248 at smtp.waveriders.net>
Resent-To: krb5-bugs at mit.edu
Received: from afstest.ucs.ualberta.ca (afstest.ucs.ualberta.ca
	[129.128.5.35])
	by waveriders.net (8.12.10/8.12.11) with ESMTP id j2T6Eckt011029
	for <antoine at verheijen.ca>; Mon, 28 Mar 2005 23:14:38 -0700 (MST)
Received: (from antoine at localhost)
	by afstest.ucs.ualberta.ca (8.11.7p1+Sun/8.11.6) id j2T6EWR02547;
	Mon, 28 Mar 2005 23:14:32 -0700 (MST)
Date: Mon, 28 Mar 2005 23:14:32 -0700 (MST)
Message-Id: <200503290614.j2T6EWR02547 at afstest.ucs.ualberta.ca>
To: krb5-bugs at mit.edu
From: antoine.verheijen at ualberta.ca
X-send-pr-version: 3.99
X-Spam-Score: -4.74
X-Spam-Flag: NO
X-Scanned-By: MIMEDefang 2.42
X-Mailman-Approved-At: Tue, 29 Mar 2005 18:16:51 -0500
Subject: libk5crypto.a on Solaris
X-BeenThere: krb5-bugs-incoming at mailman.mit.edu
X-Mailman-Version: 2.1
Precedence: list
Reply-To: antoine.verheijen at ualberta.ca
Sender: krb5-bugs-incoming-bounces at PCH.mit.edu
Errors-To: krb5-bugs-incoming-bounces at PCH.mit.edu


>Submitter-Id:	net
>Originator:	Antoine Verheijen
>Organization:  University of Alberta
>Confidential:	no
>Synopsis:	Static version of k5crypto library complains when used in Solaris
>Severity:	non-critical
>Priority:	low
>Category:	krb5-libs
>Class:		change-request
>Release:	1.4
>Environment:	Sun, Solaris 8, sparc
System: SunOS afstest 5.8 Generic_117350-19 sun4u sparc SUNW,UltraAX-i2
Architecture: sun4

>Description:
	We use both the static and shared versions of the MIT krb5 libraries.
	The static version of k5crypto (libk5crypto.a) produces the following
	complaint when used on a Solaris machine:

	ild: the archive /usr/local/lib/libk5crypto.a has entries with the same name -- consistency checks during incremental links are not possible for these entries

	This results because there are two arcfour.o files
	(lib/crypto/enc_provider/arcfour.o and lib/crypto/arcfour/arcfour.o) and
	two string_to_key.o files (lib/crypto/string_to_key.o and
	lib/crypto/arcfour/string_to_key.o) used to build the k5crypto library.
	The actual symbols provided by each duplicate file name are different.
	The library still works ... but the complaint message is distracting.
	The "problem" does not affect the shared library.

>How-To-Repeat:
	Link any program requiring use of the k5crypto library, such as "kinit",
	with the static libraries instead of the shared libraries.

>Fix:
	The easiest way to correct this is to rename the files in
	src/lib/crypto/arcfour.  This would also require a few minor changes in some
	of the files. The following small script would provided the appropriate
	changes. Admittedly, the header files don't need to be renamed but it
	provides for consistency.

-------------------------------------------------------------------------------------
#!/bin/sh

# Change to arcfour directory.

cd src/lib/crypto/arcfour

# Patch any files before renaming them.

patch -p3 << .EOF
diff -u -r src-/lib/crypto/arcfour/Makefile.in src/lib/crypto/arcfour/Makefile.in
--- src-/lib/crypto/arcfour/Makefile.in	2004-04-24 16:23:19.000001000 -0600
+++ src/lib/crypto/arcfour/Makefile.in	2005-03-28 22:09:56.000004000 -0700
@@ -14,16 +14,16 @@
 RUN_SETUP = @KRB5_RUN_ENV@ KRB5_CONFIG=$(SRCTOP)/config-files/krb5.conf
 
 STLIBOBJS=\
-	arcfour.o	\
-	string_to_key.o
+	arc4.o	\
+	arc4_string_to_key.o
 
 OBJS=\
-	$(OUTPRE)arcfour.$(OBJEXT)	\
-	$(OUTPRE)string_to_key.$(OBJEXT)
+	$(OUTPRE)arc4.$(OBJEXT)	\
+	$(OUTPRE)arc4_string_to_key.$(OBJEXT)
 
 SRCS=\
-	$(srcdir)/arcfour.c	\
-	$(srcdir)/string_to_key.c
+	$(srcdir)/arc4.c	\
+	$(srcdir)/arc4_string_to_key.c
 
 ##DOS##LIBOBJS = $(OBJS)
 
@@ -42,17 +42,17 @@
 # Makefile dependencies follow.  This must be the last section in
 # the Makefile.in file
 #
-arcfour.so arcfour.po $(OUTPRE)arcfour.$(OBJEXT): arcfour.c $(SRCTOP)/include/k5-int.h \
+arc4.so arc4.po $(OUTPRE)arc4.$(OBJEXT): arc4.c $(SRCTOP)/include/k5-int.h \
   $(BUILDTOP)/include/krb5/osconf.h $(BUILDTOP)/include/krb5/autoconf.h \
   $(SRCTOP)/include/k5-platform.h $(SRCTOP)/include/k5-thread.h \
   $(BUILDTOP)/include/krb5.h $(COM_ERR_DEPS) $(BUILDTOP)/include/profile.h \
   $(SRCTOP)/include/port-sockets.h $(SRCTOP)/include/socket-utils.h \
-  $(SRCTOP)/include/krb5/kdb.h arcfour-int.h arcfour.h
-string_to_key.so string_to_key.po $(OUTPRE)string_to_key.$(OBJEXT): string_to_key.c $(SRCTOP)/include/k5-int.h \
+  $(SRCTOP)/include/krb5/kdb.h arc4-int.h arc4.h
+arc4_string_to_key.so arc4_string_to_key.po $(OUTPRE)arc4_string_to_key.$(OBJEXT): arc4_string_to_key.c $(SRCTOP)/include/k5-int.h \
   $(BUILDTOP)/include/krb5/osconf.h $(BUILDTOP)/include/krb5/autoconf.h \
   $(SRCTOP)/include/k5-platform.h $(SRCTOP)/include/k5-thread.h \
   $(BUILDTOP)/include/krb5.h $(COM_ERR_DEPS) $(BUILDTOP)/include/profile.h \
   $(SRCTOP)/include/port-sockets.h $(SRCTOP)/include/socket-utils.h \
   $(SRCTOP)/include/krb5/kdb.h $(srcdir)/../md4/rsa-md4.h \
-  arcfour-int.h arcfour.h
+  arc4-int.h arc4.h
 
diff -u -r src-/lib/crypto/arcfour/arcfour-int.h src/lib/crypto/arcfour/arcfour-int.h
--- src-/lib/crypto/arcfour/arcfour-int.h	2001-11-06 08:25:48.000001000 -0700
+++ src/lib/crypto/arcfour/arcfour-int.h	2005-03-28 22:11:50.000002000 -0700
@@ -9,7 +9,7 @@
 #ifndef ARCFOUR_INT_H
 #define ARCFOUR_INT_H
 
-#include "arcfour.h"
+#include "arc4.h"
 
 #define CONFOUNDERLENGTH 8
 
diff -u -r src-/lib/crypto/arcfour/arcfour.c src/lib/crypto/arcfour/arcfour.c
--- src-/lib/crypto/arcfour/arcfour.c	2004-02-18 19:46:26.000001000 -0700
+++ src/lib/crypto/arcfour/arcfour.c	2005-03-28 22:10:23.000002000 -0700
@@ -7,7 +7,7 @@
 
 */
 #include "k5-int.h"
-#include "arcfour-int.h"
+#include "arc4-int.h"
 static const char *const l40 = "fortybits";
 
 void
diff -u -r src-/lib/crypto/arcfour/string_to_key.c src/lib/crypto/arcfour/string_to_key.c
--- src-/lib/crypto/arcfour/string_to_key.c	2004-09-21 14:39:19.000001000 -0600
+++ src/lib/crypto/arcfour/string_to_key.c	2005-03-28 22:10:44.000002000 -0700
@@ -1,6 +1,6 @@
 #include "k5-int.h"
 #include "rsa-md4.h"
-#include "arcfour-int.h"
+#include "arc4-int.h"
 
 static void asctouni(unsigned char *unicode, unsigned char *ascii, size_t len)
 {
.EOF

# Rename files.

mv arcfour-int.h   arc4-int.h
mv arcfour.c       arc4.c
mv arcfour.h       arc4.h
mv string_to_key.c arc4_string_to_key.c
-------------------------------------------------------------------------------------



More information about the krb5-bugs mailing list