arm_opcode: Add support for ARM MCRR/MRRC
Add support for the ARM MCRR/MRRC instructions which require the use of two registers to transfer a 64-bit co-processor registers. We are going to use this in a subsequent patch in order to properly dump 64-bit page table descriptors that exist on ARMv7A with VMSA extensions. We make use of r0 and r1 to transfer 64-bit quantities to/from DCC. Change-Id: Ic4975026c1ae4f2853795575ac7701d541248736 Signed-off-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: Michael Chalfant <michael.chalfant@gmail.com> Reviewed-on: https://review.openocd.org/c/openocd/+/5228 Tested-by: jenkins Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com>
This commit is contained in:
committed by
Antonio Borneo
parent
1bc4182ceb
commit
d27a3a00b8
@@ -231,12 +231,22 @@ struct arm {
|
||||
uint32_t crn, uint32_t crm,
|
||||
uint32_t *value);
|
||||
|
||||
/** Read coprocessor to two registers. */
|
||||
int (*mrrc)(struct target *target, int cpnum,
|
||||
uint32_t op, uint32_t crm,
|
||||
uint64_t *value);
|
||||
|
||||
/** Write coprocessor register. */
|
||||
int (*mcr)(struct target *target, int cpnum,
|
||||
uint32_t op1, uint32_t op2,
|
||||
uint32_t crn, uint32_t crm,
|
||||
uint32_t value);
|
||||
|
||||
/** Write coprocessor from two registers. */
|
||||
int (*mcrr)(struct target *target, int cpnum,
|
||||
uint32_t op, uint32_t crm,
|
||||
uint64_t value);
|
||||
|
||||
void *arch_info;
|
||||
|
||||
/** For targets conforming to ARM Debug Interface v5,
|
||||
|
||||
Reference in New Issue
Block a user