monitor: New argument type 'T'
This is a double value with optional suffixes ms, us, ns. We'll need this to get migrate_set_downtime() QMP-ready. Signed-off-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
5fd9083cd8
commit
fccfb11e0d
17
monitor.c
17
monitor.c
@ -75,6 +75,9 @@
|
||||
* user mode accepts an optional G, g, M, m, K, k suffix,
|
||||
* which multiplies the value by 2^30 for suffixes G and
|
||||
* g, 2^20 for M and m, 2^10 for K and k
|
||||
* 'T' double
|
||||
* user mode accepts an optional ms, us, ns suffix,
|
||||
* which divides the value by 1e3, 1e6, 1e9, respectively
|
||||
* '/' optional gdb-like print format (like "/10x")
|
||||
*
|
||||
* '?' optional type (for all types, except '/')
|
||||
@ -3662,6 +3665,7 @@ static const mon_cmd_t *monitor_parse_command(Monitor *mon,
|
||||
}
|
||||
break;
|
||||
case 'b':
|
||||
case 'T':
|
||||
{
|
||||
double val;
|
||||
|
||||
@ -3676,7 +3680,7 @@ static const mon_cmd_t *monitor_parse_command(Monitor *mon,
|
||||
if (get_double(mon, &val, &p) < 0) {
|
||||
goto fail;
|
||||
}
|
||||
if (*p) {
|
||||
if (c == 'b' && *p) {
|
||||
switch (*p) {
|
||||
case 'K': case 'k':
|
||||
val *= 1 << 10; p++; break;
|
||||
@ -3686,6 +3690,16 @@ static const mon_cmd_t *monitor_parse_command(Monitor *mon,
|
||||
val *= 1 << 30; p++; break;
|
||||
}
|
||||
}
|
||||
if (c == 'T' && p[0] && p[1] == 's') {
|
||||
switch (*p) {
|
||||
case 'm':
|
||||
val /= 1e3; p += 2; break;
|
||||
case 'u':
|
||||
val /= 1e6; p += 2; break;
|
||||
case 'n':
|
||||
val /= 1e9; p += 2; break;
|
||||
}
|
||||
}
|
||||
if (*p && !qemu_isspace(*p)) {
|
||||
monitor_printf(mon, "Unknown unit suffix\n");
|
||||
goto fail;
|
||||
@ -4119,6 +4133,7 @@ static int check_arg(const CmdArgs *cmd_args, QDict *args)
|
||||
}
|
||||
break;
|
||||
case 'b':
|
||||
case 'T':
|
||||
if (qobject_type(value) != QTYPE_QINT && qobject_type(value) != QTYPE_QFLOAT) {
|
||||
qemu_error_new(QERR_INVALID_PARAMETER_TYPE, name, "number");
|
||||
return -1;
|
||||
|
Loading…
Reference in New Issue
Block a user