]> git.michaelhowe.org Git - packages/o/openafs.git/commitdiff
DEVEL15-linux-avoid-returning-invalid-pointers-on-error-20090402
authorSimon Wilkinson <sxw@inf.ed.ac.uk>
Mon, 6 Apr 2009 23:50:32 +0000 (23:50 +0000)
committerDerrick Brashear <shadow@dementia.org>
Mon, 6 Apr 2009 23:50:32 +0000 (23:50 +0000)
LICENSE IPL10
FIXES 124580

avoid returning a positive error as it will look like a pointer.

src/afs/LINUX/osi_vnodeops.c
src/afs/VNOPS/afs_vnop_lookup.c

index f5ec0ad7713552ed870ce069c9b4a1c785afe4a3..2b63d2fa96f80ca8848f25d3a86467a5552ebee4 100644 (file)
@@ -1184,8 +1184,10 @@ afs_linux_lookup(struct inode *dip, struct dentry *dp)
     if (code == ENOENT)
        return ERR_PTR(0);
 #endif
-    else
-       return ERR_PTR(-code);
+    else if ((code >= 0) && (code <= MAX_ERRNO))
+        return ERR_PTR(-code);
+    else 
+       return ERR_PTR(-EIO);
 #else
     if (code == ENOENT)
        code = 0;
@@ -1525,7 +1527,10 @@ afs_linux_follow_link(struct dentry *dp, struct dentry *basep,
 
     if (code < 0) {
        dput(basep);
-       res = ERR_PTR(code);
+       if (code < -MAX_ERRNO)
+           res = ERR_PTR(-EIO);
+       else
+           res = ERR_PTR(code);
     } else {
        name[code] = '\0';
        res = lookup_dentry(name, basep, follow);
index 2c2bd3c12e8d84793acb81e19b7c41cff92028fd..eeac33b2dc9686e30bb066bf2bd114148791fe23 100644 (file)
@@ -1182,7 +1182,7 @@ afs_DoBulkStat(struct vcache *adp, long dirCookie, struct vrequest *areqp)
        afs_PutVolume(volp, READ_LOCK);
 
     /* If we did the InlineBulk RPC pull out the return code */
-    if (inlinebulk) {
+    if (inlinebulk && code == 0) {
        if ((&statsp[0])->errorCode) {
            afs_Analyze(tcp, (&statsp[0])->errorCode, &adp->f.fid, areqp,
                        AFS_STATS_FS_RPCIDX_BULKSTATUS, SHARED_LOCK, NULL);