All of lore.kernel.org
 help / color / mirror / Atom feed
From: Dan Carpenter <dan.carpenter@oracle.com>
To: James Simmons <jsimmons@infradead.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	devel@driverdev.osuosl.org,
	Andreas Dilger <andreas.dilger@intel.com>,
	Oleg Drokin <oleg.drokin@intel.com>, wang di <di.wang@intel.com>,
	Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,
	Lustre Development List <lustre-devel@lists.lustre.org>
Subject: [lustre-devel] [PATCH 05/60] staging: lustre: llite: check request != NULL in ll_migrate
Date: Mon, 30 Jan 2017 14:34:23 +0300	[thread overview]
Message-ID: <20170130113423.GB6881@mwanda> (raw)
In-Reply-To: <1485648328-2141-6-git-send-email-jsimmons@infradead.org>

On Sat, Jan 28, 2017 at 07:04:33PM -0500, James Simmons wrote:
> From: wang di <di.wang@intel.com>
> 
> Check if the request is NULL, before retrieve reply body
> from the request.
> 
> Signed-off-by: wang di <di.wang@intel.com>
> Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-7396
> Reviewed-on: http://review.whamcloud.com/17079
> Reviewed-by: John L. Hammond <john.hammond@intel.com>
> Reviewed-by: Andreas Dilger <andreas.dilger@intel.com>
> Signed-off-by: James Simmons <jsimmons@infradead.org>
> ---
>  drivers/staging/lustre/lustre/llite/file.c | 41 +++++++++++++++++-------------
>  1 file changed, 23 insertions(+), 18 deletions(-)
> 
> diff --git a/drivers/staging/lustre/lustre/llite/file.c b/drivers/staging/lustre/lustre/llite/file.c
> index a1e51a5..b681e15 100644
> --- a/drivers/staging/lustre/lustre/llite/file.c
> +++ b/drivers/staging/lustre/lustre/llite/file.c
> @@ -2656,28 +2656,33 @@ int ll_migrate(struct inode *parent, struct file *file, int mdtidx,
>  	if (!rc)
>  		ll_update_times(request, parent);
>  

I don't like how we return a non-NULL request on many error paths.  It
would be simpler to understand if mdc_rename() freed request on error.
So mdc_reint() fails but we still continue?  I don't understand that but
there are no comments about it.


> -	body = req_capsule_server_get(&request->rq_pill, &RMF_MDT_BODY);
> -	if (!body) {
> -		rc = -EPROTO;
> -		goto out_free;
> -	}
> +	if (request) {
> +		body = req_capsule_server_get(&request->rq_pill, &RMF_MDT_BODY);
> +		if (!body) {
> +			rc = -EPROTO;
> +			goto out_free;

We should call ptlrpc_req_finished(request) before returning on this
path.

regards,
dan carpenter

WARNING: multiple messages have this Message-ID (diff)
From: Dan Carpenter <dan.carpenter@oracle.com>
To: James Simmons <jsimmons@infradead.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	devel@driverdev.osuosl.org,
	Andreas Dilger <andreas.dilger@intel.com>,
	Oleg Drokin <oleg.drokin@intel.com>, wang di <di.wang@intel.com>,
	Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,
	Lustre Development List <lustre-devel@lists.lustre.org>
Subject: Re: [PATCH 05/60] staging: lustre: llite: check request != NULL in ll_migrate
Date: Mon, 30 Jan 2017 14:34:23 +0300	[thread overview]
Message-ID: <20170130113423.GB6881@mwanda> (raw)
In-Reply-To: <1485648328-2141-6-git-send-email-jsimmons@infradead.org>

On Sat, Jan 28, 2017 at 07:04:33PM -0500, James Simmons wrote:
> From: wang di <di.wang@intel.com>
> 
> Check if the request is NULL, before retrieve reply body
> from the request.
> 
> Signed-off-by: wang di <di.wang@intel.com>
> Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-7396
> Reviewed-on: http://review.whamcloud.com/17079
> Reviewed-by: John L. Hammond <john.hammond@intel.com>
> Reviewed-by: Andreas Dilger <andreas.dilger@intel.com>
> Signed-off-by: James Simmons <jsimmons@infradead.org>
> ---
>  drivers/staging/lustre/lustre/llite/file.c | 41 +++++++++++++++++-------------
>  1 file changed, 23 insertions(+), 18 deletions(-)
> 
> diff --git a/drivers/staging/lustre/lustre/llite/file.c b/drivers/staging/lustre/lustre/llite/file.c
> index a1e51a5..b681e15 100644
> --- a/drivers/staging/lustre/lustre/llite/file.c
> +++ b/drivers/staging/lustre/lustre/llite/file.c
> @@ -2656,28 +2656,33 @@ int ll_migrate(struct inode *parent, struct file *file, int mdtidx,
>  	if (!rc)
>  		ll_update_times(request, parent);
>  

I don't like how we return a non-NULL request on many error paths.  It
would be simpler to understand if mdc_rename() freed request on error.
So mdc_reint() fails but we still continue?  I don't understand that but
there are no comments about it.


> -	body = req_capsule_server_get(&request->rq_pill, &RMF_MDT_BODY);
> -	if (!body) {
> -		rc = -EPROTO;
> -		goto out_free;
> -	}
> +	if (request) {
> +		body = req_capsule_server_get(&request->rq_pill, &RMF_MDT_BODY);
> +		if (!body) {
> +			rc = -EPROTO;
> +			goto out_free;

We should call ptlrpc_req_finished(request) before returning on this
path.

regards,
dan carpenter

  reply	other threads:[~2017-01-30 11:34 UTC|newest]

Thread overview: 159+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-01-29  0:04 [lustre-devel] [PATCH 00/60] staging: lustre: batches of fixes for lustre client James Simmons
2017-01-29  0:04 ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 01/60] staging: lustre: llite: Remove access of stripe in ll_setattr_raw James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 02/60] staging: lustre: statahead: drop support for remote entry James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 03/60] staging: lustre: clio: add cl_page LRU shrinker James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 04/60] staging: lustre: mdc: quiet console message for known -EINTR James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 05/60] staging: lustre: llite: check request != NULL in ll_migrate James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-30 11:34   ` Dan Carpenter [this message]
2017-01-30 11:34     ` Dan Carpenter
2017-02-11 17:12     ` [lustre-devel] " James Simmons
2017-02-11 17:12       ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 06/60] staging: lustre: clio: revise readahead to support 16MB IO James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 07/60] staging: lustre: ptlrpc: set proper mbits for EINPROGRESS resend James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 08/60] staging: lustre: ldlm: Restore connect flags on failure James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 09/60] staging: lustre: lmv: Correctly generate target_obd James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 10/60] staging: lustre: obdclass: add more info to sysfs version string James Simmons
2017-01-29  0:04   ` James Simmons
2017-02-03 10:33   ` [lustre-devel] " Greg Kroah-Hartman
2017-02-03 10:33     ` Greg Kroah-Hartman
2017-02-08  1:04     ` [lustre-devel] " Dilger, Andreas
2017-02-08  1:04       ` Dilger, Andreas
2017-02-08  6:27       ` Greg Kroah-Hartman
2017-02-08  6:27         ` Greg Kroah-Hartman
2017-01-29  0:04 ` [lustre-devel] [PATCH 11/60] staging: lustre: obd: RCU stalls in lu_cache_shrink_count() James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 12/60] staging: lustre: lmv: Error not handled for lmv_find_target James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 13/60] staging: lustre: obdclass: health_check to report unhealthy upon LBUG James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-30 12:03   ` [lustre-devel] " Dan Carpenter
2017-01-30 12:03     ` Dan Carpenter
2017-01-31  1:00     ` [lustre-devel] " James Simmons
2017-01-31  1:00       ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 14/60] staging: lustre: lov: Ensure correct operation for large object sizes James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-31  8:53   ` [lustre-devel] " Dan Carpenter
2017-01-31  8:53     ` Dan Carpenter
2017-01-29  0:04 ` [lustre-devel] [PATCH 15/60] staging: lustre: hsm: stack overrun in hai_dump_data_field James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 16/60] staging: lustre: llite: don't ignore layout for group lock request James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 17/60] staging: lustre: obdclass: do not call lu_site_purge() for single object exceed James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 18/60] staging: lustre: ptlrpc: skip lock if export failed James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 19/60] staging: lustre: llite: handle inactive OSTs better in statfs James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 20/60] staging: lustre: llite: remove obsolete comment for ll_unlink() James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 21/60] staging: lustre: ptlrpc: correct use of list_add_tail() James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-31  8:54   ` [lustre-devel] " Dan Carpenter
2017-01-31  8:54     ` Dan Carpenter
2017-01-31 13:25     ` [lustre-devel] " Patrick Farrell
2017-01-29  0:04 ` [lustre-devel] [PATCH 22/60] staging: lustre: fid: fix race in fid allocation James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-31  8:55   ` [lustre-devel] " Dan Carpenter
2017-01-31  8:55     ` Dan Carpenter
2017-01-29  0:04 ` [lustre-devel] [PATCH 23/60] staging: lustre: lmv: remove unused placement parameter James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 24/60] staging: lustre: lustre: Remove old commented out code James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 25/60] staging: lustre: llite: normal user can't set FS default stripe James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 26/60] staging: lustre: llite: Trust creates in revalidate too James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 27/60] staging: lustre: mgc: handle config_llog_data::cld_refcount properly James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 28/60] staging: lustre: ldlm: ASSERTION(flock->blocking_export!=0) failed James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 29/60] staging: lustre: llite: Setting xattr are properly checked with and without ACLs James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 30/60] staging: lustre: ptlrpc: comment for FLD_QUERY RPC reply swab James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:04 ` [lustre-devel] [PATCH 31/60] staging: lustre: clio: sync write should update mtime James Simmons
2017-01-29  0:04   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 32/60] staging: lustre: osc: limits the number of chunks in write RPC James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 33/60] staging: lustre: libcfs: avoid stomping on module param cpu_pattern James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 34/60] staging: lustre: libcfs: default CPT matches NUMA topology James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 35/60] staging: lustre: lov: ld_target could be NULL James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 36/60] staging: lustre: header: remove assert from interval_set() James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 37/60] staging: lustre: llite: specify READA debug mask for ras_update James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 38/60] staging: lustre: llite: Adding timed wait in ll_umount_begin James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 39/60] staging: libcfs: remove integer types abstraction from libcfs James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 40/60] staging: ptlrpc: leaked rs on difficult reply James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 41/60] staging: lustre: osc: osc_match_base prototype differs from declaration James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 42/60] staging: lustre: ptlrpc: allow blocking asts to be delayed James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 43/60] staging: lustre: obd: remove OBD_NOTIFY_CREATE James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 44/60] staging: lustre: libcfs: fix error messages James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 45/60] staging: lustre: libcfs: Change positional struct initializers to C99 James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 46/60] staging: lustre: mdc: Make IT_OPEN take lookup bits lock James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 47/60] staging: lustre: mdc: avoid returning freed request James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 48/60] staging: lustre: ksocklnd: ignore timedout TX on closing connection James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 49/60] staging: lustre: socklnd: remove socklnd_init_msg James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 50/60] staging: lustre: ptlrpc: remove unused pc->pc_env James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 51/60] staging: lustre: ptlrpc: update MODULE_PARAM_DESC in ptlrpcd.c James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 52/60] staging: lustre: linkea: linkEA size limitation James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 53/60] staging: lustre: ptlrpc: update replay cursor when close during replay James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 54/60] staging: lustre: fid: Change positional struct initializers to C99 James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 55/60] staging: lustre: obd: move s3 in lmd_parse to inner loop James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 56/60] staging: lustre: llite: don't invoke direct_IO for the EOF case James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 57/60] staging: lustre: lmv: remove nlink check in lmv_revalidate_slaves James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 58/60] staging: lustre: osc: avoid 64 divide in osc_cache_too_much James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 59/60] staging: lustre: ptlrpc : remove userland usage from ptlrpc James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-29  0:05 ` [lustre-devel] [PATCH 60/60] staging: lustre: libcfs: fix minimum size check for libcfs ioctl James Simmons
2017-01-29  0:05   ` James Simmons
2017-01-30 10:51   ` [lustre-devel] " Dan Carpenter
2017-01-30 10:51     ` Dan Carpenter
2017-01-30 10:54     ` [lustre-devel] " Dan Carpenter
2017-01-30 10:54       ` Dan Carpenter
2017-01-31  0:48       ` [lustre-devel] " James Simmons
2017-01-31  0:48         ` James Simmons
2017-01-31  2:25     ` [lustre-devel] " James Simmons
2017-01-31  2:25       ` James Simmons
2017-01-31  8:13       ` [lustre-devel] " Dan Carpenter
2017-01-31  8:13         ` Dan Carpenter
2017-02-01 13:32       ` [lustre-devel] " Olaf Weber
2017-02-01 13:32         ` Olaf Weber
2017-02-01 16:39         ` Greg Kroah-Hartman
2017-02-01 16:39           ` Greg Kroah-Hartman
2017-02-03 10:46 ` [lustre-devel] [PATCH 00/60] staging: lustre: batches of fixes for lustre client Greg Kroah-Hartman
2017-02-03 10:46   ` Greg Kroah-Hartman

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20170130113423.GB6881@mwanda \
    --to=dan.carpenter@oracle.com \
    --cc=andreas.dilger@intel.com \
    --cc=devel@driverdev.osuosl.org \
    --cc=di.wang@intel.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=jsimmons@infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=lustre-devel@lists.lustre.org \
    --cc=oleg.drokin@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.