From: Oleksij Rempel Date: Tue, 21 Jan 2014 19:48:14 +0000 (+0100) Subject: mips32.c: fix IB and DB bits check for EJTAG v2.0 X-Git-Tag: v0.9.0-rc1~310 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=c13ca4de40d510c7d88d8ce7a43065e8f9209c65;p=openocd mips32.c: fix IB and DB bits check for EJTAG v2.0 Change-Id: I4e28dddc1d5d9c2b923ae17beacdd7f73591b1d0 Signed-off-by: Oleksij Rempel Reviewed-on: http://openocd.zylin.com/1931 Tested-by: jenkins Reviewed-by: Spencer Oliver --- diff --git a/src/target/mips32.c b/src/target/mips32.c index b05a5631..795efddf 100644 --- a/src/target/mips32.c +++ b/src/target/mips32.c @@ -536,10 +536,15 @@ int mips32_configure_break_unit(struct target *target) if (retval != ERROR_OK) return retval; - /* EJTAG 2.0 does not specify EJTAG_DCR_IB and EJTAG_DCR_DB bits, - * assume IB and DB registers are always present. */ - if (ejtag_info->ejtag_version == EJTAG_VERSION_20) - dcr |= EJTAG_DCR_IB | EJTAG_DCR_DB; + /* EJTAG 2.0 defines IB and DB bits in IMP instead of DCR. + * Since these DCR bits should be reserved on EJTAG 2.0, we can + * just remap them. */ + if (ejtag_info->ejtag_version == EJTAG_VERSION_20) { + if (!(ejtag_info->impcode & EJTAG_V20_IMP_NOIB)) + dcr |= EJTAG_DCR_IB; + if (!(ejtag_info->impcode & EJTAG_V20_IMP_NODB)) + dcr |= EJTAG_DCR_DB; + } if (dcr & EJTAG_DCR_IB) { retval = mips32_configure_ibs(target);