From f129142dde2a2637b2e638ca0cca372a45188923 Mon Sep 17 00:00:00 2001 From: Marc Dionne Date: Sat, 29 Oct 2011 19:23:07 -0400 Subject: [PATCH] Linux: 3.1: update RCU path walking detection in permission i_op The permission() inode operation changed again with kernel 3.1, back to the form it had before 2.6.38. This compiles fine, but is missing the new way of detecting when we get called in RCU path walking mode, resulting in system hangs. Reviewed-on: http://gerrit.openafs.org/5740 Tested-by: BuildBot Reviewed-by: Derrick Brashear (cherry picked from commit 4952df3f0359531e4a660c99c94c51eb0b169f59) Change-Id: Ibd497309e6699fb585cf70e618373e800b73cbb8 Reviewed-on: http://gerrit.openafs.org/6088 Tested-by: BuildBot Reviewed-by: Derrick Brashear --- src/afs/LINUX/osi_vnodeops.c | 5 ++++- 1 files changed, 4 insertions(+), 1 deletions(-) diff --git a/src/afs/LINUX/osi_vnodeops.c b/src/afs/LINUX/osi_vnodeops.c index e9215db..696146b 100644 --- a/src/afs/LINUX/osi_vnodeops.c +++ b/src/afs/LINUX/osi_vnodeops.c @@ -2245,10 +2245,13 @@ afs_linux_permission(struct inode *ip, int mode) cred_t *credp; int tmp = 0; + /* Check for RCU path walking */ #if defined(IOP_PERMISSION_TAKES_FLAGS) - /* We don't support RCU path walking */ if (flags & IPERM_FLAG_RCU) return -ECHILD; +#elif defined(MAY_NOT_BLOCK) + if (mode & MAY_NOT_BLOCK) + return -ECHILD; #endif credp = crref(); -- 1.7.2.5