Simplify error handling in this function implementation.
* Delete unnecessary pointer checks and variable assignments.
* Omit a redundant function call.
This issue was detected by using the Coccinelle software.
Signed-off-by: Markus Elfring <elfring@users.sourceforge.net>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Carlos Maiolino <cem@kernel.org>
        xfs_mru_cache_free_func_t free_func)
 {
        struct xfs_mru_cache    *mru = NULL;
-       int                     err = 0, grp;
+       int                     grp;
        unsigned int            grp_time;
 
        if (mrup)
        mru->lists = kzalloc(mru->grp_count * sizeof(*mru->lists),
                                GFP_KERNEL | __GFP_NOFAIL);
        if (!mru->lists) {
-               err = -ENOMEM;
-               goto exit;
+               kfree(mru);
+               return -ENOMEM;
        }
 
        for (grp = 0; grp < mru->grp_count; grp++)
        mru->free_func = free_func;
        mru->data = data;
        *mrup = mru;
-
-exit:
-       if (err && mru && mru->lists)
-               kfree(mru->lists);
-       if (err && mru)
-               kfree(mru);
-
-       return err;
+       return 0;
 }
 
 /*