diff mbox series

[4/9] part: Support getting whole disk from part_get_info_by_dev_and_name_or_num

Message ID 20201231224853.1431364-5-sean.anderson@seco.com
State Superseded
Delegated to: Tom Rini
Headers show
Series This series adds support for flashing eMMC boot partitions, and for | expand

Commit Message

Sean Anderson Dec. 31, 2020, 10:48 p.m. UTC
This adds an option to part_get_info_by_dev_and_name_or_num to allow
callers to specify whether whole-disk partitions are fine.

Signed-off-by: Sean Anderson <sean.anderson@seco.com>
---

 cmd/ab_select.c | 3 ++-
 disk/part.c     | 5 +++--
 include/part.h  | 6 +++++-
 3 files changed, 10 insertions(+), 4 deletions(-)

Comments

Simon Glass Jan. 7, 2021, 12:35 p.m. UTC | #1
On Thu, 31 Dec 2020 at 15:49, Sean Anderson <sean.anderson@seco.com> wrote:
>
> This adds an option to part_get_info_by_dev_and_name_or_num to allow
> callers to specify whether whole-disk partitions are fine.
>
> Signed-off-by: Sean Anderson <sean.anderson@seco.com>
> ---
>
>  cmd/ab_select.c | 3 ++-
>  disk/part.c     | 5 +++--
>  include/part.h  | 6 +++++-
>  3 files changed, 10 insertions(+), 4 deletions(-)
>

Reviewed-by: Simon Glass <sjg@chromium.org>

> diff --git a/cmd/ab_select.c b/cmd/ab_select.c
> index 6298fcfb60..3e46663d6e 100644
> --- a/cmd/ab_select.c
> +++ b/cmd/ab_select.c
> @@ -22,7 +22,8 @@ static int do_ab_select(struct cmd_tbl *cmdtp, int flag, int argc,
>
>         /* Lookup the "misc" partition from argv[2] and argv[3] */
>         if (part_get_info_by_dev_and_name_or_num(argv[2], argv[3],
> -                                                &dev_desc, &part_info) < 0) {
> +                                                &dev_desc, &part_info,
> +                                                false) < 0) {
>                 return CMD_RET_FAILURE;
>         }
>
> diff --git a/disk/part.c b/disk/part.c
> index 5e354e256f..39c6b00a59 100644
> --- a/disk/part.c
> +++ b/disk/part.c
> @@ -736,7 +736,8 @@ static int part_get_info_by_dev_and_name(const char *dev_iface,
>  int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
>                                          const char *dev_part_str,
>                                          struct blk_desc **dev_desc,
> -                                        struct disk_partition *part_info)
> +                                        struct disk_partition *part_info,
> +                                        int allow_whole_dev)

bool?

>  {
>         int ret;
>
> @@ -750,7 +751,7 @@ int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
>          * directly.
>          */
>         ret = blk_get_device_part_str(dev_iface, dev_part_str,
> -                                     dev_desc, part_info, 1);
> +                                     dev_desc, part_info, allow_whole_dev);
>         if (ret < 0)
>                 printf("Couldn't find partition %s %s\n",
>                        dev_iface, dev_part_str);
> diff --git a/include/part.h b/include/part.h
> index 55be724d20..778cb36199 100644
> --- a/include/part.h
> +++ b/include/part.h
> @@ -226,12 +226,16 @@ int part_get_info_by_name(struct blk_desc *dev_desc,
>   * @param[in] dev_part_str Input partition description, like "0#misc" or "0:1"
>   * @param[out] dev_desc        Place to store the device description pointer
>   * @param[out] part_info Place to store the partition information
> + * @param[in] allow_whole_dev true to allow the user to select partition 0
> + *             (which means the whole device), false to require a valid
> + *             partition number >= 1
>   * @return 0 on success, or a negative on error
>   */
>  int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
>                                          const char *dev_part_str,
>                                          struct blk_desc **dev_desc,
> -                                        struct disk_partition *part_info);
> +                                        struct disk_partition *part_info,
> +                                        int allow_whole_dev);
>
>  /**
>   * part_set_generic_name() - create generic partition like hda1 or sdb2
> --
> 2.25.1
>

Regards,
Simon
Sean Anderson Jan. 7, 2021, 2:12 p.m. UTC | #2
On 1/7/21 7:35 AM, Simon Glass wrote:
 > On Thu, 31 Dec 2020 at 15:49, Sean Anderson <sean.anderson@seco.com> 
wrote:
 >>
 >> This adds an option to part_get_info_by_dev_and_name_or_num to allow
 >> callers to specify whether whole-disk partitions are fine.
 >>
 >> Signed-off-by: Sean Anderson <sean.anderson@seco.com>
 >> ---
 >>
 >>   cmd/ab_select.c | 3 ++-
 >>   disk/part.c     | 5 +++--
 >>   include/part.h  | 6 +++++-
 >>   3 files changed, 10 insertions(+), 4 deletions(-)
 >>
 >
 > Reviewed-by: Simon Glass <sjg@chromium.org>
 >
 >> diff --git a/cmd/ab_select.c b/cmd/ab_select.c
 >> index 6298fcfb60..3e46663d6e 100644
 >> --- a/cmd/ab_select.c
 >> +++ b/cmd/ab_select.c
 >> @@ -22,7 +22,8 @@ static int do_ab_select(struct cmd_tbl *cmdtp, int 
flag, int argc,
 >>
 >>          /* Lookup the "misc" partition from argv[2] and argv[3] */
 >>          if (part_get_info_by_dev_and_name_or_num(argv[2], argv[3],
 >> -                                                &dev_desc, 
&part_info) < 0) {
 >> +                                                &dev_desc, &part_info,
 >> +                                                false) < 0) {
 >>                  return CMD_RET_FAILURE;
 >>          }
 >>
 >> diff --git a/disk/part.c b/disk/part.c
 >> index 5e354e256f..39c6b00a59 100644
 >> --- a/disk/part.c
 >> +++ b/disk/part.c
 >> @@ -736,7 +736,8 @@ static int part_get_info_by_dev_and_name(const 
char *dev_iface,
 >>   int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
 >>                                           const char *dev_part_str,
 >>                                           struct blk_desc **dev_desc,
 >> -                                        struct disk_partition 
*part_info)
 >> +                                        struct disk_partition 
*part_info,
 >> +                                        int allow_whole_dev)
 >
 > bool?

It's int to match the allow_whole_dev argument of
blk_get_device_part_str.

 >
 >>   {
 >>          int ret;
 >>
 >> @@ -750,7 +751,7 @@ int part_get_info_by_dev_and_name_or_num(const 
char *dev_iface,
 >>           * directly.
 >>           */
 >>          ret = blk_get_device_part_str(dev_iface, dev_part_str,
 >> -                                     dev_desc, part_info, 1);
 >> +                                     dev_desc, part_info, 
allow_whole_dev);
 >>          if (ret < 0)
 >>                  printf("Couldn't find partition %s %s\n",
 >>                         dev_iface, dev_part_str);
 >> diff --git a/include/part.h b/include/part.h
 >> index 55be724d20..778cb36199 100644
 >> --- a/include/part.h
 >> +++ b/include/part.h
 >> @@ -226,12 +226,16 @@ int part_get_info_by_name(struct blk_desc 
*dev_desc,
 >>    * @param[in] dev_part_str Input partition description, like 
"0#misc" or "0:1"
 >>    * @param[out] dev_desc        Place to store the device 
description pointer
 >>    * @param[out] part_info Place to store the partition information
 >> + * @param[in] allow_whole_dev true to allow the user to select 
partition 0
 >> + *             (which means the whole device), false to require a valid
 >> + *             partition number >= 1
 >>    * @return 0 on success, or a negative on error
 >>    */
 >>   int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
 >>                                           const char *dev_part_str,
 >>                                           struct blk_desc **dev_desc,
 >> -                                        struct disk_partition 
*part_info);
 >> +                                        struct disk_partition 
*part_info,
 >> +                                        int allow_whole_dev);
 >>
 >>   /**
 >>    * part_set_generic_name() - create generic partition like hda1 or 
sdb2
 >> --
 >> 2.25.1
 >>
 >
 > Regards,
 > Simon
 >
diff mbox series

Patch

diff --git a/cmd/ab_select.c b/cmd/ab_select.c
index 6298fcfb60..3e46663d6e 100644
--- a/cmd/ab_select.c
+++ b/cmd/ab_select.c
@@ -22,7 +22,8 @@  static int do_ab_select(struct cmd_tbl *cmdtp, int flag, int argc,
 
 	/* Lookup the "misc" partition from argv[2] and argv[3] */
 	if (part_get_info_by_dev_and_name_or_num(argv[2], argv[3],
-						 &dev_desc, &part_info) < 0) {
+						 &dev_desc, &part_info,
+						 false) < 0) {
 		return CMD_RET_FAILURE;
 	}
 
diff --git a/disk/part.c b/disk/part.c
index 5e354e256f..39c6b00a59 100644
--- a/disk/part.c
+++ b/disk/part.c
@@ -736,7 +736,8 @@  static int part_get_info_by_dev_and_name(const char *dev_iface,
 int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
 					 const char *dev_part_str,
 					 struct blk_desc **dev_desc,
-					 struct disk_partition *part_info)
+					 struct disk_partition *part_info,
+					 int allow_whole_dev)
 {
 	int ret;
 
@@ -750,7 +751,7 @@  int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
 	 * directly.
 	 */
 	ret = blk_get_device_part_str(dev_iface, dev_part_str,
-				      dev_desc, part_info, 1);
+				      dev_desc, part_info, allow_whole_dev);
 	if (ret < 0)
 		printf("Couldn't find partition %s %s\n",
 		       dev_iface, dev_part_str);
diff --git a/include/part.h b/include/part.h
index 55be724d20..778cb36199 100644
--- a/include/part.h
+++ b/include/part.h
@@ -226,12 +226,16 @@  int part_get_info_by_name(struct blk_desc *dev_desc,
  * @param[in] dev_part_str Input partition description, like "0#misc" or "0:1"
  * @param[out] dev_desc	Place to store the device description pointer
  * @param[out] part_info Place to store the partition information
+ * @param[in] allow_whole_dev true to allow the user to select partition 0
+ *		(which means the whole device), false to require a valid
+ *		partition number >= 1
  * @return 0 on success, or a negative on error
  */
 int part_get_info_by_dev_and_name_or_num(const char *dev_iface,
 					 const char *dev_part_str,
 					 struct blk_desc **dev_desc,
-					 struct disk_partition *part_info);
+					 struct disk_partition *part_info,
+					 int allow_whole_dev);
 
 /**
  * part_set_generic_name() - create generic partition like hda1 or sdb2