Move UPARG code to alloc_upcall() and test errors/return in callsites.
This patch removes flow control in macros which must be avoided.
(See Documentation/CodingStyle)

Signed-off-by: Fabian Frederick <f...@skynet.be>
---
This is untested.

 fs/coda/upcall.c | 107 +++++++++++++++++++++++++++++++++++--------------------
 1 file changed, 69 insertions(+), 38 deletions(-)

diff --git a/fs/coda/upcall.c b/fs/coda/upcall.c
index 9b1ffaa..7524f630 100644
--- a/fs/coda/upcall.c
+++ b/fs/coda/upcall.c
@@ -41,30 +41,24 @@
 static int coda_upcall(struct venus_comm *vc, int inSize, int *outSize,
                       union inputArgs *buffer);
 
-static void *alloc_upcall(int opcode, int size)
+static int alloc_upcall(int opcode, int insize, int *outsize,
+                       union inputArgs **inp, union outputArgs **outp)
 {
-       union inputArgs *inp;
+       CODA_ALLOC(*inp, union inputArgs *, insize);
+       if (!*inp)
+               return -ENOMEM;
 
-       CODA_ALLOC(inp, union inputArgs *, size);
-        if (!inp)
-               return ERR_PTR(-ENOMEM);
+       (*inp)->ih.opcode = opcode;
+       (*inp)->ih.pid = task_pid_nr_ns(current, &init_pid_ns);
+       (*inp)->ih.pgid = task_pgrp_nr_ns(current, &init_pid_ns);
+       (*inp)->ih.uid = from_kuid(&init_user_ns, current_fsuid());
 
-        inp->ih.opcode = opcode;
-       inp->ih.pid = task_pid_nr_ns(current, &init_pid_ns);
-       inp->ih.pgid = task_pgrp_nr_ns(current, &init_pid_ns);
-       inp->ih.uid = from_kuid(&init_user_ns, current_fsuid());
+       *outp = (union outputArgs *)inp;
+       *outsize = insize;
 
-       return (void*)inp;
+       return 0;
 }
 
-#define UPARG(op)\
-do {\
-       inp = (union inputArgs *)alloc_upcall(op, insize); \
-        if (IS_ERR(inp)) { return PTR_ERR(inp); }\
-        outp = (union outputArgs *)(inp); \
-        outsize = insize; \
-} while (0)
-
 #define INSIZE(tag) sizeof(struct coda_ ## tag ## _in)
 #define OUTSIZE(tag) sizeof(struct coda_ ## tag ## _out)
 #define SIZE(tag)  max_t(unsigned int, INSIZE(tag), OUTSIZE(tag))
@@ -78,7 +72,9 @@ int venus_rootfid(struct super_block *sb, struct CodaFid 
*fidp)
         int insize, outsize, error;
 
         insize = SIZE(root);
-        UPARG(CODA_ROOT);
+       error = alloc_upcall(CODA_ROOT, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
        error = coda_upcall(coda_vcp(sb), insize, &outsize, inp);
        if (!error)
@@ -96,7 +92,10 @@ int venus_getattr(struct super_block *sb, struct CodaFid 
*fid,
         int insize, outsize, error;
 
         insize = SIZE(getattr); 
-       UPARG(CODA_GETATTR);
+       error = alloc_upcall(CODA_GETATTR, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
+
         inp->coda_getattr.VFid = *fid;
 
        error = coda_upcall(coda_vcp(sb), insize, &outsize, inp);
@@ -115,7 +114,9 @@ int venus_setattr(struct super_block *sb, struct CodaFid 
*fid,
         int insize, outsize, error;
        
        insize = SIZE(setattr);
-       UPARG(CODA_SETATTR);
+       error = alloc_upcall(CODA_SETATTR, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_setattr.VFid = *fid;
        inp->coda_setattr.attr = *vattr;
@@ -137,7 +138,9 @@ int venus_lookup(struct super_block *sb, struct CodaFid 
*fid,
 
        offset = INSIZE(lookup);
         insize = max_t(unsigned int, offset + length +1, OUTSIZE(lookup));
-       UPARG(CODA_LOOKUP);
+       error = alloc_upcall(CODA_LOOKUP, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_lookup.VFid = *fid;
        inp->coda_lookup.name = offset;
@@ -164,8 +167,10 @@ int venus_close(struct super_block *sb, struct CodaFid 
*fid, int flags,
        int insize, outsize, error;
        
        insize = SIZE(release);
-       UPARG(CODA_CLOSE);
-       
+       error = alloc_upcall(CODA_CLOSE, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
+
        inp->ih.uid = from_kuid(&init_user_ns, uid);
         inp->coda_close.VFid = *fid;
         inp->coda_close.flags = flags;
@@ -184,7 +189,9 @@ int venus_open(struct super_block *sb, struct CodaFid *fid,
         int insize, outsize, error;
        
        insize = SIZE(open_by_fd);
-       UPARG(CODA_OPEN_BY_FD);
+       error = alloc_upcall(CODA_OPEN_BY_FD, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
        inp->coda_open_by_fd.VFid = *fid;
        inp->coda_open_by_fd.flags = flags;
@@ -208,7 +215,9 @@ int venus_mkdir(struct super_block *sb, struct CodaFid 
*dirfid,
 
        offset = INSIZE(mkdir);
        insize = max_t(unsigned int, offset + length + 1, OUTSIZE(mkdir));
-       UPARG(CODA_MKDIR);
+       error = alloc_upcall(CODA_MKDIR, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_mkdir.VFid = *dirfid;
         inp->coda_mkdir.attr = *attrs;
@@ -241,7 +250,9 @@ int venus_rename(struct super_block *sb, struct CodaFid 
*old_fid,
        offset = INSIZE(rename);
        insize = max_t(unsigned int, offset + new_length + old_length + 8,
                     OUTSIZE(rename)); 
-       UPARG(CODA_RENAME);
+       error = alloc_upcall(CODA_RENAME, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_rename.sourceFid = *old_fid;
         inp->coda_rename.destFid =  *new_fid;
@@ -276,7 +287,9 @@ int venus_create(struct super_block *sb, struct CodaFid 
*dirfid,
 
         offset = INSIZE(create);
        insize = max_t(unsigned int, offset + length + 1, OUTSIZE(create));
-       UPARG(CODA_CREATE);
+       error = alloc_upcall(CODA_CREATE, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_create.VFid = *dirfid;
         inp->coda_create.attr.va_mode = mode;
@@ -308,7 +321,9 @@ int venus_rmdir(struct super_block *sb, struct CodaFid 
*dirfid,
 
         offset = INSIZE(rmdir);
        insize = max_t(unsigned int, offset + length + 1, OUTSIZE(rmdir));
-       UPARG(CODA_RMDIR);
+       error = alloc_upcall(CODA_RMDIR, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_rmdir.VFid = *dirfid;
         inp->coda_rmdir.name = offset;
@@ -330,7 +345,9 @@ int venus_remove(struct super_block *sb, struct CodaFid 
*dirfid,
 
         offset = INSIZE(remove);
        insize = max_t(unsigned int, offset + length + 1, OUTSIZE(remove));
-       UPARG(CODA_REMOVE);
+       error = alloc_upcall(CODA_REMOVE, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_remove.VFid = *dirfid;
         inp->coda_remove.name = offset;
@@ -354,7 +371,9 @@ int venus_readlink(struct super_block *sb, struct CodaFid 
*fid,
         
        insize = max_t(unsigned int,
                     INSIZE(readlink), OUTSIZE(readlink)+ *length + 1);
-       UPARG(CODA_READLINK);
+       error = alloc_upcall(CODA_READLINK, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_readlink.VFid = *fid;
 
@@ -385,7 +404,9 @@ int venus_link(struct super_block *sb, struct CodaFid *fid,
 
        offset = INSIZE(link);
        insize = max_t(unsigned int, offset  + len + 1, OUTSIZE(link));
-        UPARG(CODA_LINK);
+       error = alloc_upcall(CODA_LINK, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_link.sourceFid = *fid;
         inp->coda_link.destFid = *dirfid;
@@ -412,8 +433,10 @@ int venus_symlink(struct super_block *sb, struct CodaFid 
*fid,
 
         offset = INSIZE(symlink);
        insize = max_t(unsigned int, offset + len + symlen + 8, 
OUTSIZE(symlink));
-       UPARG(CODA_SYMLINK);
-        
+       error = alloc_upcall(CODA_SYMLINK, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
+
         /*        inp->coda_symlink.attr = *tva; XXXXXX */ 
         inp->coda_symlink.VFid = *fid;
 
@@ -443,7 +466,9 @@ int venus_fsync(struct super_block *sb, struct CodaFid *fid)
        int insize, outsize, error;
        
        insize=SIZE(fsync);
-       UPARG(CODA_FSYNC);
+       error = alloc_upcall(CODA_FSYNC, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
        inp->coda_fsync.VFid = *fid;
        error = coda_upcall(coda_vcp(sb), sizeof(union inputArgs),
@@ -460,7 +485,9 @@ int venus_access(struct super_block *sb, struct CodaFid 
*fid, int mask)
        int insize, outsize, error;
 
        insize = SIZE(access);
-       UPARG(CODA_ACCESS);
+       error = alloc_upcall(CODA_ACCESS, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         inp->coda_access.VFid = *fid;
         inp->coda_access.flags = mask;
@@ -481,7 +508,9 @@ int venus_pioctl(struct super_block *sb, struct CodaFid 
*fid,
        int iocsize;
 
        insize = VC_MAXMSGSIZE;
-       UPARG(CODA_IOCTL);
+       error = alloc_upcall(CODA_IOCTL, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
         /* build packet for Venus */
         if (data->vi.in_size > VC_MAXDATASIZE) {
@@ -554,7 +583,9 @@ int venus_statfs(struct dentry *dentry, struct kstatfs *sfs)
         int insize, outsize, error;
         
        insize = max_t(unsigned int, INSIZE(statfs), OUTSIZE(statfs));
-       UPARG(CODA_STATFS);
+       error = alloc_upcall(CODA_STATFS, insize, &outsize, &inp, &outp);
+       if (error)
+               return error;
 
        error = coda_upcall(coda_vcp(dentry->d_sb), insize, &outsize, inp);
        if (!error) {
-- 
1.9.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to