mirror of
				https://gitlab.com/qemu-project/qemu.git
				synced 2025-10-30 07:57:14 +08:00 
			
		
		
		
	 63070ce368
			
		
	
	63070ce368
	
	
	
		
			
			Update aarch64-core.xml to include field definitions for PSTATE, which in gdb is modelled in the cpsr (current program status register) pseudo-register, named after the actual cpsr register in armv7. Defining the fields layout of the register allows easy inspection of for example, the current exception level (EL): For example. Before booting a Linux guest, EL=2, but after booting and Ctrl-C'ing in gdb, we get EL=0: (gdb) info registers $cpsr cpsr 0x20402009 [ SP EL=2 BTYPE=0 PAN C ] (gdb) cont Continuing. ^C Thread 2 received signal SIGINT, Interrupt. 0x0000ffffaaff286c in ?? () (gdb) info registers $cpsr cpsr 0x20001000 [ EL=0 BTYPE=0 SSBS C ] The aarch64-core.xml has been updated to match exactly the version retrieved from upstream gdb, retrieved in 2025-05-19 from HEAD commit 9f4dc0b137c86f6ff2098cb1ab69442c69d6023d. Link: https://sourceware.org/git/?p=binutils-gdb.git;a=blob;f=gdb/features/aarch64-core.xml;h=b8046510b9a085d30463d37b3ecc8d435f5fb7a4;hb=HEAD Signed-off-by: Manos Pitsidianakis <manos.pitsidianakis@linaro.org> Message-Id: <20250519-gdbstub-aarch64-pstate-xml-v1-1-b4dbe87fe7c6@linaro.org> [AJB: expanded upstream link] Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Message-ID: <20250603110204.838117-18-alex.bennee@linaro.org>
		
			
				
	
	
		
			95 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
| <?xml version="1.0"?>
 | |
| <!-- Copyright (C) 2009-2025 Free Software Foundation, Inc.
 | |
|      Contributed by ARM Ltd.
 | |
| 
 | |
|      Copying and distribution of this file, with or without modification,
 | |
|      are permitted in any medium without royalty provided the copyright
 | |
|      notice and this notice are preserved.  -->
 | |
| 
 | |
| <!DOCTYPE feature SYSTEM "gdb-target.dtd">
 | |
| <feature name="org.gnu.gdb.aarch64.core">
 | |
|   <reg name="x0" bitsize="64"/>
 | |
|   <reg name="x1" bitsize="64"/>
 | |
|   <reg name="x2" bitsize="64"/>
 | |
|   <reg name="x3" bitsize="64"/>
 | |
|   <reg name="x4" bitsize="64"/>
 | |
|   <reg name="x5" bitsize="64"/>
 | |
|   <reg name="x6" bitsize="64"/>
 | |
|   <reg name="x7" bitsize="64"/>
 | |
|   <reg name="x8" bitsize="64"/>
 | |
|   <reg name="x9" bitsize="64"/>
 | |
|   <reg name="x10" bitsize="64"/>
 | |
|   <reg name="x11" bitsize="64"/>
 | |
|   <reg name="x12" bitsize="64"/>
 | |
|   <reg name="x13" bitsize="64"/>
 | |
|   <reg name="x14" bitsize="64"/>
 | |
|   <reg name="x15" bitsize="64"/>
 | |
|   <reg name="x16" bitsize="64"/>
 | |
|   <reg name="x17" bitsize="64"/>
 | |
|   <reg name="x18" bitsize="64"/>
 | |
|   <reg name="x19" bitsize="64"/>
 | |
|   <reg name="x20" bitsize="64"/>
 | |
|   <reg name="x21" bitsize="64"/>
 | |
|   <reg name="x22" bitsize="64"/>
 | |
|   <reg name="x23" bitsize="64"/>
 | |
|   <reg name="x24" bitsize="64"/>
 | |
|   <reg name="x25" bitsize="64"/>
 | |
|   <reg name="x26" bitsize="64"/>
 | |
|   <reg name="x27" bitsize="64"/>
 | |
|   <reg name="x28" bitsize="64"/>
 | |
|   <reg name="x29" bitsize="64"/>
 | |
|   <reg name="x30" bitsize="64"/>
 | |
|   <reg name="sp" bitsize="64" type="data_ptr"/>
 | |
| 
 | |
|   <reg name="pc" bitsize="64" type="code_ptr"/>
 | |
| 
 | |
|   <flags id="cpsr_flags" size="4">
 | |
|     <!-- Stack Pointer.  -->
 | |
|     <field name="SP" start="0" end="0"/>
 | |
| 
 | |
|     <!-- Exception Level.  -->
 | |
|     <field name="EL" start="2" end="3"/>
 | |
|     <!-- Execution state.  -->
 | |
|     <field name="nRW" start="4" end="4"/>
 | |
| 
 | |
|     <!-- 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.5-A: Branch Target Identification BTYPE.  -->
 | |
|     <field name="BTYPE" start="10" end="11"/>
 | |
| 
 | |
|     <!-- 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"/>
 | |
| 
 | |
| </feature>
 |