blob: fd8825a7ec64f91a4f8719cd329424c650442f0d [file] [log] [blame]
Stephen Warren3a529102012-09-21 09:51:01 +00001/*
2 * Copyright (c) 2012, NVIDIA CORPORATION. All rights reserved.
3 *
4 * made from cmd_ext2, which was:
5 *
6 * (C) Copyright 2004
7 * esd gmbh <www.esd-electronics.com>
8 * Reinhard Arlt <reinhard.arlt@esd-electronics.com>
9 *
10 * made from cmd_reiserfs by
11 *
12 * (C) Copyright 2003 - 2004
13 * Sysgo Real-Time Solutions, AG <www.elinos.com>
14 * Pavel Bartusek <pba@sysgo.com>
15 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +020016 * SPDX-License-Identifier: GPL-2.0+
Stephen Warren3a529102012-09-21 09:51:01 +000017 */
18
19#include <common.h>
20#include <config.h>
21#include <command.h>
22#include <part.h>
23#include <vsprintf.h>
24
Jeroen Hofsteef384fbf2014-06-23 00:22:08 +020025static int do_part_uuid(int argc, char * const argv[])
Stephen Warren3a529102012-09-21 09:51:01 +000026{
27 int part;
Simon Glasse3394752016-02-29 15:25:34 -070028 struct blk_desc *dev_desc;
Stephen Warren3a529102012-09-21 09:51:01 +000029 disk_partition_t info;
30
31 if (argc < 2)
32 return CMD_RET_USAGE;
33 if (argc > 3)
34 return CMD_RET_USAGE;
35
Simon Glasse76ee972016-02-29 15:25:44 -070036 part = blk_get_device_part_str(argv[0], argv[1], &dev_desc, &info, 0);
Stephen Warren3a529102012-09-21 09:51:01 +000037 if (part < 0)
38 return 1;
39
40 if (argc > 2)
Simon Glass6a38e412017-08-03 12:22:09 -060041 env_set(argv[2], info.uuid);
Stephen Warren3a529102012-09-21 09:51:01 +000042 else
43 printf("%s\n", info.uuid);
44
45 return 0;
46}
47
Jeroen Hofsteef384fbf2014-06-23 00:22:08 +020048static int do_part_list(int argc, char * const argv[])
Stephen Warren3a529102012-09-21 09:51:01 +000049{
50 int ret;
Simon Glasse3394752016-02-29 15:25:34 -070051 struct blk_desc *desc;
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +010052 char *var = NULL;
53 bool bootable = false;
54 int i;
Stephen Warren3a529102012-09-21 09:51:01 +000055
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +010056 if (argc < 2)
Stephen Warren3a529102012-09-21 09:51:01 +000057 return CMD_RET_USAGE;
58
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +010059 if (argc > 2) {
60 for (i = 2; i < argc ; i++) {
61 if (argv[i][0] == '-') {
62 if (!strcmp(argv[i], "-bootable")) {
63 bootable = true;
64 } else {
65 printf("Unknown option %s\n", argv[i]);
66 return CMD_RET_USAGE;
67 }
68 } else {
69 var = argv[i];
70 break;
71 }
72 }
73
74 /* Loops should have been exited at the last argument, which
75 * as it contained the variable */
76 if (argc != i + 1)
77 return CMD_RET_USAGE;
78 }
79
Simon Glasse6649a62016-02-29 15:25:43 -070080 ret = blk_get_device_by_str(argv[0], argv[1], &desc);
Stephen Warren3a529102012-09-21 09:51:01 +000081 if (ret < 0)
82 return 1;
83
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +010084 if (var != NULL) {
Sjoerd Simonsca8982b2015-01-05 18:13:37 +010085 int p;
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +010086 char str[512] = { '\0', };
Paul Kocialkowskib613cb32015-06-15 21:35:04 +020087 disk_partition_t info;
Sjoerd Simonsca8982b2015-01-05 18:13:37 +010088
89 for (p = 1; p < 128; p++) {
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +010090 char t[5];
Simon Glassb89a8442016-02-29 15:25:48 -070091 int r = part_get_info(desc, p, &info);
Sjoerd Simonsca8982b2015-01-05 18:13:37 +010092
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +010093 if (r != 0)
94 continue;
95
96 if (bootable && !info.bootable)
97 continue;
98
Stephen Warren78bb0c12015-12-09 09:48:04 -070099 sprintf(t, "%s%x", str[0] ? " " : "", p);
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +0100100 strcat(str, t);
Sjoerd Simonsca8982b2015-01-05 18:13:37 +0100101 }
Simon Glass6a38e412017-08-03 12:22:09 -0600102 env_set(var, str);
Sjoerd Simonsca8982b2015-01-05 18:13:37 +0100103 return 0;
104 }
105
Simon Glassb89a8442016-02-29 15:25:48 -0700106 part_print(desc);
Stephen Warren3a529102012-09-21 09:51:01 +0000107
108 return 0;
109}
110
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200111static int do_part_start(int argc, char * const argv[])
112{
Simon Glasse3394752016-02-29 15:25:34 -0700113 struct blk_desc *desc;
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200114 disk_partition_t info;
115 char buf[512] = { 0 };
Sam Protsenko515a8632018-02-26 23:17:59 +0200116 char *endp;
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200117 int part;
118 int err;
119 int ret;
120
121 if (argc < 3)
122 return CMD_RET_USAGE;
123 if (argc > 4)
124 return CMD_RET_USAGE;
125
Simon Glasse6649a62016-02-29 15:25:43 -0700126 ret = blk_get_device_by_str(argv[0], argv[1], &desc);
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200127 if (ret < 0)
128 return 1;
129
Sam Protsenko515a8632018-02-26 23:17:59 +0200130 part = simple_strtoul(argv[2], &endp, 0);
131 if (*endp == '\0') {
132 err = part_get_info(desc, part, &info);
133 if (err)
134 return 1;
135 } else {
136 part = part_get_info_by_name(desc, argv[2], &info);
137 if (part == -1)
138 return 1;
139 }
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200140
141 snprintf(buf, sizeof(buf), LBAF, info.start);
142
143 if (argc > 3)
Simon Glass6a38e412017-08-03 12:22:09 -0600144 env_set(argv[3], buf);
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200145 else
146 printf("%s\n", buf);
147
148 return 0;
149}
150
151static int do_part_size(int argc, char * const argv[])
152{
Simon Glasse3394752016-02-29 15:25:34 -0700153 struct blk_desc *desc;
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200154 disk_partition_t info;
155 char buf[512] = { 0 };
Sam Protsenko515a8632018-02-26 23:17:59 +0200156 char *endp;
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200157 int part;
158 int err;
159 int ret;
160
161 if (argc < 3)
162 return CMD_RET_USAGE;
163 if (argc > 4)
164 return CMD_RET_USAGE;
165
Simon Glasse6649a62016-02-29 15:25:43 -0700166 ret = blk_get_device_by_str(argv[0], argv[1], &desc);
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200167 if (ret < 0)
168 return 1;
169
Sam Protsenko515a8632018-02-26 23:17:59 +0200170 part = simple_strtoul(argv[2], &endp, 0);
171 if (*endp == '\0') {
172 err = part_get_info(desc, part, &info);
173 if (err)
174 return 1;
175 } else {
176 part = part_get_info_by_name(desc, argv[2], &info);
177 if (part == -1)
178 return 1;
179 }
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200180
181 snprintf(buf, sizeof(buf), LBAF, info.size);
182
183 if (argc > 3)
Simon Glass6a38e412017-08-03 12:22:09 -0600184 env_set(argv[3], buf);
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200185 else
186 printf("%s\n", buf);
187
188 return 0;
189}
190
Jeroen Hofsteef384fbf2014-06-23 00:22:08 +0200191static int do_part(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Stephen Warren3a529102012-09-21 09:51:01 +0000192{
193 if (argc < 2)
194 return CMD_RET_USAGE;
195
196 if (!strcmp(argv[1], "uuid"))
197 return do_part_uuid(argc - 2, argv + 2);
198 else if (!strcmp(argv[1], "list"))
199 return do_part_list(argc - 2, argv + 2);
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200200 else if (!strcmp(argv[1], "start"))
201 return do_part_start(argc - 2, argv + 2);
202 else if (!strcmp(argv[1], "size"))
203 return do_part_size(argc - 2, argv + 2);
Stephen Warren3a529102012-09-21 09:51:01 +0000204
205 return CMD_RET_USAGE;
206}
207
208U_BOOT_CMD(
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +0100209 part, CONFIG_SYS_MAXARGS, 1, do_part,
Stephen Warren3a529102012-09-21 09:51:01 +0000210 "disk partition related commands",
maxin.john@enea.com9bc711d2015-04-28 01:44:58 +0200211 "uuid <interface> <dev>:<part>\n"
Stephen Warren3a529102012-09-21 09:51:01 +0000212 " - print partition UUID\n"
213 "part uuid <interface> <dev>:<part> <varname>\n"
214 " - set environment variable to partition UUID\n"
215 "part list <interface> <dev>\n"
Sjoerd Simonsca8982b2015-01-05 18:13:37 +0100216 " - print a device's partition table\n"
Sjoerd Simons43cdb5d2015-02-25 23:23:50 +0100217 "part list <interface> <dev> [flags] <varname>\n"
218 " - set environment variable to the list of partitions\n"
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200219 " flags can be -bootable (list only bootable partitions)\n"
220 "part start <interface> <dev> <part> <varname>\n"
221 " - set environment variable to the start of the partition (in blocks)\n"
Sam Protsenko515a8632018-02-26 23:17:59 +0200222 " part can be either partition number or partition name\n"
Paul Kocialkowskicf7b3762015-06-15 21:35:05 +0200223 "part size <interface> <dev> <part> <varname>\n"
Sam Protsenko515a8632018-02-26 23:17:59 +0200224 " - set environment variable to the size of the partition (in blocks)\n"
225 " part can be either partition number or partition name"
Stephen Warren3a529102012-09-21 09:51:01 +0000226);