This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[PATCH, RFC] Add support for choosing disassembler cpu in GDB for POWER.


As part of my patch finalizing the ISA 3.0 binutils support here:

  https://sourceware.org/ml/binutils/2016-09/msg00097.html

... I ended up clobbering some of gdb's disassembly tests.  When I went to
"fix" them, it ended up being a pain since all the tests were in one huge
test case file and they included file offsets in the matching pattern.
This meant that a simple change caused a huge patch.

I wanted to split that test case into individual test cases that match the
test cases we have in GAS.  The problem is that on POWER, we have no way
of choosing a particular cpu to disassemble for in GDB.  This seems like
a nice feature to have.

This patch adds the new GDB commands "set disassembler-cpu <CPU>" and
"show disassembler-cpu".  It also splits the one huge GDB test case into
multiple test cases without the unneeded file offsets.

Alan and Uli, does this patch look like something we'd like?  If we do want
this, what do you think of the "disassembler-cpu" command name?  Is there
something better to use?  Thoughts?

This does build and regtest with no new test case failures.

Peter


include/
	* dis-asm.h (parse_ppc_dis_option): New prototype.
	* opcode/ppc.h (PPC_DEFAULT_CPU): New define.
	(struct ppc_mopt): Moved to here from ...

opcodes/
	* ppc-dis.c (struct ppc_mopt): ... here.
	(ppc_opts): Add NULL end of table sentinel.
	(ppc_parse_cpu): Use it.
	(print_ppc_disassembler_options): Likewise.
	(parse_ppc_dis_option): New function.
	(powerpc_init_dialect): Use parse_ppc_dis_option() and PPC_DEFAULT_CPU.
	(disassemble_init_powerpc): If called from GDB, use its disassembler
	cpu.

gdb/
	* rs6000-tdep.c: Include "opcode/ppc.h".
	(gdb_disassembler_cpu): New extern declaration.
	(ppc_opts): Likewise.
	(prospective_cpu): New static declaration.
	(set_disassembler_cpu): New function.
	(show_disassembler_cpu): Likewise.
	(_initialize_rs6000_tdep): Initialize gdb_disassembler_cpu.
	Setup callbacks for set_disassembler_cpu() and show_disassembler_cpu().

gdb/testsuite/
	* gdb.arch/powerpc-power.exp: Delete test case.
	* gdb.arch/powerpc-power.s: Likewise.
	* gdb.arch/powerpc-power7.exp: New test case.
	* gdb.arch/powerpc-power7.s: Likewise.
	* gdb.arch/powerpc-power8.exp: Likewise.
	* gdb.arch/powerpc-power8.s: Likewise.
	* gdb.arch/powerpc-power9.exp: Likewise.
	* gdb.arch/powerpc-power9.s: Likewise.
	* gdb.arch/powerpc-altivec.exp: Likewise.
	* gdb.arch/powerpc-altivec.s: Likewise.
	* gdb.arch/powerpc-altivec2.exp: Likewise.
	* gdb.arch/powerpc-altivec2.s: Likewise.
	* gdb.arch/powerpc-altivec3.exp: Likewise.
	* gdb.arch/powerpc-altivec3.s: Likewise.
	* gdb.arch/powerpc-vsx.exp: Likewise.
	* gdb.arch/powerpc-vsx.s: Likewise.
	* gdb.arch/powerpc-vsx2.exp: Likewise.
	* gdb.arch/powerpc-vsx2.s: Likewise.
	* gdb.arch/powerpc-vsx3.exp: Likewise.
	* gdb.arch/powerpc-vsx3.s: Likewise.


diff --git a/include/opcode/ppc.h b/include/opcode/ppc.h
index 66d2ceb..4b94b6a 100644
--- a/include/opcode/ppc.h
+++ b/include/opcode/ppc.h
@@ -28,8 +28,19 @@
 extern "C" {
 #endif
 
+/* The default cpu type the assembler/disassembler will use if there
+   is no explcit use of -m or -M.  */
+
+#define PPC_DEFAULT_CPU "power9"
+
 typedef uint64_t ppc_cpu_t;
 
+struct ppc_mopt {
+  const char *opt;
+  ppc_cpu_t cpu;
+  ppc_cpu_t sticky;
+};
+
 /* The opcode table is an array of struct powerpc_opcode.  */
 
 struct powerpc_opcode
diff --git a/include/dis-asm.h b/include/dis-asm.h
index 05bfa37..daa700c 100644
--- a/include/dis-asm.h
+++ b/include/dis-asm.h
@@ -337,6 +337,7 @@ extern int  get_arm_regnames (int, const char **, const char **, const char *con
 extern bfd_boolean aarch64_symbol_is_valid (asymbol *, struct disassemble_info *);
 extern bfd_boolean arm_symbol_is_valid (asymbol *, struct disassemble_info *);
 extern void disassemble_init_powerpc (struct disassemble_info *);
+extern char *parse_ppc_dis_option (char *, const char *);
 
 /* Fetch the disassembler for a given BFD, if that support is available.  */
 extern disassembler_ftype disassembler (bfd *);
diff --git a/opcodes/ppc-dis.c b/opcodes/ppc-dis.c
index da1301e..b978360 100644
--- a/opcodes/ppc-dis.c
+++ b/opcodes/ppc-dis.c
@@ -44,11 +44,7 @@ struct dis_private
 #define POWERPC_DIALECT(INFO) \
   (((struct dis_private *) ((INFO)->private_data))->dialect)
 
-struct ppc_mopt {
-  const char *opt;
-  ppc_cpu_t cpu;
-  ppc_cpu_t sticky;
-};
+char *gdb_disassembler_cpu;
 
 struct ppc_mopt ppc_opts[] = {
   { "403",     PPC_OPCODE_PPC | PPC_OPCODE_403,
@@ -224,6 +220,7 @@ struct ppc_mopt ppc_opts[] = {
     PPC_OPCODE_VSX | PPC_OPCODE_VSX3 },
   { "htm",     PPC_OPCODE_PPC,
     PPC_OPCODE_HTM },
+  { NULL, 0, 0 }  /* End of table sentinel.  */
 };
 
 /* Switch between Booke and VLE dialects for interlinked dumps.  */
@@ -252,7 +249,7 @@ ppc_parse_cpu (ppc_cpu_t ppc_cpu, ppc_cpu_t *sticky, const char *arg)
 {
   unsigned int i;
 
-  for (i = 0; i < sizeof (ppc_opts) / sizeof (ppc_opts[0]); i++)
+  for (i = 0; ppc_opts[i].opt; i++)
     if (strcmp (ppc_opts[i].opt, arg) == 0)
       {
 	if (ppc_opts[i].sticky)
@@ -264,13 +261,35 @@ ppc_parse_cpu (ppc_cpu_t ppc_cpu, ppc_cpu_t *sticky, const char *arg)
 	ppc_cpu = ppc_opts[i].cpu;
 	break;
       }
-  if (i >= sizeof (ppc_opts) / sizeof (ppc_opts[0]))
+  if (ppc_opts[i].opt == NULL)
     return 0;
 
   ppc_cpu |= *sticky;
   return ppc_cpu;
 }
 
+/* Parse the OPTIONS argument looking for ',' seperated cpu names.
+   The first cpu name is copied into CPU and a pointer to the
+   next name is returned or NULL if there are no more cpu names.
+   CPU must contain enough space to hold the cpu name.  */
+
+char *
+parse_ppc_dis_option (char *cpu, const char *options)
+{
+  char *next = strchr (options, ',');
+
+  if (next != NULL)
+    {
+      strncpy (cpu, options, (size_t) (next - options));
+      cpu[(size_t) (next - options)] = 0;
+      next++;
+    }
+  else
+    strcpy (cpu, options);
+
+  return next;
+}
+
 /* Determine which set of machines to disassemble for.  */
 
 static void
@@ -323,30 +342,26 @@ powerpc_init_dialect (struct disassemble_info *info)
       dialect = ppc_parse_cpu (dialect, &sticky, "vle");
       break;
     default:
-      dialect = ppc_parse_cpu (dialect, &sticky, "power9") | PPC_OPCODE_ANY;
+      dialect = ppc_parse_cpu (dialect, &sticky, PPC_DEFAULT_CPU)
+		| PPC_OPCODE_ANY;
+      break;
     }
 
   arg = info->disassembler_options;
   while (arg != NULL)
     {
       ppc_cpu_t new_cpu = 0;
-      char *end = strchr (arg, ',');
-
-      if (end != NULL)
-	*end = 0;
+      char opt[64];
+      arg = parse_ppc_dis_option (opt, arg);
 
-      if ((new_cpu = ppc_parse_cpu (dialect, &sticky, arg)) != 0)
+      if ((new_cpu = ppc_parse_cpu (dialect, &sticky, opt)) != 0)
 	dialect = new_cpu;
-      else if (strcmp (arg, "32") == 0)
+      else if (strcmp (opt, "32") == 0)
 	dialect &= ~(ppc_cpu_t) PPC_OPCODE_64;
-      else if (strcmp (arg, "64") == 0)
+      else if (strcmp (opt, "64") == 0)
 	dialect |= PPC_OPCODE_64;
       else
-	fprintf (stderr, _("warning: ignoring unknown -M%s option\n"), arg);
-
-      if (end != NULL)
-	*end++ = ',';
-      arg = end;
+	fprintf (stderr, _("warning: ignoring unknown -M%s option\n"), opt);
     }
 
   info->private_data = priv;
@@ -405,7 +420,11 @@ disassemble_init_powerpc (struct disassemble_info *info)
     }
 
   if (info->arch == bfd_arch_powerpc)
-    powerpc_init_dialect (info);
+    {
+      if (gdb_disassembler_cpu)
+	info->disassembler_options = gdb_disassembler_cpu;
+      powerpc_init_dialect (info);
+    }
 }
 
 /* Print a big endian PowerPC instruction.  */
@@ -776,7 +795,7 @@ print_ppc_disassembler_options (FILE *stream)
 The following PPC specific disassembler options are supported for use with\n\
 the -M switch:\n"));
 
-  for (col = 0, i = 0; i < sizeof (ppc_opts) / sizeof (ppc_opts[0]); i++)
+  for (col = 0, i = 0; ppc_opts[i].opt; i++)
     {
       col += fprintf (stream, " %s,", ppc_opts[i].opt);
       if (col > 66)
diff --git a/gdb/rs6000-tdep.c b/gdb/rs6000-tdep.c
index ca4d668..3740d8e 100644
--- a/gdb/rs6000-tdep.c
+++ b/gdb/rs6000-tdep.c
@@ -57,6 +57,7 @@
 #include "ppc-ravenscar-thread.h"
 
 #include "dis-asm.h"
+#include "opcode/ppc.h"
 
 #include "trad-frame.h"
 #include "frame-unwind.h"
@@ -127,6 +128,12 @@ static const char *const powerpc_vector_strings[] =
 static enum powerpc_vector_abi powerpc_vector_abi_global = POWERPC_VEC_AUTO;
 static const char *powerpc_vector_abi_string = "auto";
 
+/* This is the variable that is set with "set disassembler-cpu".  */
+extern char *gdb_disassembler_cpu;
+static char *prospective_cpu;
+
+extern struct ppc_mopt ppc_opts[];
+
 /* To be used by skip_prologue.  */
 
 struct rs6000_framedata
@@ -6676,6 +6683,61 @@ show_powerpc_exact_watchpoints (struct ui_file *file, int from_tty,
   fprintf_filtered (file, _("Use of exact watchpoints is %s.\n"), value);
 }
 
+static void
+set_disassembler_cpu (char *args, int from_tty, struct cmd_list_element *c)
+{
+  unsigned int error = 0;
+  char *arg = prospective_cpu;
+
+  while (arg != NULL)
+    {
+      unsigned int i;
+      char opt[32];
+      arg = parse_ppc_dis_option (opt, arg);
+
+      for (i = 0; ppc_opts[i].opt; i++)
+	if (strcmp (ppc_opts[i].opt, opt) == 0)
+	  break;
+
+      if (ppc_opts[i].opt == NULL)
+	{
+	  fprintf_filtered (gdb_stdlog,
+			    _("Invalid disasembler-cpu value: '%s'.\n"), opt);
+	  error = 1;
+	  break;
+	}
+    }
+
+  if (!error)
+    {
+      free (gdb_disassembler_cpu);
+      gdb_disassembler_cpu = strdup (prospective_cpu);
+    }
+}
+
+static void
+show_disassembler_cpu (struct ui_file *file, int from_tty,
+		       struct cmd_list_element *c, const char *value)
+{
+  unsigned int i, col;
+
+  fprintf_filtered (file, _("\
+The current disassembler cpu is '%s'\n\n\
+The following cpus are supported:\n"), gdb_disassembler_cpu);
+
+  for (col = 0, i = 0; ppc_opts[i].opt; i++)
+    {
+      fprintf_filtered (file, " %s,", ppc_opts[i].opt);
+      col += strlen (ppc_opts[i].opt) + 2;
+      if (col > 66)
+        {
+          fprintf_filtered (file, "\n");
+          col = 0;
+        }
+    }
+  fprintf_filtered (file, "\n");
+}
+
 /* Read a PPC instruction from memory.  */
 
 static unsigned int
@@ -6777,6 +6839,8 @@ _initialize_rs6000_tdep (void)
   initialize_tdesc_powerpc_e500 ();
   initialize_tdesc_rs6000 ();
 
+  gdb_disassembler_cpu = strdup (PPC_DEFAULT_CPU",any");
+
   /* Add root prefix command for all "set powerpc"/"show powerpc"
      commands.  */
   add_prefix_cmd ("powerpc", no_class, set_powerpc_command,
@@ -6796,6 +6860,18 @@ _initialize_rs6000_tdep (void)
 				powerpc_set_soft_float, NULL,
 				&setpowerpccmdlist, &showpowerpccmdlist);
 
+  /* Add the command that controls the disassembler cpu.  */
+  add_setshow_string_cmd ("disassembler-cpu", no_class,
+			  &prospective_cpu, _("\
+Set the disassembler cpu.\n\
+Usage: set disassembler-cpu <cpu>[,<cpu>]*\n\
+See 'show disassembler-cpu' for the valid <cpu> names."), _("\
+Show the disassembler cpu."), _("\
+The default value is '" PPC_DEFAULT_CPU ",any'."),
+			set_disassembler_cpu,
+			show_disassembler_cpu,
+			&setlist, &showlist);
+
   add_setshow_enum_cmd ("vector-abi", class_support, powerpc_vector_strings,
 			&powerpc_vector_abi_string,
 			_("Set the vector ABI."),
diff --git a/gdb/testsuite/gdb.arch/powerpc-power.exp b/gdb/testsuite/gdb.arch/powerpc-power.exp
deleted file mode 100644
index 8594ad5..0000000
--- a/gdb/testsuite/gdb.arch/powerpc-power.exp
+++ /dev/null
@@ -1,1429 +0,0 @@
-# Copyright 2014-2016 Free Software Foundation, Inc.
-
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  
-
-# Test PowerPC instructions disassembly.
-
-standard_testfile .s
-set objfile [standard_output_file ${testfile}.o]
-
-if {![istarget "powerpc*-*-*"]} then {
-    verbose "Skipping PowerPC instructions disassembly."
-    return
-}
-
-if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
-    untested "PowerPC instructions disassembly"
-    return -1
-}
-
-clean_restart ${objfile}
-
-# Disassemble the function.
-
-set test "disass func"
-gdb_test_multiple $test $test {
-    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
-	set func $expect_out(1,string)
-	pass $test
-    }
-}
-
-proc instr_to_patt {offset instr} {
-    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
-    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\$offset>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
-}
-
-proc func_check {offset instr} {
-    global func
-
-    set test "Found $offset: $instr"
-    if [regexp -nocase -line [instr_to_patt $offset $instr] $func] {
-	pass $test
-    } else {
-	fail $test
-    }
-}
-
-
-## power7.d
-func_check +0    "lxvd2x  vs3,r4,r5"
-func_check +4    "lxvd2x  vs43,r4,r5"
-func_check +8    "stxvd2x vs3,r4,r5"
-func_check +12   "stxvd2x vs43,r4,r5"
-func_check +16   "xxmrghd vs3,vs4,vs5"
-func_check +20   "xxmrghd vs43,vs44,vs45"
-func_check +24   "xxmrgld vs3,vs4,vs5"
-func_check +28   "xxmrgld vs43,vs44,vs45"
-func_check +32   "xxmrghd vs3,vs4,vs5"
-func_check +36   "xxmrghd vs43,vs44,vs45"
-func_check +40   "xxmrgld vs3,vs4,vs5"
-func_check +44   "xxmrgld vs43,vs44,vs45"
-func_check +48   "xxpermdi vs3,vs4,vs5,1"
-func_check +52   "xxpermdi vs43,vs44,vs45,1"
-func_check +56   "xxpermdi vs3,vs4,vs5,2"
-func_check +60   "xxpermdi vs43,vs44,vs45,2"
-func_check +64   "xvmovdp vs3,vs4"
-func_check +68   "xvmovdp vs43,vs44"
-func_check +72   "xvmovdp vs3,vs4"
-func_check +76   "xvmovdp vs43,vs44"
-func_check +80   "xvcpsgndp vs3,vs4,vs5"
-func_check +84   "xvcpsgndp vs43,vs44,vs45"
-func_check +88   "doze"
-func_check +92   "nap"
-func_check +96   "sleep"
-func_check +100  "rvwinkle"
-func_check +104  "prtyw   r3,r4"
-func_check +108  "prtyd   r13,r14"
-func_check +112  "mfcfar  r10"
-func_check +116  "mtcfar  r11"
-func_check +120  "cmpb    r3,r4,r5"
-func_check +124  "lwzcix  r10,r11,r12"
-func_check +128  "dadd    f16,f17,f18"
-func_check +132  "daddq   f20,f22,f24"
-func_check +136  "dss     3"
-func_check +140  "dssall"
-func_check +144  "dst     r5,r4,1"
-func_check +148  "dstt    r8,r7,0"
-func_check +152  "dstst   r5,r6,3"
-func_check +156  "dststt  r4,r5,2"
-func_check +160  "divwe   r10,r11,r12"
-func_check +164  "divwe\.  r11,r12,r13"
-func_check +168  "divweo  r12,r13,r14"
-func_check +172  "divweo\. r13,r14,r15"
-func_check +176  "divweu  r10,r11,r12"
-func_check +180  "divweu\. r11,r12,r13"
-func_check +184  "divweuo r12,r13,r14"
-func_check +188  "divweuo\. r13,r14,r15"
-func_check +192  "bpermd  r7,r17,r27"
-func_check +196  "popcntw r10,r20"
-func_check +200  "popcntd r10,r20"
-func_check +204  "ldbrx   r20,r21,r22"
-func_check +208  "stdbrx  r20,r21,r22"
-func_check +212  "lfiwzx  f10,0,r10"
-func_check +216  "lfiwzx  f10,r9,r10"
-func_check +220  "fcfids  f4,f5"
-func_check +224  "fcfids\. f4,f5"
-func_check +228  "fcfidus f4,f5"
-func_check +232  "fcfidus\. f4,f5"
-func_check +236  "fctiwu  f4,f5"
-func_check +240  "fctiwu\. f4,f5"
-func_check +244  "fctiwuz f4,f5"
-func_check +248  "fctiwuz\. f4,f5"
-func_check +252  "fctidu  f4,f5"
-func_check +256  "fctidu\. f4,f5"
-func_check +260  "fctiduz f4,f5"
-func_check +264  "fctiduz\. f4,f5"
-func_check +268  "fcfidu  f4,f5"
-func_check +272  "fcfidu\. f4,f5"
-func_check +276  "ftdiv   cr0,f10,f11"
-func_check +280  "ftdiv   cr7,f10,f11"
-func_check +284  "ftsqrt  cr0,f10"
-func_check +288  "ftsqrt  cr7,f10"
-func_check +292  "dcbtt   r8,r9"
-func_check +296  "dcbtstt r8,r9"
-func_check +300  "dcffix  f10,f12"
-func_check +304  "dcffix\. f20,f22"
-func_check +308  "fre     f14,f15"
-func_check +312  "fre\.    f14,f15"
-func_check +316  "fres    f14,f15"
-func_check +320  "fres\.   f14,f15"
-func_check +324  "frsqrte f14,f15"
-func_check +328  "frsqrte\. f14,f15"
-func_check +332  "frsqrtes f14,f15"
-func_check +336  "frsqrtes\. f14,f15"
-func_check +340  "isel    r2,r3,r4,28"
-func_check +344  "yield"
-func_check +348  "yield"
-func_check +352  "ori     r2,r2,0"
-func_check +356  "nop"
-func_check +360  "nop"
-func_check +364  "ori     r2,r2,0"
-func_check +368  "mdoio"
-func_check +372  "mdoio"
-func_check +376  "mdoom"
-func_check +380  "mdoom"
-func_check +384  "mfppr   r10"
-func_check +388  "mfppr32 r11"
-func_check +392  "mtppr   r12"
-func_check +396  "mtppr32 r13"
-func_check +400  "tlbie   r10,r11"
-
-## altivec.d
-func_check +404  "dss     3"
-func_check +408  "dssall"
-func_check +412  "dst     r5,r4,1"
-func_check +416  "dstt    r8,r7,0"
-func_check +420  "dstst   r5,r6,3"
-func_check +424  "dststt  r4,r5,2"
-func_check +428  "lvebx   v30,r22,r24"
-func_check +432  "lvebx   v21,0,r24"
-func_check +436  "lvehx   v10,r16,r2"
-func_check +440  "lvehx   v20,0,r23"
-func_check +444  "lvewx   v17,r4,r18"
-func_check +448  "lvewx   v23,0,r8"
-func_check +452  "lvsl    v6,0,r25"
-func_check +456  "lvsl    v2,0,r6"
-func_check +460  "lvsr    v22,r16,r12"
-func_check +464  "lvsr    v0,0,r29"
-func_check +468  "lvxl    v15,r5,r13"
-func_check +472  "lvxl    v19,0,r23"
-func_check +476  "lvx     v22,r1,r2"
-func_check +480  "lvx     v18,0,r17"
-func_check +484  "mfvrsave r31"
-func_check +488  "mfvscr  v24"
-func_check +492  "mtvrsave r10"
-func_check +496  "mtvscr  v25"
-func_check +500  "stvebx  v18,r27,r10"
-func_check +504  "stvebx  v16,0,r6"
-func_check +508  "stvehx  v17,r13,r16"
-func_check +512  "stvehx  v23,0,r20"
-func_check +516  "stvewx  v11,r19,r31"
-func_check +520  "stvewx  v31,0,r1"
-func_check +524  "stvxl   v26,r21,r17"
-func_check +528  "stvxl   v13,0,r22"
-func_check +532  "stvx    v11,r31,r31"
-func_check +536  "stvx    v30,0,r16"
-func_check +540  "vaddcuw v24,v7,v28"
-func_check +544  "vaddfp  v3,v30,v11"
-func_check +548  "vaddsbs v8,v28,v9"
-func_check +552  "vaddshs v7,v5,v4"
-func_check +556  "vaddsws v22,v26,v27"
-func_check +560  "vaddubm v16,v14,v28"
-func_check +564  "vaddubs v6,v1,v25"
-func_check +568  "vadduhm v2,v4,v6"
-func_check +572  "vadduhs v26,v21,v8"
-func_check +576  "vadduwm v29,v31,v1"
-func_check +580  "vadduws v23,v13,v4"
-func_check +584  "vandc   v30,v16,v9"
-func_check +588  "vand    v3,v13,v27"
-func_check +592  "vavgsb  v4,v6,v17"
-func_check +596  "vavgsh  v23,v28,v19"
-func_check +600  "vavgsw  v8,v15,v31"
-func_check +604  "vavgub  v6,v7,v25"
-func_check +608  "vavguh  v25,v22,v10"
-func_check +612  "vavguw  v3,v23,v29"
-func_check +616  "vctsxs  v14,v2,6"
-func_check +620  "vctuxs  v9,v31,20"
-func_check +624  "vcfsx   v24,v30,3"
-func_check +628  "vcfux   v17,v21,29"
-func_check +632  "vcmpbfp v18,v28,v0"
-func_check +636  "vcmpbfp\. v19,v26,v3"
-func_check +640  "vcmpeqfp v16,v2,v11"
-func_check +644  "vcmpeqfp\. v23,v13,v13"
-func_check +648  "vcmpequb v25,v19,v10"
-func_check +652  "vcmpequb\. v18,v11,v2"
-func_check +656  "vcmpequh v9,v25,v7"
-func_check +660  "vcmpequh\. v14,v24,v21"
-func_check +664  "vcmpequw v24,v12,v5"
-func_check +668  "vcmpequw\. v19,v16,v1"
-func_check +672  "vcmpgefp v23,v17,v16"
-func_check +676  "vcmpgefp\. v19,v29,v17"
-func_check +680  "vcmpgtfp v16,v28,v13"
-func_check +684  "vcmpgtfp\. v14,v24,v7"
-func_check +688  "vcmpgtsb v16,v22,v6"
-func_check +692  "vcmpgtsb\. v2,v12,v14"
-func_check +696  "vcmpgtsh v28,v3,v29"
-func_check +700  "vcmpgtsh\. v16,v19,v13"
-func_check +704  "vcmpgtsw v15,v0,v5"
-func_check +708  "vcmpgtsw\. v21,v13,v0"
-func_check +712  "vcmpgtub v5,v10,v30"
-func_check +716  "vcmpgtub\. v7,v13,v10"
-func_check +720  "vcmpgtuh v24,v15,v16"
-func_check +724  "vcmpgtuh\. v25,v21,v27"
-func_check +728  "vcmpgtuw v17,v27,v6"
-func_check +732  "vcmpgtuw\. v8,v21,v27"
-func_check +736  "vcfsx   v1,v1,14"
-func_check +740  "vctsxs  v4,v15,25"
-func_check +744  "vctuxs  v28,v23,14"
-func_check +748  "vcfux   v6,v6,0"
-func_check +752  "vexptefp v0,v8"
-func_check +756  "vlogefp v22,v27"
-func_check +760  "vmaddfp v23,v18,v5,v18"
-func_check +764  "vmaxfp  v13,v13,v27"
-func_check +768  "vmaxsb  v8,v23,v14"
-func_check +772  "vmaxsh  v19,v17,v0"
-func_check +776  "vmaxsw  v19,v3,v22"
-func_check +780  "vmaxub  v23,v30,v28"
-func_check +784  "vmaxuh  v9,v20,v23"
-func_check +788  "vmaxuw  v21,v19,v1"
-func_check +792  "vmhaddshs v22,v13,v5,v22"
-func_check +796  "vmhraddshs v31,v0,v3,v18"
-func_check +800  "vminfp  v2,v21,v24"
-func_check +804  "vminsb  v20,v6,v10"
-func_check +808  "vminsh  v18,v27,v26"
-func_check +812  "vminsw  v3,v4,v1"
-func_check +816  "vminub  v7,v0,v13"
-func_check +820  "vminuh  v0,v12,v6"
-func_check +824  "vminuw  v6,v3,v1"
-func_check +828  "vmladduhm v3,v29,v3,v26"
-func_check +832  "vmrghb  v21,v5,v31"
-func_check +836  "vmrghh  v21,v24,v0"
-func_check +840  "vmrghw  v16,v0,v22"
-func_check +844  "vmrglb  v1,v17,v16"
-func_check +848  "vmrglh  v14,v8,v15"
-func_check +852  "vmrglw  v31,v21,v5"
-func_check +856  "vmr     v24,v9"
-func_check +860  "vmr     v24,v9"
-func_check +864  "vmsummbm v0,v24,v15,v23"
-func_check +868  "vmsumshm v1,v4,v7,v25"
-func_check +872  "vmsumshs v9,v8,v13,v31"
-func_check +876  "vmsumubm v23,v31,v12,v30"
-func_check +880  "vmsumuhm v29,v0,v26,v21"
-func_check +884  "vmsumuhs v27,v14,v25,v5"
-func_check +888  "vmulesb v10,v25,v14"
-func_check +892  "vmulesh v1,v18,v8"
-func_check +896  "vmuleub v17,v14,v9"
-func_check +900  "vmuleuh v5,v26,v9"
-func_check +904  "vmulosb v21,v18,v6"
-func_check +908  "vmulosh v4,v5,v8"
-func_check +912  "vmuloub v2,v9,v19"
-func_check +916  "vmulouh v29,v5,v4"
-func_check +920  "vnmsubfp v8,v2,v6,v5"
-func_check +924  "vnor    v31,v9,v10"
-func_check +928  "vnot    v25,v31"
-func_check +932  "vnot    v25,v31"
-func_check +936  "vor     v23,v7,v2"
-func_check +940  "vperm   v0,v28,v22,v25"
-func_check +944  "vpkpx   v16,v25,v17"
-func_check +948  "vpkshss v12,v16,v17"
-func_check +952  "vpkshus v1,v19,v23"
-func_check +956  "vpkswss v25,v7,v13"
-func_check +960  "vpkswus v4,v24,v10"
-func_check +964  "vpkuhum v9,v27,v12"
-func_check +968  "vpkuhus v22,v10,v25"
-func_check +972  "vpkuwum v30,v18,v0"
-func_check +976  "vpkuwus v7,v3,v22"
-func_check +980  "vrefp   v24,v28"
-func_check +984  "vrfim   v17,v19"
-func_check +988  "vrfin   v24,v25"
-func_check +992  "vrfip   v3,v5"
-func_check +996  "vrfiz   v8,v10"
-func_check +1000 "vrlb    v26,v18,v30"
-func_check +1004 "vrlh    v16,v17,v25"
-func_check +1008 "vrlw    v23,v30,v9"
-func_check +1012 "vrsqrtefp v2,v18"
-func_check +1016 "vsel    v20,v14,v18,v10"
-func_check +1020 "vslb    v25,v25,v12"
-func_check +1024 "vsldoi  v9,v9,v12,7"
-func_check +1028 "vslh    v14,v2,v11"
-func_check +1032 "vslo    v30,v5,v6"
-func_check +1036 "vsl     v22,v30,v9"
-func_check +1040 "vslw    v26,v26,v3"
-func_check +1044 "vspltb  v1,v20,6"
-func_check +1048 "vsplth  v16,v18,3"
-func_check +1052 "vspltisb v25,-13"
-func_check +1056 "vspltish v22,10"
-func_check +1060 "vspltisw v13,13"
-func_check +1064 "vspltw  v9,v18,2"
-func_check +1068 "vsrab   v14,v22,v0"
-func_check +1072 "vsrah   v12,v12,v18"
-func_check +1076 "vsraw   v2,v2,v13"
-func_check +1080 "vsrb    v7,v27,v5"
-func_check +1084 "vsrh    v7,v11,v29"
-func_check +1088 "vsro    v18,v30,v31"
-func_check +1092 "vsr     v2,v9,v28"
-func_check +1096 "vsrw    v0,v25,v0"
-func_check +1100 "vsubcuw v24,v2,v10"
-func_check +1104 "vsubfp  v22,v24,v20"
-func_check +1108 "vsubsbs v10,v22,v13"
-func_check +1112 "vsubshs v24,v17,v28"
-func_check +1116 "vsubsws v10,v26,v0"
-func_check +1120 "vsububm v16,v11,v24"
-func_check +1124 "vsububs v11,v21,v1"
-func_check +1128 "vsubuhm v6,v12,v24"
-func_check +1132 "vsubuhs v30,v11,v9"
-func_check +1136 "vsubuwm v19,v20,v13"
-func_check +1140 "vsubuws v18,v25,v6"
-func_check +1144 "vsum2sws v25,v10,v18"
-func_check +1148 "vsum4sbs v13,v16,v21"
-func_check +1152 "vsum4shs v23,v8,v4"
-func_check +1156 "vsum4ubs v28,v13,v30"
-func_check +1160 "vsumsws v22,v10,v8"
-func_check +1164 "vupkhpx v24,v14"
-func_check +1168 "vupkhsb v2,v22"
-func_check +1172 "vupkhsh v16,v2"
-func_check +1176 "vupklpx v10,v26"
-func_check +1180 "vupklsb v15,v28"
-func_check +1184 "vupklsh v8,v8"
-func_check +1188 "vxor    v25,v0,v3"
-
-## vsd.d
-func_check +1192 "lxsdx   vs40,r10,r20"
-func_check +1196 "lxvd2x  vs40,r10,r20"
-func_check +1200 "lxvdsx  vs40,r10,r20"
-func_check +1204 "lxvw4x  vs40,r10,r20"
-func_check +1208 "stxsdx  vs40,r10,r20"
-func_check +1212 "stxvd2x vs40,r10,r20"
-func_check +1216 "stxvw4x vs40,r10,r20"
-func_check +1220 "xsabsdp vs40,vs60"
-func_check +1224 "xsadddp vs40,vs50,vs60"
-func_check +1228 "xscmpodp cr1,vs50,vs60"
-func_check +1232 "xscmpudp cr1,vs50,vs60"
-func_check +1236 "xscpsgndp vs40,vs50,vs60"
-func_check +1240 "xscvdpsp vs40,vs60"
-func_check +1244 "xscvdpsxds vs40,vs60"
-func_check +1248 "xscvdpsxws vs40,vs60"
-func_check +1252 "xscvdpuxds vs40,vs60"
-func_check +1256 "xscvdpuxws vs40,vs60"
-func_check +1260 "xscvspdp vs40,vs60"
-func_check +1264 "xscvsxddp vs40,vs60"
-func_check +1268 "xscvuxddp vs40,vs60"
-func_check +1272 "xsdivdp vs40,vs50,vs60"
-func_check +1276 "xsmaddadp vs40,vs50,vs60"
-func_check +1280 "xsmaddmdp vs40,vs50,vs60"
-func_check +1284 "xsmaxdp vs40,vs50,vs60"
-func_check +1288 "xsmindp vs40,vs50,vs60"
-func_check +1292 "xsmsubadp vs40,vs50,vs60"
-func_check +1296 "xsmsubmdp vs40,vs50,vs60"
-func_check +1300 "xsmuldp vs40,vs50,vs60"
-func_check +1304 "xsnabsdp vs40,vs60"
-func_check +1308 "xsnegdp vs40,vs60"
-func_check +1312 "xsnmaddadp vs40,vs50,vs60"
-func_check +1316 "xsnmaddmdp vs40,vs50,vs60"
-func_check +1320 "xsnmsubadp vs40,vs50,vs60"
-func_check +1324 "xsnmsubmdp vs40,vs50,vs60"
-func_check +1328 "xsrdpi  vs40,vs60"
-func_check +1332 "xsrdpic vs40,vs60"
-func_check +1336 "xsrdpim vs40,vs60"
-func_check +1340 "xsrdpip vs40,vs60"
-func_check +1344 "xsrdpiz vs40,vs60"
-func_check +1348 "xsredp  vs40,vs60"
-func_check +1352 "xsrsqrtedp vs40,vs60"
-func_check +1356 "xssqrtdp vs40,vs60"
-func_check +1360 "xssubdp vs40,vs50,vs60"
-func_check +1364 "xstdivdp cr1,vs50,vs60"
-func_check +1368 "xstsqrtdp cr1,vs60"
-func_check +1372 "xvabsdp vs40,vs60"
-func_check +1376 "xvabssp vs40,vs60"
-func_check +1380 "xvadddp vs40,vs50,vs60"
-func_check +1384 "xvaddsp vs40,vs50,vs60"
-func_check +1388 "xvcmpeqdp vs40,vs50,vs60"
-func_check +1392 "xvcmpeqdp\. vs40,vs50,vs60"
-func_check +1396 "xvcmpeqsp vs40,vs50,vs60"
-func_check +1400 "xvcmpeqsp\. vs40,vs50,vs60"
-func_check +1404 "xvcmpgedp vs40,vs50,vs60"
-func_check +1408 "xvcmpgedp\. vs40,vs50,vs60"
-func_check +1412 "xvcmpgesp vs40,vs50,vs60"
-func_check +1416 "xvcmpgesp\. vs40,vs50,vs60"
-func_check +1420 "xvcmpgtdp vs40,vs50,vs60"
-func_check +1424 "xvcmpgtdp\. vs40,vs50,vs60"
-func_check +1428 "xvcmpgtsp vs40,vs50,vs60"
-func_check +1432 "xvcmpgtsp\. vs40,vs50,vs60"
-func_check +1436 "xvcpsgndp vs40,vs50,vs60"
-func_check +1440 "xvmovdp vs40,vs60"
-func_check +1444 "xvmovdp vs40,vs60"
-func_check +1448 "xvcpsgnsp vs40,vs50,vs60"
-func_check +1452 "xvmovsp vs40,vs60"
-func_check +1456 "xvmovsp vs40,vs60"
-func_check +1460 "xvcvdpsp vs40,vs60"
-func_check +1464 "xvcvdpsxds vs40,vs60"
-func_check +1468 "xvcvdpsxws vs40,vs60"
-func_check +1472 "xvcvdpuxds vs40,vs60"
-func_check +1476 "xvcvdpuxws vs40,vs60"
-func_check +1480 "xvcvspdp vs40,vs60"
-func_check +1484 "xvcvspsxds vs40,vs60"
-func_check +1488 "xvcvspsxws vs40,vs60"
-func_check +1492 "xvcvspuxds vs40,vs60"
-func_check +1496 "xvcvspuxws vs40,vs60"
-func_check +1500 "xvcvsxddp vs40,vs60"
-func_check +1504 "xvcvsxdsp vs40,vs60"
-func_check +1508 "xvcvsxwdp vs40,vs60"
-func_check +1512 "xvcvsxwsp vs40,vs60"
-func_check +1516 "xvcvuxddp vs40,vs60"
-func_check +1520 "xvcvuxdsp vs40,vs60"
-func_check +1524 "xvcvuxwdp vs40,vs60"
-func_check +1528 "xvcvuxwsp vs40,vs60"
-func_check +1532 "xvdivdp vs40,vs50,vs60"
-func_check +1536 "xvdivsp vs40,vs50,vs60"
-func_check +1540 "xvmaddadp vs40,vs50,vs60"
-func_check +1544 "xvmaddmdp vs40,vs50,vs60"
-func_check +1548 "xvmaddasp vs40,vs50,vs60"
-func_check +1552 "xvmaddmsp vs40,vs50,vs60"
-func_check +1556 "xvmaxdp vs40,vs50,vs60"
-func_check +1560 "xvmaxsp vs40,vs50,vs60"
-func_check +1564 "xvmindp vs40,vs50,vs60"
-func_check +1568 "xvminsp vs40,vs50,vs60"
-func_check +1572 "xvmsubadp vs40,vs50,vs60"
-func_check +1576 "xvmsubmdp vs40,vs50,vs60"
-func_check +1580 "xvmsubasp vs40,vs50,vs60"
-func_check +1584 "xvmsubmsp vs40,vs50,vs60"
-func_check +1588 "xvmuldp vs40,vs50,vs60"
-func_check +1592 "xvmulsp vs40,vs50,vs60"
-func_check +1596 "xvnabsdp vs40,vs60"
-func_check +1600 "xvnabssp vs40,vs60"
-func_check +1604 "xvnegdp vs40,vs60"
-func_check +1608 "xvnegsp vs40,vs60"
-func_check +1612 "xvnmaddadp vs40,vs50,vs60"
-func_check +1616 "xvnmaddmdp vs40,vs50,vs60"
-func_check +1620 "xvnmaddasp vs40,vs50,vs60"
-func_check +1624 "xvnmaddmsp vs40,vs50,vs60"
-func_check +1628 "xvnmsubadp vs40,vs50,vs60"
-func_check +1632 "xvnmsubmdp vs40,vs50,vs60"
-func_check +1636 "xvnmsubasp vs40,vs50,vs60"
-func_check +1640 "xvnmsubmsp vs40,vs50,vs60"
-func_check +1644 "xvrdpi  vs40,vs60"
-func_check +1648 "xvrdpic vs40,vs60"
-func_check +1652 "xvrdpim vs40,vs60"
-func_check +1656 "xvrdpip vs40,vs60"
-func_check +1660 "xvrdpiz vs40,vs60"
-func_check +1664 "xvredp  vs40,vs60"
-func_check +1668 "xvresp  vs40,vs60"
-func_check +1672 "xvrspi  vs40,vs60"
-func_check +1676 "xvrspic vs40,vs60"
-func_check +1680 "xvrspim vs40,vs60"
-func_check +1684 "xvrspip vs40,vs60"
-func_check +1688 "xvrspiz vs40,vs60"
-func_check +1692 "xvrsqrtedp vs40,vs60"
-func_check +1696 "xvrsqrtesp vs40,vs60"
-func_check +1700 "xvsqrtdp vs40,vs60"
-func_check +1704 "xvsqrtsp vs40,vs60"
-func_check +1708 "xvsubdp vs40,vs50,vs60"
-func_check +1712 "xvsubsp vs40,vs50,vs60"
-func_check +1716 "xvtdivdp cr1,vs50,vs60"
-func_check +1720 "xvtdivsp cr1,vs50,vs60"
-func_check +1724 "xvtsqrtdp cr1,vs60"
-func_check +1728 "xvtsqrtsp cr1,vs60"
-func_check +1732 "xxland  vs40,vs50,vs60"
-func_check +1736 "xxlandc vs40,vs50,vs60"
-func_check +1740 "xxlnor  vs40,vs50,vs60"
-func_check +1744 "xxlor   vs40,vs50,vs60"
-func_check +1748 "xxlxor  vs40,vs50,vs60"
-func_check +1752 "xxmrghw vs40,vs50,vs60"
-func_check +1756 "xxmrglw vs40,vs50,vs60"
-func_check +1760 "xxmrghd vs40,vs50,vs60"
-func_check +1764 "xxpermdi vs40,vs50,vs60,1"
-func_check +1768 "xxpermdi vs40,vs50,vs60,2"
-func_check +1772 "xxmrgld vs40,vs50,vs60"
-func_check +1776 "xxspltd vs40,vs50,0"
-func_check +1780 "xxspltd vs40,vs50,0"
-func_check +1784 "xxspltd vs40,vs50,1"
-func_check +1788 "xxspltd vs40,vs50,1"
-func_check +1792 "xxmrghd vs40,vs50,vs60"
-func_check +1796 "xxmrghd vs40,vs50,vs60"
-func_check +1800 "xxmrgld vs40,vs50,vs60"
-func_check +1804 "xxswapd vs40,vs50"
-func_check +1808 "xxswapd vs40,vs50"
-func_check +1812 "xxsel   vs40,vs50,vs60,vs62"
-func_check +1816 "xxsldwi vs40,vs50,vs60,2"
-func_check +1820 "xxspltw vs40,vs60,2"
-func_check +1824 "lxvd2x  vs40,0,r20"
-func_check +1828 "lxvd2x  vs40,r10,r20"
-func_check +1832 "stxvd2x vs40,0,r20"
-func_check +1836 "stxvd2x vs40,r10,r20"
-
-## power8.d
-func_check +1840 "tabort\. r5"
-func_check +1844 "tabortwc\. 7,r8,r16"
-func_check +1848 "tabortdc\. 20,r11,r10"
-func_check +1852 "tabortwci\. 17,r10,-13"
-func_check +1856 "tabortdci\. 29,r3,-5"
-func_check +1860 "tbegin\."
-func_check +1864 "tcheck  cr7"
-func_check +1868 "tend\."
-func_check +1872 "tend\."
-func_check +1876 "tendall\."
-func_check +1880 "tendall\."
-func_check +1884 "treclaim\. r24"
-func_check +1888 "trechkpt\."
-func_check +1892 "tsuspend\."
-func_check +1896 "tsuspend\."
-func_check +1900 "tresume\."
-func_check +1904 "tresume\."
-func_check +1908 "ori     r2,r2,0"
-func_check +1912 "nop"
-func_check +1916 "ori     r2,r2,0"
-func_check +1920 "rfebb   0"
-func_check +1924 "rfebb"
-func_check +1928 "rfebb"
-func_check +1932 "bctar-  12,4\\*cr5\\+gt"
-func_check +1936 "bctarl- 4,4\\*cr1\\+so"
-func_check +1940 "bctar\\+  12,4\\*cr3\\+lt"
-func_check +1944 "bctarl\\+ 4,eq"
-func_check +1948 "bctar   4,4\\*cr2\\+lt,1"
-func_check +1952 "bctarl  4,4\\*cr1\\+so,2"
-func_check +1956 "wait"
-func_check +1960 "msgsndp r8"
-func_check +1964 "mtsle   1"
-func_check +1968 "msgclrp r27"
-func_check +1972 "stqcx\.  r10,r10,r12"
-func_check +1976 "stqcx\.  r28,0,r7"
-func_check +1980 "lqarx   r24,r19,r11"
-func_check +1984 "lqarx   r22,0,r11"
-func_check +1988 "mfbhrbe r20,6"
-func_check +1992 "pbt\.    r29,r17,r16"
-func_check +1996 "pbt\.    r14,0,r7"
-func_check +2000 "clrbhrb"
-func_check +2004 "vpermxor v11,v10,v0,v23"
-func_check +2008 "vaddeuqm v24,v2,v7,v4"
-func_check +2012 "vaddecuq v10,v10,v8,v2"
-func_check +2016 "vsubeuqm v5,v15,v8,v19"
-func_check +2020 "vsubecuq v12,v31,v16,v29"
-func_check +2024 "vmulouw v20,v29,v13"
-func_check +2028 "vmuluwm v29,v0,v26"
-func_check +2032 "vaddudm v8,v21,v28"
-func_check +2036 "vmaxud  v1,v26,v1"
-func_check +2040 "vrld    v20,v3,v1"
-func_check +2044 "vcmpequd v4,v19,v11"
-func_check +2048 "vadduqm v23,v14,v30"
-func_check +2052 "vaddcuq v8,v8,v13"
-func_check +2056 "vmulosw v28,v27,v4"
-func_check +2060 "vmaxsd  v3,v4,v4"
-func_check +2064 "vmuleuw v0,v19,v21"
-func_check +2068 "vminud  v24,v20,v19"
-func_check +2072 "vcmpgtud v0,v28,v15"
-func_check +2076 "vmulesw v21,v0,v2"
-func_check +2080 "vminsd  v9,v26,v9"
-func_check +2084 "vsrad   v25,v29,v11"
-func_check +2088 "vcmpgtsd v11,v28,v11"
-func_check +2092 "bcdadd\. v5,v8,v26,1"
-func_check +2096 "vpmsumb v4,v3,v12"
-func_check +2100 "bcdsub\. v26,v31,v21,1"
-func_check +2104 "vpmsumh v5,v17,v16"
-func_check +2108 "vpkudum v23,v17,v20"
-func_check +2112 "vpmsumw v24,v21,v29"
-func_check +2116 "vpmsumd v9,v22,v13"
-func_check +2120 "vpkudus v18,v19,v18"
-func_check +2124 "vsubuqm v30,v16,v22"
-func_check +2128 "vcipher v14,v11,v7"
-func_check +2132 "vcipherlast v10,v2,v22"
-func_check +2136 "vgbbd   v23,v13"
-func_check +2140 "vsubcuq v16,v25,v16"
-func_check +2144 "vorc    v31,v1,v5"
-func_check +2148 "vncipher v4,v17,v31"
-func_check +2152 "vncipherlast v24,v2,v27"
-func_check +2156 "vbpermq v23,v21,v23"
-func_check +2160 "vpksdus v27,v18,v9"
-func_check +2164 "vnand   v27,v29,v27"
-func_check +2168 "vsld    v19,v19,v24"
-func_check +2172 "vsbox   v5,v13"
-func_check +2176 "vpksdss v25,v3,v7"
-func_check +2180 "vcmpequd\. v28,v8,v0"
-func_check +2184 "vupkhsw v26,v26"
-func_check +2188 "vshasigmaw v5,v7,0,6"
-func_check +2192 "veqv    v28,v21,v14"
-func_check +2196 "vmrgow  v1,v8,v19"
-func_check +2200 "vshasigmad v0,v10,0,10"
-func_check +2204 "vsrd    v5,v27,v14"
-func_check +2208 "vupklsw v11,v13"
-func_check +2212 "vclzb   v14,v16"
-func_check +2216 "vpopcntb v20,v27"
-func_check +2220 "vclzh   v28,v11"
-func_check +2224 "vpopcnth v24,v9"
-func_check +2228 "vclzw   v27,v31"
-func_check +2232 "vpopcntw v17,v19"
-func_check +2236 "vclzd   v12,v29"
-func_check +2240 "vpopcntd v23,v22"
-func_check +2244 "vcmpgtud\. v24,v20,v29"
-func_check +2248 "vcmpgtsd\. v9,v6,v27"
-func_check +2252 "lxsiwzx vs62,r14,r26"
-func_check +2256 "lxsiwzx vs40,0,r25"
-func_check +2260 "lxsiwax vs25,0,r26"
-func_check +2264 "lxsiwax vs3,0,r3"
-func_check +2268 "mfvsrd  r12,vs62"
-func_check +2272 "mffprwz r20,f12"
-func_check +2276 "stxsiwx vs14,r9,r14"
-func_check +2280 "stxsiwx vs21,0,r8"
-func_check +2284 "mtvsrd  vs48,r11"
-func_check +2288 "mtvrwa  v31,r23"
-func_check +2292 "mtfprwz f16,r26"
-func_check +2296 "lxsspx  vs13,r19,r13"
-func_check +2300 "lxsspx  vs18,0,r13"
-func_check +2304 "stxsspx vs43,r2,r4"
-func_check +2308 "stxsspx vs55,0,r11"
-func_check +2312 "xsaddsp vs54,vs48,vs25"
-func_check +2316 "xsmaddasp vs14,vs50,vs1"
-func_check +2320 "xssubsp vs26,vs22,vs42"
-func_check +2324 "xsmaddmsp vs27,vs53,vs52"
-func_check +2328 "xsrsqrtesp vs8,vs59"
-func_check +2332 "xssqrtsp vs12,vs41"
-func_check +2336 "xsmulsp vs57,vs11,vs32"
-func_check +2340 "xsmsubasp vs38,vs20,vs26"
-func_check +2344 "xsdivsp vs26,vs19,vs6"
-func_check +2348 "xsmsubmsp vs35,vs37,vs55"
-func_check +2352 "xsresp  vs59,vs8"
-func_check +2356 "xsnmaddasp vs44,vs33,vs33"
-func_check +2360 "xsnmaddmsp vs17,vs62,vs30"
-func_check +2364 "xsnmsubasp vs54,vs52,vs31"
-func_check +2368 "xsnmsubmsp vs37,vs5,vs58"
-func_check +2372 "xxlorc  vs30,vs54,vs44"
-func_check +2376 "xxlnand vs49,vs14,vs29"
-func_check +2380 "xxleqv  vs62,vs22,vs30"
-func_check +2384 "xscvdpspn vs60,vs54"
-func_check +2388 "xsrsp   vs22,vs45"
-func_check +2392 "xscvuxdsp vs26,vs59"
-func_check +2396 "xscvsxdsp vs38,vs49"
-func_check +2400 "xscvspdpn vs59,vs26"
-func_check +2404 "fmrgow  f24,f14,f2"
-func_check +2408 "fmrgew  f22,f7,f5"
-func_check +2412 "msgsnd  r14"
-func_check +2416 "msgclr  r23"
-func_check +2420 "lxvd2x  vs40,0,r5"
-func_check +2424 "lxvd2x  vs40,0,r5"
-func_check +2428 "lxvd2x  vs10,r20,r6"
-func_check +2432 "lxvd2x  vs10,r20,r6"
-func_check +2436 "stxvd2x vs41,0,r7"
-func_check +2440 "stxvd2x vs41,0,r7"
-func_check +2444 "stxvd2x vs11,r21,r8"
-func_check +2448 "stxvd2x vs11,r21,r8"
-
-## altivec2.d
-func_check +2452 "lvepxl  v3,0,r28"
-func_check +2456 "lvepxl  v19,r4,r18"
-func_check +2460 "lvepx   v27,0,r19"
-func_check +2464 "lvepx   v1,r25,r18"
-func_check +2468 "lvexbx  v31,0,r27"
-func_check +2472 "lvexbx  v28,r1,r12"
-func_check +2476 "lvexhx  v31,0,r14"
-func_check +2480 "lvexhx  v17,r16,r31"
-func_check +2484 "lvexwx  v22,0,r29"
-func_check +2488 "lvexwx  v23,r25,r5"
-func_check +2492 "lvsm    v3,0,r12"
-func_check +2496 "lvsm    v27,r29,r1"
-func_check +2500 "lvswxl  v7,0,r6"
-func_check +2504 "lvswxl  v7,r16,r8"
-func_check +2508 "lvswx   v14,0,r18"
-func_check +2512 "lvswx   v28,r28,r16"
-func_check +2516 "lvtlxl  v27,0,r12"
-func_check +2520 "lvtlxl  v27,r28,r0"
-func_check +2524 "lvtlx   v23,0,r25"
-func_check +2528 "lvtlx   v1,r25,r14"
-func_check +2532 "lvtrxl  v20,0,r24"
-func_check +2536 "lvtrxl  v22,r29,r24"
-func_check +2540 "lvtrx   v24,0,r8"
-func_check +2544 "lvtrx   v13,r23,r28"
-func_check +2548 "mvidsplt v12,r28,r12"
-func_check +2552 "mviwsplt v10,r27,r0"
-func_check +2556 "stvepxl v27,0,r13"
-func_check +2560 "stvepxl v2,r2,r31"
-func_check +2564 "stvepx  v3,0,r10"
-func_check +2568 "stvepx  v27,r28,r0"
-func_check +2572 "stvexbx v13,0,r6"
-func_check +2576 "stvexbx v13,r25,r3"
-func_check +2580 "stvexhx v22,0,r1"
-func_check +2584 "stvexhx v17,r14,r10"
-func_check +2588 "stvexwx v21,0,r27"
-func_check +2592 "stvexwx v31,r18,r1"
-func_check +2596 "stvflxl v26,0,r13"
-func_check +2600 "stvflxl v22,r13,r21"
-func_check +2604 "stvflx  v5,0,r9"
-func_check +2608 "stvflx  v21,r24,r1"
-func_check +2612 "stvfrxl v13,0,r10"
-func_check +2616 "stvfrxl v13,r17,r25"
-func_check +2620 "stvfrx  v17,0,r10"
-func_check +2624 "stvfrx  v8,r12,r31"
-func_check +2628 "stvswxl v18,0,r29"
-func_check +2632 "stvswxl v26,r14,r8"
-func_check +2636 "stvswx  v0,0,r15"
-func_check +2640 "stvswx  v13,r23,r7"
-func_check +2644 "vabsdub v6,v17,v16"
-func_check +2648 "vabsduh v21,v18,v4"
-func_check +2652 "vabsduw v25,v20,v9"
-func_check +2656 "vpermxor v6,v17,v20,v26"
-func_check +2660 "vaddeuqm v29,v26,v15,v28"
-func_check +2664 "vaddecuq v15,v8,v7,v24"
-func_check +2668 "vsubeuqm v2,v6,v21,v1"
-func_check +2672 "vsubecuq v29,v6,v0,v4"
-func_check +2676 "vmulouw v14,v9,v3"
-func_check +2680 "vmuluwm v24,v16,v18"
-func_check +2684 "vaddudm v10,v17,v17"
-func_check +2688 "vmaxud  v30,v25,v4"
-func_check +2692 "vrld    v10,v6,v28"
-func_check +2696 "vcmpequd v27,v7,v7"
-func_check +2700 "vadduqm v22,v16,v25"
-func_check +2704 "vaddcuq v1,v21,v29"
-func_check +2708 "vmulosw v20,v11,v19"
-func_check +2712 "vmaxsd  v24,v19,v1"
-func_check +2716 "vmuleuw v13,v27,v30"
-func_check +2720 "vminud  v9,v24,v17"
-func_check +2724 "vcmpgtud v10,v18,v28"
-func_check +2728 "vmulesw v0,v29,v22"
-func_check +2732 "vminsd  v13,v28,v1"
-func_check +2736 "vsrad   v10,v20,v5"
-func_check +2740 "vcmpgtsd v27,v21,v5"
-func_check +2744 "bcdadd\. v0,v23,v30,1"
-func_check +2748 "vpmsumb v25,v24,v26"
-func_check +2752 "bcdsub\. v8,v4,v4,1"
-func_check +2756 "vpmsumh v16,v14,v26"
-func_check +2760 "vpkudum v27,v2,v26"
-func_check +2764 "vpmsumw v6,v23,v17"
-func_check +2768 "vpmsumd v20,v6,v25"
-func_check +2772 "vpkudus v27,v22,v16"
-func_check +2776 "vsubudm v21,v20,v18"
-func_check +2780 "vsubuqm v21,v20,v18"
-func_check +2784 "vcipher v29,v29,v6"
-func_check +2788 "vcipherlast v2,v13,v20"
-func_check +2792 "vgbbd   v20,v18"
-func_check +2796 "vsubcuq v19,v8,v25"
-func_check +2800 "vorc    v9,v26,v29"
-func_check +2804 "vncipher v20,v20,v13"
-func_check +2808 "vncipherlast v15,v5,v27"
-func_check +2812 "vbpermq v3,v19,v6"
-func_check +2816 "vpksdus v30,v4,v28"
-func_check +2820 "vnand   v0,v4,v14"
-func_check +2824 "vsld    v17,v8,v29"
-func_check +2828 "vsbox   v29,v20"
-func_check +2832 "vpksdss v11,v7,v11"
-func_check +2836 "vcmpequd\. v3,v19,v16"
-func_check +2840 "vupkhsw v18,v17"
-func_check +2844 "vshasigmaw v29,v8,0,13"
-func_check +2848 "veqv    v23,v28,v26"
-func_check +2852 "vmrgew  v29,v0,v2"
-func_check +2856 "vmrgow  v29,v0,v2"
-func_check +2860 "vshasigmad v27,v19,0,0"
-func_check +2864 "vsrd    v20,v28,v28"
-func_check +2868 "vupklsw v18,v21"
-func_check +2872 "vclzb   v30,v7"
-func_check +2876 "vpopcntb v29,v21"
-func_check +2880 "vclzh   v25,v21"
-func_check +2884 "vpopcnth v16,v30"
-func_check +2888 "vclzw   v28,v3"
-func_check +2892 "vpopcntw v10,v9"
-func_check +2896 "vclzd   v22,v9"
-func_check +2900 "vpopcntd v15,v30"
-func_check +2904 "vcmpgtud\. v2,v31,v6"
-func_check +2908 "vcmpgtsd\. v20,v15,v2"
-
-## vsd2.d
-func_check +2912 "lxsiwzx vs62,r14,r26"
-func_check +2916 "lxsiwzx vs40,0,r25"
-func_check +2920 "lxsiwax vs25,0,r26"
-func_check +2924 "lxsiwax vs3,0,r3"
-func_check +2928 "mfvsrd  r12,vs30"
-func_check +2932 "mfvsrd  r12,vs30"
-func_check +2936 "mfvsrd  r12,vs62"
-func_check +2940 "mfvsrd  r12,vs62"
-func_check +2944 "mffprwz r20,f12"
-func_check +2948 "mffprwz r20,f12"
-func_check +2952 "mfvrwz  r21,v12"
-func_check +2956 "mfvrwz  r21,v12"
-func_check +2960 "stxsiwx vs14,r9,r14"
-func_check +2964 "stxsiwx vs21,0,r8"
-func_check +2968 "mtvsrd  vs11,r28"
-func_check +2972 "mtvsrd  vs11,r28"
-func_check +2976 "mtvsrd  vs43,r29"
-func_check +2980 "mtvsrd  vs43,r29"
-func_check +2984 "mtfprwa f24,r22"
-func_check +2988 "mtfprwa f24,r22"
-func_check +2992 "mtvrwa  v25,r23"
-func_check +2996 "mtvrwa  v25,r23"
-func_check +3000 "mtfprwz f26,r27"
-func_check +3004 "mtfprwz f26,r27"
-func_check +3008 "mtvrwz  v27,r28"
-func_check +3012 "mtvrwz  v27,r28"
-func_check +3016 "lxsspx  vs13,r19,r13"
-func_check +3020 "lxsspx  vs18,0,r13"
-func_check +3024 "stxsspx vs43,r2,r4"
-func_check +3028 "stxsspx vs55,0,r11"
-func_check +3032 "xsaddsp vs54,vs48,vs25"
-func_check +3036 "xsmaddasp vs14,vs50,vs1"
-func_check +3040 "xssubsp vs26,vs22,vs42"
-func_check +3044 "xsmaddmsp vs27,vs53,vs52"
-func_check +3048 "xsrsqrtesp vs8,vs59"
-func_check +3052 "xssqrtsp vs12,vs41"
-func_check +3056 "xsmulsp vs57,vs11,vs32"
-func_check +3060 "xsmsubasp vs38,vs20,vs26"
-func_check +3064 "xsdivsp vs26,vs19,vs6"
-func_check +3068 "xsmsubmsp vs35,vs37,vs55"
-func_check +3072 "xsresp  vs59,vs8"
-func_check +3076 "xsnmaddasp vs44,vs33,vs33"
-func_check +3080 "xsnmaddmsp vs17,vs62,vs30"
-func_check +3084 "xsnmsubasp vs54,vs52,vs31"
-func_check +3088 "xsnmsubmsp vs37,vs5,vs58"
-func_check +3092 "xxlorc  vs30,vs54,vs44"
-func_check +3096 "xxlnand vs49,vs14,vs29"
-func_check +3100 "xxleqv  vs62,vs22,vs30"
-func_check +3104 "xscvdpspn vs60,vs54"
-func_check +3108 "xsrsp   vs22,vs45"
-func_check +3112 "xscvuxdsp vs26,vs59"
-func_check +3116 "xscvsxdsp vs38,vs49"
-func_check +3120 "xscvspdpn vs59,vs26"
-func_check +3124 "fmrgow  f24,f14,f2"
-func_check +3128 "fmrgew  f22,f7,f5"
-
-## power9.d
-func_check +3132 "cnttzd  r3,r13"
-func_check +3136 "cnttzd\. r4,r14"
-func_check +3140 "cnttzw  r5,r15"
-func_check +3144 "cnttzw\. r6,r16"
-func_check +3148 "modsd   r10,r20,r21"
-func_check +3152 "modsw   r11,r21,r22"
-func_check +3156 "modud   r12,r22,r23"
-func_check +3160 "moduw   r13,r23,r24"
-func_check +3164 "bcdcfn\. v3,v4,0"
-func_check +3168 "bcdcfn\. v3,v4,1"
-func_check +3172 "bcdcfsq\. v4,v5,0"
-func_check +3176 "bcdcfsq\. v4,v5,1"
-func_check +3180 "bcdcfz\. v5,v6,0"
-func_check +3184 "bcdcfz\. v5,v6,1"
-func_check +3188 "bcdcpsgn\. v6,v7,v8"
-func_check +3192 "bcdctn\. v7,v8"
-func_check +3196 "bcdctsq\. v8,v9"
-func_check +3200 "bcdctz\. v9,v10,0"
-func_check +3204 "bcdctz\. v9,v10,1"
-func_check +3208 "bcdsetsgn\. v10,v11,0"
-func_check +3212 "bcdsetsgn\. v10,v11,1"
-func_check +3216 "bcdsr\.  v11,v12,v13,0"
-func_check +3220 "bcdsr\.  v11,v12,v13,1"
-func_check +3224 "bcds\.   v12,v13,v14,0"
-func_check +3228 "bcds\.   v12,v13,v14,1"
-func_check +3232 "bcdtrunc\. v13,v14,v15,0"
-func_check +3236 "bcdtrunc\. v13,v14,v15,1"
-func_check +3240 "bcdus\.  v14,v15,v16"
-func_check +3244 "bcdutrunc\. v15,v16,v17"
-func_check +3248 "lxvll   vs20,0,r21"
-func_check +3252 "lxvll   vs20,r10,r21"
-func_check +3256 "stxvll  vs21,0,r11"
-func_check +3260 "stxvll  vs21,r10,r11"
-func_check +3264 "vmul10cuq v22,v23"
-func_check +3268 "vmul10ecuq v23,v24,v25"
-func_check +3272 "vmul10euq v24,v25,v26"
-func_check +3276 "vmul10uq v25,v26"
-func_check +3280 "xsaddqp v10,v11,v12"
-func_check +3284 "xsaddqpo v11,v12,v12"
-func_check +3288 "xsrqpi  0,v20,v30,0"
-func_check +3292 "xsrqpi  1,v20,v30,0"
-func_check +3296 "xsrqpi  0,v20,v30,3"
-func_check +3300 "xsrqpi  1,v20,v30,3"
-func_check +3304 "xsrqpix 0,v21,v31,0"
-func_check +3308 "xsrqpix 1,v21,v31,0"
-func_check +3312 "xsrqpix 0,v21,v31,3"
-func_check +3316 "xsrqpix 1,v21,v31,3"
-func_check +3320 "xsmulqp v12,v13,v14"
-func_check +3324 "xsmulqpo v13,v14,v15"
-func_check +3328 "xsrqpxp 0,v22,v23,0"
-func_check +3332 "xsrqpxp 1,v22,v23,0"
-func_check +3336 "xsrqpxp 0,v22,v23,3"
-func_check +3340 "xsrqpxp 1,v22,v23,3"
-func_check +3344 "xscpsgnqp v14,v15,v16"
-func_check +3348 "xscmpoqp cr0,v15,v16"
-func_check +3352 "xscmpoqp cr7,v15,v16"
-func_check +3356 "xscmpexpqp cr0,v16,v17"
-func_check +3360 "xscmpexpqp cr7,v16,v17"
-func_check +3364 "xsmaddqp v17,v18,v19"
-func_check +3368 "xsmaddqpo v18,v19,v20"
-func_check +3372 "xsmsubqp v19,v20,v21"
-func_check +3376 "xsmsubqpo v20,v21,v22"
-func_check +3380 "xsnmaddqp v21,v22,v23"
-func_check +3384 "xsnmaddqpo v22,v23,v24"
-func_check +3388 "xsnmsubqp v23,v24,v25"
-func_check +3392 "xsnmsubqpo v24,v25,v26"
-func_check +3396 "xssubqp v25,v26,v27"
-func_check +3400 "xssubqpo v26,v27,v28"
-func_check +3404 "xsdivqp v27,v28,v29"
-func_check +3408 "xsdivqpo v28,v29,v30"
-func_check +3412 "xscmpuqp cr0,v29,v30"
-func_check +3416 "xscmpuqp cr7,v29,v30"
-func_check +3420 "xststdcqp cr0,v30,0"
-func_check +3424 "xststdcqp cr7,v30,0"
-func_check +3428 "xststdcqp cr0,v31,127"
-func_check +3432 "xststdcqp cr7,v31,127"
-func_check +3436 "xsabsqp v10,v11"
-func_check +3440 "xsxexpqp v11,v12"
-func_check +3444 "xsnabsqp v12,v13"
-func_check +3448 "xsnegqp v13,v14"
-func_check +3452 "xsxsigqp v14,v15"
-func_check +3456 "xssqrtqp v15,v16"
-func_check +3460 "xssqrtqpo v16,v17"
-func_check +3464 "xscvqpuwz v17,v18"
-func_check +3468 "xscvudqp v18,v19"
-func_check +3472 "xscvqpswz v19,v20"
-func_check +3476 "xscvsdqp v20,v21"
-func_check +3480 "xscvqpudz v21,v22"
-func_check +3484 "xscvqpdp v22,v23"
-func_check +3488 "xscvqpdpo v23,v24"
-func_check +3492 "xscvdpqp v24,v25"
-func_check +3496 "xscvqpsdz v25,v26"
-func_check +3500 "xsiexpqp v26,v27,v28"
-func_check +3504 "vpermr  v4,v5,v6,v7"
-func_check +3508 "vextractub v5,v6,0"
-func_check +3512 "vextractub v5,v6,15"
-func_check +3516 "vextractuh v6,v7,0"
-func_check +3520 "vextractuh v6,v7,15"
-func_check +3524 "vextractuw v7,v8,0"
-func_check +3528 "vextractuw v7,v8,15"
-func_check +3532 "vextractd v8,v9,0"
-func_check +3536 "vextractd v8,v9,15"
-func_check +3540 "vinsertb v9,v10,0"
-func_check +3544 "vinsertb v9,v10,15"
-func_check +3548 "vinserth v10,v11,0"
-func_check +3552 "vinserth v10,v11,15"
-func_check +3556 "vinsertw v11,v12,0"
-func_check +3560 "vinsertw v11,v12,15"
-func_check +3564 "vinsertd v12,v13,0"
-func_check +3568 "vinsertd v12,v13,15"
-func_check +3572 "mfvsrld r20,vs45"
-func_check +3576 "mtvsrws vs46,r21"
-func_check +3580 "mtvsrdd vs47,0,r23"
-func_check +3584 "mtvsrdd vs47,r22,r23"
-func_check +3588 "lxvx    vs50,0,r11"
-func_check +3592 "lxvx    vs0,r10,r11"
-func_check +3596 "lxvwsx  vs51,0,r12"
-func_check +3600 "lxvwsx  vs1,r10,r12"
-func_check +3604 "lxvh8x  vs52,0,r13"
-func_check +3608 "lxvh8x  vs2,r10,r13"
-func_check +3612 "lxvb16x vs53,0,r14"
-func_check +3616 "lxvb16x vs3,r10,r14"
-func_check +3620 "stxvx   vs54,0,r15"
-func_check +3624 "stxvx   vs4,r20,r15"
-func_check +3628 "stxvh8x vs55,0,r16"
-func_check +3632 "stxvh8x vs5,r20,r16"
-func_check +3636 "stxvb16x vs56,0,r17"
-func_check +3640 "stxvb16x vs6,r20,r17"
-func_check +3644 "xxextractuw vs4,vs5,0"
-func_check +3648 "xxextractuw vs40,vs50,15"
-func_check +3652 "xxspltib vs4,0"
-func_check +3656 "xxspltib vs41,255"
-func_check +3660 "xxinsertw vs5,vs6,0"
-func_check +3664 "xxinsertw vs50,vs60,15"
-func_check +3668 "xxbrh   vs6,vs7"
-func_check +3672 "xxbrh   vs56,vs57"
-func_check +3676 "xxbrw   vs7,vs8"
-func_check +3680 "xxbrw   vs57,vs58"
-func_check +3684 "xxbrd   vs8,vs9"
-func_check +3688 "xxbrd   vs58,vs59"
-func_check +3692 "xxbrq   vs9,vs10"
-func_check +3696 "xxbrq   vs59,vs60"
-func_check +3700 "lxsd    v20,0\\(0\\)"
-func_check +3704 "lxsd    v20,0\\(r10\\)"
-func_check +3708 "lxsd    v20,8\\(0\\)"
-func_check +3712 "lxsd    v20,8\\(r10\\)"
-func_check +3716 "lxsd    v20,-8\\(0\\)"
-func_check +3720 "lxsd    v20,-8\\(r10\\)"
-func_check +3724 "lxsd    v20,32764\\(0\\)"
-func_check +3728 "lxsd    v20,32764\\(r10\\)"
-func_check +3732 "lxsd    v20,-32768\\(0\\)"
-func_check +3736 "lxsd    v20,-32768\\(r10\\)"
-func_check +3740 "lxssp   v30,0\\(0\\)"
-func_check +3744 "lxssp   v30,0\\(r11\\)"
-func_check +3748 "lxssp   v30,8\\(0\\)"
-func_check +3752 "lxssp   v30,8\\(r11\\)"
-func_check +3756 "lxssp   v30,-8\\(0\\)"
-func_check +3760 "lxssp   v30,-8\\(r11\\)"
-func_check +3764 "lxssp   v30,32764\\(0\\)"
-func_check +3768 "lxssp   v30,32764\\(r11\\)"
-func_check +3772 "lxssp   v30,-32768\\(0\\)"
-func_check +3776 "lxssp   v30,-32768\\(r11\\)"
-func_check +3780 "lxv     vs40,0\\(0\\)"
-func_check +3784 "lxv     vs40,0\\(r12\\)"
-func_check +3788 "lxv     vs40,16\\(0\\)"
-func_check +3792 "lxv     vs40,16\\(r12\\)"
-func_check +3796 "lxv     vs40,-16\\(0\\)"
-func_check +3800 "lxv     vs10,-16\\(r12\\)"
-func_check +3804 "lxv     vs10,32752\\(0\\)"
-func_check +3808 "lxv     vs10,32752\\(r12\\)"
-func_check +3812 "lxv     vs10,-32768\\(0\\)"
-func_check +3816 "lxv     vs10,-32768\\(r12\\)"
-func_check +3820 "stxsd   v21,0\\(0\\)"
-func_check +3824 "stxsd   v21,0\\(r10\\)"
-func_check +3828 "stxsd   v21,8\\(0\\)"
-func_check +3832 "stxsd   v21,8\\(r10\\)"
-func_check +3836 "stxsd   v21,-8\\(0\\)"
-func_check +3840 "stxsd   v21,-8\\(r10\\)"
-func_check +3844 "stxsd   v21,32764\\(0\\)"
-func_check +3848 "stxsd   v21,32764\\(r10\\)"
-func_check +3852 "stxsd   v21,-32768\\(0\\)"
-func_check +3856 "stxsd   v21,-32768\\(r10\\)"
-func_check +3860 "stxssp  v31,0\\(0\\)"
-func_check +3864 "stxssp  v31,0\\(r11\\)"
-func_check +3868 "stxssp  v31,8\\(0\\)"
-func_check +3872 "stxssp  v31,8\\(r11\\)"
-func_check +3876 "stxssp  v31,-8\\(0\\)"
-func_check +3880 "stxssp  v31,-8\\(r11\\)"
-func_check +3884 "stxssp  v31,32764\\(0\\)"
-func_check +3888 "stxssp  v31,32764\\(r11\\)"
-func_check +3892 "stxssp  v31,-32768\\(0\\)"
-func_check +3896 "stxssp  v31,-32768\\(r11\\)"
-func_check +3900 "stxv    vs41,0\\(0\\)"
-func_check +3904 "stxv    vs41,0\\(r12\\)"
-func_check +3908 "stxv    vs41,16\\(0\\)"
-func_check +3912 "stxv    vs41,16\\(r12\\)"
-func_check +3916 "stxv    vs41,-16\\(0\\)"
-func_check +3920 "stxv    vs11,-16\\(r12\\)"
-func_check +3924 "stxv    vs11,32752\\(0\\)"
-func_check +3928 "stxv    vs11,32752\\(r12\\)"
-func_check +3932 "stxv    vs11,-32768\\(0\\)"
-func_check +3936 "stxv    vs11,-32768\\(r12\\)"
-func_check +3940 "xxperm  vs20,vs22,vs24"
-func_check +3944 "xxperm  vs40,vs42,vs44"
-func_check +3948 "xxpermr vs21,vs23,vs25"
-func_check +3952 "xxpermr vs41,vs43,vs45"
-func_check +3956 "extswsli r12,r20,0"
-func_check +3960 "extswsli r12,r20,1"
-func_check +3964 "extswsli r12,r20,63"
-func_check +3968 "extswsli\. r13,r21,0"
-func_check +3972 "extswsli\. r13,r21,1"
-func_check +3976 "extswsli\. r13,r21,63"
-func_check +3980 "vrlwmi  v14,v22,v23"
-func_check +3984 "vrldmi  v15,v23,v24"
-func_check +3988 "vrlwnm  v16,v24,v25"
-func_check +3992 "vrldnm  v17,v25,v26"
-func_check +3996 "vbpermd v18,v26,v27"
-func_check +4000 "vnegw   v19,v20"
-func_check +4004 "vnegd   v20,v21"
-func_check +4008 "vprtybw v21,v22"
-func_check +4012 "vprtybd v22,v23"
-func_check +4016 "vprtybq v23,v24"
-func_check +4020 "vextsb2w v24,v25"
-func_check +4024 "vextsh2w v25,v26"
-func_check +4028 "vextsb2d v26,v27"
-func_check +4032 "vextsh2d v27,v28"
-func_check +4036 "vextsw2d v28,v29"
-func_check +4040 "vctzb   v29,v30"
-func_check +4044 "vctzh   v30,v31"
-func_check +4048 "vctzw   v31,v30"
-func_check +4052 "vctzd   v30,v29"
-func_check +4056 "lxsibzx vs10,0,r20"
-func_check +4060 "lxsibzx vs50,r10,r20"
-func_check +4064 "lxsihzx vs11,0,r21"
-func_check +4068 "lxsihzx vs51,r11,r21"
-func_check +4072 "stxsibx vs12,0,r22"
-func_check +4076 "stxsibx vs52,r12,r22"
-func_check +4080 "stxsihx vs13,0,r23"
-func_check +4084 "stxsihx vs53,r13,r23"
-func_check +4088 "maddhd  r10,r11,r12,r13"
-func_check +4092 "maddhdu r20,r21,r22,r23"
-func_check +4096 "maddld  r2,r3,r4,r5"
-func_check +4100 "xscmpexpdp cr0,vs10,vs20"
-func_check +4104 "xscmpexpdp cr7,vs40,vs50"
-func_check +4108 "xsiexpdp vs41,r11,r21"
-func_check +4112 "xststdcdp cr0,vs11,127"
-func_check +4116 "xststdcdp cr7,vs41,127"
-func_check +4120 "xststdcsp cr0,vs11,127"
-func_check +4124 "xststdcsp cr7,vs41,127"
-func_check +4128 "xsxexpdp r13,vs43"
-func_check +4132 "xsxsigdp r14,vs44"
-func_check +4136 "xviexpdp vs45,vs46,vs47"
-func_check +4140 "xviexpsp vs46,vs47,vs48"
-func_check +4144 "xvtstdcdp vs54,vs55,0"
-func_check +4148 "xvtstdcdp vs54,vs55,127"
-func_check +4152 "xvtstdcsp vs55,vs56,0"
-func_check +4156 "xvtstdcsp vs55,vs56,127"
-func_check +4160 "xvxexpdp vs57,vs58"
-func_check +4164 "xvxexpsp vs58,vs59"
-func_check +4168 "xvxsigdp vs59,vs60"
-func_check +4172 "xvxsigsp vs60,vs61"
-func_check +4176 "cmpeqb  cr0,r6,r7"
-func_check +4180 "cmpeqb  cr7,r6,r7"
-func_check +4184 "cmprb   cr0,0,r8,r9"
-func_check +4188 "cmprb   cr7,0,r8,r9"
-func_check +4192 "cmprb   cr0,1,r8,r9"
-func_check +4196 "cmprb   cr7,1,r8,r9"
-func_check +4200 "setb    r15,cr0"
-func_check +4204 "setb    r15,cr7"
-func_check +4208 "lxvl    vs26,0,r10"
-func_check +4212 "lxvl    vs56,r20,r10"
-func_check +4216 "stxvl   vs27,0,r11"
-func_check +4220 "stxvl   vs57,r21,r11"
-func_check +4224 "vclzlsbb r20,v30"
-func_check +4228 "vctzlsbb r21,v31"
-func_check +4232 "vcmpneb v10,v11,v12"
-func_check +4236 "vcmpneb\. v20,v21,v22"
-func_check +4240 "vcmpneh v11,v12,v13"
-func_check +4244 "vcmpneh\. v21,v22,v23"
-func_check +4248 "vcmpnew v12,v13,v14"
-func_check +4252 "vcmpnew\. v22,v23,v24"
-func_check +4256 "vcmpnezb v13,v14,v15"
-func_check +4260 "vcmpnezb\. v23,v24,v25"
-func_check +4264 "vcmpnezh v14,v15,v16"
-func_check +4268 "vcmpnezh\. v24,v25,v26"
-func_check +4272 "vcmpnezw v15,v16,v17"
-func_check +4276 "vcmpnezw\. v25,v26,v27"
-func_check +4280 "vextublx r16,r17,v10"
-func_check +4284 "vextubrx r17,r18,v11"
-func_check +4288 "vextuhlx r18,r19,v12"
-func_check +4292 "vextuhrx r19,r20,v13"
-func_check +4296 "vextuwlx r20,r21,v14"
-func_check +4300 "vextuwrx r21,r22,v15"
-func_check +4304 "dtstsfi cr0,0,f3"
-func_check +4308 "dtstsfi cr7,63,f3"
-func_check +4312 "dtstsfiq cr0,0,f4"
-func_check +4316 "dtstsfiq cr7,63,f4"
-func_check +4320 "xscvhpdp vs40,vs50"
-func_check +4324 "xscvdphp vs41,vs51"
-func_check +4328 "xvcvhpsp vs42,vs52"
-func_check +4332 "xvcvsphp vs43,vs53"
-func_check +4336 "addpcis r3,0"
-func_check +4340 "addpcis r3,0"
-func_check +4344 "addpcis r4,1"
-func_check +4348 "addpcis r4,1"
-func_check +4352 "addpcis r5,-2"
-func_check +4356 "addpcis r5,-2"
-func_check +4360 "addpcis r6,32767"
-func_check +4364 "addpcis r6,32767"
-func_check +4368 "addpcis r7,-32768"
-func_check +4372 "addpcis r7,-32768"
-func_check +4376 "slbsync"
-func_check +4380 "slbieg  r10,r11"
-func_check +4384 "slbmfee r3,r4"
-func_check +4388 "slbmfee r3,r4"
-func_check +4392 "slbmfee r3,r4,1"
-func_check +4396 "slbmfev r4,r5"
-func_check +4400 "slbmfev r4,r5"
-func_check +4404 "slbmfev r4,r5,1"
-func_check +4408 "tlbie   r3,r4"
-func_check +4412 "tlbie   r3,r4"
-func_check +4416 "tlbie   r3,r4,3,1,1"
-func_check +4420 "tlbiel  r3"
-func_check +4424 "tlbiel  r3"
-func_check +4428 "tlbiel  r3,r4,3,1,1"
-func_check +4432 "copy    r12,r13"
-func_check +4436 "paste\.  r10,r11"
-func_check +4440 "cpabort"
-func_check +4444 "hwsync"
-func_check +4448 "hwsync"
-func_check +4452 "hwsync"
-func_check +4456 "lwsync"
-func_check +4460 "lwsync"
-func_check +4464 "ptesync"
-func_check +4468 "ptesync"
-func_check +4472 "ldat    r20,0,0"
-func_check +4476 "ldat    r20,r10,28"
-func_check +4480 "lwat    r21,0,0"
-func_check +4484 "lwat    r21,r11,28"
-func_check +4488 "stdat   r22,0,0"
-func_check +4492 "stdat   r22,r12,28"
-func_check +4496 "stwat   r23,0,0"
-func_check +4500 "stwat   r23,r13,28"
-func_check +4504 "urfid"
-func_check +4508 "rmieg   r30"
-func_check +4512 "ldmx    r10,0,r15"
-func_check +4516 "ldmx    r10,r3,r15"
-func_check +4520 "stop"
-func_check +4524 "wait"
-func_check +4528 "wait"
-func_check +4532 "darn    r3,0"
-func_check +4536 "darn    r3,1"
-func_check +4540 "darn    r3,2"
-func_check +4544 "mcrxrx  cr0"
-func_check +4548 "mcrxrx  cr7"
-func_check +4552 "vslv    v20,v21,v22"
-func_check +4556 "vsrv    v23,v24,v25"
-func_check +4560 "msgsync"
-func_check +4564 "xscmpeqdp vs30,vs40,vs50"
-func_check +4568 "xscmpgtdp vs31,vs41,vs51"
-func_check +4572 "xscmpgedp vs32,vs42,vs52"
-func_check +4576 "xsmincdp vs34,vs44,vs54"
-func_check +4580 "xsmaxcdp vs35,vs45,vs55"
-func_check +4584 "xsminjdp vs36,vs46,vs56"
-func_check +4588 "xsmaxjdp vs37,vs47,vs57"
-func_check +4592 "vmsumudm v20,v21,v22,v23"
-func_check +4596 "addex   r11,r12,r13,0"
-func_check +4600 "addex   r11,r12,r13,1"
-func_check +4604 "addex   r11,r12,r13,2"
-func_check +4608 "mffs    f25"
-func_check +4612 "mffs\.   f25"
-func_check +4616 "mffsce  f26"
-func_check +4620 "mffscdrn f27,f20"
-func_check +4624 "mffscdrni f28,0"
-func_check +4628 "mffscdrni f28,7"
-func_check +4632 "mffscrn f29,f21"
-func_check +4636 "mffscrni f30,0"
-func_check +4640 "mffscrni f30,3"
-func_check +4644 "mffsl   f31"
-func_check +4648 "slbiag  r10"
-
-## altivec3.d
-func_check +4652 "vmul10cuq v11,v30"
-func_check +4656 "vcmpneb v30,v1,v23"
-func_check +4660 "vpermr  v30,v19,v30,v29"
-func_check +4664 "vmul10ecuq v20,v20,v17"
-func_check +4668 "vcmpneh v27,v19,v31"
-func_check +4672 "vrlwmi  v6,v9,v23"
-func_check +4676 "vcmpnew v22,v26,v1"
-func_check +4680 "vrldmi  v24,v30,v25"
-func_check +4684 "vcmpnezb v19,v29,v22"
-func_check +4688 "vcmpnezh v8,v23,v19"
-func_check +4692 "vrlwnm  v27,v24,v11"
-func_check +4696 "vcmpnezw v21,v13,v10"
-func_check +4700 "vrldnm  v5,v20,v29"
-func_check +4704 "vmul10uq v30,v19"
-func_check +4708 "vextractub v24,v21,12"
-func_check +4712 "vmul10euq v0,v19,v28"
-func_check +4716 "vextractuh v10,v3,12"
-func_check +4720 "vextractuw v28,v12,7"
-func_check +4724 "vextractd v30,v27,1"
-func_check +4728 "vinsertb v25,v31,4"
-func_check +4732 "bcdcpsgn\. v21,v14,v30"
-func_check +4736 "vinserth v22,v18,5"
-func_check +4740 "vinsertw v29,v22,1"
-func_check +4744 "vinsertd v29,v13,7"
-func_check +4748 "vcmpneb\. v22,v25,v8"
-func_check +4752 "vcmpneh\. v16,v15,v21"
-func_check +4756 "bcdus\.  v22,v21,v31"
-func_check +4760 "vcmpnew\. v1,v12,v12"
-func_check +4764 "bcds\.   v5,v3,v8,1"
-func_check +4768 "bcdtrunc\. v27,v22,v1,0"
-func_check +4772 "vcmpnezb\. v2,v26,v0"
-func_check +4776 "bcdutrunc\. v26,v14,v7"
-func_check +4780 "vcmpnezh\. v16,v5,v12"
-func_check +4784 "bcdctsq\. v24,v5"
-func_check +4788 "bcdcfsq\. v7,v0,0"
-func_check +4792 "bcdctz\. v30,v12,1"
-func_check +4796 "bcdctn\. v17,v23"
-func_check +4800 "bcdcfz\. v4,v15,1"
-func_check +4804 "bcdcfn\. v29,v5,1"
-func_check +4808 "bcdsetsgn\. v27,v12,0"
-func_check +4812 "vcmpnezw\. v14,v28,v25"
-func_check +4816 "bcdsr\.  v2,v2,v6,1"
-func_check +4820 "vbpermd v25,v0,v5"
-func_check +4824 "vclzlsbb r28,v25"
-func_check +4828 "vctzlsbb r2,v24"
-func_check +4832 "vnegw   v21,v11"
-func_check +4836 "vnegd   v17,v27"
-func_check +4840 "vprtybw v31,v23"
-func_check +4844 "vprtybd v21,v23"
-func_check +4848 "vprtybq v21,v18"
-func_check +4852 "vextsb2w v30,v4"
-func_check +4856 "vextsh2w v3,v26"
-func_check +4860 "vextsb2d v11,v17"
-func_check +4864 "vextsh2d v5,v10"
-func_check +4868 "vextsw2d v13,v25"
-func_check +4872 "vctzb   v25,v2"
-func_check +4876 "vctzh   v0,v3"
-func_check +4880 "vctzw   v22,v6"
-func_check +4884 "vctzd   v26,v24"
-func_check +4888 "vextublx r6,r31,v2"
-func_check +4892 "vextuhlx r13,r0,v18"
-func_check +4896 "vextuwlx r14,r30,v31"
-func_check +4900 "vsrv    v15,v12,v14"
-func_check +4904 "vextubrx r20,r10,v30"
-func_check +4908 "vslv    v21,v21,v2"
-func_check +4912 "vextuhrx r15,r9,v1"
-func_check +4916 "vextuwrx r21,r17,v16"
-func_check +4920 "vmsumudm v20,v21,v22,v23"
-
-## vsx3.d
-func_check +4924 "lxvx    vs34,r6,r25"
-func_check +4928 "lxvx    vs20,0,r10"
-func_check +4932 "lxvl    vs20,r24,r10"
-func_check +4936 "lxvl    vs54,0,r29"
-func_check +4940 "lxvll   vs24,r20,r19"
-func_check +4944 "lxvll   vs34,0,r14"
-func_check +4948 "mfvsrld r2,vs22"
-func_check +4952 "lxvwsx  vs58,r26,r25"
-func_check +4956 "lxvwsx  vs55,0,r29"
-func_check +4960 "stxvx   vs14,r21,r4"
-func_check +4964 "stxvx   vs30,0,r22"
-func_check +4968 "stxvl   vs0,r26,r4"
-func_check +4972 "stxvl   vs37,0,r22"
-func_check +4976 "mtvsrws vs24,r10"
-func_check +4980 "stxvll  vs30,r21,r15"
-func_check +4984 "stxvll  vs39,0,r14"
-func_check +4988 "mtvsrdd vs12,r6,r5"
-func_check +4992 "mtvsrdd vs38,0,r21"
-func_check +4996 "lxsibzx vs59,r28,r6"
-func_check +5000 "lxsibzx vs30,0,r8"
-func_check +5004 "lxvh8x  vs42,r23,r17"
-func_check +5008 "lxvh8x  vs36,0,r5"
-func_check +5012 "lxsihzx vs12,r9,r11"
-func_check +5016 "lxsihzx vs49,0,r13"
-func_check +5020 "lxvb16x vs37,r3,r19"
-func_check +5024 "lxvb16x vs0,0,r30"
-func_check +5028 "stxsibx vs2,r30,r6"
-func_check +5032 "stxsibx vs12,0,r13"
-func_check +5036 "stxvh8x vs16,r29,r8"
-func_check +5040 "stxvh8x vs55,0,r10"
-func_check +5044 "stxsihx vs34,r2,r23"
-func_check +5048 "stxsihx vs60,0,r23"
-func_check +5052 "stxvb16x vs23,r14,r12"
-func_check +5056 "stxvb16x vs19,0,r5"
-func_check +5060 "lxsd    v24,0\\(0\\)"
-func_check +5064 "lxsd    v15,16\\(r21\\)"
-func_check +5068 "lxssp   v6,0\\(0\\)"
-func_check +5072 "lxssp   v23,16\\(r9\\)"
-func_check +5076 "xscmpeqdp vs18,vs51,vs33"
-func_check +5080 "xscmpgtdp vs2,vs26,vs34"
-func_check +5084 "xscmpgedp vs5,vs26,vs20"
-func_check +5088 "xxperm  vs44,vs10,vs43"
-func_check +5092 "xxpermr vs41,vs20,vs5"
-func_check +5096 "xscmpexpdp cr4,vs18,vs55"
-func_check +5100 "xxextractuw vs23,vs37,3"
-func_check +5104 "xxspltib vs54,235"
-func_check +5108 "xxinsertw vs15,vs30,4"
-func_check +5112 "xsmaxcdp vs12,vs11,vs7"
-func_check +5116 "xsmincdp vs32,vs25,vs24"
-func_check +5120 "xsmaxjdp vs25,vs53,vs12"
-func_check +5124 "xststdcsp cr2,vs36,127"
-func_check +5128 "xsminjdp vs32,vs21,vs45"
-func_check +5132 "xsxexpdp r17,vs50"
-func_check +5136 "xsxsigdp r7,vs40"
-func_check +5140 "xscvhpdp vs54,vs34"
-func_check +5144 "xscvdphp vs58,vs54"
-func_check +5148 "xststdcdp cr0,vs38,127"
-func_check +5152 "xvtstdcsp vs56,vs53,127"
-func_check +5156 "xviexpsp vs54,vs20,vs52"
-func_check +5160 "xsiexpdp vs57,r28,r29"
-func_check +5164 "xvxexpdp vs1,vs20"
-func_check +5168 "xvxsigdp vs54,vs59"
-func_check +5172 "xxbrh   vs18,vs37"
-func_check +5176 "xvxexpsp vs14,vs1"
-func_check +5180 "xvxsigsp vs52,vs13"
-func_check +5184 "xxbrw   vs19,vs5"
-func_check +5188 "xxbrd   vs51,vs55"
-func_check +5192 "xvcvhpsp vs35,vs17"
-func_check +5196 "xvcvsphp vs15,vs45"
-func_check +5200 "xxbrq   vs17,vs31"
-func_check +5204 "xvtstdcdp vs16,vs12,127"
-func_check +5208 "xviexpdp vs27,vs9,vs8"
-func_check +5212 "lxv     vs4,0\\(0\\)"
-func_check +5216 "lxv     vs40,16\\(r20\\)"
-func_check +5220 "stxv    vs50,0\\(0\\)"
-func_check +5224 "stxv    vs8,16\\(r16\\)"
-func_check +5228 "stxsd   v3,0\\(0\\)"
-func_check +5232 "stxsd   v17,16\\(r2\\)"
-func_check +5236 "stxssp  v13,0\\(0\\)"
-func_check +5240 "stxssp  v17,16\\(r13\\)"
-func_check +5244 "xsaddqp v8,v10,v18"
-func_check +5248 "xsaddqpo v5,v1,v29"
-func_check +5252 "xsrqpi  0,v12,v18,3"
-func_check +5256 "xsrqpix 1,v31,v19,0"
-func_check +5260 "xsmulqp v14,v1,v6"
-func_check +5264 "xsmulqpo v17,v7,v27"
-func_check +5268 "xsrqpxp 0,v4,v11,0"
-func_check +5272 "xscpsgnqp v29,v23,v28"
-func_check +5276 "xscmpoqp cr7,v13,v27"
-func_check +5280 "xscmpexpqp cr5,v21,v6"
-func_check +5284 "xsmaddqp v2,v19,v4"
-func_check +5288 "xsmaddqpo v30,v7,v16"
-func_check +5292 "xsmsubqp v21,v30,v15"
-func_check +5296 "xsmsubqpo v12,v17,v30"
-func_check +5300 "xsnmaddqp v6,v30,v12"
-func_check +5304 "xsnmaddqpo v12,v22,v12"
-func_check +5308 "xsnmsubqp v10,v29,v27"
-func_check +5312 "xsnmsubqpo v29,v29,v13"
-func_check +5316 "xssubqp v19,v27,v4"
-func_check +5320 "xssubqpo v13,v8,v1"
-func_check +5324 "xsdivqp v8,v3,v27"
-func_check +5328 "xsdivqpo v24,v20,v27"
-func_check +5332 "xscmpuqp cr7,v14,v4"
-func_check +5336 "xststdcqp cr4,v2,127"
-func_check +5340 "xsabsqp v31,v22"
-func_check +5344 "xsxexpqp v25,v3"
-func_check +5348 "xsnabsqp v10,v28"
-func_check +5352 "xsnegqp v19,v31"
-func_check +5356 "xsxsigqp v11,v13"
-func_check +5360 "xssqrtqp v13,v14"
-func_check +5364 "xssqrtqpo v1,v27"
-func_check +5368 "xscvqpuwz v3,v7"
-func_check +5372 "xscvudqp v20,v18"
-func_check +5376 "xscvqpswz v29,v29"
-func_check +5380 "xscvsdqp v2,v28"
-func_check +5384 "xscvqpudz v23,v4"
-func_check +5388 "xscvqpdp v3,v20"
-func_check +5392 "xscvqpdpo v1,v3"
-func_check +5396 "xscvdpqp v19,v12"
-func_check +5400 "xscvqpsdz v13,v4"
-func_check +5404 "xsiexpqp v7,v24,v7"
diff --git a/gdb/testsuite/gdb.arch/powerpc-power.s b/gdb/testsuite/gdb.arch/powerpc-power.s
deleted file mode 100644
index 6fe2520..0000000
--- a/gdb/testsuite/gdb.arch/powerpc-power.s
+++ /dev/null
@@ -1,1389 +0,0 @@
-/* This testcase is part of GDB, the GNU debugger.
-
-   Copyright 2014-2016 Free Software Foundation, Inc.
-
-   This program is free software; you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 3 of the License, or
-   (at your option) any later version.
-
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-
-   You should have received a copy of the GNU General Public License
-   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
-
-	.text
-	.globl	func
-func:
-
-## power7.d
-	.long  0x7c642e98    /* <+0>:     lxvd2x  vs3,r4,r5          */
-	.long  0x7d642e99    /* <+4>:     lxvd2x  vs43,r4,r5         */
-	.long  0x7c642f98    /* <+8>:     stxvd2x vs3,r4,r5          */
-	.long  0x7d642f99    /* <+12>:    stxvd2x vs43,r4,r5         */
-	.long  0xf0642850    /* <+16>:    xxmrghd vs3,vs4,vs5        */
-	.long  0xf16c6857    /* <+20>:    xxmrghd vs43,vs44,vs45     */
-	.long  0xf0642b50    /* <+24>:    xxmrgld vs3,vs4,vs5        */
-	.long  0xf16c6b57    /* <+28>:    xxmrgld vs43,vs44,vs45     */
-	.long  0xf0642850    /* <+32>:    xxmrghd vs3,vs4,vs5        */
-	.long  0xf16c6857    /* <+36>:    xxmrghd vs43,vs44,vs45     */
-	.long  0xf0642b50    /* <+40>:    xxmrgld vs3,vs4,vs5        */
-	.long  0xf16c6b57    /* <+44>:    xxmrgld vs43,vs44,vs45     */
-	.long  0xf0642950    /* <+48>:    xxpermdi vs3,vs4,vs5,1     */
-	.long  0xf16c6957    /* <+52>:    xxpermdi vs43,vs44,vs45,1  */
-	.long  0xf0642a50    /* <+56>:    xxpermdi vs3,vs4,vs5,2     */
-	.long  0xf16c6a57    /* <+60>:    xxpermdi vs43,vs44,vs45,2  */
-	.long  0xf0642780    /* <+64>:    xvmovdp vs3,vs4            */
-	.long  0xf16c6787    /* <+68>:    xvmovdp vs43,vs44          */
-	.long  0xf0642780    /* <+72>:    xvmovdp vs3,vs4            */
-	.long  0xf16c6787    /* <+76>:    xvmovdp vs43,vs44          */
-	.long  0xf0642f80    /* <+80>:    xvcpsgndp vs3,vs4,vs5      */
-	.long  0xf16c6f87    /* <+84>:    xvcpsgndp vs43,vs44,vs45   */
-	.long  0x4c000324    /* <+88>:    doze                       */
-	.long  0x4c000364    /* <+92>:    nap                        */
-	.long  0x4c0003a4    /* <+96>:    sleep                      */
-	.long  0x4c0003e4    /* <+100>:   rvwinkle                   */
-	.long  0x7c830134    /* <+104>:   prtyw   r3,r4              */
-	.long  0x7dcd0174    /* <+108>:   prtyd   r13,r14            */
-	.long  0x7d5c02a6    /* <+112>:   mfcfar  r10                */
-	.long  0x7d7c03a6    /* <+116>:   mtcfar  r11                */
-	.long  0x7c832bf8    /* <+120>:   cmpb    r3,r4,r5           */
-	.long  0x7d4b662a    /* <+124>:   lwzcix  r10,r11,r12        */
-	.long  0xee119004    /* <+128>:   dadd    f16,f17,f18        */
-	.long  0xfe96c004    /* <+132>:   daddq   f20,f22,f24        */
-	.long  0x7c60066c    /* <+136>:   dss     3                  */
-	.long  0x7e00066c    /* <+140>:   dssall                     */
-	.long  0x7c2522ac    /* <+144>:   dst     r5,r4,1            */
-	.long  0x7e083aac    /* <+148>:   dstt    r8,r7,0            */
-	.long  0x7c6532ec    /* <+152>:   dstst   r5,r6,3            */
-	.long  0x7e442aec    /* <+156>:   dststt  r4,r5,2            */
-	.long  0x7d4b6356    /* <+160>:   divwe   r10,r11,r12        */
-	.long  0x7d6c6b57    /* <+164>:   divwe.  r11,r12,r13        */
-	.long  0x7d8d7756    /* <+168>:   divweo  r12,r13,r14        */
-	.long  0x7dae7f57    /* <+172>:   divweo. r13,r14,r15        */
-	.long  0x7d4b6316    /* <+176>:   divweu  r10,r11,r12        */
-	.long  0x7d6c6b17    /* <+180>:   divweu. r11,r12,r13        */
-	.long  0x7d8d7716    /* <+184>:   divweuo r12,r13,r14        */
-	.long  0x7dae7f17    /* <+188>:   divweuo. r13,r14,r15       */
-	.long  0x7e27d9f8    /* <+192>:   bpermd  r7,r17,r27         */
-	.long  0x7e8a02f4    /* <+196>:   popcntw r10,r20            */
-	.long  0x7e8a03f4    /* <+200>:   popcntd r10,r20            */
-	.long  0x7e95b428    /* <+204>:   ldbrx   r20,r21,r22        */
-	.long  0x7e95b528    /* <+208>:   stdbrx  r20,r21,r22        */
-	.long  0x7d4056ee    /* <+212>:   lfiwzx  f10,0,r10          */
-	.long  0x7d4956ee    /* <+216>:   lfiwzx  f10,r9,r10         */
-	.long  0xec802e9c    /* <+220>:   fcfids  f4,f5              */
-	.long  0xec802e9d    /* <+224>:   fcfids. f4,f5              */
-	.long  0xec802f9c    /* <+228>:   fcfidus f4,f5              */
-	.long  0xec802f9d    /* <+232>:   fcfidus. f4,f5             */
-	.long  0xfc80291c    /* <+236>:   fctiwu  f4,f5              */
-	.long  0xfc80291d    /* <+240>:   fctiwu. f4,f5              */
-	.long  0xfc80291e    /* <+244>:   fctiwuz f4,f5              */
-	.long  0xfc80291f    /* <+248>:   fctiwuz. f4,f5             */
-	.long  0xfc802f5c    /* <+252>:   fctidu  f4,f5              */
-	.long  0xfc802f5d    /* <+256>:   fctidu. f4,f5              */
-	.long  0xfc802f5e    /* <+260>:   fctiduz f4,f5              */
-	.long  0xfc802f5f    /* <+264>:   fctiduz. f4,f5             */
-	.long  0xfc802f9c    /* <+268>:   fcfidu  f4,f5              */
-	.long  0xfc802f9d    /* <+272>:   fcfidu. f4,f5              */
-	.long  0xfc0a5900    /* <+276>:   ftdiv   cr0,f10,f11        */
-	.long  0xff8a5900    /* <+280>:   ftdiv   cr7,f10,f11        */
-	.long  0xfc005140    /* <+284>:   ftsqrt  cr0,f10            */
-	.long  0xff805140    /* <+288>:   ftsqrt  cr7,f10            */
-	.long  0x7e084a2c    /* <+292>:   dcbtt   r8,r9              */
-	.long  0x7e0849ec    /* <+296>:   dcbtstt r8,r9              */
-	.long  0xed406644    /* <+300>:   dcffix  f10,f12            */
-	.long  0xee80b645    /* <+304>:   dcffix. f20,f22            */
-	.long  0xfdc07830    /* <+308>:   fre     f14,f15            */
-	.long  0xfdc07831    /* <+312>:   fre.    f14,f15            */
-	.long  0xedc07830    /* <+316>:   fres    f14,f15            */
-	.long  0xedc07831    /* <+320>:   fres.   f14,f15            */
-	.long  0xfdc07834    /* <+324>:   frsqrte f14,f15            */
-	.long  0xfdc07835    /* <+328>:   frsqrte. f14,f15           */
-	.long  0xedc07834    /* <+332>:   frsqrtes f14,f15           */
-	.long  0xedc07835    /* <+336>:   frsqrtes. f14,f15          */
-	.long  0x7c43271e    /* <+340>:   isel    r2,r3,r4,28        */
-	.long  0x7f7bdb78    /* <+344>:   yield                      */
-	.long  0x7f7bdb78    /* <+348>:   yield                      */
-	.long  0x60420000    /* <+352>:   ori     r2,r2,0            */
-	.long  0x60000000    /* <+356>:   nop                        */
-	.long  0x60000000    /* <+360>:   nop                        */
-	.long  0x60420000    /* <+364>:   ori     r2,r2,0            */
-	.long  0x7fbdeb78    /* <+368>:   mdoio                      */
-	.long  0x7fbdeb78    /* <+372>:   mdoio                      */
-	.long  0x7fdef378    /* <+376>:   mdoom                      */
-	.long  0x7fdef378    /* <+380>:   mdoom                      */
-	.long  0x7d40e2a6    /* <+384>:   mfppr   r10                */
-	.long  0x7d62e2a6    /* <+388>:   mfppr32 r11                */
-	.long  0x7d80e3a6    /* <+392>:   mtppr   r12                */
-	.long  0x7da2e3a6    /* <+396>:   mtppr32 r13                */
-	.long  0x7d605264    /* <+400>:   tlbie   r10,r11            */
-
-## altivec.d
-	.long  0x7c60066c    /* <+404>:   dss     3                  */
-	.long  0x7e00066c    /* <+408>:   dssall                     */
-	.long  0x7c2522ac    /* <+412>:   dst     r5,r4,1            */
-	.long  0x7e083aac    /* <+416>:   dstt    r8,r7,0            */
-	.long  0x7c6532ec    /* <+420>:   dstst   r5,r6,3            */
-	.long  0x7e442aec    /* <+424>:   dststt  r4,r5,2            */
-	.long  0x7fd6c00e    /* <+428>:   lvebx   v30,r22,r24        */
-	.long  0x7ea0c00e    /* <+432>:   lvebx   v21,0,r24          */
-	.long  0x7d50104e    /* <+436>:   lvehx   v10,r16,r2         */
-	.long  0x7e80b84e    /* <+440>:   lvehx   v20,0,r23          */
-	.long  0x7e24908e    /* <+444>:   lvewx   v17,r4,r18         */
-	.long  0x7ee0408e    /* <+448>:   lvewx   v23,0,r8           */
-	.long  0x7cc0c80c    /* <+452>:   lvsl    v6,0,r25           */
-	.long  0x7c40300c    /* <+456>:   lvsl    v2,0,r6            */
-	.long  0x7ed0604c    /* <+460>:   lvsr    v22,r16,r12        */
-	.long  0x7c00e84c    /* <+464>:   lvsr    v0,0,r29           */
-	.long  0x7de56ace    /* <+468>:   lvxl    v15,r5,r13         */
-	.long  0x7e60bace    /* <+472>:   lvxl    v19,0,r23          */
-	.long  0x7ec110ce    /* <+476>:   lvx     v22,r1,r2          */
-	.long  0x7e4088ce    /* <+480>:   lvx     v18,0,r17          */
-	.long  0x7fe042a6    /* <+484>:   mfvrsave r31               */
-	.long  0x13000604    /* <+488>:   mfvscr  v24                */
-	.long  0x7d4043a6    /* <+492>:   mtvrsave r10               */
-	.long  0x1000ce44    /* <+496>:   mtvscr  v25                */
-	.long  0x7e5b510e    /* <+500>:   stvebx  v18,r27,r10        */
-	.long  0x7e00310e    /* <+504>:   stvebx  v16,0,r6           */
-	.long  0x7e2d814e    /* <+508>:   stvehx  v17,r13,r16        */
-	.long  0x7ee0a14e    /* <+512>:   stvehx  v23,0,r20          */
-	.long  0x7d73f98e    /* <+516>:   stvewx  v11,r19,r31        */
-	.long  0x7fe0098e    /* <+520>:   stvewx  v31,0,r1           */
-	.long  0x7f558bce    /* <+524>:   stvxl   v26,r21,r17        */
-	.long  0x7da0b3ce    /* <+528>:   stvxl   v13,0,r22          */
-	.long  0x7d7ff9ce    /* <+532>:   stvx    v11,r31,r31        */
-	.long  0x7fc081ce    /* <+536>:   stvx    v30,0,r16          */
-	.long  0x1307e180    /* <+540>:   vaddcuw v24,v7,v28         */
-	.long  0x107e580a    /* <+544>:   vaddfp  v3,v30,v11         */
-	.long  0x111c4b00    /* <+548>:   vaddsbs v8,v28,v9          */
-	.long  0x10e52340    /* <+552>:   vaddshs v7,v5,v4           */
-	.long  0x12dadb80    /* <+556>:   vaddsws v22,v26,v27        */
-	.long  0x120ee000    /* <+560>:   vaddubm v16,v14,v28        */
-	.long  0x10c1ca00    /* <+564>:   vaddubs v6,v1,v25          */
-	.long  0x10443040    /* <+568>:   vadduhm v2,v4,v6           */
-	.long  0x13554240    /* <+572>:   vadduhs v26,v21,v8         */
-	.long  0x13bf0880    /* <+576>:   vadduwm v29,v31,v1         */
-	.long  0x12ed2280    /* <+580>:   vadduws v23,v13,v4         */
-	.long  0x13d04c44    /* <+584>:   vandc   v30,v16,v9         */
-	.long  0x106ddc04    /* <+588>:   vand    v3,v13,v27         */
-	.long  0x10868d02    /* <+592>:   vavgsb  v4,v6,v17          */
-	.long  0x12fc9d42    /* <+596>:   vavgsh  v23,v28,v19        */
-	.long  0x110ffd82    /* <+600>:   vavgsw  v8,v15,v31         */
-	.long  0x10c7cc02    /* <+604>:   vavgub  v6,v7,v25          */
-	.long  0x13365442    /* <+608>:   vavguh  v25,v22,v10        */
-	.long  0x1077ec82    /* <+612>:   vavguw  v3,v23,v29         */
-	.long  0x11c613ca    /* <+616>:   vctsxs  v14,v2,6           */
-	.long  0x1134fb8a    /* <+620>:   vctuxs  v9,v31,20          */
-	.long  0x1303f34a    /* <+624>:   vcfsx   v24,v30,3          */
-	.long  0x123dab0a    /* <+628>:   vcfux   v17,v21,29         */
-	.long  0x125c03c6    /* <+632>:   vcmpbfp v18,v28,v0         */
-	.long  0x127a1fc6    /* <+636>:   vcmpbfp. v19,v26,v3        */
-	.long  0x120258c6    /* <+640>:   vcmpeqfp v16,v2,v11        */
-	.long  0x12ed6cc6    /* <+644>:   vcmpeqfp. v23,v13,v13      */
-	.long  0x13335006    /* <+648>:   vcmpequb v25,v19,v10       */
-	.long  0x124b1406    /* <+652>:   vcmpequb. v18,v11,v2       */
-	.long  0x11393846    /* <+656>:   vcmpequh v9,v25,v7         */
-	.long  0x11d8ac46    /* <+660>:   vcmpequh. v14,v24,v21      */
-	.long  0x130c2886    /* <+664>:   vcmpequw v24,v12,v5        */
-	.long  0x12700c86    /* <+668>:   vcmpequw. v19,v16,v1       */
-	.long  0x12f181c6    /* <+672>:   vcmpgefp v23,v17,v16       */
-	.long  0x127d8dc6    /* <+676>:   vcmpgefp. v19,v29,v17      */
-	.long  0x121c6ac6    /* <+680>:   vcmpgtfp v16,v28,v13       */
-	.long  0x11d83ec6    /* <+684>:   vcmpgtfp. v14,v24,v7       */
-	.long  0x12163306    /* <+688>:   vcmpgtsb v16,v22,v6        */
-	.long  0x104c7706    /* <+692>:   vcmpgtsb. v2,v12,v14       */
-	.long  0x1383eb46    /* <+696>:   vcmpgtsh v28,v3,v29        */
-	.long  0x12136f46    /* <+700>:   vcmpgtsh. v16,v19,v13      */
-	.long  0x11e02b86    /* <+704>:   vcmpgtsw v15,v0,v5         */
-	.long  0x12ad0786    /* <+708>:   vcmpgtsw. v21,v13,v0       */
-	.long  0x10aaf206    /* <+712>:   vcmpgtub v5,v10,v30        */
-	.long  0x10ed5606    /* <+716>:   vcmpgtub. v7,v13,v10       */
-	.long  0x130f8246    /* <+720>:   vcmpgtuh v24,v15,v16       */
-	.long  0x1335de46    /* <+724>:   vcmpgtuh. v25,v21,v27      */
-	.long  0x123b3286    /* <+728>:   vcmpgtuw v17,v27,v6        */
-	.long  0x1115de86    /* <+732>:   vcmpgtuw. v8,v21,v27       */
-	.long  0x102e0b4a    /* <+736>:   vcfsx   v1,v1,14           */
-	.long  0x10997bca    /* <+740>:   vctsxs  v4,v15,25          */
-	.long  0x138ebb8a    /* <+744>:   vctuxs  v28,v23,14         */
-	.long  0x10c0330a    /* <+748>:   vcfux   v6,v6,0            */
-	.long  0x1000418a    /* <+752>:   vexptefp v0,v8             */
-	.long  0x12c0d9ca    /* <+756>:   vlogefp v22,v27            */
-	.long  0x12f2916e    /* <+760>:   vmaddfp v23,v18,v5,v18     */
-	.long  0x11addc0a    /* <+764>:   vmaxfp  v13,v13,v27        */
-	.long  0x11177102    /* <+768>:   vmaxsb  v8,v23,v14         */
-	.long  0x12710142    /* <+772>:   vmaxsh  v19,v17,v0         */
-	.long  0x1263b182    /* <+776>:   vmaxsw  v19,v3,v22         */
-	.long  0x12fee002    /* <+780>:   vmaxub  v23,v30,v28        */
-	.long  0x1134b842    /* <+784>:   vmaxuh  v9,v20,v23         */
-	.long  0x12b30882    /* <+788>:   vmaxuw  v21,v19,v1         */
-	.long  0x12cd2da0    /* <+792>:   vmhaddshs v22,v13,v5,v22   */
-	.long  0x13e01ca1    /* <+796>:   vmhraddshs v31,v0,v3,v18   */
-	.long  0x1055c44a    /* <+800>:   vminfp  v2,v21,v24         */
-	.long  0x12865302    /* <+804>:   vminsb  v20,v6,v10         */
-	.long  0x125bd342    /* <+808>:   vminsh  v18,v27,v26        */
-	.long  0x10640b82    /* <+812>:   vminsw  v3,v4,v1           */
-	.long  0x10e06a02    /* <+816>:   vminub  v7,v0,v13          */
-	.long  0x100c3242    /* <+820>:   vminuh  v0,v12,v6          */
-	.long  0x10c30a82    /* <+824>:   vminuw  v6,v3,v1           */
-	.long  0x107d1ea2    /* <+828>:   vmladduhm v3,v29,v3,v26    */
-	.long  0x12a5f80c    /* <+832>:   vmrghb  v21,v5,v31         */
-	.long  0x12b8004c    /* <+836>:   vmrghh  v21,v24,v0         */
-	.long  0x1200b08c    /* <+840>:   vmrghw  v16,v0,v22         */
-	.long  0x1031810c    /* <+844>:   vmrglb  v1,v17,v16         */
-	.long  0x11c8794c    /* <+848>:   vmrglh  v14,v8,v15         */
-	.long  0x13f5298c    /* <+852>:   vmrglw  v31,v21,v5         */
-	.long  0x13094c84    /* <+856>:   vmr     v24,v9             */
-	.long  0x13094c84    /* <+860>:   vmr     v24,v9             */
-	.long  0x10187de5    /* <+864>:   vmsummbm v0,v24,v15,v23    */
-	.long  0x10243e68    /* <+868>:   vmsumshm v1,v4,v7,v25      */
-	.long  0x11286fe9    /* <+872>:   vmsumshs v9,v8,v13,v31     */
-	.long  0x12ff67a4    /* <+876>:   vmsumubm v23,v31,v12,v30   */
-	.long  0x13a0d566    /* <+880>:   vmsumuhm v29,v0,v26,v21    */
-	.long  0x136ec967    /* <+884>:   vmsumuhs v27,v14,v25,v5    */
-	.long  0x11597308    /* <+888>:   vmulesb v10,v25,v14        */
-	.long  0x10324348    /* <+892>:   vmulesh v1,v18,v8          */
-	.long  0x122e4a08    /* <+896>:   vmuleub v17,v14,v9         */
-	.long  0x10ba4a48    /* <+900>:   vmuleuh v5,v26,v9          */
-	.long  0x12b23108    /* <+904>:   vmulosb v21,v18,v6         */
-	.long  0x10854148    /* <+908>:   vmulosh v4,v5,v8           */
-	.long  0x10499808    /* <+912>:   vmuloub v2,v9,v19          */
-	.long  0x13a52048    /* <+916>:   vmulouh v29,v5,v4          */
-	.long  0x110229af    /* <+920>:   vnmsubfp v8,v2,v6,v5       */
-	.long  0x13e95504    /* <+924>:   vnor    v31,v9,v10         */
-	.long  0x133ffd04    /* <+928>:   vnot    v25,v31            */
-	.long  0x133ffd04    /* <+932>:   vnot    v25,v31            */
-	.long  0x12e71484    /* <+936>:   vor     v23,v7,v2          */
-	.long  0x101cb66b    /* <+940>:   vperm   v0,v28,v22,v25     */
-	.long  0x12198b0e    /* <+944>:   vpkpx   v16,v25,v17        */
-	.long  0x1190898e    /* <+948>:   vpkshss v12,v16,v17        */
-	.long  0x1033b90e    /* <+952>:   vpkshus v1,v19,v23         */
-	.long  0x132769ce    /* <+956>:   vpkswss v25,v7,v13         */
-	.long  0x1098514e    /* <+960>:   vpkswus v4,v24,v10         */
-	.long  0x113b600e    /* <+964>:   vpkuhum v9,v27,v12         */
-	.long  0x12cac88e    /* <+968>:   vpkuhus v22,v10,v25        */
-	.long  0x13d2004e    /* <+972>:   vpkuwum v30,v18,v0         */
-	.long  0x10e3b0ce    /* <+976>:   vpkuwus v7,v3,v22          */
-	.long  0x1300e10a    /* <+980>:   vrefp   v24,v28            */
-	.long  0x12209aca    /* <+984>:   vrfim   v17,v19            */
-	.long  0x1300ca0a    /* <+988>:   vrfin   v24,v25            */
-	.long  0x10602a8a    /* <+992>:   vrfip   v3,v5              */
-	.long  0x1100524a    /* <+996>:   vrfiz   v8,v10             */
-	.long  0x1352f004    /* <+1000>:  vrlb    v26,v18,v30        */
-	.long  0x1211c844    /* <+1004>:  vrlh    v16,v17,v25        */
-	.long  0x12fe4884    /* <+1008>:  vrlw    v23,v30,v9         */
-	.long  0x1040914a    /* <+1012>:  vrsqrtefp v2,v18           */
-	.long  0x128e92aa    /* <+1016>:  vsel    v20,v14,v18,v10    */
-	.long  0x13396104    /* <+1020>:  vslb    v25,v25,v12        */
-	.long  0x112961ec    /* <+1024>:  vsldoi  v9,v9,v12,7        */
-	.long  0x11c25944    /* <+1028>:  vslh    v14,v2,v11         */
-	.long  0x13c5340c    /* <+1032>:  vslo    v30,v5,v6          */
-	.long  0x12de49c4    /* <+1036>:  vsl     v22,v30,v9         */
-	.long  0x135a1984    /* <+1040>:  vslw    v26,v26,v3         */
-	.long  0x1026a20c    /* <+1044>:  vspltb  v1,v20,6           */
-	.long  0x1203924c    /* <+1048>:  vsplth  v16,v18,3          */
-	.long  0x1333030c    /* <+1052>:  vspltisb v25,-13           */
-	.long  0x12ca034c    /* <+1056>:  vspltish v22,10            */
-	.long  0x11ad038c    /* <+1060>:  vspltisw v13,13            */
-	.long  0x1122928c    /* <+1064>:  vspltw  v9,v18,2           */
-	.long  0x11d60304    /* <+1068>:  vsrab   v14,v22,v0         */
-	.long  0x118c9344    /* <+1072>:  vsrah   v12,v12,v18        */
-	.long  0x10426b84    /* <+1076>:  vsraw   v2,v2,v13          */
-	.long  0x10fb2a04    /* <+1080>:  vsrb    v7,v27,v5          */
-	.long  0x10ebea44    /* <+1084>:  vsrh    v7,v11,v29         */
-	.long  0x125efc4c    /* <+1088>:  vsro    v18,v30,v31        */
-	.long  0x1049e2c4    /* <+1092>:  vsr     v2,v9,v28          */
-	.long  0x10190284    /* <+1096>:  vsrw    v0,v25,v0          */
-	.long  0x13025580    /* <+1100>:  vsubcuw v24,v2,v10         */
-	.long  0x12d8a04a    /* <+1104>:  vsubfp  v22,v24,v20        */
-	.long  0x11566f00    /* <+1108>:  vsubsbs v10,v22,v13        */
-	.long  0x1311e740    /* <+1112>:  vsubshs v24,v17,v28        */
-	.long  0x115a0780    /* <+1116>:  vsubsws v10,v26,v0         */
-	.long  0x120bc400    /* <+1120>:  vsububm v16,v11,v24        */
-	.long  0x11750e00    /* <+1124>:  vsububs v11,v21,v1         */
-	.long  0x10ccc440    /* <+1128>:  vsubuhm v6,v12,v24         */
-	.long  0x13cb4e40    /* <+1132>:  vsubuhs v30,v11,v9         */
-	.long  0x12746c80    /* <+1136>:  vsubuwm v19,v20,v13        */
-	.long  0x12593680    /* <+1140>:  vsubuws v18,v25,v6         */
-	.long  0x132a9688    /* <+1144>:  vsum2sws v25,v10,v18       */
-	.long  0x11b0af08    /* <+1148>:  vsum4sbs v13,v16,v21       */
-	.long  0x12e82648    /* <+1152>:  vsum4shs v23,v8,v4         */
-	.long  0x138df608    /* <+1156>:  vsum4ubs v28,v13,v30       */
-	.long  0x12ca4788    /* <+1160>:  vsumsws v22,v10,v8         */
-	.long  0x1300734e    /* <+1164>:  vupkhpx v24,v14            */
-	.long  0x1040b20e    /* <+1168>:  vupkhsb v2,v22             */
-	.long  0x1200124e    /* <+1172>:  vupkhsh v16,v2             */
-	.long  0x1140d3ce    /* <+1176>:  vupklpx v10,v26            */
-	.long  0x11e0e28e    /* <+1180>:  vupklsb v15,v28            */
-	.long  0x110042ce    /* <+1184>:  vupklsh v8,v8              */
-	.long  0x13201cc4    /* <+1188>:  vxor    v25,v0,v3          */
-
-## vsd.d
-	.long  0x7d0aa499    /* <+1192>:  lxsdx   vs40,r10,r20       */
-	.long  0x7d0aa699    /* <+1196>:  lxvd2x  vs40,r10,r20       */
-	.long  0x7d0aa299    /* <+1200>:  lxvdsx  vs40,r10,r20       */
-	.long  0x7d0aa619    /* <+1204>:  lxvw4x  vs40,r10,r20       */
-	.long  0x7d0aa599    /* <+1208>:  stxsdx  vs40,r10,r20       */
-	.long  0x7d0aa799    /* <+1212>:  stxvd2x vs40,r10,r20       */
-	.long  0x7d0aa719    /* <+1216>:  stxvw4x vs40,r10,r20       */
-	.long  0xf100e567    /* <+1220>:  xsabsdp vs40,vs60          */
-	.long  0xf112e107    /* <+1224>:  xsadddp vs40,vs50,vs60     */
-	.long  0xf092e15e    /* <+1228>:  xscmpodp cr1,vs50,vs60     */
-	.long  0xf092e11e    /* <+1232>:  xscmpudp cr1,vs50,vs60     */
-	.long  0xf112e587    /* <+1236>:  xscpsgndp vs40,vs50,vs60   */
-	.long  0xf100e427    /* <+1240>:  xscvdpsp vs40,vs60         */
-	.long  0xf100e563    /* <+1244>:  xscvdpsxds vs40,vs60       */
-	.long  0xf100e163    /* <+1248>:  xscvdpsxws vs40,vs60       */
-	.long  0xf100e523    /* <+1252>:  xscvdpuxds vs40,vs60       */
-	.long  0xf100e123    /* <+1256>:  xscvdpuxws vs40,vs60       */
-	.long  0xf100e527    /* <+1260>:  xscvspdp vs40,vs60         */
-	.long  0xf100e5e3    /* <+1264>:  xscvsxddp vs40,vs60        */
-	.long  0xf100e5a3    /* <+1268>:  xscvuxddp vs40,vs60        */
-	.long  0xf112e1c7    /* <+1272>:  xsdivdp vs40,vs50,vs60     */
-	.long  0xf112e10f    /* <+1276>:  xsmaddadp vs40,vs50,vs60   */
-	.long  0xf112e14f    /* <+1280>:  xsmaddmdp vs40,vs50,vs60   */
-	.long  0xf112e507    /* <+1284>:  xsmaxdp vs40,vs50,vs60     */
-	.long  0xf112e547    /* <+1288>:  xsmindp vs40,vs50,vs60     */
-	.long  0xf112e18f    /* <+1292>:  xsmsubadp vs40,vs50,vs60   */
-	.long  0xf112e1cf    /* <+1296>:  xsmsubmdp vs40,vs50,vs60   */
-	.long  0xf112e187    /* <+1300>:  xsmuldp vs40,vs50,vs60     */
-	.long  0xf100e5a7    /* <+1304>:  xsnabsdp vs40,vs60         */
-	.long  0xf100e5e7    /* <+1308>:  xsnegdp vs40,vs60          */
-	.long  0xf112e50f    /* <+1312>:  xsnmaddadp vs40,vs50,vs60  */
-	.long  0xf112e54f    /* <+1316>:  xsnmaddmdp vs40,vs50,vs60  */
-	.long  0xf112e58f    /* <+1320>:  xsnmsubadp vs40,vs50,vs60  */
-	.long  0xf112e5cf    /* <+1324>:  xsnmsubmdp vs40,vs50,vs60  */
-	.long  0xf100e127    /* <+1328>:  xsrdpi  vs40,vs60          */
-	.long  0xf100e1af    /* <+1332>:  xsrdpic vs40,vs60          */
-	.long  0xf100e1e7    /* <+1336>:  xsrdpim vs40,vs60          */
-	.long  0xf100e1a7    /* <+1340>:  xsrdpip vs40,vs60          */
-	.long  0xf100e167    /* <+1344>:  xsrdpiz vs40,vs60          */
-	.long  0xf100e16b    /* <+1348>:  xsredp  vs40,vs60          */
-	.long  0xf100e12b    /* <+1352>:  xsrsqrtedp vs40,vs60       */
-	.long  0xf100e12f    /* <+1356>:  xssqrtdp vs40,vs60         */
-	.long  0xf112e147    /* <+1360>:  xssubdp vs40,vs50,vs60     */
-	.long  0xf092e1ee    /* <+1364>:  xstdivdp cr1,vs50,vs60     */
-	.long  0xf080e1aa    /* <+1368>:  xstsqrtdp cr1,vs60         */
-	.long  0xf100e767    /* <+1372>:  xvabsdp vs40,vs60          */
-	.long  0xf100e667    /* <+1376>:  xvabssp vs40,vs60          */
-	.long  0xf112e307    /* <+1380>:  xvadddp vs40,vs50,vs60     */
-	.long  0xf112e207    /* <+1384>:  xvaddsp vs40,vs50,vs60     */
-	.long  0xf112e31f    /* <+1388>:  xvcmpeqdp vs40,vs50,vs60   */
-	.long  0xf112e71f    /* <+1392>:  xvcmpeqdp. vs40,vs50,vs60  */
-	.long  0xf112e21f    /* <+1396>:  xvcmpeqsp vs40,vs50,vs60   */
-	.long  0xf112e61f    /* <+1400>:  xvcmpeqsp. vs40,vs50,vs60  */
-	.long  0xf112e39f    /* <+1404>:  xvcmpgedp vs40,vs50,vs60   */
-	.long  0xf112e79f    /* <+1408>:  xvcmpgedp. vs40,vs50,vs60  */
-	.long  0xf112e29f    /* <+1412>:  xvcmpgesp vs40,vs50,vs60   */
-	.long  0xf112e69f    /* <+1416>:  xvcmpgesp. vs40,vs50,vs60  */
-	.long  0xf112e35f    /* <+1420>:  xvcmpgtdp vs40,vs50,vs60   */
-	.long  0xf112e75f    /* <+1424>:  xvcmpgtdp. vs40,vs50,vs60  */
-	.long  0xf112e25f    /* <+1428>:  xvcmpgtsp vs40,vs50,vs60   */
-	.long  0xf112e65f    /* <+1432>:  xvcmpgtsp. vs40,vs50,vs60  */
-	.long  0xf112e787    /* <+1436>:  xvcpsgndp vs40,vs50,vs60   */
-	.long  0xf11ce787    /* <+1440>:  xvmovdp vs40,vs60          */
-	.long  0xf11ce787    /* <+1444>:  xvmovdp vs40,vs60          */
-	.long  0xf112e687    /* <+1448>:  xvcpsgnsp vs40,vs50,vs60   */
-	.long  0xf11ce687    /* <+1452>:  xvmovsp vs40,vs60          */
-	.long  0xf11ce687    /* <+1456>:  xvmovsp vs40,vs60          */
-	.long  0xf100e627    /* <+1460>:  xvcvdpsp vs40,vs60         */
-	.long  0xf100e763    /* <+1464>:  xvcvdpsxds vs40,vs60       */
-	.long  0xf100e363    /* <+1468>:  xvcvdpsxws vs40,vs60       */
-	.long  0xf100e723    /* <+1472>:  xvcvdpuxds vs40,vs60       */
-	.long  0xf100e323    /* <+1476>:  xvcvdpuxws vs40,vs60       */
-	.long  0xf100e727    /* <+1480>:  xvcvspdp vs40,vs60         */
-	.long  0xf100e663    /* <+1484>:  xvcvspsxds vs40,vs60       */
-	.long  0xf100e263    /* <+1488>:  xvcvspsxws vs40,vs60       */
-	.long  0xf100e623    /* <+1492>:  xvcvspuxds vs40,vs60       */
-	.long  0xf100e223    /* <+1496>:  xvcvspuxws vs40,vs60       */
-	.long  0xf100e7e3    /* <+1500>:  xvcvsxddp vs40,vs60        */
-	.long  0xf100e6e3    /* <+1504>:  xvcvsxdsp vs40,vs60        */
-	.long  0xf100e3e3    /* <+1508>:  xvcvsxwdp vs40,vs60        */
-	.long  0xf100e2e3    /* <+1512>:  xvcvsxwsp vs40,vs60        */
-	.long  0xf100e7a3    /* <+1516>:  xvcvuxddp vs40,vs60        */
-	.long  0xf100e6a3    /* <+1520>:  xvcvuxdsp vs40,vs60        */
-	.long  0xf100e3a3    /* <+1524>:  xvcvuxwdp vs40,vs60        */
-	.long  0xf100e2a3    /* <+1528>:  xvcvuxwsp vs40,vs60        */
-	.long  0xf112e3c7    /* <+1532>:  xvdivdp vs40,vs50,vs60     */
-	.long  0xf112e2c7    /* <+1536>:  xvdivsp vs40,vs50,vs60     */
-	.long  0xf112e30f    /* <+1540>:  xvmaddadp vs40,vs50,vs60   */
-	.long  0xf112e34f    /* <+1544>:  xvmaddmdp vs40,vs50,vs60   */
-	.long  0xf112e20f    /* <+1548>:  xvmaddasp vs40,vs50,vs60   */
-	.long  0xf112e24f    /* <+1552>:  xvmaddmsp vs40,vs50,vs60   */
-	.long  0xf112e707    /* <+1556>:  xvmaxdp vs40,vs50,vs60     */
-	.long  0xf112e607    /* <+1560>:  xvmaxsp vs40,vs50,vs60     */
-	.long  0xf112e747    /* <+1564>:  xvmindp vs40,vs50,vs60     */
-	.long  0xf112e647    /* <+1568>:  xvminsp vs40,vs50,vs60     */
-	.long  0xf112e38f    /* <+1572>:  xvmsubadp vs40,vs50,vs60   */
-	.long  0xf112e3cf    /* <+1576>:  xvmsubmdp vs40,vs50,vs60   */
-	.long  0xf112e28f    /* <+1580>:  xvmsubasp vs40,vs50,vs60   */
-	.long  0xf112e2cf    /* <+1584>:  xvmsubmsp vs40,vs50,vs60   */
-	.long  0xf112e387    /* <+1588>:  xvmuldp vs40,vs50,vs60     */
-	.long  0xf112e287    /* <+1592>:  xvmulsp vs40,vs50,vs60     */
-	.long  0xf100e7a7    /* <+1596>:  xvnabsdp vs40,vs60         */
-	.long  0xf100e6a7    /* <+1600>:  xvnabssp vs40,vs60         */
-	.long  0xf100e7e7    /* <+1604>:  xvnegdp vs40,vs60          */
-	.long  0xf100e6e7    /* <+1608>:  xvnegsp vs40,vs60          */
-	.long  0xf112e70f    /* <+1612>:  xvnmaddadp vs40,vs50,vs60  */
-	.long  0xf112e74f    /* <+1616>:  xvnmaddmdp vs40,vs50,vs60  */
-	.long  0xf112e60f    /* <+1620>:  xvnmaddasp vs40,vs50,vs60  */
-	.long  0xf112e64f    /* <+1624>:  xvnmaddmsp vs40,vs50,vs60  */
-	.long  0xf112e78f    /* <+1628>:  xvnmsubadp vs40,vs50,vs60  */
-	.long  0xf112e7cf    /* <+1632>:  xvnmsubmdp vs40,vs50,vs60  */
-	.long  0xf112e68f    /* <+1636>:  xvnmsubasp vs40,vs50,vs60  */
-	.long  0xf112e6cf    /* <+1640>:  xvnmsubmsp vs40,vs50,vs60  */
-	.long  0xf100e327    /* <+1644>:  xvrdpi  vs40,vs60          */
-	.long  0xf100e3af    /* <+1648>:  xvrdpic vs40,vs60          */
-	.long  0xf100e3e7    /* <+1652>:  xvrdpim vs40,vs60          */
-	.long  0xf100e3a7    /* <+1656>:  xvrdpip vs40,vs60          */
-	.long  0xf100e367    /* <+1660>:  xvrdpiz vs40,vs60          */
-	.long  0xf100e36b    /* <+1664>:  xvredp  vs40,vs60          */
-	.long  0xf100e26b    /* <+1668>:  xvresp  vs40,vs60          */
-	.long  0xf100e227    /* <+1672>:  xvrspi  vs40,vs60          */
-	.long  0xf100e2af    /* <+1676>:  xvrspic vs40,vs60          */
-	.long  0xf100e2e7    /* <+1680>:  xvrspim vs40,vs60          */
-	.long  0xf100e2a7    /* <+1684>:  xvrspip vs40,vs60          */
-	.long  0xf100e267    /* <+1688>:  xvrspiz vs40,vs60          */
-	.long  0xf100e32b    /* <+1692>:  xvrsqrtedp vs40,vs60       */
-	.long  0xf100e22b    /* <+1696>:  xvrsqrtesp vs40,vs60       */
-	.long  0xf100e32f    /* <+1700>:  xvsqrtdp vs40,vs60         */
-	.long  0xf100e22f    /* <+1704>:  xvsqrtsp vs40,vs60         */
-	.long  0xf112e347    /* <+1708>:  xvsubdp vs40,vs50,vs60     */
-	.long  0xf112e247    /* <+1712>:  xvsubsp vs40,vs50,vs60     */
-	.long  0xf092e3ee    /* <+1716>:  xvtdivdp cr1,vs50,vs60     */
-	.long  0xf092e2ee    /* <+1720>:  xvtdivsp cr1,vs50,vs60     */
-	.long  0xf080e3aa    /* <+1724>:  xvtsqrtdp cr1,vs60         */
-	.long  0xf080e2aa    /* <+1728>:  xvtsqrtsp cr1,vs60         */
-	.long  0xf112e417    /* <+1732>:  xxland  vs40,vs50,vs60     */
-	.long  0xf112e457    /* <+1736>:  xxlandc vs40,vs50,vs60     */
-	.long  0xf112e517    /* <+1740>:  xxlnor  vs40,vs50,vs60     */
-	.long  0xf112e497    /* <+1744>:  xxlor   vs40,vs50,vs60     */
-	.long  0xf112e4d7    /* <+1748>:  xxlxor  vs40,vs50,vs60     */
-	.long  0xf112e097    /* <+1752>:  xxmrghw vs40,vs50,vs60     */
-	.long  0xf112e197    /* <+1756>:  xxmrglw vs40,vs50,vs60     */
-	.long  0xf112e057    /* <+1760>:  xxmrghd vs40,vs50,vs60     */
-	.long  0xf112e157    /* <+1764>:  xxpermdi vs40,vs50,vs60,1  */
-	.long  0xf112e257    /* <+1768>:  xxpermdi vs40,vs50,vs60,2  */
-	.long  0xf112e357    /* <+1772>:  xxmrgld vs40,vs50,vs60     */
-	.long  0xf1129057    /* <+1776>:  xxspltd vs40,vs50,0        */
-	.long  0xf1129057    /* <+1780>:  xxspltd vs40,vs50,0        */
-	.long  0xf1129357    /* <+1784>:  xxspltd vs40,vs50,1        */
-	.long  0xf1129357    /* <+1788>:  xxspltd vs40,vs50,1        */
-	.long  0xf112e057    /* <+1792>:  xxmrghd vs40,vs50,vs60     */
-	.long  0xf112e057    /* <+1796>:  xxmrghd vs40,vs50,vs60     */
-	.long  0xf112e357    /* <+1800>:  xxmrgld vs40,vs50,vs60     */
-	.long  0xf1129257    /* <+1804>:  xxswapd vs40,vs50          */
-	.long  0xf1129257    /* <+1808>:  xxswapd vs40,vs50          */
-	.long  0xf112e7bf    /* <+1812>:  xxsel   vs40,vs50,vs60,vs62*/
-	.long  0xf112e217    /* <+1816>:  xxsldwi vs40,vs50,vs60,2   */
-	.long  0xf102e293    /* <+1820>:  xxspltw vs40,vs60,2        */
-	.long  0x7d00a699    /* <+1824>:  lxvd2x  vs40,0,r20         */
-	.long  0x7d0aa699    /* <+1828>:  lxvd2x  vs40,r10,r20       */
-	.long  0x7d00a799    /* <+1832>:  stxvd2x vs40,0,r20         */
-	.long  0x7d0aa799    /* <+1836>:  stxvd2x vs40,r10,r20       */
-
-## power8.d
-	.long  0x7c05071d    /* <+1840>:  tabort. r5                 */
-	.long  0x7ce8861d    /* <+1844>:  tabortwc. 7,r8,r16         */
-	.long  0x7e8b565d    /* <+1848>:  tabortdc. 20,r11,r10       */
-	.long  0x7e2a9e9d    /* <+1852>:  tabortwci. 17,r10,-13      */
-	.long  0x7fa3dedd    /* <+1856>:  tabortdci. 29,r3,-5        */
-	.long  0x7c00051d    /* <+1860>:  tbegin.                    */
-	.long  0x7f80059c    /* <+1864>:  tcheck  cr7                */
-	.long  0x7c00055d    /* <+1868>:  tend.                      */
-	.long  0x7c00055d    /* <+1872>:  tend.                      */
-	.long  0x7e00055d    /* <+1876>:  tendall.                   */
-	.long  0x7e00055d    /* <+1880>:  tendall.                   */
-	.long  0x7c18075d    /* <+1884>:  treclaim. r24              */
-	.long  0x7c0007dd    /* <+1888>:  trechkpt.                  */
-	.long  0x7c0005dd    /* <+1892>:  tsuspend.                  */
-	.long  0x7c0005dd    /* <+1896>:  tsuspend.                  */
-	.long  0x7c2005dd    /* <+1900>:  tresume.                   */
-	.long  0x7c2005dd    /* <+1904>:  tresume.                   */
-	.long  0x60420000    /* <+1908>:  ori     r2,r2,0            */
-	.long  0x60000000    /* <+1912>:  nop                        */
-	.long  0x60420000    /* <+1916>:  ori     r2,r2,0            */
-	.long  0x4c000124    /* <+1920>:  rfebb   0                  */
-	.long  0x4c000924    /* <+1924>:  rfebb                      */
-	.long  0x4c000924    /* <+1928>:  rfebb                      */
-	.long  0x4d950460    /* <+1932>:  bctar-  12,4*cr5+gt        */
-	.long  0x4c870461    /* <+1936>:  bctarl- 4,4*cr1+so         */
-	.long  0x4dac0460    /* <+1940>:  bctar+  12,4*cr3+lt        */
-	.long  0x4ca20461    /* <+1944>:  bctarl+ 4,eq               */
-	.long  0x4c880c60    /* <+1948>:  bctar   4,4*cr2+lt,1       */
-	.long  0x4c871461    /* <+1952>:  bctarl  4,4*cr1+so,2       */
-	.long  0x7c00003c    /* <+1956>:  waitasec                   */
-	.long  0x7c00411c    /* <+1960>:  msgsndp r8                 */
-	.long  0x7c200126    /* <+1964>:  mtsle   1                  */
-	.long  0x7c00d95c    /* <+1968>:  msgclrp r27                */
-	.long  0x7d4a616d    /* <+1972>:  stqcx.  r10,r10,r12        */
-	.long  0x7f80396d    /* <+1976>:  stqcx.  r28,0,r7           */
-	.long  0x7f135a28    /* <+1980>:  lqarx   r24,r19,r11        */
-	.long  0x7ec05a28    /* <+1984>:  lqarx   r22,0,r11          */
-	.long  0x7e80325c    /* <+1988>:  mfbhrbe r20,6              */
-	.long  0x7fb18329    /* <+1992>:  pbt.    r29,r17,r16        */
-	.long  0x7dc03b29    /* <+1996>:  pbt.    r14,0,r7           */
-	.long  0x7c00035c    /* <+2000>:  clrbhrb                    */
-	.long  0x116a05ed    /* <+2004>:  vpermxor v11,v10,v0,v23    */
-	.long  0x1302393c    /* <+2008>:  vaddeuqm v24,v2,v7,v4      */
-	.long  0x114a40bd    /* <+2012>:  vaddecuq v10,v10,v8,v2     */
-	.long  0x10af44fe    /* <+2016>:  vsubeuqm v5,v15,v8,v19     */
-	.long  0x119f877f    /* <+2020>:  vsubecuq v12,v31,v16,v29   */
-	.long  0x129d6888    /* <+2024>:  vmulouw v20,v29,v13        */
-	.long  0x13a0d089    /* <+2028>:  vmuluwm v29,v0,v26         */
-	.long  0x1115e0c0    /* <+2032>:  vaddudm v8,v21,v28         */
-	.long  0x103a08c2    /* <+2036>:  vmaxud  v1,v26,v1          */
-	.long  0x128308c4    /* <+2040>:  vrld    v20,v3,v1          */
-	.long  0x109358c7    /* <+2044>:  vcmpequd v4,v19,v11        */
-	.long  0x12eef100    /* <+2048>:  vadduqm v23,v14,v30        */
-	.long  0x11086940    /* <+2052>:  vaddcuq v8,v8,v13          */
-	.long  0x139b2188    /* <+2056>:  vmulosw v28,v27,v4         */
-	.long  0x106421c2    /* <+2060>:  vmaxsd  v3,v4,v4           */
-	.long  0x1013aa88    /* <+2064>:  vmuleuw v0,v19,v21         */
-	.long  0x13149ac2    /* <+2068>:  vminud  v24,v20,v19        */
-	.long  0x101c7ac7    /* <+2072>:  vcmpgtud v0,v28,v15        */
-	.long  0x12a01388    /* <+2076>:  vmulesw v21,v0,v2          */
-	.long  0x113a4bc2    /* <+2080>:  vminsd  v9,v26,v9          */
-	.long  0x133d5bc4    /* <+2084>:  vsrad   v25,v29,v11        */
-	.long  0x117c5bc7    /* <+2088>:  vcmpgtsd v11,v28,v11       */
-	.long  0x10a8d601    /* <+2092>:  bcdadd. v5,v8,v26,1        */
-	.long  0x10836408    /* <+2096>:  vpmsumb v4,v3,v12          */
-	.long  0x135fae41    /* <+2100>:  bcdsub. v26,v31,v21,1      */
-	.long  0x10b18448    /* <+2104>:  vpmsumh v5,v17,v16         */
-	.long  0x12f1a44e    /* <+2108>:  vpkudum v23,v17,v20        */
-	.long  0x1315ec88    /* <+2112>:  vpmsumw v24,v21,v29        */
-	.long  0x11366cc8    /* <+2116>:  vpmsumd v9,v22,v13         */
-	.long  0x125394ce    /* <+2120>:  vpkudus v18,v19,v18        */
-	.long  0x13d0b500    /* <+2124>:  vsubuqm v30,v16,v22        */
-	.long  0x11cb3d08    /* <+2128>:  vcipher v14,v11,v7         */
-	.long  0x1142b509    /* <+2132>:  vcipherlast v10,v2,v22     */
-	.long  0x12e06d0c    /* <+2136>:  vgbbd   v23,v13            */
-	.long  0x12198540    /* <+2140>:  vsubcuq v16,v25,v16        */
-	.long  0x13e12d44    /* <+2144>:  vorc    v31,v1,v5          */
-	.long  0x1091fd48    /* <+2148>:  vncipher v4,v17,v31        */
-	.long  0x1302dd49    /* <+2152>:  vncipherlast v24,v2,v27    */
-	.long  0x12f5bd4c    /* <+2156>:  vbpermq v23,v21,v23        */
-	.long  0x13724d4e    /* <+2160>:  vpksdus v27,v18,v9         */
-	.long  0x137ddd84    /* <+2164>:  vnand   v27,v29,v27        */
-	.long  0x1273c5c4    /* <+2168>:  vsld    v19,v19,v24        */
-	.long  0x10ad05c8    /* <+2172>:  vsbox   v5,v13             */
-	.long  0x13233dce    /* <+2176>:  vpksdss v25,v3,v7          */
-	.long  0x138804c7    /* <+2180>:  vcmpequd. v28,v8,v0        */
-	.long  0x1340d64e    /* <+2184>:  vupkhsw v26,v26            */
-	.long  0x10a73682    /* <+2188>:  vshasigmaw v5,v7,0,6       */
-	.long  0x13957684    /* <+2192>:  veqv    v28,v21,v14        */
-	.long  0x10289e8c    /* <+2196>:  vmrgow  v1,v8,v19          */
-	.long  0x100a56c2    /* <+2200>:  vshasigmad v0,v10,0,10     */
-	.long  0x10bb76c4    /* <+2204>:  vsrd    v5,v27,v14         */
-	.long  0x11606ece    /* <+2208>:  vupklsw v11,v13            */
-	.long  0x11c08702    /* <+2212>:  vclzb   v14,v16            */
-	.long  0x1280df03    /* <+2216>:  vpopcntb v20,v27           */
-	.long  0x13805f42    /* <+2220>:  vclzh   v28,v11            */
-	.long  0x13004f43    /* <+2224>:  vpopcnth v24,v9            */
-	.long  0x1360ff82    /* <+2228>:  vclzw   v27,v31            */
-	.long  0x12209f83    /* <+2232>:  vpopcntw v17,v19           */
-	.long  0x1180efc2    /* <+2236>:  vclzd   v12,v29            */
-	.long  0x12e0b7c3    /* <+2240>:  vpopcntd v23,v22           */
-	.long  0x1314eec7    /* <+2244>:  vcmpgtud. v24,v20,v29      */
-	.long  0x1126dfc7    /* <+2248>:  vcmpgtsd. v9,v6,v27        */
-	.long  0x7fced019    /* <+2252>:  lxsiwzx vs62,r14,r26       */
-	.long  0x7d00c819    /* <+2256>:  lxsiwzx vs40,0,r25         */
-	.long  0x7f20d098    /* <+2260>:  lxsiwax vs25,0,r26         */
-	.long  0x7c601898    /* <+2264>:  lxsiwax vs3,0,r3           */
-	.long  0x7fcc0067    /* <+2268>:  mfvsrd  r12,vs62           */
-	.long  0x7d9400e6    /* <+2272>:  mffprwz r20,f12            */
-	.long  0x7dc97118    /* <+2276>:  stxsiwx vs14,r9,r14        */
-	.long  0x7ea04118    /* <+2280>:  stxsiwx vs21,0,r8          */
-	.long  0x7e0b0167    /* <+2284>:  mtvsrd  vs48,r11           */
-	.long  0x7ff701a7    /* <+2288>:  mtvrwa  v31,r23            */
-	.long  0x7e1a01e6    /* <+2292>:  mtfprwz f16,r26            */
-	.long  0x7db36c18    /* <+2296>:  lxsspx  vs13,r19,r13       */
-	.long  0x7e406c18    /* <+2300>:  lxsspx  vs18,0,r13         */
-	.long  0x7d622519    /* <+2304>:  stxsspx vs43,r2,r4         */
-	.long  0x7ee05d19    /* <+2308>:  stxsspx vs55,0,r11         */
-	.long  0xf2d0c805    /* <+2312>:  xsaddsp vs54,vs48,vs25     */
-	.long  0xf1d2080c    /* <+2316>:  xsmaddasp vs14,vs50,vs1    */
-	.long  0xf3565042    /* <+2320>:  xssubsp vs26,vs22,vs42     */
-	.long  0xf375a04e    /* <+2324>:  xsmaddmsp vs27,vs53,vs52   */
-	.long  0xf100d82a    /* <+2328>:  xsrsqrtesp vs8,vs59        */
-	.long  0xf180482e    /* <+2332>:  xssqrtsp vs12,vs41         */
-	.long  0xf32b0083    /* <+2336>:  xsmulsp vs57,vs11,vs32     */
-	.long  0xf0d4d089    /* <+2340>:  xsmsubasp vs38,vs20,vs26   */
-	.long  0xf35330c0    /* <+2344>:  xsdivsp vs26,vs19,vs6      */
-	.long  0xf065b8cf    /* <+2348>:  xsmsubmsp vs35,vs37,vs55   */
-	.long  0xf3604069    /* <+2352>:  xsresp  vs59,vs8           */
-	.long  0xf1810c0f    /* <+2356>:  xsnmaddasp vs44,vs33,vs33  */
-	.long  0xf23ef44c    /* <+2360>:  xsnmaddmsp vs17,vs62,vs30  */
-	.long  0xf2d4fc8d    /* <+2364>:  xsnmsubasp vs54,vs52,vs31  */
-	.long  0xf0a5d4cb    /* <+2368>:  xsnmsubmsp vs37,vs5,vs58   */
-	.long  0xf3d66556    /* <+2372>:  xxlorc  vs30,vs54,vs44     */
-	.long  0xf22eed91    /* <+2376>:  xxlnand vs49,vs14,vs29     */
-	.long  0xf3d6f5d1    /* <+2380>:  xxleqv  vs62,vs22,vs30     */
-	.long  0xf380b42f    /* <+2384>:  xscvdpspn vs60,vs54        */
-	.long  0xf2c06c66    /* <+2388>:  xsrsp   vs22,vs45          */
-	.long  0xf340dca2    /* <+2392>:  xscvuxdsp vs26,vs59        */
-	.long  0xf0c08ce3    /* <+2396>:  xscvsxdsp vs38,vs49        */
-	.long  0xf360d52d    /* <+2400>:  xscvspdpn vs59,vs26        */
-	.long  0xff0e168c    /* <+2404>:  fmrgow  f24,f14,f2         */
-	.long  0xfec72f8c    /* <+2408>:  fmrgew  f22,f7,f5          */
-	.long  0x7c00719c    /* <+2412>:  msgsnd  r14                */
-	.long  0x7c00b9dc    /* <+2416>:  msgclr  r23                */
-	.long  0x7d002e99    /* <+2420>:  lxvd2x  vs40,0,r5          */
-	.long  0x7d002e99    /* <+2424>:  lxvd2x  vs40,0,r5          */
-	.long  0x7d543698    /* <+2428>:  lxvd2x  vs10,r20,r6        */
-	.long  0x7d543698    /* <+2432>:  lxvd2x  vs10,r20,r6        */
-	.long  0x7d203f99    /* <+2436>:  stxvd2x vs41,0,r7          */
-	.long  0x7d203f99    /* <+2440>:  stxvd2x vs41,0,r7          */
-	.long  0x7d754798    /* <+2444>:  stxvd2x vs11,r21,r8        */
-	.long  0x7d754798    /* <+2448>:  stxvd2x vs11,r21,r8        */
-
-## altivec2.d
-	.long  0x7c60e20e    /* <+2452>:  lvepxl  v3,0,r28           */
-	.long  0x7e64920e    /* <+2456>:  lvepxl  v19,r4,r18         */
-	.long  0x7f609a4e    /* <+2460>:  lvepx   v27,0,r19          */
-	.long  0x7c39924e    /* <+2464>:  lvepx   v1,r25,r18         */
-	.long  0x7fe0da0a    /* <+2468>:  lvexbx  v31,0,r27          */
-	.long  0x7f81620a    /* <+2472>:  lvexbx  v28,r1,r12         */
-	.long  0x7fe0724a    /* <+2476>:  lvexhx  v31,0,r14          */
-	.long  0x7e30fa4a    /* <+2480>:  lvexhx  v17,r16,r31        */
-	.long  0x7ec0ea8a    /* <+2484>:  lvexwx  v22,0,r29          */
-	.long  0x7ef92a8a    /* <+2488>:  lvexwx  v23,r25,r5         */
-	.long  0x7c60660a    /* <+2492>:  lvsm    v3,0,r12           */
-	.long  0x7f7d0e0a    /* <+2496>:  lvsm    v27,r29,r1         */
-	.long  0x7ce036ca    /* <+2500>:  lvswxl  v7,0,r6            */
-	.long  0x7cf046ca    /* <+2504>:  lvswxl  v7,r16,r8          */
-	.long  0x7dc094ca    /* <+2508>:  lvswx   v14,0,r18          */
-	.long  0x7f9c84ca    /* <+2512>:  lvswx   v28,r28,r16        */
-	.long  0x7f60668a    /* <+2516>:  lvtlxl  v27,0,r12          */
-	.long  0x7f7c068a    /* <+2520>:  lvtlxl  v27,r28,r0         */
-	.long  0x7ee0cc8a    /* <+2524>:  lvtlx   v23,0,r25          */
-	.long  0x7c39748a    /* <+2528>:  lvtlx   v1,r25,r14         */
-	.long  0x7e80c64a    /* <+2532>:  lvtrxl  v20,0,r24          */
-	.long  0x7eddc64a    /* <+2536>:  lvtrxl  v22,r29,r24        */
-	.long  0x7f00444a    /* <+2540>:  lvtrx   v24,0,r8           */
-	.long  0x7db7e44a    /* <+2544>:  lvtrx   v13,r23,r28        */
-	.long  0x7d9c60dc    /* <+2548>:  mvidsplt v12,r28,r12       */
-	.long  0x7d5b005c    /* <+2552>:  mviwsplt v10,r27,r0        */
-	.long  0x7f606e0e    /* <+2556>:  stvepxl v27,0,r13          */
-	.long  0x7c42fe0e    /* <+2560>:  stvepxl v2,r2,r31          */
-	.long  0x7c60564e    /* <+2564>:  stvepx  v3,0,r10           */
-	.long  0x7f7c064e    /* <+2568>:  stvepx  v27,r28,r0         */
-	.long  0x7da0330a    /* <+2572>:  stvexbx v13,0,r6           */
-	.long  0x7db91b0a    /* <+2576>:  stvexbx v13,r25,r3         */
-	.long  0x7ec00b4a    /* <+2580>:  stvexhx v22,0,r1           */
-	.long  0x7e2e534a    /* <+2584>:  stvexhx v17,r14,r10        */
-	.long  0x7ea0db8a    /* <+2588>:  stvexwx v21,0,r27          */
-	.long  0x7ff20b8a    /* <+2592>:  stvexwx v31,r18,r1         */
-	.long  0x7f406f8a    /* <+2596>:  stvflxl v26,0,r13          */
-	.long  0x7ecdaf8a    /* <+2600>:  stvflxl v22,r13,r21        */
-	.long  0x7ca04d8a    /* <+2604>:  stvflx  v5,0,r9            */
-	.long  0x7eb80d8a    /* <+2608>:  stvflx  v21,r24,r1         */
-	.long  0x7da0574a    /* <+2612>:  stvfrxl v13,0,r10          */
-	.long  0x7db1cf4a    /* <+2616>:  stvfrxl v13,r17,r25        */
-	.long  0x7e20554a    /* <+2620>:  stvfrx  v17,0,r10          */
-	.long  0x7d0cfd4a    /* <+2624>:  stvfrx  v8,r12,r31         */
-	.long  0x7e40efca    /* <+2628>:  stvswxl v18,0,r29          */
-	.long  0x7f4e47ca    /* <+2632>:  stvswxl v26,r14,r8         */
-	.long  0x7c007dca    /* <+2636>:  stvswx  v0,0,r15           */
-	.long  0x7db73dca    /* <+2640>:  stvswx  v13,r23,r7         */
-	.long  0x10d18403    /* <+2644>:  vabsdub v6,v17,v16         */
-	.long  0x12b22443    /* <+2648>:  vabsduh v21,v18,v4         */
-	.long  0x13344c83    /* <+2652>:  vabsduw v25,v20,v9         */
-	.long  0x10d1a6ad    /* <+2656>:  vpermxor v6,v17,v20,v26    */
-	.long  0x13ba7f3c    /* <+2660>:  vaddeuqm v29,v26,v15,v28   */
-	.long  0x11e83e3d    /* <+2664>:  vaddecuq v15,v8,v7,v24     */
-	.long  0x1046a87e    /* <+2668>:  vsubeuqm v2,v6,v21,v1      */
-	.long  0x13a6013f    /* <+2672>:  vsubecuq v29,v6,v0,v4      */
-	.long  0x11c91888    /* <+2676>:  vmulouw v14,v9,v3          */
-	.long  0x13109089    /* <+2680>:  vmuluwm v24,v16,v18        */
-	.long  0x115188c0    /* <+2684>:  vaddudm v10,v17,v17        */
-	.long  0x13d920c2    /* <+2688>:  vmaxud  v30,v25,v4         */
-	.long  0x1146e0c4    /* <+2692>:  vrld    v10,v6,v28         */
-	.long  0x136738c7    /* <+2696>:  vcmpequd v27,v7,v7         */
-	.long  0x12d0c900    /* <+2700>:  vadduqm v22,v16,v25        */
-	.long  0x1035e940    /* <+2704>:  vaddcuq v1,v21,v29         */
-	.long  0x128b9988    /* <+2708>:  vmulosw v20,v11,v19        */
-	.long  0x131309c2    /* <+2712>:  vmaxsd  v24,v19,v1         */
-	.long  0x11bbf288    /* <+2716>:  vmuleuw v13,v27,v30        */
-	.long  0x11388ac2    /* <+2720>:  vminud  v9,v24,v17         */
-	.long  0x1152e2c7    /* <+2724>:  vcmpgtud v10,v18,v28       */
-	.long  0x101db388    /* <+2728>:  vmulesw v0,v29,v22         */
-	.long  0x11bc0bc2    /* <+2732>:  vminsd  v13,v28,v1         */
-	.long  0x11542bc4    /* <+2736>:  vsrad   v10,v20,v5         */
-	.long  0x13752bc7    /* <+2740>:  vcmpgtsd v27,v21,v5        */
-	.long  0x1017f601    /* <+2744>:  bcdadd. v0,v23,v30,1       */
-	.long  0x1338d408    /* <+2748>:  vpmsumb v25,v24,v26        */
-	.long  0x11042641    /* <+2752>:  bcdsub. v8,v4,v4,1         */
-	.long  0x120ed448    /* <+2756>:  vpmsumh v16,v14,v26        */
-	.long  0x1362d44e    /* <+2760>:  vpkudum v27,v2,v26         */
-	.long  0x10d78c88    /* <+2764>:  vpmsumw v6,v23,v17         */
-	.long  0x1286ccc8    /* <+2768>:  vpmsumd v20,v6,v25         */
-	.long  0x137684ce    /* <+2772>:  vpkudus v27,v22,v16        */
-	.long  0x12b494c0    /* <+2776>:  vsubudm v21,v20,v18        */
-	.long  0x12b49500    /* <+2780>:  vsubuqm v21,v20,v18        */
-	.long  0x13bd3508    /* <+2784>:  vcipher v29,v29,v6         */
-	.long  0x104da509    /* <+2788>:  vcipherlast v2,v13,v20     */
-	.long  0x1280950c    /* <+2792>:  vgbbd   v20,v18            */
-	.long  0x1268cd40    /* <+2796>:  vsubcuq v19,v8,v25         */
-	.long  0x113aed44    /* <+2800>:  vorc    v9,v26,v29         */
-	.long  0x12946d48    /* <+2804>:  vncipher v20,v20,v13       */
-	.long  0x11e5dd49    /* <+2808>:  vncipherlast v15,v5,v27    */
-	.long  0x1073354c    /* <+2812>:  vbpermq v3,v19,v6          */
-	.long  0x13c4e54e    /* <+2816>:  vpksdus v30,v4,v28         */
-	.long  0x10047584    /* <+2820>:  vnand   v0,v4,v14          */
-	.long  0x1228edc4    /* <+2824>:  vsld    v17,v8,v29         */
-	.long  0x13b405c8    /* <+2828>:  vsbox   v29,v20            */
-	.long  0x11675dce    /* <+2832>:  vpksdss v11,v7,v11         */
-	.long  0x107384c7    /* <+2836>:  vcmpequd. v3,v19,v16       */
-	.long  0x12408e4e    /* <+2840>:  vupkhsw v18,v17            */
-	.long  0x13a86e82    /* <+2844>:  vshasigmaw v29,v8,0,13     */
-	.long  0x12fcd684    /* <+2848>:  veqv    v23,v28,v26        */
-	.long  0x13a0178c    /* <+2852>:  vmrgew  v29,v0,v2          */
-	.long  0x13a0168c    /* <+2856>:  vmrgow  v29,v0,v2          */
-	.long  0x137306c2    /* <+2860>:  vshasigmad v27,v19,0,0     */
-	.long  0x129ce6c4    /* <+2864>:  vsrd    v20,v28,v28        */
-	.long  0x1240aece    /* <+2868>:  vupklsw v18,v21            */
-	.long  0x13c03f02    /* <+2872>:  vclzb   v30,v7             */
-	.long  0x13a0af03    /* <+2876>:  vpopcntb v29,v21           */
-	.long  0x1320af42    /* <+2880>:  vclzh   v25,v21            */
-	.long  0x1200f743    /* <+2884>:  vpopcnth v16,v30           */
-	.long  0x13801f82    /* <+2888>:  vclzw   v28,v3             */
-	.long  0x11404f83    /* <+2892>:  vpopcntw v10,v9            */
-	.long  0x12c04fc2    /* <+2896>:  vclzd   v22,v9             */
-	.long  0x11e0f7c3    /* <+2900>:  vpopcntd v15,v30           */
-	.long  0x105f36c7    /* <+2904>:  vcmpgtud. v2,v31,v6        */
-	.long  0x128f17c7    /* <+2908>:  vcmpgtsd. v20,v15,v2       */
-
-## vsd2.d
-	.long  0x7fced019    /* <+2912>:  lxsiwzx vs62,r14,r26       */
-	.long  0x7d00c819    /* <+2916>:  lxsiwzx vs40,0,r25         */
-	.long  0x7f20d098    /* <+2920>:  lxsiwax vs25,0,r26         */
-	.long  0x7c601898    /* <+2924>:  lxsiwax vs3,0,r3           */
-	.long  0x7fcc0066    /* <+2928>:  mfvsrd  r12,vs30           */
-	.long  0x7fcc0066    /* <+2932>:  mfvsrd  r12,vs30           */
-	.long  0x7fcc0067    /* <+2936>:  mfvsrd  r12,vs62           */
-	.long  0x7fcc0067    /* <+2940>:  mfvsrd  r12,vs62           */
-	.long  0x7d9400e6    /* <+2944>:  mffprwz r20,f12            */
-	.long  0x7d9400e6    /* <+2948>:  mffprwz r20,f12            */
-	.long  0x7d9500e7    /* <+2952>:  mfvrwz  r21,v12            */
-	.long  0x7d9500e7    /* <+2956>:  mfvrwz  r21,v12            */
-	.long  0x7dc97118    /* <+2960>:  stxsiwx vs14,r9,r14        */
-	.long  0x7ea04118    /* <+2964>:  stxsiwx vs21,0,r8          */
-	.long  0x7d7c0166    /* <+2968>:  mtvsrd  vs11,r28           */
-	.long  0x7d7c0166    /* <+2972>:  mtvsrd  vs11,r28           */
-	.long  0x7d7d0167    /* <+2976>:  mtvsrd  vs43,r29           */
-	.long  0x7d7d0167    /* <+2980>:  mtvsrd  vs43,r29           */
-	.long  0x7f1601a6    /* <+2984>:  mtfprwa f24,r22            */
-	.long  0x7f1601a6    /* <+2988>:  mtfprwa f24,r22            */
-	.long  0x7f3701a7    /* <+2992>:  mtvrwa  v25,r23            */
-	.long  0x7f3701a7    /* <+2996>:  mtvrwa  v25,r23            */
-	.long  0x7f5b01e6    /* <+3000>:  mtfprwz f26,r27            */
-	.long  0x7f5b01e6    /* <+3004>:  mtfprwz f26,r27            */
-	.long  0x7f7c01e7    /* <+3008>:  mtvrwz  v27,r28            */
-	.long  0x7f7c01e7    /* <+3012>:  mtvrwz  v27,r28            */
-	.long  0x7db36c18    /* <+3016>:  lxsspx  vs13,r19,r13       */
-	.long  0x7e406c18    /* <+3020>:  lxsspx  vs18,0,r13         */
-	.long  0x7d622519    /* <+3024>:  stxsspx vs43,r2,r4         */
-	.long  0x7ee05d19    /* <+3028>:  stxsspx vs55,0,r11         */
-	.long  0xf2d0c805    /* <+3032>:  xsaddsp vs54,vs48,vs25     */
-	.long  0xf1d2080c    /* <+3036>:  xsmaddasp vs14,vs50,vs1    */
-	.long  0xf3565042    /* <+3040>:  xssubsp vs26,vs22,vs42     */
-	.long  0xf375a04e    /* <+3044>:  xsmaddmsp vs27,vs53,vs52   */
-	.long  0xf100d82a    /* <+3048>:  xsrsqrtesp vs8,vs59        */
-	.long  0xf180482e    /* <+3052>:  xssqrtsp vs12,vs41         */
-	.long  0xf32b0083    /* <+3056>:  xsmulsp vs57,vs11,vs32     */
-	.long  0xf0d4d089    /* <+3060>:  xsmsubasp vs38,vs20,vs26   */
-	.long  0xf35330c0    /* <+3064>:  xsdivsp vs26,vs19,vs6      */
-	.long  0xf065b8cf    /* <+3068>:  xsmsubmsp vs35,vs37,vs55   */
-	.long  0xf3604069    /* <+3072>:  xsresp  vs59,vs8           */
-	.long  0xf1810c0f    /* <+3076>:  xsnmaddasp vs44,vs33,vs33  */
-	.long  0xf23ef44c    /* <+3080>:  xsnmaddmsp vs17,vs62,vs30  */
-	.long  0xf2d4fc8d    /* <+3084>:  xsnmsubasp vs54,vs52,vs31  */
-	.long  0xf0a5d4cb    /* <+3088>:  xsnmsubmsp vs37,vs5,vs58   */
-	.long  0xf3d66556    /* <+3092>:  xxlorc  vs30,vs54,vs44     */
-	.long  0xf22eed91    /* <+3096>:  xxlnand vs49,vs14,vs29     */
-	.long  0xf3d6f5d1    /* <+3100>:  xxleqv  vs62,vs22,vs30     */
-	.long  0xf380b42f    /* <+3104>:  xscvdpspn vs60,vs54        */
-	.long  0xf2c06c66    /* <+3108>:  xsrsp   vs22,vs45          */
-	.long  0xf340dca2    /* <+3112>:  xscvuxdsp vs26,vs59        */
-	.long  0xf0c08ce3    /* <+3116>:  xscvsxdsp vs38,vs49        */
-	.long  0xf360d52d    /* <+3120>:  xscvspdpn vs59,vs26        */
-	.long  0xff0e168c    /* <+3124>:  fmrgow  f24,f14,f2         */
-	.long  0xfec72f8c    /* <+3128>:  fmrgew  f22,f7,f5          */
-
-## power9.d
-	.long  0x7da30474    /* <+3132>:  cnttzd  r3,r13             */
-	.long  0x7dc40475    /* <+3136>:  cnttzd. r4,r14             */
-	.long  0x7de50434    /* <+3140>:  cnttzw  r5,r15             */
-	.long  0x7e060435    /* <+3144>:  cnttzw. r6,r16             */
-	.long  0x7d54ae12    /* <+3148>:  modsd   r10,r20,r21        */
-	.long  0x7d75b616    /* <+3152>:  modsw   r11,r21,r22        */
-	.long  0x7d96ba12    /* <+3156>:  modud   r12,r22,r23        */
-	.long  0x7db7c216    /* <+3160>:  moduw   r13,r23,r24        */
-	.long  0x10672581    /* <+3164>:  bcdcfn. v3,v4,0            */
-	.long  0x10672781    /* <+3168>:  bcdcfn. v3,v4,1            */
-	.long  0x10822d81    /* <+3172>:  bcdcfsq. v4,v5,0           */
-	.long  0x10822f81    /* <+3176>:  bcdcfsq. v4,v5,1           */
-	.long  0x10a63581    /* <+3180>:  bcdcfz. v5,v6,0            */
-	.long  0x10a63781    /* <+3184>:  bcdcfz. v5,v6,1            */
-	.long  0x10c74341    /* <+3188>:  bcdcpsgn. v6,v7,v8         */
-	.long  0x10e54581    /* <+3192>:  bcdctn. v7,v8              */
-	.long  0x11004d81    /* <+3196>:  bcdctsq. v8,v9             */
-	.long  0x11245581    /* <+3200>:  bcdctz. v9,v10,0           */
-	.long  0x11245781    /* <+3204>:  bcdctz. v9,v10,1           */
-	.long  0x115f5d81    /* <+3208>:  bcdsetsgn. v10,v11,0       */
-	.long  0x115f5f81    /* <+3212>:  bcdsetsgn. v10,v11,1       */
-	.long  0x116c6dc1    /* <+3216>:  bcdsr.  v11,v12,v13,0      */
-	.long  0x116c6fc1    /* <+3220>:  bcdsr.  v11,v12,v13,1      */
-	.long  0x118d74c1    /* <+3224>:  bcds.   v12,v13,v14,0      */
-	.long  0x118d76c1    /* <+3228>:  bcds.   v12,v13,v14,1      */
-	.long  0x11ae7d01    /* <+3232>:  bcdtrunc. v13,v14,v15,0    */
-	.long  0x11ae7f01    /* <+3236>:  bcdtrunc. v13,v14,v15,1    */
-	.long  0x11cf8481    /* <+3240>:  bcdus.  v14,v15,v16        */
-	.long  0x11f08d41    /* <+3244>:  bcdutrunc. v15,v16,v17     */
-	.long  0x7e80aa5a    /* <+3248>:  lxvll   vs20,0,r21         */
-	.long  0x7e8aaa5a    /* <+3252>:  lxvll   vs20,r10,r21       */
-	.long  0x7ea05b5a    /* <+3256>:  stxvll  vs21,0,r11         */
-	.long  0x7eaa5b5a    /* <+3260>:  stxvll  vs21,r10,r11       */
-	.long  0x12d70001    /* <+3264>:  vmul10cuq v22,v23          */
-	.long  0x12f8c841    /* <+3268>:  vmul10ecuq v23,v24,v25     */
-	.long  0x1319d241    /* <+3272>:  vmul10euq v24,v25,v26      */
-	.long  0x133a0201    /* <+3276>:  vmul10uq v25,v26           */
-	.long  0xfd4b6008    /* <+3280>:  xsaddqp v10,v11,v12        */
-	.long  0xfd6c6009    /* <+3284>:  xsaddqpo v11,v12,v12       */
-	.long  0xfe80f00a    /* <+3288>:  xsrqpi  0,v20,v30,0        */
-	.long  0xfe81f00a    /* <+3292>:  xsrqpi  1,v20,v30,0        */
-	.long  0xfe80f60a    /* <+3296>:  xsrqpi  0,v20,v30,3        */
-	.long  0xfe81f60a    /* <+3300>:  xsrqpi  1,v20,v30,3        */
-	.long  0xfea0f80b    /* <+3304>:  xsrqpix 0,v21,v31,0        */
-	.long  0xfea1f80b    /* <+3308>:  xsrqpix 1,v21,v31,0        */
-	.long  0xfea0fe0b    /* <+3312>:  xsrqpix 0,v21,v31,3        */
-	.long  0xfea1fe0b    /* <+3316>:  xsrqpix 1,v21,v31,3        */
-	.long  0xfd8d7048    /* <+3320>:  xsmulqp v12,v13,v14        */
-	.long  0xfdae7849    /* <+3324>:  xsmulqpo v13,v14,v15       */
-	.long  0xfec0b84a    /* <+3328>:  xsrqpxp 0,v22,v23,0        */
-	.long  0xfec1b84a    /* <+3332>:  xsrqpxp 1,v22,v23,0        */
-	.long  0xfec0be4a    /* <+3336>:  xsrqpxp 0,v22,v23,3        */
-	.long  0xfec1be4a    /* <+3340>:  xsrqpxp 1,v22,v23,3        */
-	.long  0xfdcf80c8    /* <+3344>:  xscpsgnqp v14,v15,v16      */
-	.long  0xfc0f8108    /* <+3348>:  xscmpoqp cr0,v15,v16       */
-	.long  0xff8f8108    /* <+3352>:  xscmpoqp cr7,v15,v16       */
-	.long  0xfc108948    /* <+3356>:  xscmpexpqp cr0,v16,v17     */
-	.long  0xff908948    /* <+3360>:  xscmpexpqp cr7,v16,v17     */
-	.long  0xfe329b08    /* <+3364>:  xsmaddqp v17,v18,v19       */
-	.long  0xfe53a309    /* <+3368>:  xsmaddqpo v18,v19,v20      */
-	.long  0xfe74ab48    /* <+3372>:  xsmsubqp v19,v20,v21       */
-	.long  0xfe95b349    /* <+3376>:  xsmsubqpo v20,v21,v22      */
-	.long  0xfeb6bb88    /* <+3380>:  xsnmaddqp v21,v22,v23      */
-	.long  0xfed7c389    /* <+3384>:  xsnmaddqpo v22,v23,v24     */
-	.long  0xfef8cbc8    /* <+3388>:  xsnmsubqp v23,v24,v25      */
-	.long  0xff19d3c9    /* <+3392>:  xsnmsubqpo v24,v25,v26     */
-	.long  0xff3adc08    /* <+3396>:  xssubqp v25,v26,v27        */
-	.long  0xff5be409    /* <+3400>:  xssubqpo v26,v27,v28       */
-	.long  0xff7cec48    /* <+3404>:  xsdivqp v27,v28,v29        */
-	.long  0xff9df449    /* <+3408>:  xsdivqpo v28,v29,v30       */
-	.long  0xfc1df508    /* <+3412>:  xscmpuqp cr0,v29,v30       */
-	.long  0xff9df508    /* <+3416>:  xscmpuqp cr7,v29,v30       */
-	.long  0xfc00f588    /* <+3420>:  xststdcqp cr0,v30,0        */
-	.long  0xff80f588    /* <+3424>:  xststdcqp cr7,v30,0        */
-	.long  0xfc7ffd88    /* <+3428>:  xststdcqp cr0,v31,127      */
-	.long  0xfffffd88    /* <+3432>:  xststdcqp cr7,v31,127      */
-	.long  0xfd405e48    /* <+3436>:  xsabsqp v10,v11            */
-	.long  0xfd626648    /* <+3440>:  xsxexpqp v11,v12           */
-	.long  0xfd886e48    /* <+3444>:  xsnabsqp v12,v13           */
-	.long  0xfdb07648    /* <+3448>:  xsnegqp v13,v14            */
-	.long  0xfdd27e48    /* <+3452>:  xsxsigqp v14,v15           */
-	.long  0xfdfb8648    /* <+3456>:  xssqrtqp v15,v16           */
-	.long  0xfe1b8e49    /* <+3460>:  xssqrtqpo v16,v17          */
-	.long  0xfe219688    /* <+3464>:  xscvqpuwz v17,v18          */
-	.long  0xfe429e88    /* <+3468>:  xscvudqp v18,v19           */
-	.long  0xfe69a688    /* <+3472>:  xscvqpswz v19,v20          */
-	.long  0xfe8aae88    /* <+3476>:  xscvsdqp v20,v21           */
-	.long  0xfeb1b688    /* <+3480>:  xscvqpudz v21,v22          */
-	.long  0xfed4be88    /* <+3484>:  xscvqpdp v22,v23           */
-	.long  0xfef4c689    /* <+3488>:  xscvqpdpo v23,v24          */
-	.long  0xff16ce88    /* <+3492>:  xscvdpqp v24,v25           */
-	.long  0xff39d688    /* <+3496>:  xscvqpsdz v25,v26          */
-	.long  0xff5be6c8    /* <+3500>:  xsiexpqp v26,v27,v28       */
-	.long  0x108531fb    /* <+3504>:  vpermr  v4,v5,v6,v7        */
-	.long  0x10a0320d    /* <+3508>:  vextractub v5,v6,0         */
-	.long  0x10af320d    /* <+3512>:  vextractub v5,v6,15        */
-	.long  0x10c03a4d    /* <+3516>:  vextractuh v6,v7,0         */
-	.long  0x10cf3a4d    /* <+3520>:  vextractuh v6,v7,15        */
-	.long  0x10e0428d    /* <+3524>:  vextractuw v7,v8,0         */
-	.long  0x10ef428d    /* <+3528>:  vextractuw v7,v8,15        */
-	.long  0x11004acd    /* <+3532>:  vextractd v8,v9,0          */
-	.long  0x110f4acd    /* <+3536>:  vextractd v8,v9,15         */
-	.long  0x1120530d    /* <+3540>:  vinsertb v9,v10,0          */
-	.long  0x112f530d    /* <+3544>:  vinsertb v9,v10,15         */
-	.long  0x11405b4d    /* <+3548>:  vinserth v10,v11,0         */
-	.long  0x114f5b4d    /* <+3552>:  vinserth v10,v11,15        */
-	.long  0x1160638d    /* <+3556>:  vinsertw v11,v12,0         */
-	.long  0x116f638d    /* <+3560>:  vinsertw v11,v12,15        */
-	.long  0x11806bcd    /* <+3564>:  vinsertd v12,v13,0         */
-	.long  0x118f6bcd    /* <+3568>:  vinsertd v12,v13,15        */
-	.long  0x7db40267    /* <+3572>:  mfvsrld r20,vs45           */
-	.long  0x7dd50327    /* <+3576>:  mtvsrws vs46,r21           */
-	.long  0x7de0bb67    /* <+3580>:  mtvsrdd vs47,0,r23         */
-	.long  0x7df6bb67    /* <+3584>:  mtvsrdd vs47,r22,r23       */
-	.long  0x7e405a19    /* <+3588>:  lxvx    vs50,0,r11         */
-	.long  0x7c0a5a18    /* <+3592>:  lxvx    vs0,r10,r11        */
-	.long  0x7e6062d9    /* <+3596>:  lxvwsx  vs51,0,r12         */
-	.long  0x7c2a62d8    /* <+3600>:  lxvwsx  vs1,r10,r12        */
-	.long  0x7e806e59    /* <+3604>:  lxvh8x  vs52,0,r13         */
-	.long  0x7c4a6e58    /* <+3608>:  lxvh8x  vs2,r10,r13        */
-	.long  0x7ea076d9    /* <+3612>:  lxvb16x vs53,0,r14         */
-	.long  0x7c6a76d8    /* <+3616>:  lxvb16x vs3,r10,r14        */
-	.long  0x7ec07b19    /* <+3620>:  stxvx   vs54,0,r15         */
-	.long  0x7c947b18    /* <+3624>:  stxvx   vs4,r20,r15        */
-	.long  0x7ee08759    /* <+3628>:  stxvh8x vs55,0,r16         */
-	.long  0x7cb48758    /* <+3632>:  stxvh8x vs5,r20,r16        */
-	.long  0x7f008fd9    /* <+3636>:  stxvb16x vs56,0,r17        */
-	.long  0x7cd48fd8    /* <+3640>:  stxvb16x vs6,r20,r17       */
-	.long  0xf0802a94    /* <+3644>:  xxextractuw vs4,vs5,0      */
-	.long  0xf10f9297    /* <+3648>:  xxextractuw vs40,vs50,15   */
-	.long  0xf08002d0    /* <+3652>:  xxspltib vs4,0             */
-	.long  0xf127fad1    /* <+3656>:  xxspltib vs41,255          */
-	.long  0xf0a032d4    /* <+3660>:  xxinsertw vs5,vs6,0        */
-	.long  0xf24fe2d7    /* <+3664>:  xxinsertw vs50,vs60,15     */
-	.long  0xf0c73f6c    /* <+3668>:  xxbrh   vs6,vs7            */
-	.long  0xf307cf6f    /* <+3672>:  xxbrh   vs56,vs57          */
-	.long  0xf0ef476c    /* <+3676>:  xxbrw   vs7,vs8            */
-	.long  0xf32fd76f    /* <+3680>:  xxbrw   vs57,vs58          */
-	.long  0xf1174f6c    /* <+3684>:  xxbrd   vs8,vs9            */
-	.long  0xf357df6f    /* <+3688>:  xxbrd   vs58,vs59          */
-	.long  0xf13f576c    /* <+3692>:  xxbrq   vs9,vs10           */
-	.long  0xf37fe76f    /* <+3696>:  xxbrq   vs59,vs60          */
-	.long  0xe6800002    /* <+3700>:  lxsd    v20,0(0)           */
-	.long  0xe68a0002    /* <+3704>:  lxsd    v20,0(r10)         */
-	.long  0xe680000a    /* <+3708>:  lxsd    v20,8(0)           */
-	.long  0xe68a000a    /* <+3712>:  lxsd    v20,8(r10)         */
-	.long  0xe680fffa    /* <+3716>:  lxsd    v20,-8(0)          */
-	.long  0xe68afffa    /* <+3720>:  lxsd    v20,-8(r10)        */
-	.long  0xe6807ffe    /* <+3724>:  lxsd    v20,32764(0)       */
-	.long  0xe68a7ffe    /* <+3728>:  lxsd    v20,32764(r10)     */
-	.long  0xe6808002    /* <+3732>:  lxsd    v20,-32768(0)      */
-	.long  0xe68a8002    /* <+3736>:  lxsd    v20,-32768(r10)    */
-	.long  0xe7c00003    /* <+3740>:  lxssp   v30,0(0)           */
-	.long  0xe7cb0003    /* <+3744>:  lxssp   v30,0(r11)         */
-	.long  0xe7c0000b    /* <+3748>:  lxssp   v30,8(0)           */
-	.long  0xe7cb000b    /* <+3752>:  lxssp   v30,8(r11)         */
-	.long  0xe7c0fffb    /* <+3756>:  lxssp   v30,-8(0)          */
-	.long  0xe7cbfffb    /* <+3760>:  lxssp   v30,-8(r11)        */
-	.long  0xe7c07fff    /* <+3764>:  lxssp   v30,32764(0)       */
-	.long  0xe7cb7fff    /* <+3768>:  lxssp   v30,32764(r11)     */
-	.long  0xe7c08003    /* <+3772>:  lxssp   v30,-32768(0)      */
-	.long  0xe7cb8003    /* <+3776>:  lxssp   v30,-32768(r11)    */
-	.long  0xf5000009    /* <+3780>:  lxv     vs40,0(0)          */
-	.long  0xf50c0009    /* <+3784>:  lxv     vs40,0(r12)        */
-	.long  0xf5000019    /* <+3788>:  lxv     vs40,16(0)         */
-	.long  0xf50c0019    /* <+3792>:  lxv     vs40,16(r12)       */
-	.long  0xf500fff9    /* <+3796>:  lxv     vs40,-16(0)        */
-	.long  0xf54cfff1    /* <+3800>:  lxv     vs10,-16(r12)      */
-	.long  0xf5407ff1    /* <+3804>:  lxv     vs10,32752(0)      */
-	.long  0xf54c7ff1    /* <+3808>:  lxv     vs10,32752(r12)    */
-	.long  0xf5408001    /* <+3812>:  lxv     vs10,-32768(0)     */
-	.long  0xf54c8001    /* <+3816>:  lxv     vs10,-32768(r12)   */
-	.long  0xf6a00002    /* <+3820>:  stxsd   v21,0(0)           */
-	.long  0xf6aa0002    /* <+3824>:  stxsd   v21,0(r10)         */
-	.long  0xf6a0000a    /* <+3828>:  stxsd   v21,8(0)           */
-	.long  0xf6aa000a    /* <+3832>:  stxsd   v21,8(r10)         */
-	.long  0xf6a0fffa    /* <+3836>:  stxsd   v21,-8(0)          */
-	.long  0xf6aafffa    /* <+3840>:  stxsd   v21,-8(r10)        */
-	.long  0xf6a07ffe    /* <+3844>:  stxsd   v21,32764(0)       */
-	.long  0xf6aa7ffe    /* <+3848>:  stxsd   v21,32764(r10)     */
-	.long  0xf6a08002    /* <+3852>:  stxsd   v21,-32768(0)      */
-	.long  0xf6aa8002    /* <+3856>:  stxsd   v21,-32768(r10)    */
-	.long  0xf7e00003    /* <+3860>:  stxssp  v31,0(0)           */
-	.long  0xf7eb0003    /* <+3864>:  stxssp  v31,0(r11)         */
-	.long  0xf7e0000b    /* <+3868>:  stxssp  v31,8(0)           */
-	.long  0xf7eb000b    /* <+3872>:  stxssp  v31,8(r11)         */
-	.long  0xf7e0fffb    /* <+3876>:  stxssp  v31,-8(0)          */
-	.long  0xf7ebfffb    /* <+3880>:  stxssp  v31,-8(r11)        */
-	.long  0xf7e07fff    /* <+3884>:  stxssp  v31,32764(0)       */
-	.long  0xf7eb7fff    /* <+3888>:  stxssp  v31,32764(r11)     */
-	.long  0xf7e08003    /* <+3892>:  stxssp  v31,-32768(0)      */
-	.long  0xf7eb8003    /* <+3896>:  stxssp  v31,-32768(r11)    */
-	.long  0xf520000d    /* <+3900>:  stxv    vs41,0(0)          */
-	.long  0xf52c000d    /* <+3904>:  stxv    vs41,0(r12)        */
-	.long  0xf520001d    /* <+3908>:  stxv    vs41,16(0)         */
-	.long  0xf52c001d    /* <+3912>:  stxv    vs41,16(r12)       */
-	.long  0xf520fffd    /* <+3916>:  stxv    vs41,-16(0)        */
-	.long  0xf56cfff5    /* <+3920>:  stxv    vs11,-16(r12)      */
-	.long  0xf5607ff5    /* <+3924>:  stxv    vs11,32752(0)      */
-	.long  0xf56c7ff5    /* <+3928>:  stxv    vs11,32752(r12)    */
-	.long  0xf5608005    /* <+3932>:  stxv    vs11,-32768(0)     */
-	.long  0xf56c8005    /* <+3936>:  stxv    vs11,-32768(r12)   */
-	.long  0xf296c0d0    /* <+3940>:  xxperm  vs20,vs22,vs24     */
-	.long  0xf10a60d7    /* <+3944>:  xxperm  vs40,vs42,vs44     */
-	.long  0xf2b7c9d0    /* <+3948>:  xxpermr vs21,vs23,vs25     */
-	.long  0xf12b69d7    /* <+3952>:  xxpermr vs41,vs43,vs45     */
-	.long  0x7e8c06f4    /* <+3956>:  extswsli r12,r20,0         */
-	.long  0x7e8c0ef4    /* <+3960>:  extswsli r12,r20,1         */
-	.long  0x7e8cfef6    /* <+3964>:  extswsli r12,r20,63        */
-	.long  0x7ead06f5    /* <+3968>:  extswsli. r13,r21,0        */
-	.long  0x7ead0ef5    /* <+3972>:  extswsli. r13,r21,1        */
-	.long  0x7eadfef7    /* <+3976>:  extswsli. r13,r21,63       */
-	.long  0x11d6b885    /* <+3980>:  vrlwmi  v14,v22,v23        */
-	.long  0x11f7c0c5    /* <+3984>:  vrldmi  v15,v23,v24        */
-	.long  0x1218c985    /* <+3988>:  vrlwnm  v16,v24,v25        */
-	.long  0x1239d1c5    /* <+3992>:  vrldnm  v17,v25,v26        */
-	.long  0x125addcc    /* <+3996>:  vbpermd v18,v26,v27        */
-	.long  0x1266a602    /* <+4000>:  vnegw   v19,v20            */
-	.long  0x1287ae02    /* <+4004>:  vnegd   v20,v21            */
-	.long  0x12a8b602    /* <+4008>:  vprtybw v21,v22            */
-	.long  0x12c9be02    /* <+4012>:  vprtybd v22,v23            */
-	.long  0x12eac602    /* <+4016>:  vprtybq v23,v24            */
-	.long  0x1310ce02    /* <+4020>:  vextsb2w v24,v25           */
-	.long  0x1331d602    /* <+4024>:  vextsh2w v25,v26           */
-	.long  0x1358de02    /* <+4028>:  vextsb2d v26,v27           */
-	.long  0x1379e602    /* <+4032>:  vextsh2d v27,v28           */
-	.long  0x139aee02    /* <+4036>:  vextsw2d v28,v29           */
-	.long  0x13bcf602    /* <+4040>:  vctzb   v29,v30            */
-	.long  0x13ddfe02    /* <+4044>:  vctzh   v30,v31            */
-	.long  0x13fef602    /* <+4048>:  vctzw   v31,v30            */
-	.long  0x13dfee02    /* <+4052>:  vctzd   v30,v29            */
-	.long  0x7d40a61a    /* <+4056>:  lxsibzx vs10,0,r20         */
-	.long  0x7e4aa61b    /* <+4060>:  lxsibzx vs50,r10,r20       */
-	.long  0x7d60ae5a    /* <+4064>:  lxsihzx vs11,0,r21         */
-	.long  0x7e6bae5b    /* <+4068>:  lxsihzx vs51,r11,r21       */
-	.long  0x7d80b71a    /* <+4072>:  stxsibx vs12,0,r22         */
-	.long  0x7e8cb71b    /* <+4076>:  stxsibx vs52,r12,r22       */
-	.long  0x7da0bf5a    /* <+4080>:  stxsihx vs13,0,r23         */
-	.long  0x7eadbf5b    /* <+4084>:  stxsihx vs53,r13,r23       */
-	.long  0x114b6370    /* <+4088>:  maddhd  r10,r11,r12,r13    */
-	.long  0x1295b5f1    /* <+4092>:  maddhdu r20,r21,r22,r23    */
-	.long  0x10432173    /* <+4096>:  maddld  r2,r3,r4,r5        */
-	.long  0xf00aa1d8    /* <+4100>:  xscmpexpdp cr0,vs10,vs20   */
-	.long  0xf38891de    /* <+4104>:  xscmpexpdp cr7,vs40,vs50   */
-	.long  0xf12baf2d    /* <+4108>:  xsiexpdp vs41,r11,r21      */
-	.long  0xf07f5da8    /* <+4112>:  xststdcdp cr0,vs11,127     */
-	.long  0xf3ff4daa    /* <+4116>:  xststdcdp cr7,vs41,127     */
-	.long  0xf07f5ca8    /* <+4120>:  xststdcsp cr0,vs11,127     */
-	.long  0xf3ff4caa    /* <+4124>:  xststdcsp cr7,vs41,127     */
-	.long  0xf1a05d6e    /* <+4128>:  xsxexpdp r13,vs43          */
-	.long  0xf1c1656e    /* <+4132>:  xsxsigdp r14,vs44          */
-	.long  0xf1ae7fc7    /* <+4136>:  xviexpdp vs45,vs46,vs47    */
-	.long  0xf1cf86c7    /* <+4140>:  xviexpsp vs46,vs47,vs48    */
-	.long  0xf2c0bfab    /* <+4144>:  xvtstdcdp vs54,vs55,0      */
-	.long  0xf2dfbfef    /* <+4148>:  xvtstdcdp vs54,vs55,127    */
-	.long  0xf2e0c6ab    /* <+4152>:  xvtstdcsp vs55,vs56,0      */
-	.long  0xf2ffc6ef    /* <+4156>:  xvtstdcsp vs55,vs56,127    */
-	.long  0xf320d76f    /* <+4160>:  xvxexpdp vs57,vs58         */
-	.long  0xf348df6f    /* <+4164>:  xvxexpsp vs58,vs59         */
-	.long  0xf361e76f    /* <+4168>:  xvxsigdp vs59,vs60         */
-	.long  0xf389ef6f    /* <+4172>:  xvxsigsp vs60,vs61         */
-	.long  0x7c0639c0    /* <+4176>:  cmpeqb  cr0,r6,r7          */
-	.long  0x7f8639c0    /* <+4180>:  cmpeqb  cr7,r6,r7          */
-	.long  0x7c084980    /* <+4184>:  cmprb   cr0,0,r8,r9        */
-	.long  0x7f884980    /* <+4188>:  cmprb   cr7,0,r8,r9        */
-	.long  0x7c284980    /* <+4192>:  cmprb   cr0,1,r8,r9        */
-	.long  0x7fa84980    /* <+4196>:  cmprb   cr7,1,r8,r9        */
-	.long  0x7de00100    /* <+4200>:  setb    r15,cr0            */
-	.long  0x7dfc0100    /* <+4204>:  setb    r15,cr7            */
-	.long  0x7f40521a    /* <+4208>:  lxvl    vs26,0,r10         */
-	.long  0x7f14521b    /* <+4212>:  lxvl    vs56,r20,r10       */
-	.long  0x7f605b1a    /* <+4216>:  stxvl   vs27,0,r11         */
-	.long  0x7f355b1b    /* <+4220>:  stxvl   vs57,r21,r11       */
-	.long  0x1280f602    /* <+4224>:  vclzlsbb r20,v30           */
-	.long  0x12a1fe02    /* <+4228>:  vctzlsbb r21,v31           */
-	.long  0x114b6007    /* <+4232>:  vcmpneb v10,v11,v12        */
-	.long  0x1295b407    /* <+4236>:  vcmpneb. v20,v21,v22       */
-	.long  0x116c6847    /* <+4240>:  vcmpneh v11,v12,v13        */
-	.long  0x12b6bc47    /* <+4244>:  vcmpneh. v21,v22,v23       */
-	.long  0x118d7087    /* <+4248>:  vcmpnew v12,v13,v14        */
-	.long  0x12d7c487    /* <+4252>:  vcmpnew. v22,v23,v24       */
-	.long  0x11ae7907    /* <+4256>:  vcmpnezb v13,v14,v15       */
-	.long  0x12f8cd07    /* <+4260>:  vcmpnezb. v23,v24,v25      */
-	.long  0x11cf8147    /* <+4264>:  vcmpnezh v14,v15,v16       */
-	.long  0x1319d547    /* <+4268>:  vcmpnezh. v24,v25,v26      */
-	.long  0x11f08987    /* <+4272>:  vcmpnezw v15,v16,v17       */
-	.long  0x133add87    /* <+4276>:  vcmpnezw. v25,v26,v27      */
-	.long  0x1211560d    /* <+4280>:  vextublx r16,r17,v10       */
-	.long  0x12325f0d    /* <+4284>:  vextubrx r17,r18,v11       */
-	.long  0x1253664d    /* <+4288>:  vextuhlx r18,r19,v12       */
-	.long  0x12746f4d    /* <+4292>:  vextuhrx r19,r20,v13       */
-	.long  0x1295768d    /* <+4296>:  vextuwlx r20,r21,v14       */
-	.long  0x12b67f8d    /* <+4300>:  vextuwrx r21,r22,v15       */
-	.long  0xec001d46    /* <+4304>:  dtstsfi cr0,0,f3           */
-	.long  0xefbf1d46    /* <+4308>:  dtstsfi cr7,63,f3          */
-	.long  0xfc002546    /* <+4312>:  dtstsfiq cr0,0,f4          */
-	.long  0xffbf2546    /* <+4316>:  dtstsfiq cr7,63,f4         */
-	.long  0xf110956f    /* <+4320>:  xscvhpdp vs40,vs50         */
-	.long  0xf1319d6f    /* <+4324>:  xscvdphp vs41,vs51         */
-	.long  0xf158a76f    /* <+4328>:  xvcvhpsp vs42,vs52         */
-	.long  0xf179af6f    /* <+4332>:  xvcvsphp vs43,vs53         */
-	.long  0x4c600004    /* <+4336>:  addpcis r3,0               */
-	.long  0x4c600004    /* <+4340>:  addpcis r3,0               */
-	.long  0x4c800005    /* <+4344>:  addpcis r4,1               */
-	.long  0x4c800005    /* <+4348>:  addpcis r4,1               */
-	.long  0x4cbfffc4    /* <+4352>:  addpcis r5,-2              */
-	.long  0x4cbfffc4    /* <+4356>:  addpcis r5,-2              */
-	.long  0x4cdf7fc5    /* <+4360>:  addpcis r6,32767           */
-	.long  0x4cdf7fc5    /* <+4364>:  addpcis r6,32767           */
-	.long  0x4ce08004    /* <+4368>:  addpcis r7,-32768          */
-	.long  0x4ce08004    /* <+4372>:  addpcis r7,-32768          */
-	.long  0x7c0002a4    /* <+4376>:  slbsync                    */
-	.long  0x7d405ba4    /* <+4380>:  slbieg  r10,r11            */
-	.long  0x7c602726    /* <+4384>:  slbmfee r3,r4              */
-	.long  0x7c602726    /* <+4388>:  slbmfee r3,r4              */
-	.long  0x7c612726    /* <+4392>:  slbmfee r3,r4,1            */
-	.long  0x7c802ea6    /* <+4396>:  slbmfev r4,r5              */
-	.long  0x7c802ea6    /* <+4400>:  slbmfev r4,r5              */
-	.long  0x7c812ea6    /* <+4404>:  slbmfev r4,r5,1            */
-	.long  0x7c801a64    /* <+4408>:  tlbie   r3,r4              */
-	.long  0x7c801a64    /* <+4412>:  tlbie   r3,r4              */
-	.long  0x7c8f1a64    /* <+4416>:  tlbie   r3,r4,3,1,1        */
-	.long  0x7c001a24    /* <+4420>:  tlbiel  r3                 */
-	.long  0x7c001a24    /* <+4424>:  tlbiel  r3                 */
-	.long  0x7c8f1a24    /* <+4428>:  tlbiel  r3,r4,3,1,1        */
-	.long  0x7c2c6e0c    /* <+4432>:  copy    r12,r13            */
-	.long  0x7c2a5f0d    /* <+4436>:  paste.  r10,r11            */
-	.long  0x7c00068c    /* <+4440>:  cpabort                    */
-	.long  0x7c0004ac    /* <+4444>:  hwsync                     */
-	.long  0x7c0004ac    /* <+4448>:  hwsync                     */
-	.long  0x7c0004ac    /* <+4452>:  hwsync                     */
-	.long  0x7c2004ac    /* <+4456>:  lwsync                     */
-	.long  0x7c2004ac    /* <+4460>:  lwsync                     */
-	.long  0x7c4004ac    /* <+4464>:  ptesync                    */
-	.long  0x7c4004ac    /* <+4468>:  ptesync                    */
-	.long  0x7e8004cc    /* <+4472>:  ldat    r20,0,0            */
-	.long  0x7e8ae4cc    /* <+4476>:  ldat    r20,r10,28         */
-	.long  0x7ea0048c    /* <+4480>:  lwat    r21,0,0            */
-	.long  0x7eabe48c    /* <+4484>:  lwat    r21,r11,28         */
-	.long  0x7ec005cc    /* <+4488>:  stdat   r22,0,0            */
-	.long  0x7ecce5cc    /* <+4492>:  stdat   r22,r12,28         */
-	.long  0x7ee0058c    /* <+4496>:  stwat   r23,0,0            */
-	.long  0x7eede58c    /* <+4500>:  stwat   r23,r13,28         */
-	.long  0x4c000264    /* <+4504>:  urfid                      */
-	.long  0x7c00f6e4    /* <+4508>:  rmieg   r30                */
-	.long  0x7d407a6a    /* <+4512>:  ldmx    r10,0,r15          */
-	.long  0x7d437a6a    /* <+4516>:  ldmx    r10,r3,r15         */
-	.long  0x4c0002e4    /* <+4520>:  stop                       */
-	.long  0x7c00003c    /* <+4524>:  wait                       */
-	.long  0x7c00003c    /* <+4528>:  wait                       */
-	.long  0x7c6005e6    /* <+4532>:  darn    r3,0               */
-	.long  0x7c6105e6    /* <+4536>:  darn    r3,1               */
-	.long  0x7c6205e6    /* <+4540>:  darn    r3,2               */
-	.long  0x7c000480    /* <+4544>:  mcrxrx  cr0                */
-	.long  0x7f800480    /* <+4548>:  mcrxrx  cr7                */
-	.long  0x1295b744    /* <+4552>:  vslv    v20,v21,v22        */
-	.long  0x12f8cf04    /* <+4556>:  vsrv    v23,v24,v25        */
-	.long  0x7c0006ec    /* <+4560>:  msgsync                    */
-	.long  0xf3c8901e    /* <+4564>:  xscmpeqdp vs30,vs40,vs50   */
-	.long  0xf3e9985e    /* <+4568>:  xscmpgtdp vs31,vs41,vs51   */
-	.long  0xf00aa09f    /* <+4572>:  xscmpgedp vs32,vs42,vs52   */
-	.long  0xf04cb447    /* <+4576>:  xsmincdp vs34,vs44,vs54    */
-	.long  0xf06dbc07    /* <+4580>:  xsmaxcdp vs35,vs45,vs55    */
-	.long  0xf08ec4c7    /* <+4584>:  xsminjdp vs36,vs46,vs56    */
-	.long  0xf0afcc87    /* <+4588>:  xsmaxjdp vs37,vs47,vs57    */
-	.long  0x1295b5e3    /* <+4592>:  vmsumudm v20,v21,v22,v23   */
-	.long  0x7d6c6954    /* <+4596>:  addex   r11,r12,r13,0      */
-	.long  0x7d6c6b54    /* <+4600>:  addex   r11,r12,r13,1      */
-	.long  0x7d6c6d54    /* <+4604>:  addex   r11,r12,r13,2      */
-	.long  0xff20048e    /* <+4608>:  mffs    f25                */
-	.long  0xff20048f    /* <+4612>:  mffs.   f25                */
-	.long  0xff41048e    /* <+4616>:  mffsce  f26                */
-	.long  0xff74a48e    /* <+4620>:  mffscdrn f27,f20           */
-	.long  0xff95048e    /* <+4624>:  mffscdrni f28,0            */
-	.long  0xff953c8e    /* <+4628>:  mffscdrni f28,7            */
-	.long  0xffb6ac8e    /* <+4632>:  mffscrn f29,f21            */
-	.long  0xffd7048e    /* <+4636>:  mffscrni f30,0             */
-	.long  0xffd71c8e    /* <+4640>:  mffscrni f30,3             */
-	.long  0xfff8048e    /* <+4644>:  mffsl   f31                */
-	.long  0x7d4006a4    /* <+4648>:  slbiag  r10                */
-
-## altivec3.d
-	.long  0x117e0001    /* <+4652>:  vmul10cuq v11,v30          */
-	.long  0x13c1b807    /* <+4656>:  vcmpneb v30,v1,v23         */
-	.long  0x13d3f77b    /* <+4660>:  vpermr  v30,v19,v30,v29    */
-	.long  0x12948841    /* <+4664>:  vmul10ecuq v20,v20,v17     */
-	.long  0x1373f847    /* <+4668>:  vcmpneh v27,v19,v31        */
-	.long  0x10c9b885    /* <+4672>:  vrlwmi  v6,v9,v23          */
-	.long  0x12da0887    /* <+4676>:  vcmpnew v22,v26,v1         */
-	.long  0x131ec8c5    /* <+4680>:  vrldmi  v24,v30,v25        */
-	.long  0x127db107    /* <+4684>:  vcmpnezb v19,v29,v22       */
-	.long  0x11179947    /* <+4688>:  vcmpnezh v8,v23,v19        */
-	.long  0x13785985    /* <+4692>:  vrlwnm  v27,v24,v11        */
-	.long  0x12ad5187    /* <+4696>:  vcmpnezw v21,v13,v10       */
-	.long  0x10b4e9c5    /* <+4700>:  vrldnm  v5,v20,v29         */
-	.long  0x13d30201    /* <+4704>:  vmul10uq v30,v19           */
-	.long  0x130caa0d    /* <+4708>:  vextractub v24,v21,12      */
-	.long  0x1013e241    /* <+4712>:  vmul10euq v0,v19,v28       */
-	.long  0x114c1a4d    /* <+4716>:  vextractuh v10,v3,12       */
-	.long  0x1387628d    /* <+4720>:  vextractuw v28,v12,7       */
-	.long  0x13c1dacd    /* <+4724>:  vextractd v30,v27,1        */
-	.long  0x1324fb0d    /* <+4728>:  vinsertb v25,v31,4         */
-	.long  0x12aef341    /* <+4732>:  bcdcpsgn. v21,v14,v30      */
-	.long  0x12c5934d    /* <+4736>:  vinserth v22,v18,5         */
-	.long  0x13a1b38d    /* <+4740>:  vinsertw v29,v22,1         */
-	.long  0x13a76bcd    /* <+4744>:  vinsertd v29,v13,7         */
-	.long  0x12d94407    /* <+4748>:  vcmpneb. v22,v25,v8        */
-	.long  0x120fac47    /* <+4752>:  vcmpneh. v16,v15,v21       */
-	.long  0x12d5fc81    /* <+4756>:  bcdus.  v22,v21,v31        */
-	.long  0x102c6487    /* <+4760>:  vcmpnew. v1,v12,v12        */
-	.long  0x10a346c1    /* <+4764>:  bcds.   v5,v3,v8,1         */
-	.long  0x13760d01    /* <+4768>:  bcdtrunc. v27,v22,v1,0     */
-	.long  0x105a0507    /* <+4772>:  vcmpnezb. v2,v26,v0        */
-	.long  0x134e3d41    /* <+4776>:  bcdutrunc. v26,v14,v7      */
-	.long  0x12056547    /* <+4780>:  vcmpnezh. v16,v5,v12       */
-	.long  0x13002d81    /* <+4784>:  bcdctsq. v24,v5            */
-	.long  0x10e20581    /* <+4788>:  bcdcfsq. v7,v0,0           */
-	.long  0x13c46781    /* <+4792>:  bcdctz. v30,v12,1          */
-	.long  0x1225bd81    /* <+4796>:  bcdctn. v17,v23            */
-	.long  0x10867f81    /* <+4800>:  bcdcfz. v4,v15,1           */
-	.long  0x13a72f81    /* <+4804>:  bcdcfn. v29,v5,1           */
-	.long  0x137f6581    /* <+4808>:  bcdsetsgn. v27,v12,0       */
-	.long  0x11dccd87    /* <+4812>:  vcmpnezw. v14,v28,v25      */
-	.long  0x104237c1    /* <+4816>:  bcdsr.  v2,v2,v6,1         */
-	.long  0x13202dcc    /* <+4820>:  vbpermd v25,v0,v5          */
-	.long  0x1380ce02    /* <+4824>:  vclzlsbb r28,v25           */
-	.long  0x1041c602    /* <+4828>:  vctzlsbb r2,v24            */
-	.long  0x12a65e02    /* <+4832>:  vnegw   v21,v11            */
-	.long  0x1227de02    /* <+4836>:  vnegd   v17,v27            */
-	.long  0x13e8be02    /* <+4840>:  vprtybw v31,v23            */
-	.long  0x12a9be02    /* <+4844>:  vprtybd v21,v23            */
-	.long  0x12aa9602    /* <+4848>:  vprtybq v21,v18            */
-	.long  0x13d02602    /* <+4852>:  vextsb2w v30,v4            */
-	.long  0x1071d602    /* <+4856>:  vextsh2w v3,v26            */
-	.long  0x11788e02    /* <+4860>:  vextsb2d v11,v17           */
-	.long  0x10b95602    /* <+4864>:  vextsh2d v5,v10            */
-	.long  0x11bace02    /* <+4868>:  vextsw2d v13,v25           */
-	.long  0x133c1602    /* <+4872>:  vctzb   v25,v2             */
-	.long  0x101d1e02    /* <+4876>:  vctzh   v0,v3              */
-	.long  0x12de3602    /* <+4880>:  vctzw   v22,v6             */
-	.long  0x135fc602    /* <+4884>:  vctzd   v26,v24            */
-	.long  0x10df160d    /* <+4888>:  vextublx r6,r31,v2         */
-	.long  0x11a0964d    /* <+4892>:  vextuhlx r13,r0,v18        */
-	.long  0x11defe8d    /* <+4896>:  vextuwlx r14,r30,v31       */
-	.long  0x11ec7704    /* <+4900>:  vsrv    v15,v12,v14        */
-	.long  0x128af70d    /* <+4904>:  vextubrx r20,r10,v30       */
-	.long  0x12b51744    /* <+4908>:  vslv    v21,v21,v2         */
-	.long  0x11e90f4d    /* <+4912>:  vextuhrx r15,r9,v1         */
-	.long  0x12b1878d    /* <+4916>:  vextuwrx r21,r17,v16       */
-	.long  0x1295b5e3    /* <+4920>:  vmsumudm v20,v21,v22,v23   */
-## vsx3.d
-	.long  0x7c46ca19    /* <+4924>:  lxvx    vs34,r6,r25        */
-	.long  0x7e805218    /* <+4928>:  lxvx    vs20,0,r10         */
-	.long  0x7e98521a    /* <+4932>:  lxvl    vs20,r24,r10       */
-	.long  0x7ec0ea1b    /* <+4936>:  lxvl    vs54,0,r29         */
-	.long  0x7f149a5a    /* <+4940>:  lxvll   vs24,r20,r19       */
-	.long  0x7c40725b    /* <+4944>:  lxvll   vs34,0,r14         */
-	.long  0x7ec20266    /* <+4948>:  mfvsrld r2,vs22            */
-	.long  0x7f5acad9    /* <+4952>:  lxvwsx  vs58,r26,r25       */
-	.long  0x7ee0ead9    /* <+4956>:  lxvwsx  vs55,0,r29         */
-	.long  0x7dd52318    /* <+4960>:  stxvx   vs14,r21,r4        */
-	.long  0x7fc0b318    /* <+4964>:  stxvx   vs30,0,r22         */
-	.long  0x7c1a231a    /* <+4968>:  stxvl   vs0,r26,r4         */
-	.long  0x7ca0b31b    /* <+4972>:  stxvl   vs37,0,r22         */
-	.long  0x7f0a0326    /* <+4976>:  mtvsrws vs24,r10           */
-	.long  0x7fd57b5a    /* <+4980>:  stxvll  vs30,r21,r15       */
-	.long  0x7ce0735b    /* <+4984>:  stxvll  vs39,0,r14         */
-	.long  0x7d862b66    /* <+4988>:  mtvsrdd vs12,r6,r5         */
-	.long  0x7cc0ab67    /* <+4992>:  mtvsrdd vs38,0,r21         */
-	.long  0x7f7c361b    /* <+4996>:  lxsibzx vs59,r28,r6        */
-	.long  0x7fc0461a    /* <+5000>:  lxsibzx vs30,0,r8          */
-	.long  0x7d578e59    /* <+5004>:  lxvh8x  vs42,r23,r17       */
-	.long  0x7c802e59    /* <+5008>:  lxvh8x  vs36,0,r5          */
-	.long  0x7d895e5a    /* <+5012>:  lxsihzx vs12,r9,r11        */
-	.long  0x7e206e5b    /* <+5016>:  lxsihzx vs49,0,r13         */
-	.long  0x7ca39ed9    /* <+5020>:  lxvb16x vs37,r3,r19        */
-	.long  0x7c00f6d8    /* <+5024>:  lxvb16x vs0,0,r30          */
-	.long  0x7c5e371a    /* <+5028>:  stxsibx vs2,r30,r6         */
-	.long  0x7d806f1a    /* <+5032>:  stxsibx vs12,0,r13         */
-	.long  0x7e1d4758    /* <+5036>:  stxvh8x vs16,r29,r8        */
-	.long  0x7ee05759    /* <+5040>:  stxvh8x vs55,0,r10         */
-	.long  0x7c42bf5b    /* <+5044>:  stxsihx vs34,r2,r23        */
-	.long  0x7f80bf5b    /* <+5048>:  stxsihx vs60,0,r23         */
-	.long  0x7eee67d8    /* <+5052>:  stxvb16x vs23,r14,r12      */
-	.long  0x7e602fd8    /* <+5056>:  stxvb16x vs19,0,r5         */
-	.long  0xe7000002    /* <+5060>:  lxsd    v24,0(0)           */
-	.long  0xe5f50012    /* <+5064>:  lxsd    v15,16(r21)        */
-	.long  0xe4c00003    /* <+5068>:  lxssp   v6,0(0)            */
-	.long  0xe6e90013    /* <+5072>:  lxssp   v23,16(r9)         */
-	.long  0xf253081e    /* <+5076>:  xscmpeqdp vs18,vs51,vs33   */
-	.long  0xf05a105a    /* <+5080>:  xscmpgtdp vs2,vs26,vs34    */
-	.long  0xf0baa098    /* <+5084>:  xscmpgedp vs5,vs26,vs20    */
-	.long  0xf18a58d3    /* <+5088>:  xxperm  vs44,vs10,vs43     */
-	.long  0xf13429d1    /* <+5092>:  xxpermr vs41,vs20,vs5      */
-	.long  0xf212b9da    /* <+5096>:  xscmpexpdp cr4,vs18,vs55   */
-	.long  0xf2e32a96    /* <+5100>:  xxextractuw vs23,vs37,3    */
-	.long  0xf2c75ad1    /* <+5104>:  xxspltib vs54,235          */
-	.long  0xf1e4f2d4    /* <+5108>:  xxinsertw vs15,vs30,4      */
-	.long  0xf18b3c00    /* <+5112>:  xsmaxcdp vs12,vs11,vs7     */
-	.long  0xf019c441    /* <+5116>:  xsmincdp vs32,vs25,vs24    */
-	.long  0xf3356484    /* <+5120>:  xsmaxjdp vs25,vs53,vs12    */
-	.long  0xf17f24aa    /* <+5124>:  xststdcsp cr2,vs36,127     */
-	.long  0xf0156cc3    /* <+5128>:  xsminjdp vs32,vs21,vs45    */
-	.long  0xf220956e    /* <+5132>:  xsxexpdp r17,vs50          */
-	.long  0xf0e1456e    /* <+5136>:  xsxsigdp r7,vs40           */
-	.long  0xf2d0156f    /* <+5140>:  xscvhpdp vs54,vs34         */
-	.long  0xf351b56f    /* <+5144>:  xscvdphp vs58,vs54         */
-	.long  0xf07f35aa    /* <+5148>:  xststdcdp cr0,vs38,127     */
-	.long  0xf31faeef    /* <+5152>:  xvtstdcsp vs56,vs53,127    */
-	.long  0xf2d4a6c3    /* <+5156>:  xviexpsp vs54,vs20,vs52    */
-	.long  0xf33cef2d    /* <+5160>:  xsiexpdp vs57,r28,r29      */
-	.long  0xf020a76c    /* <+5164>:  xvxexpdp vs1,vs20          */
-	.long  0xf2c1df6f    /* <+5168>:  xvxsigdp vs54,vs59         */
-	.long  0xf2472f6e    /* <+5172>:  xxbrh   vs18,vs37          */
-	.long  0xf1c80f6c    /* <+5176>:  xvxexpsp vs14,vs1          */
-	.long  0xf2896f6d    /* <+5180>:  xvxsigsp vs52,vs13         */
-	.long  0xf26f2f6c    /* <+5184>:  xxbrw   vs19,vs5           */
-	.long  0xf277bf6f    /* <+5188>:  xxbrd   vs51,vs55          */
-	.long  0xf0788f6d    /* <+5192>:  xvcvhpsp vs35,vs17         */
-	.long  0xf1f96f6e    /* <+5196>:  xvcvsphp vs15,vs45         */
-	.long  0xf23fff6c    /* <+5200>:  xxbrq   vs17,vs31          */
-	.long  0xf21f67ec    /* <+5204>:  xvtstdcdp vs16,vs12,127    */
-	.long  0xf36947c0    /* <+5208>:  xviexpdp vs27,vs9,vs8      */
-	.long  0xf4800001    /* <+5212>:  lxv     vs4,0(0)           */
-	.long  0xf5140019    /* <+5216>:  lxv     vs40,16(r20)       */
-	.long  0xf640000d    /* <+5220>:  stxv    vs50,0(0)          */
-	.long  0xf5100015    /* <+5224>:  stxv    vs8,16(r16)        */
-	.long  0xf4600002    /* <+5228>:  stxsd   v3,0(0)            */
-	.long  0xf6220012    /* <+5232>:  stxsd   v17,16(r2)         */
-	.long  0xf5a00003    /* <+5236>:  stxssp  v13,0(0)           */
-	.long  0xf62d0013    /* <+5240>:  stxssp  v17,16(r13)        */
-	.long  0xfd0a9008    /* <+5244>:  xsaddqp v8,v10,v18         */
-	.long  0xfca1e809    /* <+5248>:  xsaddqpo v5,v1,v29         */
-	.long  0xfd80960a    /* <+5252>:  xsrqpi  0,v12,v18,3        */
-	.long  0xffe1980b    /* <+5256>:  xsrqpix 1,v31,v19,0        */
-	.long  0xfdc13048    /* <+5260>:  xsmulqp v14,v1,v6          */
-	.long  0xfe27d849    /* <+5264>:  xsmulqpo v17,v7,v27        */
-	.long  0xfc80584a    /* <+5268>:  xsrqpxp 0,v4,v11,0         */
-	.long  0xffb7e0c8    /* <+5272>:  xscpsgnqp v29,v23,v28      */
-	.long  0xff8dd908    /* <+5276>:  xscmpoqp cr7,v13,v27       */
-	.long  0xfe953148    /* <+5280>:  xscmpexpqp cr5,v21,v6      */
-	.long  0xfc532308    /* <+5284>:  xsmaddqp v2,v19,v4         */
-	.long  0xffc78309    /* <+5288>:  xsmaddqpo v30,v7,v16       */
-	.long  0xfebe7b48    /* <+5292>:  xsmsubqp v21,v30,v15       */
-	.long  0xfd91f349    /* <+5296>:  xsmsubqpo v12,v17,v30      */
-	.long  0xfcde6388    /* <+5300>:  xsnmaddqp v6,v30,v12       */
-	.long  0xfd966389    /* <+5304>:  xsnmaddqpo v12,v22,v12     */
-	.long  0xfd5ddbc8    /* <+5308>:  xsnmsubqp v10,v29,v27      */
-	.long  0xffbd6bc9    /* <+5312>:  xsnmsubqpo v29,v29,v13     */
-	.long  0xfe7b2408    /* <+5316>:  xssubqp v19,v27,v4         */
-	.long  0xfda80c09    /* <+5320>:  xssubqpo v13,v8,v1         */
-	.long  0xfd03dc48    /* <+5324>:  xsdivqp v8,v3,v27          */
-	.long  0xff14dc49    /* <+5328>:  xsdivqpo v24,v20,v27       */
-	.long  0xff8e2508    /* <+5332>:  xscmpuqp cr7,v14,v4        */
-	.long  0xfe7f1588    /* <+5336>:  xststdcqp cr4,v2,127       */
-	.long  0xffe0b648    /* <+5340>:  xsabsqp v31,v22            */
-	.long  0xff221e48    /* <+5344>:  xsxexpqp v25,v3            */
-	.long  0xfd48e648    /* <+5348>:  xsnabsqp v10,v28           */
-	.long  0xfe70fe48    /* <+5352>:  xsnegqp v19,v31            */
-	.long  0xfd726e48    /* <+5356>:  xsxsigqp v11,v13           */
-	.long  0xfdbb7648    /* <+5360>:  xssqrtqp v13,v14           */
-	.long  0xfc3bde49    /* <+5364>:  xssqrtqpo v1,v27           */
-	.long  0xfc613e88    /* <+5368>:  xscvqpuwz v3,v7            */
-	.long  0xfe829688    /* <+5372>:  xscvudqp v20,v18           */
-	.long  0xffa9ee88    /* <+5376>:  xscvqpswz v29,v29          */
-	.long  0xfc4ae688    /* <+5380>:  xscvsdqp v2,v28            */
-	.long  0xfef12688    /* <+5384>:  xscvqpudz v23,v4           */
-	.long  0xfc74a688    /* <+5388>:  xscvqpdp v3,v20            */
-	.long  0xfc341e89    /* <+5392>:  xscvqpdpo v1,v3            */
-	.long  0xfe766688    /* <+5396>:  xscvdpqp v19,v12           */
-	.long  0xfdb92688    /* <+5400>:  xscvqpsdz v13,v4           */
-	.long  0xfcf83ec8    /* <+5404>:  xsiexpqp v7,v24,v7         */
diff --git a/gdb/testsuite/gdb.arch/powerpc-altivec.exp b/gdb/testsuite/gdb.arch/powerpc-altivec.exp
new file mode 100644
index 0000000..acbb113
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-altivec.exp
@@ -0,0 +1,257 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu altivec"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "dss     3"
+func_check "dssall"
+func_check "dst     r5,r4,1"
+func_check "dstt    r8,r7,0"
+func_check "dstst   r5,r6,3"
+func_check "dststt  r4,r5,2"
+func_check "lvebx   v30,r22,r24"
+func_check "lvebx   v21,0,r24"
+func_check "lvehx   v10,r16,r2"
+func_check "lvehx   v20,0,r23"
+func_check "lvewx   v17,r4,r18"
+func_check "lvewx   v23,0,r8"
+func_check "lvsl    v6,0,r25"
+func_check "lvsl    v2,0,r6"
+func_check "lvsr    v22,r16,r12"
+func_check "lvsr    v0,0,r29"
+func_check "lvxl    v15,r5,r13"
+func_check "lvxl    v19,0,r23"
+func_check "lvx     v22,r1,r2"
+func_check "lvx     v18,0,r17"
+func_check "mfvrsave r31"
+func_check "mfvscr  v24"
+func_check "mtvrsave r10"
+func_check "mtvscr  v25"
+func_check "stvebx  v18,r27,r10"
+func_check "stvebx  v16,0,r6"
+func_check "stvehx  v17,r13,r16"
+func_check "stvehx  v23,0,r20"
+func_check "stvewx  v11,r19,r31"
+func_check "stvewx  v31,0,r1"
+func_check "stvxl   v26,r21,r17"
+func_check "stvxl   v13,0,r22"
+func_check "stvx    v11,r31,r31"
+func_check "stvx    v30,0,r16"
+func_check "vaddcuw v24,v7,v28"
+func_check "vaddfp  v3,v30,v11"
+func_check "vaddsbs v8,v28,v9"
+func_check "vaddshs v7,v5,v4"
+func_check "vaddsws v22,v26,v27"
+func_check "vaddubm v16,v14,v28"
+func_check "vaddubs v6,v1,v25"
+func_check "vadduhm v2,v4,v6"
+func_check "vadduhs v26,v21,v8"
+func_check "vadduwm v29,v31,v1"
+func_check "vadduws v23,v13,v4"
+func_check "vandc   v30,v16,v9"
+func_check "vand    v3,v13,v27"
+func_check "vavgsb  v4,v6,v17"
+func_check "vavgsh  v23,v28,v19"
+func_check "vavgsw  v8,v15,v31"
+func_check "vavgub  v6,v7,v25"
+func_check "vavguh  v25,v22,v10"
+func_check "vavguw  v3,v23,v29"
+func_check "vctsxs  v14,v2,6"
+func_check "vctuxs  v9,v31,20"
+func_check "vcfsx   v24,v30,3"
+func_check "vcfux   v17,v21,29"
+func_check "vcmpbfp v18,v28,v0"
+func_check "vcmpbfp\. v19,v26,v3"
+func_check "vcmpeqfp v16,v2,v11"
+func_check "vcmpeqfp\. v23,v13,v13"
+func_check "vcmpequb v25,v19,v10"
+func_check "vcmpequb\. v18,v11,v2"
+func_check "vcmpequh v9,v25,v7"
+func_check "vcmpequh\. v14,v24,v21"
+func_check "vcmpequw v24,v12,v5"
+func_check "vcmpequw\. v19,v16,v1"
+func_check "vcmpgefp v23,v17,v16"
+func_check "vcmpgefp\. v19,v29,v17"
+func_check "vcmpgtfp v16,v28,v13"
+func_check "vcmpgtfp\. v14,v24,v7"
+func_check "vcmpgtsb v16,v22,v6"
+func_check "vcmpgtsb\. v2,v12,v14"
+func_check "vcmpgtsh v28,v3,v29"
+func_check "vcmpgtsh\. v16,v19,v13"
+func_check "vcmpgtsw v15,v0,v5"
+func_check "vcmpgtsw\. v21,v13,v0"
+func_check "vcmpgtub v5,v10,v30"
+func_check "vcmpgtub\. v7,v13,v10"
+func_check "vcmpgtuh v24,v15,v16"
+func_check "vcmpgtuh\. v25,v21,v27"
+func_check "vcmpgtuw v17,v27,v6"
+func_check "vcmpgtuw\. v8,v21,v27"
+func_check "vcfsx   v1,v1,14"
+func_check "vctsxs  v4,v15,25"
+func_check "vctuxs  v28,v23,14"
+func_check "vcfux   v6,v6,0"
+func_check "vexptefp v0,v8"
+func_check "vlogefp v22,v27"
+func_check "vmaddfp v23,v18,v5,v18"
+func_check "vmaxfp  v13,v13,v27"
+func_check "vmaxsb  v8,v23,v14"
+func_check "vmaxsh  v19,v17,v0"
+func_check "vmaxsw  v19,v3,v22"
+func_check "vmaxub  v23,v30,v28"
+func_check "vmaxuh  v9,v20,v23"
+func_check "vmaxuw  v21,v19,v1"
+func_check "vmhaddshs v22,v13,v5,v22"
+func_check "vmhraddshs v31,v0,v3,v18"
+func_check "vminfp  v2,v21,v24"
+func_check "vminsb  v20,v6,v10"
+func_check "vminsh  v18,v27,v26"
+func_check "vminsw  v3,v4,v1"
+func_check "vminub  v7,v0,v13"
+func_check "vminuh  v0,v12,v6"
+func_check "vminuw  v6,v3,v1"
+func_check "vmladduhm v3,v29,v3,v26"
+func_check "vmrghb  v21,v5,v31"
+func_check "vmrghh  v21,v24,v0"
+func_check "vmrghw  v16,v0,v22"
+func_check "vmrglb  v1,v17,v16"
+func_check "vmrglh  v14,v8,v15"
+func_check "vmrglw  v31,v21,v5"
+func_check "vmr     v24,v9"
+func_check "vmr     v24,v9"
+func_check "vmsummbm v0,v24,v15,v23"
+func_check "vmsumshm v1,v4,v7,v25"
+func_check "vmsumshs v9,v8,v13,v31"
+func_check "vmsumubm v23,v31,v12,v30"
+func_check "vmsumuhm v29,v0,v26,v21"
+func_check "vmsumuhs v27,v14,v25,v5"
+func_check "vmulesb v10,v25,v14"
+func_check "vmulesh v1,v18,v8"
+func_check "vmuleub v17,v14,v9"
+func_check "vmuleuh v5,v26,v9"
+func_check "vmulosb v21,v18,v6"
+func_check "vmulosh v4,v5,v8"
+func_check "vmuloub v2,v9,v19"
+func_check "vmulouh v29,v5,v4"
+func_check "vnmsubfp v8,v2,v6,v5"
+func_check "vnor    v31,v9,v10"
+func_check "vnot    v25,v31"
+func_check "vnot    v25,v31"
+func_check "vor     v23,v7,v2"
+func_check "vperm   v0,v28,v22,v25"
+func_check "vpkpx   v16,v25,v17"
+func_check "vpkshss v12,v16,v17"
+func_check "vpkshus v1,v19,v23"
+func_check "vpkswss v25,v7,v13"
+func_check "vpkswus v4,v24,v10"
+func_check "vpkuhum v9,v27,v12"
+func_check "vpkuhus v22,v10,v25"
+func_check "vpkuwum v30,v18,v0"
+func_check "vpkuwus v7,v3,v22"
+func_check "vrefp   v24,v28"
+func_check "vrfim   v17,v19"
+func_check "vrfin   v24,v25"
+func_check "vrfip   v3,v5"
+func_check "vrfiz   v8,v10"
+func_check "vrlb    v26,v18,v30"
+func_check "vrlh    v16,v17,v25"
+func_check "vrlw    v23,v30,v9"
+func_check "vrsqrtefp v2,v18"
+func_check "vsel    v20,v14,v18,v10"
+func_check "vslb    v25,v25,v12"
+func_check "vsldoi  v9,v9,v12,7"
+func_check "vslh    v14,v2,v11"
+func_check "vslo    v30,v5,v6"
+func_check "vsl     v22,v30,v9"
+func_check "vslw    v26,v26,v3"
+func_check "vspltb  v1,v20,6"
+func_check "vsplth  v16,v18,3"
+func_check "vspltisb v25,-13"
+func_check "vspltish v22,10"
+func_check "vspltisw v13,13"
+func_check "vspltw  v9,v18,2"
+func_check "vsrab   v14,v22,v0"
+func_check "vsrah   v12,v12,v18"
+func_check "vsraw   v2,v2,v13"
+func_check "vsrb    v7,v27,v5"
+func_check "vsrh    v7,v11,v29"
+func_check "vsro    v18,v30,v31"
+func_check "vsr     v2,v9,v28"
+func_check "vsrw    v0,v25,v0"
+func_check "vsubcuw v24,v2,v10"
+func_check "vsubfp  v22,v24,v20"
+func_check "vsubsbs v10,v22,v13"
+func_check "vsubshs v24,v17,v28"
+func_check "vsubsws v10,v26,v0"
+func_check "vsububm v16,v11,v24"
+func_check "vsububs v11,v21,v1"
+func_check "vsubuhm v6,v12,v24"
+func_check "vsubuhs v30,v11,v9"
+func_check "vsubuwm v19,v20,v13"
+func_check "vsubuws v18,v25,v6"
+func_check "vsum2sws v25,v10,v18"
+func_check "vsum4sbs v13,v16,v21"
+func_check "vsum4shs v23,v8,v4"
+func_check "vsum4ubs v28,v13,v30"
+func_check "vsumsws v22,v10,v8"
+func_check "vupkhpx v24,v14"
+func_check "vupkhsb v2,v22"
+func_check "vupkhsh v16,v2"
+func_check "vupklpx v10,v26"
+func_check "vupklsb v15,v28"
+func_check "vupklsh v8,v8"
+func_check "vxor    v25,v0,v3"
diff --git a/gdb/testsuite/gdb.arch/powerpc-altivec.s b/gdb/testsuite/gdb.arch/powerpc-altivec.s
new file mode 100644
index 0000000..8e10a4e
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-altivec.s
@@ -0,0 +1,217 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7c60066c    /* dss     3                  */
+	.long  0x7e00066c    /* dssall                     */
+	.long  0x7c2522ac    /* dst     r5,r4,1            */
+	.long  0x7e083aac    /* dstt    r8,r7,0            */
+	.long  0x7c6532ec    /* dstst   r5,r6,3            */
+	.long  0x7e442aec    /* dststt  r4,r5,2            */
+	.long  0x7fd6c00e    /* lvebx   v30,r22,r24        */
+	.long  0x7ea0c00e    /* lvebx   v21,0,r24          */
+	.long  0x7d50104e    /* lvehx   v10,r16,r2         */
+	.long  0x7e80b84e    /* lvehx   v20,0,r23          */
+	.long  0x7e24908e    /* lvewx   v17,r4,r18         */
+	.long  0x7ee0408e    /* lvewx   v23,0,r8           */
+	.long  0x7cc0c80c    /* lvsl    v6,0,r25           */
+	.long  0x7c40300c    /* lvsl    v2,0,r6            */
+	.long  0x7ed0604c    /* lvsr    v22,r16,r12        */
+	.long  0x7c00e84c    /* lvsr    v0,0,r29           */
+	.long  0x7de56ace    /* lvxl    v15,r5,r13         */
+	.long  0x7e60bace    /* lvxl    v19,0,r23          */
+	.long  0x7ec110ce    /* lvx     v22,r1,r2          */
+	.long  0x7e4088ce    /* lvx     v18,0,r17          */
+	.long  0x7fe042a6    /* mfvrsave r31               */
+	.long  0x13000604    /* mfvscr  v24                */
+	.long  0x7d4043a6    /* mtvrsave r10               */
+	.long  0x1000ce44    /* mtvscr  v25                */
+	.long  0x7e5b510e    /* stvebx  v18,r27,r10        */
+	.long  0x7e00310e    /* stvebx  v16,0,r6           */
+	.long  0x7e2d814e    /* stvehx  v17,r13,r16        */
+	.long  0x7ee0a14e    /* stvehx  v23,0,r20          */
+	.long  0x7d73f98e    /* stvewx  v11,r19,r31        */
+	.long  0x7fe0098e    /* stvewx  v31,0,r1           */
+	.long  0x7f558bce    /* stvxl   v26,r21,r17        */
+	.long  0x7da0b3ce    /* stvxl   v13,0,r22          */
+	.long  0x7d7ff9ce    /* stvx    v11,r31,r31        */
+	.long  0x7fc081ce    /* stvx    v30,0,r16          */
+	.long  0x1307e180    /* vaddcuw v24,v7,v28         */
+	.long  0x107e580a    /* vaddfp  v3,v30,v11         */
+	.long  0x111c4b00    /* vaddsbs v8,v28,v9          */
+	.long  0x10e52340    /* vaddshs v7,v5,v4           */
+	.long  0x12dadb80    /* vaddsws v22,v26,v27        */
+	.long  0x120ee000    /* vaddubm v16,v14,v28        */
+	.long  0x10c1ca00    /* vaddubs v6,v1,v25          */
+	.long  0x10443040    /* vadduhm v2,v4,v6           */
+	.long  0x13554240    /* vadduhs v26,v21,v8         */
+	.long  0x13bf0880    /* vadduwm v29,v31,v1         */
+	.long  0x12ed2280    /* vadduws v23,v13,v4         */
+	.long  0x13d04c44    /* vandc   v30,v16,v9         */
+	.long  0x106ddc04    /* vand    v3,v13,v27         */
+	.long  0x10868d02    /* vavgsb  v4,v6,v17          */
+	.long  0x12fc9d42    /* vavgsh  v23,v28,v19        */
+	.long  0x110ffd82    /* vavgsw  v8,v15,v31         */
+	.long  0x10c7cc02    /* vavgub  v6,v7,v25          */
+	.long  0x13365442    /* vavguh  v25,v22,v10        */
+	.long  0x1077ec82    /* vavguw  v3,v23,v29         */
+	.long  0x11c613ca    /* vctsxs  v14,v2,6           */
+	.long  0x1134fb8a    /* vctuxs  v9,v31,20          */
+	.long  0x1303f34a    /* vcfsx   v24,v30,3          */
+	.long  0x123dab0a    /* vcfux   v17,v21,29         */
+	.long  0x125c03c6    /* vcmpbfp v18,v28,v0         */
+	.long  0x127a1fc6    /* vcmpbfp. v19,v26,v3        */
+	.long  0x120258c6    /* vcmpeqfp v16,v2,v11        */
+	.long  0x12ed6cc6    /* vcmpeqfp. v23,v13,v13      */
+	.long  0x13335006    /* vcmpequb v25,v19,v10       */
+	.long  0x124b1406    /* vcmpequb. v18,v11,v2       */
+	.long  0x11393846    /* vcmpequh v9,v25,v7         */
+	.long  0x11d8ac46    /* vcmpequh. v14,v24,v21      */
+	.long  0x130c2886    /* vcmpequw v24,v12,v5        */
+	.long  0x12700c86    /* vcmpequw. v19,v16,v1       */
+	.long  0x12f181c6    /* vcmpgefp v23,v17,v16       */
+	.long  0x127d8dc6    /* vcmpgefp. v19,v29,v17      */
+	.long  0x121c6ac6    /* vcmpgtfp v16,v28,v13       */
+	.long  0x11d83ec6    /* vcmpgtfp. v14,v24,v7       */
+	.long  0x12163306    /* vcmpgtsb v16,v22,v6        */
+	.long  0x104c7706    /* vcmpgtsb. v2,v12,v14       */
+	.long  0x1383eb46    /* vcmpgtsh v28,v3,v29        */
+	.long  0x12136f46    /* vcmpgtsh. v16,v19,v13      */
+	.long  0x11e02b86    /* vcmpgtsw v15,v0,v5         */
+	.long  0x12ad0786    /* vcmpgtsw. v21,v13,v0       */
+	.long  0x10aaf206    /* vcmpgtub v5,v10,v30        */
+	.long  0x10ed5606    /* vcmpgtub. v7,v13,v10       */
+	.long  0x130f8246    /* vcmpgtuh v24,v15,v16       */
+	.long  0x1335de46    /* vcmpgtuh. v25,v21,v27      */
+	.long  0x123b3286    /* vcmpgtuw v17,v27,v6        */
+	.long  0x1115de86    /* vcmpgtuw. v8,v21,v27       */
+	.long  0x102e0b4a    /* vcfsx   v1,v1,14           */
+	.long  0x10997bca    /* vctsxs  v4,v15,25          */
+	.long  0x138ebb8a    /* vctuxs  v28,v23,14         */
+	.long  0x10c0330a    /* vcfux   v6,v6,0            */
+	.long  0x1000418a    /* vexptefp v0,v8             */
+	.long  0x12c0d9ca    /* vlogefp v22,v27            */
+	.long  0x12f2916e    /* vmaddfp v23,v18,v5,v18     */
+	.long  0x11addc0a    /* vmaxfp  v13,v13,v27        */
+	.long  0x11177102    /* vmaxsb  v8,v23,v14         */
+	.long  0x12710142    /* vmaxsh  v19,v17,v0         */
+	.long  0x1263b182    /* vmaxsw  v19,v3,v22         */
+	.long  0x12fee002    /* vmaxub  v23,v30,v28        */
+	.long  0x1134b842    /* vmaxuh  v9,v20,v23         */
+	.long  0x12b30882    /* vmaxuw  v21,v19,v1         */
+	.long  0x12cd2da0    /* vmhaddshs v22,v13,v5,v22   */
+	.long  0x13e01ca1    /* vmhraddshs v31,v0,v3,v18   */
+	.long  0x1055c44a    /* vminfp  v2,v21,v24         */
+	.long  0x12865302    /* vminsb  v20,v6,v10         */
+	.long  0x125bd342    /* vminsh  v18,v27,v26        */
+	.long  0x10640b82    /* vminsw  v3,v4,v1           */
+	.long  0x10e06a02    /* vminub  v7,v0,v13          */
+	.long  0x100c3242    /* vminuh  v0,v12,v6          */
+	.long  0x10c30a82    /* vminuw  v6,v3,v1           */
+	.long  0x107d1ea2    /* vmladduhm v3,v29,v3,v26    */
+	.long  0x12a5f80c    /* vmrghb  v21,v5,v31         */
+	.long  0x12b8004c    /* vmrghh  v21,v24,v0         */
+	.long  0x1200b08c    /* vmrghw  v16,v0,v22         */
+	.long  0x1031810c    /* vmrglb  v1,v17,v16         */
+	.long  0x11c8794c    /* vmrglh  v14,v8,v15         */
+	.long  0x13f5298c    /* vmrglw  v31,v21,v5         */
+	.long  0x13094c84    /* vmr     v24,v9             */
+	.long  0x13094c84    /* vmr     v24,v9             */
+	.long  0x10187de5    /* vmsummbm v0,v24,v15,v23    */
+	.long  0x10243e68    /* vmsumshm v1,v4,v7,v25      */
+	.long  0x11286fe9    /* vmsumshs v9,v8,v13,v31     */
+	.long  0x12ff67a4    /* vmsumubm v23,v31,v12,v30   */
+	.long  0x13a0d566    /* vmsumuhm v29,v0,v26,v21    */
+	.long  0x136ec967    /* vmsumuhs v27,v14,v25,v5    */
+	.long  0x11597308    /* vmulesb v10,v25,v14        */
+	.long  0x10324348    /* vmulesh v1,v18,v8          */
+	.long  0x122e4a08    /* vmuleub v17,v14,v9         */
+	.long  0x10ba4a48    /* vmuleuh v5,v26,v9          */
+	.long  0x12b23108    /* vmulosb v21,v18,v6         */
+	.long  0x10854148    /* vmulosh v4,v5,v8           */
+	.long  0x10499808    /* vmuloub v2,v9,v19          */
+	.long  0x13a52048    /* vmulouh v29,v5,v4          */
+	.long  0x110229af    /* vnmsubfp v8,v2,v6,v5       */
+	.long  0x13e95504    /* vnor    v31,v9,v10         */
+	.long  0x133ffd04    /* vnot    v25,v31            */
+	.long  0x133ffd04    /* vnot    v25,v31            */
+	.long  0x12e71484    /* vor     v23,v7,v2          */
+	.long  0x101cb66b    /* vperm   v0,v28,v22,v25     */
+	.long  0x12198b0e    /* vpkpx   v16,v25,v17        */
+	.long  0x1190898e    /* vpkshss v12,v16,v17        */
+	.long  0x1033b90e    /* vpkshus v1,v19,v23         */
+	.long  0x132769ce    /* vpkswss v25,v7,v13         */
+	.long  0x1098514e    /* vpkswus v4,v24,v10         */
+	.long  0x113b600e    /* vpkuhum v9,v27,v12         */
+	.long  0x12cac88e    /* vpkuhus v22,v10,v25        */
+	.long  0x13d2004e    /* vpkuwum v30,v18,v0         */
+	.long  0x10e3b0ce    /* vpkuwus v7,v3,v22          */
+	.long  0x1300e10a    /* vrefp   v24,v28            */
+	.long  0x12209aca    /* vrfim   v17,v19            */
+	.long  0x1300ca0a    /* vrfin   v24,v25            */
+	.long  0x10602a8a    /* vrfip   v3,v5              */
+	.long  0x1100524a    /* vrfiz   v8,v10             */
+	.long  0x1352f004    /* vrlb    v26,v18,v30        */
+	.long  0x1211c844    /* vrlh    v16,v17,v25        */
+	.long  0x12fe4884    /* vrlw    v23,v30,v9         */
+	.long  0x1040914a    /* vrsqrtefp v2,v18           */
+	.long  0x128e92aa    /* vsel    v20,v14,v18,v10    */
+	.long  0x13396104    /* vslb    v25,v25,v12        */
+	.long  0x112961ec    /* vsldoi  v9,v9,v12,7        */
+	.long  0x11c25944    /* vslh    v14,v2,v11         */
+	.long  0x13c5340c    /* vslo    v30,v5,v6          */
+	.long  0x12de49c4    /* vsl     v22,v30,v9         */
+	.long  0x135a1984    /* vslw    v26,v26,v3         */
+	.long  0x1026a20c    /* vspltb  v1,v20,6           */
+	.long  0x1203924c    /* vsplth  v16,v18,3          */
+	.long  0x1333030c    /* vspltisb v25,-13           */
+	.long  0x12ca034c    /* vspltish v22,10            */
+	.long  0x11ad038c    /* vspltisw v13,13            */
+	.long  0x1122928c    /* vspltw  v9,v18,2           */
+	.long  0x11d60304    /* vsrab   v14,v22,v0         */
+	.long  0x118c9344    /* vsrah   v12,v12,v18        */
+	.long  0x10426b84    /* vsraw   v2,v2,v13          */
+	.long  0x10fb2a04    /* vsrb    v7,v27,v5          */
+	.long  0x10ebea44    /* vsrh    v7,v11,v29         */
+	.long  0x125efc4c    /* vsro    v18,v30,v31        */
+	.long  0x1049e2c4    /* vsr     v2,v9,v28          */
+	.long  0x10190284    /* vsrw    v0,v25,v0          */
+	.long  0x13025580    /* vsubcuw v24,v2,v10         */
+	.long  0x12d8a04a    /* vsubfp  v22,v24,v20        */
+	.long  0x11566f00    /* vsubsbs v10,v22,v13        */
+	.long  0x1311e740    /* vsubshs v24,v17,v28        */
+	.long  0x115a0780    /* vsubsws v10,v26,v0         */
+	.long  0x120bc400    /* vsububm v16,v11,v24        */
+	.long  0x11750e00    /* vsububs v11,v21,v1         */
+	.long  0x10ccc440    /* vsubuhm v6,v12,v24         */
+	.long  0x13cb4e40    /* vsubuhs v30,v11,v9         */
+	.long  0x12746c80    /* vsubuwm v19,v20,v13        */
+	.long  0x12593680    /* vsubuws v18,v25,v6         */
+	.long  0x132a9688    /* vsum2sws v25,v10,v18       */
+	.long  0x11b0af08    /* vsum4sbs v13,v16,v21       */
+	.long  0x12e82648    /* vsum4shs v23,v8,v4         */
+	.long  0x138df608    /* vsum4ubs v28,v13,v30       */
+	.long  0x12ca4788    /* vsumsws v22,v10,v8         */
+	.long  0x1300734e    /* vupkhpx v24,v14            */
+	.long  0x1040b20e    /* vupkhsb v2,v22             */
+	.long  0x1200124e    /* vupkhsh v16,v2             */
+	.long  0x1140d3ce    /* vupklpx v10,v26            */
+	.long  0x11e0e28e    /* vupklsb v15,v28            */
+	.long  0x110042ce    /* vupklsh v8,v8              */
+	.long  0x13201cc4    /* vxor    v25,v0,v3          */
diff --git a/gdb/testsuite/gdb.arch/powerpc-altivec2.exp b/gdb/testsuite/gdb.arch/powerpc-altivec2.exp
new file mode 100644
index 0000000..3e76157
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-altivec2.exp
@@ -0,0 +1,175 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu altivec"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "lvepxl  v3,0,r28"
+func_check "lvepxl  v19,r4,r18"
+func_check "lvepx   v27,0,r19"
+func_check "lvepx   v1,r25,r18"
+func_check "lvexbx  v31,0,r27"
+func_check "lvexbx  v28,r1,r12"
+func_check "lvexhx  v31,0,r14"
+func_check "lvexhx  v17,r16,r31"
+func_check "lvexwx  v22,0,r29"
+func_check "lvexwx  v23,r25,r5"
+func_check "lvsm    v3,0,r12"
+func_check "lvsm    v27,r29,r1"
+func_check "lvswxl  v7,0,r6"
+func_check "lvswxl  v7,r16,r8"
+func_check "lvswx   v14,0,r18"
+func_check "lvswx   v28,r28,r16"
+func_check "lvtlxl  v27,0,r12"
+func_check "lvtlxl  v27,r28,r0"
+func_check "lvtlx   v23,0,r25"
+func_check "lvtlx   v1,r25,r14"
+func_check "lvtrxl  v20,0,r24"
+func_check "lvtrxl  v22,r29,r24"
+func_check "lvtrx   v24,0,r8"
+func_check "lvtrx   v13,r23,r28"
+func_check "mvidsplt v12,r28,r12"
+func_check "mviwsplt v10,r27,r0"
+func_check "stvepxl v27,0,r13"
+func_check "stvepxl v2,r2,r31"
+func_check "stvepx  v3,0,r10"
+func_check "stvepx  v27,r28,r0"
+func_check "stvexbx v13,0,r6"
+func_check "stvexbx v13,r25,r3"
+func_check "stvexhx v22,0,r1"
+func_check "stvexhx v17,r14,r10"
+func_check "stvexwx v21,0,r27"
+func_check "stvexwx v31,r18,r1"
+func_check "stvflxl v26,0,r13"
+func_check "stvflxl v22,r13,r21"
+func_check "stvflx  v5,0,r9"
+func_check "stvflx  v21,r24,r1"
+func_check "stvfrxl v13,0,r10"
+func_check "stvfrxl v13,r17,r25"
+func_check "stvfrx  v17,0,r10"
+func_check "stvfrx  v8,r12,r31"
+func_check "stvswxl v18,0,r29"
+func_check "stvswxl v26,r14,r8"
+func_check "stvswx  v0,0,r15"
+func_check "stvswx  v13,r23,r7"
+func_check "vabsdub v6,v17,v16"
+func_check "vabsduh v21,v18,v4"
+func_check "vabsduw v25,v20,v9"
+func_check "vpermxor v6,v17,v20,v26"
+func_check "vaddeuqm v29,v26,v15,v28"
+func_check "vaddecuq v15,v8,v7,v24"
+func_check "vsubeuqm v2,v6,v21,v1"
+func_check "vsubecuq v29,v6,v0,v4"
+func_check "vmulouw v14,v9,v3"
+func_check "vmuluwm v24,v16,v18"
+func_check "vaddudm v10,v17,v17"
+func_check "vmaxud  v30,v25,v4"
+func_check "vrld    v10,v6,v28"
+func_check "vcmpequd v27,v7,v7"
+func_check "vadduqm v22,v16,v25"
+func_check "vaddcuq v1,v21,v29"
+func_check "vmulosw v20,v11,v19"
+func_check "vmaxsd  v24,v19,v1"
+func_check "vmuleuw v13,v27,v30"
+func_check "vminud  v9,v24,v17"
+func_check "vcmpgtud v10,v18,v28"
+func_check "vmulesw v0,v29,v22"
+func_check "vminsd  v13,v28,v1"
+func_check "vsrad   v10,v20,v5"
+func_check "vcmpgtsd v27,v21,v5"
+func_check "bcdadd\. v0,v23,v30,1"
+func_check "vpmsumb v25,v24,v26"
+func_check "bcdsub\. v8,v4,v4,1"
+func_check "vpmsumh v16,v14,v26"
+func_check "vpkudum v27,v2,v26"
+func_check "vpmsumw v6,v23,v17"
+func_check "vpmsumd v20,v6,v25"
+func_check "vpkudus v27,v22,v16"
+func_check "vsubudm v21,v20,v18"
+func_check "vsubuqm v21,v20,v18"
+func_check "vcipher v29,v29,v6"
+func_check "vcipherlast v2,v13,v20"
+func_check "vgbbd   v20,v18"
+func_check "vsubcuq v19,v8,v25"
+func_check "vorc    v9,v26,v29"
+func_check "vncipher v20,v20,v13"
+func_check "vncipherlast v15,v5,v27"
+func_check "vbpermq v3,v19,v6"
+func_check "vpksdus v30,v4,v28"
+func_check "vnand   v0,v4,v14"
+func_check "vsld    v17,v8,v29"
+func_check "vsbox   v29,v20"
+func_check "vpksdss v11,v7,v11"
+func_check "vcmpequd\. v3,v19,v16"
+func_check "vupkhsw v18,v17"
+func_check "vshasigmaw v29,v8,0,13"
+func_check "veqv    v23,v28,v26"
+func_check "vmrgew  v29,v0,v2"
+func_check "vmrgow  v29,v0,v2"
+func_check "vshasigmad v27,v19,0,0"
+func_check "vsrd    v20,v28,v28"
+func_check "vupklsw v18,v21"
+func_check "vclzb   v30,v7"
+func_check "vpopcntb v29,v21"
+func_check "vclzh   v25,v21"
+func_check "vpopcnth v16,v30"
+func_check "vclzw   v28,v3"
+func_check "vpopcntw v10,v9"
+func_check "vclzd   v22,v9"
+func_check "vpopcntd v15,v30"
+func_check "vcmpgtud\. v2,v31,v6"
+func_check "vcmpgtsd\. v20,v15,v2"
diff --git a/gdb/testsuite/gdb.arch/powerpc-altivec2.s b/gdb/testsuite/gdb.arch/powerpc-altivec2.s
new file mode 100644
index 0000000..67e068c
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-altivec2.s
@@ -0,0 +1,135 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7c60e20e    /* lvepxl  v3,0,r28           */
+	.long  0x7e64920e    /* lvepxl  v19,r4,r18         */
+	.long  0x7f609a4e    /* lvepx   v27,0,r19          */
+	.long  0x7c39924e    /* lvepx   v1,r25,r18         */
+	.long  0x7fe0da0a    /* lvexbx  v31,0,r27          */
+	.long  0x7f81620a    /* lvexbx  v28,r1,r12         */
+	.long  0x7fe0724a    /* lvexhx  v31,0,r14          */
+	.long  0x7e30fa4a    /* lvexhx  v17,r16,r31        */
+	.long  0x7ec0ea8a    /* lvexwx  v22,0,r29          */
+	.long  0x7ef92a8a    /* lvexwx  v23,r25,r5         */
+	.long  0x7c60660a    /* lvsm    v3,0,r12           */
+	.long  0x7f7d0e0a    /* lvsm    v27,r29,r1         */
+	.long  0x7ce036ca    /* lvswxl  v7,0,r6            */
+	.long  0x7cf046ca    /* lvswxl  v7,r16,r8          */
+	.long  0x7dc094ca    /* lvswx   v14,0,r18          */
+	.long  0x7f9c84ca    /* lvswx   v28,r28,r16        */
+	.long  0x7f60668a    /* lvtlxl  v27,0,r12          */
+	.long  0x7f7c068a    /* lvtlxl  v27,r28,r0         */
+	.long  0x7ee0cc8a    /* lvtlx   v23,0,r25          */
+	.long  0x7c39748a    /* lvtlx   v1,r25,r14         */
+	.long  0x7e80c64a    /* lvtrxl  v20,0,r24          */
+	.long  0x7eddc64a    /* lvtrxl  v22,r29,r24        */
+	.long  0x7f00444a    /* lvtrx   v24,0,r8           */
+	.long  0x7db7e44a    /* lvtrx   v13,r23,r28        */
+	.long  0x7d9c60dc    /* mvidsplt v12,r28,r12       */
+	.long  0x7d5b005c    /* mviwsplt v10,r27,r0        */
+	.long  0x7f606e0e    /* stvepxl v27,0,r13          */
+	.long  0x7c42fe0e    /* stvepxl v2,r2,r31          */
+	.long  0x7c60564e    /* stvepx  v3,0,r10           */
+	.long  0x7f7c064e    /* stvepx  v27,r28,r0         */
+	.long  0x7da0330a    /* stvexbx v13,0,r6           */
+	.long  0x7db91b0a    /* stvexbx v13,r25,r3         */
+	.long  0x7ec00b4a    /* stvexhx v22,0,r1           */
+	.long  0x7e2e534a    /* stvexhx v17,r14,r10        */
+	.long  0x7ea0db8a    /* stvexwx v21,0,r27          */
+	.long  0x7ff20b8a    /* stvexwx v31,r18,r1         */
+	.long  0x7f406f8a    /* stvflxl v26,0,r13          */
+	.long  0x7ecdaf8a    /* stvflxl v22,r13,r21        */
+	.long  0x7ca04d8a    /* stvflx  v5,0,r9            */
+	.long  0x7eb80d8a    /* stvflx  v21,r24,r1         */
+	.long  0x7da0574a    /* stvfrxl v13,0,r10          */
+	.long  0x7db1cf4a    /* stvfrxl v13,r17,r25        */
+	.long  0x7e20554a    /* stvfrx  v17,0,r10          */
+	.long  0x7d0cfd4a    /* stvfrx  v8,r12,r31         */
+	.long  0x7e40efca    /* stvswxl v18,0,r29          */
+	.long  0x7f4e47ca    /* stvswxl v26,r14,r8         */
+	.long  0x7c007dca    /* stvswx  v0,0,r15           */
+	.long  0x7db73dca    /* stvswx  v13,r23,r7         */
+	.long  0x10d18403    /* vabsdub v6,v17,v16         */
+	.long  0x12b22443    /* vabsduh v21,v18,v4         */
+	.long  0x13344c83    /* vabsduw v25,v20,v9         */
+	.long  0x10d1a6ad    /* vpermxor v6,v17,v20,v26    */
+	.long  0x13ba7f3c    /* vaddeuqm v29,v26,v15,v28   */
+	.long  0x11e83e3d    /* vaddecuq v15,v8,v7,v24     */
+	.long  0x1046a87e    /* vsubeuqm v2,v6,v21,v1      */
+	.long  0x13a6013f    /* vsubecuq v29,v6,v0,v4      */
+	.long  0x11c91888    /* vmulouw v14,v9,v3          */
+	.long  0x13109089    /* vmuluwm v24,v16,v18        */
+	.long  0x115188c0    /* vaddudm v10,v17,v17        */
+	.long  0x13d920c2    /* vmaxud  v30,v25,v4         */
+	.long  0x1146e0c4    /* vrld    v10,v6,v28         */
+	.long  0x136738c7    /* vcmpequd v27,v7,v7         */
+	.long  0x12d0c900    /* vadduqm v22,v16,v25        */
+	.long  0x1035e940    /* vaddcuq v1,v21,v29         */
+	.long  0x128b9988    /* vmulosw v20,v11,v19        */
+	.long  0x131309c2    /* vmaxsd  v24,v19,v1         */
+	.long  0x11bbf288    /* vmuleuw v13,v27,v30        */
+	.long  0x11388ac2    /* vminud  v9,v24,v17         */
+	.long  0x1152e2c7    /* vcmpgtud v10,v18,v28       */
+	.long  0x101db388    /* vmulesw v0,v29,v22         */
+	.long  0x11bc0bc2    /* vminsd  v13,v28,v1         */
+	.long  0x11542bc4    /* vsrad   v10,v20,v5         */
+	.long  0x13752bc7    /* vcmpgtsd v27,v21,v5        */
+	.long  0x1017f601    /* bcdadd. v0,v23,v30,1       */
+	.long  0x1338d408    /* vpmsumb v25,v24,v26        */
+	.long  0x11042641    /* bcdsub. v8,v4,v4,1         */
+	.long  0x120ed448    /* vpmsumh v16,v14,v26        */
+	.long  0x1362d44e    /* vpkudum v27,v2,v26         */
+	.long  0x10d78c88    /* vpmsumw v6,v23,v17         */
+	.long  0x1286ccc8    /* vpmsumd v20,v6,v25         */
+	.long  0x137684ce    /* vpkudus v27,v22,v16        */
+	.long  0x12b494c0    /* vsubudm v21,v20,v18        */
+	.long  0x12b49500    /* vsubuqm v21,v20,v18        */
+	.long  0x13bd3508    /* vcipher v29,v29,v6         */
+	.long  0x104da509    /* vcipherlast v2,v13,v20     */
+	.long  0x1280950c    /* vgbbd   v20,v18            */
+	.long  0x1268cd40    /* vsubcuq v19,v8,v25         */
+	.long  0x113aed44    /* vorc    v9,v26,v29         */
+	.long  0x12946d48    /* vncipher v20,v20,v13       */
+	.long  0x11e5dd49    /* vncipherlast v15,v5,v27    */
+	.long  0x1073354c    /* vbpermq v3,v19,v6          */
+	.long  0x13c4e54e    /* vpksdus v30,v4,v28         */
+	.long  0x10047584    /* vnand   v0,v4,v14          */
+	.long  0x1228edc4    /* vsld    v17,v8,v29         */
+	.long  0x13b405c8    /* vsbox   v29,v20            */
+	.long  0x11675dce    /* vpksdss v11,v7,v11         */
+	.long  0x107384c7    /* vcmpequd. v3,v19,v16       */
+	.long  0x12408e4e    /* vupkhsw v18,v17            */
+	.long  0x13a86e82    /* vshasigmaw v29,v8,0,13     */
+	.long  0x12fcd684    /* veqv    v23,v28,v26        */
+	.long  0x13a0178c    /* vmrgew  v29,v0,v2          */
+	.long  0x13a0168c    /* vmrgow  v29,v0,v2          */
+	.long  0x137306c2    /* vshasigmad v27,v19,0,0     */
+	.long  0x129ce6c4    /* vsrd    v20,v28,v28        */
+	.long  0x1240aece    /* vupklsw v18,v21            */
+	.long  0x13c03f02    /* vclzb   v30,v7             */
+	.long  0x13a0af03    /* vpopcntb v29,v21           */
+	.long  0x1320af42    /* vclzh   v25,v21            */
+	.long  0x1200f743    /* vpopcnth v16,v30           */
+	.long  0x13801f82    /* vclzw   v28,v3             */
+	.long  0x11404f83    /* vpopcntw v10,v9            */
+	.long  0x12c04fc2    /* vclzd   v22,v9             */
+	.long  0x11e0f7c3    /* vpopcntd v15,v30           */
+	.long  0x105f36c7    /* vcmpgtud. v2,v31,v6        */
+	.long  0x128f17c7    /* vcmpgtsd. v20,v15,v2       */
diff --git a/gdb/testsuite/gdb.arch/powerpc-altivec3.exp b/gdb/testsuite/gdb.arch/powerpc-altivec3.exp
new file mode 100644
index 0000000..a6d04e0
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-altivec3.exp
@@ -0,0 +1,128 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu altivec"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "vmul10cuq v11,v30"
+func_check "vcmpneb v30,v1,v23"
+func_check "vpermr  v30,v19,v30,v29"
+func_check "vmul10ecuq v20,v20,v17"
+func_check "vcmpneh v27,v19,v31"
+func_check "vrlwmi  v6,v9,v23"
+func_check "vcmpnew v22,v26,v1"
+func_check "vrldmi  v24,v30,v25"
+func_check "vcmpnezb v19,v29,v22"
+func_check "vcmpnezh v8,v23,v19"
+func_check "vrlwnm  v27,v24,v11"
+func_check "vcmpnezw v21,v13,v10"
+func_check "vrldnm  v5,v20,v29"
+func_check "vmul10uq v30,v19"
+func_check "vextractub v24,v21,12"
+func_check "vmul10euq v0,v19,v28"
+func_check "vextractuh v10,v3,12"
+func_check "vextractuw v28,v12,7"
+func_check "vextractd v30,v27,1"
+func_check "vinsertb v25,v31,4"
+func_check "bcdcpsgn\. v21,v14,v30"
+func_check "vinserth v22,v18,5"
+func_check "vinsertw v29,v22,1"
+func_check "vinsertd v29,v13,7"
+func_check "vcmpneb\. v22,v25,v8"
+func_check "vcmpneh\. v16,v15,v21"
+func_check "bcdus\.  v22,v21,v31"
+func_check "vcmpnew\. v1,v12,v12"
+func_check "bcds\.   v5,v3,v8,1"
+func_check "bcdtrunc\. v27,v22,v1,0"
+func_check "vcmpnezb\. v2,v26,v0"
+func_check "bcdutrunc\. v26,v14,v7"
+func_check "vcmpnezh\. v16,v5,v12"
+func_check "bcdctsq\. v24,v5"
+func_check "bcdcfsq\. v7,v0,0"
+func_check "bcdctz\. v30,v12,1"
+func_check "bcdctn\. v17,v23"
+func_check "bcdcfz\. v4,v15,1"
+func_check "bcdcfn\. v29,v5,1"
+func_check "bcdsetsgn\. v27,v12,0"
+func_check "vcmpnezw\. v14,v28,v25"
+func_check "bcdsr\.  v2,v2,v6,1"
+func_check "vbpermd v25,v0,v5"
+func_check "vclzlsbb r28,v25"
+func_check "vctzlsbb r2,v24"
+func_check "vnegw   v21,v11"
+func_check "vnegd   v17,v27"
+func_check "vprtybw v31,v23"
+func_check "vprtybd v21,v23"
+func_check "vprtybq v21,v18"
+func_check "vextsb2w v30,v4"
+func_check "vextsh2w v3,v26"
+func_check "vextsb2d v11,v17"
+func_check "vextsh2d v5,v10"
+func_check "vextsw2d v13,v25"
+func_check "vctzb   v25,v2"
+func_check "vctzh   v0,v3"
+func_check "vctzw   v22,v6"
+func_check "vctzd   v26,v24"
+func_check "vextublx r6,r31,v2"
+func_check "vextuhlx r13,r0,v18"
+func_check "vextuwlx r14,r30,v31"
+func_check "vsrv    v15,v12,v14"
+func_check "vextubrx r20,r10,v30"
+func_check "vslv    v21,v21,v2"
+func_check "vextuhrx r15,r9,v1"
+func_check "vextuwrx r21,r17,v16"
+func_check "vmsumudm v20,v21,v22,v23"
diff --git a/gdb/testsuite/gdb.arch/powerpc-altivec3.s b/gdb/testsuite/gdb.arch/powerpc-altivec3.s
new file mode 100644
index 0000000..bdc9ddc
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-altivec3.s
@@ -0,0 +1,88 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x117e0001    /* vmul10cuq v11,v30          */
+	.long  0x13c1b807    /* vcmpneb v30,v1,v23         */
+	.long  0x13d3f77b    /* vpermr  v30,v19,v30,v29    */
+	.long  0x12948841    /* vmul10ecuq v20,v20,v17     */
+	.long  0x1373f847    /* vcmpneh v27,v19,v31        */
+	.long  0x10c9b885    /* vrlwmi  v6,v9,v23          */
+	.long  0x12da0887    /* vcmpnew v22,v26,v1         */
+	.long  0x131ec8c5    /* vrldmi  v24,v30,v25        */
+	.long  0x127db107    /* vcmpnezb v19,v29,v22       */
+	.long  0x11179947    /* vcmpnezh v8,v23,v19        */
+	.long  0x13785985    /* vrlwnm  v27,v24,v11        */
+	.long  0x12ad5187    /* vcmpnezw v21,v13,v10       */
+	.long  0x10b4e9c5    /* vrldnm  v5,v20,v29         */
+	.long  0x13d30201    /* vmul10uq v30,v19           */
+	.long  0x130caa0d    /* vextractub v24,v21,12      */
+	.long  0x1013e241    /* vmul10euq v0,v19,v28       */
+	.long  0x114c1a4d    /* vextractuh v10,v3,12       */
+	.long  0x1387628d    /* vextractuw v28,v12,7       */
+	.long  0x13c1dacd    /* vextractd v30,v27,1        */
+	.long  0x1324fb0d    /* vinsertb v25,v31,4         */
+	.long  0x12aef341    /* bcdcpsgn. v21,v14,v30      */
+	.long  0x12c5934d    /* vinserth v22,v18,5         */
+	.long  0x13a1b38d    /* vinsertw v29,v22,1         */
+	.long  0x13a76bcd    /* vinsertd v29,v13,7         */
+	.long  0x12d94407    /* vcmpneb. v22,v25,v8        */
+	.long  0x120fac47    /* vcmpneh. v16,v15,v21       */
+	.long  0x12d5fc81    /* bcdus.  v22,v21,v31        */
+	.long  0x102c6487    /* vcmpnew. v1,v12,v12        */
+	.long  0x10a346c1    /* bcds.   v5,v3,v8,1         */
+	.long  0x13760d01    /* bcdtrunc. v27,v22,v1,0     */
+	.long  0x105a0507    /* vcmpnezb. v2,v26,v0        */
+	.long  0x134e3d41    /* bcdutrunc. v26,v14,v7      */
+	.long  0x12056547    /* vcmpnezh. v16,v5,v12       */
+	.long  0x13002d81    /* bcdctsq. v24,v5            */
+	.long  0x10e20581    /* bcdcfsq. v7,v0,0           */
+	.long  0x13c46781    /* bcdctz. v30,v12,1          */
+	.long  0x1225bd81    /* bcdctn. v17,v23            */
+	.long  0x10867f81    /* bcdcfz. v4,v15,1           */
+	.long  0x13a72f81    /* bcdcfn. v29,v5,1           */
+	.long  0x137f6581    /* bcdsetsgn. v27,v12,0       */
+	.long  0x11dccd87    /* vcmpnezw. v14,v28,v25      */
+	.long  0x104237c1    /* bcdsr.  v2,v2,v6,1         */
+	.long  0x13202dcc    /* vbpermd v25,v0,v5          */
+	.long  0x1380ce02    /* vclzlsbb r28,v25           */
+	.long  0x1041c602    /* vctzlsbb r2,v24            */
+	.long  0x12a65e02    /* vnegw   v21,v11            */
+	.long  0x1227de02    /* vnegd   v17,v27            */
+	.long  0x13e8be02    /* vprtybw v31,v23            */
+	.long  0x12a9be02    /* vprtybd v21,v23            */
+	.long  0x12aa9602    /* vprtybq v21,v18            */
+	.long  0x13d02602    /* vextsb2w v30,v4            */
+	.long  0x1071d602    /* vextsh2w v3,v26            */
+	.long  0x11788e02    /* vextsb2d v11,v17           */
+	.long  0x10b95602    /* vextsh2d v5,v10            */
+	.long  0x11bace02    /* vextsw2d v13,v25           */
+	.long  0x133c1602    /* vctzb   v25,v2             */
+	.long  0x101d1e02    /* vctzh   v0,v3              */
+	.long  0x12de3602    /* vctzw   v22,v6             */
+	.long  0x135fc602    /* vctzd   v26,v24            */
+	.long  0x10df160d    /* vextublx r6,r31,v2         */
+	.long  0x11a0964d    /* vextuhlx r13,r0,v18        */
+	.long  0x11defe8d    /* vextuwlx r14,r30,v31       */
+	.long  0x11ec7704    /* vsrv    v15,v12,v14        */
+	.long  0x128af70d    /* vextubrx r20,r10,v30       */
+	.long  0x12b51744    /* vslv    v21,v21,v2         */
+	.long  0x11e90f4d    /* vextuhrx r15,r9,v1         */
+	.long  0x12b1878d    /* vextuwrx r21,r17,v16       */
+	.long  0x1295b5e3    /* vmsumudm v20,v21,v22,v23   */
diff --git a/gdb/testsuite/gdb.arch/powerpc-power7.exp b/gdb/testsuite/gdb.arch/powerpc-power7.exp
new file mode 100644
index 0000000..68004f9
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-power7.exp
@@ -0,0 +1,161 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu power7"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "lxvd2x  vs3,r4,r5"
+func_check "lxvd2x  vs43,r4,r5"
+func_check "stxvd2x vs3,r4,r5"
+func_check "stxvd2x vs43,r4,r5"
+func_check "xxmrghd vs3,vs4,vs5"
+func_check "xxmrghd vs43,vs44,vs45"
+func_check "xxmrgld vs3,vs4,vs5"
+func_check "xxmrgld vs43,vs44,vs45"
+func_check "xxmrghd vs3,vs4,vs5"
+func_check "xxmrghd vs43,vs44,vs45"
+func_check "xxmrgld vs3,vs4,vs5"
+func_check "xxmrgld vs43,vs44,vs45"
+func_check "xxpermdi vs3,vs4,vs5,1"
+func_check "xxpermdi vs43,vs44,vs45,1"
+func_check "xxpermdi vs3,vs4,vs5,2"
+func_check "xxpermdi vs43,vs44,vs45,2"
+func_check "xvmovdp vs3,vs4"
+func_check "xvmovdp vs43,vs44"
+func_check "xvmovdp vs3,vs4"
+func_check "xvmovdp vs43,vs44"
+func_check "xvcpsgndp vs3,vs4,vs5"
+func_check "xvcpsgndp vs43,vs44,vs45"
+func_check "doze"
+func_check "nap"
+func_check "sleep"
+func_check "rvwinkle"
+func_check "prtyw   r3,r4"
+func_check "prtyd   r13,r14"
+func_check "mfcfar  r10"
+func_check "mtcfar  r11"
+func_check "cmpb    r3,r4,r5"
+func_check "lwzcix  r10,r11,r12"
+func_check "dadd    f16,f17,f18"
+func_check "daddq   f20,f22,f24"
+func_check "dss     3"
+func_check "dssall"
+func_check "dst     r5,r4,1"
+func_check "dstt    r8,r7,0"
+func_check "dstst   r5,r6,3"
+func_check "dststt  r4,r5,2"
+func_check "divwe   r10,r11,r12"
+func_check "divwe\.  r11,r12,r13"
+func_check "divweo  r12,r13,r14"
+func_check "divweo\. r13,r14,r15"
+func_check "divweu  r10,r11,r12"
+func_check "divweu\. r11,r12,r13"
+func_check "divweuo r12,r13,r14"
+func_check "divweuo\. r13,r14,r15"
+func_check "bpermd  r7,r17,r27"
+func_check "popcntw r10,r20"
+func_check "popcntd r10,r20"
+func_check "ldbrx   r20,r21,r22"
+func_check "stdbrx  r20,r21,r22"
+func_check "lfiwzx  f10,0,r10"
+func_check "lfiwzx  f10,r9,r10"
+func_check "fcfids  f4,f5"
+func_check "fcfids\. f4,f5"
+func_check "fcfidus f4,f5"
+func_check "fcfidus\. f4,f5"
+func_check "fctiwu  f4,f5"
+func_check "fctiwu\. f4,f5"
+func_check "fctiwuz f4,f5"
+func_check "fctiwuz\. f4,f5"
+func_check "fctidu  f4,f5"
+func_check "fctidu\. f4,f5"
+func_check "fctiduz f4,f5"
+func_check "fctiduz\. f4,f5"
+func_check "fcfidu  f4,f5"
+func_check "fcfidu\. f4,f5"
+func_check "ftdiv   cr0,f10,f11"
+func_check "ftdiv   cr7,f10,f11"
+func_check "ftsqrt  cr0,f10"
+func_check "ftsqrt  cr7,f10"
+func_check "dcbtt   r8,r9"
+func_check "dcbtstt r8,r9"
+func_check "dcffix  f10,f12"
+func_check "dcffix\. f20,f22"
+func_check "fre     f14,f15"
+func_check "fre\.    f14,f15"
+func_check "fres    f14,f15"
+func_check "fres\.   f14,f15"
+func_check "frsqrte f14,f15"
+func_check "frsqrte\. f14,f15"
+func_check "frsqrtes f14,f15"
+func_check "frsqrtes\. f14,f15"
+func_check "isel    r2,r3,r4,28"
+func_check "yield"
+func_check "yield"
+func_check "ori     r2,r2,0"
+func_check "nop"
+func_check "nop"
+func_check "ori     r2,r2,0"
+func_check "mdoio"
+func_check "mdoio"
+func_check "mdoom"
+func_check "mdoom"
+func_check "mfppr   r10"
+func_check "mfppr32 r11"
+func_check "mtppr   r12"
+func_check "mtppr32 r13"
+func_check "tlbie   r10,r11"
diff --git a/gdb/testsuite/gdb.arch/powerpc-power7.s b/gdb/testsuite/gdb.arch/powerpc-power7.s
new file mode 100644
index 0000000..cadb4a2
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-power7.s
@@ -0,0 +1,121 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7c642e98    /* lxvd2x  vs3,r4,r5          */
+	.long  0x7d642e99    /* lxvd2x  vs43,r4,r5         */
+	.long  0x7c642f98    /* stxvd2x vs3,r4,r5          */
+	.long  0x7d642f99    /* stxvd2x vs43,r4,r5         */
+	.long  0xf0642850    /* xxmrghd vs3,vs4,vs5        */
+	.long  0xf16c6857    /* xxmrghd vs43,vs44,vs45     */
+	.long  0xf0642b50    /* xxmrgld vs3,vs4,vs5        */
+	.long  0xf16c6b57    /* xxmrgld vs43,vs44,vs45     */
+	.long  0xf0642850    /* xxmrghd vs3,vs4,vs5        */
+	.long  0xf16c6857    /* xxmrghd vs43,vs44,vs45     */
+	.long  0xf0642b50    /* xxmrgld vs3,vs4,vs5        */
+	.long  0xf16c6b57    /* xxmrgld vs43,vs44,vs45     */
+	.long  0xf0642950    /* xxpermdi vs3,vs4,vs5,1     */
+	.long  0xf16c6957    /* xxpermdi vs43,vs44,vs45,1  */
+	.long  0xf0642a50    /* xxpermdi vs3,vs4,vs5,2     */
+	.long  0xf16c6a57    /* xxpermdi vs43,vs44,vs45,2  */
+	.long  0xf0642780    /* xvmovdp vs3,vs4            */
+	.long  0xf16c6787    /* xvmovdp vs43,vs44          */
+	.long  0xf0642780    /* xvmovdp vs3,vs4            */
+	.long  0xf16c6787    /* xvmovdp vs43,vs44          */
+	.long  0xf0642f80    /* xvcpsgndp vs3,vs4,vs5      */
+	.long  0xf16c6f87    /* xvcpsgndp vs43,vs44,vs45   */
+	.long  0x4c000324    /* doze                       */
+	.long  0x4c000364    /* nap                        */
+	.long  0x4c0003a4    /* sleep                      */
+	.long  0x4c0003e4    /* rvwinkle                   */
+	.long  0x7c830134    /* prtyw   r3,r4              */
+	.long  0x7dcd0174    /* prtyd   r13,r14            */
+	.long  0x7d5c02a6    /* mfcfar  r10                */
+	.long  0x7d7c03a6    /* mtcfar  r11                */
+	.long  0x7c832bf8    /* cmpb    r3,r4,r5           */
+	.long  0x7d4b662a    /* lwzcix  r10,r11,r12        */
+	.long  0xee119004    /* dadd    f16,f17,f18        */
+	.long  0xfe96c004    /* daddq   f20,f22,f24        */
+	.long  0x7c60066c    /* dss     3                  */
+	.long  0x7e00066c    /* dssall                     */
+	.long  0x7c2522ac    /* dst     r5,r4,1            */
+	.long  0x7e083aac    /* dstt    r8,r7,0            */
+	.long  0x7c6532ec    /* dstst   r5,r6,3            */
+	.long  0x7e442aec    /* dststt  r4,r5,2            */
+	.long  0x7d4b6356    /* divwe   r10,r11,r12        */
+	.long  0x7d6c6b57    /* divwe.  r11,r12,r13        */
+	.long  0x7d8d7756    /* divweo  r12,r13,r14        */
+	.long  0x7dae7f57    /* divweo. r13,r14,r15        */
+	.long  0x7d4b6316    /* divweu  r10,r11,r12        */
+	.long  0x7d6c6b17    /* divweu. r11,r12,r13        */
+	.long  0x7d8d7716    /* divweuo r12,r13,r14        */
+	.long  0x7dae7f17    /* divweuo. r13,r14,r15       */
+	.long  0x7e27d9f8    /* bpermd  r7,r17,r27         */
+	.long  0x7e8a02f4    /* popcntw r10,r20            */
+	.long  0x7e8a03f4    /* popcntd r10,r20            */
+	.long  0x7e95b428    /* ldbrx   r20,r21,r22        */
+	.long  0x7e95b528    /* stdbrx  r20,r21,r22        */
+	.long  0x7d4056ee    /* lfiwzx  f10,0,r10          */
+	.long  0x7d4956ee    /* lfiwzx  f10,r9,r10         */
+	.long  0xec802e9c    /* fcfids  f4,f5              */
+	.long  0xec802e9d    /* fcfids. f4,f5              */
+	.long  0xec802f9c    /* fcfidus f4,f5              */
+	.long  0xec802f9d    /* fcfidus. f4,f5             */
+	.long  0xfc80291c    /* fctiwu  f4,f5              */
+	.long  0xfc80291d    /* fctiwu. f4,f5              */
+	.long  0xfc80291e    /* fctiwuz f4,f5              */
+	.long  0xfc80291f    /* fctiwuz. f4,f5             */
+	.long  0xfc802f5c    /* fctidu  f4,f5              */
+	.long  0xfc802f5d    /* fctidu. f4,f5              */
+	.long  0xfc802f5e    /* fctiduz f4,f5              */
+	.long  0xfc802f5f    /* fctiduz. f4,f5             */
+	.long  0xfc802f9c    /* fcfidu  f4,f5              */
+	.long  0xfc802f9d    /* fcfidu. f4,f5              */
+	.long  0xfc0a5900    /* ftdiv   cr0,f10,f11        */
+	.long  0xff8a5900    /* ftdiv   cr7,f10,f11        */
+	.long  0xfc005140    /* ftsqrt  cr0,f10            */
+	.long  0xff805140    /* ftsqrt  cr7,f10            */
+	.long  0x7e084a2c    /* dcbtt   r8,r9              */
+	.long  0x7e0849ec    /* dcbtstt r8,r9              */
+	.long  0xed406644    /* dcffix  f10,f12            */
+	.long  0xee80b645    /* dcffix. f20,f22            */
+	.long  0xfdc07830    /* fre     f14,f15            */
+	.long  0xfdc07831    /* fre.    f14,f15            */
+	.long  0xedc07830    /* fres    f14,f15            */
+	.long  0xedc07831    /* fres.   f14,f15            */
+	.long  0xfdc07834    /* frsqrte f14,f15            */
+	.long  0xfdc07835    /* frsqrte. f14,f15           */
+	.long  0xedc07834    /* frsqrtes f14,f15           */
+	.long  0xedc07835    /* frsqrtes. f14,f15          */
+	.long  0x7c43271e    /* isel    r2,r3,r4,28        */
+	.long  0x7f7bdb78    /* yield                      */
+	.long  0x7f7bdb78    /* yield                      */
+	.long  0x60420000    /* ori     r2,r2,0            */
+	.long  0x60000000    /* nop                        */
+	.long  0x60000000    /* nop                        */
+	.long  0x60420000    /* ori     r2,r2,0            */
+	.long  0x7fbdeb78    /* mdoio                      */
+	.long  0x7fbdeb78    /* mdoio                      */
+	.long  0x7fdef378    /* mdoom                      */
+	.long  0x7fdef378    /* mdoom                      */
+	.long  0x7d40e2a6    /* mfppr   r10                */
+	.long  0x7d62e2a6    /* mfppr32 r11                */
+	.long  0x7d80e3a6    /* mtppr   r12                */
+	.long  0x7da2e3a6    /* mtppr32 r13                */
+	.long  0x7d605264    /* tlbie   r10,r11            */
diff --git a/gdb/testsuite/gdb.arch/powerpc-power8.exp b/gdb/testsuite/gdb.arch/powerpc-power8.exp
new file mode 100644
index 0000000..9b7950a
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-power8.exp
@@ -0,0 +1,245 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu power8"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "tabort\. r5"
+func_check "tabortwc\. 7,r8,r16"
+func_check "tabortdc\. 20,r11,r10"
+func_check "tabortwci\. 17,r10,-13"
+func_check "tabortdci\. 29,r3,-5"
+func_check "tbegin\. "
+func_check "tcheck  cr7"
+func_check "tend\.   "
+func_check "tend\.   "
+func_check "tendall\."
+func_check "tendall\."
+func_check "treclaim\. r24"
+func_check "trechkpt\."
+func_check "tsuspend\."
+func_check "tsuspend\."
+func_check "tresume\."
+func_check "tresume\."
+func_check "ori     r2,r2,0"
+func_check "nop"
+func_check "ori     r2,r2,0"
+func_check "rfebb   0"
+func_check "rfebb   "
+func_check "rfebb   "
+func_check "bctar-  12,4\\*cr5\\+gt"
+func_check "bctarl- 4,4\\*cr1\\+so"
+func_check "bctar\\+  12,4\\*cr3\\+lt"
+func_check "bctarl\\+ 4,eq"
+func_check "bctar   4,4\\*cr2\\+lt,1"
+func_check "bctarl  4,4\\*cr1\\+so,2"
+func_check "waitasec"
+func_check "msgsndp r8"
+func_check "mtsle   1"
+func_check "msgclrp r27"
+func_check "stqcx\.  r10,r10,r12"
+func_check "stqcx\.  r28,0,r7"
+func_check "lqarx   r24,r19,r11"
+func_check "lqarx   r22,0,r11"
+func_check "mfbhrbe r20,6"
+func_check "pbt\.    r29,r17,r16"
+func_check "pbt\.    r14,0,r7"
+func_check "clrbhrb"
+func_check "vpermxor v11,v10,v0,v23"
+func_check "vaddeuqm v24,v2,v7,v4"
+func_check "vaddecuq v10,v10,v8,v2"
+func_check "vsubeuqm v5,v15,v8,v19"
+func_check "vsubecuq v12,v31,v16,v29"
+func_check "vmulouw v20,v29,v13"
+func_check "vmuluwm v29,v0,v26"
+func_check "vaddudm v8,v21,v28"
+func_check "vmaxud  v1,v26,v1"
+func_check "vrld    v20,v3,v1"
+func_check "vcmpequd v4,v19,v11"
+func_check "vadduqm v23,v14,v30"
+func_check "vaddcuq v8,v8,v13"
+func_check "vmulosw v28,v27,v4"
+func_check "vmaxsd  v3,v4,v4"
+func_check "vmuleuw v0,v19,v21"
+func_check "vminud  v24,v20,v19"
+func_check "vcmpgtud v0,v28,v15"
+func_check "vmulesw v21,v0,v2"
+func_check "vminsd  v9,v26,v9"
+func_check "vsrad   v25,v29,v11"
+func_check "vcmpgtsd v11,v28,v11"
+func_check "bcdadd\. v5,v8,v26,1"
+func_check "vpmsumb v4,v3,v12"
+func_check "bcdsub\. v26,v31,v21,1"
+func_check "vpmsumh v5,v17,v16"
+func_check "vpkudum v23,v17,v20"
+func_check "vpmsumw v24,v21,v29"
+func_check "vpmsumd v9,v22,v13"
+func_check "vpkudus v18,v19,v18"
+func_check "vsubuqm v30,v16,v22"
+func_check "vcipher v14,v11,v7"
+func_check "vcipherlast v10,v2,v22"
+func_check "vgbbd   v23,v13"
+func_check "vsubcuq v16,v25,v16"
+func_check "vorc    v31,v1,v5"
+func_check "vncipher v4,v17,v31"
+func_check "vncipherlast v24,v2,v27"
+func_check "vbpermq v23,v21,v23"
+func_check "vpksdus v27,v18,v9"
+func_check "vnand   v27,v29,v27"
+func_check "vsld    v19,v19,v24"
+func_check "vsbox   v5,v13"
+func_check "vpksdss v25,v3,v7"
+func_check "vcmpequd\. v28,v8,v0"
+func_check "vupkhsw v26,v26"
+func_check "vshasigmaw v5,v7,0,6"
+func_check "veqv    v28,v21,v14"
+func_check "vmrgow  v1,v8,v19"
+func_check "vshasigmad v0,v10,0,10"
+func_check "vsrd    v5,v27,v14"
+func_check "vupklsw v11,v13"
+func_check "vclzb   v14,v16"
+func_check "vpopcntb v20,v27"
+func_check "vclzh   v28,v11"
+func_check "vpopcnth v24,v9"
+func_check "vclzw   v27,v31"
+func_check "vpopcntw v17,v19"
+func_check "vclzd   v12,v29"
+func_check "vpopcntd v23,v22"
+func_check "vcmpgtud\. v24,v20,v29"
+func_check "vcmpgtsd\. v9,v6,v27"
+func_check "lxsiwzx vs62,r14,r26"
+func_check "lxsiwzx vs40,0,r25"
+func_check "lxsiwax vs25,0,r26"
+func_check "lxsiwax vs3,0,r3"
+func_check "mfvsrd  r12,vs62"
+func_check "mffprwz r20,f12"
+func_check "stxsiwx vs14,r9,r14"
+func_check "stxsiwx vs21,0,r8"
+func_check "mtvsrd  vs48,r11"
+func_check "mtvrwa  v31,r23"
+func_check "mtfprwz f16,r26"
+func_check "lxsspx  vs13,r19,r13"
+func_check "lxsspx  vs18,0,r13"
+func_check "stxsspx vs43,r2,r4"
+func_check "stxsspx vs55,0,r11"
+func_check "xsaddsp vs54,vs48,vs25"
+func_check "xsmaddasp vs14,vs50,vs1"
+func_check "xssubsp vs26,vs22,vs42"
+func_check "xsmaddmsp vs27,vs53,vs52"
+func_check "xsrsqrtesp vs8,vs59"
+func_check "xssqrtsp vs12,vs41"
+func_check "xsmulsp vs57,vs11,vs32"
+func_check "xsmsubasp vs38,vs20,vs26"
+func_check "xsdivsp vs26,vs19,vs6"
+func_check "xsmsubmsp vs35,vs37,vs55"
+func_check "xsresp  vs59,vs8"
+func_check "xsnmaddasp vs44,vs33,vs33"
+func_check "xsnmaddmsp vs17,vs62,vs30"
+func_check "xsnmsubasp vs54,vs52,vs31"
+func_check "xsnmsubmsp vs37,vs5,vs58"
+func_check "xxlorc  vs30,vs54,vs44"
+func_check "xxlnand vs49,vs14,vs29"
+func_check "xxleqv  vs62,vs22,vs30"
+func_check "xscvdpspn vs60,vs54"
+func_check "xsrsp   vs22,vs45"
+func_check "xscvuxdsp vs26,vs59"
+func_check "xscvsxdsp vs38,vs49"
+func_check "xscvspdpn vs59,vs26"
+func_check "fmrgow  f24,f14,f2"
+func_check "fmrgew  f22,f7,f5"
+func_check "msgsnd  r14"
+func_check "msgclr  r23"
+func_check "lxvd2x  vs40,0,r5"
+func_check "lxvd2x  vs40,0,r5"
+func_check "lxvd2x  vs10,r20,r6"
+func_check "lxvd2x  vs10,r20,r6"
+func_check "stxvd2x vs41,0,r7"
+func_check "stxvd2x vs41,0,r7"
+func_check "stxvd2x vs11,r21,r8"
+func_check "stxvd2x vs11,r21,r8"
+func_check "lbarx   r20,0,r7"
+func_check "lbarx   r20,0,r7"
+func_check "lbarx   r20,0,r7,1"
+func_check "lbarx   r20,r1,r7"
+func_check "lbarx   r20,r1,r7"
+func_check "lbarx   r20,r1,r7,1"
+func_check "ldarx   r21,0,r8"
+func_check "ldarx   r21,0,r8"
+func_check "ldarx   r21,0,r8,1"
+func_check "ldarx   r21,r1,r8"
+func_check "ldarx   r21,r1,r8"
+func_check "ldarx   r21,r1,r8,1"
+func_check "lharx   r22,0,r9"
+func_check "lharx   r22,0,r9"
+func_check "lharx   r22,0,r9,1"
+func_check "lharx   r22,r1,r9"
+func_check "lharx   r22,r1,r9"
+func_check "lharx   r22,r1,r9,1"
+func_check "lwarx   r23,0,r10"
+func_check "lwarx   r23,0,r10"
+func_check "lwarx   r23,0,r10,1"
+func_check "lwarx   r23,r1,r10"
+func_check "lwarx   r23,r1,r10"
+func_check "lwarx   r23,r1,r10,1"
+func_check "stbcx\.  r10,0,r7"
+func_check "stbcx\.  r10,r1,r7"
+func_check "sthcx\.  r11,0,r8"
+func_check "sthcx\.  r11,r1,r8"
+func_check "stwcx\.  r12,0,r9"
+func_check "stwcx\.  r12,r1,r9"
+func_check "stdcx\.  r13,0,r10"
+func_check "stdcx\.  r13,r1,r10"
diff --git a/gdb/testsuite/gdb.arch/powerpc-power8.s b/gdb/testsuite/gdb.arch/powerpc-power8.s
new file mode 100644
index 0000000..1f528a9
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-power8.s
@@ -0,0 +1,205 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7c05071d    /* tabort. r5                 */
+	.long  0x7ce8861d    /* tabortwc. 7,r8,r16         */
+	.long  0x7e8b565d    /* tabortdc. 20,r11,r10       */
+	.long  0x7e2a9e9d    /* tabortwci. 17,r10,-13      */
+	.long  0x7fa3dedd    /* tabortdci. 29,r3,-5        */
+	.long  0x7c00051d    /* tbegin.                    */
+	.long  0x7f80059c    /* tcheck  cr7                */
+	.long  0x7c00055d    /* tend.                      */
+	.long  0x7c00055d    /* tend.                      */
+	.long  0x7e00055d    /* tendall.                   */
+	.long  0x7e00055d    /* tendall.                   */
+	.long  0x7c18075d    /* treclaim. r24              */
+	.long  0x7c0007dd    /* trechkpt.                  */
+	.long  0x7c0005dd    /* tsuspend.                  */
+	.long  0x7c0005dd    /* tsuspend.                  */
+	.long  0x7c2005dd    /* tresume.                   */
+	.long  0x7c2005dd    /* tresume.                   */
+	.long  0x60420000    /* ori     r2,r2,0            */
+	.long  0x60000000    /* nop                        */
+	.long  0x60420000    /* ori     r2,r2,0            */
+	.long  0x4c000124    /* rfebb   0                  */
+	.long  0x4c000924    /* rfebb                      */
+	.long  0x4c000924    /* rfebb                      */
+	.long  0x4d950460    /* bctar-  12,4*cr5+gt        */
+	.long  0x4c870461    /* bctarl- 4,4*cr1+so         */
+	.long  0x4dac0460    /* bctar+  12,4*cr3+lt        */
+	.long  0x4ca20461    /* bctarl+ 4,eq               */
+	.long  0x4c880c60    /* bctar   4,4*cr2+lt,1       */
+	.long  0x4c871461    /* bctarl  4,4*cr1+so,2       */
+	.long  0x7c00003c    /* waitasec                   */
+	.long  0x7c00411c    /* msgsndp r8                 */
+	.long  0x7c200126    /* mtsle   1                  */
+	.long  0x7c00d95c    /* msgclrp r27                */
+	.long  0x7d4a616d    /* stqcx.  r10,r10,r12        */
+	.long  0x7f80396d    /* stqcx.  r28,0,r7           */
+	.long  0x7f135a28    /* lqarx   r24,r19,r11        */
+	.long  0x7ec05a28    /* lqarx   r22,0,r11          */
+	.long  0x7e80325c    /* mfbhrbe r20,6              */
+	.long  0x7fb18329    /* pbt.    r29,r17,r16        */
+	.long  0x7dc03b29    /* pbt.    r14,0,r7           */
+	.long  0x7c00035c    /* clrbhrb                    */
+	.long  0x116a05ed    /* vpermxor v11,v10,v0,v23    */
+	.long  0x1302393c    /* vaddeuqm v24,v2,v7,v4      */
+	.long  0x114a40bd    /* vaddecuq v10,v10,v8,v2     */
+	.long  0x10af44fe    /* vsubeuqm v5,v15,v8,v19     */
+	.long  0x119f877f    /* vsubecuq v12,v31,v16,v29   */
+	.long  0x129d6888    /* vmulouw v20,v29,v13        */
+	.long  0x13a0d089    /* vmuluwm v29,v0,v26         */
+	.long  0x1115e0c0    /* vaddudm v8,v21,v28         */
+	.long  0x103a08c2    /* vmaxud  v1,v26,v1          */
+	.long  0x128308c4    /* vrld    v20,v3,v1          */
+	.long  0x109358c7    /* vcmpequd v4,v19,v11        */
+	.long  0x12eef100    /* vadduqm v23,v14,v30        */
+	.long  0x11086940    /* vaddcuq v8,v8,v13          */
+	.long  0x139b2188    /* vmulosw v28,v27,v4         */
+	.long  0x106421c2    /* vmaxsd  v3,v4,v4           */
+	.long  0x1013aa88    /* vmuleuw v0,v19,v21         */
+	.long  0x13149ac2    /* vminud  v24,v20,v19        */
+	.long  0x101c7ac7    /* vcmpgtud v0,v28,v15        */
+	.long  0x12a01388    /* vmulesw v21,v0,v2          */
+	.long  0x113a4bc2    /* vminsd  v9,v26,v9          */
+	.long  0x133d5bc4    /* vsrad   v25,v29,v11        */
+	.long  0x117c5bc7    /* vcmpgtsd v11,v28,v11       */
+	.long  0x10a8d601    /* bcdadd. v5,v8,v26,1        */
+	.long  0x10836408    /* vpmsumb v4,v3,v12          */
+	.long  0x135fae41    /* bcdsub. v26,v31,v21,1      */
+	.long  0x10b18448    /* vpmsumh v5,v17,v16         */
+	.long  0x12f1a44e    /* vpkudum v23,v17,v20        */
+	.long  0x1315ec88    /* vpmsumw v24,v21,v29        */
+	.long  0x11366cc8    /* vpmsumd v9,v22,v13         */
+	.long  0x125394ce    /* vpkudus v18,v19,v18        */
+	.long  0x13d0b500    /* vsubuqm v30,v16,v22        */
+	.long  0x11cb3d08    /* vcipher v14,v11,v7         */
+	.long  0x1142b509    /* vcipherlast v10,v2,v22     */
+	.long  0x12e06d0c    /* vgbbd   v23,v13            */
+	.long  0x12198540    /* vsubcuq v16,v25,v16        */
+	.long  0x13e12d44    /* vorc    v31,v1,v5          */
+	.long  0x1091fd48    /* vncipher v4,v17,v31        */
+	.long  0x1302dd49    /* vncipherlast v24,v2,v27    */
+	.long  0x12f5bd4c    /* vbpermq v23,v21,v23        */
+	.long  0x13724d4e    /* vpksdus v27,v18,v9         */
+	.long  0x137ddd84    /* vnand   v27,v29,v27        */
+	.long  0x1273c5c4    /* vsld    v19,v19,v24        */
+	.long  0x10ad05c8    /* vsbox   v5,v13             */
+	.long  0x13233dce    /* vpksdss v25,v3,v7          */
+	.long  0x138804c7    /* vcmpequd. v28,v8,v0        */
+	.long  0x1340d64e    /* vupkhsw v26,v26            */
+	.long  0x10a73682    /* vshasigmaw v5,v7,0,6       */
+	.long  0x13957684    /* veqv    v28,v21,v14        */
+	.long  0x10289e8c    /* vmrgow  v1,v8,v19          */
+	.long  0x100a56c2    /* vshasigmad v0,v10,0,10     */
+	.long  0x10bb76c4    /* vsrd    v5,v27,v14         */
+	.long  0x11606ece    /* vupklsw v11,v13            */
+	.long  0x11c08702    /* vclzb   v14,v16            */
+	.long  0x1280df03    /* vpopcntb v20,v27           */
+	.long  0x13805f42    /* vclzh   v28,v11            */
+	.long  0x13004f43    /* vpopcnth v24,v9            */
+	.long  0x1360ff82    /* vclzw   v27,v31            */
+	.long  0x12209f83    /* vpopcntw v17,v19           */
+	.long  0x1180efc2    /* vclzd   v12,v29            */
+	.long  0x12e0b7c3    /* vpopcntd v23,v22           */
+	.long  0x1314eec7    /* vcmpgtud. v24,v20,v29      */
+	.long  0x1126dfc7    /* vcmpgtsd. v9,v6,v27        */
+	.long  0x7fced019    /* lxsiwzx vs62,r14,r26       */
+	.long  0x7d00c819    /* lxsiwzx vs40,0,r25         */
+	.long  0x7f20d098    /* lxsiwax vs25,0,r26         */
+	.long  0x7c601898    /* lxsiwax vs3,0,r3           */
+	.long  0x7fcc0067    /* mfvsrd  r12,vs62           */
+	.long  0x7d9400e6    /* mffprwz r20,f12            */
+	.long  0x7dc97118    /* stxsiwx vs14,r9,r14        */
+	.long  0x7ea04118    /* stxsiwx vs21,0,r8          */
+	.long  0x7e0b0167    /* mtvsrd  vs48,r11           */
+	.long  0x7ff701a7    /* mtvrwa  v31,r23            */
+	.long  0x7e1a01e6    /* mtfprwz f16,r26            */
+	.long  0x7db36c18    /* lxsspx  vs13,r19,r13       */
+	.long  0x7e406c18    /* lxsspx  vs18,0,r13         */
+	.long  0x7d622519    /* stxsspx vs43,r2,r4         */
+	.long  0x7ee05d19    /* stxsspx vs55,0,r11         */
+	.long  0xf2d0c805    /* xsaddsp vs54,vs48,vs25     */
+	.long  0xf1d2080c    /* xsmaddasp vs14,vs50,vs1    */
+	.long  0xf3565042    /* xssubsp vs26,vs22,vs42     */
+	.long  0xf375a04e    /* xsmaddmsp vs27,vs53,vs52   */
+	.long  0xf100d82a    /* xsrsqrtesp vs8,vs59        */
+	.long  0xf180482e    /* xssqrtsp vs12,vs41         */
+	.long  0xf32b0083    /* xsmulsp vs57,vs11,vs32     */
+	.long  0xf0d4d089    /* xsmsubasp vs38,vs20,vs26   */
+	.long  0xf35330c0    /* xsdivsp vs26,vs19,vs6      */
+	.long  0xf065b8cf    /* xsmsubmsp vs35,vs37,vs55   */
+	.long  0xf3604069    /* xsresp  vs59,vs8           */
+	.long  0xf1810c0f    /* xsnmaddasp vs44,vs33,vs33  */
+	.long  0xf23ef44c    /* xsnmaddmsp vs17,vs62,vs30  */
+	.long  0xf2d4fc8d    /* xsnmsubasp vs54,vs52,vs31  */
+	.long  0xf0a5d4cb    /* xsnmsubmsp vs37,vs5,vs58   */
+	.long  0xf3d66556    /* xxlorc  vs30,vs54,vs44     */
+	.long  0xf22eed91    /* xxlnand vs49,vs14,vs29     */
+	.long  0xf3d6f5d1    /* xxleqv  vs62,vs22,vs30     */
+	.long  0xf380b42f    /* xscvdpspn vs60,vs54        */
+	.long  0xf2c06c66    /* xsrsp   vs22,vs45          */
+	.long  0xf340dca2    /* xscvuxdsp vs26,vs59        */
+	.long  0xf0c08ce3    /* xscvsxdsp vs38,vs49        */
+	.long  0xf360d52d    /* xscvspdpn vs59,vs26        */
+	.long  0xff0e168c    /* fmrgow  f24,f14,f2         */
+	.long  0xfec72f8c    /* fmrgew  f22,f7,f5          */
+	.long  0x7c00719c    /* msgsnd  r14                */
+	.long  0x7c00b9dc    /* msgclr  r23                */
+	.long  0x7d002e99    /* lxvd2x  vs40,0,r5          */
+	.long  0x7d002e99    /* lxvd2x  vs40,0,r5          */
+	.long  0x7d543698    /* lxvd2x  vs10,r20,r6        */
+	.long  0x7d543698    /* lxvd2x  vs10,r20,r6        */
+	.long  0x7d203f99    /* stxvd2x vs41,0,r7          */
+	.long  0x7d203f99    /* stxvd2x vs41,0,r7          */
+	.long  0x7d754798    /* stxvd2x vs11,r21,r8        */
+	.long  0x7d754798    /* stxvd2x vs11,r21,r8        */
+	.long  0x7e803868    /* lbarx   r20,0,r7           */
+	.long  0x7e803868    /* lbarx   r20,0,r7           */
+	.long  0x7e803869    /* lbarx   r20,0,r7,1         */
+	.long  0x7e813868    /* lbarx   r20,r1,r7          */
+	.long  0x7e813868    /* lbarx   r20,r1,r7          */
+	.long  0x7e813869    /* lbarx   r20,r1,r7,1        */
+	.long  0x7ea040a8    /* ldarx   r21,0,r8           */
+	.long  0x7ea040a8    /* ldarx   r21,0,r8           */
+	.long  0x7ea040a9    /* ldarx   r21,0,r8,1         */
+	.long  0x7ea140a8    /* ldarx   r21,r1,r8          */
+	.long  0x7ea140a8    /* ldarx   r21,r1,r8          */
+	.long  0x7ea140a9    /* ldarx   r21,r1,r8,1        */
+	.long  0x7ec048e8    /* lharx   r22,0,r9           */
+	.long  0x7ec048e8    /* lharx   r22,0,r9           */
+	.long  0x7ec048e9    /* lharx   r22,0,r9,1         */
+	.long  0x7ec148e8    /* lharx   r22,r1,r9          */
+	.long  0x7ec148e8    /* lharx   r22,r1,r9          */
+	.long  0x7ec148e9    /* lharx   r22,r1,r9,1        */
+	.long  0x7ee05028    /* lwarx   r23,0,r10          */
+	.long  0x7ee05028    /* lwarx   r23,0,r10          */
+	.long  0x7ee05029    /* lwarx   r23,0,r10,1        */
+	.long  0x7ee15028    /* lwarx   r23,r1,r10         */
+	.long  0x7ee15028    /* lwarx   r23,r1,r10         */
+	.long  0x7ee15029    /* lwarx   r23,r1,r10,1       */
+	.long  0x7d403d6d    /* stbcx.  r10,0,r7           */
+	.long  0x7d413d6d    /* stbcx.  r10,r1,r7          */
+	.long  0x7d6045ad    /* sthcx.  r11,0,r8           */
+	.long  0x7d6145ad    /* sthcx.  r11,r1,r8          */
+	.long  0x7d80492d    /* stwcx.  r12,0,r9           */
+	.long  0x7d81492d    /* stwcx.  r12,r1,r9          */
+	.long  0x7da051ad    /* stdcx.  r13,0,r10          */
+	.long  0x7da151ad    /* stdcx.  r13,r1,r10         */
diff --git a/gdb/testsuite/gdb.arch/powerpc-power9.exp b/gdb/testsuite/gdb.arch/powerpc-power9.exp
new file mode 100644
index 0000000..e2b3407
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-power9.exp
@@ -0,0 +1,442 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu power9"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "cnttzd  r3,r13"
+func_check "cnttzd\. r4,r14"
+func_check "cnttzw  r5,r15"
+func_check "cnttzw\. r6,r16"
+func_check "modsd   r10,r20,r21"
+func_check "modsw   r11,r21,r22"
+func_check "modud   r12,r22,r23"
+func_check "moduw   r13,r23,r24"
+func_check "bcdcfn\. v3,v4,0"
+func_check "bcdcfn\. v3,v4,1"
+func_check "bcdcfsq\. v4,v5,0"
+func_check "bcdcfsq\. v4,v5,1"
+func_check "bcdcfz\. v5,v6,0"
+func_check "bcdcfz\. v5,v6,1"
+func_check "bcdcpsgn\. v6,v7,v8"
+func_check "bcdctn\. v7,v8"
+func_check "bcdctsq\. v8,v9"
+func_check "bcdctz\. v9,v10,0"
+func_check "bcdctz\. v9,v10,1"
+func_check "bcdsetsgn\. v10,v11,0"
+func_check "bcdsetsgn\. v10,v11,1"
+func_check "bcdsr\.  v11,v12,v13,0"
+func_check "bcdsr\.  v11,v12,v13,1"
+func_check "bcds\.   v12,v13,v14,0"
+func_check "bcds\.   v12,v13,v14,1"
+func_check "bcdtrunc\. v13,v14,v15,0"
+func_check "bcdtrunc\. v13,v14,v15,1"
+func_check "bcdus\.  v14,v15,v16"
+func_check "bcdutrunc\. v15,v16,v17"
+func_check "lxvll   vs20,0,r21"
+func_check "lxvll   vs20,r10,r21"
+func_check "stxvll  vs21,0,r11"
+func_check "stxvll  vs21,r10,r11"
+func_check "vmul10cuq v22,v23"
+func_check "vmul10ecuq v23,v24,v25"
+func_check "vmul10euq v24,v25,v26"
+func_check "vmul10uq v25,v26"
+func_check "xsaddqp v10,v11,v12"
+func_check "xsaddqpo v11,v12,v12"
+func_check "xsrqpi  0,v20,v30,0"
+func_check "xsrqpi  1,v20,v30,0"
+func_check "xsrqpi  0,v20,v30,3"
+func_check "xsrqpi  1,v20,v30,3"
+func_check "xsrqpix 0,v21,v31,0"
+func_check "xsrqpix 1,v21,v31,0"
+func_check "xsrqpix 0,v21,v31,3"
+func_check "xsrqpix 1,v21,v31,3"
+func_check "xsmulqp v12,v13,v14"
+func_check "xsmulqpo v13,v14,v15"
+func_check "xsrqpxp 0,v22,v23,0"
+func_check "xsrqpxp 1,v22,v23,0"
+func_check "xsrqpxp 0,v22,v23,3"
+func_check "xsrqpxp 1,v22,v23,3"
+func_check "xscpsgnqp v14,v15,v16"
+func_check "xscmpoqp cr0,v15,v16"
+func_check "xscmpoqp cr7,v15,v16"
+func_check "xscmpexpqp cr0,v16,v17"
+func_check "xscmpexpqp cr7,v16,v17"
+func_check "xsmaddqp v17,v18,v19"
+func_check "xsmaddqpo v18,v19,v20"
+func_check "xsmsubqp v19,v20,v21"
+func_check "xsmsubqpo v20,v21,v22"
+func_check "xsnmaddqp v21,v22,v23"
+func_check "xsnmaddqpo v22,v23,v24"
+func_check "xsnmsubqp v23,v24,v25"
+func_check "xsnmsubqpo v24,v25,v26"
+func_check "xssubqp v25,v26,v27"
+func_check "xssubqpo v26,v27,v28"
+func_check "xsdivqp v27,v28,v29"
+func_check "xsdivqpo v28,v29,v30"
+func_check "xscmpuqp cr0,v29,v30"
+func_check "xscmpuqp cr7,v29,v30"
+func_check "xststdcqp cr0,v30,0"
+func_check "xststdcqp cr7,v30,0"
+func_check "xststdcqp cr0,v31,127"
+func_check "xststdcqp cr7,v31,127"
+func_check "xsabsqp v10,v11"
+func_check "xsxexpqp v11,v12"
+func_check "xsnabsqp v12,v13"
+func_check "xsnegqp v13,v14"
+func_check "xsxsigqp v14,v15"
+func_check "xssqrtqp v15,v16"
+func_check "xssqrtqpo v16,v17"
+func_check "xscvqpuwz v17,v18"
+func_check "xscvudqp v18,v19"
+func_check "xscvqpswz v19,v20"
+func_check "xscvsdqp v20,v21"
+func_check "xscvqpudz v21,v22"
+func_check "xscvqpdp v22,v23"
+func_check "xscvqpdpo v23,v24"
+func_check "xscvdpqp v24,v25"
+func_check "xscvqpsdz v25,v26"
+func_check "xsiexpqp v26,v27,v28"
+func_check "vpermr  v4,v5,v6,v7"
+func_check "vextractub v5,v6,0"
+func_check "vextractub v5,v6,15"
+func_check "vextractuh v6,v7,0"
+func_check "vextractuh v6,v7,15"
+func_check "vextractuw v7,v8,0"
+func_check "vextractuw v7,v8,15"
+func_check "vextractd v8,v9,0"
+func_check "vextractd v8,v9,15"
+func_check "vinsertb v9,v10,0"
+func_check "vinsertb v9,v10,15"
+func_check "vinserth v10,v11,0"
+func_check "vinserth v10,v11,15"
+func_check "vinsertw v11,v12,0"
+func_check "vinsertw v11,v12,15"
+func_check "vinsertd v12,v13,0"
+func_check "vinsertd v12,v13,15"
+func_check "mfvsrld r20,vs45"
+func_check "mtvsrws vs46,r21"
+func_check "mtvsrdd vs47,0,r23"
+func_check "mtvsrdd vs47,r22,r23"
+func_check "lxvx    vs50,0,r11"
+func_check "lxvx    vs0,r10,r11"
+func_check "lxvwsx  vs51,0,r12"
+func_check "lxvwsx  vs1,r10,r12"
+func_check "lxvh8x  vs52,0,r13"
+func_check "lxvh8x  vs2,r10,r13"
+func_check "lxvb16x vs53,0,r14"
+func_check "lxvb16x vs3,r10,r14"
+func_check "stxvx   vs54,0,r15"
+func_check "stxvx   vs4,r20,r15"
+func_check "stxvh8x vs55,0,r16"
+func_check "stxvh8x vs5,r20,r16"
+func_check "stxvb16x vs56,0,r17"
+func_check "stxvb16x vs6,r20,r17"
+func_check "xxextractuw vs4,vs5,0"
+func_check "xxextractuw vs40,vs50,15"
+func_check "xxspltib vs4,0"
+func_check "xxspltib vs4,128"
+func_check "xxspltib vs41,255"
+func_check "xxspltib vs41,255"
+func_check "xxinsertw vs5,vs6,0"
+func_check "xxinsertw vs50,vs60,15"
+func_check "xxbrh   vs6,vs7"
+func_check "xxbrh   vs56,vs57"
+func_check "xxbrw   vs7,vs8"
+func_check "xxbrw   vs57,vs58"
+func_check "xxbrd   vs8,vs9"
+func_check "xxbrd   vs58,vs59"
+func_check "xxbrq   vs9,vs10"
+func_check "xxbrq   vs59,vs60"
+func_check "lxsd    v20,0\\(0\\)"
+func_check "lxsd    v20,0\\(r10\\)"
+func_check "lxsd    v20,8\\(0\\)"
+func_check "lxsd    v20,8\\(r10\\)"
+func_check "lxsd    v20,-8\\(0\\)"
+func_check "lxsd    v20,-8\\(r10\\)"
+func_check "lxsd    v20,32764\\(0\\)"
+func_check "lxsd    v20,32764\\(r10\\)"
+func_check "lxsd    v20,-32768\\(0\\)"
+func_check "lxsd    v20,-32768\\(r10\\)"
+func_check "lxssp   v30,0\\(0\\)"
+func_check "lxssp   v30,0\\(r11\\)"
+func_check "lxssp   v30,8\\(0\\)"
+func_check "lxssp   v30,8\\(r11\\)"
+func_check "lxssp   v30,-8\\(0\\)"
+func_check "lxssp   v30,-8\\(r11\\)"
+func_check "lxssp   v30,32764\\(0\\)"
+func_check "lxssp   v30,32764\\(r11\\)"
+func_check "lxssp   v30,-32768\\(0\\)"
+func_check "lxssp   v30,-32768\\(r11\\)"
+func_check "lxv     vs40,0\\(0\\)"
+func_check "lxv     vs40,0\\(r12\\)"
+func_check "lxv     vs40,16\\(0\\)"
+func_check "lxv     vs40,16\\(r12\\)"
+func_check "lxv     vs40,-16\\(0\\)"
+func_check "lxv     vs10,-16\\(r12\\)"
+func_check "lxv     vs10,32752\\(0\\)"
+func_check "lxv     vs10,32752\\(r12\\)"
+func_check "lxv     vs10,-32768\\(0\\)"
+func_check "lxv     vs10,-32768\\(r12\\)"
+func_check "stxsd   v21,0\\(0\\)"
+func_check "stxsd   v21,0\\(r10\\)"
+func_check "stxsd   v21,8\\(0\\)"
+func_check "stxsd   v21,8\\(r10\\)"
+func_check "stxsd   v21,-8\\(0\\)"
+func_check "stxsd   v21,-8\\(r10\\)"
+func_check "stxsd   v21,32764\\(0\\)"
+func_check "stxsd   v21,32764\\(r10\\)"
+func_check "stxsd   v21,-32768\\(0\\)"
+func_check "stxsd   v21,-32768\\(r10\\)"
+func_check "stxssp  v31,0\\(0\\)"
+func_check "stxssp  v31,0\\(r11\\)"
+func_check "stxssp  v31,8\\(0\\)"
+func_check "stxssp  v31,8\\(r11\\)"
+func_check "stxssp  v31,-8\\(0\\)"
+func_check "stxssp  v31,-8\\(r11\\)"
+func_check "stxssp  v31,32764\\(0\\)"
+func_check "stxssp  v31,32764\\(r11\\)"
+func_check "stxssp  v31,-32768\\(0\\)"
+func_check "stxssp  v31,-32768\\(r11\\)"
+func_check "stxv    vs41,0\\(0\\)"
+func_check "stxv    vs41,0\\(r12\\)"
+func_check "stxv    vs41,16\\(0\\)"
+func_check "stxv    vs41,16\\(r12\\)"
+func_check "stxv    vs41,-16\\(0\\)"
+func_check "stxv    vs11,-16\\(r12\\)"
+func_check "stxv    vs11,32752\\(0\\)"
+func_check "stxv    vs11,32752\\(r12\\)"
+func_check "stxv    vs11,-32768\\(0\\)"
+func_check "stxv    vs11,-32768\\(r12\\)"
+func_check "xxperm  vs20,vs22,vs24"
+func_check "xxperm  vs40,vs42,vs44"
+func_check "xxpermr vs21,vs23,vs25"
+func_check "xxpermr vs41,vs43,vs45"
+func_check "extswsli r12,r20,0"
+func_check "extswsli r12,r20,1"
+func_check "extswsli r12,r20,63"
+func_check "extswsli\. r13,r21,0"
+func_check "extswsli\. r13,r21,1"
+func_check "extswsli\. r13,r21,63"
+func_check "vrlwmi  v14,v22,v23"
+func_check "vrldmi  v15,v23,v24"
+func_check "vrlwnm  v16,v24,v25"
+func_check "vrldnm  v17,v25,v26"
+func_check "vbpermd v18,v26,v27"
+func_check "vnegw   v19,v20"
+func_check "vnegd   v20,v21"
+func_check "vprtybw v21,v22"
+func_check "vprtybd v22,v23"
+func_check "vprtybq v23,v24"
+func_check "vextsb2w v24,v25"
+func_check "vextsh2w v25,v26"
+func_check "vextsb2d v26,v27"
+func_check "vextsh2d v27,v28"
+func_check "vextsw2d v28,v29"
+func_check "vctzb   v29,v30"
+func_check "vctzh   v30,v31"
+func_check "vctzw   v31,v30"
+func_check "vctzd   v30,v29"
+func_check "lxsibzx vs10,0,r20"
+func_check "lxsibzx vs50,r10,r20"
+func_check "lxsihzx vs11,0,r21"
+func_check "lxsihzx vs51,r11,r21"
+func_check "stxsibx vs12,0,r22"
+func_check "stxsibx vs52,r12,r22"
+func_check "stxsihx vs13,0,r23"
+func_check "stxsihx vs53,r13,r23"
+func_check "maddhd  r10,r11,r12,r13"
+func_check "maddhdu r20,r21,r22,r23"
+func_check "maddld  r2,r3,r4,r5"
+func_check "xscmpexpdp cr0,vs10,vs20"
+func_check "xscmpexpdp cr7,vs40,vs50"
+func_check "xsiexpdp vs41,r11,r21"
+func_check "xststdcdp cr0,vs11,127"
+func_check "xststdcdp cr7,vs41,127"
+func_check "xststdcsp cr0,vs11,127"
+func_check "xststdcsp cr7,vs41,127"
+func_check "xsxexpdp r13,vs43"
+func_check "xsxsigdp r14,vs44"
+func_check "xviexpdp vs45,vs46,vs47"
+func_check "xviexpsp vs46,vs47,vs48"
+func_check "xvtstdcdp vs54,vs55,0"
+func_check "xvtstdcdp vs54,vs55,127"
+func_check "xvtstdcsp vs55,vs56,0"
+func_check "xvtstdcsp vs55,vs56,127"
+func_check "xvxexpdp vs57,vs58"
+func_check "xvxexpsp vs58,vs59"
+func_check "xvxsigdp vs59,vs60"
+func_check "xvxsigsp vs60,vs61"
+func_check "cmpeqb  cr0,r6,r7"
+func_check "cmpeqb  cr7,r6,r7"
+func_check "cmprb   cr0,0,r8,r9"
+func_check "cmprb   cr7,0,r8,r9"
+func_check "cmprb   cr0,1,r8,r9"
+func_check "cmprb   cr7,1,r8,r9"
+func_check "setb    r15,cr0"
+func_check "setb    r15,cr7"
+func_check "lxvl    vs26,0,r10"
+func_check "lxvl    vs56,r20,r10"
+func_check "stxvl   vs27,0,r11"
+func_check "stxvl   vs57,r21,r11"
+func_check "vclzlsbb r20,v30"
+func_check "vctzlsbb r21,v31"
+func_check "vcmpneb v10,v11,v12"
+func_check "vcmpneb\. v20,v21,v22"
+func_check "vcmpneh v11,v12,v13"
+func_check "vcmpneh\. v21,v22,v23"
+func_check "vcmpnew v12,v13,v14"
+func_check "vcmpnew\. v22,v23,v24"
+func_check "vcmpnezb v13,v14,v15"
+func_check "vcmpnezb\. v23,v24,v25"
+func_check "vcmpnezh v14,v15,v16"
+func_check "vcmpnezh\. v24,v25,v26"
+func_check "vcmpnezw v15,v16,v17"
+func_check "vcmpnezw\. v25,v26,v27"
+func_check "vextublx r16,r17,v10"
+func_check "vextubrx r17,r18,v11"
+func_check "vextuhlx r18,r19,v12"
+func_check "vextuhrx r19,r20,v13"
+func_check "vextuwlx r20,r21,v14"
+func_check "vextuwrx r21,r22,v15"
+func_check "dtstsfi cr0,0,f3"
+func_check "dtstsfi cr7,63,f3"
+func_check "dtstsfiq cr0,0,f4"
+func_check "dtstsfiq cr7,63,f4"
+func_check "xscvhpdp vs40,vs50"
+func_check "xscvdphp vs41,vs51"
+func_check "xvcvhpsp vs42,vs52"
+func_check "xvcvsphp vs43,vs53"
+func_check "addpcis r3,0"
+func_check "addpcis r3,0"
+func_check "addpcis r4,1"
+func_check "addpcis r4,1"
+func_check "addpcis r5,-2"
+func_check "addpcis r5,-2"
+func_check "addpcis r6,32767"
+func_check "addpcis r6,32767"
+func_check "addpcis r7,-32768"
+func_check "addpcis r7,-32768"
+func_check "slbsync"
+func_check "slbiag  r10"
+func_check "slbieg  r10,r11"
+func_check "slbmfee r3,r4"
+func_check "slbmfee r3,r4"
+func_check "slbmfee r3,r4,1"
+func_check "slbmfev r4,r5"
+func_check "slbmfev r4,r5"
+func_check "slbmfev r4,r5,1"
+func_check "tlbie   r3,r4"
+func_check "tlbie   r3,r4"
+func_check "tlbie   r3,r4,3,1,1"
+func_check "tlbiel  r3"
+func_check "tlbiel  r3"
+func_check "tlbiel  r3,r4,3,1,1"
+func_check "copy    r12,r13"
+func_check "paste\.  r10,r11"
+func_check "cpabort"
+func_check "hwsync"
+func_check "hwsync"
+func_check "hwsync"
+func_check "lwsync"
+func_check "lwsync"
+func_check "ptesync"
+func_check "ptesync"
+func_check "ldat    r20,0,0"
+func_check "ldat    r20,r10,28"
+func_check "lwat    r21,0,0"
+func_check "lwat    r21,r11,28"
+func_check "stdat   r22,0,0"
+func_check "stdat   r22,r12,28"
+func_check "stwat   r23,0,0"
+func_check "stwat   r23,r13,28"
+func_check "urfid"
+func_check "rmieg   r30"
+func_check "ldmx    r10,0,r15"
+func_check "ldmx    r10,r3,r15"
+func_check "stop"
+func_check "wait    "
+func_check "wait    "
+func_check "darn    r3,0"
+func_check "darn    r3,1"
+func_check "darn    r3,2"
+func_check "mcrxrx  cr0"
+func_check "mcrxrx  cr7"
+func_check "vslv    v20,v21,v22"
+func_check "vsrv    v23,v24,v25"
+func_check "msgsync"
+func_check "xscmpeqdp vs30,vs40,vs50"
+func_check "xscmpgtdp vs31,vs41,vs51"
+func_check "xscmpgedp vs32,vs42,vs52"
+func_check "xsmincdp vs34,vs44,vs54"
+func_check "xsmaxcdp vs35,vs45,vs55"
+func_check "xsminjdp vs36,vs46,vs56"
+func_check "xsmaxjdp vs37,vs47,vs57"
+func_check "vmsumudm v20,v21,v22,v23"
+func_check "addex   r11,r12,r13,0"
+func_check "addex   r11,r12,r13,1"
+func_check "addex   r11,r12,r13,2"
+func_check "mffs    f25"
+func_check "mffs\.   f25"
+func_check "mffsce  f26"
+func_check "mffscdrn f27,f20"
+func_check "mffscdrni f28,0"
+func_check "mffscdrni f28,7"
+func_check "mffscrn f29,f21"
+func_check "mffscrni f30,0"
+func_check "mffscrni f30,3"
+func_check "mffsl   f31"
diff --git a/gdb/testsuite/gdb.arch/powerpc-power9.s b/gdb/testsuite/gdb.arch/powerpc-power9.s
new file mode 100644
index 0000000..8018202
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-power9.s
@@ -0,0 +1,402 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7da30474    /* cnttzd  r3,r13             */
+	.long  0x7dc40475    /* cnttzd. r4,r14             */
+	.long  0x7de50434    /* cnttzw  r5,r15             */
+	.long  0x7e060435    /* cnttzw. r6,r16             */
+	.long  0x7d54ae12    /* modsd   r10,r20,r21        */
+	.long  0x7d75b616    /* modsw   r11,r21,r22        */
+	.long  0x7d96ba12    /* modud   r12,r22,r23        */
+	.long  0x7db7c216    /* moduw   r13,r23,r24        */
+	.long  0x10672581    /* bcdcfn. v3,v4,0            */
+	.long  0x10672781    /* bcdcfn. v3,v4,1            */
+	.long  0x10822d81    /* bcdcfsq. v4,v5,0           */
+	.long  0x10822f81    /* bcdcfsq. v4,v5,1           */
+	.long  0x10a63581    /* bcdcfz. v5,v6,0            */
+	.long  0x10a63781    /* bcdcfz. v5,v6,1            */
+	.long  0x10c74341    /* bcdcpsgn. v6,v7,v8         */
+	.long  0x10e54581    /* bcdctn. v7,v8              */
+	.long  0x11004d81    /* bcdctsq. v8,v9             */
+	.long  0x11245581    /* bcdctz. v9,v10,0           */
+	.long  0x11245781    /* bcdctz. v9,v10,1           */
+	.long  0x115f5d81    /* bcdsetsgn. v10,v11,0       */
+	.long  0x115f5f81    /* bcdsetsgn. v10,v11,1       */
+	.long  0x116c6dc1    /* bcdsr.  v11,v12,v13,0      */
+	.long  0x116c6fc1    /* bcdsr.  v11,v12,v13,1      */
+	.long  0x118d74c1    /* bcds.   v12,v13,v14,0      */
+	.long  0x118d76c1    /* bcds.   v12,v13,v14,1      */
+	.long  0x11ae7d01    /* bcdtrunc. v13,v14,v15,0    */
+	.long  0x11ae7f01    /* bcdtrunc. v13,v14,v15,1    */
+	.long  0x11cf8481    /* bcdus.  v14,v15,v16        */
+	.long  0x11f08d41    /* bcdutrunc. v15,v16,v17     */
+	.long  0x7e80aa5a    /* lxvll   vs20,0,r21         */
+	.long  0x7e8aaa5a    /* lxvll   vs20,r10,r21       */
+	.long  0x7ea05b5a    /* stxvll  vs21,0,r11         */
+	.long  0x7eaa5b5a    /* stxvll  vs21,r10,r11       */
+	.long  0x12d70001    /* vmul10cuq v22,v23          */
+	.long  0x12f8c841    /* vmul10ecuq v23,v24,v25     */
+	.long  0x1319d241    /* vmul10euq v24,v25,v26      */
+	.long  0x133a0201    /* vmul10uq v25,v26           */
+	.long  0xfd4b6008    /* xsaddqp v10,v11,v12        */
+	.long  0xfd6c6009    /* xsaddqpo v11,v12,v12       */
+	.long  0xfe80f00a    /* xsrqpi  0,v20,v30,0        */
+	.long  0xfe81f00a    /* xsrqpi  1,v20,v30,0        */
+	.long  0xfe80f60a    /* xsrqpi  0,v20,v30,3        */
+	.long  0xfe81f60a    /* xsrqpi  1,v20,v30,3        */
+	.long  0xfea0f80b    /* xsrqpix 0,v21,v31,0        */
+	.long  0xfea1f80b    /* xsrqpix 1,v21,v31,0        */
+	.long  0xfea0fe0b    /* xsrqpix 0,v21,v31,3        */
+	.long  0xfea1fe0b    /* xsrqpix 1,v21,v31,3        */
+	.long  0xfd8d7048    /* xsmulqp v12,v13,v14        */
+	.long  0xfdae7849    /* xsmulqpo v13,v14,v15       */
+	.long  0xfec0b84a    /* xsrqpxp 0,v22,v23,0        */
+	.long  0xfec1b84a    /* xsrqpxp 1,v22,v23,0        */
+	.long  0xfec0be4a    /* xsrqpxp 0,v22,v23,3        */
+	.long  0xfec1be4a    /* xsrqpxp 1,v22,v23,3        */
+	.long  0xfdcf80c8    /* xscpsgnqp v14,v15,v16      */
+	.long  0xfc0f8108    /* xscmpoqp cr0,v15,v16       */
+	.long  0xff8f8108    /* xscmpoqp cr7,v15,v16       */
+	.long  0xfc108948    /* xscmpexpqp cr0,v16,v17     */
+	.long  0xff908948    /* xscmpexpqp cr7,v16,v17     */
+	.long  0xfe329b08    /* xsmaddqp v17,v18,v19       */
+	.long  0xfe53a309    /* xsmaddqpo v18,v19,v20      */
+	.long  0xfe74ab48    /* xsmsubqp v19,v20,v21       */
+	.long  0xfe95b349    /* xsmsubqpo v20,v21,v22      */
+	.long  0xfeb6bb88    /* xsnmaddqp v21,v22,v23      */
+	.long  0xfed7c389    /* xsnmaddqpo v22,v23,v24     */
+	.long  0xfef8cbc8    /* xsnmsubqp v23,v24,v25      */
+	.long  0xff19d3c9    /* xsnmsubqpo v24,v25,v26     */
+	.long  0xff3adc08    /* xssubqp v25,v26,v27        */
+	.long  0xff5be409    /* xssubqpo v26,v27,v28       */
+	.long  0xff7cec48    /* xsdivqp v27,v28,v29        */
+	.long  0xff9df449    /* xsdivqpo v28,v29,v30       */
+	.long  0xfc1df508    /* xscmpuqp cr0,v29,v30       */
+	.long  0xff9df508    /* xscmpuqp cr7,v29,v30       */
+	.long  0xfc00f588    /* xststdcqp cr0,v30,0        */
+	.long  0xff80f588    /* xststdcqp cr7,v30,0        */
+	.long  0xfc7ffd88    /* xststdcqp cr0,v31,127      */
+	.long  0xfffffd88    /* xststdcqp cr7,v31,127      */
+	.long  0xfd405e48    /* xsabsqp v10,v11            */
+	.long  0xfd626648    /* xsxexpqp v11,v12           */
+	.long  0xfd886e48    /* xsnabsqp v12,v13           */
+	.long  0xfdb07648    /* xsnegqp v13,v14            */
+	.long  0xfdd27e48    /* xsxsigqp v14,v15           */
+	.long  0xfdfb8648    /* xssqrtqp v15,v16           */
+	.long  0xfe1b8e49    /* xssqrtqpo v16,v17          */
+	.long  0xfe219688    /* xscvqpuwz v17,v18          */
+	.long  0xfe429e88    /* xscvudqp v18,v19           */
+	.long  0xfe69a688    /* xscvqpswz v19,v20          */
+	.long  0xfe8aae88    /* xscvsdqp v20,v21           */
+	.long  0xfeb1b688    /* xscvqpudz v21,v22          */
+	.long  0xfed4be88    /* xscvqpdp v22,v23           */
+	.long  0xfef4c689    /* xscvqpdpo v23,v24          */
+	.long  0xff16ce88    /* xscvdpqp v24,v25           */
+	.long  0xff39d688    /* xscvqpsdz v25,v26          */
+	.long  0xff5be6c8    /* xsiexpqp v26,v27,v28       */
+	.long  0x108531fb    /* vpermr  v4,v5,v6,v7        */
+	.long  0x10a0320d    /* vextractub v5,v6,0         */
+	.long  0x10af320d    /* vextractub v5,v6,15        */
+	.long  0x10c03a4d    /* vextractuh v6,v7,0         */
+	.long  0x10cf3a4d    /* vextractuh v6,v7,15        */
+	.long  0x10e0428d    /* vextractuw v7,v8,0         */
+	.long  0x10ef428d    /* vextractuw v7,v8,15        */
+	.long  0x11004acd    /* vextractd v8,v9,0          */
+	.long  0x110f4acd    /* vextractd v8,v9,15         */
+	.long  0x1120530d    /* vinsertb v9,v10,0          */
+	.long  0x112f530d    /* vinsertb v9,v10,15         */
+	.long  0x11405b4d    /* vinserth v10,v11,0         */
+	.long  0x114f5b4d    /* vinserth v10,v11,15        */
+	.long  0x1160638d    /* vinsertw v11,v12,0         */
+	.long  0x116f638d    /* vinsertw v11,v12,15        */
+	.long  0x11806bcd    /* vinsertd v12,v13,0         */
+	.long  0x118f6bcd    /* vinsertd v12,v13,15        */
+	.long  0x7db40267    /* mfvsrld r20,vs45           */
+	.long  0x7dd50327    /* mtvsrws vs46,r21           */
+	.long  0x7de0bb67    /* mtvsrdd vs47,0,r23         */
+	.long  0x7df6bb67    /* mtvsrdd vs47,r22,r23       */
+	.long  0x7e405a19    /* lxvx    vs50,0,r11         */
+	.long  0x7c0a5a18    /* lxvx    vs0,r10,r11        */
+	.long  0x7e6062d9    /* lxvwsx  vs51,0,r12         */
+	.long  0x7c2a62d8    /* lxvwsx  vs1,r10,r12        */
+	.long  0x7e806e59    /* lxvh8x  vs52,0,r13         */
+	.long  0x7c4a6e58    /* lxvh8x  vs2,r10,r13        */
+	.long  0x7ea076d9    /* lxvb16x vs53,0,r14         */
+	.long  0x7c6a76d8    /* lxvb16x vs3,r10,r14        */
+	.long  0x7ec07b19    /* stxvx   vs54,0,r15         */
+	.long  0x7c947b18    /* stxvx   vs4,r20,r15        */
+	.long  0x7ee08759    /* stxvh8x vs55,0,r16         */
+	.long  0x7cb48758    /* stxvh8x vs5,r20,r16        */
+	.long  0x7f008fd9    /* stxvb16x vs56,0,r17        */
+	.long  0x7cd48fd8    /* stxvb16x vs6,r20,r17       */
+	.long  0xf0802a94    /* xxextractuw vs4,vs5,0      */
+	.long  0xf10f9297    /* xxextractuw vs40,vs50,15   */
+	.long  0xf08002d0    /* xxspltib vs4,0             */
+	.long  0xf08402d0    /* xxspltib vs4,128           */
+	.long  0xf127fad1    /* xxspltib vs41,255          */
+	.long  0xf127fad1    /* xxspltib vs41,255          */
+	.long  0xf0a032d4    /* xxinsertw vs5,vs6,0        */
+	.long  0xf24fe2d7    /* xxinsertw vs50,vs60,15     */
+	.long  0xf0c73f6c    /* xxbrh   vs6,vs7            */
+	.long  0xf307cf6f    /* xxbrh   vs56,vs57          */
+	.long  0xf0ef476c    /* xxbrw   vs7,vs8            */
+	.long  0xf32fd76f    /* xxbrw   vs57,vs58          */
+	.long  0xf1174f6c    /* xxbrd   vs8,vs9            */
+	.long  0xf357df6f    /* xxbrd   vs58,vs59          */
+	.long  0xf13f576c    /* xxbrq   vs9,vs10           */
+	.long  0xf37fe76f    /* xxbrq   vs59,vs60          */
+	.long  0xe6800002    /* lxsd    v20,0(0)           */
+	.long  0xe68a0002    /* lxsd    v20,0(r10)         */
+	.long  0xe680000a    /* lxsd    v20,8(0)           */
+	.long  0xe68a000a    /* lxsd    v20,8(r10)         */
+	.long  0xe680fffa    /* lxsd    v20,-8(0)          */
+	.long  0xe68afffa    /* lxsd    v20,-8(r10)        */
+	.long  0xe6807ffe    /* lxsd    v20,32764(0)       */
+	.long  0xe68a7ffe    /* lxsd    v20,32764(r10)     */
+	.long  0xe6808002    /* lxsd    v20,-32768(0)      */
+	.long  0xe68a8002    /* lxsd    v20,-32768(r10)    */
+	.long  0xe7c00003    /* lxssp   v30,0(0)           */
+	.long  0xe7cb0003    /* lxssp   v30,0(r11)         */
+	.long  0xe7c0000b    /* lxssp   v30,8(0)           */
+	.long  0xe7cb000b    /* lxssp   v30,8(r11)         */
+	.long  0xe7c0fffb    /* lxssp   v30,-8(0)          */
+	.long  0xe7cbfffb    /* lxssp   v30,-8(r11)        */
+	.long  0xe7c07fff    /* lxssp   v30,32764(0)       */
+	.long  0xe7cb7fff    /* lxssp   v30,32764(r11)     */
+	.long  0xe7c08003    /* lxssp   v30,-32768(0)      */
+	.long  0xe7cb8003    /* lxssp   v30,-32768(r11)    */
+	.long  0xf5000009    /* lxv     vs40,0(0)          */
+	.long  0xf50c0009    /* lxv     vs40,0(r12)        */
+	.long  0xf5000019    /* lxv     vs40,16(0)         */
+	.long  0xf50c0019    /* lxv     vs40,16(r12)       */
+	.long  0xf500fff9    /* lxv     vs40,-16(0)        */
+	.long  0xf54cfff1    /* lxv     vs10,-16(r12)      */
+	.long  0xf5407ff1    /* lxv     vs10,32752(0)      */
+	.long  0xf54c7ff1    /* lxv     vs10,32752(r12)    */
+	.long  0xf5408001    /* lxv     vs10,-32768(0)     */
+	.long  0xf54c8001    /* lxv     vs10,-32768(r12)   */
+	.long  0xf6a00002    /* stxsd   v21,0(0)           */
+	.long  0xf6aa0002    /* stxsd   v21,0(r10)         */
+	.long  0xf6a0000a    /* stxsd   v21,8(0)           */
+	.long  0xf6aa000a    /* stxsd   v21,8(r10)         */
+	.long  0xf6a0fffa    /* stxsd   v21,-8(0)          */
+	.long  0xf6aafffa    /* stxsd   v21,-8(r10)        */
+	.long  0xf6a07ffe    /* stxsd   v21,32764(0)       */
+	.long  0xf6aa7ffe    /* stxsd   v21,32764(r10)     */
+	.long  0xf6a08002    /* stxsd   v21,-32768(0)      */
+	.long  0xf6aa8002    /* stxsd   v21,-32768(r10)    */
+	.long  0xf7e00003    /* stxssp  v31,0(0)           */
+	.long  0xf7eb0003    /* stxssp  v31,0(r11)         */
+	.long  0xf7e0000b    /* stxssp  v31,8(0)           */
+	.long  0xf7eb000b    /* stxssp  v31,8(r11)         */
+	.long  0xf7e0fffb    /* stxssp  v31,-8(0)          */
+	.long  0xf7ebfffb    /* stxssp  v31,-8(r11)        */
+	.long  0xf7e07fff    /* stxssp  v31,32764(0)       */
+	.long  0xf7eb7fff    /* stxssp  v31,32764(r11)     */
+	.long  0xf7e08003    /* stxssp  v31,-32768(0)      */
+	.long  0xf7eb8003    /* stxssp  v31,-32768(r11)    */
+	.long  0xf520000d    /* stxv    vs41,0(0)          */
+	.long  0xf52c000d    /* stxv    vs41,0(r12)        */
+	.long  0xf520001d    /* stxv    vs41,16(0)         */
+	.long  0xf52c001d    /* stxv    vs41,16(r12)       */
+	.long  0xf520fffd    /* stxv    vs41,-16(0)        */
+	.long  0xf56cfff5    /* stxv    vs11,-16(r12)      */
+	.long  0xf5607ff5    /* stxv    vs11,32752(0)      */
+	.long  0xf56c7ff5    /* stxv    vs11,32752(r12)    */
+	.long  0xf5608005    /* stxv    vs11,-32768(0)     */
+	.long  0xf56c8005    /* stxv    vs11,-32768(r12)   */
+	.long  0xf296c0d0    /* xxperm  vs20,vs22,vs24     */
+	.long  0xf10a60d7    /* xxperm  vs40,vs42,vs44     */
+	.long  0xf2b7c9d0    /* xxpermr vs21,vs23,vs25     */
+	.long  0xf12b69d7    /* xxpermr vs41,vs43,vs45     */
+	.long  0x7e8c06f4    /* extswsli r12,r20,0         */
+	.long  0x7e8c0ef4    /* extswsli r12,r20,1         */
+	.long  0x7e8cfef6    /* extswsli r12,r20,63        */
+	.long  0x7ead06f5    /* extswsli. r13,r21,0        */
+	.long  0x7ead0ef5    /* extswsli. r13,r21,1        */
+	.long  0x7eadfef7    /* extswsli. r13,r21,63       */
+	.long  0x11d6b885    /* vrlwmi  v14,v22,v23        */
+	.long  0x11f7c0c5    /* vrldmi  v15,v23,v24        */
+	.long  0x1218c985    /* vrlwnm  v16,v24,v25        */
+	.long  0x1239d1c5    /* vrldnm  v17,v25,v26        */
+	.long  0x125addcc    /* vbpermd v18,v26,v27        */
+	.long  0x1266a602    /* vnegw   v19,v20            */
+	.long  0x1287ae02    /* vnegd   v20,v21            */
+	.long  0x12a8b602    /* vprtybw v21,v22            */
+	.long  0x12c9be02    /* vprtybd v22,v23            */
+	.long  0x12eac602    /* vprtybq v23,v24            */
+	.long  0x1310ce02    /* vextsb2w v24,v25           */
+	.long  0x1331d602    /* vextsh2w v25,v26           */
+	.long  0x1358de02    /* vextsb2d v26,v27           */
+	.long  0x1379e602    /* vextsh2d v27,v28           */
+	.long  0x139aee02    /* vextsw2d v28,v29           */
+	.long  0x13bcf602    /* vctzb   v29,v30            */
+	.long  0x13ddfe02    /* vctzh   v30,v31            */
+	.long  0x13fef602    /* vctzw   v31,v30            */
+	.long  0x13dfee02    /* vctzd   v30,v29            */
+	.long  0x7d40a61a    /* lxsibzx vs10,0,r20         */
+	.long  0x7e4aa61b    /* lxsibzx vs50,r10,r20       */
+	.long  0x7d60ae5a    /* lxsihzx vs11,0,r21         */
+	.long  0x7e6bae5b    /* lxsihzx vs51,r11,r21       */
+	.long  0x7d80b71a    /* stxsibx vs12,0,r22         */
+	.long  0x7e8cb71b    /* stxsibx vs52,r12,r22       */
+	.long  0x7da0bf5a    /* stxsihx vs13,0,r23         */
+	.long  0x7eadbf5b    /* stxsihx vs53,r13,r23       */
+	.long  0x114b6370    /* maddhd  r10,r11,r12,r13    */
+	.long  0x1295b5f1    /* maddhdu r20,r21,r22,r23    */
+	.long  0x10432173    /* maddld  r2,r3,r4,r5        */
+	.long  0xf00aa1d8    /* xscmpexpdp cr0,vs10,vs20   */
+	.long  0xf38891de    /* xscmpexpdp cr7,vs40,vs50   */
+	.long  0xf12baf2d    /* xsiexpdp vs41,r11,r21      */
+	.long  0xf07f5da8    /* xststdcdp cr0,vs11,127     */
+	.long  0xf3ff4daa    /* xststdcdp cr7,vs41,127     */
+	.long  0xf07f5ca8    /* xststdcsp cr0,vs11,127     */
+	.long  0xf3ff4caa    /* xststdcsp cr7,vs41,127     */
+	.long  0xf1a05d6e    /* xsxexpdp r13,vs43          */
+	.long  0xf1c1656e    /* xsxsigdp r14,vs44          */
+	.long  0xf1ae7fc7    /* xviexpdp vs45,vs46,vs47    */
+	.long  0xf1cf86c7    /* xviexpsp vs46,vs47,vs48    */
+	.long  0xf2c0bfab    /* xvtstdcdp vs54,vs55,0      */
+	.long  0xf2dfbfef    /* xvtstdcdp vs54,vs55,127    */
+	.long  0xf2e0c6ab    /* xvtstdcsp vs55,vs56,0      */
+	.long  0xf2ffc6ef    /* xvtstdcsp vs55,vs56,127    */
+	.long  0xf320d76f    /* xvxexpdp vs57,vs58         */
+	.long  0xf348df6f    /* xvxexpsp vs58,vs59         */
+	.long  0xf361e76f    /* xvxsigdp vs59,vs60         */
+	.long  0xf389ef6f    /* xvxsigsp vs60,vs61         */
+	.long  0x7c0639c0    /* cmpeqb  cr0,r6,r7          */
+	.long  0x7f8639c0    /* cmpeqb  cr7,r6,r7          */
+	.long  0x7c084980    /* cmprb   cr0,0,r8,r9        */
+	.long  0x7f884980    /* cmprb   cr7,0,r8,r9        */
+	.long  0x7c284980    /* cmprb   cr0,1,r8,r9        */
+	.long  0x7fa84980    /* cmprb   cr7,1,r8,r9        */
+	.long  0x7de00100    /* setb    r15,cr0            */
+	.long  0x7dfc0100    /* setb    r15,cr7            */
+	.long  0x7f40521a    /* lxvl    vs26,0,r10         */
+	.long  0x7f14521b    /* lxvl    vs56,r20,r10       */
+	.long  0x7f605b1a    /* stxvl   vs27,0,r11         */
+	.long  0x7f355b1b    /* stxvl   vs57,r21,r11       */
+	.long  0x1280f602    /* vclzlsbb r20,v30           */
+	.long  0x12a1fe02    /* vctzlsbb r21,v31           */
+	.long  0x114b6007    /* vcmpneb v10,v11,v12        */
+	.long  0x1295b407    /* vcmpneb. v20,v21,v22       */
+	.long  0x116c6847    /* vcmpneh v11,v12,v13        */
+	.long  0x12b6bc47    /* vcmpneh. v21,v22,v23       */
+	.long  0x118d7087    /* vcmpnew v12,v13,v14        */
+	.long  0x12d7c487    /* vcmpnew. v22,v23,v24       */
+	.long  0x11ae7907    /* vcmpnezb v13,v14,v15       */
+	.long  0x12f8cd07    /* vcmpnezb. v23,v24,v25      */
+	.long  0x11cf8147    /* vcmpnezh v14,v15,v16       */
+	.long  0x1319d547    /* vcmpnezh. v24,v25,v26      */
+	.long  0x11f08987    /* vcmpnezw v15,v16,v17       */
+	.long  0x133add87    /* vcmpnezw. v25,v26,v27      */
+	.long  0x1211560d    /* vextublx r16,r17,v10       */
+	.long  0x12325f0d    /* vextubrx r17,r18,v11       */
+	.long  0x1253664d    /* vextuhlx r18,r19,v12       */
+	.long  0x12746f4d    /* vextuhrx r19,r20,v13       */
+	.long  0x1295768d    /* vextuwlx r20,r21,v14       */
+	.long  0x12b67f8d    /* vextuwrx r21,r22,v15       */
+	.long  0xec001d46    /* dtstsfi cr0,0,f3           */
+	.long  0xefbf1d46    /* dtstsfi cr7,63,f3          */
+	.long  0xfc002546    /* dtstsfiq cr0,0,f4          */
+	.long  0xffbf2546    /* dtstsfiq cr7,63,f4         */
+	.long  0xf110956f    /* xscvhpdp vs40,vs50         */
+	.long  0xf1319d6f    /* xscvdphp vs41,vs51         */
+	.long  0xf158a76f    /* xvcvhpsp vs42,vs52         */
+	.long  0xf179af6f    /* xvcvsphp vs43,vs53         */
+	.long  0x4c600004    /* addpcis r3,0               */
+	.long  0x4c600004    /* addpcis r3,0               */
+	.long  0x4c800005    /* addpcis r4,1               */
+	.long  0x4c800005    /* addpcis r4,1               */
+	.long  0x4cbfffc4    /* addpcis r5,-2              */
+	.long  0x4cbfffc4    /* addpcis r5,-2              */
+	.long  0x4cdf7fc5    /* addpcis r6,32767           */
+	.long  0x4cdf7fc5    /* addpcis r6,32767           */
+	.long  0x4ce08004    /* addpcis r7,-32768          */
+	.long  0x4ce08004    /* addpcis r7,-32768          */
+	.long  0x7c0002a4    /* slbsync                    */
+	.long  0x7d4006a4    /* slbiag  r10                */
+	.long  0x7d405ba4    /* slbieg  r10,r11            */
+	.long  0x7c602726    /* slbmfee r3,r4              */
+	.long  0x7c602726    /* slbmfee r3,r4              */
+	.long  0x7c612726    /* slbmfee r3,r4,1            */
+	.long  0x7c802ea6    /* slbmfev r4,r5              */
+	.long  0x7c802ea6    /* slbmfev r4,r5              */
+	.long  0x7c812ea6    /* slbmfev r4,r5,1            */
+	.long  0x7c801a64    /* tlbie   r3,r4              */
+	.long  0x7c801a64    /* tlbie   r3,r4              */
+	.long  0x7c8f1a64    /* tlbie   r3,r4,3,1,1        */
+	.long  0x7c001a24    /* tlbiel  r3                 */
+	.long  0x7c001a24    /* tlbiel  r3                 */
+	.long  0x7c8f1a24    /* tlbiel  r3,r4,3,1,1        */
+	.long  0x7c2c6e0c    /* copy    r12,r13            */
+	.long  0x7c2a5f0d    /* paste.  r10,r11            */
+	.long  0x7c00068c    /* cpabort                    */
+	.long  0x7c0004ac    /* hwsync                     */
+	.long  0x7c0004ac    /* hwsync                     */
+	.long  0x7c0004ac    /* hwsync                     */
+	.long  0x7c2004ac    /* lwsync                     */
+	.long  0x7c2004ac    /* lwsync                     */
+	.long  0x7c4004ac    /* ptesync                    */
+	.long  0x7c4004ac    /* ptesync                    */
+	.long  0x7e8004cc    /* ldat    r20,0,0            */
+	.long  0x7e8ae4cc    /* ldat    r20,r10,28         */
+	.long  0x7ea0048c    /* lwat    r21,0,0            */
+	.long  0x7eabe48c    /* lwat    r21,r11,28         */
+	.long  0x7ec005cc    /* stdat   r22,0,0            */
+	.long  0x7ecce5cc    /* stdat   r22,r12,28         */
+	.long  0x7ee0058c    /* stwat   r23,0,0            */
+	.long  0x7eede58c    /* stwat   r23,r13,28         */
+	.long  0x4c000264    /* urfid                      */
+	.long  0x7c00f6e4    /* rmieg   r30                */
+	.long  0x7d407a6a    /* ldmx    r10,0,r15          */
+	.long  0x7d437a6a    /* ldmx    r10,r3,r15         */
+	.long  0x4c0002e4    /* stop                       */
+	.long  0x7c00003c    /* wait                       */
+	.long  0x7c00003c    /* wait                       */
+	.long  0x7c6005e6    /* darn    r3,0               */
+	.long  0x7c6105e6    /* darn    r3,1               */
+	.long  0x7c6205e6    /* darn    r3,2               */
+	.long  0x7c000480    /* mcrxrx  cr0                */
+	.long  0x7f800480    /* mcrxrx  cr7                */
+	.long  0x1295b744    /* vslv    v20,v21,v22        */
+	.long  0x12f8cf04    /* vsrv    v23,v24,v25        */
+	.long  0x7c0006ec    /* msgsync                    */
+	.long  0xf3c8901e    /* xscmpeqdp vs30,vs40,vs50   */
+	.long  0xf3e9985e    /* xscmpgtdp vs31,vs41,vs51   */
+	.long  0xf00aa09f    /* xscmpgedp vs32,vs42,vs52   */
+	.long  0xf04cb447    /* xsmincdp vs34,vs44,vs54    */
+	.long  0xf06dbc07    /* xsmaxcdp vs35,vs45,vs55    */
+	.long  0xf08ec4c7    /* xsminjdp vs36,vs46,vs56    */
+	.long  0xf0afcc87    /* xsmaxjdp vs37,vs47,vs57    */
+	.long  0x1295b5e3    /* vmsumudm v20,v21,v22,v23   */
+	.long  0x7d6c6954    /* addex   r11,r12,r13,0      */
+	.long  0x7d6c6b54    /* addex   r11,r12,r13,1      */
+	.long  0x7d6c6d54    /* addex   r11,r12,r13,2      */
+	.long  0xff20048e    /* mffs    f25                */
+	.long  0xff20048f    /* mffs.   f25                */
+	.long  0xff41048e    /* mffsce  f26                */
+	.long  0xff74a48e    /* mffscdrn f27,f20           */
+	.long  0xff95048e    /* mffscdrni f28,0            */
+	.long  0xff953c8e    /* mffscdrni f28,7            */
+	.long  0xffb6ac8e    /* mffscrn f29,f21            */
+	.long  0xffd7048e    /* mffscrni f30,0             */
+	.long  0xffd71c8e    /* mffscrni f30,3             */
+	.long  0xfff8048e    /* mffsl   f31                */
diff --git a/gdb/testsuite/gdb.arch/powerpc-vsx.exp b/gdb/testsuite/gdb.arch/powerpc-vsx.exp
new file mode 100644
index 0000000..41b06ce
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-vsx.exp
@@ -0,0 +1,222 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu vsx"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "lxsdx   vs40,r10,r20"
+func_check "lxvd2x  vs40,r10,r20"
+func_check "lxvdsx  vs40,r10,r20"
+func_check "lxvw4x  vs40,r10,r20"
+func_check "stxsdx  vs40,r10,r20"
+func_check "stxvd2x vs40,r10,r20"
+func_check "stxvw4x vs40,r10,r20"
+func_check "xsabsdp vs40,vs60"
+func_check "xsadddp vs40,vs50,vs60"
+func_check "xscmpodp cr1,vs50,vs60"
+func_check "xscmpudp cr1,vs50,vs60"
+func_check "xscpsgndp vs40,vs50,vs60"
+func_check "xscvdpsp vs40,vs60"
+func_check "xscvdpsxds vs40,vs60"
+func_check "xscvdpsxws vs40,vs60"
+func_check "xscvdpuxds vs40,vs60"
+func_check "xscvdpuxws vs40,vs60"
+func_check "xscvspdp vs40,vs60"
+func_check "xscvsxddp vs40,vs60"
+func_check "xscvuxddp vs40,vs60"
+func_check "xsdivdp vs40,vs50,vs60"
+func_check "xsmaddadp vs40,vs50,vs60"
+func_check "xsmaddmdp vs40,vs50,vs60"
+func_check "xsmaxdp vs40,vs50,vs60"
+func_check "xsmindp vs40,vs50,vs60"
+func_check "xsmsubadp vs40,vs50,vs60"
+func_check "xsmsubmdp vs40,vs50,vs60"
+func_check "xsmuldp vs40,vs50,vs60"
+func_check "xsnabsdp vs40,vs60"
+func_check "xsnegdp vs40,vs60"
+func_check "xsnmaddadp vs40,vs50,vs60"
+func_check "xsnmaddmdp vs40,vs50,vs60"
+func_check "xsnmsubadp vs40,vs50,vs60"
+func_check "xsnmsubmdp vs40,vs50,vs60"
+func_check "xsrdpi  vs40,vs60"
+func_check "xsrdpic vs40,vs60"
+func_check "xsrdpim vs40,vs60"
+func_check "xsrdpip vs40,vs60"
+func_check "xsrdpiz vs40,vs60"
+func_check "xsredp  vs40,vs60"
+func_check "xsrsqrtedp vs40,vs60"
+func_check "xssqrtdp vs40,vs60"
+func_check "xssubdp vs40,vs50,vs60"
+func_check "xstdivdp cr1,vs50,vs60"
+func_check "xstsqrtdp cr1,vs60"
+func_check "xvabsdp vs40,vs60"
+func_check "xvabssp vs40,vs60"
+func_check "xvadddp vs40,vs50,vs60"
+func_check "xvaddsp vs40,vs50,vs60"
+func_check "xvcmpeqdp vs40,vs50,vs60"
+func_check "xvcmpeqdp\. vs40,vs50,vs60"
+func_check "xvcmpeqsp vs40,vs50,vs60"
+func_check "xvcmpeqsp\. vs40,vs50,vs60"
+func_check "xvcmpgedp vs40,vs50,vs60"
+func_check "xvcmpgedp\. vs40,vs50,vs60"
+func_check "xvcmpgesp vs40,vs50,vs60"
+func_check "xvcmpgesp\. vs40,vs50,vs60"
+func_check "xvcmpgtdp vs40,vs50,vs60"
+func_check "xvcmpgtdp\. vs40,vs50,vs60"
+func_check "xvcmpgtsp vs40,vs50,vs60"
+func_check "xvcmpgtsp\. vs40,vs50,vs60"
+func_check "xvcpsgndp vs40,vs50,vs60"
+func_check "xvmovdp vs40,vs60"
+func_check "xvmovdp vs40,vs60"
+func_check "xvcpsgnsp vs40,vs50,vs60"
+func_check "xvmovsp vs40,vs60"
+func_check "xvmovsp vs40,vs60"
+func_check "xvcvdpsp vs40,vs60"
+func_check "xvcvdpsxds vs40,vs60"
+func_check "xvcvdpsxws vs40,vs60"
+func_check "xvcvdpuxds vs40,vs60"
+func_check "xvcvdpuxws vs40,vs60"
+func_check "xvcvspdp vs40,vs60"
+func_check "xvcvspsxds vs40,vs60"
+func_check "xvcvspsxws vs40,vs60"
+func_check "xvcvspuxds vs40,vs60"
+func_check "xvcvspuxws vs40,vs60"
+func_check "xvcvsxddp vs40,vs60"
+func_check "xvcvsxdsp vs40,vs60"
+func_check "xvcvsxwdp vs40,vs60"
+func_check "xvcvsxwsp vs40,vs60"
+func_check "xvcvuxddp vs40,vs60"
+func_check "xvcvuxdsp vs40,vs60"
+func_check "xvcvuxwdp vs40,vs60"
+func_check "xvcvuxwsp vs40,vs60"
+func_check "xvdivdp vs40,vs50,vs60"
+func_check "xvdivsp vs40,vs50,vs60"
+func_check "xvmaddadp vs40,vs50,vs60"
+func_check "xvmaddmdp vs40,vs50,vs60"
+func_check "xvmaddasp vs40,vs50,vs60"
+func_check "xvmaddmsp vs40,vs50,vs60"
+func_check "xvmaxdp vs40,vs50,vs60"
+func_check "xvmaxsp vs40,vs50,vs60"
+func_check "xvmindp vs40,vs50,vs60"
+func_check "xvminsp vs40,vs50,vs60"
+func_check "xvmsubadp vs40,vs50,vs60"
+func_check "xvmsubmdp vs40,vs50,vs60"
+func_check "xvmsubasp vs40,vs50,vs60"
+func_check "xvmsubmsp vs40,vs50,vs60"
+func_check "xvmuldp vs40,vs50,vs60"
+func_check "xvmulsp vs40,vs50,vs60"
+func_check "xvnabsdp vs40,vs60"
+func_check "xvnabssp vs40,vs60"
+func_check "xvnegdp vs40,vs60"
+func_check "xvnegsp vs40,vs60"
+func_check "xvnmaddadp vs40,vs50,vs60"
+func_check "xvnmaddmdp vs40,vs50,vs60"
+func_check "xvnmaddasp vs40,vs50,vs60"
+func_check "xvnmaddmsp vs40,vs50,vs60"
+func_check "xvnmsubadp vs40,vs50,vs60"
+func_check "xvnmsubmdp vs40,vs50,vs60"
+func_check "xvnmsubasp vs40,vs50,vs60"
+func_check "xvnmsubmsp vs40,vs50,vs60"
+func_check "xvrdpi  vs40,vs60"
+func_check "xvrdpic vs40,vs60"
+func_check "xvrdpim vs40,vs60"
+func_check "xvrdpip vs40,vs60"
+func_check "xvrdpiz vs40,vs60"
+func_check "xvredp  vs40,vs60"
+func_check "xvresp  vs40,vs60"
+func_check "xvrspi  vs40,vs60"
+func_check "xvrspic vs40,vs60"
+func_check "xvrspim vs40,vs60"
+func_check "xvrspip vs40,vs60"
+func_check "xvrspiz vs40,vs60"
+func_check "xvrsqrtedp vs40,vs60"
+func_check "xvrsqrtesp vs40,vs60"
+func_check "xvsqrtdp vs40,vs60"
+func_check "xvsqrtsp vs40,vs60"
+func_check "xvsubdp vs40,vs50,vs60"
+func_check "xvsubsp vs40,vs50,vs60"
+func_check "xvtdivdp cr1,vs50,vs60"
+func_check "xvtdivsp cr1,vs50,vs60"
+func_check "xvtsqrtdp cr1,vs60"
+func_check "xvtsqrtsp cr1,vs60"
+func_check "xxland  vs40,vs50,vs60"
+func_check "xxlandc vs40,vs50,vs60"
+func_check "xxlnor  vs40,vs50,vs60"
+func_check "xxlor   vs40,vs50,vs60"
+func_check "xxlxor  vs40,vs50,vs60"
+func_check "xxmrghw vs40,vs50,vs60"
+func_check "xxmrglw vs40,vs50,vs60"
+func_check "xxmrghd vs40,vs50,vs60"
+func_check "xxpermdi vs40,vs50,vs60,1"
+func_check "xxpermdi vs40,vs50,vs60,2"
+func_check "xxmrgld vs40,vs50,vs60"
+func_check "xxspltd vs40,vs50,0"
+func_check "xxspltd vs40,vs50,0"
+func_check "xxspltd vs40,vs50,1"
+func_check "xxspltd vs40,vs50,1"
+func_check "xxmrghd vs40,vs50,vs60"
+func_check "xxmrghd vs40,vs50,vs60"
+func_check "xxmrgld vs40,vs50,vs60"
+func_check "xxswapd vs40,vs50"
+func_check "xxswapd vs40,vs50"
+func_check "xxsel   vs40,vs50,vs60,vs62"
+func_check "xxsldwi vs40,vs50,vs60,2"
+func_check "xxspltw vs40,vs60,2"
+func_check "lxvd2x  vs40,0,r20"
+func_check "lxvd2x  vs40,r10,r20"
+func_check "stxvd2x vs40,0,r20"
+func_check "stxvd2x vs40,r10,r20"
diff --git a/gdb/testsuite/gdb.arch/powerpc-vsx.s b/gdb/testsuite/gdb.arch/powerpc-vsx.s
new file mode 100644
index 0000000..c7e85c1
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-vsx.s
@@ -0,0 +1,182 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7d0aa499    /* lxsdx   vs40,r10,r20       */
+	.long  0x7d0aa699    /* lxvd2x  vs40,r10,r20       */
+	.long  0x7d0aa299    /* lxvdsx  vs40,r10,r20       */
+	.long  0x7d0aa619    /* lxvw4x  vs40,r10,r20       */
+	.long  0x7d0aa599    /* stxsdx  vs40,r10,r20       */
+	.long  0x7d0aa799    /* stxvd2x vs40,r10,r20       */
+	.long  0x7d0aa719    /* stxvw4x vs40,r10,r20       */
+	.long  0xf100e567    /* xsabsdp vs40,vs60          */
+	.long  0xf112e107    /* xsadddp vs40,vs50,vs60     */
+	.long  0xf092e15e    /* xscmpodp cr1,vs50,vs60     */
+	.long  0xf092e11e    /* xscmpudp cr1,vs50,vs60     */
+	.long  0xf112e587    /* xscpsgndp vs40,vs50,vs60   */
+	.long  0xf100e427    /* xscvdpsp vs40,vs60         */
+	.long  0xf100e563    /* xscvdpsxds vs40,vs60       */
+	.long  0xf100e163    /* xscvdpsxws vs40,vs60       */
+	.long  0xf100e523    /* xscvdpuxds vs40,vs60       */
+	.long  0xf100e123    /* xscvdpuxws vs40,vs60       */
+	.long  0xf100e527    /* xscvspdp vs40,vs60         */
+	.long  0xf100e5e3    /* xscvsxddp vs40,vs60        */
+	.long  0xf100e5a3    /* xscvuxddp vs40,vs60        */
+	.long  0xf112e1c7    /* xsdivdp vs40,vs50,vs60     */
+	.long  0xf112e10f    /* xsmaddadp vs40,vs50,vs60   */
+	.long  0xf112e14f    /* xsmaddmdp vs40,vs50,vs60   */
+	.long  0xf112e507    /* xsmaxdp vs40,vs50,vs60     */
+	.long  0xf112e547    /* xsmindp vs40,vs50,vs60     */
+	.long  0xf112e18f    /* xsmsubadp vs40,vs50,vs60   */
+	.long  0xf112e1cf    /* xsmsubmdp vs40,vs50,vs60   */
+	.long  0xf112e187    /* xsmuldp vs40,vs50,vs60     */
+	.long  0xf100e5a7    /* xsnabsdp vs40,vs60         */
+	.long  0xf100e5e7    /* xsnegdp vs40,vs60          */
+	.long  0xf112e50f    /* xsnmaddadp vs40,vs50,vs60  */
+	.long  0xf112e54f    /* xsnmaddmdp vs40,vs50,vs60  */
+	.long  0xf112e58f    /* xsnmsubadp vs40,vs50,vs60  */
+	.long  0xf112e5cf    /* xsnmsubmdp vs40,vs50,vs60  */
+	.long  0xf100e127    /* xsrdpi  vs40,vs60          */
+	.long  0xf100e1af    /* xsrdpic vs40,vs60          */
+	.long  0xf100e1e7    /* xsrdpim vs40,vs60          */
+	.long  0xf100e1a7    /* xsrdpip vs40,vs60          */
+	.long  0xf100e167    /* xsrdpiz vs40,vs60          */
+	.long  0xf100e16b    /* xsredp  vs40,vs60          */
+	.long  0xf100e12b    /* xsrsqrtedp vs40,vs60       */
+	.long  0xf100e12f    /* xssqrtdp vs40,vs60         */
+	.long  0xf112e147    /* xssubdp vs40,vs50,vs60     */
+	.long  0xf092e1ee    /* xstdivdp cr1,vs50,vs60     */
+	.long  0xf080e1aa    /* xstsqrtdp cr1,vs60         */
+	.long  0xf100e767    /* xvabsdp vs40,vs60          */
+	.long  0xf100e667    /* xvabssp vs40,vs60          */
+	.long  0xf112e307    /* xvadddp vs40,vs50,vs60     */
+	.long  0xf112e207    /* xvaddsp vs40,vs50,vs60     */
+	.long  0xf112e31f    /* xvcmpeqdp vs40,vs50,vs60   */
+	.long  0xf112e71f    /* xvcmpeqdp. vs40,vs50,vs60  */
+	.long  0xf112e21f    /* xvcmpeqsp vs40,vs50,vs60   */
+	.long  0xf112e61f    /* xvcmpeqsp. vs40,vs50,vs60  */
+	.long  0xf112e39f    /* xvcmpgedp vs40,vs50,vs60   */
+	.long  0xf112e79f    /* xvcmpgedp. vs40,vs50,vs60  */
+	.long  0xf112e29f    /* xvcmpgesp vs40,vs50,vs60   */
+	.long  0xf112e69f    /* xvcmpgesp. vs40,vs50,vs60  */
+	.long  0xf112e35f    /* xvcmpgtdp vs40,vs50,vs60   */
+	.long  0xf112e75f    /* xvcmpgtdp. vs40,vs50,vs60  */
+	.long  0xf112e25f    /* xvcmpgtsp vs40,vs50,vs60   */
+	.long  0xf112e65f    /* xvcmpgtsp. vs40,vs50,vs60  */
+	.long  0xf112e787    /* xvcpsgndp vs40,vs50,vs60   */
+	.long  0xf11ce787    /* xvmovdp vs40,vs60          */
+	.long  0xf11ce787    /* xvmovdp vs40,vs60          */
+	.long  0xf112e687    /* xvcpsgnsp vs40,vs50,vs60   */
+	.long  0xf11ce687    /* xvmovsp vs40,vs60          */
+	.long  0xf11ce687    /* xvmovsp vs40,vs60          */
+	.long  0xf100e627    /* xvcvdpsp vs40,vs60         */
+	.long  0xf100e763    /* xvcvdpsxds vs40,vs60       */
+	.long  0xf100e363    /* xvcvdpsxws vs40,vs60       */
+	.long  0xf100e723    /* xvcvdpuxds vs40,vs60       */
+	.long  0xf100e323    /* xvcvdpuxws vs40,vs60       */
+	.long  0xf100e727    /* xvcvspdp vs40,vs60         */
+	.long  0xf100e663    /* xvcvspsxds vs40,vs60       */
+	.long  0xf100e263    /* xvcvspsxws vs40,vs60       */
+	.long  0xf100e623    /* xvcvspuxds vs40,vs60       */
+	.long  0xf100e223    /* xvcvspuxws vs40,vs60       */
+	.long  0xf100e7e3    /* xvcvsxddp vs40,vs60        */
+	.long  0xf100e6e3    /* xvcvsxdsp vs40,vs60        */
+	.long  0xf100e3e3    /* xvcvsxwdp vs40,vs60        */
+	.long  0xf100e2e3    /* xvcvsxwsp vs40,vs60        */
+	.long  0xf100e7a3    /* xvcvuxddp vs40,vs60        */
+	.long  0xf100e6a3    /* xvcvuxdsp vs40,vs60        */
+	.long  0xf100e3a3    /* xvcvuxwdp vs40,vs60        */
+	.long  0xf100e2a3    /* xvcvuxwsp vs40,vs60        */
+	.long  0xf112e3c7    /* xvdivdp vs40,vs50,vs60     */
+	.long  0xf112e2c7    /* xvdivsp vs40,vs50,vs60     */
+	.long  0xf112e30f    /* xvmaddadp vs40,vs50,vs60   */
+	.long  0xf112e34f    /* xvmaddmdp vs40,vs50,vs60   */
+	.long  0xf112e20f    /* xvmaddasp vs40,vs50,vs60   */
+	.long  0xf112e24f    /* xvmaddmsp vs40,vs50,vs60   */
+	.long  0xf112e707    /* xvmaxdp vs40,vs50,vs60     */
+	.long  0xf112e607    /* xvmaxsp vs40,vs50,vs60     */
+	.long  0xf112e747    /* xvmindp vs40,vs50,vs60     */
+	.long  0xf112e647    /* xvminsp vs40,vs50,vs60     */
+	.long  0xf112e38f    /* xvmsubadp vs40,vs50,vs60   */
+	.long  0xf112e3cf    /* xvmsubmdp vs40,vs50,vs60   */
+	.long  0xf112e28f    /* xvmsubasp vs40,vs50,vs60   */
+	.long  0xf112e2cf    /* xvmsubmsp vs40,vs50,vs60   */
+	.long  0xf112e387    /* xvmuldp vs40,vs50,vs60     */
+	.long  0xf112e287    /* xvmulsp vs40,vs50,vs60     */
+	.long  0xf100e7a7    /* xvnabsdp vs40,vs60         */
+	.long  0xf100e6a7    /* xvnabssp vs40,vs60         */
+	.long  0xf100e7e7    /* xvnegdp vs40,vs60          */
+	.long  0xf100e6e7    /* xvnegsp vs40,vs60          */
+	.long  0xf112e70f    /* xvnmaddadp vs40,vs50,vs60  */
+	.long  0xf112e74f    /* xvnmaddmdp vs40,vs50,vs60  */
+	.long  0xf112e60f    /* xvnmaddasp vs40,vs50,vs60  */
+	.long  0xf112e64f    /* xvnmaddmsp vs40,vs50,vs60  */
+	.long  0xf112e78f    /* xvnmsubadp vs40,vs50,vs60  */
+	.long  0xf112e7cf    /* xvnmsubmdp vs40,vs50,vs60  */
+	.long  0xf112e68f    /* xvnmsubasp vs40,vs50,vs60  */
+	.long  0xf112e6cf    /* xvnmsubmsp vs40,vs50,vs60  */
+	.long  0xf100e327    /* xvrdpi  vs40,vs60          */
+	.long  0xf100e3af    /* xvrdpic vs40,vs60          */
+	.long  0xf100e3e7    /* xvrdpim vs40,vs60          */
+	.long  0xf100e3a7    /* xvrdpip vs40,vs60          */
+	.long  0xf100e367    /* xvrdpiz vs40,vs60          */
+	.long  0xf100e36b    /* xvredp  vs40,vs60          */
+	.long  0xf100e26b    /* xvresp  vs40,vs60          */
+	.long  0xf100e227    /* xvrspi  vs40,vs60          */
+	.long  0xf100e2af    /* xvrspic vs40,vs60          */
+	.long  0xf100e2e7    /* xvrspim vs40,vs60          */
+	.long  0xf100e2a7    /* xvrspip vs40,vs60          */
+	.long  0xf100e267    /* xvrspiz vs40,vs60          */
+	.long  0xf100e32b    /* xvrsqrtedp vs40,vs60       */
+	.long  0xf100e22b    /* xvrsqrtesp vs40,vs60       */
+	.long  0xf100e32f    /* xvsqrtdp vs40,vs60         */
+	.long  0xf100e22f    /* xvsqrtsp vs40,vs60         */
+	.long  0xf112e347    /* xvsubdp vs40,vs50,vs60     */
+	.long  0xf112e247    /* xvsubsp vs40,vs50,vs60     */
+	.long  0xf092e3ee    /* xvtdivdp cr1,vs50,vs60     */
+	.long  0xf092e2ee    /* xvtdivsp cr1,vs50,vs60     */
+	.long  0xf080e3aa    /* xvtsqrtdp cr1,vs60         */
+	.long  0xf080e2aa    /* xvtsqrtsp cr1,vs60         */
+	.long  0xf112e417    /* xxland  vs40,vs50,vs60     */
+	.long  0xf112e457    /* xxlandc vs40,vs50,vs60     */
+	.long  0xf112e517    /* xxlnor  vs40,vs50,vs60     */
+	.long  0xf112e497    /* xxlor   vs40,vs50,vs60     */
+	.long  0xf112e4d7    /* xxlxor  vs40,vs50,vs60     */
+	.long  0xf112e097    /* xxmrghw vs40,vs50,vs60     */
+	.long  0xf112e197    /* xxmrglw vs40,vs50,vs60     */
+	.long  0xf112e057    /* xxmrghd vs40,vs50,vs60     */
+	.long  0xf112e157    /* xxpermdi vs40,vs50,vs60,1  */
+	.long  0xf112e257    /* xxpermdi vs40,vs50,vs60,2  */
+	.long  0xf112e357    /* xxmrgld vs40,vs50,vs60     */
+	.long  0xf1129057    /* xxspltd vs40,vs50,0        */
+	.long  0xf1129057    /* xxspltd vs40,vs50,0        */
+	.long  0xf1129357    /* xxspltd vs40,vs50,1        */
+	.long  0xf1129357    /* xxspltd vs40,vs50,1        */
+	.long  0xf112e057    /* xxmrghd vs40,vs50,vs60     */
+	.long  0xf112e057    /* xxmrghd vs40,vs50,vs60     */
+	.long  0xf112e357    /* xxmrgld vs40,vs50,vs60     */
+	.long  0xf1129257    /* xxswapd vs40,vs50          */
+	.long  0xf1129257    /* xxswapd vs40,vs50          */
+	.long  0xf112e7bf    /* xxsel   vs40,vs50,vs60,vs62 */
+	.long  0xf112e217    /* xxsldwi vs40,vs50,vs60,2   */
+	.long  0xf102e293    /* xxspltw vs40,vs60,2        */
+	.long  0x7d00a699    /* lxvd2x  vs40,0,r20         */
+	.long  0x7d0aa699    /* lxvd2x  vs40,r10,r20       */
+	.long  0x7d00a799    /* stxvd2x vs40,0,r20         */
+	.long  0x7d0aa799    /* stxvd2x vs40,r10,r20       */
diff --git a/gdb/testsuite/gdb.arch/powerpc-vsx2.exp b/gdb/testsuite/gdb.arch/powerpc-vsx2.exp
new file mode 100644
index 0000000..8f84eee
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-vsx2.exp
@@ -0,0 +1,115 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu vsx"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "lxsiwzx vs62,r14,r26"
+func_check "lxsiwzx vs40,0,r25"
+func_check "lxsiwax vs25,0,r26"
+func_check "lxsiwax vs3,0,r3"
+func_check "mfvsrd  r12,vs30"
+func_check "mfvsrd  r12,vs30"
+func_check "mfvsrd  r12,vs62"
+func_check "mfvsrd  r12,vs62"
+func_check "mffprwz r20,f12"
+func_check "mffprwz r20,f12"
+func_check "mfvrwz  r21,v12"
+func_check "mfvrwz  r21,v12"
+func_check "stxsiwx vs14,r9,r14"
+func_check "stxsiwx vs21,0,r8"
+func_check "mtvsrd  vs11,r28"
+func_check "mtvsrd  vs11,r28"
+func_check "mtvsrd  vs43,r29"
+func_check "mtvsrd  vs43,r29"
+func_check "mtfprwa f24,r22"
+func_check "mtfprwa f24,r22"
+func_check "mtvrwa  v25,r23"
+func_check "mtvrwa  v25,r23"
+func_check "mtfprwz f26,r27"
+func_check "mtfprwz f26,r27"
+func_check "mtvrwz  v27,r28"
+func_check "mtvrwz  v27,r28"
+func_check "lxsspx  vs13,r19,r13"
+func_check "lxsspx  vs18,0,r13"
+func_check "stxsspx vs43,r2,r4"
+func_check "stxsspx vs55,0,r11"
+func_check "xsaddsp vs54,vs48,vs25"
+func_check "xsmaddasp vs14,vs50,vs1"
+func_check "xssubsp vs26,vs22,vs42"
+func_check "xsmaddmsp vs27,vs53,vs52"
+func_check "xsrsqrtesp vs8,vs59"
+func_check "xssqrtsp vs12,vs41"
+func_check "xsmulsp vs57,vs11,vs32"
+func_check "xsmsubasp vs38,vs20,vs26"
+func_check "xsdivsp vs26,vs19,vs6"
+func_check "xsmsubmsp vs35,vs37,vs55"
+func_check "xsresp  vs59,vs8"
+func_check "xsnmaddasp vs44,vs33,vs33"
+func_check "xsnmaddmsp vs17,vs62,vs30"
+func_check "xsnmsubasp vs54,vs52,vs31"
+func_check "xsnmsubmsp vs37,vs5,vs58"
+func_check "xxlorc  vs30,vs54,vs44"
+func_check "xxlnand vs49,vs14,vs29"
+func_check "xxleqv  vs62,vs22,vs30"
+func_check "xscvdpspn vs60,vs54"
+func_check "xsrsp   vs22,vs45"
+func_check "xscvuxdsp vs26,vs59"
+func_check "xscvsxdsp vs38,vs49"
+func_check "xscvspdpn vs59,vs26"
+func_check "fmrgow  f24,f14,f2"
+func_check "fmrgew  f22,f7,f5"
diff --git a/gdb/testsuite/gdb.arch/powerpc-vsx2.s b/gdb/testsuite/gdb.arch/powerpc-vsx2.s
new file mode 100644
index 0000000..c21759f
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-vsx2.s
@@ -0,0 +1,75 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7fced019    /* lxsiwzx vs62,r14,r26       */
+	.long  0x7d00c819    /* lxsiwzx vs40,0,r25         */
+	.long  0x7f20d098    /* lxsiwax vs25,0,r26         */
+	.long  0x7c601898    /* lxsiwax vs3,0,r3           */
+	.long  0x7fcc0066    /* mfvsrd  r12,vs30           */
+	.long  0x7fcc0066    /* mfvsrd  r12,vs30           */
+	.long  0x7fcc0067    /* mfvsrd  r12,vs62           */
+	.long  0x7fcc0067    /* mfvsrd  r12,vs62           */
+	.long  0x7d9400e6    /* mffprwz r20,f12            */
+	.long  0x7d9400e6    /* mffprwz r20,f12            */
+	.long  0x7d9500e7    /* mfvrwz  r21,v12            */
+	.long  0x7d9500e7    /* mfvrwz  r21,v12            */
+	.long  0x7dc97118    /* stxsiwx vs14,r9,r14        */
+	.long  0x7ea04118    /* stxsiwx vs21,0,r8          */
+	.long  0x7d7c0166    /* mtvsrd  vs11,r28           */
+	.long  0x7d7c0166    /* mtvsrd  vs11,r28           */
+	.long  0x7d7d0167    /* mtvsrd  vs43,r29           */
+	.long  0x7d7d0167    /* mtvsrd  vs43,r29           */
+	.long  0x7f1601a6    /* mtfprwa f24,r22            */
+	.long  0x7f1601a6    /* mtfprwa f24,r22            */
+	.long  0x7f3701a7    /* mtvrwa  v25,r23            */
+	.long  0x7f3701a7    /* mtvrwa  v25,r23            */
+	.long  0x7f5b01e6    /* mtfprwz f26,r27            */
+	.long  0x7f5b01e6    /* mtfprwz f26,r27            */
+	.long  0x7f7c01e7    /* mtvrwz  v27,r28            */
+	.long  0x7f7c01e7    /* mtvrwz  v27,r28            */
+	.long  0x7db36c18    /* lxsspx  vs13,r19,r13       */
+	.long  0x7e406c18    /* lxsspx  vs18,0,r13         */
+	.long  0x7d622519    /* stxsspx vs43,r2,r4         */
+	.long  0x7ee05d19    /* stxsspx vs55,0,r11         */
+	.long  0xf2d0c805    /* xsaddsp vs54,vs48,vs25     */
+	.long  0xf1d2080c    /* xsmaddasp vs14,vs50,vs1    */
+	.long  0xf3565042    /* xssubsp vs26,vs22,vs42     */
+	.long  0xf375a04e    /* xsmaddmsp vs27,vs53,vs52   */
+	.long  0xf100d82a    /* xsrsqrtesp vs8,vs59        */
+	.long  0xf180482e    /* xssqrtsp vs12,vs41         */
+	.long  0xf32b0083    /* xsmulsp vs57,vs11,vs32     */
+	.long  0xf0d4d089    /* xsmsubasp vs38,vs20,vs26   */
+	.long  0xf35330c0    /* xsdivsp vs26,vs19,vs6      */
+	.long  0xf065b8cf    /* xsmsubmsp vs35,vs37,vs55   */
+	.long  0xf3604069    /* xsresp  vs59,vs8           */
+	.long  0xf1810c0f    /* xsnmaddasp vs44,vs33,vs33  */
+	.long  0xf23ef44c    /* xsnmaddmsp vs17,vs62,vs30  */
+	.long  0xf2d4fc8d    /* xsnmsubasp vs54,vs52,vs31  */
+	.long  0xf0a5d4cb    /* xsnmsubmsp vs37,vs5,vs58   */
+	.long  0xf3d66556    /* xxlorc  vs30,vs54,vs44     */
+	.long  0xf22eed91    /* xxlnand vs49,vs14,vs29     */
+	.long  0xf3d6f5d1    /* xxleqv  vs62,vs22,vs30     */
+	.long  0xf380b42f    /* xscvdpspn vs60,vs54        */
+	.long  0xf2c06c66    /* xsrsp   vs22,vs45          */
+	.long  0xf340dca2    /* xscvuxdsp vs26,vs59        */
+	.long  0xf0c08ce3    /* xscvsxdsp vs38,vs49        */
+	.long  0xf360d52d    /* xscvspdpn vs59,vs26        */
+	.long  0xff0e168c    /* fmrgow  f24,f14,f2         */
+	.long  0xfec72f8c    /* fmrgew  f22,f7,f5          */
diff --git a/gdb/testsuite/gdb.arch/powerpc-vsx3.exp b/gdb/testsuite/gdb.arch/powerpc-vsx3.exp
new file mode 100644
index 0000000..24905d1
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-vsx3.exp
@@ -0,0 +1,181 @@
+# Copyright 2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Test PowerPC instructions disassembly.
+
+standard_testfile .s
+set objfile [standard_output_file ${testfile}.o]
+
+if {![istarget "powerpc*-*-*"]} then {
+    verbose "Skipping PowerPC instructions disassembly."
+    return
+}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
+    untested "PowerPC instructions disassembly"
+    return -1
+}
+
+clean_restart ${objfile}
+
+# Disassemble the function.
+
+gdb_test "set disassembler-cpu vsx"
+set test "disass func"
+gdb_test_multiple $test $test {
+    -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
+	set func $expect_out(1,string)
+	pass $test
+    }
+}
+
+proc instr_to_patt {instr} {
+    # 0x0000000000000018 <+24>:	stxvd2x vs43,r4,r5
+    return ".*\r\n\[ \t\]*0x\[0-9a-f\]+ <\\+\[0-9a-f\]*>:\[ \t\]*[string map [list { } "\[ \t\]+" . {\.}] $instr]\[ \t\]*\r\n.*"
+}
+
+proc func_check {instr} {
+    global func
+
+    set test "Found: $instr"
+    if [regexp -nocase -line [instr_to_patt $instr] $func] {
+	pass $test
+    } else {
+	fail $test
+    }
+}
+
+func_check "lxvx    vs34,r6,r25"
+func_check "lxvx    vs20,0,r10"
+func_check "lxvl    vs20,r24,r10"
+func_check "lxvl    vs54,0,r29"
+func_check "lxvll   vs24,r20,r19"
+func_check "lxvll   vs34,0,r14"
+func_check "mfvsrld r2,vs22"
+func_check "lxvwsx  vs58,r26,r25"
+func_check "lxvwsx  vs55,0,r29"
+func_check "stxvx   vs14,r21,r4"
+func_check "stxvx   vs30,0,r22"
+func_check "stxvl   vs0,r26,r4"
+func_check "stxvl   vs37,0,r22"
+func_check "mtvsrws vs24,r10"
+func_check "stxvll  vs30,r21,r15"
+func_check "stxvll  vs39,0,r14"
+func_check "mtvsrdd vs12,r6,r5"
+func_check "mtvsrdd vs38,0,r21"
+func_check "lxsibzx vs59,r28,r6"
+func_check "lxsibzx vs30,0,r8"
+func_check "lxvh8x  vs42,r23,r17"
+func_check "lxvh8x  vs36,0,r5"
+func_check "lxsihzx vs12,r9,r11"
+func_check "lxsihzx vs49,0,r13"
+func_check "lxvb16x vs37,r3,r19"
+func_check "lxvb16x vs0,0,r30"
+func_check "stxsibx vs2,r30,r6"
+func_check "stxsibx vs12,0,r13"
+func_check "stxvh8x vs16,r29,r8"
+func_check "stxvh8x vs55,0,r10"
+func_check "stxsihx vs34,r2,r23"
+func_check "stxsihx vs60,0,r23"
+func_check "stxvb16x vs23,r14,r12"
+func_check "stxvb16x vs19,0,r5"
+func_check "lxsd    v24,0\\(0\\)"
+func_check "lxsd    v15,16\\(r21\\)"
+func_check "lxssp   v6,0\\(0\\)"
+func_check "lxssp   v23,16\\(r9\\)"
+func_check "xscmpeqdp vs18,vs51,vs33"
+func_check "xscmpgtdp vs2,vs26,vs34"
+func_check "xscmpgedp vs5,vs26,vs20"
+func_check "xxperm  vs44,vs10,vs43"
+func_check "xxpermr vs41,vs20,vs5"
+func_check "xscmpexpdp cr4,vs18,vs55"
+func_check "xxextractuw vs23,vs37,3"
+func_check "xxspltib vs54,235"
+func_check "xxinsertw vs15,vs30,4"
+func_check "xsmaxcdp vs12,vs11,vs7"
+func_check "xsmincdp vs32,vs25,vs24"
+func_check "xsmaxjdp vs25,vs53,vs12"
+func_check "xststdcsp cr2,vs36,127"
+func_check "xsminjdp vs32,vs21,vs45"
+func_check "xsxexpdp r17,vs50"
+func_check "xsxsigdp r7,vs40"
+func_check "xscvhpdp vs54,vs34"
+func_check "xscvdphp vs58,vs54"
+func_check "xststdcdp cr0,vs38,127"
+func_check "xvtstdcsp vs56,vs53,127"
+func_check "xviexpsp vs54,vs20,vs52"
+func_check "xsiexpdp vs57,r28,r29"
+func_check "xvxexpdp vs1,vs20"
+func_check "xvxsigdp vs54,vs59"
+func_check "xxbrh   vs18,vs37"
+func_check "xvxexpsp vs14,vs1"
+func_check "xvxsigsp vs52,vs13"
+func_check "xxbrw   vs19,vs5"
+func_check "xxbrd   vs51,vs55"
+func_check "xvcvhpsp vs35,vs17"
+func_check "xvcvsphp vs15,vs45"
+func_check "xxbrq   vs17,vs31"
+func_check "xvtstdcdp vs16,vs12,127"
+func_check "xviexpdp vs27,vs9,vs8"
+func_check "lxv     vs4,0\\(0\\)"
+func_check "lxv     vs40,16\\(r20\\)"
+func_check "stxv    vs50,0\\(0\\)"
+func_check "stxv    vs8,16\\(r16\\)"
+func_check "stxsd   v3,0\\(0\\)"
+func_check "stxsd   v17,16\\(r2\\)"
+func_check "stxssp  v13,0\\(0\\)"
+func_check "stxssp  v17,16\\(r13\\)"
+func_check "xsaddqp v8,v10,v18"
+func_check "xsaddqpo v5,v1,v29"
+func_check "xsrqpi  0,v12,v18,3"
+func_check "xsrqpix 1,v31,v19,0"
+func_check "xsmulqp v14,v1,v6"
+func_check "xsmulqpo v17,v7,v27"
+func_check "xsrqpxp 0,v4,v11,0"
+func_check "xscpsgnqp v29,v23,v28"
+func_check "xscmpoqp cr7,v13,v27"
+func_check "xscmpexpqp cr5,v21,v6"
+func_check "xsmaddqp v2,v19,v4"
+func_check "xsmaddqpo v30,v7,v16"
+func_check "xsmsubqp v21,v30,v15"
+func_check "xsmsubqpo v12,v17,v30"
+func_check "xsnmaddqp v6,v30,v12"
+func_check "xsnmaddqpo v12,v22,v12"
+func_check "xsnmsubqp v10,v29,v27"
+func_check "xsnmsubqpo v29,v29,v13"
+func_check "xssubqp v19,v27,v4"
+func_check "xssubqpo v13,v8,v1"
+func_check "xsdivqp v8,v3,v27"
+func_check "xsdivqpo v24,v20,v27"
+func_check "xscmpuqp cr7,v14,v4"
+func_check "xststdcqp cr4,v2,127"
+func_check "xsabsqp v31,v22"
+func_check "xsxexpqp v25,v3"
+func_check "xsnabsqp v10,v28"
+func_check "xsnegqp v19,v31"
+func_check "xsxsigqp v11,v13"
+func_check "xssqrtqp v13,v14"
+func_check "xssqrtqpo v1,v27"
+func_check "xscvqpuwz v3,v7"
+func_check "xscvudqp v20,v18"
+func_check "xscvqpswz v29,v29"
+func_check "xscvsdqp v2,v28"
+func_check "xscvqpudz v23,v4"
+func_check "xscvqpdp v3,v20"
+func_check "xscvqpdpo v1,v3"
+func_check "xscvdpqp v19,v12"
+func_check "xscvqpsdz v13,v4"
+func_check "xsiexpqp v7,v24,v7"
diff --git a/gdb/testsuite/gdb.arch/powerpc-vsx3.s b/gdb/testsuite/gdb.arch/powerpc-vsx3.s
new file mode 100644
index 0000000..1ada3cc
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/powerpc-vsx3.s
@@ -0,0 +1,141 @@
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2016 Free Software Foundation, Inc.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+	.text
+	.globl func
+func:
+	.long  0x7c46ca19    /* lxvx    vs34,r6,r25        */
+	.long  0x7e805218    /* lxvx    vs20,0,r10         */
+	.long  0x7e98521a    /* lxvl    vs20,r24,r10       */
+	.long  0x7ec0ea1b    /* lxvl    vs54,0,r29         */
+	.long  0x7f149a5a    /* lxvll   vs24,r20,r19       */
+	.long  0x7c40725b    /* lxvll   vs34,0,r14         */
+	.long  0x7ec20266    /* mfvsrld r2,vs22            */
+	.long  0x7f5acad9    /* lxvwsx  vs58,r26,r25       */
+	.long  0x7ee0ead9    /* lxvwsx  vs55,0,r29         */
+	.long  0x7dd52318    /* stxvx   vs14,r21,r4        */
+	.long  0x7fc0b318    /* stxvx   vs30,0,r22         */
+	.long  0x7c1a231a    /* stxvl   vs0,r26,r4         */
+	.long  0x7ca0b31b    /* stxvl   vs37,0,r22         */
+	.long  0x7f0a0326    /* mtvsrws vs24,r10           */
+	.long  0x7fd57b5a    /* stxvll  vs30,r21,r15       */
+	.long  0x7ce0735b    /* stxvll  vs39,0,r14         */
+	.long  0x7d862b66    /* mtvsrdd vs12,r6,r5         */
+	.long  0x7cc0ab67    /* mtvsrdd vs38,0,r21         */
+	.long  0x7f7c361b    /* lxsibzx vs59,r28,r6        */
+	.long  0x7fc0461a    /* lxsibzx vs30,0,r8          */
+	.long  0x7d578e59    /* lxvh8x  vs42,r23,r17       */
+	.long  0x7c802e59    /* lxvh8x  vs36,0,r5          */
+	.long  0x7d895e5a    /* lxsihzx vs12,r9,r11        */
+	.long  0x7e206e5b    /* lxsihzx vs49,0,r13         */
+	.long  0x7ca39ed9    /* lxvb16x vs37,r3,r19        */
+	.long  0x7c00f6d8    /* lxvb16x vs0,0,r30          */
+	.long  0x7c5e371a    /* stxsibx vs2,r30,r6         */
+	.long  0x7d806f1a    /* stxsibx vs12,0,r13         */
+	.long  0x7e1d4758    /* stxvh8x vs16,r29,r8        */
+	.long  0x7ee05759    /* stxvh8x vs55,0,r10         */
+	.long  0x7c42bf5b    /* stxsihx vs34,r2,r23        */
+	.long  0x7f80bf5b    /* stxsihx vs60,0,r23         */
+	.long  0x7eee67d8    /* stxvb16x vs23,r14,r12      */
+	.long  0x7e602fd8    /* stxvb16x vs19,0,r5         */
+	.long  0xe7000002    /* lxsd    v24,0(0)           */
+	.long  0xe5f50012    /* lxsd    v15,16(r21)        */
+	.long  0xe4c00003    /* lxssp   v6,0(0)            */
+	.long  0xe6e90013    /* lxssp   v23,16(r9)         */
+	.long  0xf253081e    /* xscmpeqdp vs18,vs51,vs33   */
+	.long  0xf05a105a    /* xscmpgtdp vs2,vs26,vs34    */
+	.long  0xf0baa098    /* xscmpgedp vs5,vs26,vs20    */
+	.long  0xf18a58d3    /* xxperm  vs44,vs10,vs43     */
+	.long  0xf13429d1    /* xxpermr vs41,vs20,vs5      */
+	.long  0xf212b9da    /* xscmpexpdp cr4,vs18,vs55   */
+	.long  0xf2e32a96    /* xxextractuw vs23,vs37,3    */
+	.long  0xf2c75ad1    /* xxspltib vs54,235          */
+	.long  0xf1e4f2d4    /* xxinsertw vs15,vs30,4      */
+	.long  0xf18b3c00    /* xsmaxcdp vs12,vs11,vs7     */
+	.long  0xf019c441    /* xsmincdp vs32,vs25,vs24    */
+	.long  0xf3356484    /* xsmaxjdp vs25,vs53,vs12    */
+	.long  0xf17f24aa    /* xststdcsp cr2,vs36,127     */
+	.long  0xf0156cc3    /* xsminjdp vs32,vs21,vs45    */
+	.long  0xf220956e    /* xsxexpdp r17,vs50          */
+	.long  0xf0e1456e    /* xsxsigdp r7,vs40           */
+	.long  0xf2d0156f    /* xscvhpdp vs54,vs34         */
+	.long  0xf351b56f    /* xscvdphp vs58,vs54         */
+	.long  0xf07f35aa    /* xststdcdp cr0,vs38,127     */
+	.long  0xf31faeef    /* xvtstdcsp vs56,vs53,127    */
+	.long  0xf2d4a6c3    /* xviexpsp vs54,vs20,vs52    */
+	.long  0xf33cef2d    /* xsiexpdp vs57,r28,r29      */
+	.long  0xf020a76c    /* xvxexpdp vs1,vs20          */
+	.long  0xf2c1df6f    /* xvxsigdp vs54,vs59         */
+	.long  0xf2472f6e    /* xxbrh   vs18,vs37          */
+	.long  0xf1c80f6c    /* xvxexpsp vs14,vs1          */
+	.long  0xf2896f6d    /* xvxsigsp vs52,vs13         */
+	.long  0xf26f2f6c    /* xxbrw   vs19,vs5           */
+	.long  0xf277bf6f    /* xxbrd   vs51,vs55          */
+	.long  0xf0788f6d    /* xvcvhpsp vs35,vs17         */
+	.long  0xf1f96f6e    /* xvcvsphp vs15,vs45         */
+	.long  0xf23fff6c    /* xxbrq   vs17,vs31          */
+	.long  0xf21f67ec    /* xvtstdcdp vs16,vs12,127    */
+	.long  0xf36947c0    /* xviexpdp vs27,vs9,vs8      */
+	.long  0xf4800001    /* lxv     vs4,0(0)           */
+	.long  0xf5140019    /* lxv     vs40,16(r20)       */
+	.long  0xf640000d    /* stxv    vs50,0(0)          */
+	.long  0xf5100015    /* stxv    vs8,16(r16)        */
+	.long  0xf4600002    /* stxsd   v3,0(0)            */
+	.long  0xf6220012    /* stxsd   v17,16(r2)         */
+	.long  0xf5a00003    /* stxssp  v13,0(0)           */
+	.long  0xf62d0013    /* stxssp  v17,16(r13)        */
+	.long  0xfd0a9008    /* xsaddqp v8,v10,v18         */
+	.long  0xfca1e809    /* xsaddqpo v5,v1,v29         */
+	.long  0xfd80960a    /* xsrqpi  0,v12,v18,3        */
+	.long  0xffe1980b    /* xsrqpix 1,v31,v19,0        */
+	.long  0xfdc13048    /* xsmulqp v14,v1,v6          */
+	.long  0xfe27d849    /* xsmulqpo v17,v7,v27        */
+	.long  0xfc80584a    /* xsrqpxp 0,v4,v11,0         */
+	.long  0xffb7e0c8    /* xscpsgnqp v29,v23,v28      */
+	.long  0xff8dd908    /* xscmpoqp cr7,v13,v27       */
+	.long  0xfe953148    /* xscmpexpqp cr5,v21,v6      */
+	.long  0xfc532308    /* xsmaddqp v2,v19,v4         */
+	.long  0xffc78309    /* xsmaddqpo v30,v7,v16       */
+	.long  0xfebe7b48    /* xsmsubqp v21,v30,v15       */
+	.long  0xfd91f349    /* xsmsubqpo v12,v17,v30      */
+	.long  0xfcde6388    /* xsnmaddqp v6,v30,v12       */
+	.long  0xfd966389    /* xsnmaddqpo v12,v22,v12     */
+	.long  0xfd5ddbc8    /* xsnmsubqp v10,v29,v27      */
+	.long  0xffbd6bc9    /* xsnmsubqpo v29,v29,v13     */
+	.long  0xfe7b2408    /* xssubqp v19,v27,v4         */
+	.long  0xfda80c09    /* xssubqpo v13,v8,v1         */
+	.long  0xfd03dc48    /* xsdivqp v8,v3,v27          */
+	.long  0xff14dc49    /* xsdivqpo v24,v20,v27       */
+	.long  0xff8e2508    /* xscmpuqp cr7,v14,v4        */
+	.long  0xfe7f1588    /* xststdcqp cr4,v2,127       */
+	.long  0xffe0b648    /* xsabsqp v31,v22            */
+	.long  0xff221e48    /* xsxexpqp v25,v3            */
+	.long  0xfd48e648    /* xsnabsqp v10,v28           */
+	.long  0xfe70fe48    /* xsnegqp v19,v31            */
+	.long  0xfd726e48    /* xsxsigqp v11,v13           */
+	.long  0xfdbb7648    /* xssqrtqp v13,v14           */
+	.long  0xfc3bde49    /* xssqrtqpo v1,v27           */
+	.long  0xfc613e88    /* xscvqpuwz v3,v7            */
+	.long  0xfe829688    /* xscvudqp v20,v18           */
+	.long  0xffa9ee88    /* xscvqpswz v29,v29          */
+	.long  0xfc4ae688    /* xscvsdqp v2,v28            */
+	.long  0xfef12688    /* xscvqpudz v23,v4           */
+	.long  0xfc74a688    /* xscvqpdp v3,v20            */
+	.long  0xfc341e89    /* xscvqpdpo v1,v3            */
+	.long  0xfe766688    /* xscvdpqp v19,v12           */
+	.long  0xfdb92688    /* xscvqpsdz v13,v4           */
+	.long  0xfcf83ec8    /* xsiexpqp v7,v24,v7         */


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]