[git] GCRYPT - branch, master, updated. libgcrypt-1.7.3-33-g618b897
by Werner Koch
cvs at cvs.gnupg.org
Fri Dec 9 15:26:01 CET 2016
This is an automated email from the git hooks/post-receive script. It was
generated because a ref change was pushed to the repository containing
the project "The GNU crypto library".
The branch, master has been updated
via 618b8978f46f4011c11512fd5f30c15e01652e2e (commit)
from 656395ba4cf34f42dda3a120bda3ed1220755a3d (commit)
Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.
- Log -----------------------------------------------------------------
commit 618b8978f46f4011c11512fd5f30c15e01652e2e
Author: Werner Koch <wk at gnupg.org>
Date: Fri Dec 9 12:10:54 2016 +0100
Improve handling of mlock error codes.
* acinclude.m4 (GNUPG_CHECK_MLOCK): Check also for EAGAIN which is a
legitimate return code and does not indicate a broken mlock().
* src/secmem.c (lock_pool_pages): Test ERR instead of ERRNO which
could have been overwritten by cap_from+text et al.
--
On FreeBSD, if there are not enough free pages, mlock() can return
EAGAIN, as documented in mlock(2). That doesn't mean that mlock is
broken. I suspect this same issue also exists on the other BSD's.
Suggested-by: Ruben Kerkhof <ruben at rubenkerkhof.com>
This is (now) also true for Linux.
Signed-off-by: Werner Koch <wk at gnupg.org>
diff --git a/acinclude.m4 b/acinclude.m4
index 96be833..90b3cb9 100644
--- a/acinclude.m4
+++ b/acinclude.m4
@@ -242,7 +242,7 @@ int main()
pool += (pgsize - ((long int)pool % pgsize));
err = mlock( pool, 4096 );
- if( !err || errno == EPERM )
+ if( !err || errno == EPERM || errno == EGAIN)
return 0; /* okay */
return 1; /* hmmm */
diff --git a/src/secmem.c b/src/secmem.c
index 4fa267b..55424f2 100644
--- a/src/secmem.c
+++ b/src/secmem.c
@@ -282,15 +282,15 @@ lock_pool_pages (void *p, size_t n)
if (err)
{
- if (errno != EPERM
-#ifdef EAGAIN /* OpenBSD returns this */
- && errno != EAGAIN
+ if (err != EPERM
+#ifdef EAGAIN /* BSD and also Linux may return EAGAIN */
+ && err != EAGAIN
#endif
#ifdef ENOSYS /* Some SCOs return this (function not implemented) */
- && errno != ENOSYS
+ && err != ENOSYS
#endif
#ifdef ENOMEM /* Linux might return this. */
- && errno != ENOMEM
+ && err != ENOMEM
#endif
)
log_error ("can't lock memory: %s\n", strerror (err));
@@ -341,15 +341,15 @@ lock_pool_pages (void *p, size_t n)
if (err)
{
- if (errno != EPERM
-#ifdef EAGAIN /* OpenBSD returns this. */
- && errno != EAGAIN
+ if (err != EPERM
+#ifdef EAGAIN /* BSD and also Linux may return this. */
+ && err != EAGAIN
#endif
#ifdef ENOSYS /* Some SCOs return this (function not implemented). */
- && errno != ENOSYS
+ && err != ENOSYS
#endif
#ifdef ENOMEM /* Linux might return this. */
- && errno != ENOMEM
+ && err != ENOMEM
#endif
)
log_error ("can't lock memory: %s\n", strerror (err));
-----------------------------------------------------------------------
Summary of changes:
acinclude.m4 | 2 +-
src/secmem.c | 20 ++++++++++----------
2 files changed, 11 insertions(+), 11 deletions(-)
hooks/post-receive
--
The GNU crypto library
http://git.gnupg.org
More information about the Gnupg-commits
mailing list