[libtirpc] - Fixed last remaining BSD license issues

Steve Dickson steved at fedoraproject.org
Tue Aug 31 17:59:18 UTC 2010


commit d8bfcae760ea5126b96bd78e83390c890344f2c3
Author: Tom 'spot' Callaway <tcallawa at redhat.com>
Date:   Tue Aug 31 13:58:25 2010 -0400

    - Fixed last remaining BSD license issues
    
    Signed-off-by: Steve Dickson <steved at redhat.com>

 libtirpc-0.2.1-BSD-license.patch |  508 ++++++++++++++++++++++++++++++++++++++
 libtirpc.spec                    |    3 +
 2 files changed, 511 insertions(+), 0 deletions(-)
---
diff --git a/libtirpc-0.2.1-BSD-license.patch b/libtirpc-0.2.1-BSD-license.patch
new file mode 100644
index 0000000..7e64bfb
--- /dev/null
+++ b/libtirpc-0.2.1-BSD-license.patch
@@ -0,0 +1,508 @@
+commit ba3945e2c7828be7926fd55d50f03db97dc7e022
+Author: Tom 'spot' Callaway <tcallawa at redhat.com>
+Date:   Tue Aug 31 13:38:21 2010 -0400
+
+    Fixed last remaining license issues
+    
+    Three files in libtirpc have the "BSD with advertising" or "BSD 4
+    clause" license on them (Free, but GPL incompatible). Thankfully, two of
+    the three files (tirpc/libc_private.h and tirpc/nss_tls.h) aren't
+    necessary on Linux at all. They were copied from FreeBSD, but FreeBSD
+    (and NetBSD) include those headers, so they can be conditionalized out
+    in the code. The third header, tirpc/reentrant.h originally came from
+    FreeBSD, but had been modified to point to the Linux pthread equivalent
+    functions. I'm pretty sure that would cause the code to break on
+    FreeBSD/NetBSD.
+    
+    This patch does the following:
+    
+    - Zeros out tirpc/libc_private.h (This file should be deleted from the
+      source control)
+    - Zeros out tirpc/nss_tls.h (This file should be deleted from the source
+      control)
+    - Takes a fresh copy of tirpc/reentrant.h from FreeBSD CVS to inherit
+      the new license (the advertising clause has been dropped in FreeBSD)
+    - Updates tirpc/reentrant.h so that it contains the correct definition
+      mappings for Linux, conditionalized only for Linux.
+    - Updates all source files which #include libc_private.h so that the
+      include is conditionalized on FreeBSD or NetBSD. I honestly don't think
+      these files even need to be included on those platforms, but I'd rather
+      be safe than sorry here.
+    
+    Signed-off-by: Steve Dickson <steved at redhat.com>
+
+diff --git a/src/getrpcent.c b/src/getrpcent.c
+index d7d7ddc..645f18f 100644
+--- a/src/getrpcent.c
++++ b/src/getrpcent.c
+@@ -46,7 +46,9 @@
+ #include <rpcsvc/yp_prot.h>
+ #include <rpcsvc/ypclnt.h>
+ #endif
++#if defined(__FreeBSD__) || defined(__NetBSD__)
+ #include <libc_private.h>
++#endif
+ 
+ /*
+  * Internet version.
+diff --git a/src/mt_misc.c b/src/mt_misc.c
+index 4cba143..fe12c31 100644
+--- a/src/mt_misc.c
++++ b/src/mt_misc.c
+@@ -123,17 +123,17 @@ __rpc_createerr()
+ void tsd_key_delete(void)
+ {
+ 	if (clnt_broadcast_key != -1)
+-		thr_keydelete(clnt_broadcast_key);
++		pthread_key_delete(clnt_broadcast_key);
+ 	if (rpc_call_key != -1)
+-		thr_keydelete(rpc_call_key);
++		pthread_key_delete(rpc_call_key);
+ 	if (tcp_key != -1)
+-		thr_keydelete(tcp_key);
++		pthread_key_delete(tcp_key);
+ 	if (udp_key != -1)
+-		thr_keydelete(udp_key);
++		pthread_key_delete(udp_key);
+ 	if (nc_key != -1)
+-		thr_keydelete(nc_key);
++		pthread_key_delete(nc_key);
+ 	if (rce_key != -1)
+-		thr_keydelete(rce_key);
++		pthread_key_delete(rce_key);
+ 	return;
+ }
+ 
+diff --git a/src/svc_auth_des.c b/src/svc_auth_des.c
+index 479334f..e0ff6cb 100644
+--- a/src/svc_auth_des.c
++++ b/src/svc_auth_des.c
+@@ -60,7 +60,9 @@
+ #include <rpc/svc.h>
+ #include <rpc/rpc_msg.h>
+ #include <rpc/svc_auth.h>
++#if defined(__FreeBSD__) || defined(__NetBSD__)
+ #include <libc_private.h>
++#endif
+ 
+ extern int key_decryptsession_pk(const char *, netobj *, des_block *);
+ 
+diff --git a/src/xdr_reference.c b/src/xdr_reference.c
+index 821dc8e..1da2c14 100644
+--- a/src/xdr_reference.c
++++ b/src/xdr_reference.c
+@@ -46,7 +46,10 @@
+ 
+ #include <rpc/types.h>
+ #include <rpc/xdr.h>
+-#include "libc_private.h"
++
++#if defined(__FreeBSD__) || defined(__NetBSD__)
++#include <libc_private.h>
++#endif
+ 
+ /*
+  * XDR an indirect pointer
+diff --git a/tirpc/libc_private.h b/tirpc/libc_private.h
+index 63f8610..e69de29 100644
+--- a/tirpc/libc_private.h
++++ b/tirpc/libc_private.h
+@@ -1,129 +0,0 @@
+-/*
+- * Copyright (c) 1998 John Birrell <jb at cimlogic.com.au>.
+- * All rights reserved.
+- *
+- * Redistribution and use in source and binary forms, with or without
+- * modification, are permitted provided that the following conditions
+- * are met:
+- * 1. Redistributions of source code must retain the above copyright
+- *    notice, this list of conditions and the following disclaimer.
+- * 2. Redistributions in binary form must reproduce the above copyright
+- *    notice, this list of conditions and the following disclaimer in the
+- *    documentation and/or other materials provided with the distribution.
+- * 3. All advertising materials mentioning features or use of this software
+- *    must display the following acknowledgement:
+- *	This product includes software developed by John Birrell.
+- * 4. Neither the name of the author nor the names of any co-contributors
+- *    may be used to endorse or promote products derived from this software
+- *    without specific prior written permission.
+- *
+- * THIS SOFTWARE IS PROVIDED BY JOHN BIRRELL AND CONTRIBUTORS ``AS IS'' AND
+- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+- * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+- * SUCH DAMAGE.
+- *
+- * $FreeBSD: src/lib/libc/include/libc_private.h,v 1.11 2003/11/05 18:17:30 deischen Exp $
+- *
+- * Private definitions for libc, libc_r and libpthread.
+- *
+- */
+-
+-#ifndef _LIBC_PRIVATE_H_
+-#define _LIBC_PRIVATE_H_
+-
+-/*
+- * This global flag is non-zero when a process has created one
+- * or more threads. It is used to avoid calling locking functions
+- * when they are not required.
+- */
+-extern int	__isthreaded;
+-
+-/*
+- * File lock contention is difficult to diagnose without knowing
+- * where locks were set. Allow a debug library to be built which
+- * records the source file and line number of each lock call.
+- */
+-#ifdef	_FLOCK_DEBUG
+-#define _FLOCKFILE(x)	_flockfile_debug(x, __FILE__, __LINE__)
+-#else
+-#define _FLOCKFILE(x)	_flockfile(x)
+-#endif
+-
+-/*
+- * Macros for locking and unlocking FILEs. These test if the
+- * process is threaded to avoid locking when not required.
+- */
+-#define	FLOCKFILE(fp)		if (__isthreaded) _FLOCKFILE(fp)
+-#define	FUNLOCKFILE(fp)		if (__isthreaded) _funlockfile(fp)
+-
+-/*
+- * Indexes into the pthread jump table.
+- *
+- * Warning! If you change this type, you must also change the threads
+- * libraries that reference it (libc_r, libpthread).
+- */
+-typedef enum {
+-	PJT_COND_BROADCAST,
+-	PJT_COND_DESTROY,
+-	PJT_COND_INIT,
+-	PJT_COND_SIGNAL,
+-	PJT_COND_WAIT,
+-	PJT_GETSPECIFIC,
+-	PJT_KEY_CREATE,
+-	PJT_KEY_DELETE,
+-	PJT_MAIN_NP,
+-	PJT_MUTEX_DESTROY,
+-	PJT_MUTEX_INIT,
+-	PJT_MUTEX_LOCK,
+-	PJT_MUTEX_TRYLOCK,
+-	PJT_MUTEX_UNLOCK,
+-	PJT_MUTEXATTR_DESTROY,
+-	PJT_MUTEXATTR_INIT,
+-	PJT_MUTEXATTR_SETTYPE,
+-	PJT_ONCE,
+-	PJT_RWLOCK_DESTROY,
+-	PJT_RWLOCK_INIT,
+-	PJT_RWLOCK_RDLOCK,
+-	PJT_RWLOCK_TRYRDLOCK,
+-	PJT_RWLOCK_TRYWRLOCK,
+-	PJT_RWLOCK_UNLOCK,
+-	PJT_RWLOCK_WRLOCK,
+-	PJT_SELF,
+-	PJT_SETSPECIFIC,
+-	PJT_SIGMASK,
+-	PJT_MAX
+-} pjt_index_t;
+-
+-typedef int (*pthread_func_t)(void);
+-typedef pthread_func_t pthread_func_entry_t[2];
+-
+-extern pthread_func_entry_t __thr_jtable[];
+-
+-/*
+- * yplib internal interfaces
+- */
+-#ifdef YP
+-int _yp_check(char **);
+-#endif
+-
+-
+-/*
+- * This is a pointer in the C run-time startup code. It is used
+- * by getprogname() and setprogname().
+- */
+-extern const char *__progname;
+-
+-/*
+- * This is the lock to make malloc() thread-safe.  It is externalized
+- * so that thread libraries can protect malloc across fork().
+- */
+-extern struct _spinlock *__malloc_lock;
+-
+-#endif /* _LIBC_PRIVATE_H_ */
+diff --git a/tirpc/nss_tls.h b/tirpc/nss_tls.h
+index 7536736..e69de29 100644
+--- a/tirpc/nss_tls.h
++++ b/tirpc/nss_tls.h
+@@ -1,80 +0,0 @@
+-/*-
+- * Copyright (c) 2003 Networks Associates Technology, Inc.
+- * All rights reserved.
+- *
+- * This software was developed for the FreeBSD Project by
+- * Jacques A. Vidrine, Safeport Network Services, and Network
+- * Associates Laboratories, the Security Research Division of Network
+- * Associates, Inc. under DARPA/SPAWAR contract N66001-01-C-8035
+- * ("CBOSS"), as part of the DARPA CHATS research program.
+- *
+- * Redistribution and use in source and binary forms, with or without
+- * modification, are permitted provided that the following conditions
+- * are met:
+- * 1. Redistributions of source code must retain the above copyright
+- *    notice, this list of conditions and the following disclaimer.
+- * 2. Redistributions in binary form must reproduce the above copyright
+- *    notice, this list of conditions and the following disclaimer in the
+- *    documentation and/or other materials provided with the distribution.
+- *
+- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+- * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+- * SUCH DAMAGE.
+- *
+- * $FreeBSD: src/lib/libc/include/nss_tls.h,v 1.2 2003/04/21 15:44:25 nectar Exp $
+- *
+- * Macros which generate thread local storage handling code in NSS modules.
+- */
+-#ifndef _NSS_TLS_H_
+-#define _NSS_TLS_H_
+-
+-#define NSS_TLS_HANDLING(name)					\
+-static pthread_key_t name##_state_key;				\
+-static	void	 name##_keyinit(void);				\
+-static	int	 name##_getstate(struct name##_state **);	\
+-\
+-static void								\
+-name##_keyinit(void)							\
+-{									\
+-	(void)_pthread_key_create(&name##_state_key, name##_endstate);	\
+-}									\
+-\
+-static int							\
+-name##_getstate(struct name##_state **p)			\
+-{								\
+-	static struct name##_state st;				\
+-	static pthread_once_t	keyinit = PTHREAD_ONCE_INIT;	\
+-	int			rv;				\
+-								\
+-	if (!__isthreaded || _pthread_main_np() != 0) {		\
+-		*p = &st;					\
+-		return (0);					\
+-	}							\
+-	rv = _pthread_once(&keyinit, name##_keyinit);		\
+-	if (rv != 0)						\
+-		return (rv);					\
+-	*p = _pthread_getspecific(name##_state_key);		\
+-	if (*p != NULL)						\
+-		return (0);					\
+-	*p = calloc(1, sizeof(**p));				\
+-	if (*p == NULL)						\
+-		return (ENOMEM);				\
+-	rv = _pthread_setspecific(name##_state_key, *p);	\
+-	if (rv != 0) {						\
+-		free(*p);					\
+-		*p = NULL;					\
+-	}							\
+-	return (rv);						\
+-}								\
+-/* allow the macro invocation to end with a semicolon */	\
+-typedef int _##name##_bmVjdGFy
+-
+-#endif /* _NSS_TLS_H_ */
+diff --git a/tirpc/reentrant.h b/tirpc/reentrant.h
+index fda8f65..9489b15 100644
+--- a/tirpc/reentrant.h
++++ b/tirpc/reentrant.h
+@@ -13,13 +13,6 @@
+  * 2. Redistributions in binary form must reproduce the above copyright
+  *    notice, this list of conditions and the following disclaimer in the
+  *    documentation and/or other materials provided with the distribution.
+- * 3. All advertising materials mentioning features or use of this software
+- *    must display the following acknowledgement:
+- *        This product includes software developed by the NetBSD
+- *        Foundation, Inc. and its contributors.
+- * 4. Neither the name of The NetBSD Foundation nor the names of its
+- *    contributors may be used to endorse or promote products derived
+- *    from this software without specific prior written permission.
+  *
+  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+@@ -33,95 +26,51 @@
+  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+  * POSSIBILITY OF SUCH DAMAGE.
+  *
+- * $FreeBSD: src/lib/libc/include/reentrant.h,v 1.2 2002/11/01 09:37:17 dfr Exp $
+  */
+ 
+-/*
+- * Requirements:
+- * 
+- * 1. The thread safe mechanism should be lightweight so the library can
+- *    be used by non-threaded applications without unreasonable overhead.
+- * 
+- * 2. There should be no dependency on a thread engine for non-threaded
+- *    applications.
+- * 
+- * 3. There should be no dependency on any particular thread engine.
+- * 
+- * 4. The library should be able to be compiled without support for thread
+- *    safety.
+- * 
+- * 
+- * Rationale:
+- * 
+- * One approach for thread safety is to provide discrete versions of the
+- * library: one thread safe, the other not.  The disadvantage of this is
+- * that libc is rather large, and two copies of a library which are 99%+
+- * identical is not an efficent use of resources.
+- * 
+- * Another approach is to provide a single thread safe library.  However,
+- * it should not add significant run time or code size overhead to non-
+- * threaded applications.
+- * 
+- * Since the NetBSD C library is used in other projects, it should be
+- * easy to replace the mutual exclusion primitives with ones provided by
+- * another system.  Similarly, it should also be easy to remove all
+- * support for thread safety completely if the target environment does
+- * not support threads.
+- * 
+- * 
+- * Implementation Details:
+- * 
+- * The mutex primitives used by the library (mutex_t, mutex_lock, etc.)
+- * are macros which expand to the cooresponding primitives provided by
+- * the thread engine or to nothing.  The latter is used so that code is
+- * not unreasonably cluttered with #ifdefs when all thread safe support
+- * is removed.
+- * 
+- * The mutex macros can be directly mapped to the mutex primitives from
+- * pthreads, however it should be reasonably easy to wrap another mutex
+- * implementation so it presents a similar interface.
+- * 
+- * Stub implementations of the mutex functions are provided with *weak*
+- * linkage.  These functions simply return success.  When linked with a
+- * thread library (i.e. -lpthread), the functions will override the
+- * stubs.
++/* 
++ * This file was derived from a copy in FreeBSD CVS on August 26, 2010. 
++ * FreeBSD/NetBSD have slightly different definitions for some/most of
++ * these functions and types, so they should just use the ones found
++ * in their system copy of reentrant.h.
++ * These definitions are only guaranteed to be valid on Linux. 
+  */
+-#ifndef _REENTRANT_H
+-#define _REENTRANT_H
+-#include <pthread.h>
+-#include <libc_private.h>
+ 
+-#include <stdlib.h>
++#if defined(__linux__)
++
++#include <pthread.h>
+ 
+ #define mutex_t			pthread_mutex_t
+ #define cond_t			pthread_cond_t
+ #define rwlock_t		pthread_rwlock_t
++#define once_t			pthread_once_t
+ 
+ #define thread_key_t		pthread_key_t
+ #define MUTEX_INITIALIZER	PTHREAD_MUTEX_INITIALIZER
+ #define RWLOCK_INITIALIZER	PTHREAD_RWLOCK_INITIALIZER
++#define ONCE_INITIALIZER	PTHREAD_ONCE_INIT
++
+ #define mutex_init(m, a)	pthread_mutex_init(m, a)
+ #define mutex_lock(m)		pthread_mutex_lock(m)
+ #define mutex_unlock(m)		pthread_mutex_unlock(m)
+-#define mutex_trylock(m)	pthread_mutex_trylock(m)
+ 
+-#define cond_init(c, a, p)	 pthread_cond_init(c, a)
+-#define cond_signal(m)		 pthread_cond_signal(m)
+-#define cond_broadcast(m)	 pthread_cond_broadcast(m)
+-#define cond_wait(c, m)		 pthread_cond_wait(c, m)
++#define cond_init(c, a, p)	pthread_cond_init(c, a)
++#define cond_signal(m)		pthread_cond_signal(m)
++#define cond_broadcast(m)	pthread_cond_broadcast(m)
++#define cond_wait(c, m)		pthread_cond_wait(c, m)
+ 
+-#define rwlock_init(l, a)        pthread_rwlock_init(l, a)
+-#define rwlock_rdlock(l)	 pthread_rwlock_rdlock(l)
+-#define rwlock_wrlock(l)	 pthread_rwlock_wrlock(l)
+-#define rwlock_unlock(l)	 pthread_rwlock_unlock(l)
++#define rwlock_init(l, a)	pthread_rwlock_init(l, a)
++#define rwlock_rdlock(l)	pthread_rwlock_rdlock(l)
++#define rwlock_wrlock(l)	pthread_rwlock_wrlock(l)
++#define rwlock_unlock(l)	pthread_rwlock_unlock(l)
+ 
+-#define thr_keycreate(k, d)	 pthread_key_create(k, d)
+-#define thr_keydelete(k)	 pthread_key_delete(k)
+-#define thr_setspecific(k, p)	 pthread_setspecific(k, p)
+-#define thr_getspecific(k)	 pthread_getspecific(k)
+-#define thr_sigsetmask(f, n, o)	 pthread_sigmask(f, n, o)
++#define thr_keycreate(k, d)	pthread_key_create(k, d)
++#define thr_setspecific(k, p)	pthread_setspecific(k, p)
++#define thr_getspecific(k)	pthread_getspecific(k)
++#define thr_sigsetmask(f, n, o)	pthread_sigmask(f, n, o)
+ 
+-#define thr_self()		 pthread_self()
+-#define thr_exit(x)		 pthread_exit(x)
++#define thr_once(o, i)		pthread_once(o, i)
++#define thr_self()		pthread_self()
++#define thr_exit(x)		pthread_exit(x)
+ 
+-#endif /* reentrant.h */
++#endif
+diff --git a/tirpc/spinlock.h b/tirpc/spinlock.h
+index 8e9adb1..393fb83 100644
+--- a/tirpc/spinlock.h
++++ b/tirpc/spinlock.h
+@@ -37,37 +37,5 @@
+ 
+ #ifndef _SPINLOCK_H_
+ #define _SPINLOCK_H_
+-#include <sys/cdefs.h>
+-#include <sys/types.h>
+-
+-/*
+- * Lock structure with room for debugging information.
+- */
+-struct _spinlock {
+-	volatile long	access_lock;
+-	volatile long	lock_owner;
+-	volatile char	*fname;
+-	volatile int	lineno;
+-};
+-typedef struct _spinlock spinlock_t;
+-
+-#define	_SPINLOCK_INITIALIZER	{ 0, 0, 0, 0 }
+-
+-#define _SPINUNLOCK(_lck)	_spinunlock(_lck);
+-#ifdef	_LOCK_DEBUG
+-#define	_SPINLOCK(_lck)		_spinlock_debug(_lck, __FILE__, __LINE__)
+-#else
+-#define	_SPINLOCK(_lck)		_spinlock(_lck)
+-#endif
+-
+-/*
+- * Thread function prototype definitions:
+- */
+-__BEGIN_DECLS
+-long	_atomic_lock(volatile long *);
+-void	_spinlock(spinlock_t *);
+-void	_spinunlock(spinlock_t *);
+-void	_spinlock_debug(spinlock_t *, char *, int);
+-__END_DECLS
+ 
+ #endif /* _SPINLOCK_H_ */
diff --git a/libtirpc.spec b/libtirpc.spec
index fa9585f..e8b9c74 100644
--- a/libtirpc.spec
+++ b/libtirpc.spec
@@ -10,6 +10,7 @@ Patch001: libtirpc-0-2-2-rc2.patch
 
 Patch100: libtirpc-0.2.1-SISSL-license.patch
 Patch101: libtirpc-0.2.1-replace-SISSL-with-BSD.patch
+Patch102: libtirpc-0.2.1-BSD-license.patch
 
 BuildRoot:	%{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
 Source0:	http://downloads.sourceforge.net/libtirpc/libtirpc-%{version}.tar.bz2
@@ -47,6 +48,7 @@ developing programs which use the tirpc library.
 
 %patch100 -p1
 %patch101 -p1
+%patch102 -p1
 
 # Remove .orig files
 find . -name "*.orig" | xargs rm -f
@@ -134,6 +136,7 @@ rm -rf %{buildroot}
 %changelog
 * Mon Aug 30 2010 Steve Dickson  <steved at redhat.com> 0.2.1-5
 - Relicense these SISSL files to 3 clause BSD
+- Fixed last remaining BSD license issues
 
 * Fri Jul 16 2010 Steve Dickson  <steved at redhat.com> 0.2.1-4
 - Add back SISSL license attribution


More information about the scm-commits mailing list