part.c 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  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 <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. *
  16. * SPDX-License-Identifier: GPL-2.0+
  17. */
  18. #include <common.h>
  19. #include <config.h>
  20. #include <command.h>
  21. #include <part.h>
  22. #include <vsprintf.h>
  23. static int do_part_uuid(int argc, char * const argv[])
  24. {
  25. int part;
  26. struct blk_desc *dev_desc;
  27. disk_partition_t info;
  28. if (argc < 2)
  29. return CMD_RET_USAGE;
  30. if (argc > 3)
  31. return CMD_RET_USAGE;
  32. part = blk_get_device_part_str(argv[0], argv[1], &dev_desc, &info, 0);
  33. if (part < 0)
  34. return 1;
  35. if (argc > 2)
  36. env_set(argv[2], info.uuid);
  37. else
  38. printf("%s\n", info.uuid);
  39. return 0;
  40. }
  41. static int do_part_list(int argc, char * const argv[])
  42. {
  43. int ret;
  44. struct blk_desc *desc;
  45. char *var = NULL;
  46. bool bootable = false;
  47. int i;
  48. if (argc < 2)
  49. return CMD_RET_USAGE;
  50. if (argc > 2) {
  51. for (i = 2; i < argc ; i++) {
  52. if (argv[i][0] == '-') {
  53. if (!strcmp(argv[i], "-bootable")) {
  54. bootable = true;
  55. } else {
  56. printf("Unknown option %s\n", argv[i]);
  57. return CMD_RET_USAGE;
  58. }
  59. } else {
  60. var = argv[i];
  61. break;
  62. }
  63. }
  64. /* Loops should have been exited at the last argument, which
  65. * as it contained the variable */
  66. if (argc != i + 1)
  67. return CMD_RET_USAGE;
  68. }
  69. ret = blk_get_device_by_str(argv[0], argv[1], &desc);
  70. if (ret < 0)
  71. return 1;
  72. if (var != NULL) {
  73. int p;
  74. char str[512] = { '\0', };
  75. disk_partition_t info;
  76. for (p = 1; p < 128; p++) {
  77. char t[5];
  78. int r = part_get_info(desc, p, &info);
  79. if (r != 0)
  80. continue;
  81. if (bootable && !info.bootable)
  82. continue;
  83. sprintf(t, "%s%x", str[0] ? " " : "", p);
  84. strcat(str, t);
  85. }
  86. env_set(var, str);
  87. return 0;
  88. }
  89. part_print(desc);
  90. return 0;
  91. }
  92. static int do_part_start(int argc, char * const argv[])
  93. {
  94. struct blk_desc *desc;
  95. disk_partition_t info;
  96. char buf[512] = { 0 };
  97. int part;
  98. int err;
  99. int ret;
  100. if (argc < 3)
  101. return CMD_RET_USAGE;
  102. if (argc > 4)
  103. return CMD_RET_USAGE;
  104. part = simple_strtoul(argv[2], NULL, 0);
  105. ret = blk_get_device_by_str(argv[0], argv[1], &desc);
  106. if (ret < 0)
  107. return 1;
  108. err = part_get_info(desc, part, &info);
  109. if (err)
  110. return 1;
  111. snprintf(buf, sizeof(buf), LBAF, info.start);
  112. if (argc > 3)
  113. env_set(argv[3], buf);
  114. else
  115. printf("%s\n", buf);
  116. return 0;
  117. }
  118. static int do_part_size(int argc, char * const argv[])
  119. {
  120. struct blk_desc *desc;
  121. disk_partition_t info;
  122. char buf[512] = { 0 };
  123. int part;
  124. int err;
  125. int ret;
  126. if (argc < 3)
  127. return CMD_RET_USAGE;
  128. if (argc > 4)
  129. return CMD_RET_USAGE;
  130. part = simple_strtoul(argv[2], NULL, 0);
  131. ret = blk_get_device_by_str(argv[0], argv[1], &desc);
  132. if (ret < 0)
  133. return 1;
  134. err = part_get_info(desc, part, &info);
  135. if (err)
  136. return 1;
  137. snprintf(buf, sizeof(buf), LBAF, info.size);
  138. if (argc > 3)
  139. env_set(argv[3], buf);
  140. else
  141. printf("%s\n", buf);
  142. return 0;
  143. }
  144. static int do_part(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
  145. {
  146. if (argc < 2)
  147. return CMD_RET_USAGE;
  148. if (!strcmp(argv[1], "uuid"))
  149. return do_part_uuid(argc - 2, argv + 2);
  150. else if (!strcmp(argv[1], "list"))
  151. return do_part_list(argc - 2, argv + 2);
  152. else if (!strcmp(argv[1], "start"))
  153. return do_part_start(argc - 2, argv + 2);
  154. else if (!strcmp(argv[1], "size"))
  155. return do_part_size(argc - 2, argv + 2);
  156. return CMD_RET_USAGE;
  157. }
  158. U_BOOT_CMD(
  159. part, CONFIG_SYS_MAXARGS, 1, do_part,
  160. "disk partition related commands",
  161. "uuid <interface> <dev>:<part>\n"
  162. " - print partition UUID\n"
  163. "part uuid <interface> <dev>:<part> <varname>\n"
  164. " - set environment variable to partition UUID\n"
  165. "part list <interface> <dev>\n"
  166. " - print a device's partition table\n"
  167. "part list <interface> <dev> [flags] <varname>\n"
  168. " - set environment variable to the list of partitions\n"
  169. " flags can be -bootable (list only bootable partitions)\n"
  170. "part start <interface> <dev> <part> <varname>\n"
  171. " - set environment variable to the start of the partition (in blocks)\n"
  172. "part size <interface> <dev> <part> <varname>\n"
  173. " - set environment variable to the size of the partition (in blocks)"
  174. );