AArch64: Add missing CPSR flags
authorAlan Hayward <alan.hayward@arm.com>
Wed, 26 Jun 2019 14:48:12 +0000 (15:48 +0100)
committerAlan Hayward <alan.hayward@arm.com>
Wed, 26 Jun 2019 14:48:12 +0000 (15:48 +0100)
Add all the CPSR flags for Armv8.1-A through to Armv8.4-A.

In addition, document all the existing flags, and remove
the superfluous empty spaces.

gdb/ChangeLog:

* features/aarch64-core.c (create_feature_aarch64_core):
Regenerate.
* features/aarch64-core.xml: Add cpsr flags.

gdb/ChangeLog
gdb/features/aarch64-core.c
gdb/features/aarch64-core.xml

index 3e6a1704fbba7875d15b134a256d6661f6f5827c..04a9ebc1edc0c098b031b1f7a0726c3f9527524d 100644 (file)
@@ -1,3 +1,9 @@
+2019-06-26  Alan Hayward  <alan.hayward@arm.com>
+
+       * features/aarch64-core.c (create_feature_aarch64_core):
+       Regenerate.
+       * features/aarch64-core.xml: Add cpsr flags.
+
 2019-06-26  Alan Hayward  <alan.hayward@arm.com>
 
        * arm-tdep.c (arm_gnu_triplet_regexp): New function.
index cd3de02cbc122d0be4a2b30a806b259222b17519..c6e1910be07553e19d5c80bd6742896bdfe931cb 100644 (file)
@@ -12,16 +12,19 @@ create_feature_aarch64_core (struct target_desc *result, long regnum)
   tdesc_type_with_fields *type_with_fields;
   type_with_fields = tdesc_create_flags (feature, "cpsr_flags", 4);
   tdesc_add_flag (type_with_fields, 0, "SP");
-  tdesc_add_flag (type_with_fields, 1, "");
   tdesc_add_bitfield (type_with_fields, "EL", 2, 3);
   tdesc_add_flag (type_with_fields, 4, "nRW");
-  tdesc_add_flag (type_with_fields, 5, "");
   tdesc_add_flag (type_with_fields, 6, "F");
   tdesc_add_flag (type_with_fields, 7, "I");
   tdesc_add_flag (type_with_fields, 8, "A");
   tdesc_add_flag (type_with_fields, 9, "D");
+  tdesc_add_flag (type_with_fields, 12, "SSBS");
   tdesc_add_flag (type_with_fields, 20, "IL");
   tdesc_add_flag (type_with_fields, 21, "SS");
+  tdesc_add_flag (type_with_fields, 22, "PAN");
+  tdesc_add_flag (type_with_fields, 23, "UAO");
+  tdesc_add_flag (type_with_fields, 24, "DIT");
+  tdesc_add_flag (type_with_fields, 25, "TCO");
   tdesc_add_flag (type_with_fields, 28, "V");
   tdesc_add_flag (type_with_fields, 29, "C");
   tdesc_add_flag (type_with_fields, 30, "Z");
index 6c6b98552b43a27a3b5f789f2ea58ec2f3210d02..368798158903e5979912a26b9adce38ed3b0f3f0 100644 (file)
   <reg name="pc" bitsize="64" type="code_ptr"/>
 
   <flags id="cpsr_flags" size="4">
+    <!-- Stack Pointer.  -->
     <field name="SP" start="0" end="0"/>
-    <field name="" start="1" end="1"/>
+
+    <!-- Exception Level.  -->
     <field name="EL" start="2" end="3"/>
+    <!-- Execution state.  -->
     <field name="nRW" start="4" end="4"/>
-    <field name="" start="5" end="5"/>
+
+    <!-- FIQ interrupt mask.  -->
     <field name="F" start="6" end="6"/>
+    <!-- IRQ interrupt mask.  -->
     <field name="I" start="7" end="7"/>
+    <!-- SError interrupt mask.  -->
     <field name="A" start="8" end="8"/>
+    <!-- Debug exception mask.  -->
     <field name="D" start="9" end="9"/>
 
+    <!-- ARMv8.0-A: Speculative Store Bypass.  -->
+    <field name="SSBS" start="12" end="12"/>
+
+    <!-- Illegal Execution state.  -->
     <field name="IL" start="20" end="20"/>
+    <!-- Software Step.  -->
     <field name="SS" start="21" end="21"/>
+    <!-- ARMv8.1-A: Privileged Access Never.  -->
+    <field name="PAN" start="22" end="22"/>
+    <!-- ARMv8.2-A: User Access Override.  -->
+    <field name="UAO" start="23" end="23"/>
+    <!-- ARMv8.4-A: Data Independent Timing.  -->
+    <field name="DIT" start="24" end="24"/>
+    <!-- ARMv8.5-A: Tag Check Override.  -->
+    <field name="TCO" start="25" end="25"/>
 
+    <!-- Overflow Condition flag.  -->
     <field name="V" start="28" end="28"/>
+    <!-- Carry Condition flag.  -->
     <field name="C" start="29" end="29"/>
+    <!-- Zero Condition flag.  -->
     <field name="Z" start="30" end="30"/>
+    <!-- Negative Condition flag.  -->
     <field name="N" start="31" end="31"/>
   </flags>
   <reg name="cpsr" bitsize="32" type="cpsr_flags"/>