[PATCH 13/15] RFC: lib: Support a binary prefix 0y

Sean Anderson seanga2 at gmail.com
Wed Jul 21 10:05:30 CEST 2021


On 7/20/21 9:29 AM, Simon Glass wrote:
> In some cases it is useful to be able to supply a binary value to a
> command. Use the '0y' prefix for this (binarY).

To bikeshed: 0b please

https://gcc.gnu.org/onlinedocs/gcc/Binary-constants.html

--Sean

> 
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
> 
>   doc/usage/cmdline.rst | 6 ++++++
>   lib/strto.c           | 3 +++
>   test/str_ut.c         | 8 ++++++++
>   3 files changed, 17 insertions(+)
> 
> diff --git a/doc/usage/cmdline.rst b/doc/usage/cmdline.rst
> index 7f2cfad2a0f..05ce65958c4 100644
> --- a/doc/usage/cmdline.rst
> +++ b/doc/usage/cmdline.rst
> @@ -96,3 +96,9 @@ convenient::
>   
>     => i2c speed 0x30000
>     Setting bus speed to 196608 Hz
> +
> +U-Boot also supports a `0y` for binary base 2 ("binarY")::
> +
> +  => mw 100 0y11010011
> +  => md 100 1
> +  00000100: 000000d3                             ....
> diff --git a/lib/strto.c b/lib/strto.c
> index 120214d83f8..a7531e877f5 100644
> --- a/lib/strto.c
> +++ b/lib/strto.c
> @@ -26,6 +26,9 @@ static const char *_parse_integer_fixup_radix(const char *s, uint *basep)
>   		} else if (ch == 'm') {
>   			*basep = 10;
>   			s += 2;
> +		} else if (ch == 'y') {
> +			*basep = 2;
> +			s += 2;
>   		} else if (!*basep) {
>   			/* Only select octal if we don't have a base */
>   			*basep = 8;
> diff --git a/test/str_ut.c b/test/str_ut.c
> index 716f7c45c38..731ef0c49ae 100644
> --- a/test/str_ut.c
> +++ b/test/str_ut.c
> @@ -117,6 +117,10 @@ static int str_simple_strtoul(struct unit_test_state *uts)
>   	ut_assertok(run_strtoul(uts, "0x123fg", 0, 0x123f, 6, false));
>   	ut_assertok(run_strtoul(uts, "0m123a", 16, 123, 5, false));
>   
> +	/* check binary */
> +	ut_assertok(run_strtoul(uts, "1011b", 2, 0xb, 4, false));
> +	ut_assertok(run_strtoul(uts, "0y111more", 0, 7, 5, false));
> +
>   	return 0;
>   }
>   STR_TEST(str_simple_strtoul, 0);
> @@ -186,6 +190,10 @@ static int str_simple_strtoull(struct unit_test_state *uts)
>   	ut_assertok(run_strtoull(uts, "0x123fg", 0, 0x123f, 6, false));
>   	ut_assertok(run_strtoull(uts, "0m123a", 16, 123, 5, false));
>   
> +	/* check binary */
> +	ut_assertok(run_strtoull(uts, "1011b", 2, 0xb, 4, false));
> +	ut_assertok(run_strtoull(uts, "0y111more", 0, 7, 5, false));
> +
>   	return 0;
>   }
>   STR_TEST(str_simple_strtoull, 0);
> 



More information about the U-Boot mailing list