Linux RDMA and InfiniBand development
 help / color / mirror / Atom feed
From: Zhu Yanjun <yanjun.zhu@linux.dev>
To: "Zhijian Li (Fujitsu)" <lizhijian@fujitsu.com>,
	"zyjzyj2000@gmail.com" <zyjzyj2000@gmail.com>,
	"jgg@ziepe.ca" <jgg@ziepe.ca>,
	"leon@kernel.org" <leon@kernel.org>,
	"linux-rdma@vger.kernel.org" <linux-rdma@vger.kernel.org>
Subject: Re: [PATCH 1/1] RDMA/rxe: Return the correct errno
Date: Thu, 11 Apr 2024 12:55:18 +0200	[thread overview]
Message-ID: <5cb275ac-0405-4097-bd63-a64fe58bfc92@linux.dev> (raw)
In-Reply-To: <402329bf-b959-4210-a3a0-7a3847dd8811@fujitsu.com>


在 2024/4/11 11:11, Zhijian Li (Fujitsu) 写道:
>
> On 08/04/2024 22:21, Zhu Yanjun wrote:
>> In the function __rxe_add_to_pool, the function xa_alloc_cyclic is
>> called. The return value of the function xa_alloc_cyclic is as below:
>> "
>>    Return: 0 if the allocation succeeded without wrapping.  1 if the
>>    allocation succeeded after wrapping, -ENOMEM if memory could not be
>>    allocated or -EBUSY if there are no free entries in @limit.
>> "
>> But now the function __rxe_add_to_pool only returns -EINVAL. All the
>> returned error value should be returned to the caller.
>>
> make sense.
>
>
>> Signed-off-by: Zhu Yanjun <yanjun.zhu@linux.dev>
>> ---
>>    drivers/infiniband/sw/rxe/rxe_pool.c | 6 ++++--
>>    1 file changed, 4 insertions(+), 2 deletions(-)
>>
>> diff --git a/drivers/infiniband/sw/rxe/rxe_pool.c b/drivers/infiniband/sw/rxe/rxe_pool.c
>> index 6215c6de3a84..43ba0277bd7b 100644
>> --- a/drivers/infiniband/sw/rxe/rxe_pool.c
>> +++ b/drivers/infiniband/sw/rxe/rxe_pool.c
>> @@ -122,8 +122,10 @@ int __rxe_add_to_pool(struct rxe_pool *pool, struct rxe_pool_elem *elem,
>>    	int err;
> I'd like to assign 'err' a default error code: -EINVAL

Thanks a lot for your comments.

Before the local variable err is used, this variable err has already 
been set.

As such, it is not necessary to initialize this local variable when it 
is declared.

Best Regards,

Zhu Yanjun

>
>
> Thanks
> Zhijian
>
>
>
>>    	gfp_t gfp_flags;
>>    
>> -	if (atomic_inc_return(&pool->num_elem) > pool->max_elem)
>> +	if (atomic_inc_return(&pool->num_elem) > pool->max_elem) {
>> +		err = -EINVAL;
>>    		goto err_cnt;
>> +	}
>>    
>>    	elem->pool = pool;
>>    	elem->obj = (u8 *)elem - pool->elem_offset;
>> @@ -147,7 +149,7 @@ int __rxe_add_to_pool(struct rxe_pool *pool, struct rxe_pool_elem *elem,
>>    
>>    err_cnt:
>>    	atomic_dec(&pool->num_elem);
>> -	return -EINVAL;
>> +	return err;
>>    }
>>    
>>    void *rxe_pool_get_index(struct rxe_pool *pool, u32 index)

  reply	other threads:[~2024-04-11 10:55 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-04-08 14:21 [PATCH 1/1] RDMA/rxe: Return the correct errno Zhu Yanjun
2024-04-11  9:11 ` Zhijian Li (Fujitsu)
2024-04-11 10:55   ` Zhu Yanjun [this message]
2024-04-11 11:47 ` Leon Romanovsky

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=5cb275ac-0405-4097-bd63-a64fe58bfc92@linux.dev \
    --to=yanjun.zhu@linux.dev \
    --cc=jgg@ziepe.ca \
    --cc=leon@kernel.org \
    --cc=linux-rdma@vger.kernel.org \
    --cc=lizhijian@fujitsu.com \
    --cc=zyjzyj2000@gmail.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox