All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v3] lib: add size unit t/p/e to memparse
@ 2014-04-02  8:54 Gui Hecheng
  2014-05-15  1:39 ` [ping][PATCH " Gui Hecheng
                   ` (2 more replies)
  0 siblings, 3 replies; 7+ messages in thread
From: Gui Hecheng @ 2014-04-02  8:54 UTC (permalink / raw)
  To: linux-kernel; +Cc: linux-btrfs, 1i5t5.duncan, Gui Hecheng

For modern filesystems such as btrfs, t/p/e size level operations
are common.
add size unit t/p/e parsing to memparse

Signed-off-by: Gui Hecheng <guihc.fnst@cn.fujitsu.com>
---
changelog
	v1->v2: replace kilobyte with kibibyte, and others
	v2->v3: add missing unit "bytes" in comment
---
 lib/cmdline.c | 25 ++++++++++++++++++++-----
 1 file changed, 20 insertions(+), 5 deletions(-)

diff --git a/lib/cmdline.c b/lib/cmdline.c
index eb67911..511b9be 100644
--- a/lib/cmdline.c
+++ b/lib/cmdline.c
@@ -119,11 +119,17 @@ char *get_options(const char *str, int nints, int *ints)
  *	@retptr: (output) Optional pointer to next char after parse completes
  *
  *	Parses a string into a number.  The number stored at @ptr is
- *	potentially suffixed with %K (for kilobytes, or 1024 bytes),
- *	%M (for megabytes, or 1048576 bytes), or %G (for gigabytes, or
- *	1073741824).  If the number is suffixed with K, M, or G, then
- *	the return value is the number multiplied by one kilobyte, one
- *	megabyte, or one gigabyte, respectively.
+ *	potentially suffixed with
+ *	%K (for kibibytes, or 1024 bytes),
+ *	%M (for mebibytes, or 1048576 bytes),
+ *	%G (for gibibytes, or 1073741824 bytes),
+ *	%T (for tebibytes, or 1099511627776 bytes),
+ *	%P (for pebibytes, or 1125899906842624 bytes),
+ *	%E (for exbibytes, or 1152921504606846976 bytes).
+ *	If the number is suffixed with K, M, G, T, P, E, then
+ *	the return value is the number multiplied by one kibibyte, one
+ *	mebibyte, one gibibyte, one tebibyte, one pebibyte, one exbibyte,
+ *	respectively.
  */
 
 unsigned long long memparse(const char *ptr, char **retptr)
@@ -133,6 +139,15 @@ unsigned long long memparse(const char *ptr, char **retptr)
 	unsigned long long ret = simple_strtoull(ptr, &endptr, 0);
 
 	switch (*endptr) {
+	case 'E':
+	case 'e':
+		ret <<= 10;
+	case 'P':
+	case 'p':
+		ret <<= 10;
+	case 'T':
+	case 't':
+		ret <<= 10;
 	case 'G':
 	case 'g':
 		ret <<= 10;
-- 
1.8.1.4


^ permalink raw reply related	[flat|nested] 7+ messages in thread

* Re: [ping][PATCH v3] lib: add size unit t/p/e to memparse
  2014-04-02  8:54 [PATCH v3] lib: add size unit t/p/e to memparse Gui Hecheng
@ 2014-05-15  1:39 ` Gui Hecheng
  2014-06-05  9:03 ` ·[ping][PATCH " Gui Hecheng
  2014-06-12 21:15 ` [PATCH " Andrew Morton
  2 siblings, 0 replies; 7+ messages in thread
From: Gui Hecheng @ 2014-05-15  1:39 UTC (permalink / raw)
  To: clm; +Cc: linux-kernel, linux-btrfs

On Wed, 2014-04-02 at 16:54 +0800, Gui Hecheng wrote:
> For modern filesystems such as btrfs, t/p/e size level operations
> are common.
> add size unit t/p/e parsing to memparse
> 
> Signed-off-by: Gui Hecheng <guihc.fnst@cn.fujitsu.com>
> ---
> changelog
> 	v1->v2: replace kilobyte with kibibyte, and others
> 	v2->v3: add missing unit "bytes" in comment
> ---
>  lib/cmdline.c | 25 ++++++++++++++++++++-----
>  1 file changed, 20 insertions(+), 5 deletions(-)
> 
> diff --git a/lib/cmdline.c b/lib/cmdline.c
> index eb67911..511b9be 100644
> --- a/lib/cmdline.c
> +++ b/lib/cmdline.c
> @@ -119,11 +119,17 @@ char *get_options(const char *str, int nints, int *ints)
>   *	@retptr: (output) Optional pointer to next char after parse completes
>   *
>   *	Parses a string into a number.  The number stored at @ptr is
> - *	potentially suffixed with %K (for kilobytes, or 1024 bytes),
> - *	%M (for megabytes, or 1048576 bytes), or %G (for gigabytes, or
> - *	1073741824).  If the number is suffixed with K, M, or G, then
> - *	the return value is the number multiplied by one kilobyte, one
> - *	megabyte, or one gigabyte, respectively.
> + *	potentially suffixed with
> + *	%K (for kibibytes, or 1024 bytes),
> + *	%M (for mebibytes, or 1048576 bytes),
> + *	%G (for gibibytes, or 1073741824 bytes),
> + *	%T (for tebibytes, or 1099511627776 bytes),
> + *	%P (for pebibytes, or 1125899906842624 bytes),
> + *	%E (for exbibytes, or 1152921504606846976 bytes).
> + *	If the number is suffixed with K, M, G, T, P, E, then
> + *	the return value is the number multiplied by one kibibyte, one
> + *	mebibyte, one gibibyte, one tebibyte, one pebibyte, one exbibyte,
> + *	respectively.
>   */
>  
>  unsigned long long memparse(const char *ptr, char **retptr)
> @@ -133,6 +139,15 @@ unsigned long long memparse(const char *ptr, char **retptr)
>  	unsigned long long ret = simple_strtoull(ptr, &endptr, 0);
>  
>  	switch (*endptr) {
> +	case 'E':
> +	case 'e':
> +		ret <<= 10;
> +	case 'P':
> +	case 'p':
> +		ret <<= 10;
> +	case 'T':
> +	case 't':
> +		ret <<= 10;
>  	case 'G':
>  	case 'g':
>  		ret <<= 10;



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: ·[ping][PATCH v3] lib: add size unit t/p/e to memparse
  2014-04-02  8:54 [PATCH v3] lib: add size unit t/p/e to memparse Gui Hecheng
  2014-05-15  1:39 ` [ping][PATCH " Gui Hecheng
@ 2014-06-05  9:03 ` Gui Hecheng
  2014-06-12 21:15 ` [PATCH " Andrew Morton
  2 siblings, 0 replies; 7+ messages in thread
From: Gui Hecheng @ 2014-06-05  9:03 UTC (permalink / raw)
  To: akpm; +Cc: linux-btrfs, linux-kernel

On Wed, 2014-04-02 at 16:54 +0800, Gui Hecheng wrote:
> For modern filesystems such as btrfs, t/p/e size level operations
> are common.
> add size unit t/p/e parsing to memparse
> 
> Signed-off-by: Gui Hecheng <guihc.fnst@cn.fujitsu.com>
> ---
> changelog
> 	v1->v2: replace kilobyte with kibibyte, and others
> 	v2->v3: add missing unit "bytes" in comment
> ---
>  lib/cmdline.c | 25 ++++++++++++++++++++-----
>  1 file changed, 20 insertions(+), 5 deletions(-)
> 
> diff --git a/lib/cmdline.c b/lib/cmdline.c
> index eb67911..511b9be 100644
> --- a/lib/cmdline.c
> +++ b/lib/cmdline.c
> @@ -119,11 +119,17 @@ char *get_options(const char *str, int nints, int *ints)
>   *	@retptr: (output) Optional pointer to next char after parse completes
>   *
>   *	Parses a string into a number.  The number stored at @ptr is
> - *	potentially suffixed with %K (for kilobytes, or 1024 bytes),
> - *	%M (for megabytes, or 1048576 bytes), or %G (for gigabytes, or
> - *	1073741824).  If the number is suffixed with K, M, or G, then
> - *	the return value is the number multiplied by one kilobyte, one
> - *	megabyte, or one gigabyte, respectively.
> + *	potentially suffixed with
> + *	%K (for kibibytes, or 1024 bytes),
> + *	%M (for mebibytes, or 1048576 bytes),
> + *	%G (for gibibytes, or 1073741824 bytes),
> + *	%T (for tebibytes, or 1099511627776 bytes),
> + *	%P (for pebibytes, or 1125899906842624 bytes),
> + *	%E (for exbibytes, or 1152921504606846976 bytes).
> + *	If the number is suffixed with K, M, G, T, P, E, then
> + *	the return value is the number multiplied by one kibibyte, one
> + *	mebibyte, one gibibyte, one tebibyte, one pebibyte, one exbibyte,
> + *	respectively.
>   */
>  
>  unsigned long long memparse(const char *ptr, char **retptr)
> @@ -133,6 +139,15 @@ unsigned long long memparse(const char *ptr, char **retptr)
>  	unsigned long long ret = simple_strtoull(ptr, &endptr, 0);
>  
>  	switch (*endptr) {
> +	case 'E':
> +	case 'e':
> +		ret <<= 10;
> +	case 'P':
> +	case 'p':
> +		ret <<= 10;
> +	case 'T':
> +	case 't':
> +		ret <<= 10;
>  	case 'G':
>  	case 'g':
>  		ret <<= 10;



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3] lib: add size unit t/p/e to memparse
  2014-04-02  8:54 [PATCH v3] lib: add size unit t/p/e to memparse Gui Hecheng
  2014-05-15  1:39 ` [ping][PATCH " Gui Hecheng
  2014-06-05  9:03 ` ·[ping][PATCH " Gui Hecheng
@ 2014-06-12 21:15 ` Andrew Morton
  2014-06-13  1:33   ` Gui Hecheng
  2014-06-13  5:54   ` Brendan Hide
  2 siblings, 2 replies; 7+ messages in thread
From: Andrew Morton @ 2014-06-12 21:15 UTC (permalink / raw)
  To: Gui Hecheng; +Cc: linux-kernel, linux-btrfs, 1i5t5.duncan

On Wed, 2 Apr 2014 16:54:37 +0800 Gui Hecheng <guihc.fnst@cn.fujitsu.com> wrote:

> For modern filesystems such as btrfs, t/p/e size level operations
> are common.
> add size unit t/p/e parsing to memparse
> 
> Signed-off-by: Gui Hecheng <guihc.fnst@cn.fujitsu.com>
> ---
> changelog
> 	v1->v2: replace kilobyte with kibibyte, and others
> 	v2->v3: add missing unit "bytes" in comment
> ---
>  lib/cmdline.c | 25 ++++++++++++++++++++-----
>  1 file changed, 20 insertions(+), 5 deletions(-)
> 
> diff --git a/lib/cmdline.c b/lib/cmdline.c
> index eb67911..511b9be 100644
> --- a/lib/cmdline.c
> +++ b/lib/cmdline.c
> @@ -119,11 +119,17 @@ char *get_options(const char *str, int nints, int *ints)
>   *	@retptr: (output) Optional pointer to next char after parse completes
>   *
>   *	Parses a string into a number.  The number stored at @ptr is
> - *	potentially suffixed with %K (for kilobytes, or 1024 bytes),
> - *	%M (for megabytes, or 1048576 bytes), or %G (for gigabytes, or
> - *	1073741824).  If the number is suffixed with K, M, or G, then
> - *	the return value is the number multiplied by one kilobyte, one
> - *	megabyte, or one gigabyte, respectively.
> + *	potentially suffixed with
> + *	%K (for kibibytes, or 1024 bytes),
> + *	%M (for mebibytes, or 1048576 bytes),
> + *	%G (for gibibytes, or 1073741824 bytes),
> + *	%T (for tebibytes, or 1099511627776 bytes),
> + *	%P (for pebibytes, or 1125899906842624 bytes),
> + *	%E (for exbibytes, or 1152921504606846976 bytes).

I'm afraid I find these names quite idiotic - we all know what the
traditional terms mean so why go and muck with it.

Also, kibibytes sounds like cat food.

> @@ -133,6 +139,15 @@ unsigned long long memparse(const char *ptr, char **retptr)
>  	unsigned long long ret = simple_strtoull(ptr, &endptr, 0);
>  
>  	switch (*endptr) {
> +	case 'E':
> +	case 'e':
> +		ret <<= 10;
> +	case 'P':
> +	case 'p':
> +		ret <<= 10;
> +	case 'T':
> +	case 't':
> +		ret <<= 10;
>  	case 'G':
>  	case 'g':
>  		ret <<= 10;

That bit makes sense.

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3] lib: add size unit t/p/e to memparse
  2014-06-12 21:15 ` [PATCH " Andrew Morton
@ 2014-06-13  1:33   ` Gui Hecheng
  2014-06-13  5:54   ` Brendan Hide
  1 sibling, 0 replies; 7+ messages in thread
From: Gui Hecheng @ 2014-06-13  1:33 UTC (permalink / raw)
  To: Andrew Morton; +Cc: linux-kernel, linux-btrfs, 1i5t5.duncan

On Thu, 2014-06-12 at 14:15 -0700, Andrew Morton wrote:
> On Wed, 2 Apr 2014 16:54:37 +0800 Gui Hecheng <guihc.fnst@cn.fujitsu.com> wrote:
> 
> > For modern filesystems such as btrfs, t/p/e size level operations
> > are common.
> > add size unit t/p/e parsing to memparse
> > 
> > Signed-off-by: Gui Hecheng <guihc.fnst@cn.fujitsu.com>
> > ---
> > changelog
> > 	v1->v2: replace kilobyte with kibibyte, and others
> > 	v2->v3: add missing unit "bytes" in comment
> > ---
> >  lib/cmdline.c | 25 ++++++++++++++++++++-----
> >  1 file changed, 20 insertions(+), 5 deletions(-)
> > 
> > diff --git a/lib/cmdline.c b/lib/cmdline.c
> > index eb67911..511b9be 100644
> > --- a/lib/cmdline.c
> > +++ b/lib/cmdline.c
> > @@ -119,11 +119,17 @@ char *get_options(const char *str, int nints, int *ints)
> >   *	@retptr: (output) Optional pointer to next char after parse completes
> >   *
> >   *	Parses a string into a number.  The number stored at @ptr is
> > - *	potentially suffixed with %K (for kilobytes, or 1024 bytes),
> > - *	%M (for megabytes, or 1048576 bytes), or %G (for gigabytes, or
> > - *	1073741824).  If the number is suffixed with K, M, or G, then
> > - *	the return value is the number multiplied by one kilobyte, one
> > - *	megabyte, or one gigabyte, respectively.
> > + *	potentially suffixed with
> > + *	%K (for kibibytes, or 1024 bytes),
> > + *	%M (for mebibytes, or 1048576 bytes),
> > + *	%G (for gibibytes, or 1073741824 bytes),
> > + *	%T (for tebibytes, or 1099511627776 bytes),
> > + *	%P (for pebibytes, or 1125899906842624 bytes),
> > + *	%E (for exbibytes, or 1152921504606846976 bytes).
> 
> I'm afraid I find these names quite idiotic - we all know what the
> traditional terms mean so why go and muck with it.
> 
> Also, kibibytes sounds like cat food.

Yes, I will cleanup this part, Thanks very much.

-Gui

> > @@ -133,6 +139,15 @@ unsigned long long memparse(const char *ptr, char **retptr)
> >  	unsigned long long ret = simple_strtoull(ptr, &endptr, 0);
> >  
> >  	switch (*endptr) {
> > +	case 'E':
> > +	case 'e':
> > +		ret <<= 10;
> > +	case 'P':
> > +	case 'p':
> > +		ret <<= 10;
> > +	case 'T':
> > +	case 't':
> > +		ret <<= 10;
> >  	case 'G':
> >  	case 'g':
> >  		ret <<= 10;
> 
> That bit makes sense.



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3] lib: add size unit t/p/e to memparse
  2014-06-12 21:15 ` [PATCH " Andrew Morton
  2014-06-13  1:33   ` Gui Hecheng
@ 2014-06-13  5:54   ` Brendan Hide
  2014-06-13  6:56     ` Hugo Mills
  1 sibling, 1 reply; 7+ messages in thread
From: Brendan Hide @ 2014-06-13  5:54 UTC (permalink / raw)
  To: Andrew Morton, Gui Hecheng; +Cc: linux-kernel, linux-btrfs, 1i5t5.duncan

On 12/06/14 23:15, Andrew Morton wrote:
> On Wed, 2 Apr 2014 16:54:37 +0800 Gui Hecheng <guihc.fnst@cn.fujitsu.com> wrote:
>
>> For modern filesystems such as btrfs, t/p/e size level operations
>> are common.
>> add size unit t/p/e parsing to memparse
>>
>> Signed-off-by: Gui Hecheng <guihc.fnst@cn.fujitsu.com>
>> ---
>> changelog
>> 	v1->v2: replace kilobyte with kibibyte, and others
>> 	v2->v3: add missing unit "bytes" in comment
>> ---
>>   lib/cmdline.c | 25 ++++++++++++++++++++-----
>>   1 file changed, 20 insertions(+), 5 deletions(-)
>>
>> diff --git a/lib/cmdline.c b/lib/cmdline.c
>> index eb67911..511b9be 100644
>> --- a/lib/cmdline.c
>> +++ b/lib/cmdline.c
>> @@ -119,11 +119,17 @@ char *get_options(const char *str, int nints, int *ints)
>>    *	@retptr: (output) Optional pointer to next char after parse completes
>>    *
>>    *	Parses a string into a number.  The number stored at @ptr is
>> - *	potentially suffixed with %K (for kilobytes, or 1024 bytes),
>> - *	%M (for megabytes, or 1048576 bytes), or %G (for gigabytes, or
>> - *	1073741824).  If the number is suffixed with K, M, or G, then
>> - *	the return value is the number multiplied by one kilobyte, one
>> - *	megabyte, or one gigabyte, respectively.
>> + *	potentially suffixed with
>> + *	%K (for kibibytes, or 1024 bytes),
>> + *	%M (for mebibytes, or 1048576 bytes),
>> + *	%G (for gibibytes, or 1073741824 bytes),
>> + *	%T (for tebibytes, or 1099511627776 bytes),
>> + *	%P (for pebibytes, or 1125899906842624 bytes),
>> + *	%E (for exbibytes, or 1152921504606846976 bytes).
> I'm afraid I find these names quite idiotic - we all know what the
> traditional terms mean so why go and muck with it.
>
> Also, kibibytes sounds like cat food.
Hi, Andrew

While I agree it sounds like cat food, it seemed like a good opportunity 
to fix a minor issue that is otherwise unlikely to be fixed for a very 
long time. Should we feel uncomfortable with the patch, as is, because 
of language/correctness friction? Pedantry included, the patch is 
correct. ;)

Thanks

-- 
__________
Brendan Hide
http://swiftspirit.co.za/
http://www.webafrica.co.za/?AFF1E97


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3] lib: add size unit t/p/e to memparse
  2014-06-13  5:54   ` Brendan Hide
@ 2014-06-13  6:56     ` Hugo Mills
  0 siblings, 0 replies; 7+ messages in thread
From: Hugo Mills @ 2014-06-13  6:56 UTC (permalink / raw)
  To: Brendan Hide
  Cc: Andrew Morton, Gui Hecheng, linux-kernel, linux-btrfs, 1i5t5.duncan

[-- Attachment #1: Type: text/plain, Size: 1853 bytes --]

On Fri, Jun 13, 2014 at 07:54:44AM +0200, Brendan Hide wrote:
> On 12/06/14 23:15, Andrew Morton wrote:
> >On Wed, 2 Apr 2014 16:54:37 +0800 Gui Hecheng <guihc.fnst@cn.fujitsu.com> wrote:
> >>+ *	%K (for kibibytes, or 1024 bytes),
> >>+ *	%M (for mebibytes, or 1048576 bytes),
> >>+ *	%G (for gibibytes, or 1073741824 bytes),
> >>+ *	%T (for tebibytes, or 1099511627776 bytes),
> >>+ *	%P (for pebibytes, or 1125899906842624 bytes),
> >>+ *	%E (for exbibytes, or 1152921504606846976 bytes).
> >I'm afraid I find these names quite idiotic - we all know what the
> >traditional terms mean so why go and muck with it.
> >
> >Also, kibibytes sounds like cat food.
> Hi, Andrew
> 
> While I agree it sounds like cat food, it seemed like a good opportunity to
> fix a minor issue that is otherwise unlikely to be fixed for a very long
> time. Should we feel uncomfortable with the patch, as is, because of
> language/correctness friction? Pedantry included, the patch is correct. ;)

   Last night, I wrote a very grumpy reply to Andrew. I'm glad I
didn't send it, because Brendan has managed to cover at least one of
my points much more politely than I did.

   My other comment is that TB vs TiB is a 10% difference in the
magnitude of the number, and so the accumulated error is now no longer
small enough to be brushed under the carpet as we all did in days
past. By Andrew's thinking, a 4 TB disk is 3.638 TB in size. I'd say a
4 TB disk is 3.638 TiB in size, and I can be precise (±1GB in the
latter case) with both values.

   Hugo.

PS. Let's just not talk about 1.44 "MB" floppy disks.

-- 
=== Hugo Mills: hugo@... carfax.org.uk | darksatanic.net | lug.org.uk ===
  PGP key: 65E74AC0 from wwwkeys.eu.pgp.net or http://www.carfax.org.uk
         --- 2 + 2 = 5,  for sufficiently large values of 2. ---         

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 811 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2014-06-13  6:56 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-04-02  8:54 [PATCH v3] lib: add size unit t/p/e to memparse Gui Hecheng
2014-05-15  1:39 ` [ping][PATCH " Gui Hecheng
2014-06-05  9:03 ` ·[ping][PATCH " Gui Hecheng
2014-06-12 21:15 ` [PATCH " Andrew Morton
2014-06-13  1:33   ` Gui Hecheng
2014-06-13  5:54   ` Brendan Hide
2014-06-13  6:56     ` Hugo Mills

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.