[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <50642ECB.20707@kernel.dk>
Date: Thu, 27 Sep 2012 12:47:39 +0200
From: Jens Axboe <axboe@...nel.dk>
To: Tejun Heo <tj@...nel.org>
CC: Maxim Levitsky <maximlevitsky@...il.com>,
Andrew Morton <akpm@...ux-foundation.org>,
Alex Dubov <oakad@...oo.com>, linux-kernel@...r.kernel.org
Subject: Re: [PATCH 1/2] scatterlist: add sg_nents
On 09/26/2012 06:38 PM, Tejun Heo wrote:
> (cc'ing Jens)
>
> On Wed, Sep 26, 2012 at 11:49:00AM +0200, Maxim Levitsky wrote:
>> Useful helper to know the number of entries in scatterlist.
>>
>> Signed-off-by: Maxim Levitsky <maximlevitsky@...il.com>
>> ---
>> include/linux/scatterlist.h | 1 +
>> lib/scatterlist.c | 22 ++++++++++++++++++++++
>> 2 files changed, 23 insertions(+)
>>
>> diff --git a/include/linux/scatterlist.h b/include/linux/scatterlist.h
>> index 7b600da..4bd6c06 100644
>> --- a/include/linux/scatterlist.h
>> +++ b/include/linux/scatterlist.h
>> @@ -201,6 +201,7 @@ static inline void *sg_virt(struct scatterlist *sg)
>> return page_address(sg_page(sg)) + sg->offset;
>> }
>>
>> +int sg_nents(struct scatterlist *sg);
>> struct scatterlist *sg_next(struct scatterlist *);
>> struct scatterlist *sg_last(struct scatterlist *s, unsigned int);
>> void sg_init_table(struct scatterlist *, unsigned int);
>> diff --git a/lib/scatterlist.c b/lib/scatterlist.c
>> index e76d85c..5cd9cdc 100644
>> --- a/lib/scatterlist.c
>> +++ b/lib/scatterlist.c
>> @@ -39,6 +39,28 @@ struct scatterlist *sg_next(struct scatterlist *sg)
>> EXPORT_SYMBOL(sg_next);
>>
>> /**
>> + * sg_nents - return total count of entries in scatterlist
>> + * @sg: The scatterlist
>> + *
>> + * Description:
>> + * Allows to know how many entries are in sg, taking into acount
>> + * chaining as well
>> + *
>> + **/
>> +int sg_nents(struct scatterlist *sg)
>> +{
>> + int nents = 0;
>> + while (sg) {
>> + nents++;
>> + sg = sg_next(sg);
>> + }
>> +
>> + return nents;
>> +}
>> +EXPORT_SYMBOL(sg_nents);
>
> How about the following instead?
>
> for (nents = 0; sg; sg = sg_next(sg))
> nents++;
> return nents;
>
> Other than that,
>
> Acked-by: Tejun Heo <tj@...nel.org>
Agree, that'd be cleaner. I've just applied it as-is. Maxim, feel free
to send an update to it. I pulled the driver bit into the
for-3.7/drivers branch as well.
--
Jens Axboe
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists