]> Git Repo - u-boot.git/blame - cmd/part.c
cmd: part: Allow passing partition name to start and size
[u-boot.git] / cmd / part.c
CommitLineData
5cf41dcc
SW
1/*
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 <[email protected]>
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 <[email protected]>
15 *
1a459660 16 * SPDX-License-Identifier: GPL-2.0+
5cf41dcc
SW
17 */
18
19#include <common.h>
20#include <config.h>
21#include <command.h>
22#include <part.h>
23#include <vsprintf.h>
24
0e350f81 25static int do_part_uuid(int argc, char * const argv[])
5cf41dcc
SW
26{
27 int part;
4101f687 28 struct blk_desc *dev_desc;
5cf41dcc
SW
29 disk_partition_t info;
30
31 if (argc < 2)
32 return CMD_RET_USAGE;
33 if (argc > 3)
34 return CMD_RET_USAGE;
35
e35929e4 36 part = blk_get_device_part_str(argv[0], argv[1], &dev_desc, &info, 0);
5cf41dcc
SW
37 if (part < 0)
38 return 1;
39
40 if (argc > 2)
382bee57 41 env_set(argv[2], info.uuid);
5cf41dcc
SW
42 else
43 printf("%s\n", info.uuid);
44
45 return 0;
46}
47
0e350f81 48static int do_part_list(int argc, char * const argv[])
5cf41dcc
SW
49{
50 int ret;
4101f687 51 struct blk_desc *desc;
0798d6fd
SS
52 char *var = NULL;
53 bool bootable = false;
54 int i;
5cf41dcc 55
0798d6fd 56 if (argc < 2)
5cf41dcc
SW
57 return CMD_RET_USAGE;
58
0798d6fd
SS
59 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
ebac37cf 80 ret = blk_get_device_by_str(argv[0], argv[1], &desc);
5cf41dcc
SW
81 if (ret < 0)
82 return 1;
83
0798d6fd 84 if (var != NULL) {
e86df6ef 85 int p;
0798d6fd 86 char str[512] = { '\0', };
a78f78eb 87 disk_partition_t info;
e86df6ef
SS
88
89 for (p = 1; p < 128; p++) {
0798d6fd 90 char t[5];
3e8bd469 91 int r = part_get_info(desc, p, &info);
e86df6ef 92
0798d6fd
SS
93 if (r != 0)
94 continue;
95
96 if (bootable && !info.bootable)
97 continue;
98
653447b4 99 sprintf(t, "%s%x", str[0] ? " " : "", p);
0798d6fd 100 strcat(str, t);
e86df6ef 101 }
382bee57 102 env_set(var, str);
e86df6ef
SS
103 return 0;
104 }
105
3e8bd469 106 part_print(desc);
5cf41dcc
SW
107
108 return 0;
109}
110
8607c4f1
PK
111static int do_part_start(int argc, char * const argv[])
112{
4101f687 113 struct blk_desc *desc;
8607c4f1
PK
114 disk_partition_t info;
115 char buf[512] = { 0 };
36df616a 116 char *endp;
8607c4f1
PK
117 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
ebac37cf 126 ret = blk_get_device_by_str(argv[0], argv[1], &desc);
8607c4f1
PK
127 if (ret < 0)
128 return 1;
129
36df616a
SP
130 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 }
8607c4f1
PK
140
141 snprintf(buf, sizeof(buf), LBAF, info.start);
142
143 if (argc > 3)
382bee57 144 env_set(argv[3], buf);
8607c4f1
PK
145 else
146 printf("%s\n", buf);
147
148 return 0;
149}
150
151static int do_part_size(int argc, char * const argv[])
152{
4101f687 153 struct blk_desc *desc;
8607c4f1
PK
154 disk_partition_t info;
155 char buf[512] = { 0 };
36df616a 156 char *endp;
8607c4f1
PK
157 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
ebac37cf 166 ret = blk_get_device_by_str(argv[0], argv[1], &desc);
8607c4f1
PK
167 if (ret < 0)
168 return 1;
169
36df616a
SP
170 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 }
8607c4f1
PK
180
181 snprintf(buf, sizeof(buf), LBAF, info.size);
182
183 if (argc > 3)
382bee57 184 env_set(argv[3], buf);
8607c4f1
PK
185 else
186 printf("%s\n", buf);
187
188 return 0;
189}
190
0e350f81 191static int do_part(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
5cf41dcc
SW
192{
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);
8607c4f1
PK
200 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);
5cf41dcc
SW
204
205 return CMD_RET_USAGE;
206}
207
208U_BOOT_CMD(
0798d6fd 209 part, CONFIG_SYS_MAXARGS, 1, do_part,
5cf41dcc 210 "disk partition related commands",
8ca584ec 211 "uuid <interface> <dev>:<part>\n"
5cf41dcc
SW
212 " - 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"
e86df6ef 216 " - print a device's partition table\n"
0798d6fd
SS
217 "part list <interface> <dev> [flags] <varname>\n"
218 " - set environment variable to the list of partitions\n"
8607c4f1
PK
219 " 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"
36df616a 222 " part can be either partition number or partition name\n"
8607c4f1 223 "part size <interface> <dev> <part> <varname>\n"
36df616a
SP
224 " - set environment variable to the size of the partition (in blocks)\n"
225 " part can be either partition number or partition name"
5cf41dcc 226);
This page took 0.243339 seconds and 4 git commands to generate.