From: Benjamin Herrenschmidt <benh@kernel.crashing.org>
To: QEMU Developers <qemu-devel@nongnu.org>
Subject: [Qemu-devel] [PATCH] monitor: Add an "xlate" command for translating a virtual address
Date: Sat, 13 Aug 2016 21:52:00 +1000 [thread overview]
Message-ID: <1471089120.12231.48.camel@kernel.crashing.org> (raw)
This is very handy when debugging a guest, especially when it's
stuck on accessing some HW and the only way to figure out what
specific piece of HW is to translate the virtual address to
a hardware address that can then be matched with the mtree
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
---
hmp-commands.hx | 15 +++++++++++++++
monitor.c | 11 +++++++++++
2 files changed, 26 insertions(+)
diff --git a/hmp-commands.hx b/hmp-commands.hx
index 848efee..2d0ce4e 100644
--- a/hmp-commands.hx
+++ b/hmp-commands.hx
@@ -569,6 +569,21 @@ Write to I/O port.
ETEXI
{
+ .name = "xlate",
+ .args_type = "addr:l",
+ .params = "addr",
+ .help = "Translate virtual address via the MMU",
+ .mhandler.cmd = hmp_mmu_xlate,
+ },
+
+STEXI
+@item xlate @var{addr}
+@findex xlate
+Translate virtual address
+
+ETEXI
+
+ {
.name = "sendkey",
.args_type = "keys:s,hold-time:i?",
.params = "keys [hold_ms]",
diff --git a/monitor.c b/monitor.c
index 5d68a5d..b2b3a6e 100644
--- a/monitor.c
+++ b/monitor.c
@@ -1505,6 +1505,17 @@ static void hmp_ioport_write(Monitor *mon, const QDict *qdict)
}
}
+static void hmp_mmu_xlate(Monitor *mon, const QDict *qdict)
+{
+ CPUState *cpu = mon_get_cpu();
+ vaddr va = qdict_get_int(qdict, "addr");
+ hwaddr pa;
+
+ pa = cpu_get_phys_page_debug(cpu, va);
+ pa |= (va & ~TARGET_PAGE_MASK);
+ monitor_printf(mon, "0x%#" HWADDR_PRIx "\n", pa);
+}
+
static void hmp_boot_set(Monitor *mon, const QDict *qdict)
{
Error *local_err = NULL;
next reply other threads:[~2016-08-13 11:52 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-08-13 11:52 Benjamin Herrenschmidt [this message]
2016-08-14 18:55 ` [Qemu-devel] [PATCH] monitor: Add an "xlate" command for translating a virtual address Peter Maydell
2016-08-14 21:24 ` Benjamin Herrenschmidt
2016-08-14 22:55 ` Benjamin Herrenschmidt
2016-08-15 10:02 ` Peter Maydell
2016-08-15 11:34 ` Benjamin Herrenschmidt
2016-08-15 11:44 ` Peter Maydell
2016-08-15 11:56 ` Benjamin Herrenschmidt
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=1471089120.12231.48.camel@kernel.crashing.org \
--to=benh@kernel.crashing.org \
--cc=qemu-devel@nongnu.org \
/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;
as well as URLs for NNTP newsgroup(s).