Blame SOURCES/gdb-rhbz1320945-power9-28of38.patch

a094f6
commit e43de63c8fd11a15d7c6c852747c81664c0beb2a
a094f6
Author: Alan Modra <amodra@gmail.com>
a094f6
Date:   Thu May 19 00:10:35 2016 +0930
a094f6
a094f6
    Fix powerpc subis range
a094f6
    
a094f6
            * ppc-opc.c: Formatting.
a094f6
            (NSISIGNOPT): Define.
a094f6
            (powerpc_opcodes <subis>): Use NSISIGNOPT.
a094f6
a094f6
### a/opcodes/ChangeLog
a094f6
### b/opcodes/ChangeLog
a094f6
## -1,3 +1,9 @@
a094f6
+2016-05-19  Alan Modra  <amodra@gmail.com>
a094f6
+
a094f6
+	* ppc-opc.c: Formatting.
a094f6
+	(NSISIGNOPT): Define.
a094f6
+	(powerpc_opcodes <subis>): Use NSISIGNOPT.
a094f6
+
a094f6
 2016-05-18  Maciej W. Rozycki  <macro@imgtec.com>
a094f6
 
a094f6
 	* mips-dis.c (is_compressed_mode_p): Add `micromips_p' operand,
a094f6
--- a/opcodes/ppc-opc.c
a094f6
+++ b/opcodes/ppc-opc.c
a094f6
@@ -186,25 +186,25 @@ const struct powerpc_operand powerpc_operands[] =
a094f6
      This sets the y bit of the BO field appropriately.  */
a094f6
 #define BDM BDA + 1
a094f6
   { 0xfffc, 0, insert_bdm, extract_bdm,
a094f6
-      PPC_OPERAND_RELATIVE | PPC_OPERAND_SIGNED },
a094f6
+    PPC_OPERAND_RELATIVE | PPC_OPERAND_SIGNED },
a094f6
 
a094f6
   /* The BD field in a B form instruction when the - modifier is used
a094f6
      and absolute address is used.  */
a094f6
 #define BDMA BDM + 1
a094f6
   { 0xfffc, 0, insert_bdm, extract_bdm,
a094f6
-      PPC_OPERAND_ABSOLUTE | PPC_OPERAND_SIGNED },
a094f6
+    PPC_OPERAND_ABSOLUTE | PPC_OPERAND_SIGNED },
a094f6
 
a094f6
   /* The BD field in a B form instruction when the + modifier is used.
a094f6
      This sets the y bit of the BO field appropriately.  */
a094f6
 #define BDP BDMA + 1
a094f6
   { 0xfffc, 0, insert_bdp, extract_bdp,
a094f6
-      PPC_OPERAND_RELATIVE | PPC_OPERAND_SIGNED },
a094f6
+    PPC_OPERAND_RELATIVE | PPC_OPERAND_SIGNED },
a094f6
 
a094f6
   /* The BD field in a B form instruction when the + modifier is used
a094f6
      and absolute addressing is used.  */
a094f6
 #define BDPA BDP + 1
a094f6
   { 0xfffc, 0, insert_bdp, extract_bdp,
a094f6
-      PPC_OPERAND_ABSOLUTE | PPC_OPERAND_SIGNED },
a094f6
+    PPC_OPERAND_ABSOLUTE | PPC_OPERAND_SIGNED },
a094f6
 
a094f6
   /* The BF field in an X or XL form instruction.  */
a094f6
 #define BF BDPA + 1
a094f6
@@ -414,7 +414,8 @@ const struct powerpc_operand powerpc_operands[] =
a094f6
 
a094f6
   /* Power4 version for mfcr.  */
a094f6
 #define FXM4 FXM + 1
a094f6
-  { 0xff, 12, insert_fxm, extract_fxm, PPC_OPERAND_OPTIONAL | PPC_OPERAND_OPTIONAL_VALUE},
a094f6
+  { 0xff, 12, insert_fxm, extract_fxm,
a094f6
+    PPC_OPERAND_OPTIONAL | PPC_OPERAND_OPTIONAL_VALUE},
a094f6
   /* If the FXM4 operand is ommitted, use the sentinel value -1.  */
a094f6
   { -1, -1, NULL, NULL, 0},
a094f6
 
a094f6
@@ -493,10 +494,16 @@ const struct powerpc_operand powerpc_operands[] =
a094f6
      SI field, only negated.  */
a094f6
 #define NSI NBI + 1
a094f6
   { 0xffff, 0, insert_nsi, extract_nsi,
a094f6
-      PPC_OPERAND_NEGATIVE | PPC_OPERAND_SIGNED },
a094f6
+    PPC_OPERAND_NEGATIVE | PPC_OPERAND_SIGNED },
a094f6
+
a094f6
+  /* The NSI field in a D form instruction when we accept a wide range
a094f6
+     of positive values.  */
a094f6
+#define NSISIGNOPT NSI + 1
a094f6
+  { 0xffff, 0, NULL, NULL,
a094f6
+    PPC_OPERAND_NEGATIVE | PPC_OPERAND_SIGNED | PPC_OPERAND_SIGNOPT },
a094f6
 
a094f6
   /* The RA field in an D, DS, DQ, X, XO, M, or MDS form instruction.  */
a094f6
-#define RA NSI + 1
a094f6
+#define RA NSISIGNOPT + 1
a094f6
 #define RA_MASK (0x1f << 16)
a094f6
   { 0x1f, 16, NULL, NULL, PPC_OPERAND_GPR },
a094f6
 
a094f6
@@ -601,7 +608,7 @@ const struct powerpc_operand powerpc_operands[] =
a094f6
      SCLSCI8 field, only negated.  */
a094f6
 #define SCLSCI8N SCLSCI8 + 1
a094f6
   { 0xffffffff, PPC_OPSHIFT_INV, insert_sci8n, extract_sci8n,
a094f6
-      PPC_OPERAND_NEGATIVE | PPC_OPERAND_SIGNED },
a094f6
+    PPC_OPERAND_NEGATIVE | PPC_OPERAND_SIGNED },
a094f6
 
a094f6
   /* The SD field of the SD4 form instruction.  */
a094f6
 #define SE_SD SCLSCI8N + 1
a094f6
@@ -690,7 +697,8 @@ const struct powerpc_operand powerpc_operands[] =
a094f6
   /* The TBR field in an XFX form instruction.  This is like the SPR
a094f6
      field, but it is optional.  */
a094f6
 #define TBR SV + 1
a094f6
-  { 0x3ff, 11, insert_tbr, extract_tbr, PPC_OPERAND_OPTIONAL | PPC_OPERAND_OPTIONAL_VALUE},
a094f6
+  { 0x3ff, 11, insert_tbr, extract_tbr,
a094f6
+    PPC_OPERAND_OPTIONAL | PPC_OPERAND_OPTIONAL_VALUE},
a094f6
   /* If the TBR operand is ommitted, use the value 268.  */
a094f6
   { -1, 268, NULL, NULL, 0},
a094f6
 
a094f6
@@ -874,12 +882,12 @@ const struct powerpc_operand powerpc_operands[] =
a094f6
   /* The VLESIMM field in a D form instruction.  */
a094f6
 #define VLESIMM URC + 1
a094f6
   { 0xffff, PPC_OPSHIFT_INV, insert_vlesi, extract_vlesi,
a094f6
-      PPC_OPERAND_SIGNED | PPC_OPERAND_SIGNOPT },
a094f6
+    PPC_OPERAND_SIGNED | PPC_OPERAND_SIGNOPT },
a094f6
 
a094f6
   /* The VLENSIMM field in a D form instruction.  */
a094f6
 #define VLENSIMM VLESIMM + 1
a094f6
   { 0xffff, PPC_OPSHIFT_INV, insert_vlensi, extract_vlensi,
a094f6
-      PPC_OPERAND_NEGATIVE | PPC_OPERAND_SIGNED | PPC_OPERAND_SIGNOPT },
a094f6
+    PPC_OPERAND_NEGATIVE | PPC_OPERAND_SIGNED | PPC_OPERAND_SIGNOPT },
a094f6
 
a094f6
   /* The VLEUIMM field in a D form instruction.  */
a094f6
 #define VLEUIMM VLENSIMM + 1
a094f6
@@ -3878,7 +3886,7 @@ const struct powerpc_opcode powerpc_opcodes[] = {
a094f6
 {"liu",		OP(15),		DRA_MASK,    PWRCOM,	PPCNONE,	{RT, SISIGNOPT}},
a094f6
 {"addis",	OP(15),		OP_MASK,     PPCCOM,	PPCNONE,	{RT, RA0, SISIGNOPT}},
a094f6
 {"cau",		OP(15),		OP_MASK,     PWRCOM,	PPCNONE,	{RT, RA0, SISIGNOPT}},
a094f6
-{"subis",	OP(15),		OP_MASK,     PPCCOM,	PPCNONE,	{RT, RA0, NSI}},
a094f6
+{"subis",	OP(15),		OP_MASK,     PPCCOM,	PPCNONE,	{RT, RA0, NSISIGNOPT}},
a094f6
 
a094f6
 {"bdnz-",    BBO(16,BODNZ,0,0),		BBOATBI_MASK,  PPCCOM,	 PPCNONE,	{BDM}},
a094f6
 {"bdnz+",    BBO(16,BODNZ,0,0),		BBOATBI_MASK,  PPCCOM,	 PPCNONE,	{BDP}},