提交 3440557b 编写于 作者: B bellard

ioport read command


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@912 c046a42c-6fe2-441c-8c8c-71466251a162
上级 d329a6fb
...@@ -630,6 +630,35 @@ static void do_send_key(const char *string) ...@@ -630,6 +630,35 @@ static void do_send_key(const char *string)
} }
} }
static void do_ioport_read(int count, int format, int size, int addr, int has_index, int index)
{
uint32_t val;
int suffix;
if (has_index) {
cpu_outb(NULL, addr & 0xffff, index & 0xff);
addr++;
}
addr &= 0xffff;
switch(size) {
default:
case 1:
val = cpu_inb(NULL, addr);
suffix = 'b';
break;
case 2:
val = cpu_inw(NULL, addr);
suffix = 'w';
break;
case 4:
val = cpu_inl(NULL, addr);
suffix = 'l';
break;
}
term_printf("port%c[0x%04x] = %#0*x\n",
suffix, addr, size * 2, val);
}
static term_cmd_t term_cmds[] = { static term_cmd_t term_cmds[] = {
{ "help|?", "s?", do_help, { "help|?", "s?", do_help,
...@@ -666,6 +695,9 @@ static term_cmd_t term_cmds[] = { ...@@ -666,6 +695,9 @@ static term_cmd_t term_cmds[] = {
"/fmt addr", "physical memory dump starting at 'addr'", }, "/fmt addr", "physical memory dump starting at 'addr'", },
{ "p|print", "/i", do_print, { "p|print", "/i", do_print,
"/fmt expr", "print expression value (use $reg for CPU register access)", }, "/fmt expr", "print expression value (use $reg for CPU register access)", },
{ "i", "/ii.", do_ioport_read,
"/fmt addr", "I/O port read" },
{ "sendkey", "s", do_send_key, { "sendkey", "s", do_send_key,
"keys", "send keys to the VM (e.g. 'sendkey ctrl-alt-f1')" }, "keys", "send keys to the VM (e.g. 'sendkey ctrl-alt-f1')" },
{ NULL, NULL, }, { NULL, NULL, },
...@@ -1285,12 +1317,23 @@ static void term_handle_command(const char *cmdline) ...@@ -1285,12 +1317,23 @@ static void term_handle_command(const char *cmdline)
int val; int val;
while (isspace(*p)) while (isspace(*p))
p++; p++;
if (*typestr == '?') { if (*typestr == '?' || *typestr == '.') {
typestr++; typestr++;
if (*typestr == '?') {
if (*p == '\0') if (*p == '\0')
has_arg = 0; has_arg = 0;
else else
has_arg = 1; has_arg = 1;
} else {
if (*p == '.') {
p++;
while (isspace(*p))
p++;
has_arg = 1;
} else {
has_arg = 0;
}
}
if (nb_args >= MAX_ARGS) if (nb_args >= MAX_ARGS)
goto error_args; goto error_args;
args[nb_args++] = (void *)has_arg; args[nb_args++] = (void *)has_arg;
...@@ -1369,6 +1412,9 @@ static void term_handle_command(const char *cmdline) ...@@ -1369,6 +1412,9 @@ static void term_handle_command(const char *cmdline)
case 5: case 5:
cmd->handler(args[0], args[1], args[2], args[3], args[4]); cmd->handler(args[0], args[1], args[2], args[3], args[4]);
break; break;
case 6:
cmd->handler(args[0], args[1], args[2], args[3], args[4], args[5]);
break;
default: default:
term_printf("unsupported number of arguments: %d\n", nb_args); term_printf("unsupported number of arguments: %d\n", nb_args);
goto fail; goto fail;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册