[U-Boot] [PATCH v3 1/3] net: Add a command to manipulate ethernet devices
Alban Bedel
alban.bedel at avionic-design.de
Tue Oct 14 18:26:09 CEST 2014
Add the 'eth' command for operations on ethernet devices.
This first version only contains a command to show a device
properties, currently only name, index and MAC address.
Signed-off-by: Alban Bedel <alban.bedel at avionic-design.de>
---
v1: * Patch didn't exists
v2: * Patch didn't exists
v3: * Replace the dedicated 'eth_eeprom' command with a subcommand
to the 'eth' command
---
common/cmd_net.c | 48 ++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 48 insertions(+)
diff --git a/common/cmd_net.c b/common/cmd_net.c
index 09489d4..9cc0bdf 100644
--- a/common/cmd_net.c
+++ b/common/cmd_net.c
@@ -445,3 +445,51 @@ U_BOOT_CMD(
);
#endif /* CONFIG_CMD_LINK_LOCAL */
+
+static int do_eth_show(struct eth_device *dev,
+ int argc, char * const argv[])
+{
+ printf("Name : %s\n", dev->name);
+ printf("Index: %d\n", dev->index);
+ printf("MAC : %pM\n", dev->enetaddr);
+ return 0;
+}
+
+static int do_eth(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
+{
+ struct eth_device *dev;
+ char *endp = NULL;
+ int index;
+
+ if (argc < 3)
+ return CMD_RET_USAGE;
+
+ /* Get the ethernet device, by ID or by name */
+ index = (int) simple_strtoul(argv[1], &endp, 16);
+ if (endp > argv[1])
+ dev = eth_get_dev_by_index(index);
+ else
+ dev = eth_get_dev_by_name(argv[2]);
+
+ if (!dev) {
+ printf("Ethernet device not found\n");
+ return CMD_RET_FAILURE;
+ }
+
+ if (!strcmp(argv[2], "show"))
+ return do_eth_show(dev, argc - 2, argv + 2);
+
+ printf("Unknown eth sub command: %s\n", argv[2]);
+
+ return CMD_RET_USAGE;
+}
+
+U_BOOT_CMD(
+ eth, 7, 0, do_eth,
+ "extended ops for ethernet devices",
+ "<dev> <command> [<args>...]\n"
+ " - run command on a device, device may be a name or id.\n"
+ "\n"
+ "eth <dev> show\n"
+ " - show basic information about the ethernet device\n"
+);
--
2.1.1
More information about the U-Boot
mailing list