target: use bool for backup_working_area
[openocd.git] / src / target / arm_dpm.c
index ab9b50e2302a89fce24aed831dcec48c687a20db..9f3a444afc5dae407e5c8a03783ef666b02e7107 100644 (file)
@@ -63,6 +63,29 @@ static int dpm_mrc(struct target *target, int cpnum,
        return retval;
 }
 
+static int dpm_mrrc(struct target *target, int cpnum,
+       uint32_t op, uint32_t crm, uint64_t *value)
+{
+       struct arm *arm = target_to_arm(target);
+       struct arm_dpm *dpm = arm->dpm;
+       int retval;
+
+       retval = dpm->prepare(dpm);
+       if (retval != ERROR_OK)
+               return retval;
+
+       LOG_DEBUG("MRRC p%d, %d, r0, r1, c%d", cpnum,
+                (int)op, (int)crm);
+
+       /* read coprocessor register into R0, R1; return via DCC */
+       retval = dpm->instr_read_data_r0_r1(dpm,
+                       ARMV5_T_MRRC(cpnum, op, 0, 1, crm),
+                       value);
+
+       /* (void) */ dpm->finish(dpm);
+       return retval;
+}
+
 static int dpm_mcr(struct target *target, int cpnum,
        uint32_t op1, uint32_t op2, uint32_t crn, uint32_t crm,
        uint32_t value)
@@ -88,6 +111,29 @@ static int dpm_mcr(struct target *target, int cpnum,
        return retval;
 }
 
+static int dpm_mcrr(struct target *target, int cpnum,
+       uint32_t op, uint32_t crm, uint64_t value)
+{
+       struct arm *arm = target_to_arm(target);
+       struct arm_dpm *dpm = arm->dpm;
+       int retval;
+
+       retval = dpm->prepare(dpm);
+       if (retval != ERROR_OK)
+               return retval;
+
+       LOG_DEBUG("MCRR p%d, %d, r0, r1, c%d", cpnum,
+               (int)op, (int)crm);
+
+       /* read DCC into r0, r1; then write coprocessor register from R0, R1 */
+       retval = dpm->instr_write_data_r0_r1(dpm,
+                       ARMV5_T_MCRR(cpnum, op, 0, 1, crm), value);
+
+       /* (void) */ dpm->finish(dpm);
+
+       return retval;
+}
+
 /*----------------------------------------------------------------------*/
 
 /*
@@ -1070,6 +1116,8 @@ int arm_dpm_setup(struct arm_dpm *dpm)
        /* coprocessor access setup */
        arm->mrc = dpm_mrc;
        arm->mcr = dpm_mcr;
+       arm->mrrc = dpm_mrrc;
+       arm->mcrr = dpm_mcrr;
 
        /* breakpoint setup -- optional until it works everywhere */
        if (!target->type->add_breakpoint) {

Linking to existing account procedure

If you already have an account and want to add another login method you MUST first sign in with your existing account and then change URL to read https://review.openocd.org/login/?link to get to this page again but this time it'll work for linking. Thank you.

SSH host keys fingerprints

1024 SHA256:YKx8b7u5ZWdcbp7/4AeXNaqElP49m6QrwfXaqQGJAOk gerrit-code-review@openocd.zylin.com (DSA)
384 SHA256:jHIbSQa4REvwCFG4cq5LBlBLxmxSqelQPem/EXIrxjk gerrit-code-review@openocd.org (ECDSA)
521 SHA256:UAOPYkU9Fjtcao0Ul/Rrlnj/OsQvt+pgdYSZ4jOYdgs gerrit-code-review@openocd.org (ECDSA)
256 SHA256:A13M5QlnozFOvTllybRZH6vm7iSt0XLxbA48yfc2yfY gerrit-code-review@openocd.org (ECDSA)
256 SHA256:spYMBqEYoAOtK7yZBrcwE8ZpYt6b68Cfh9yEVetvbXg gerrit-code-review@openocd.org (ED25519)
+--[ED25519 256]--+
|=..              |
|+o..   .         |
|*.o   . .        |
|+B . . .         |
|Bo. = o S        |
|Oo.+ + =         |
|oB=.* = . o      |
| =+=.+   + E     |
|. .=o   . o      |
+----[SHA256]-----+
2048 SHA256:0Onrb7/PHjpo6iVZ7xQX2riKN83FJ3KGU0TvI0TaFG4 gerrit-code-review@openocd.zylin.com (RSA)