diff options
author | fluffy <fluffy@FreeBSD.org> | 2012-09-02 21:53:16 +0800 |
---|---|---|
committer | fluffy <fluffy@FreeBSD.org> | 2012-09-02 21:53:16 +0800 |
commit | 6a21efe0e8037caacf3a41799048b32bb2d0cf7a (patch) | |
tree | 025ee465136f8d3ad96ee2841d6d9577186784c4 /news/inn | |
parent | f51e3608b1699a9b768dbb4843d24ace10ffae77 (diff) | |
download | freebsd-ports-graphics-6a21efe0e8037caacf3a41799048b32bb2d0cf7a.tar.gz freebsd-ports-graphics-6a21efe0e8037caacf3a41799048b32bb2d0cf7a.tar.zst freebsd-ports-graphics-6a21efe0e8037caacf3a41799048b32bb2d0cf7a.zip |
- Fix innd/nnrpd semget failures
Do not set any shmem permission bits except for the six allowed bits
PR: 171134
Submitted by: G. Paul Ziemba
Diffstat (limited to 'news/inn')
-rw-r--r-- | news/inn/Makefile | 2 | ||||
-rw-r--r-- | news/inn/files/patch-storage_buffindexed_shmem.c | 73 |
2 files changed, 74 insertions, 1 deletions
diff --git a/news/inn/Makefile b/news/inn/Makefile index 706472cb3f0..fde838499e2 100644 --- a/news/inn/Makefile +++ b/news/inn/Makefile @@ -7,7 +7,7 @@ PORTNAME?= inn PORTVERSION?= 2.5.2 -PORTREVISION?= 2 +PORTREVISION?= 3 CATEGORIES= news ipv6 # Master distribution broken #MASTER_SITES?= ${MASTER_SITE_ISC} diff --git a/news/inn/files/patch-storage_buffindexed_shmem.c b/news/inn/files/patch-storage_buffindexed_shmem.c new file mode 100644 index 00000000000..9472e1467c6 --- /dev/null +++ b/news/inn/files/patch-storage_buffindexed_shmem.c @@ -0,0 +1,73 @@ +The problem seems to be that unsupported permission bits are being given to semget(2) as in the following snippet (there are several such instances): + +storage/buffindexed/shmem.c: + + id = semget(kt, 2, IPC_CREAT|S_IRWXU|S_IRWXG|S_IRWXO); + +The semget(2) man page does not indicate that the usual file mode bits may be used. Instead, it allows: + + SEM_R Read access for user. + + SEM_A Alter access for user. + + (SEM_R>>3) Read access for group. + + (SEM_A>>3) Alter access for group. + + (SEM_R>>6) Read access for other. + + (SEM_A>>6) Alter access for other. + +The allowed bits correspond to read and write bits of the file mode constants. The execute bit is not among the defined bits for semget. + +The fix: do not set any permission bits except for the six allowed bits. + +Note that the documentation for linux semget differs, and seems to allow but ignore the execute bits. + +Patch attached with submission follows: + +--- storage/buffindexed/shmem.c.orig 2012-08-27 23:39:42.000000000 -0700 ++++ storage/buffindexed/shmem.c 2012-08-27 23:37:50.000000000 -0700 +@@ -26,7 +26,9 @@ + static int smcGetSemaphore(const char *name) + { + key_t kt = ftok( (char *)name, 0 ); +- int id = semget(kt, 0, S_IRWXU|S_IRWXG|S_IRWXO); ++ int perm = SEM_R | SEM_A | (SEM_R>>3) | (SEM_A>>3) | ++ (SEM_R>>6) | (SEM_A>>6); ++ int id = semget(kt, 0, perm); + + if (id < 0) { + syswarn("semget failed to get semaphore for %s", name); +@@ -37,15 +39,17 @@ + static int smcCreateSemaphore(const char *name) + { + key_t kt = ftok( (char *)name, 0 ); +- int id = semget(kt, 2, IPC_CREAT|S_IRWXU|S_IRWXG|S_IRWXO); ++ int perm = SEM_R | SEM_A | (SEM_R>>3) | (SEM_A>>3) | ++ (SEM_R>>6) | (SEM_A>>6); ++ int id = semget(kt, 2, IPC_CREAT|perm); + + if (id < 0) { + if (errno == EACCES || errno == EINVAL) { + /* looks like a wrong semaphore exists. remove it. */ +- id = semget(kt, 0, S_IRWXU|S_IRWXG|S_IRWXO); ++ id = semget(kt, 0, perm); + if (id < 0) { + /* couldn't even retrieve it. */ +- syswarn("cant get semaphore using %s", name); ++ syswarn("cant get semaphore using %s (key=%d)", name, kt); + return id; + } + /* try to remove it */ +@@ -65,7 +69,7 @@ + } + #endif + /* and retry creating it */ +- id = semget(kt, 2, IPC_CREAT|S_IRWXU|S_IRWXG|S_IRWXO); ++ id = semget(kt, 2, IPC_CREAT|perm); + } + } + if (id < 0) + + |