]>
Commit | Line | Data |
---|---|---|
83d290c5 | 1 | // SPDX-License-Identifier: GPL-2.0+ |
5cf41dcc SW |
2 | /* |
3 | * Copyright (c) 2012, NVIDIA CORPORATION. All rights reserved. | |
4 | * | |
5 | * made from cmd_ext2, which was: | |
6 | * | |
7 | * (C) Copyright 2004 | |
8 | * esd gmbh <www.esd-electronics.com> | |
9 | * Reinhard Arlt <[email protected]> | |
10 | * | |
11 | * made from cmd_reiserfs by | |
12 | * | |
13 | * (C) Copyright 2003 - 2004 | |
14 | * Sysgo Real-Time Solutions, AG <www.elinos.com> | |
15 | * Pavel Bartusek <[email protected]> | |
5cf41dcc SW |
16 | */ |
17 | ||
18 | #include <common.h> | |
19 | #include <config.h> | |
20 | #include <command.h> | |
9fb625ce | 21 | #include <env.h> |
5cf41dcc SW |
22 | #include <part.h> |
23 | #include <vsprintf.h> | |
24 | ||
64e6a49a SP |
25 | enum cmd_part_info { |
26 | CMD_PART_INFO_START = 0, | |
27 | CMD_PART_INFO_SIZE, | |
be683756 | 28 | CMD_PART_INFO_NUMBER |
64e6a49a SP |
29 | }; |
30 | ||
0e350f81 | 31 | static int do_part_uuid(int argc, char * const argv[]) |
5cf41dcc SW |
32 | { |
33 | int part; | |
4101f687 | 34 | struct blk_desc *dev_desc; |
5cf41dcc SW |
35 | disk_partition_t info; |
36 | ||
37 | if (argc < 2) | |
38 | return CMD_RET_USAGE; | |
39 | if (argc > 3) | |
40 | return CMD_RET_USAGE; | |
41 | ||
e35929e4 | 42 | part = blk_get_device_part_str(argv[0], argv[1], &dev_desc, &info, 0); |
5cf41dcc SW |
43 | if (part < 0) |
44 | return 1; | |
45 | ||
46 | if (argc > 2) | |
382bee57 | 47 | env_set(argv[2], info.uuid); |
5cf41dcc SW |
48 | else |
49 | printf("%s\n", info.uuid); | |
50 | ||
51 | return 0; | |
52 | } | |
53 | ||
0e350f81 | 54 | static int do_part_list(int argc, char * const argv[]) |
5cf41dcc SW |
55 | { |
56 | int ret; | |
4101f687 | 57 | struct blk_desc *desc; |
0798d6fd SS |
58 | char *var = NULL; |
59 | bool bootable = false; | |
60 | int i; | |
5cf41dcc | 61 | |
0798d6fd | 62 | if (argc < 2) |
5cf41dcc SW |
63 | return CMD_RET_USAGE; |
64 | ||
0798d6fd SS |
65 | if (argc > 2) { |
66 | for (i = 2; i < argc ; i++) { | |
67 | if (argv[i][0] == '-') { | |
68 | if (!strcmp(argv[i], "-bootable")) { | |
69 | bootable = true; | |
70 | } else { | |
71 | printf("Unknown option %s\n", argv[i]); | |
72 | return CMD_RET_USAGE; | |
73 | } | |
74 | } else { | |
75 | var = argv[i]; | |
76 | break; | |
77 | } | |
78 | } | |
79 | ||
80 | /* Loops should have been exited at the last argument, which | |
81 | * as it contained the variable */ | |
82 | if (argc != i + 1) | |
83 | return CMD_RET_USAGE; | |
84 | } | |
85 | ||
ebac37cf | 86 | ret = blk_get_device_by_str(argv[0], argv[1], &desc); |
5cf41dcc SW |
87 | if (ret < 0) |
88 | return 1; | |
89 | ||
0798d6fd | 90 | if (var != NULL) { |
e86df6ef | 91 | int p; |
0798d6fd | 92 | char str[512] = { '\0', }; |
a78f78eb | 93 | disk_partition_t info; |
e86df6ef | 94 | |
7e295116 | 95 | for (p = 1; p < MAX_SEARCH_PARTITIONS; p++) { |
0798d6fd | 96 | char t[5]; |
3e8bd469 | 97 | int r = part_get_info(desc, p, &info); |
e86df6ef | 98 | |
0798d6fd SS |
99 | if (r != 0) |
100 | continue; | |
101 | ||
102 | if (bootable && !info.bootable) | |
103 | continue; | |
104 | ||
653447b4 | 105 | sprintf(t, "%s%x", str[0] ? " " : "", p); |
0798d6fd | 106 | strcat(str, t); |
e86df6ef | 107 | } |
382bee57 | 108 | env_set(var, str); |
e86df6ef SS |
109 | return 0; |
110 | } | |
111 | ||
3e8bd469 | 112 | part_print(desc); |
5cf41dcc SW |
113 | |
114 | return 0; | |
115 | } | |
116 | ||
64e6a49a | 117 | static int do_part_info(int argc, char * const argv[], enum cmd_part_info param) |
8607c4f1 | 118 | { |
4101f687 | 119 | struct blk_desc *desc; |
8607c4f1 PK |
120 | disk_partition_t info; |
121 | char buf[512] = { 0 }; | |
36df616a | 122 | char *endp; |
8607c4f1 PK |
123 | int part; |
124 | int err; | |
125 | int ret; | |
126 | ||
127 | if (argc < 3) | |
128 | return CMD_RET_USAGE; | |
129 | if (argc > 4) | |
130 | return CMD_RET_USAGE; | |
131 | ||
ebac37cf | 132 | ret = blk_get_device_by_str(argv[0], argv[1], &desc); |
8607c4f1 PK |
133 | if (ret < 0) |
134 | return 1; | |
135 | ||
36df616a SP |
136 | part = simple_strtoul(argv[2], &endp, 0); |
137 | if (*endp == '\0') { | |
138 | err = part_get_info(desc, part, &info); | |
139 | if (err) | |
140 | return 1; | |
141 | } else { | |
142 | part = part_get_info_by_name(desc, argv[2], &info); | |
143 | if (part == -1) | |
144 | return 1; | |
145 | } | |
8607c4f1 | 146 | |
64e6a49a SP |
147 | switch (param) { |
148 | case CMD_PART_INFO_START: | |
149 | snprintf(buf, sizeof(buf), LBAF, info.start); | |
150 | break; | |
151 | case CMD_PART_INFO_SIZE: | |
152 | snprintf(buf, sizeof(buf), LBAF, info.size); | |
153 | break; | |
be683756 | 154 | case CMD_PART_INFO_NUMBER: |
400b9554 | 155 | snprintf(buf, sizeof(buf), "0x%x", part); |
be683756 | 156 | break; |
64e6a49a SP |
157 | default: |
158 | printf("** Unknown cmd_part_info value: %d\n", param); | |
159 | return 1; | |
160 | } | |
8607c4f1 PK |
161 | |
162 | if (argc > 3) | |
382bee57 | 163 | env_set(argv[3], buf); |
8607c4f1 PK |
164 | else |
165 | printf("%s\n", buf); | |
166 | ||
167 | return 0; | |
168 | } | |
169 | ||
64e6a49a | 170 | static int do_part_start(int argc, char * const argv[]) |
8607c4f1 | 171 | { |
64e6a49a SP |
172 | return do_part_info(argc, argv, CMD_PART_INFO_START); |
173 | } | |
8607c4f1 | 174 | |
64e6a49a SP |
175 | static int do_part_size(int argc, char * const argv[]) |
176 | { | |
177 | return do_part_info(argc, argv, CMD_PART_INFO_SIZE); | |
8607c4f1 PK |
178 | } |
179 | ||
be683756 RT |
180 | static int do_part_number(int argc, char * const argv[]) |
181 | { | |
182 | return do_part_info(argc, argv, CMD_PART_INFO_NUMBER); | |
183 | } | |
184 | ||
0e350f81 | 185 | static int do_part(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) |
5cf41dcc SW |
186 | { |
187 | if (argc < 2) | |
188 | return CMD_RET_USAGE; | |
189 | ||
190 | if (!strcmp(argv[1], "uuid")) | |
191 | return do_part_uuid(argc - 2, argv + 2); | |
192 | else if (!strcmp(argv[1], "list")) | |
193 | return do_part_list(argc - 2, argv + 2); | |
8607c4f1 PK |
194 | else if (!strcmp(argv[1], "start")) |
195 | return do_part_start(argc - 2, argv + 2); | |
196 | else if (!strcmp(argv[1], "size")) | |
197 | return do_part_size(argc - 2, argv + 2); | |
be683756 RT |
198 | else if (!strcmp(argv[1], "number")) |
199 | return do_part_number(argc - 2, argv + 2); | |
5cf41dcc SW |
200 | |
201 | return CMD_RET_USAGE; | |
202 | } | |
203 | ||
204 | U_BOOT_CMD( | |
0798d6fd | 205 | part, CONFIG_SYS_MAXARGS, 1, do_part, |
5cf41dcc | 206 | "disk partition related commands", |
8ca584ec | 207 | "uuid <interface> <dev>:<part>\n" |
5cf41dcc SW |
208 | " - print partition UUID\n" |
209 | "part uuid <interface> <dev>:<part> <varname>\n" | |
210 | " - set environment variable to partition UUID\n" | |
211 | "part list <interface> <dev>\n" | |
e86df6ef | 212 | " - print a device's partition table\n" |
0798d6fd SS |
213 | "part list <interface> <dev> [flags] <varname>\n" |
214 | " - set environment variable to the list of partitions\n" | |
8607c4f1 PK |
215 | " flags can be -bootable (list only bootable partitions)\n" |
216 | "part start <interface> <dev> <part> <varname>\n" | |
217 | " - set environment variable to the start of the partition (in blocks)\n" | |
36df616a | 218 | " part can be either partition number or partition name\n" |
8607c4f1 | 219 | "part size <interface> <dev> <part> <varname>\n" |
36df616a | 220 | " - set environment variable to the size of the partition (in blocks)\n" |
be683756 RT |
221 | " part can be either partition number or partition name\n" |
222 | "part number <interface> <dev> <part> <varname>\n" | |
223 | " - set environment variable to the partition number using the partition name\n" | |
224 | " part must be specified as partition name" | |
5cf41dcc | 225 | ); |