summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGreg Bellows <greg.bellows@linaro.org>2014-11-19 09:09:24 -0600
committerGreg Bellows <greg.bellows@linaro.org>2014-11-20 11:19:26 -0600
commit34285b6245e62780c255977316d5a03336e1b62d (patch)
tree28cc6561ae8791eb8fbd329bee4e6971e8b85d84
parent4ef9fd56ca4ed8a504632d56a87ebd87d044ccb7 (diff)
android-console: Add avd start command
Add Android emulator console "avd start" commmand and associated help messages. Signed-off-by: Greg Bellows <greg.bellows@linaro.org>
-rw-r--r--android-commands.h7
-rw-r--r--android-console.c18
-rw-r--r--android-console.h1
3 files changed, 26 insertions, 0 deletions
diff --git a/android-commands.h b/android-commands.h
index 86791d44b..3c65964e6 100644
--- a/android-commands.h
+++ b/android-commands.h
@@ -112,6 +112,13 @@ static mon_cmd_t android_avd_cmds[] = {
.mhandler.cmd = android_console_avd_stop,
},
{
+ .name = "start",
+ .args_type = "",
+ .params = "",
+ .help = "start/restart the virtual device",
+ .mhandler.cmd = android_console_avd_start,
+ },
+ {
.name = "status",
.args_type = "",
.params = "",
diff --git a/android-console.c b/android-console.c
index 1e8565c4c..bf0240cd2 100644
--- a/android-console.c
+++ b/android-console.c
@@ -716,6 +716,7 @@ void android_console_event(Monitor *mon, const QDict *qdict)
enum {
CMD_AVD,
CMD_AVD_STOP,
+ CMD_AVD_START,
CMD_AVD_STATUS,
};
@@ -733,6 +734,9 @@ static const char *avd_help[] = {
/* CMD_AVD_STOP */
"'avd stop' stops the virtual device immediately, use 'avd start' to "
"continue execution",
+ /* CMD_AVD_START */
+ "'avd start' will start or continue the virtual device, use 'avd stop' to "
+ "stop it",
/* CMD_AVD_STATUS */
"'avd status' will indicate whether the virtual device is running or not",
};
@@ -749,6 +753,18 @@ void android_console_avd_stop(Monitor *mon, const QDict *qdict)
monitor_printf(mon, "OK\n");
}
+void android_console_avd_start(Monitor *mon, const QDict *qdict)
+{
+ if (runstate_is_running()) {
+ monitor_printf(mon, "KO: virtual device already running\n");
+ return;
+ }
+
+ qmp_cont(NULL);
+
+ monitor_printf(mon, "OK\n");
+}
+
void android_console_avd_status(Monitor *mon, const QDict *qdict)
{
monitor_printf(mon, "virtual device is %s\n",
@@ -768,6 +784,8 @@ void android_console_avd(Monitor *mon, const QDict *qdict)
if (helptext) {
if (strstr(helptext, "stop")) {
cmd = CMD_AVD_STOP;
+ } else if (strstr(helptext, "start")) {
+ cmd = CMD_AVD_START;
} else if (strstr(helptext, "status")) {
cmd = CMD_AVD_STATUS;
}
diff --git a/android-console.h b/android-console.h
index 9f9d9cb44..36a4090ce 100644
--- a/android-console.h
+++ b/android-console.h
@@ -43,6 +43,7 @@ void android_console_event_text(Monitor *mon, const QDict *qdict);
void android_console_event(Monitor *mon, const QDict *qdict);
void android_console_avd_stop(Monitor *mon, const QDict *qdict);
+void android_console_avd_start(Monitor *mon, const QDict *qdict);
void android_console_avd_status(Monitor *mon, const QDict *qdict);
void android_console_avd(Monitor *mon, const QDict *qdict);