diff options
author | Alex Williamson <alex.williamson@hp.com> | 2007-10-02 09:20:41 -0600 |
---|---|---|
committer | Alex Williamson <alex.williamson@hp.com> | 2007-10-02 09:20:41 -0600 |
commit | c2d2f8a44648d127e967687f21e77857b001e7de (patch) | |
tree | 957866aac486c136657cc8d57e4677dfedab3658 /tools/debugger | |
parent | e31f395496beff3d9d343156f54a6d4068c93cab (diff) | |
download | xen-c2d2f8a44648d127e967687f21e77857b001e7de.tar.gz xen-c2d2f8a44648d127e967687f21e77857b001e7de.tar.bz2 xen-c2d2f8a44648d127e967687f21e77857b001e7de.zip |
[IA64] xenitp: Display symbolic names of cr.
Signed-off-by: Tristan Gingold <tgingold@free.fr>
Diffstat (limited to 'tools/debugger')
-rw-r--r-- | tools/debugger/xenitp/ia64-dis.c | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/tools/debugger/xenitp/ia64-dis.c b/tools/debugger/xenitp/ia64-dis.c index b566cdc00f..c9593a46f5 100644 --- a/tools/debugger/xenitp/ia64-dis.c +++ b/tools/debugger/xenitp/ia64-dis.c @@ -214,6 +214,42 @@ print_insn_ia64 (bfd_vma memaddr, struct disassemble_info *info) } (*info->fprintf_func) (info->stream, "%s", regname); } + else if (odesc->str[0] == 'c' && odesc->str[1] == 'r') + { + switch (value) + { + case 0: strcpy (regname, "cr.dcr"); break; + case 1: strcpy (regname, "cr.itm"); break; + case 2: strcpy (regname, "cr.iva"); break; + case 8: strcpy (regname, "cr.pta"); break; + case 16: strcpy (regname, "cr.ipsr"); break; + case 17: strcpy (regname, "cr.isr"); break; + case 19: strcpy (regname, "cr.iip"); break; + case 20: strcpy (regname, "cr.ifa"); break; + case 21: strcpy (regname, "cr.itir"); break; + case 22: strcpy (regname, "cr.iipa"); break; + case 23: strcpy (regname, "cr.ifa"); break; + case 24: strcpy (regname, "cr.iim"); break; + case 25: strcpy (regname, "cr.iha"); break; + case 64: strcpy (regname, "cr.lid"); break; + case 65: strcpy (regname, "cr.ivr"); break; + case 66: strcpy (regname, "cr.tpr"); break; + case 67: strcpy (regname, "cr.eoi"); break; + case 68: strcpy (regname, "cr.irr0"); break; + case 69: strcpy (regname, "cr.irr1"); break; + case 70: strcpy (regname, "cr.irr2"); break; + case 71: strcpy (regname, "cr.irr3"); break; + case 72: strcpy (regname, "cr.itv"); break; + case 73: strcpy (regname, "cr.pmv"); break; + case 74: strcpy (regname, "cr.cmcv"); break; + case 80: strcpy (regname, "cr.lrr0"); break; + case 81: strcpy (regname, "cr.lrr1"); break; + default: + sprintf (regname, "cr%u", (unsigned int) value); + break; + } + (*info->fprintf_func) (info->stream, "%s", regname); + } else (*info->fprintf_func) (info->stream, "%s%d", odesc->str, (int)value); break; |