From: Eddie Cai <eddie.cai.linux@gmail.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [U-Boot 2/3] cmd: add rockusb command
Date: Wed, 15 Mar 2017 15:56:04 +0800 [thread overview]
Message-ID: <1489564565-20856-3-git-send-email-eddie.cai.linux@gmail.com> (raw)
In-Reply-To: <1489564565-20856-1-git-send-email-eddie.cai.linux@gmail.com>
this patch add rockusb command. the usage is
rockusb <USB_controller> [<devtype>] <devnum>
e.g. rockusb 0 mmc 0
Signed-off-by: Eddie Cai <eddie.cai.linux@gmail.com>
---
cmd/Kconfig | 12 +++++++++
cmd/Makefile | 1 +
cmd/rockusb.c | 79 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
include/rockusb.h | 13 +++++++++
4 files changed, 105 insertions(+)
create mode 100644 cmd/rockusb.c
create mode 100644 include/rockusb.h
diff --git a/cmd/Kconfig b/cmd/Kconfig
index ef53156..dac2cc0 100644
--- a/cmd/Kconfig
+++ b/cmd/Kconfig
@@ -475,6 +475,18 @@ config CMD_DFU
Enables the command "dfu" which is used to have U-Boot create a DFU
class device via USB.
+config CMD_ROCKUSB
+ bool "rockusb"
+ select USB_FUNCTION_ROCKUSB
+ help
+ Enables the command "rockusb" which is used to have U-Boot create a
+ Rockusb class device via USB.
+
+config USB_FUNCTION_ROCKUSB
+ bool "Enable USB rockusb gadget"
+ help
+ This enables the USB part of the rockusb gadget.
+
config CMD_USB_MASS_STORAGE
bool "UMS usb mass storage"
help
diff --git a/cmd/Makefile b/cmd/Makefile
index f13bb8c..f5f1663 100644
--- a/cmd/Makefile
+++ b/cmd/Makefile
@@ -141,6 +141,7 @@ endif
obj-$(CONFIG_CMD_USB) += usb.o disk.o
obj-$(CONFIG_CMD_FASTBOOT) += fastboot.o
+obj-$(CONFIG_CMD_ROCKUSB) += rockusb.o
obj-$(CONFIG_CMD_FS_UUID) += fs_uuid.o
obj-$(CONFIG_CMD_USB_MASS_STORAGE) += usb_mass_storage.o
diff --git a/cmd/rockusb.c b/cmd/rockusb.c
new file mode 100644
index 0000000..f5bd86e
--- /dev/null
+++ b/cmd/rockusb.c
@@ -0,0 +1,79 @@
+/*
+ * Copyright (C) 2017 Eddie Cai <eddie.cai.linux@gmail.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+
+#include <common.h>
+#include <command.h>
+#include <console.h>
+#include <g_dnl.h>
+#include <usb.h>
+#include <rockusb.h>
+
+
+static int do_rockusb(cmd_tbl_t *cmdtp, int flag, int argc, char *const argv[])
+{
+ int controller_index, dev_index;
+ char *usb_controller;
+ char *devtype;
+ char *devnum;
+ int ret;
+
+ if (argc < 2)
+ return CMD_RET_USAGE;
+
+ usb_controller = argv[1];
+ controller_index = simple_strtoul(usb_controller, NULL, 0);
+
+ if (argc >= 4) {
+ devtype = argv[2];
+ devnum = argv[3];
+ } else {
+ devtype = "mmc";
+ devnum = argv[2];
+ }
+ dev_index = simple_strtoul(devnum, NULL, 0);
+ rockusb_dev_init(devtype, dev_index);
+
+ ret = board_usb_init(controller_index, USB_INIT_DEVICE);
+ if (ret) {
+ error("USB init failed: %d", ret);
+ return CMD_RET_FAILURE;
+ }
+
+ g_dnl_clear_detach();
+ ret = g_dnl_register("usb_dnl_rockusb");
+ if (ret)
+ return ret;
+ printf("do_rockusb1\n");
+ if (!g_dnl_board_usb_cable_connected()) {
+ puts("\rUSB cable not detected.\n" \
+ "Command exit.\n");
+ ret = CMD_RET_FAILURE;
+ goto exit;
+ }
+
+ while (1) {
+ if (g_dnl_detach())
+ break;
+ if (ctrlc())
+ break;
+ usb_gadget_handle_interrupts(controller_index);
+ }
+ printf("do_rockusb2\n");
+ ret = CMD_RET_SUCCESS;
+
+exit:
+ g_dnl_unregister();
+ g_dnl_clear_detach();
+ board_usb_cleanup(controller_index, USB_INIT_DEVICE);
+
+ return ret;
+}
+
+U_BOOT_CMD(rockusb, 4, 1, do_rockusb,
+ "Use the ROCKUSB",
+ "rockusb <USB_controller> [<devtype>] <devnum> e.g. rockusb 0 mmc 0\n"
+ " devtype defaults to mmc"
+);
diff --git a/include/rockusb.h b/include/rockusb.h
new file mode 100644
index 0000000..cdea63d
--- /dev/null
+++ b/include/rockusb.h
@@ -0,0 +1,13 @@
+/*
+ * (C) Copyright 2017
+ *
+ * Eddie Cai <eddie.cai.linux@gmail.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+#ifndef _ROCKUSB_H_
+#define _ROCKUSB_H_
+
+void rockusb_dev_init(char *dev_type, int dev_index);
+
+#endif /* _ROCKUSB_H_ */
--
2.7.4
next prev parent reply other threads:[~2017-03-15 7:56 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-03-15 7:56 [U-Boot] [U-Boot 0/3] introduce Rockchip rockusb Eddie Cai
2017-03-15 7:56 ` [U-Boot] [U-Boot 1/3] drivers: usb: gadget: add the rockusb gadget Eddie Cai
2017-03-16 7:05 ` Kever Yang
2017-03-20 7:24 ` Eddie Cai
2017-03-20 8:37 ` Lukasz Majewski
2017-04-20 0:56 ` Eddie Cai
2017-04-20 10:04 ` Lukasz Majewski
2017-03-15 7:56 ` Eddie Cai [this message]
2017-03-20 2:29 ` [U-Boot] [U-Boot 2/3] cmd: add rockusb command Simon Glass
2017-03-20 8:14 ` Eddie Cai
2017-03-22 13:05 ` Simon Glass
2017-04-20 10:11 ` Lukasz Majewski
2017-03-15 7:56 ` [U-Boot] [U-Boot 3/3] rockchip: rk3288: enable rockusb support on rk3288 based device Eddie Cai
2017-03-20 2:30 ` Simon Glass
2017-03-20 8:16 ` Eddie Cai
2017-05-02 10:37 ` Eddie Cai
2017-05-03 10:09 ` Simon Glass
2017-05-04 7:17 ` Eddie Cai
2017-05-04 9:19 ` Lukasz Majewski
2017-05-04 16:49 ` Simon Glass
2017-05-05 1:15 ` Eddie Cai
2017-05-14 9:32 ` Simon Glass
2017-05-14 21:49 ` Lukasz Majewski
2017-04-20 10:12 ` Lukasz Majewski
2017-03-15 9:06 ` [U-Boot] [U-Boot 0/3] introduce Rockchip rockusb Lukasz Majewski
2017-03-15 9:31 ` Eddie Cai
2017-03-15 9:46 ` Lukasz Majewski
2017-03-16 21:26 ` Marek Vasut
2017-03-20 1:53 ` Eddie Cai
2017-03-20 12:24 ` Marek Vasut
2017-03-20 16:01 ` Simon Glass
2017-03-20 16:33 ` Marek Vasut
2017-03-21 5:17 ` Kever Yang
2017-03-21 14:27 ` Tom Rini
2017-03-27 8:27 ` Lukasz Majewski
2017-03-28 9:13 ` Eddie Cai
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1489564565-20856-3-git-send-email-eddie.cai.linux@gmail.com \
--to=eddie.cai.linux@gmail.com \
--cc=u-boot@lists.denx.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox