new upstream release
apply official bdb-4.6.21 patches
This commit is contained in:
parent
62f1c6f935
commit
c3337e2059
@ -1,2 +1,2 @@
|
|||||||
db-4.6.21.tar.gz
|
db-4.6.21.tar.gz
|
||||||
openldap-2.4.10.tgz
|
openldap-2.4.11.tgz
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
# not work with some versions of OpenLDAP.
|
# not work with some versions of OpenLDAP.
|
||||||
%define db_version 4.6.21
|
%define db_version 4.6.21
|
||||||
%define ldbm_backend berkeley
|
%define ldbm_backend berkeley
|
||||||
%define version 2.4.10
|
%define version 2.4.11
|
||||||
%define evolution_connector_prefix %{_libdir}/evolution-openldap
|
%define evolution_connector_prefix %{_libdir}/evolution-openldap
|
||||||
%define evolution_connector_includedir %{evolution_connector_prefix}/include
|
%define evolution_connector_includedir %{evolution_connector_prefix}/include
|
||||||
%define evolution_connector_libdir %{evolution_connector_prefix}/%{_lib}
|
%define evolution_connector_libdir %{evolution_connector_prefix}/%{_lib}
|
||||||
@ -11,7 +11,7 @@
|
|||||||
Summary: The configuration files, libraries, and documentation for OpenLDAP
|
Summary: The configuration files, libraries, and documentation for OpenLDAP
|
||||||
Name: openldap
|
Name: openldap
|
||||||
Version: %{version}
|
Version: %{version}
|
||||||
Release: 2%{?dist}
|
Release: 1%{?dist}
|
||||||
License: OpenLDAP
|
License: OpenLDAP
|
||||||
Group: System Environment/Daemons
|
Group: System Environment/Daemons
|
||||||
Source0: ftp://ftp.OpenLDAP.org/pub/OpenLDAP/openldap-release/openldap-%{version}.tgz
|
Source0: ftp://ftp.OpenLDAP.org/pub/OpenLDAP/openldap-release/openldap-%{version}.tgz
|
||||||
@ -34,13 +34,13 @@ Patch5: openldap-2.4.6-nosql.patch
|
|||||||
Patch6: openldap-2.3.19-gethostbyXXXX_r.patch
|
Patch6: openldap-2.3.19-gethostbyXXXX_r.patch
|
||||||
Patch9: openldap-2.3.37-smbk5pwd.patch
|
Patch9: openldap-2.3.37-smbk5pwd.patch
|
||||||
Patch10: openldap-2.4.6-multilib.patch
|
Patch10: openldap-2.4.6-multilib.patch
|
||||||
Patch11: openldap-2.3.27-ber-decode.patch
|
|
||||||
|
|
||||||
# Patches for the evolution library
|
# Patches for the evolution library
|
||||||
Patch200: openldap-2.4.6-evolution-ntlm.patch
|
Patch200: openldap-2.4.6-evolution-ntlm.patch
|
||||||
|
|
||||||
# Patches for db4 library
|
# Patches for db4 library
|
||||||
|
Patch400: patch.4.6.21.1
|
||||||
|
Patch401: patch.4.6.21.2
|
||||||
|
|
||||||
URL: http://www.openldap.org/
|
URL: http://www.openldap.org/
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-root
|
BuildRoot: %{_tmppath}/%{name}-%{version}-root
|
||||||
@ -120,6 +120,8 @@ programs needed for accessing and modifying OpenLDAP directories.
|
|||||||
%setup -q -c -a 1
|
%setup -q -c -a 1
|
||||||
|
|
||||||
pushd db-%{db_version}
|
pushd db-%{db_version}
|
||||||
|
%patch400 -p0 -b .patch1
|
||||||
|
%patch401 -p0 -b .patch2
|
||||||
popd
|
popd
|
||||||
|
|
||||||
pushd openldap-%{version}
|
pushd openldap-%{version}
|
||||||
@ -132,7 +134,6 @@ pushd openldap-%{version}
|
|||||||
%patch6 -p1 -b .gethostbyname_r
|
%patch6 -p1 -b .gethostbyname_r
|
||||||
%patch9 -p1 -b .smbk5pwd
|
%patch9 -p1 -b .smbk5pwd
|
||||||
%patch10 -p1 -b .multilib
|
%patch10 -p1 -b .multilib
|
||||||
%patch11 -p0 -b .ber-decode
|
|
||||||
|
|
||||||
cp %{_datadir}/libtool/config.{sub,guess} build/
|
cp %{_datadir}/libtool/config.{sub,guess} build/
|
||||||
popd
|
popd
|
||||||
@ -599,6 +600,10 @@ fi
|
|||||||
%attr(0644,root,root) %{evolution_connector_libdir}/*.a
|
%attr(0644,root,root) %{evolution_connector_libdir}/*.a
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Jul 21 2008 Jan Safranek <jsafranek@redhat.com> 2.4.11-1
|
||||||
|
- new upstream release
|
||||||
|
- apply official bdb-4.6.21 patches
|
||||||
|
|
||||||
* Wed Jul 2 2008 Jan Safranek <jsafranek@redhat.com> 2.4.10-2
|
* Wed Jul 2 2008 Jan Safranek <jsafranek@redhat.com> 2.4.10-2
|
||||||
- fix CVE-2008-2952 (#453728)
|
- fix CVE-2008-2952 (#453728)
|
||||||
|
|
||||||
|
94
patch.4.6.21.1
Normal file
94
patch.4.6.21.1
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
Official usptream patch #1
|
||||||
|
|
||||||
|
Source: http://www.oracle.com/technology/products/berkeley-db/db/update/4.6.21/patch.4.6.21.html
|
||||||
|
|
||||||
|
*** dbinc/mp.h 2007-09-28 01:28:25.000000000 +1000
|
||||||
|
--- dbinc/mp.h 2008-02-14 01:22:09.000000000 +1100
|
||||||
|
***************
|
||||||
|
*** 639,644 ****
|
||||||
|
--- 639,647 ----
|
||||||
|
*/
|
||||||
|
#define MP_TRUNC_RECOVER 0x01
|
||||||
|
|
||||||
|
+ /* Private flags to DB_MPOOLFILE->close. */
|
||||||
|
+ #define DB_MPOOL_NOLOCK 0x002 /* Already have mpf locked. */
|
||||||
|
+
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
*** mp/mp_fopen.c 2007-05-18 03:18:01.000000000 +1000
|
||||||
|
--- mp/mp_fopen.c 2008-02-12 16:09:42.000000000 +1100
|
||||||
|
***************
|
||||||
|
*** 888,894 ****
|
||||||
|
* when we try to flush them.
|
||||||
|
*/
|
||||||
|
deleted = 0;
|
||||||
|
! MUTEX_LOCK(dbenv, mfp->mutex);
|
||||||
|
if (F_ISSET(dbmfp, MP_MULTIVERSION))
|
||||||
|
--mfp->multiversion;
|
||||||
|
if (--mfp->mpf_cnt == 0 || LF_ISSET(DB_MPOOL_DISCARD)) {
|
||||||
|
--- 888,895 ----
|
||||||
|
* when we try to flush them.
|
||||||
|
*/
|
||||||
|
deleted = 0;
|
||||||
|
! if (!LF_ISSET(DB_MPOOL_NOLOCK))
|
||||||
|
! MUTEX_LOCK(dbenv, mfp->mutex);
|
||||||
|
if (F_ISSET(dbmfp, MP_MULTIVERSION))
|
||||||
|
--mfp->multiversion;
|
||||||
|
if (--mfp->mpf_cnt == 0 || LF_ISSET(DB_MPOOL_DISCARD)) {
|
||||||
|
***************
|
||||||
|
*** 909,921 ****
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mfp->block_cnt == 0) {
|
||||||
|
if ((t_ret =
|
||||||
|
__memp_mf_discard(dbmp, mfp)) != 0 && ret == 0)
|
||||||
|
ret = t_ret;
|
||||||
|
deleted = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
! if (!deleted)
|
||||||
|
MUTEX_UNLOCK(dbenv, mfp->mutex);
|
||||||
|
|
||||||
|
done: /* Discard the DB_MPOOLFILE structure. */
|
||||||
|
--- 910,928 ----
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mfp->block_cnt == 0) {
|
||||||
|
+ /*
|
||||||
|
+ * We should never discard this mp file if our caller
|
||||||
|
+ * is holding the lock on it. See comment in
|
||||||
|
+ * __memp_sync_file.
|
||||||
|
+ */
|
||||||
|
+ DB_ASSERT(dbenv, !LF_ISSET(DB_MPOOL_NOLOCK));
|
||||||
|
if ((t_ret =
|
||||||
|
__memp_mf_discard(dbmp, mfp)) != 0 && ret == 0)
|
||||||
|
ret = t_ret;
|
||||||
|
deleted = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
! if (!deleted && !LF_ISSET(DB_MPOOL_NOLOCK))
|
||||||
|
MUTEX_UNLOCK(dbenv, mfp->mutex);
|
||||||
|
|
||||||
|
done: /* Discard the DB_MPOOLFILE structure. */
|
||||||
|
*** mp/mp_sync.c 2007-06-02 04:32:44.000000000 +1000
|
||||||
|
--- mp/mp_sync.c 2008-02-12 16:09:42.000000000 +1100
|
||||||
|
***************
|
||||||
|
*** 755,761 ****
|
||||||
|
* This is important since we are called with the hash bucket
|
||||||
|
* locked. The mfp will get freed via the cleanup pass.
|
||||||
|
*/
|
||||||
|
! if (dbmfp != NULL && (t_ret = __memp_fclose(dbmfp, 0)) != 0 && ret == 0)
|
||||||
|
ret = t_ret;
|
||||||
|
|
||||||
|
--mfp->mpf_cnt;
|
||||||
|
--- 755,762 ----
|
||||||
|
* This is important since we are called with the hash bucket
|
||||||
|
* locked. The mfp will get freed via the cleanup pass.
|
||||||
|
*/
|
||||||
|
! if (dbmfp != NULL &&
|
||||||
|
! (t_ret = __memp_fclose(dbmfp, DB_MPOOL_NOLOCK)) != 0 && ret == 0)
|
||||||
|
ret = t_ret;
|
||||||
|
|
||||||
|
--mfp->mpf_cnt;
|
||||||
|
|
31
patch.4.6.21.2
Normal file
31
patch.4.6.21.2
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
Official usptream patch #2
|
||||||
|
|
||||||
|
Source: http://www.oracle.com/technology/products/berkeley-db/db/update/4.6.21/patch.4.6.21.html
|
||||||
|
|
||||||
|
*** mp/mp_region.c 2007-05-18 03:18:01.000000000 +1000
|
||||||
|
--- mp/mp_region.c 2008-06-24 13:15:56.000000000 +1000
|
||||||
|
***************
|
||||||
|
*** 249,256 ****
|
||||||
|
mtx_base = htab[0].mtx_hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mtx_base != MUTEX_INVALID)
|
||||||
|
! mtx_base += reginfo_off * htab_buckets;
|
||||||
|
|
||||||
|
/* Allocate hash table space and initialize it. */
|
||||||
|
if ((ret = __env_alloc(infop,
|
||||||
|
--- 249,262 ----
|
||||||
|
mtx_base = htab[0].mtx_hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ /*
|
||||||
|
+ * We preallocated all of the mutexes in a block, so for regions after
|
||||||
|
+ * the first, we skip mutexes in use in earlier regions. Each region
|
||||||
|
+ * has the same number of buckets and there are two mutexes per hash
|
||||||
|
+ * bucket (the bucket mutex and the I/O mutex).
|
||||||
|
+ */
|
||||||
|
if (mtx_base != MUTEX_INVALID)
|
||||||
|
! mtx_base += reginfo_off * htab_buckets * 2;
|
||||||
|
|
||||||
|
/* Allocate hash table space and initialize it. */
|
||||||
|
if ((ret = __env_alloc(infop,
|
Loading…
Reference in New Issue
Block a user